X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?p=palacios.git;a=blobdiff_plain;f=geekos%2Fsrc%2Fgeekos%2Fqueue.c;fp=geekos%2Fsrc%2Fgeekos%2Fqueue.c;h=ed1a664ff4ca129a637ec8aad312bda1be1e90ef;hp=0000000000000000000000000000000000000000;hb=ddc16b0737cf58f7aa90a69c6652cdf4090aec51;hpb=626595465a2c6987606a6bc697df65130ad8c2d3 diff --git a/geekos/src/geekos/queue.c b/geekos/src/geekos/queue.c new file mode 100644 index 0000000..ed1a664 --- /dev/null +++ b/geekos/src/geekos/queue.c @@ -0,0 +1,58 @@ +/* + * This file is part of the Palacios Virtual Machine Monitor developed + * by the V3VEE Project with funding from the United States National + * Science Foundation and the Department of Energy. + * + * The V3VEE Project is a joint project between Northwestern University + * and the University of New Mexico. You can find out more at + * http://www.v3vee.org + * + * Copyright (c) 2008, Jack Lange + * Copyright (c) 2008, The V3VEE Project + * All rights reserved. + * + * Author: Jack Lange + * + * This is free software. You are permitted to use, + * redistribute, and modify it as specified in the file "V3VEE_LICENSE". + */ + +#include + + + +void init_queue(struct gen_queue * queue) { + queue->num_entries = 0; + INIT_LIST_HEAD(&(queue->entries)); +} + + +struct gen_queue * create_queue() { + struct gen_queue * tmp_queue = Malloc(sizeof(struct gen_queue)); + init_queue(tmp_queue); + return tmp_queue; +} + +void enqueue(struct gen_queue * queue, void * entry) { + struct queue_entry * q_entry = Malloc(sizeof(struct queue_entry)); + + q_entry->entry = entry; + list_add_tail(&(q_entry->entry_list), &(queue->entries)); + queue->num_entries++; +} + + +void * dequeue(struct gen_queue * queue) { + void * entry_val = 0; + + if (!list_empty(&(queue->entries))) { + struct list_head * q_entry = queue->entries.next; + struct queue_entry * tmp_entry = list_entry(q_entry, struct queue_entry, entry_list); + + entry_val = tmp_entry->entry; + list_del(q_entry); + Free(tmp_entry); + } + + return entry_val; +}