Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp1294869ybk; Thu, 14 May 2020 05:35:08 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzDXkSWZ3Hs9ediDiwEEfSk9PwN5XLA/X9NlRY406uls7+J6DOZ0O8Anoc0tabvEOLNZ9x9 X-Received: by 2002:a17:906:909:: with SMTP id i9mr3488663ejd.347.1589459708409; Thu, 14 May 2020 05:35:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1589459708; cv=none; d=google.com; s=arc-20160816; b=eOZZVRIgdsqyfwNkDfRMZH60fd3csyTBIF3rjpY62yiJp4ATb5exEN2eIvIgPP328G MUQaZ9ruY5fruQFCtshMdS3ooN14gtgi7N7fdaTnSKskTy5Lk5NvoNrNxjb6MWSAb9Mk OfGyfhacbyuDkhs6IhI9WQJRkT2DEWIHW8avyFJwThl74xg73dv1jJL2pqHG+nr8xQKT wNJXVDKAkmsDueu7QtCiA468Lm4JuKtyLwyG3Wzi8mgjVKhOoYoULpHFwXsF0YomaWMB KiHkS66OSe2QuUXjxSRYZWR4ZW6EzZqX7UJwrgmTz3SIG7iOcLSVhSKNkmc+2nZscyHO NulA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:references :in-reply-to:subject:cc:to:from; bh=fh4fhLiL0xwfbpYUQrXg2UdjfunTAuOmYj7bWgnWglw=; b=YRRdl1bO/GHH4ucaUuyyKfQMDkFmaniDpu0H/rzt+j+lPNrLjrr6hFRyEjZPhoo6wU y6kfuTJU5TuKL1tha48sPREDRFdi1VZPfslFffiZFxjHjVRxJOFNW1+pGXsNDPPeXCCq JAewb/Xtulf4rFfPcgG3hhfNTEfew/FP4NNzVdPRobwXNRGbt/PhN81AnftCxMOIsj+K pSjD71DvLWI5o9Ws/od/zN1xkWH9hOFgBnwKnEiQVy/3jC7lsdvY6oap1Et4BZcGLVEf OKY8Q+OehMAJvOISFON5Fof5gHb2+yFNQyp6c6BW4ZwGcV/QwFoFrUSkXg55FQ5FYE8y W9CQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u20si1529025eda.9.2020.05.14.05.34.46; Thu, 14 May 2020 05:35:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726124AbgENMd2 (ORCPT + 99 others); Thu, 14 May 2020 08:33:28 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45464 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1725925AbgENMd1 (ORCPT ); Thu, 14 May 2020 08:33:27 -0400 Received: from Galois.linutronix.de (Galois.linutronix.de [IPv6:2a0a:51c0:0:12e:550::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B8283C061A0C for ; Thu, 14 May 2020 05:33:27 -0700 (PDT) Received: from p5de0bf0b.dip0.t-ipconnect.de ([93.224.191.11] helo=nanos.tec.linutronix.de) by Galois.linutronix.de with esmtpsa (TLS1.2:DHE_RSA_AES_256_CBC_SHA256:256) (Exim 4.80) (envelope-from ) id 1jZD2t-0006Lq-6u; Thu, 14 May 2020 14:33:03 +0200 Received: by nanos.tec.linutronix.de (Postfix, from userid 1000) id 7484A1004CE; Thu, 14 May 2020 14:33:02 +0200 (CEST) From: Thomas Gleixner To: Andy Lutomirski Cc: LKML , X86 ML , "Paul E. McKenney" , Andy Lutomirski , Alexandre Chartre , Frederic Weisbecker , Paolo Bonzini , Sean Christopherson , Masami Hiramatsu , Petr Mladek , Steven Rostedt , Joel Fernandes , Boris Ostrovsky , Juergen Gross , Brian Gerst , Mathieu Desnoyers , Josh Poimboeuf , Will Deacon Subject: Re: [patch V4 part 3 17/29] x86/entry: Convert Invalid Opcode exception to IDTENTRY In-Reply-To: References: <20200505134354.774943181@linutronix.de> <20200505134904.955511913@linutronix.de> Date: Thu, 14 May 2020 14:33:02 +0200 Message-ID: <87k11ezog1.fsf@nanos.tec.linutronix.de> MIME-Version: 1.0 Content-Type: text/plain X-Linutronix-Spam-Score: -1.0 X-Linutronix-Spam-Level: - X-Linutronix-Spam-Status: No , -1.0 points, 5.0 required, ALL_TRUSTED=-1,SHORTCIRCUIT=-0.0001 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Andy Lutomirski writes: > On Tue, May 5, 2020 at 7:15 AM Thomas Gleixner wrote: >> >> From: Thomas Gleixner >> >> Convert #UD to IDTENTRY: >> - Implement the C entry point with DEFINE_IDTENTRY >> - Emit the ASM stub with DECLARE_IDTENTRY >> - Remove the ASM idtentry in 64bit >> - Remove the open coded ASM entry code in 32bit >> - Fixup the XEN/PV code >> - Fixup the FOOF bug call in fault.c >> - Remove the old prototyoes >> >> No functional change. > > I think there *is* a functional change: > > >> --- a/arch/x86/mm/fault.c >> +++ b/arch/x86/mm/fault.c >> @@ -567,7 +567,7 @@ static int is_f00f_bug(struct pt_regs *r >> nr = (address - idt_descr.address) >> 3; >> >> if (nr == 6) { >> - do_invalid_op(regs, 0); >> + handle_invalid_op(regs); > > I suspect the old code was wrong and no one noticed because no one has > a F00F-buggy machine any more. I don't think so. It's really just the same thing. The old #UD C function was: void do_invalid_op(struct pt_regs *regs, long error_code) { do_error_trap(regs, error_code, "invalid opcode", X86_TRAP_UD, SIGILL, ILL_ILLOPN, (void __user *)uprobe_get_trap_addr(regs)); } after expanding the DO_ERROR() muck. The new one does: void handle_invalid_op(struct pt_regs *regs) { do_error_trap(regs, 0, "invalid opcode", X86_TRAP_UD, SIGILL, ILL_ILLOPN, error_get_trap_addr(regs)); } which is exactly the same except for the error code being hardcoded to zero in handle_invalid_op() because #UD does not have one. > So maybe document that you fixed up the F00F bug, too. Otherwise: Not sure what to document :) Thanks, tglx