Changeset 99c2c69e in mainline for kernel/generic/include/adt
- Timestamp:
- 2013-09-13T00:36:30Z (12 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 67fbd5e
- Parents:
- 7f84430 (diff), 11d41be5 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)links above to see all the changes relative to each parent. - Location:
- kernel/generic/include/adt
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/generic/include/adt/bitmap.h
r7f84430 r99c2c69e 38 38 #include <typedefs.h> 39 39 40 #define BITS2BYTES(bits) (bits ? ((((bits)-1)>>3)+1) : 0) 40 #define BITMAP_ELEMENT 8 41 #define BITMAP_REMAINER 7 41 42 42 43 typedef struct { 43 uint8_t *map; 44 size_t bits; 44 size_t elements; 45 uint8_t *bits; 46 size_t next_fit; 45 47 } bitmap_t; 46 48 47 extern void bitmap_initialize(bitmap_t *bitmap, uint8_t *map, size_t bits); 48 extern void bitmap_set_range(bitmap_t *bitmap, size_t start, size_t bits); 49 extern void bitmap_clear_range(bitmap_t *bitmap, size_t start, size_t bits); 50 extern void bitmap_copy(bitmap_t *dst, bitmap_t *src, size_t bits); 49 static inline void bitmap_set(bitmap_t *bitmap, size_t element, 50 unsigned int value) 51 { 52 if (element >= bitmap->elements) 53 return; 54 55 size_t byte = element / BITMAP_ELEMENT; 56 uint8_t mask = 1 << (element & BITMAP_REMAINER); 57 58 if (value) { 59 bitmap->bits[byte] |= mask; 60 } else { 61 bitmap->bits[byte] &= ~mask; 62 bitmap->next_fit = byte; 63 } 64 } 51 65 52 static inline int bitmap_get(bitmap_t *bitmap, size_t bit)66 static inline unsigned int bitmap_get(bitmap_t *bitmap, size_t element) 53 67 { 54 if (bit >= bitmap->bits)68 if (element >= bitmap->elements) 55 69 return 0; 56 70 57 return !! ((bitmap->map)[bit/8] & (1 << (bit & 7))); 71 size_t byte = element / BITMAP_ELEMENT; 72 uint8_t mask = 1 << (element & BITMAP_REMAINER); 73 74 return !!((bitmap->bits)[byte] & mask); 58 75 } 59 76 77 extern size_t bitmap_size(size_t); 78 extern void bitmap_initialize(bitmap_t *, size_t, void *); 79 80 extern void bitmap_set_range(bitmap_t *, size_t, size_t); 81 extern void bitmap_clear_range(bitmap_t *, size_t, size_t); 82 83 extern int bitmap_allocate_range(bitmap_t *, size_t, size_t, size_t, size_t, 84 size_t *); 85 extern void bitmap_copy(bitmap_t *, bitmap_t *, size_t); 60 86 61 87 #endif -
kernel/generic/include/adt/list.h
r7f84430 r99c2c69e 1 1 /* 2 2 * Copyright (c) 2001-2004 Jakub Jermar 3 * Copyright (c) 201 1Jiri Svoboda3 * Copyright (c) 2013 Jiri Svoboda 4 4 * All rights reserved. 5 5 * … … 65 65 66 66 #define list_get_instance(link, type, member) \ 67 ((type *) (((void *)(link)) - ((void *) &(((type *) NULL)->member)))) 68 69 #define list_foreach(list, iterator) \ 70 for (link_t *iterator = (list).head.next; \ 71 iterator != &(list).head; iterator = iterator->next) 67 ((type *) (((void *)(link)) - list_link_to_void(&(((type *) NULL)->member)))) 68 69 #define list_foreach(list, member, itype, iterator) \ 70 for (itype *iterator = NULL; iterator == NULL; iterator = (itype *) 1) \ 71 for (link_t *_link = (list).head.next; \ 72 iterator = list_get_instance(_link, itype, member), \ 73 _link != &(list).head; _link = _link->next) 72 74 73 75 #define assert_link_not_used(link) \ … … 204 206 } 205 207 208 /** Get next item in list. 209 * 210 * @param link Current item link 211 * @param list List containing @a link 212 * 213 * @return Next item or NULL if @a link is the last item. 214 */ 215 static inline link_t *list_next(link_t *link, const list_t *list) 216 { 217 return (link->next == &list->head) ? NULL : link->next; 218 } 219 220 /** Get previous item in list. 221 * 222 * @param link Current item link 223 * @param list List containing @a link 224 * 225 * @return Previous item or NULL if @a link is the first item. 226 */ 227 static inline link_t *list_prev(link_t *link, const list_t *list) 228 { 229 return (link->prev == &list->head) ? NULL : link->prev; 230 } 231 206 232 /** Split or concatenate headless doubly-linked circular list 207 233 * … … 270 296 { 271 297 unsigned int cnt = 0; 272 273 list_foreach(*list, link) { 298 link_t *link; 299 300 link = list_first(list); 301 while (link != NULL) { 274 302 if (cnt == n) 275 303 return link; 276 304 277 305 cnt++; 306 link = list_next(link, list); 278 307 } 279 308 280 309 return NULL; 310 } 311 312 /** Verify that argument type is a pointer to link_t (at compile time). 313 * 314 * This can be used to check argument type in a macro. 315 */ 316 static inline const void *list_link_to_void(const link_t *link) 317 { 318 return link; 281 319 } 282 320
Note:
See TracChangeset
for help on using the changeset viewer.
