Home | History | Annotate | Download | only in netlink
      1 struct list_head {
      2 	struct list_head *next;
      3 };
      4 
      5 #define LIST_HEAD(name) \
      6 	struct list_head name = { &(name) }
      7 
      8 static inline int list_empty(const struct list_head *head)
      9 {
     10 	return head->next == head;
     11 }
     12 
     13 static inline void list_add(struct list_head *new, struct list_head *head)
     14 {
     15 	new->next = head->next;
     16 	head->next = new;
     17 }
     18 
     19 static inline void list_del(struct list_head *entry, struct list_head *prev)
     20 {
     21 	prev->next = entry->next;
     22 	entry->next = entry;
     23 }
     24 
     25 #define list_for_each_safe(pos, n, head) \
     26 	for (n = (head), pos = (head)->next; pos != (head); \
     27 	     n = pos, pos = n->next)
     28 
     29 #undef offsetof
     30 #define offsetof(TYPE, MEMBER) ((size_t) &((TYPE *)0)->MEMBER)
     31 
     32 #define container_of(ptr, type, member) ({			\
     33 	const typeof( ((type *)0)->member ) *__mptr = (ptr);	\
     34 	(type *)( (char *)__mptr - offsetof(type,member) );})
     35 
     36 #ifdef DEBUG
     37 #define pynl_dbg(fmt, ...) \
     38 	fprintf(stderr, "%s: " fmt, __func__, __VA_ARGS__)
     39 #else
     40 #define pynl_dbg(fmt, ...)
     41 #endif
     42