Blame view
lib/list_debug.c
2.59 KB
199a9afc3 [PATCH] Debug var... |
1 2 3 4 5 6 7 |
/* * Copyright 2006, Red Hat, Inc., Dave Jones * Released under the General Public License (GPL). * * This file contains the linked list implementations for * DEBUG_LIST. */ |
8bc3bcc93 lib: reduce the u... |
8 |
#include <linux/export.h> |
199a9afc3 [PATCH] Debug var... |
9 |
#include <linux/list.h> |
50af5ead3 bug.h: add includ... |
10 |
#include <linux/bug.h> |
b116ee4d7 lib: fix implicit... |
11 |
#include <linux/kernel.h> |
559f9badd rcu: List-debug v... |
12 |
#include <linux/rculist.h> |
199a9afc3 [PATCH] Debug var... |
13 14 15 16 17 18 19 20 21 22 23 24 |
/* * Insert a new entry between two known consecutive entries. * * This is only for internal list manipulation where we know * the prev/next entries already! */ void __list_add(struct list_head *new, struct list_head *prev, struct list_head *next) { |
924d9addb list debugging: u... |
25 26 27 28 29 30 31 32 33 34 |
WARN(next->prev != prev, "list_add corruption. next->prev should be " "prev (%p), but was %p. (next=%p). ", prev, next->prev, next); WARN(prev->next != next, "list_add corruption. prev->next should be " "next (%p), but was %p. (prev=%p). ", next, prev->next, prev); |
17a801f4b list_debug: WARN ... |
35 36 37 38 |
WARN(new == prev || new == next, "list_add double add: new=%p, prev=%p, next=%p. ", new, prev, next); |
199a9afc3 [PATCH] Debug var... |
39 40 41 |
next->prev = new; new->next = next; new->prev = prev; |
1c97be677 list: Use WRITE_O... |
42 |
WRITE_ONCE(prev->next, new); |
199a9afc3 [PATCH] Debug var... |
43 44 |
} EXPORT_SYMBOL(__list_add); |
3c18d4de8 Expand CONFIG_DEB... |
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 |
void __list_del_entry(struct list_head *entry) { struct list_head *prev, *next; prev = entry->prev; next = entry->next; if (WARN(next == LIST_POISON1, "list_del corruption, %p->next is LIST_POISON1 (%p) ", entry, LIST_POISON1) || WARN(prev == LIST_POISON2, "list_del corruption, %p->prev is LIST_POISON2 (%p) ", entry, LIST_POISON2) || WARN(prev->next != entry, "list_del corruption. prev->next should be %p, " "but was %p ", entry, prev->next) || WARN(next->prev != entry, "list_del corruption. next->prev should be %p, " "but was %p ", entry, next->prev)) return; __list_del(prev, next); } EXPORT_SYMBOL(__list_del_entry); |
199a9afc3 [PATCH] Debug var... |
73 |
/** |
199a9afc3 [PATCH] Debug var... |
74 75 76 77 78 79 80 |
* list_del - deletes entry from list. * @entry: the element to delete from the list. * Note: list_empty on entry does not return true after this, the entry is * in an undefined state. */ void list_del(struct list_head *entry) { |
3c18d4de8 Expand CONFIG_DEB... |
81 |
__list_del_entry(entry); |
199a9afc3 [PATCH] Debug var... |
82 83 84 85 |
entry->next = LIST_POISON1; entry->prev = LIST_POISON2; } EXPORT_SYMBOL(list_del); |
559f9badd rcu: List-debug v... |
86 87 88 89 90 91 92 93 |
/* * RCU variants. */ void __list_add_rcu(struct list_head *new, struct list_head *prev, struct list_head *next) { WARN(next->prev != prev, |
5cf05ad75 rcu: Fix broken s... |
94 95 |
"list_add_rcu corruption. next->prev should be prev (%p), but was %p. (next=%p). ", |
559f9badd rcu: List-debug v... |
96 97 |
prev, next->prev, next); WARN(prev->next != next, |
5cf05ad75 rcu: Fix broken s... |
98 99 |
"list_add_rcu corruption. prev->next should be next (%p), but was %p. (prev=%p). ", |
559f9badd rcu: List-debug v... |
100 101 102 103 104 105 106 |
next, prev->next, prev); new->next = next; new->prev = prev; rcu_assign_pointer(list_next_rcu(prev), new); next->prev = new; } EXPORT_SYMBOL(__list_add_rcu); |