Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1349444imu; Sat, 17 Nov 2018 23:20:32 -0800 (PST) X-Google-Smtp-Source: AJdET5d4E49Kt5OdMEX/M+N8nmW/1zPRaTmSEQT1mND0FQ85I4EbBkBt5b6IUxqNWZe4cLHuX3Yj X-Received: by 2002:a17:902:108a:: with SMTP id c10-v6mr17257437pla.171.1542525632520; Sat, 17 Nov 2018 23:20:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542525632; cv=none; d=google.com; s=arc-20160816; b=QTbTJmRH1wzL6Zc3nGzNTv6rh7K9yre8Jb5A+21GrdMq/dwXZFhVK4Dm8lZLhxpthB d6bB9mnC3ld2cNOyijWyKjT0EUO73wNW3FMMjRbtb1vjsSfHsmzigoBTtYhTuSDGHNJe dkAjwgVjHkzWIzpgkEmZ0+zlRdQQ9Add65p5uk30TYoBTL7x+6niUywDU6nw9Gv/2hd5 BiaerGa5mg74tsney8HdkVgJk0B0lbVFTdsZ3xg5dBjtAilKAUQQIKe11Bp0CoKXu+Qf nDFpnJrx/idJD95AUVbv+1ELLCncysdIz+eGwZy07iog2GpjcdXEJng/wi2Txt3/bvT8 htqQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:organization:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=Lt9qKUJZQeG/P7nTchTgsC3n03k3tw35LX/JPcL9uMg=; b=OkUkCe7+Oqw/0y9B0mu7t2xqUiCqwlexgwXZ1OKcps6EBFXR8W5PGBXUUcltifRJeG sHUeyyjUfL6hQxcEW1yq6Z6IKv54rq/VjGF9iaIuE3F0AzB8PWnHijJsLZT64ugHk9RA Td4jAaG5tjfhcNqoUjAzoroF8HM+8yq4dpRFwOhxoVK1Da22OoskXKRq6LcrssjLgXiZ V0O69fjO3acZU/upDBNrTRtbO0M4v6MANikXA15iPgyDf3ZeudN5FyV+ZIb1wtiCHo+j lV19+VCzJLv70pLRi/liRnWuIRnOV9ParIucsWewsuPgQE3woT5oRWNK/EDpSZbk4mia S2rg== 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 l1-v6si13632623plg.274.2018.11.17.23.20.17; Sat, 17 Nov 2018 23:20:32 -0800 (PST) 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 S1726964AbeKRRhz (ORCPT + 99 others); Sun, 18 Nov 2018 12:37:55 -0500 Received: from mga06.intel.com ([134.134.136.31]:54574 "EHLO mga06.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725914AbeKRRhz (ORCPT ); Sun, 18 Nov 2018 12:37:55 -0500 X-Amp-Result: UNSCANNABLE X-Amp-File-Uploaded: False Received: from fmsmga008.fm.intel.com ([10.253.24.58]) by orsmga104.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 17 Nov 2018 23:18:27 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.56,247,1539673200"; d="scan'208";a="87333577" Received: from kaczmarx-mobl.ger.corp.intel.com (HELO localhost) ([10.249.254.89]) by fmsmga008.fm.intel.com with ESMTP; 17 Nov 2018 23:18:18 -0800 Date: Sun, 18 Nov 2018 09:18:16 +0200 From: Jarkko Sakkinen To: Andy Lutomirski Cc: Dave Hansen , "Christopherson, Sean J" , Jethro Beekman , Florian Weimer , Linux API , Jann Horn , Linus Torvalds , X86 ML , linux-arch , LKML , Peter Zijlstra , Rich Felker , nhorman@redhat.com, npmccallum@redhat.com, "Ayoun, Serge" , shay.katz-zamir@intel.com, linux-sgx@vger.kernel.org, Andy Shevchenko , Thomas Gleixner , Ingo Molnar , Borislav Petkov Subject: Re: RFC: userspace exception fixups Message-ID: <20181118071816.GB4795@linux.intel.com> References: <20181118071548.GA4795@linux.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20181118071548.GA4795@linux.intel.com> Organization: Intel Finland Oy - BIC 0357606-4 - Westendinkatu 7, 02160 Espoo User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Nov 18, 2018 at 09:15:48AM +0200, Jarkko Sakkinen wrote: > On Thu, Nov 01, 2018 at 10:53:40AM -0700, Andy Lutomirski wrote: > > Hi all- > > > > The people working on SGX enablement are grappling with a somewhat > > annoying issue: the x86 EENTER instruction is used from user code and > > can, as part of its normal-ish operation, raise an exception. It is > > also highly likely to be used from a library, and signal handling in > > libraries is unpleasant at best. > > > > There's been some discussion of adding a vDSO entry point to wrap > > EENTER and do something sensible with the exceptions, but I'm > > wondering if a more general mechanism would be helpful. > > I haven't really followed all of this discussion because I've been busy > working on the patch set but for me all of these approaches look awfully > complicated. > > I'll throw my own suggestion and apologize if this has been already > suggested and discarded: return-to-AEP. > > My idea is to do just a small extension to SGX AEX handling. At the > moment hardware will RAX, RBX and RCX with ERESUME parameters. We can > fill extend this by filling other three spare registers with exception s/fill extend/extend/ /Jarkko