blob: 2e08e564b7df242a16b79b3c537b1acddd0edd34 (
plain)
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
|
#ifndef _QUEUE_H_
#define _QUEUE_H_
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include "linux_list.h"
struct queue {
size_t max_size;
size_t cur_size;
unsigned int num_elems;
struct list_head head;
};
struct queue_node {
struct list_head head;
size_t size;
char data[0];
};
struct queue *queue_create(size_t max_size);
void queue_destroy(struct queue *b);
unsigned int queue_len(const struct queue *b);
int queue_add(struct queue *b, const void *data, size_t size);
void queue_del(struct queue *b, void *data);
void queue_iterate(struct queue *b,
const void *data,
int (*iterate)(void *data1, void *data2));
#endif
|