Re: Linux guest kernel threat model for Confidential Computing
From: Greg Kroah-Hartman
Date: Wed Feb 08 2023 - 02:19:42 EST
On Tue, Feb 07, 2023 at 01:53:34PM -0600, Carlos Bilbao wrote:
> On 2/7/23 00:03, Greg Kroah-Hartman wrote:
>
> > On Mon, Feb 06, 2023 at 06:27:48PM -0600, Carlos Bilbao wrote:
> > > On 1/25/23 6:28 AM, Reshetova, Elena wrote:
> > > > 2) One of the described in the above doc mitigations is "hardening of the enabled
> > > > code". What we mean by this, as well as techniques that are being used are
> > > > described in this document: > https://intel.github.io/ccc-linux-guest-hardening-docs/tdx-guest-hardening.html
> > > Regarding driver hardening, does anyone have a better filtering idea?
> > >
> > > The current solution assumes the kernel command line is trusted and cannot
> > > avoid the __init() functions that waste memory.
> > That is two different things (command line trust and __init()
> > functions), so I do not understand the relationship at all here. Please
> > explain it better.
>
>
> No relation other than it would be nice to have a solution that does not
> require kernel command line and that prevents __init()s.
Again, __init() has nothing to do with the kernel command line so I do
not understand the relationship here. Have a specific example?
> > Also, why would an __init() function waste memory? Memory usage isn't
> > an issue here, right?
> >
> > > I don't know if the
> > > __exit() routines of the filtered devices are called, but it doesn't sound
> > > much better to allocate memory and free it right after.
> > What device has a __exit() function? Drivers have module init/exit
> > functions but they should do nothing but register themselves with the
> > relevant busses and they are only loaded if the device is found in the
> > system.
> >
> > And what exactly is incorrect about allocating memory and then freeing
> > it when not needed?
>
>
> Currently proposed device filtering does not stop the __init() functions
> from these drivers to be called. Whatever memory is allocated by
> blacklisted drivers is wasted because those drivers cannot ever be used.
> Sure, memory can be allocated and freed as soon as it is no longer needed,
> but these memory would never be needed.
Drivers are never even loaded if the hardware is not present, and a
driver init function should do nothing anyway if it is written properly,
so again, I do not understand what you are referring to here.
Again, a real example might help explain your concerns, pointers to the
code?
> More pressing concern than wasted memory, which may be unimportant, there's
> the issue of what are those driver init functions doing. For example, as
> part of device setup, MMIO regs may be involved, which we cannot trust. It's
> a lot more code to worry about from a CoCo perspective.
Again, specific example?
And if you don't want a driver to be loaded, don't build it into your
kernel as Ted said. Or better yet, use the in-kernel functionality to
prevent drivers from ever loading or binding to a device until you tell
it from userspace that it is safe to do so.
So I don't think this is a real issue unless you have pointers to code
you are concerned about.
> > So again, I don't understand the question, sorry.
>
> Given the limitations of current approach, does anyone have any other ideas
> for filtering devices prior to their initialization?
What is wrong with the functionality we have today for this very thing?
Does it not work properly for you? If so, why not, for what devices and
drivers and busses do you still have problems with?
thanks,
greg k-h