[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <CALCETrUDoMKRsB8EHNo1iZB-KxidWB_LCivReE6DvCT2HQ2PzQ@mail.gmail.com>
Date: Tue, 24 Nov 2020 13:57:00 -0800
From: Andy Lutomirski <luto@...nel.org>
To: "Dr. Greg" <greg@...ellic.com>
Cc: Andy Lutomirski <luto@...nel.org>,
Jarkko Sakkinen <jarkko.sakkinen@...ux.intel.com>,
X86 ML <x86@...nel.org>, linux-sgx@...r.kernel.org,
LKML <linux-kernel@...r.kernel.org>,
Andrew Morton <akpm@...ux-foundation.org>,
Andy Shevchenko <andriy.shevchenko@...ux.intel.com>,
asapek@...gle.com, Borislav Petkov <bp@...en8.de>,
"Xing, Cedric" <cedric.xing@...el.com>, chenalexchen@...gle.com,
Conrad Parker <conradparker@...gle.com>, cyhanish@...gle.com,
Dave Hansen <dave.hansen@...el.com>,
"Huang, Haitao" <haitao.huang@...el.com>,
"Huang, Kai" <kai.huang@...el.com>,
"Svahn, Kai" <kai.svahn@...el.com>, Keith Moyer <kmoy@...gle.com>,
Christian Ludloff <ludloff@...gle.com>,
Neil Horman <nhorman@...hat.com>,
Nathaniel McCallum <npmccallum@...hat.com>,
Patrick Uiterwijk <puiterwijk@...hat.com>,
David Rientjes <rientjes@...gle.com>,
"Christopherson, Sean J" <sean.j.christopherson@...el.com>,
Thomas Gleixner <tglx@...utronix.de>, yaozhangx@...gle.com,
Mikko Ylinen <mikko.ylinen@...el.com>
Subject: Re: [PATCH v40 00/24] Intel SGX foundations
On Tue, Nov 24, 2020 at 10:40 AM Dr. Greg <greg@...ellic.com> wrote:
>
> On Sat, Nov 21, 2020 at 10:36:58AM -0800, Andy Lutomirski wrote:
>
> Intel SGX developer licensing requires that you provide application
> recipients with a full and complete runtime along with the signed
> application. Our developer license allowed us to substitute our
> runtime for Intel's.
Upstream Linux wants nothing to do with Intel's developer licensing.
> > > Given that this driver is no longer locked to the Intel trust root, by
> > > virtue of being restricted to run only on platforms which support
> > > Flexible Launch Control, there is no longer any legitimate technical
> > > reason to not expose all of the functionality of the hardware.
>
> > I read this three times, and I can't tell what functionality you're
> > referring to.
>
> Yes you do, as I mentioned to Dave in my last e-mail, we have been
> disagreeing about this for a year.
No, I don't. It's entirely possible that I'm aware of the
functionality you're referring to, but that doesn't mean that your
description quoted above is sufficient for me to have the slightest
idea which functionality you mean right here.
>
> You were at some kind of seminar where SGX was discussed. Based on
> that you developed a 'manifesto' regarding how Linux should implement
> the technology. That manifesto indicated there would be no place for
> cryptographic policy control on enclaves.
That's not what I said. Paraphrasing myself, I said that there is no
place for a driver in upstream Linux that allows only Intel-approved
code to run. That is not at all the same thing as saying we won't
support cryptographic policy in a way that allows the platform owner
an appropriate degree of control.
Actually supporting launch control (the EINIT-enforced kind) in
upstream Linux will be tricky but is surely possible. It would
probably help if Intel or firmware vendors had some clear
specification of exactly how they intend for platform owners to select
an SGXLEPUBKEYHASH value. (A nice spec in which an authenticated UEFI
variable contained the desired SGXLEPUBKEYHASH and lock state might be
an excellent start.) Supporting this in upstream Linux will also
require decoupling the user code that creates an enclave from the user
code that invokes the LE. Jarkko already wrote some code for this,
and it could be revived. If this ends up being inconsistent with
Intel's licensing requirements, then Intel can change their licensing
requirements or people can just ignore Intel and use a different
signing key.
Frankly, using Intel's signing key in SGXLEPUBKEYHASH offers a dubious
degree of protection in the first place -- it assumes that Intel will
never approve a malware enclave, and it also assumes that the lack of
functioning EINITTOKEN revocation won't break the whole scheme.
>
> A well taken and considered point on a locked launch control platform
> but completely irrelevant for this driver, that only operates on
> Flexible Launch Control platforms. By demanding compliance with only
> that vision you deny platform owners a final measure of defense
> against anonymous code execution.
I am denying Intel the chance to impose their licensing requirements.
The fact that Intel chose to poison the well with their licensing
system and that, as a result, Linux won't support the Intel model of
launch control to protect platform owners is an unfortunate side
effect.
>
> > > The patch that I am including below implements signature based policy
> > > controls for enclave initialization. It does so in a manner that is
> > > completely transparent to the default behavior of the driver, which is
> > > to initialize any enclave passed to it with the exception of enclaves
> > > that set the PROVISION_KEY attribute bit.
>
> > It's completely unreviewable. It's an ABI patch, and it does not
> > document what it does, nor does it document why it does it. It's
> > just a bunch of code. NAK.
>
> You can certainly NAK-away Andy[0]. I've had sufficent private
> feedback from reasoned and informed individuals that I've made my
> point that this isn't about technical considerations.
Depends on what you mean by "technical". In the submitting-patches
guide (https://www.kernel.org/doc/html/v5.9/process/submitting-patches.html),
you will find instructions to "describe your changes" and "separate
your changes". If you can produce a reasonably, reviewable submission
of your code, I will review it. But I am not going to dig through
your diff to try to find the hidden technical merit.
>
> Here is the link, again, to the patch in 'git am' compliant format.
>
> ftp://ftp.enjellic.com/pub/sgx/kernel/SFLC-v41.patch
>
> I've been watching Linux patches go by for close to 30 years. If this
> is completely unreviewable garbage, legitimate concerns can be raised
> about what is getting pushed into the kernel.
The kernel review process is by no means perfect. That does not mean
that you get to apply your unreviewable garbage just because other
people have pulled it off in the past.
> For the LKML record, absent our patch the driver has an open security
> issue with respect to anonymous code execution that should be
> addressed, if that issue is indeed of any concern.
What do you mean?
> The only thing that I can think of is that you disagree with the
> optional capability of blocking the enclave from implementing
> anonymously executable memory. Absent that ability there is the
> security issue that has now been extensively discussed.
You keep sending a patch that blocks mmap and mprotect on an
initialized enclave. As far as I can tell, you haven't explained how
it's any better than the code it replaces. The code it replaces
enforces per-page maximum permissions, and all the infrastructure is
in place for the platform owner to be able to enforce their rules
without breaking ABI.
Your proposal appears to accomplish something a little bit like what
the code in -tip does, except without as much room for future
improvements. Since you haven't tried to explain why you think it's
better, I can't really evaluate it.
Powered by blists - more mailing lists