|
@@ -45,19 +45,17 @@ static inline void INIT_LIST_HEAD_RCU(struct list_head *list)
|
|
* This is only for internal list manipulation where we know
|
|
* This is only for internal list manipulation where we know
|
|
* the prev/next entries already!
|
|
* the prev/next entries already!
|
|
*/
|
|
*/
|
|
-#ifndef CONFIG_DEBUG_LIST
|
|
|
|
static inline void __list_add_rcu(struct list_head *new,
|
|
static inline void __list_add_rcu(struct list_head *new,
|
|
struct list_head *prev, struct list_head *next)
|
|
struct list_head *prev, struct list_head *next)
|
|
{
|
|
{
|
|
|
|
+ if (!__list_add_valid(new, prev, next))
|
|
|
|
+ return;
|
|
|
|
+
|
|
new->next = next;
|
|
new->next = next;
|
|
new->prev = prev;
|
|
new->prev = prev;
|
|
rcu_assign_pointer(list_next_rcu(prev), new);
|
|
rcu_assign_pointer(list_next_rcu(prev), new);
|
|
next->prev = new;
|
|
next->prev = new;
|
|
}
|
|
}
|
|
-#else
|
|
|
|
-void __list_add_rcu(struct list_head *new,
|
|
|
|
- struct list_head *prev, struct list_head *next);
|
|
|
|
-#endif
|
|
|
|
|
|
|
|
/**
|
|
/**
|
|
* list_add_rcu - add a new entry to rcu-protected list
|
|
* list_add_rcu - add a new entry to rcu-protected list
|