From mboxrd@z Thu Jan 1 00:00:00 1970 From: Kees Cook Subject: Re: [kernel-hardening] Re: [PATCH v9 1/4] syscalls: Verify address limit before returning to user-mode Date: Fri, 12 May 2017 14:04:49 -0700 Message-ID: References: <20170512072802.5a686f23@mschwideX1> <20170512075458.09a3a1ce@mschwideX1> <20170512202106.GO22219@n2100.armlinux.org.uk> <20170512203044.GI4626@worktop.programming.kicks-ass.net> <20170512204556.GP22219@n2100.armlinux.org.uk> Mime-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Return-path: In-Reply-To: Sender: linux-api-owner-u79uwXL29TY76Z2rM5mHXA@public.gmane.org To: Russell King - ARM Linux Cc: Peter Zijlstra , Mark Rutland , Brian Gerst , Kernel Hardening , Catalin Marinas , Heiko Carstens , Oleg Nesterov , David Howells , Dave Hansen , "H . Peter Anvin" , Ingo Molnar , Pavel Tikhomirov , linux-s390 , the arch/x86 maintainers , Christian Borntraeger , =?UTF-8?Q?Ren=C3=A9_Nyffenegger?= , Greg KH , "Paul E . McKenney" , Rik van Riel List-Id: linux-api@vger.kernel.org On Fri, May 12, 2017 at 2:00 PM, Kees Cook wrote: > On Fri, May 12, 2017 at 1:45 PM, Russell King - ARM Linux > wrote: >> On Fri, May 12, 2017 at 10:30:44PM +0200, Peter Zijlstra wrote: >>> On Fri, May 12, 2017 at 09:21:06PM +0100, Russell King - ARM Linux wrote: >>> > On Fri, May 12, 2017 at 12:30:02PM -0700, Kees Cook wrote: >>> > > I'm clearly not explaining things well enough. I shouldn't say >>> > > "corruption", I should say "malicious manipulation". The methodology >>> > > of attacks against the stack are quite different from the other kinds >>> > > of attacks like use-after-free, heap overflow, etc. Being able to >>> > > exhaust the kernel stack (either due to deep recursion or unbounded >>> > > alloca()) >>> > >>> > I really hope we don't have alloca() use in the kernel. Do you have >>> > evidence to support that assertion? >>> > >>> > IMHO alloca() (or similar) should not be present in any kernel code >>> > because we have a limited stack - we have kmalloc() etc for that kind >>> > of thing. >>> >>> On stack variable length arrays get implemented by the compiler doing >>> alloca(), and we sadly have a few of those around. >> >> I hope their size is appropriately limited, but something tells me it >> would be foolish to assume that. >> >>> But yes, fully agreed on the desirability of alloca() and things. >> >> Hmm, I wonder if -fno-builtin-alloca would prevent those... it looks >> like it certainly would prevent an explicit alloca() call. > > Building with -Werror=vla is exciting. :) > > A lot of it is in crypto (which are relatively static sizes, just > using function callbacks), but there is plenty more. I meant to also paste an example (which is harmless, I haven't looked extensively at other examples): unsigned long alignmask = crypto_tfm_alg_alignmask(tfm); unsigned int size = crypto_tfm_alg_blocksize(tfm); u8 buffer[size + alignmask]; Looking at all the places (and having tried to remove a few of these in pstore), I think it might be quite frustrating to eliminate them all and then declare VLAs dead. I'm not against trying, though. :) -Kees -- Kees Cook Pixel Security