Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp722065img; Wed, 20 Mar 2019 09:28:33 -0700 (PDT) X-Google-Smtp-Source: APXvYqxeVbMrLeSOOzbXUay4xbnAEh7tSiszrpDYapW73S+cCwSpZDUHmv0d5r7xF1UgasgBUIyn X-Received: by 2002:aa7:83ca:: with SMTP id j10mr31255482pfn.50.1553099313125; Wed, 20 Mar 2019 09:28:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553099313; cv=none; d=google.com; s=arc-20160816; b=DLZZGaX6mrBVPiZ8i2NLNNOi/1HnxBTdjYF69B1dLegjjAT1iFU3pFUFvfPaxR4NSJ DJqaJkxVhN8CILuj1jhqgTsLg3sXBraLz/EF0C3u3+E3DJhRWeP7q9Aj87PKfAaaFeYN Q8ix52JlPmru7iUCAmffEoWDI/wcOyobuSgxlgI+ttbuqwL+/Y4jerBvUuHOaRYxE4/U mseBoiOVOpKAzcmQx1g9+Ra0MNvgemHJNEIq4x7oJOGhZb5//GLqrH8xOxrawj6Z7FQ2 r6lZKvZOwakFW8QevkatX4bdX44I2qRJ3xjGsAA131TIfKk0+Lchqp01oq1QKMfzSuzy D8jQ== 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=PNvesNt+j5dNloQ+rHsnvockYc5pazML5GSj0H7aJ7s=; b=wzljzjSpE/wSVrbr3zUdszBlv7w8PMjhPHuJT5xdb3MRZ/yNbhwXGuxi9HKN2vDlKu ybo2ymG4vo1eh9C+iUCgjI2jZ2VqsWdwDHM9ywyVdDtyddFNlOo7KXR5YOEIJlzMLP8V KT+p72uo0yblWV8zvnbaXffVwivGLSUzqqGAc31bTxljmDjVn2xxSgUB9GB+vK3fG/jT ViCtIoF8JZJkka0oDqluvV+Q65AHM9KBqqnl+B59iVz39K1legRBib0dEHuDBdvM5tRP EL4KD2kTas9Nx6B6tb67y1M/0UTgtpLLBFn0DVG1BV2cwi1lBvInk6mQyo4e1JPd5VIM ibOQ== 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 k11si2151812pls.244.2019.03.20.09.28.17; Wed, 20 Mar 2019 09:28:33 -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 S1727897AbfCTQ0B (ORCPT + 99 others); Wed, 20 Mar 2019 12:26:01 -0400 Received: from mga02.intel.com ([134.134.136.20]:39998 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727395AbfCTQ0B (ORCPT ); Wed, 20 Mar 2019 12:26:01 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga003.jf.intel.com ([10.7.209.27]) by orsmga101.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 20 Mar 2019 09:26:00 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.60,249,1549958400"; d="scan'208";a="135715876" Received: from sorenthe-mobl1.ger.corp.intel.com (HELO localhost) ([10.249.254.203]) by orsmga003.jf.intel.com with ESMTP; 20 Mar 2019 09:25:49 -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, Andy Lutomirski , Jarkko Sakkinen , Dave Hansen Subject: [PATCH v19,RESEND 23/27] x86/traps: Attempt to fixup exceptions in vDSO before signaling Date: Wed, 20 Mar 2019 18:21:15 +0200 Message-Id: <20190320162119.4469-24-jarkko.sakkinen@linux.intel.com> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20190320162119.4469-1-jarkko.sakkinen@linux.intel.com> References: <20190320162119.4469-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 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/arch/x86/kernel/traps.c b/arch/x86/kernel/traps.c index d26f9e9c3d83..02eda456c119 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), task); } -- 2.19.1