Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp2258258ybi; Sat, 13 Jul 2019 10:13:34 -0700 (PDT) X-Google-Smtp-Source: APXvYqxz7z9mvCams6h0qOMxbUIsBzlMZYM5F/1AdrzUYTMfJDZm70pVM9bT7rFAw5GSXquzEXO0 X-Received: by 2002:a17:90a:9905:: with SMTP id b5mr19735551pjp.70.1563038014165; Sat, 13 Jul 2019 10:13:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1563038014; cv=none; d=google.com; s=arc-20160816; b=MbLx2BHCmMiec/X/60Ddu5nici+Wz//BfcKTt7LUwU5y2u/slnZan6IkB2TUhIWGc5 YvFIt+fLuPXw0p9MC6fINbCJNL0n/5ydPifUXVOZr2GbddH5S5ghXkdCnGriSF391Agt y8J2qQfiWZXVypty6jkXECcGoXNhk2GLEmfEUU/H4ptUY2C3MlfKiOHALyUGw3EA3SP+ 84qgOjJeyZjx3k3lQN9ab5pjMElV8RZaOcNLmcqF4Ww4c0DUohyzHqGlGHUZSOOL1k9o TZgMExVZJLFAAU5jqE4IoXoN02r6VmtfAOC7fPJ2LYqSxrftTvEcJkUUbmDheavwNULn tIDg== 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=ecmGk0xWh5OW//aRTO6cY572cCF6Wi8dqJkfk11tzjg=; b=md26y2BwtiTt4ju1WnQiCyQixczR80jLtU+35IfSgQp7WPzYXh3Xosets70TIu6nTs QR+ooMlZEBGNvYmOokbQ4Ro2zv+3LAb1yxWrZKC537CPqaEm9riwHVw5BFqySMWsuVnD IEAkmTiBeMc4tdSJzXw/TyjKJnu4Xp8QOf8QSaKu8rQfDDi9IqAJu7wFroeRzJ/fmIUP ug52wBw7gv83miQbRAebi1+4HUX+zda5E0qJ4wT1ToOR4FCib/SL/ecJhWxnBehoJuE8 38QIswrdxuIvsoC60embHUMx8MhhVAjFMGFxLzBUWq6/CohVBHBW2JaCLiB6WeIP+1vY RGWQ== 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 c15si11081241pfr.73.2019.07.13.10.13.19; Sat, 13 Jul 2019 10:13:34 -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 S1728192AbfGMRM2 (ORCPT + 99 others); Sat, 13 Jul 2019 13:12:28 -0400 Received: from mga09.intel.com ([134.134.136.24]:34201 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727853AbfGMRM2 (ORCPT ); Sat, 13 Jul 2019 13:12:28 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga005.jf.intel.com ([10.7.209.41]) by orsmga102.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 13 Jul 2019 10:12:27 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.63,487,1557212400"; d="scan'208";a="341981599" Received: from hbriegel-mobl.ger.corp.intel.com (HELO localhost) ([10.252.50.48]) by orsmga005.jf.intel.com with ESMTP; 13 Jul 2019 10:12:18 -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, Andy Lutomirski , Jarkko Sakkinen , Dave Hansen Subject: [PATCH v21 22/28] x86/traps: Attempt to fixup exceptions in vDSO before signaling Date: Sat, 13 Jul 2019 20:07:58 +0300 Message-Id: <20190713170804.2340-23-jarkko.sakkinen@linux.intel.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190713170804.2340-1-jarkko.sakkinen@linux.intel.com> References: <20190713170804.2340-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 Cc: Andy Lutomirski Cc: Jarkko Sakkinen Cc: Dave Hansen Cc: Josh Triplett Signed-off-by: Sean Christopherson --- arch/x86/kernel/traps.c | 14 ++++++++++++++ arch/x86/mm/fault.c | 7 +++++++ 2 files changed, 21 insertions(+) diff --git a/arch/x86/kernel/traps.c b/arch/x86/kernel/traps.c index 87095a477154..2d5e06278f6e 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; } /* @@ -561,6 +565,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; @@ -775,6 +782,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. @@ -855,6 +866,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 140f1196f819..fa874656fd14 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 @@ -921,6 +922,9 @@ __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); @@ -1038,6 +1042,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