Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp3620478ybg; Mon, 28 Oct 2019 16:04:47 -0700 (PDT) X-Google-Smtp-Source: APXvYqyRu7Oq4C7kHKbG87NznZ6qfMDg2SeLQlyi5DSRBW5/g7+N7NkySQrgTp+pcQSpm7h7QhNc X-Received: by 2002:aa7:c34c:: with SMTP id j12mr1527311edr.175.1572303887170; Mon, 28 Oct 2019 16:04:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1572303887; cv=none; d=google.com; s=arc-20160816; b=gb+hgd+Dn93J4+bSkjCegt3SyfC364LG9EXGRZ1vpwdkV3obUf9BEtljnZ3ialsLSj dafA61nm709WR+TvuAWz2d/0c4TZ5e5hEm8ClQPA9bMBDi51FocCc0Krcme/cREAusaT cxUpNHVMbutxN8G3Ou6kRNpEkb9QwmHgjumQzdal+1JNsPOtqBYqeIzQwVcBzzdLl5jW e9HTZN/vhNekAN/JfzAPDJiPpw8E4lqkR5tNSxOm4D7NGJMVdJC90F6/SfqDWu+DWDMC Cttyb04Z8VzKA/bi2PXM5F8plL7pzorswvTfSqSprmVGpL8DLFu0tfhxUMKPlbHttCkn FpfA== 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; bh=uQ4v/waYVvTA06FNV6WAydy7u4DyGgxVp2XfPmVZBXU=; b=sPyBpkbyEex3qrszu55t3CM89KT21hcynqn3PqupkBYk5xJJ1IX5hNqd3gcOZ8yjwt UDBl9ffi12uaxPEp3Ufpe/HInIO4R9AIJ4pNQ5YgQ2+QFHmpdX55MmxQ3NnLQWGhf8Vg RVCoQu1jCXnKJ85f00y/HysgZBTy64DIrfzeCs5ur+ytnS/cMO+TL3NWVtr11nrMuSFB PT4/05C/l5tUzTBx+4clzNvYVeO7VKFACi24dfRLg32Is5/6HT05MmvCeRALqknc+rP+ P93PvgqcZNr3EYzr2RNqiqetQHlx9eNll5zi4MEJ7eztPxMJePREKiUuy34Ep3XFojF4 NUGA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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. [209.132.180.67]) by mx.google.com with ESMTP id d10si130681edk.122.2019.10.28.16.04.23; Mon, 28 Oct 2019 16:04:47 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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 S2391148AbfJ1VG7 (ORCPT + 99 others); Mon, 28 Oct 2019 17:06:59 -0400 Received: from mga06.intel.com ([134.134.136.31]:44723 "EHLO mga06.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727689AbfJ1VG6 (ORCPT ); Mon, 28 Oct 2019 17:06:58 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by orsmga104.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 28 Oct 2019 14:06:58 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.68,241,1569308400"; d="scan'208";a="224760115" Received: from shrehore-mobl1.ti.intel.com (HELO localhost) ([10.251.82.5]) by fmsmga004.fm.intel.com with ESMTP; 28 Oct 2019 14:06:50 -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, serge.ayoun@intel.com, shay.katz-zamir@intel.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 v23 20/24] x86/traps: Attempt to fixup exceptions in vDSO before signaling Date: Mon, 28 Oct 2019 23:03:20 +0200 Message-Id: <20191028210324.12475-21-jarkko.sakkinen@linux.intel.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20191028210324.12475-1-jarkko.sakkinen@linux.intel.com> References: <20191028210324.12475-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 4bb0f8447112..9f06a3441f10 100644 --- a/arch/x86/kernel/traps.c +++ b/arch/x86/kernel/traps.c @@ -61,6 +61,7 @@ #include #include #include +#include #ifdef CONFIG_X86_64 #include @@ -210,6 +211,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; } /* @@ -557,6 +561,9 @@ do_general_protection(struct pt_regs *regs, long error_code) return; } + if (fixup_vdso_exception(regs, X86_TRAP_GP, error_code, 0)) + return; + tsk->thread.error_code = error_code; tsk->thread.trap_nr = X86_TRAP_GP; @@ -771,6 +778,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. @@ -851,6 +862,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 0e0842e941eb..105252776172 100644 --- a/arch/x86/mm/fault.c +++ b/arch/x86/mm/fault.c @@ -29,6 +29,7 @@ #include /* efi_recover_from_page_fault()*/ #include /* store_idt(), ... */ #include /* exception stack */ +#include /* fixup_vdso_exception() */ #define CREATE_TRACE_POINTS #include @@ -901,6 +902,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); @@ -1018,6 +1023,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.20.1