fsdetails: Show virtio-9p vs virtiofs driver field

Signed-off-by: Cole Robinson <crobinso@redhat.com>
This commit is contained in:
Cole Robinson 2022-02-19 09:49:01 -05:00
parent d65d31cea2
commit a7682fc9eb
2 changed files with 28 additions and 13 deletions

View File

@ -97,10 +97,19 @@ class vmmFSDetails(vmmGObjectUI):
else:
simple_store_set("fs-type-combo", [DeviceFilesystem.TYPE_MOUNT])
simple_store_set("fs-driver-combo",
[DeviceFilesystem.DRIVER_LOOP,
DeviceFilesystem.DRIVER_NBD,
None])
if self.conn.is_container_only():
simple_store_set("fs-driver-combo",
[DeviceFilesystem.DRIVER_LOOP,
DeviceFilesystem.DRIVER_NBD,
None])
else:
domcaps = self.vm.get_domain_capabilities()
rows = []
if domcaps.supports_filesystem_virtiofs():
rows.append(["virtiofs", "virtiofs"])
rows.append([None, "virtio-9p"])
uiutil.build_simple_combo(
self.widget("fs-driver-combo"), rows, sort=False)
simple_store_set("fs-format-combo", ["raw", "qcow2"])
self.widget("fs-readonly").set_visible(
@ -129,7 +138,7 @@ class vmmFSDetails(vmmGObjectUI):
uiutil.set_grid_row_visible(
self.widget("fs-format-combo"), show_format)
show_driver_combo = fstype == DeviceFilesystem.TYPE_FILE
show_driver_combo = is_qemu or fstype == DeviceFilesystem.TYPE_FILE
if fstype == DeviceFilesystem.TYPE_TEMPLATE:
source_text = _("Te_mplate:")
@ -213,7 +222,11 @@ class vmmFSDetails(vmmGObjectUI):
if _EDIT_FS_READONLY in self._active_edits:
dev.readonly = readonly
if _EDIT_FS_DRIVER in self._active_edits:
origdriver = dev.driver_type
dev.driver_type = driver
if origdriver == "virtiofs" or driver == "virtiofs":
# Need to reset the accessmode for virtiofs
dev.accessmode = dev.default_accessmode()
if _EDIT_FS_FORMAT in self._active_edits:
dev.driver_format = fsformat

View File

@ -127,6 +127,15 @@ class DeviceFilesystem(Device):
if self.target:
self.validate_target(self.target)
def default_accessmode(self):
if self.driver_type == "virtiofs":
# let libvirt fill in default accessmode=passthrough
return None
# libvirt qemu defaults to accessmode=passthrough, but that
# really only works well for qemu running as root, which is
# not the common case. so use mode=mapped
return self.MODE_MAPPED
##################
# Default config #
@ -146,11 +155,4 @@ class DeviceFilesystem(Device):
self.type = self.TYPE_MOUNT
if self.accessmode is None:
if self.driver_type == "virtiofs":
# let libvirt fill in default accessmode=passthrough
pass
else:
# libvirt qemu defaults to accessmode=passthrough, but that
# really only works well for qemu running as root, which is
# not the common case. so use mode=mapped
self.accessmode = self.MODE_MAPPED
self.accessmode = self.default_accessmode()