Le 16/05/2022 à 09:32, Xiu Jianfeng a écrit : > Add support for adding a random offset to the stack while handling > syscalls. This patch uses mftb() instead of get_random_int() for better > performance. > > In order to avoid unconditional stack canaries on syscall entry (due to > the use of alloca()), also disable stack protector to avoid triggering > needless checks and slowing down the entry path. As there is no general > way to control stack protector coverage with a function attribute, this > must be disabled at the compilation unit level. > > Signed-off-by: Xiu Jianfeng <xiujianf...@huawei.com> >
Did you see this patch generates sparse warnings ? See https://patchwork.ozlabs.org/project/linuxppc-dev/patch/20220516073225.112875-1-xiujianf...@huawei.com/ It is not directly related to this patch but that's worth a patch to fix it. > --- > Changes in v2: > -move choose choose_random_kstack_offset() to the end of > system_call_exception > -allow full 6 (10) bits of entropy > -disable stack-protector for interrupt.c > --- > arch/powerpc/Kconfig | 1 + > arch/powerpc/kernel/Makefile | 7 +++++++ > arch/powerpc/kernel/interrupt.c | 19 ++++++++++++++++++- > 3 files changed, 26 insertions(+), 1 deletion(-) > > diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig > index 98309eeae09c..2f0019a0054e 100644 > --- a/arch/powerpc/Kconfig > +++ b/arch/powerpc/Kconfig > @@ -192,6 +192,7 @@ config PPC > select HAVE_ARCH_KASAN if PPC32 && PPC_PAGE_SHIFT <= 14 > select HAVE_ARCH_KASAN_VMALLOC if PPC32 && PPC_PAGE_SHIFT <= 14 > select HAVE_ARCH_KFENCE if PPC_BOOK3S_32 || PPC_8xx || > 40x > + select HAVE_ARCH_RANDOMIZE_KSTACK_OFFSET > select HAVE_ARCH_KGDB > select HAVE_ARCH_MMAP_RND_BITS > select HAVE_ARCH_MMAP_RND_COMPAT_BITS if COMPAT > diff --git a/arch/powerpc/kernel/Makefile b/arch/powerpc/kernel/Makefile > index 4ddd161aef32..5c5e85b8229b 100644 > --- a/arch/powerpc/kernel/Makefile > +++ b/arch/powerpc/kernel/Makefile > @@ -40,6 +40,13 @@ CFLAGS_cputable.o += -DDISABLE_BRANCH_PROFILING > CFLAGS_btext.o += -DDISABLE_BRANCH_PROFILING > endif > > +#ifdef CONFIG_RANDOMIZE_KSTACK_OFFSET > +# Remove stack protector to avoid triggering unneeded stack canary > +# checks due to randomize_kstack_offset. > +CFLAGS_REMOVE_interrupt.o = -fstack-protector -fstack-protector-strong > +CFLAGS_interrupt.o += -fno-stack-protector > +#endif > + > obj-y := cputable.o syscalls.o \ > irq.o align.o signal_$(BITS).o pmc.o vdso.o \ > process.o systbl.o idle.o \ > diff --git a/arch/powerpc/kernel/interrupt.c b/arch/powerpc/kernel/interrupt.c > index 784ea3289c84..d7cdcb6fc336 100644 > --- a/arch/powerpc/kernel/interrupt.c > +++ b/arch/powerpc/kernel/interrupt.c > @@ -4,6 +4,7 @@ > #include <linux/err.h> > #include <linux/compat.h> > #include <linux/sched/debug.h> /* for show_regs */ > +#include <linux/randomize_kstack.h> > > #include <asm/kup.h> > #include <asm/cputime.h> > @@ -78,10 +79,12 @@ notrace long system_call_exception(long r3, long r4, long > r5, > long r6, long r7, long r8, > unsigned long r0, struct pt_regs *regs) > { > + long ret; > syscall_fn f; > > kuap_lock(); > > + add_random_kstack_offset(); > regs->orig_gpr3 = r3; > > if (IS_ENABLED(CONFIG_PPC_IRQ_SOFT_MASK_DEBUG)) > @@ -229,7 +232,21 @@ notrace long system_call_exception(long r3, long r4, > long r5, > f = (void *)sys_call_table[r0]; > } > > - return f(r3, r4, r5, r6, r7, r8); > + ret = f(r3, r4, r5, r6, r7, r8); > + /* > + * Ultimately, this value will get limited by KSTACK_OFFSET_MAX(), > + * so the maximum stack offset is 1k bytes(10 bits). > + * > + * The actual entropy will be further reduced by the compiler when > + * applying stack alignment constraints: the powerpc architecture > + * may have two kinds of stack alignment(16-bytes and 8-bytes). > + * > + * So the resulting 6 or 7 bits of entropy is seen in SP[9:4] or > SP[9:3]. > + * > + */ > + choose_random_kstack_offset(mftb()); > + > + return ret; > } > > static notrace void booke_load_dbcr0(void)