linux/arch
Andrey Konovalov 51fb34de2a kasan, arm64: reset pointer tags of vmapped stacks
Once tag-based KASAN modes start tagging vmalloc() allocations, kernel
stacks start getting tagged if CONFIG_VMAP_STACK is enabled.

Reset the tag of kernel stack pointers after allocation in
arch_alloc_vmap_stack().

For SW_TAGS KASAN, when CONFIG_KASAN_STACK is enabled, the instrumentation
can't handle the SP register being tagged.

For HW_TAGS KASAN, there's no instrumentation-related issues.  However,
the impact of having a tagged SP register needs to be properly evaluated,
so keep it non-tagged for now.

Note, that the memory for the stack allocation still gets tagged to catch
vmalloc-into-stack out-of-bounds accesses.

[andreyknvl@google.com: fix case when a stack is retrieved from cached_stacks]
  Link: https://lkml.kernel.org/r/f50c5f96ef896d7936192c888b0c0a7674e33184.1644943792.git.andreyknvl@google.com
[dan.carpenter@oracle.com: remove unnecessary check in alloc_thread_stack_node()]
  Link: https://lkml.kernel.org/r/20220301080706.GB17208@kili

Link: https://lkml.kernel.org/r/698c5ab21743c796d46c15d075b9481825973e34.1643047180.git.andreyknvl@google.com
Signed-off-by: Andrey Konovalov <andreyknvl@google.com>
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Acked-by: Catalin Marinas <catalin.marinas@arm.com>
Acked-by: Marco Elver <elver@google.com>
Reviewed-by: Marco Elver <elver@google.com>
Cc: Alexander Potapenko <glider@google.com>
Cc: Andrey Ryabinin <ryabinin.a.a@gmail.com>
Cc: Dmitry Vyukov <dvyukov@google.com>
Cc: Evgenii Stepanov <eugenis@google.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Peter Collingbourne <pcc@google.com>
Cc: Vincenzo Frascino <vincenzo.frascino@arm.com>
Cc: Will Deacon <will@kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2022-03-24 19:06:47 -07:00
..
alpha Networking changes for 5.18. 2022-03-24 13:13:26 -07:00
arc asm-generic updates for 5.18 2022-03-23 18:03:08 -07:00
arm Networking changes for 5.18. 2022-03-24 13:13:26 -07:00
arm64 kasan, arm64: reset pointer tags of vmapped stacks 2022-03-24 19:06:47 -07:00
csky asm-generic updates for 5.18 2022-03-23 18:03:08 -07:00
h8300 Merge branch 'set_fs-4' of git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic into asm-generic 2022-02-25 11:16:58 +01:00
hexagon asm-generic updates for 5.18 2022-03-23 18:03:08 -07:00
ia64 flexible-array transformations for 5.18-rc1 2022-03-24 11:39:32 -07:00
m68k asm-generic updates for 5.18 2022-03-23 18:03:08 -07:00
microblaze asm-generic updates for 5.18 2022-03-23 18:03:08 -07:00
mips Networking changes for 5.18. 2022-03-24 13:13:26 -07:00
nios2 asm-generic updates for 5.18 2022-03-23 18:03:08 -07:00
openrisc asm-generic updates for 5.18 2022-03-23 18:03:08 -07:00
parisc Networking changes for 5.18. 2022-03-24 13:13:26 -07:00
powerpc mm/migration: add trace events for THP migrations 2022-03-24 19:06:45 -07:00
riscv Merge branch 'akpm' (patches from Andrew) 2022-03-24 14:14:07 -07:00
s390 kasan, x86, arm64, s390: rename functions for modules shadow 2022-03-24 19:06:47 -07:00
sh flexible-array transformations for 5.18-rc1 2022-03-24 11:39:32 -07:00
sparc Networking changes for 5.18. 2022-03-24 13:13:26 -07:00
um flexible-array transformations for 5.18-rc1 2022-03-24 11:39:32 -07:00
x86 kasan, x86, arm64, s390: rename functions for modules shadow 2022-03-24 19:06:47 -07:00
xtensa Networking changes for 5.18. 2022-03-24 13:13:26 -07:00
.gitignore
Kconfig asm-generic updates for 5.18 2022-03-23 18:03:08 -07:00