Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753042AbaBYOFx (ORCPT ); Tue, 25 Feb 2014 09:05:53 -0500 Received: from mail-qc0-f180.google.com ([209.85.216.180]:49511 "EHLO mail-qc0-f180.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752954AbaBYOFu (ORCPT ); Tue, 25 Feb 2014 09:05:50 -0500 Date: Tue, 25 Feb 2014 09:07:51 -0500 (EST) From: Vince Weaver To: "H. Peter Anvin" cc: Peter Zijlstra , Steven Rostedt , Vince Weaver , Linux Kernel , Ingo Molnar Subject: Re: perf_fuzzer compiled for x32 causes reboot In-Reply-To: <530C12CA.6070308@zytor.com> Message-ID: References: <18f0cea3-7e3b-4477-b433-0269f3de976b@email.android.com> <20140224172536.GD9987@twins.programming.kicks-ass.net> <530B841F.5050803@zytor.com> <530B90A5.3090302@zytor.com> <20140224141329.1cd3bb52@gandalf.local.home> <20140224193043.GP6835@laptop.programming.kicks-ass.net> <530C12CA.6070308@zytor.com> User-Agent: Alpine 2.10 (DEB 1266 2009-07-14) MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 24 Feb 2014, H. Peter Anvin wrote: > On 02/24/2014 11:30 AM, Peter Zijlstra wrote: > > On Mon, Feb 24, 2014 at 02:13:29PM -0500, Steven Rostedt wrote: > >> Ah, and x86_64 saves off the cr2 register when entering NMI and restores > >> it before returning. But it seems to be missing from the i386 code. > > > > arch/x86/kernel/nmi.c: > > > > #define nmi_nesting_preprocess(regs) \ > > do { \ > > if (this_cpu_read(nmi_state) != NMI_NOT_RUNNING) { \ > > this_cpu_write(nmi_state, NMI_LATCHED); \ > > return; \ > > } \ > > this_cpu_write(nmi_state, NMI_EXECUTING); \ > > this_cpu_write(nmi_cr2, read_cr2()); \ > > } while (0); \ > > nmi_restart: > > > > #define nmi_nesting_postprocess() \ > > do { \ > > if (unlikely(this_cpu_read(nmi_cr2) != read_cr2())) \ > > write_cr2(this_cpu_read(nmi_cr2)); \ > > if (this_cpu_dec_return(nmi_state)) \ > > goto nmi_restart; \ > > } while (0) > > > > That very much looks like saving/restoring CR2 to me. > > > > FWIW; I hate how the x86_64 and i386 versions of this NMI nesting magic > > are so completely different. > > Is there any way that nmi_cr2 can end up getting overwritten by multiple > nestings of some kind? I would have thought it would have made more > sense to spill cr2 onto the stack after the stack has been properly set up. So how can I help with debugging this? While the missing cr2 issue made debugging frustrating, I find the other aspects of the bug more serious: 1. Programs that are doing valid memory accesses can segfault and worse 2. This bug can cause an instant-reboot of the system (I assume somehow with the right combination of memory accesses it causes a triple-fault?) #2 is why I spent all of this time tracking this down, I couldn't leave a machine fuzzing overnight without the machine rebooting. Vince -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/