diff options
| author | Mark Brown <broonie@kernel.org> | 2016-02-09 21:20:39 +0300 | 
|---|---|---|
| committer | Mark Brown <broonie@kernel.org> | 2016-02-09 21:20:39 +0300 | 
| commit | fcdcc79628a1919bde9acf239e364f65bab6327c (patch) | |
| tree | 5499be387cf3028c90ac083b1cf866ebed7bf7e0 /lib/list_debug.c | |
| parent | 7a8d44bc89e5cddcd5c0704a11a90484d36ba6ba (diff) | |
| parent | a0a90718f18264dc904d34a580f332006f5561e9 (diff) | |
| download | linux-fcdcc79628a1919bde9acf239e364f65bab6327c.tar.xz | |
Merge branch 'topic/acpi' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi into spi-pxa2xx
Diffstat (limited to 'lib/list_debug.c')
| -rw-r--r-- | lib/list_debug.c | 11 | 
1 files changed, 10 insertions, 1 deletions
| diff --git a/lib/list_debug.c b/lib/list_debug.c index c24c2f7e296f..3345a089ef7b 100644 --- a/lib/list_debug.c +++ b/lib/list_debug.c @@ -12,6 +12,13 @@  #include <linux/kernel.h>  #include <linux/rculist.h> +static struct list_head force_poison; +void list_force_poison(struct list_head *entry) +{ +	entry->next = &force_poison; +	entry->prev = &force_poison; +} +  /*   * Insert a new entry between two known consecutive entries.   * @@ -23,6 +30,8 @@ void __list_add(struct list_head *new,  			      struct list_head *prev,  			      struct list_head *next)  { +	WARN(new->next == &force_poison || new->prev == &force_poison, +		"list_add attempted on force-poisoned entry\n");  	WARN(next->prev != prev,  		"list_add corruption. next->prev should be "  		"prev (%p), but was %p. (next=%p).\n", @@ -37,7 +46,7 @@ void __list_add(struct list_head *new,  	next->prev = new;  	new->next = next;  	new->prev = prev; -	prev->next = new; +	WRITE_ONCE(prev->next, new);  }  EXPORT_SYMBOL(__list_add); | 
