mirror of
https://github.com/virt-manager/virt-manager.git
synced 2025-01-10 01:18:03 +03:00
virtinst: guest: Fill in SEV platform specific data automatically
The data in question are 'cbitpos' denoting which addressing bit is the encryption bit and 'reduced_phys_bits' denoting how many physical address space we lose by turning on the encryption. Both of these are hypervisor dependent and thus will be the same for all the guest residing on the same host, but need to be specified for future migration purposes. But given we can probe them from domain capabilities, we don't need the user to provide them and thus enhancing cli user experience. This requires a new _SEV domaincapabilities XML class to be created so that we can query the specific properties. Reviewed-by: Cole Robinson <crobinso@redhat.com> Signed-off-by: Erik Skultety <eskultet@redhat.com>
This commit is contained in:
parent
480a6834c2
commit
1a8728fc2d
@ -0,0 +1,61 @@
|
||||
<domain type="kvm">
|
||||
<name>foobar</name>
|
||||
<uuid>00000000-1111-2222-3333-444444444444</uuid>
|
||||
<memory>65536</memory>
|
||||
<currentMemory>65536</currentMemory>
|
||||
<vcpu>1</vcpu>
|
||||
<os>
|
||||
<type arch="x86_64" machine="q35">hvm</type>
|
||||
<loader readonly="yes" type="pflash">/usr/share/edk2/ovmf/OVMF_CODE.fd</loader>
|
||||
<boot dev="hd"/>
|
||||
</os>
|
||||
<features>
|
||||
<acpi/>
|
||||
<apic/>
|
||||
<vmport state="off"/>
|
||||
</features>
|
||||
<cpu mode="host-model"/>
|
||||
<clock offset="utc">
|
||||
<timer name="rtc" tickpolicy="catchup"/>
|
||||
<timer name="pit" tickpolicy="delay"/>
|
||||
<timer name="hpet" present="no"/>
|
||||
</clock>
|
||||
<pm>
|
||||
<suspend-to-mem enabled="no"/>
|
||||
<suspend-to-disk enabled="no"/>
|
||||
</pm>
|
||||
<devices>
|
||||
<emulator>/usr/bin/qemu-kvm</emulator>
|
||||
<controller type="usb" index="0" model="ich9-ehci1"/>
|
||||
<controller type="usb" index="0" model="ich9-uhci1">
|
||||
<master startport="0"/>
|
||||
</controller>
|
||||
<controller type="usb" index="0" model="ich9-uhci2">
|
||||
<master startport="2"/>
|
||||
</controller>
|
||||
<controller type="usb" index="0" model="ich9-uhci3">
|
||||
<master startport="4"/>
|
||||
</controller>
|
||||
<interface type="bridge">
|
||||
<source bridge="testsuitebr0"/>
|
||||
<mac address="00:11:22:33:44:55"/>
|
||||
<model type="e1000e"/>
|
||||
</interface>
|
||||
<console type="pty"/>
|
||||
<input type="tablet" bus="usb"/>
|
||||
<graphics type="spice" port="-1" tlsPort="-1" autoport="yes">
|
||||
<image compression="off"/>
|
||||
</graphics>
|
||||
<sound model="ich9"/>
|
||||
<video>
|
||||
<model type="qxl"/>
|
||||
</video>
|
||||
<redirdev bus="usb" type="spicevmc"/>
|
||||
<redirdev bus="usb" type="spicevmc"/>
|
||||
</devices>
|
||||
<launchSecurity type="sev">
|
||||
<cbitpos>47</cbitpos>
|
||||
<reducedPhysBits>1</reducedPhysBits>
|
||||
<policy>0x03</policy>
|
||||
</launchSecurity>
|
||||
</domain>
|
@ -898,6 +898,7 @@ c.add_invalid("--disk none --location nfs:example.com/fake --nonetworks") # Usi
|
||||
|
||||
c = vinst.add_category("kvm-x86_64-launch-security", "--disk none --noautoconsole")
|
||||
c.add_compare("--boot uefi --machine q35 --launchSecurity type=sev,reducedPhysBits=1,policy=0x0001,cbitpos=47,dhCert=BASE64CERT,session=BASE64SESSION --connect " + utils.URIs.kvm_amd_sev, "x86_64-launch-security-sev-full") # Full cmdline
|
||||
c.add_compare("--boot uefi --machine q35 --launchSecurity sev --connect " + utils.URIs.kvm_amd_sev, "x86_64-launch-security-sev") # Fill in platform data from domcaps
|
||||
c.add_valid("--boot uefi --machine q35 --launchSecurity sev,reducedPhysBits=1,cbitpos=47 --connect " + utils.URIs.kvm_amd_sev) # Default policy == 0x0003 will be used
|
||||
c.add_invalid("--launchSecurity policy=0x0001 --connect " + utils.URIs.kvm_amd_sev) # Missing launchSecurity 'type'
|
||||
|
||||
|
@ -24,7 +24,9 @@ class DomainLaunchSecurity(XMLBuilder):
|
||||
if not self.type:
|
||||
raise RuntimeError(_("Missing mandatory attribute 'type'"))
|
||||
|
||||
def _set_defaults_sev(self):
|
||||
def _set_defaults_sev(self, guest):
|
||||
domcaps = guest.lookup_domcaps()
|
||||
|
||||
# 'policy' is a mandatory 4-byte argument for the SEV firmware,
|
||||
# if missing, let's use 0x03 which, according to the table at
|
||||
# https://libvirt.org/formatdomain.html#launchSecurity:
|
||||
@ -33,6 +35,11 @@ class DomainLaunchSecurity(XMLBuilder):
|
||||
if self.policy is None:
|
||||
self.policy = "0x03"
|
||||
|
||||
if self.cbitpos is None:
|
||||
self.cbitpos = domcaps.features.sev.cbitpos
|
||||
if self.reducedPhysBits is None:
|
||||
self.reducedPhysBits = domcaps.features.sev.reducedPhysBits
|
||||
|
||||
def set_defaults(self, guest):
|
||||
if self.is_sev():
|
||||
return self._set_defaults_sev()
|
||||
return self._set_defaults_sev(guest)
|
||||
|
@ -71,6 +71,16 @@ def _make_capsblock(xml_root_name):
|
||||
return TmpClass
|
||||
|
||||
|
||||
################################
|
||||
# SEV launch security handling #
|
||||
################################
|
||||
|
||||
class _SEV(XMLBuilder):
|
||||
XML_NAME = "sev"
|
||||
cbitpos = XMLProperty("./cbitpos", is_int=True)
|
||||
reducedPhysBits = XMLProperty("./reducedPhysBits", is_int=True)
|
||||
|
||||
|
||||
#############################
|
||||
# Misc toplevel XML classes #
|
||||
#############################
|
||||
@ -89,6 +99,7 @@ class _Devices(_CapsBlock):
|
||||
class _Features(_CapsBlock):
|
||||
XML_NAME = "features"
|
||||
gic = XMLChildProperty(_make_capsblock("gic"), is_single=True)
|
||||
sev = XMLChildProperty(_SEV, is_single=True)
|
||||
|
||||
|
||||
###############
|
||||
|
Loading…
Reference in New Issue
Block a user