-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathqueue.c
88 lines (74 loc) · 3 KB
/
queue.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#include "queue.h"
#include <Library/UefiLib.h>
BOOLEAN list_empty(
Queue *queue
)
{
return NULL == queue->front;
}
VOID list_dump(
Queue *queue
)
{
Print(L"Queue dump: %x\r\n", queue);
if (list_empty(queue))
return;
Node *current = (Node *)queue->front;
while (NULL != current) {
Print(L"Current node: %x\r\n", ((UINT64 *)(current->item))[0]);
current = current->previous;
}
}
VOID list_dump_broken(
Queue *queue
)
{
Print(L"Queue broken dump: %x\r\n", queue);
UINT64 *current = list_dequeue(queue);
while (NULL != current) {
if (NULL != current) {
Print(L"Current node: %x\r\n", current);
for (int i = 0; i < 4; ++i) {
Print(L"%x ", current[i]);
}
Print(L"\r\n");
}
// Print(L"Current node: %x\r\n", ((UINT64 *)(current->item))[0]);
current = list_dequeue(queue);
}
}
Queue *list_create()
{
Queue *queue = AllocatePool(sizeof(Queue));
queue->front = NULL;
return queue;
}
VOID list_enqueue(
Queue *queue,
VOID *item
)
/*
Put at the back of the queue
*/
{
Node *node = AllocatePool(sizeof(Node));
node->item = item;
node->previous = queue->front;
queue->front = node;
}
VOID *list_dequeue(
Queue *queue
)
/*
Pop an element at the front of the queue
*/
{
if (NULL == queue->front)
return NULL;
VOID *item = queue->front->item;
Node *previous = queue->front->previous;
FreePool(queue->front);
queue->front = previous;
// Print(L"...%x%x", item, previous);
return item;
}