Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp46214ybz; Tue, 21 Apr 2020 14:56:54 -0700 (PDT) X-Google-Smtp-Source: APiQypL58atQUxgFV9+9qtksDe1MU4n+HmrvH4AN7zRdhC7KezvHWzi3CidQPInnIywhEd5MJJ+1 X-Received: by 2002:a05:6402:3129:: with SMTP id dd9mr7715844edb.121.1587506214699; Tue, 21 Apr 2020 14:56:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587506214; cv=none; d=google.com; s=arc-20160816; b=BREmmoyQPEFxGBSAaRLyppjTF5i86MGN/VkxOlFa7DpYmpb4BcjgpotrLKbzZMLIgH RUIWPRugDzZl5y3XhNQPyEYOVqOOr9p9VRM8+H7LzLXZAzOYtAG3VsMAZiPDI5wNKXYY IzWutodYQ8ZlJcIYEXo4t7VASlYfBxnyBWAMX2tOXvAcu/pZEsQO+Zp1kC5tuNIbtK3x p5iLJGONREM6TFRgy9eyBBI5lGXLqtC0euCkYfDyMYrTtRyFKl8CbVn50YmQgatOCt4j hsY3NOxDSmqZDTPc+J3ISwoDWx8br/n4O7U6yjfuPrehJUyEA2DvvmIs2Esve6CHLUh0 +BYA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :ironport-sdr:ironport-sdr; bh=IZDLtNg1iL14XK80R0AWwH56UmzJVENxBMp6OutKc+o=; b=r/c4u50JL0zLapycxSWklj3UPH9CIxsSnw2lwlnjzkoNahuOLYl4M1322BVs4WKy9d O+DpJluM0DK01DVdF5TNTQsYiiPvXy7SPNglCcz01XMIr6gdUgfdTYffkGYDT40I40ud LNd2oKyImo9fVDe2U5cx8aU2oVwNTqkk6/y9NUOQkL5Uky9bARJSD9Y/Cywk1yCqHrtm ljRE31c4aTJrJVqeOl41ta60wr8J5iKDugpPGoty98DlOp5FE7ZQElVAb2BkKbwN+OXs txFENAWHC/7vvlrpMkA5e2+8OA3GlS0G/L1T/GPSARqLdx2BYRDl3wlFrflF0Cqojw3A kGMA== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b26si1198640edw.447.2020.04.21.14.56.32; Tue, 21 Apr 2020 14:56:54 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726284AbgDUVzD (ORCPT + 99 others); Tue, 21 Apr 2020 17:55:03 -0400 Received: from mga09.intel.com ([134.134.136.24]:43154 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726055AbgDUVzD (ORCPT ); Tue, 21 Apr 2020 17:55:03 -0400 IronPort-SDR: 0mZX7F6+j+bfQs5JpBiv6gtBE9H88cm2L3j3FB35wHWWPRtkQtHxOUgzteENm2eUPW3x4FP1oy 42Q5tFQyY4xg== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga005.fm.intel.com ([10.253.24.32]) by orsmga102.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 21 Apr 2020 14:55:02 -0700 IronPort-SDR: MWagytJ/9a37MlemrLusJVeg+mGW18aCCVsDtzEbMKfeEhKM6laI8Uq5k2KLwh/zTTP/n2mNXs nITXcGr6z6Fw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.72,411,1580803200"; d="scan'208";a="456260846" Received: from mnchalux-mobl2.gar.corp.intel.com (HELO localhost) ([10.252.44.234]) by fmsmga005.fm.intel.com with ESMTP; 21 Apr 2020 14:54:57 -0700 From: Jarkko Sakkinen To: linux-kernel@vger.kernel.org, x86@kernel.org, linux-sgx@vger.kernel.org Cc: akpm@linux-foundation.org, dave.hansen@intel.com, sean.j.christopherson@intel.com, nhorman@redhat.com, npmccallum@redhat.com, haitao.huang@intel.com, andriy.shevchenko@linux.intel.com, tglx@linutronix.de, kai.svahn@intel.com, bp@alien8.de, josh@joshtriplett.org, luto@kernel.org, kai.huang@intel.com, rientjes@google.com, cedric.xing@intel.com, puiterwijk@redhat.com, Andy Lutomirski , Jarkko Sakkinen Subject: [PATCH v29 17/20] x86/traps: Attempt to fixup exceptions in vDSO before signaling Date: Wed, 22 Apr 2020 00:53:13 +0300 Message-Id: <20200421215316.56503-18-jarkko.sakkinen@linux.intel.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200421215316.56503-1-jarkko.sakkinen@linux.intel.com> References: <20200421215316.56503-1-jarkko.sakkinen@linux.intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Sean Christopherson vDSO functions can now leverage an exception fixup mechanism similar to kernel exception fixup. For vDSO exception fixup, the initial user is Intel's Software Guard Extensions (SGX), which will wrap the low-level transitions to/from the enclave, i.e. EENTER and ERESUME instructions, in a vDSO function and leverage fixup to intercept exceptions that would otherwise generate a signal. This allows the vDSO wrapper to return the fault information directly to its caller, obviating the need for SGX applications and libraries to juggle signal handlers. Attempt to fixup vDSO exceptions immediately prior to populating and sending signal information. Except for the delivery mechanism, an exception in a vDSO function should be treated like any other exception in userspace, e.g. any fault that is successfully handled by the kernel should not be directly visible to userspace. Although it's debatable whether or not all exceptions are of interest to enclaves, defer to the vDSO fixup to decide whether to do fixup or generate a signal. Future users of vDSO fixup, if there ever are any, will undoubtedly have different requirements than SGX enclaves, e.g. the fixup vs. signal logic can be made function specific if/when necessary. Suggested-by: Andy Lutomirski Signed-off-by: Sean Christopherson Signed-off-by: Jarkko Sakkinen --- arch/x86/kernel/traps.c | 14 ++++++++++++++ arch/x86/mm/fault.c | 8 ++++++++ 2 files changed, 22 insertions(+) diff --git a/arch/x86/kernel/traps.c b/arch/x86/kernel/traps.c index 6ef00eb6fbb9..a814b1aea94d 100644 --- a/arch/x86/kernel/traps.c +++ b/arch/x86/kernel/traps.c @@ -56,6 +56,7 @@ #include #include #include +#include #ifdef CONFIG_X86_64 #include @@ -205,6 +206,9 @@ do_trap_no_signal(struct task_struct *tsk, int trapnr, const char *str, tsk->thread.error_code = error_code; tsk->thread.trap_nr = trapnr; die(str, regs, error_code); + } else { + if (fixup_vdso_exception(regs, trapnr, error_code, 0)) + return 0; } /* @@ -518,6 +522,9 @@ dotraplinkage void do_general_protection(struct pt_regs *regs, long error_code) tsk->thread.error_code = error_code; tsk->thread.trap_nr = X86_TRAP_GP; + if (fixup_vdso_exception(regs, X86_TRAP_GP, error_code, 0)) + return; + show_signal(tsk, SIGSEGV, "", desc, regs, error_code); force_sig(SIGSEGV); @@ -762,6 +769,10 @@ dotraplinkage void do_debug(struct pt_regs *regs, long error_code) SIGTRAP) == NOTIFY_STOP) goto exit; + if (user_mode(regs) && + fixup_vdso_exception(regs, X86_TRAP_DB, error_code, 0)) + goto exit; + /* * Let others (NMI) know that the debug stack is in use * as we may switch to the interrupt stack. @@ -842,6 +853,9 @@ static void math_error(struct pt_regs *regs, int error_code, int trapnr) if (!si_code) return; + if (fixup_vdso_exception(regs, trapnr, error_code, 0)) + return; + force_sig_fault(SIGFPE, si_code, (void __user *)uprobe_get_trap_addr(regs)); } diff --git a/arch/x86/mm/fault.c b/arch/x86/mm/fault.c index 6b662d272af6..42965b47b52f 100644 --- a/arch/x86/mm/fault.c +++ b/arch/x86/mm/fault.c @@ -30,6 +30,7 @@ #include /* store_idt(), ... */ #include /* exception stack */ #include /* VMALLOC_START, ... */ +#include /* fixup_vdso_exception() */ #define CREATE_TRACE_POINTS #include @@ -902,6 +903,10 @@ __bad_area_nosemaphore(struct pt_regs *regs, unsigned long error_code, sanitize_error_code(address, &error_code); + if (fixup_vdso_exception(regs, X86_TRAP_PF, error_code, + address)) + return; + if (likely(show_unhandled_signals)) show_signal_msg(regs, error_code, address, tsk); @@ -1019,6 +1024,9 @@ do_sigbus(struct pt_regs *regs, unsigned long error_code, unsigned long address, sanitize_error_code(address, &error_code); + if (fixup_vdso_exception(regs, X86_TRAP_PF, error_code, address)) + return; + set_signal_archinfo(address, error_code); #ifdef CONFIG_MEMORY_FAILURE -- 2.25.1