summaryrefslogtreecommitdiff
path: root/mm/debug_page_ref.c
diff options
context:
space:
mode:
authorAndrey Konovalov <andreyknvl@gmail.com>2024-01-10 01:12:34 +0300
committerAndrew Morton <akpm@linux-foundation.org>2024-01-13 02:20:45 +0300
commitcc478e0b6bdffd20561e1a07941a65f6c8962cab (patch)
tree36e164b0477fa685f44d53fdc8deaac90225227a /mm/debug_page_ref.c
parentaaa2c9a97c22af5bf011f6dd8e0538219b45af88 (diff)
downloadlinux-cc478e0b6bdffd20561e1a07941a65f6c8962cab.tar.xz
kasan: avoid resetting aux_lock
With commit 63b85ac56a64 ("kasan: stop leaking stack trace handles"), KASAN zeroes out alloc meta when an object is freed. The zeroed out data purposefully includes alloc and auxiliary stack traces but also accidentally includes aux_lock. As aux_lock is only initialized for each object slot during slab creation, when the freed slot is reallocated, saving auxiliary stack traces for the new object leads to lockdep reports when taking the zeroed out aux_lock. Arguably, we could reinitialize aux_lock when the object is reallocated, but a simpler solution is to avoid zeroing out aux_lock when an object gets freed. Link: https://lkml.kernel.org/r/20240109221234.90929-1-andrey.konovalov@linux.dev Fixes: 63b85ac56a64 ("kasan: stop leaking stack trace handles") Signed-off-by: Andrey Konovalov <andreyknvl@gmail.com> Reported-by: Paul E. McKenney <paulmck@kernel.org> Closes: https://lore.kernel.org/linux-next/5cc0f83c-e1d6-45c5-be89-9b86746fe731@paulmck-laptop/ Reviewed-by: Marco Elver <elver@google.com> Tested-by: Paul E. McKenney <paulmck@kernel.org> Cc: Alexander Potapenko <glider@google.com> Cc: Andrey Ryabinin <ryabinin.a.a@gmail.com> Cc: Dmitry Vyukov <dvyukov@google.com> Cc: Liam R. Howlett <Liam.Howlett@oracle.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Diffstat (limited to 'mm/debug_page_ref.c')
0 files changed, 0 insertions, 0 deletions