Changeset 55b77d9 in mainline for kernel/generic/include
- Timestamp:
- 2011-06-17T20:39:16Z (14 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 8f164724
- Parents:
- 98caf49
- Location:
- kernel/generic/include
- Files:
-
- 13 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/generic/include/adt/btree.h
r98caf49 r55b77d9 89 89 typedef struct { 90 90 btree_node_t *root; /**< B-tree root node pointer. */ 91 li nk_t leaf_head; /**< Leaf-level list head. */91 list_t leaf_list; /**< List of leaves. */ 92 92 } btree_t; 93 93 -
kernel/generic/include/adt/hash_table.h
r98caf49 r55b77d9 68 68 /** Hash table structure. */ 69 69 typedef struct { 70 li nk_t *entry;70 list_t *entry; 71 71 size_t entries; 72 72 size_t max_keys; -
kernel/generic/include/adt/list.h
r98caf49 r55b77d9 1 1 /* 2 2 * Copyright (c) 2001-2004 Jakub Jermar 3 * Copyright (c) 2011 Jiri Svoboda 3 4 * All rights reserved. 4 5 * … … 39 40 #include <trace.h> 40 41 41 /** Doubly linked list head and link type. */42 /** Doubly linked list link. */ 42 43 typedef struct link { 43 44 struct link *prev; /**< Pointer to the previous item in the list. */ … … 45 46 } link_t; 46 47 48 /** Doubly linked list. */ 49 typedef struct list { 50 link_t head; /**< List head. Does not have any data. */ 51 } list_t; 52 47 53 /** Declare and initialize statically allocated list. 48 54 * … … 51 57 */ 52 58 #define LIST_INITIALIZE(name) \ 53 link_t name = { \ 54 .prev = &name, \ 55 .next = &name \ 59 list_t name = { \ 60 .head = { \ 61 .prev = &(name).head, \ 62 .next = &(name).head \ 63 } \ 56 64 } 57 65 … … 60 68 61 69 #define list_foreach(list, iterator) \ 62 for (link_t *iterator = (list). next; \63 iterator != &(list) ; iterator = iterator->next)70 for (link_t *iterator = (list).head.next; \ 71 iterator != &(list).head; iterator = iterator->next) 64 72 65 73 /** Initialize doubly-linked circular list link … … 80 88 * Initialize doubly-linked circular list. 81 89 * 82 * @param list Pointer to link_t structure representing the list. 83 * 84 */ 85 NO_TRACE static inline void list_initialize(link_t *list) 86 { 87 list->prev = list; 88 list->next = list; 90 * @param list Pointer to list_t structure. 91 * 92 */ 93 NO_TRACE static inline void list_initialize(list_t *list) 94 { 95 list->head.prev = &list->head; 96 list->head.next = &list->head; 97 } 98 99 /** Insert item before another item in doubly-linked circular list. 100 * 101 */ 102 static inline void list_insert_before(link_t *lnew, link_t *lold) 103 { 104 lnew->next = lold; 105 lnew->prev = lold->prev; 106 lold->prev->next = lnew; 107 lold->prev = lnew; 108 } 109 110 /** Insert item after another item in doubly-linked circular list. 111 * 112 */ 113 static inline void list_insert_after(link_t *lnew, link_t *lold) 114 { 115 lnew->prev = lold; 116 lnew->next = lold->next; 117 lold->next->prev = lnew; 118 lold->next = lnew; 89 119 } 90 120 … … 94 124 * 95 125 * @param link Pointer to link_t structure to be added. 96 * @param list Pointer to link_t structure representing the list. 97 * 98 */ 99 NO_TRACE static inline void list_prepend(link_t *link, link_t *list) 100 { 101 link->next = list->next; 102 link->prev = list; 103 list->next->prev = link; 104 list->next = link; 126 * @param list Pointer to list_t structure. 127 * 128 */ 129 NO_TRACE static inline void list_prepend(link_t *link, list_t *list) 130 { 131 list_insert_after(link, &list->head); 105 132 } 106 133 … … 110 137 * 111 138 * @param link Pointer to link_t structure to be added. 112 * @param list Pointer to link_t structure representing the list. 113 * 114 */ 115 NO_TRACE static inline void list_append(link_t *link, link_t *list) 116 { 117 link->prev = list->prev; 118 link->next = list; 119 list->prev->next = link; 120 list->prev = link; 121 } 122 123 /** Insert item before another item in doubly-linked circular list. 124 * 125 */ 126 static inline void list_insert_before(link_t *link, link_t *list) 127 { 128 list_append(link, list); 129 } 130 131 /** Insert item after another item in doubly-linked circular list. 132 * 133 */ 134 static inline void list_insert_after(link_t *link, link_t *list) 135 { 136 list_prepend(list, link); 139 * @param list Pointer to list_t structure. 140 * 141 */ 142 NO_TRACE static inline void list_append(link_t *link, list_t *list) 143 { 144 list_insert_before(link, &list->head); 137 145 } 138 146 … … 156 164 * Query emptiness of doubly-linked circular list. 157 165 * 158 * @param list Pointer to lin k_t structure representing the list.159 * 160 */ 161 NO_TRACE static inline int list_empty(li nk_t *list)162 { 163 return (list-> next == list);164 } 165 166 /** Get head item of alist.167 * 168 * @param list Pointer to li nk_t structure representing the list.166 * @param list Pointer to lins_t structure. 167 * 168 */ 169 NO_TRACE static inline int list_empty(list_t *list) 170 { 171 return (list->head.next == &list->head); 172 } 173 174 /** Get first item in list. 175 * 176 * @param list Pointer to list_t structure. 169 177 * 170 178 * @return Head item of the list. … … 172 180 * 173 181 */ 174 static inline link_t *list_head(link_t *list) 175 { 176 return ((list->next == list) ? NULL : list->next); 182 static inline link_t *list_first(list_t *list) 183 { 184 return ((list->head.next == &list->head) ? NULL : list->head.next); 185 } 186 187 /** Get last item in list. 188 * 189 * @param list Pointer to list_t structure. 190 * 191 * @return Head item of the list. 192 * @return NULL if the list is empty. 193 * 194 */ 195 static inline link_t *list_last(list_t *list) 196 { 197 return ((list->head.prev == &list->head) ? NULL : list->head.prev); 177 198 } 178 199 … … 231 252 } 232 253 233 /** Get n-th item ofa list.254 /** Get n-th item in a list. 234 255 * 235 256 * @param list Pointer to link_t structure representing the list. … … 240 261 * 241 262 */ 242 static inline link_t *list_nth(li nk_t *list, unsigned int n)263 static inline link_t *list_nth(list_t *list, unsigned int n) 243 264 { 244 265 unsigned int cnt = 0; … … 254 275 } 255 276 256 extern int list_member(const link_t *, const li nk_t *);257 extern void list_concat(li nk_t *, link_t *);258 extern unsigned int list_count(const li nk_t *);277 extern int list_member(const link_t *, const list_t *); 278 extern void list_concat(list_t *, list_t *); 279 extern unsigned int list_count(const list_t *); 259 280 260 281 #endif -
kernel/generic/include/console/chardev.h
r98caf49 r55b77d9 88 88 /** Fields suitable for multiplexing. */ 89 89 link_t link; 90 li nk_t list;90 list_t list; 91 91 92 92 /** Implementation of outdev operations. */ -
kernel/generic/include/console/kconsole.h
r98caf49 r55b77d9 91 91 92 92 SPINLOCK_EXTERN(cmd_lock); 93 extern li nk_t cmd_head;93 extern list_t cmd_list; 94 94 95 95 extern void kconsole_init(void); -
kernel/generic/include/cpu.h
r98caf49 r55b77d9 59 59 60 60 IRQ_SPINLOCK_DECLARE(timeoutlock); 61 li nk_t timeout_active_head;61 list_t timeout_active_list; 62 62 63 63 /** -
kernel/generic/include/ipc/ipc.h
r98caf49 r55b77d9 166 166 167 167 /** Phones connected to this answerbox. */ 168 li nk_t connected_phones;168 list_t connected_phones; 169 169 /** Received calls. */ 170 li nk_t calls;171 li nk_t dispatched_calls; /* Should be hash table in the future */170 list_t calls; 171 list_t dispatched_calls; /* Should be hash table in the future */ 172 172 173 173 /** Answered calls. */ 174 li nk_t answers;174 list_t answers; 175 175 176 176 IRQ_SPINLOCK_DECLARE(irq_lock); 177 177 178 178 /** Notifications from IRQ handlers. */ 179 li nk_t irq_notifs;179 list_t irq_notifs; 180 180 /** IRQs with notifications to this answerbox. */ 181 li nk_t irq_head;181 list_t irq_list; 182 182 } answerbox_t; 183 183 … … 243 243 extern void ipc_backsend_err(phone_t *, call_t *, sysarg_t); 244 244 extern void ipc_answerbox_slam_phones(answerbox_t *, bool); 245 extern void ipc_cleanup_call_list(li nk_t *);245 extern void ipc_cleanup_call_list(list_t *); 246 246 247 247 extern void ipc_print_task(task_id_t); -
kernel/generic/include/mm/as.h
r98caf49 r55b77d9 254 254 255 255 extern as_operations_t *as_operations; 256 extern li nk_t inactive_as_with_asid_head;256 extern list_t inactive_as_with_asid_list; 257 257 258 258 extern void as_init(void); -
kernel/generic/include/mm/buddy.h
r98caf49 r55b77d9 72 72 /** Maximal order of block which can be stored by buddy system. */ 73 73 uint8_t max_order; 74 li nk_t *order;74 list_t *order; 75 75 buddy_system_operations_t *op; 76 76 /** Pointer to be used by the implementation. */ -
kernel/generic/include/mm/slab.h
r98caf49 r55b77d9 111 111 112 112 /* Slabs */ 113 li nk_t full_slabs; /**< List of full slabs */114 li nk_t partial_slabs; /**< List of partial slabs */113 list_t full_slabs; /**< List of full slabs */ 114 list_t partial_slabs; /**< List of partial slabs */ 115 115 SPINLOCK_DECLARE(slablock); 116 116 /* Magazines */ 117 li nk_t magazines; /**< List o full magazines */117 list_t magazines; /**< List o full magazines */ 118 118 SPINLOCK_DECLARE(maglock); 119 119 -
kernel/generic/include/proc/scheduler.h
r98caf49 r55b77d9 48 48 typedef struct { 49 49 IRQ_SPINLOCK_DECLARE(lock); 50 li nk_t rq_head;/**< List of ready threads. */51 size_t n; 50 list_t rq; /**< List of ready threads. */ 51 size_t n; /**< Number of threads in rq_ready. */ 52 52 } runq_t; 53 53 -
kernel/generic/include/proc/task.h
r98caf49 r55b77d9 73 73 char name[TASK_NAME_BUFLEN]; 74 74 /** List of threads contained in this task. */ 75 li nk_t th_head;75 list_t threads; 76 76 /** Address space. */ 77 77 as_t *as; … … 94 94 stats_ipc_t ipc_info; /**< IPC statistics */ 95 95 /** List of synchronous answerboxes. */ 96 li nk_t sync_box_head;96 list_t sync_boxes; 97 97 98 98 #ifdef CONFIG_UDEBUG -
kernel/generic/include/synch/waitq.h
r98caf49 r55b77d9 63 63 64 64 /** List of sleeping threads for which there was no missed_wakeup. */ 65 li nk_t head;65 list_t sleepers; 66 66 } waitq_t; 67 67
Note:
See TracChangeset
for help on using the changeset viewer.