From: Jan H. Schönherr Date: Tue, 19 Jul 2011 19:10:26 +0000 (+0200) Subject: rcu: Fix wrong check in list_splice_init_rcu() X-Git-Tag: firefly_0821_release~3680^2~4992^2 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=7f70893173b056df691b2ee7546bb44fd9abae6a;p=firefly-linux-kernel-4.4.55.git rcu: Fix wrong check in list_splice_init_rcu() If the list to be spliced is empty, then list_splice_init_rcu() has nothing to do. Unfortunately, list_splice_init_rcu() does not check the list to be spliced; it instead checks the list to be spliced into. This results in memory leaks given current usage. This commit therefore fixes the empty-list check. Signed-off-by: Jan H. Schönherr Signed-off-by: Paul E. McKenney --- diff --git a/include/linux/rculist.h b/include/linux/rculist.h index e3beb315517a..d079290843a9 100644 --- a/include/linux/rculist.h +++ b/include/linux/rculist.h @@ -183,7 +183,7 @@ static inline void list_splice_init_rcu(struct list_head *list, struct list_head *last = list->prev; struct list_head *at = head->next; - if (list_empty(head)) + if (list_empty(list)) return; /* "first" and "last" tracking list, so initialize it. */