From ab06c61d1a4a3dc993018a45241b31ecb9082e28 Mon Sep 17 00:00:00 2001 From: Mathias Gibbens Date: Thu, 12 Sep 2024 12:12:24 -0600 Subject: [PATCH] internal/server/instance/drivers: Disable 9p and vsock for Windows VMs Windows guests don't support virtiofs-9p or virtio-vsock devices, so don't include them in the generated qemu config. Depends on the instance's configuration field `image.os` containing the string "Windows" somewhere in its value. Signed-off-by: Mathias Gibbens --- .../server/instance/drivers/driver_qemu.go | 82 ++++++++++--------- 1 file changed, 44 insertions(+), 38 deletions(-) diff --git a/internal/server/instance/drivers/driver_qemu.go b/internal/server/instance/drivers/driver_qemu.go index 58e3421355d..f92a48b84b1 100644 --- a/internal/server/instance/drivers/driver_qemu.go +++ b/internal/server/instance/drivers/driver_qemu.go @@ -3384,25 +3384,28 @@ func (d *qemu) generateQemuConfigFile(cpuInfo *cpuTopology, mountInfo *storagePo cfg = append(cfg, qemuTablet(&tabletOpts)...) - // Existing vsock ID from volatile. - vsockID, err := d.getVsockID() - if err != nil { - return "", nil, err - } + // Windows doesn't support virtio-vsock. + if !strings.Contains(strings.ToLower(d.expandedConfig["image.os"]), "windows") { + // Existing vsock ID from volatile. + vsockID, err := d.getVsockID() + if err != nil { + return "", nil, err + } - devBus, devAddr, multi = bus.allocate(busFunctionGroupGeneric) - vsockOpts := qemuVsockOpts{ - dev: qemuDevOpts{ - busName: bus.name, - devBus: devBus, - devAddr: devAddr, - multifunction: multi, - }, - vsockFD: vsockFD, - vsockID: vsockID, - } + devBus, devAddr, multi = bus.allocate(busFunctionGroupGeneric) + vsockOpts := qemuVsockOpts{ + dev: qemuDevOpts{ + busName: bus.name, + devBus: devBus, + devAddr: devAddr, + multifunction: multi, + }, + vsockFD: vsockFD, + vsockID: vsockID, + } - cfg = append(cfg, qemuVsock(&vsockOpts)...) + cfg = append(cfg, qemuVsock(&vsockOpts)...) + } devBus, devAddr, multi = bus.allocate(busFunctionGroupGeneric) serialOpts := qemuSerialOpts{ @@ -3450,25 +3453,10 @@ func (d *qemu) generateQemuConfigFile(cpuInfo *cpuTopology, mountInfo *storagePo cfg = append(cfg, qemuSCSI(&scsiOpts)...) - // Always export the config directory as a 9p config drive, in case the host or VM guest doesn't support - // virtio-fs. - devBus, devAddr, multi = bus.allocate(busFunctionGroup9p) - driveConfig9pOpts := qemuDriveConfigOpts{ - dev: qemuDevOpts{ - busName: bus.name, - devBus: devBus, - devAddr: devAddr, - multifunction: multi, - }, - name: "config", - protocol: "9p", - path: d.configDriveMountPath(), - } - - cfg = append(cfg, qemuDriveConfig(&driveConfig9pOpts)...) - - // Pass in the agents if INCUS_AGENT_PATH is set. - if util.PathExists(os.Getenv("INCUS_AGENT_PATH")) { + // Windows doesn't support virtio-9p. + if !strings.Contains(strings.ToLower(d.expandedConfig["image.os"]), "windows") { + // Always export the config directory as a 9p config drive, in case the host or VM guest doesn't support + // virtio-fs. devBus, devAddr, multi = bus.allocate(busFunctionGroup9p) driveConfig9pOpts := qemuDriveConfigOpts{ dev: qemuDevOpts{ @@ -3477,12 +3465,30 @@ func (d *qemu) generateQemuConfigFile(cpuInfo *cpuTopology, mountInfo *storagePo devAddr: devAddr, multifunction: multi, }, - name: "agent", + name: "config", protocol: "9p", - path: os.Getenv("INCUS_AGENT_PATH"), + path: d.configDriveMountPath(), } cfg = append(cfg, qemuDriveConfig(&driveConfig9pOpts)...) + + // Pass in the agents if INCUS_AGENT_PATH is set. + if util.PathExists(os.Getenv("INCUS_AGENT_PATH")) { + devBus, devAddr, multi = bus.allocate(busFunctionGroup9p) + driveConfig9pOpts := qemuDriveConfigOpts{ + dev: qemuDevOpts{ + busName: bus.name, + devBus: devBus, + devAddr: devAddr, + multifunction: multi, + }, + name: "agent", + protocol: "9p", + path: os.Getenv("INCUS_AGENT_PATH"), + } + + cfg = append(cfg, qemuDriveConfig(&driveConfig9pOpts)...) + } } // If user has requested AMD SEV, check if supported and add to QEMU config.