Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp284641ybg; Mon, 1 Jun 2020 00:59:06 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxbVWjzXoZIjGg9j9ziJsPkjlK7x0cIomf00UQbvO8RDfB3THBCoptbhxnjwpGQXicVjfYL X-Received: by 2002:a05:6402:3078:: with SMTP id bs24mr5879143edb.284.1590998346001; Mon, 01 Jun 2020 00:59:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590998345; cv=none; d=google.com; s=arc-20160816; b=X/npygJM+XnN9fnmLy4RhXWLD9o8QuUmbx+u0MzAPn3mMrKXQR5SfvbGc74F67Eq52 ydURs94Nebjz4eiPuNus3so3EBv+79NcE7aSZRpTPvXkQpfY1ozuyKi9AqCi9ntyYGcR 8eD2+ebRSSeZU9PttW8DuDlEgNE/QvFmBMCd6UMy/0//84XzeFlQ7ZgkuVFY/F8qsDsK Fp/G5VCuaxpIWRkjE4zrHWS73LYxR0tUEqxnr3yxTpO3rqunuvsTm7+xelNCn6oIOic6 95/eMzk9Ivvi5O8ZsDUlpbxwrFTlzh+vM7ZlA3GxjLENN8QZqv0WnAHUjJVDlGhgkWRA jtXw== 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=1DNQdrC0aeBPBVNGOqZ0EWyXrXrgMmuCgZxxNLq0sgM=; b=oCBjzFVoz4wD0yUlv3/E0yS2jFm8IHwjQSiqz7EsPFXEqAGFk1YmsBFwASQcL1pjLw +Sle33YdOmJrdNJJhngayTxrY70De7yoZwqW9SagUjrvonn3HdYcOxV0wpAhWQQ8RKET dtOin0NSMM9LnCE/pZZujU75p9IKpEhceJ7LqZdqRdPtIkmlMIEUV45bqTmnJXUP23pM CD57a3wUVgkfC6hw645V/YTPkX0Ohu8JJhh/8n+Zdn7APtnHCEMW4P5GGvrRRDmnkrBU A6/c+047mcIrD/vpwm/GsW0Ldh2YmmNZWGSIgRY6nXtCPcda96u8hSYJsd7tOm4PWzlE JvjQ== 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 w19si5139178edt.402.2020.06.01.00.58.43; Mon, 01 Jun 2020 00:59:05 -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 S1726667AbgFAHy2 (ORCPT + 99 others); Mon, 1 Jun 2020 03:54:28 -0400 Received: from mga18.intel.com ([134.134.136.126]:18154 "EHLO mga18.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727828AbgFAHy0 (ORCPT ); Mon, 1 Jun 2020 03:54:26 -0400 IronPort-SDR: 5vSDb7MnqOCJdPXmsMX/7MBQGBff2hpMmDL4a9w0LmfxxVTwqI8sbXESReHLZFmpL7IeRGRcV+ IrGmHi1jwcCQ== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga003.fm.intel.com ([10.253.24.29]) by orsmga106.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 01 Jun 2020 00:54:26 -0700 IronPort-SDR: 1ts4H7NbqFNQbcSptf7aHjsDnKZJLpipkvvo0ARX+Hklwnn2EgJ1U6fqkn5COgvrvND5sLHVV0 EdgfcueKbWXQ== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.73,460,1583222400"; d="scan'208";a="311879843" Received: from yhanin-mobl1.ger.corp.intel.com (HELO localhost) ([10.249.43.17]) by FMSMGA003.fm.intel.com with ESMTP; 01 Jun 2020 00:54:20 -0700 From: Jarkko Sakkinen To: linux-kernel@vger.kernel.org, x86@kernel.org, linux-sgx@vger.kernel.org Cc: Sean Christopherson , Andy Lutomirski , Jethro Beekman , Jarkko Sakkinen , akpm@linux-foundation.org, andriy.shevchenko@linux.intel.com, asapek@google.com, bp@alien8.de, cedric.xing@intel.com, chenalexchen@google.com, conradparker@google.com, cyhanish@google.com, dave.hansen@intel.com, haitao.huang@intel.com, josh@joshtriplett.org, kai.huang@intel.com, kai.svahn@intel.com, kmoy@google.com, ludloff@google.com, luto@kernel.org, nhorman@redhat.com, npmccallum@redhat.com, puiterwijk@redhat.com, rientjes@google.com, tglx@linutronix.de, yaozhangx@google.com Subject: [PATCH v32 17/21] x86/traps: Attempt to fixup exceptions in vDSO before signaling Date: Mon, 1 Jun 2020 10:52:14 +0300 Message-Id: <20200601075218.65618-18-jarkko.sakkinen@linux.intel.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200601075218.65618-1-jarkko.sakkinen@linux.intel.com> References: <20200601075218.65618-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 Acked-by: Jethro Beekman 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 d54cffdc7cac..cce8fb2c560d 100644 --- a/arch/x86/kernel/traps.c +++ b/arch/x86/kernel/traps.c @@ -57,6 +57,7 @@ #include #include #include +#include #ifdef CONFIG_X86_64 #include @@ -206,6 +207,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; } /* @@ -538,6 +542,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); @@ -791,6 +798,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. @@ -871,6 +882,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 23666e34abbc..e9ed3c7299ac 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 @@ -924,6 +925,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); @@ -1041,6 +1046,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