Ignore generated files.
[pintos-anon] / src / lib / bitmap.h
1 #ifndef HEADER_BITMAP_H
2 #define HEADER_BITMAP_H 1
3
4 #include <stdbool.h>
5 #include <stddef.h>
6
7 struct bitmap
8   {
9     size_t bit_cnt;
10     elem_type *bits;
11   };
12
13 void bitmap_init (struct bitmap *, size_t bit_cnt);
14 void bitmap_destroy (struct bitmap *);
15
16 size_t bitmap_size (const struct bitmap *);
17
18 void bitmap_set (struct bitmap *, size_t idx, bool);
19 void bitmap_set_all (struct bitmap *, bool);
20
21 void bitmap_mark (struct bitmap *, size_t idx);
22 void bitmap_reset (struct bitmap *, size_t idx);
23 void bitmap_flip (struct bitmap *, size_t idx);
24
25 bool bitmap_test (const struct bitmap *, size_t idx);
26
27 #define BITMAP_ERROR ((size_t) -1)
28 size_t bitmap_scan (const struct bitmap *, bool);
29 size_t bitmap_find_and_set (struct bitmap *);
30 size_t bitmap_find_and_clear (struct bitmap *);
31
32 size_t bitmap_set_cnt (const struct bitmap *);
33 bool bitmap_clear_cnt (const struct bitmap *);
34
35 bool bitmap_any (const struct bitmap *);
36 bool bitmap_none (const struct bitmap *);
37 bool bitmap_all (const struct bitmap *);
38
39 #endif /* bitmap.h */