David Gibson <david@xxxxxxxxxxxxxxxxxxxxx> writes: > On Thu, Jun 04, 2020 at 01:39:22AM -0300, Thiago Jung Bauermann wrote: >> >> Hello David, >> >> David Gibson <david@xxxxxxxxxxxxxxxxxxxxx> writes: >> >> > A number of hardware platforms are implementing mechanisms whereby the >> > hypervisor does not have unfettered access to guest memory, in order >> > to mitigate the security impact of a compromised hypervisor. >> > >> > AMD's SEV implements this with in-cpu memory encryption, and Intel has >> > its own memory encryption mechanism. POWER has an upcoming mechanism >> > to accomplish this in a different way, using a new memory protection >> > level plus a small trusted ultravisor. s390 also has a protected >> > execution environment. >> > >> > The current code (committed or draft) for these features has each >> > platform's version configured entirely differently. That doesn't seem >> > ideal for users, or particularly for management layers. >> > >> > AMD SEV introduces a notionally generic machine option >> > "machine-encryption", but it doesn't actually cover any cases other >> > than SEV. >> > >> > This series is a proposal to at least partially unify configuration >> > for these mechanisms, by renaming and generalizing AMD's >> > "memory-encryption" property. It is replaced by a >> > "guest-memory-protection" property pointing to a platform specific >> > object which configures and manages the specific details. >> > >> > For now this series covers just AMD SEV and POWER PEF. I'm hoping it >> >> Thank you very much for this series! Using a machine property is a nice >> way of configuring this. >> >> >From an end-user perspective, `-M pseries,guest-memory-protection` in >> the command line already expresses everything that QEMU needs to know, >> so having to add `-object pef-guest,id=pef0` seems a bit redundant. Is >> it possible to make QEMU create the pef-guest object behind the scenes >> when the guest-memory-protection property is specified? > > Not exactly - the object needs to exist for the QOM core to resolve it > before we'd have a chance to look at the value to conditionally create > the object. > > What we could do, however, is always create a PEF object in the > machine, and it would just have no effect if the machine parameter > wasn't specified. > > I did consider that option, but left it this way for greater > consistency with AMD SEV - there the object can't be auto-created, > since it has mandatory parameters needed to configure the encryption. > > I'm open to persuasion about changing that, though. What about having it both ways? QEMU could always create a PEF object, and if the command line defines one, it will correspond to it. And if the command line doesn't define one, then it would also work because the PEF object is already there. That way, compatibility with AMD SEV is preserved but we also get command line simplicity where it is not needed. -- Thiago Jung Bauermann IBM Linux Technology Center