Commit 336abff6 authored by Alexander Potapenko's avatar Alexander Potapenko Committed by Linus Torvalds

kasan: use dump_stack_lvl(KERN_ERR) to print stacks

Most of the contents of KASAN reports are printed with pr_err(), so use a
consistent logging level to print the memory access stacks.

Link: https://lkml.kernel.org/r/20210506105405.3535023-2-glider@google.comSigned-off-by: default avatarAlexander Potapenko <glider@google.com>
Reviewed-by: default avatarMarco Elver <elver@google.com>
Cc: Andrey Ryabinin <ryabinin.a.a@gmail.com>
Cc: Prasad Sodagudi <psodagud@quicinc.com>
Cc: Dmitry Vyukov <dvyukov@google.com>
Cc: he, bo <bo.he@intel.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: Petr Mladek <pmladek@suse.com>
Cc: Sergey Senozhatsky <senozhatsky@chromium.org>
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: Yanmin Zhang <yanmin_zhang@linux.intel.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 4469c0f1
...@@ -230,7 +230,7 @@ static void print_address_description(void *addr, u8 tag) ...@@ -230,7 +230,7 @@ static void print_address_description(void *addr, u8 tag)
{ {
struct page *page = kasan_addr_to_page(addr); struct page *page = kasan_addr_to_page(addr);
dump_stack(); dump_stack_lvl(KERN_ERR);
pr_err("\n"); pr_err("\n");
if (page && PageSlab(page)) { if (page && PageSlab(page)) {
...@@ -375,7 +375,7 @@ void kasan_report_async(void) ...@@ -375,7 +375,7 @@ void kasan_report_async(void)
pr_err("BUG: KASAN: invalid-access\n"); pr_err("BUG: KASAN: invalid-access\n");
pr_err("Asynchronous mode enabled: no access details available\n"); pr_err("Asynchronous mode enabled: no access details available\n");
pr_err("\n"); pr_err("\n");
dump_stack(); dump_stack_lvl(KERN_ERR);
end_report(&flags, 0); end_report(&flags, 0);
} }
#endif /* CONFIG_KASAN_HW_TAGS */ #endif /* CONFIG_KASAN_HW_TAGS */
...@@ -420,7 +420,7 @@ static void __kasan_report(unsigned long addr, size_t size, bool is_write, ...@@ -420,7 +420,7 @@ static void __kasan_report(unsigned long addr, size_t size, bool is_write,
pr_err("\n"); pr_err("\n");
print_memory_metadata(info.first_bad_addr); print_memory_metadata(info.first_bad_addr);
} else { } else {
dump_stack(); dump_stack_lvl(KERN_ERR);
} }
end_report(&flags, addr); end_report(&flags, addr);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment