mirror of
https://github.com/tbsdtv/linux_media.git
synced 2025-07-23 20:51:03 +02:00
list debugging: warn when deleting a deleted entry
Use the magic LIST_POISON* values to detect an incorrect use of list_del on a deleted entry. This DEBUG_LIST specific warning is easier to understand than the generic Oops message caused by LIST_POISON dereference. Signed-off-by: Baruch Siach <baruch@tkos.co.il> Cc: Dave Jones <davej@codemonkey.org.uk> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
committed by
Linus Torvalds
parent
55817d3d5c
commit
e3f76e3386
@@ -43,6 +43,12 @@ EXPORT_SYMBOL(__list_add);
|
|||||||
*/
|
*/
|
||||||
void list_del(struct list_head *entry)
|
void list_del(struct list_head *entry)
|
||||||
{
|
{
|
||||||
|
WARN(entry->next == LIST_POISON1,
|
||||||
|
"list_del corruption, next is LIST_POISON1 (%p)\n",
|
||||||
|
LIST_POISON1);
|
||||||
|
WARN(entry->next != LIST_POISON1 && entry->prev == LIST_POISON2,
|
||||||
|
"list_del corruption, prev is LIST_POISON2 (%p)\n",
|
||||||
|
LIST_POISON2);
|
||||||
WARN(entry->prev->next != entry,
|
WARN(entry->prev->next != entry,
|
||||||
"list_del corruption. prev->next should be %p, "
|
"list_del corruption. prev->next should be %p, "
|
||||||
"but was %p\n", entry, entry->prev->next);
|
"but was %p\n", entry, entry->prev->next);
|
||||||
|
Reference in New Issue
Block a user