The patch titled Subject: mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8 has been added to the -mm tree. Its filename is mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8.patch This patch should soon appear at http://ozlabs.org/~akpm/mmots/broken-out/mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8.patch and later at http://ozlabs.org/~akpm/mmotm/broken-out/mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8.patch Before you just go and hit "reply", please: a) Consider who else should be cc'ed b) Prefer to cc a suitable mailing list as well c) Ideally: find the original patch on the mailing list and do a reply-to-all to that, adding suitable additional cc's *** Remember to use Documentation/SubmitChecklist when testing your code *** The -mm tree is included into linux-next and is updated there every 3-4 working days ------------------------------------------------------ From: Alexander Potapenko <glider@xxxxxxxxxx> Subject: mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8 v8: - removed vmalloc() calls - it turned out to be hard to check if vmalloc() is available Signed-off-by: Alexander Potapenko <glider@xxxxxxxxxx> Cc: Christoph Lameter <cl@xxxxxxxxx> Cc: Pekka Enberg <penberg@xxxxxxxxxx> Cc: David Rientjes <rientjes@xxxxxxxxxx> Cc: Joonsoo Kim <iamjoonsoo.kim@xxxxxxx> Cc: Andrey Konovalov <adech.fo@xxxxxxxxx> Cc: Dmitry Vyukov <dvyukov@xxxxxxxxxx> Cc: Andrey Ryabinin <ryabinin.a.a@xxxxxxxxx> Cc: Steven Rostedt <rostedt@xxxxxxxxxxx> Cc: Konstantin Serebryany <kcc@xxxxxxxxxx> Cc: Dmitry Chernenkov <dmitryc@xxxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> --- lib/Kconfig | 1 + lib/stackdepot.c | 7 +++++-- mm/kasan/kasan.c | 4 +--- mm/kasan/kasan.h | 9 ++++----- mm/kasan/report.c | 3 +-- 5 files changed, 12 insertions(+), 12 deletions(-) diff -puN lib/Kconfig~mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8 lib/Kconfig --- a/lib/Kconfig~mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8 +++ a/lib/Kconfig @@ -538,5 +538,6 @@ config ARCH_HAS_MMIO_FLUSH config STACKDEPOT bool + select STACKTRACE endmenu diff -puN lib/stackdepot.c~mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8 lib/stackdepot.c --- a/lib/stackdepot.c~mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8 +++ a/lib/stackdepot.c @@ -34,6 +34,7 @@ #include <linux/mm.h> #include <linux/percpu.h> #include <linux/printk.h> +#include <linux/slab.h> #include <linux/stacktrace.h> #include <linux/stackdepot.h> #include <linux/string.h> @@ -203,7 +204,7 @@ depot_stack_handle_t depot_save_stack(st void *prealloc = NULL; if (unlikely(trace->nr_entries == 0)) - goto exit; + goto fast_exit; hash = hash_stack(trace->entries, trace->nr_entries); /* Bad luck, we won't store this stack. */ @@ -266,10 +267,12 @@ depot_stack_handle_t depot_save_stack(st spin_unlock_irqrestore(&depot_lock, flags); exit: - if (prealloc) + if (prealloc) { /* Nobody used this memory, ok to free it. */ free_pages((unsigned long)prealloc, STACK_ALLOC_ORDER); + } if (found) retval = found->handle.handle; +fast_exit: return retval; } diff -puN mm/kasan/kasan.c~mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8 mm/kasan/kasan.c --- a/mm/kasan/kasan.c~mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8 +++ a/mm/kasan/kasan.c @@ -414,6 +414,7 @@ void kasan_poison_object_data(struct kme #endif } +#ifdef CONFIG_SLAB static inline int in_irqentry_text(unsigned long ptr) { return (ptr >= (unsigned long)&__irqentry_text_start && @@ -457,13 +458,10 @@ static inline depot_stack_handle_t save_ static inline void set_track(struct kasan_track *track, gfp_t flags) { - track->cpu = raw_smp_processor_id(); track->pid = current->pid; - track->when = jiffies; track->stack = save_stack(flags); } -#ifdef CONFIG_SLAB struct kasan_alloc_meta *get_alloc_info(struct kmem_cache *cache, const void *object) { diff -puN mm/kasan/kasan.h~mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8 mm/kasan/kasan.h --- a/mm/kasan/kasan.h~mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8 +++ a/mm/kasan/kasan.h @@ -68,16 +68,15 @@ enum kasan_state { #define KASAN_STACK_DEPTH 64 struct kasan_track { - u64 cpu : 6; /* for NR_CPUS = 64 */ - u64 pid : 16; /* 65536 processes */ - u64 when : 42; /* ~140 years */ - depot_stack_handle_t stack : sizeof(depot_stack_handle_t); + u32 pid; + depot_stack_handle_t stack; }; struct kasan_alloc_meta { + struct kasan_track track; u32 state : 2; /* enum kasan_state */ u32 alloc_size : 30; - struct kasan_track track; + u32 reserved; }; struct kasan_free_meta { diff -puN mm/kasan/report.c~mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8 mm/kasan/report.c --- a/mm/kasan/report.c~mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8 +++ a/mm/kasan/report.c @@ -119,8 +119,7 @@ static inline bool init_task_stack_addr( #ifdef CONFIG_SLAB static void print_track(struct kasan_track *track) { - pr_err("PID = %u, CPU = %u, timestamp = %lu\n", track->pid, - track->cpu, (unsigned long)track->when); + pr_err("PID = %u\n", track->pid); if (track->stack) { struct stack_trace trace; _ Patches currently in -mm which might be from glider@xxxxxxxxxx are kasan-modify-kmalloc_large_oob_right-add-kmalloc_pagealloc_oob_right.patch mm-kasan-slab-support.patch mm-kasan-added-gfp-flags-to-kasan-api.patch arch-ftrace-for-kasan-put-hard-soft-irq-entries-into-separate-sections.patch mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab.patch mm-kasan-stackdepot-implementation-enable-stackdepot-for-slab-v8.patch kasan-test-fix-warn-if-the-uaf-could-not-be-detected-in-kmalloc_uaf2.patch mm-kasan-initial-memory-quarantine-implementation.patch mm-kasan-initial-memory-quarantine-implementation-v8.patch -- To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html