Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S934235AbcKQRFe (ORCPT ); Thu, 17 Nov 2016 12:05:34 -0500 Received: from mx1.redhat.com ([209.132.183.28]:36302 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754574AbcKQRFE (ORCPT ); Thu, 17 Nov 2016 12:05:04 -0500 Date: Thu, 17 Nov 2016 08:36:20 -0600 From: Josh Poimboeuf To: Vince Weaver Cc: Dmitry Vyukov , Peter Zijlstra , "linux-kernel@vger.kernel.org" , Ingo Molnar , Arnaldo Carvalho de Melo , "davej@codemonkey.org.uk" , Stephane Eranian Subject: Re: perf: fuzzer KASAN unwind_get_return_address Message-ID: <20161117143620.qi6ebud3xqwj6pvb@treble> References: <20161116143746.zoxdxrfqvmx35wln@treble> <20161116144943.GB3117@twins.programming.kicks-ass.net> <20161116145849.GR3157@twins.programming.kicks-ass.net> <20161117044828.vedc3whqkuki624r@treble> <20161117090446.GC3142@twins.programming.kicks-ass.net> <20161117091341.GS3157@twins.programming.kicks-ass.net> <20161117093028.GT3157@twins.programming.kicks-ass.net> <20161117140150.o6vy7bsrbjkg2nzd@treble> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.6.0.1 (2016-04-01) X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.25]); Thu, 17 Nov 2016 14:36:21 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1453 Lines: 33 On Thu, Nov 17, 2016 at 09:25:58AM -0500, Vince Weaver wrote: > On Thu, 17 Nov 2016, Josh Poimboeuf wrote: > > > On Thu, Nov 17, 2016 at 10:48:27AM +0100, Dmitry Vyukov wrote: > > > Just in case, there is currently a known KASAN false positive related > > > to longjmp's on GPFs. When a syscall hits GPF stack is unwound to > > > kernel entry point, this leaves a bunch of stray poisoned redzones on > > > the thread stack. They later cause false stack-out-of-bounds reports. > > > > > > But this does not seem to be the case here. Kernel is not tainted. And > > > shadow at the bottom of the reports looks sane. > > > > > > But if that's the case somehow, we will need to add > > > kasan_unpoison_remaining_stack() call before a longjmp like we did for > > > jprobe_return(): > > > https://groups.google.com/d/msg/kasan-dev/Hzox58yZ4MU/TOdFoWMuBQAJ > > > > I'm pretty sure this isn't a KASAN false positive. The unwinder does > > actually seem to be accessing a bad area of the stack, in the middle of > > a function's stack frame. > > I'm having trouble reproducing it on a few other machines I have fuzzing. > So there might be some kernel option contributing, I need to compare > .configs. > > Also the machine that easily triggers the problem I'm compiling with > gcc-5.4 where the machines I can't are using gcc-4.9. I believe KASAN only works with gcc 5 and later, so that would explain why you aren't seeing it with gcc 4.9. -- Josh