mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-12-31 18:15:25 +00:00
llow to add a disk as an USB device (QEmu/KVM)
* src/domain_conf.c src/domain_conf.h src/qemu_conf.c src/qemu_driver.c: patch from Guido Günther allowing to add disk as USB devices * docs/libvirt.rng: extend the schemas for the new value * tests/qemuxml2argvdata/qemuxml2argv-disk-usb.args tests/qemuxml2argvdata/qemuxml2argv-disk-usb.xml tests/qemuxml2argvtest.c tests/qemuxml2xmltest.c: add a specific test to the regression suite Daniel
This commit is contained in:
parent
d1710d35ea
commit
5ba372306a
11
ChangeLog
11
ChangeLog
@ -1,3 +1,14 @@
|
|||||||
|
Fri Aug 8 16:53:24 CEST 2008 Daniel Veillard <veillard@redhat.com>
|
||||||
|
|
||||||
|
* src/domain_conf.c src/domain_conf.h src/qemu_conf.c
|
||||||
|
src/qemu_driver.c: patch from Guido Günther allowing to add
|
||||||
|
disk as USB devices
|
||||||
|
* docs/libvirt.rng: extend the schemas for the new value
|
||||||
|
* tests/qemuxml2argvdata/qemuxml2argv-disk-usb.args
|
||||||
|
tests/qemuxml2argvdata/qemuxml2argv-disk-usb.xml
|
||||||
|
tests/qemuxml2argvtest.c tests/qemuxml2xmltest.c: add a specific
|
||||||
|
test to the regression suite
|
||||||
|
|
||||||
Fri Aug 8 16:15:55 CEST 2008 Daniel Veillard <veillard@redhat.com>
|
Fri Aug 8 16:15:55 CEST 2008 Daniel Veillard <veillard@redhat.com>
|
||||||
|
|
||||||
* src/domain_conf.c src/domain_conf.h src/qemu_conf.c
|
* src/domain_conf.c src/domain_conf.h src/qemu_conf.c
|
||||||
|
@ -412,6 +412,7 @@
|
|||||||
<value>virtio</value>
|
<value>virtio</value>
|
||||||
<value>fdc</value>
|
<value>fdc</value>
|
||||||
<value>xen</value>
|
<value>xen</value>
|
||||||
|
<value>usb</value>
|
||||||
</choice>
|
</choice>
|
||||||
</attribute>
|
</attribute>
|
||||||
</optional>
|
</optional>
|
||||||
|
@ -84,7 +84,8 @@ VIR_ENUM_IMPL(virDomainDiskBus, VIR_DOMAIN_DISK_BUS_LAST,
|
|||||||
"fdc",
|
"fdc",
|
||||||
"scsi",
|
"scsi",
|
||||||
"virtio",
|
"virtio",
|
||||||
"xen")
|
"xen",
|
||||||
|
"usb")
|
||||||
|
|
||||||
VIR_ENUM_IMPL(virDomainFS, VIR_DOMAIN_FS_TYPE_LAST,
|
VIR_ENUM_IMPL(virDomainFS, VIR_DOMAIN_FS_TYPE_LAST,
|
||||||
"mount",
|
"mount",
|
||||||
|
@ -72,6 +72,7 @@ enum virDomainDiskBus {
|
|||||||
VIR_DOMAIN_DISK_BUS_SCSI,
|
VIR_DOMAIN_DISK_BUS_SCSI,
|
||||||
VIR_DOMAIN_DISK_BUS_VIRTIO,
|
VIR_DOMAIN_DISK_BUS_VIRTIO,
|
||||||
VIR_DOMAIN_DISK_BUS_XEN,
|
VIR_DOMAIN_DISK_BUS_XEN,
|
||||||
|
VIR_DOMAIN_DISK_BUS_USB,
|
||||||
|
|
||||||
VIR_DOMAIN_DISK_BUS_LAST
|
VIR_DOMAIN_DISK_BUS_LAST
|
||||||
};
|
};
|
||||||
|
@ -55,7 +55,8 @@ VIR_ENUM_IMPL(virDomainDiskQEMUBus, VIR_DOMAIN_DISK_BUS_LAST,
|
|||||||
"floppy",
|
"floppy",
|
||||||
"scsi",
|
"scsi",
|
||||||
"virtio",
|
"virtio",
|
||||||
"xen")
|
"xen",
|
||||||
|
"usb")
|
||||||
|
|
||||||
|
|
||||||
#define qemudLog(level, msg...) fprintf(stderr, msg)
|
#define qemudLog(level, msg...) fprintf(stderr, msg)
|
||||||
@ -772,6 +773,16 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
|||||||
goto no_memory; \
|
goto no_memory; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
#define ADD_USBDISK(thisarg) \
|
||||||
|
do { \
|
||||||
|
ADD_ARG_LIT("-usbdevice"); \
|
||||||
|
ADD_ARG_SPACE; \
|
||||||
|
if ((asprintf(&qargv[qargc++], "disk:%s", thisarg)) == -1) { \
|
||||||
|
qargv[qargc-1] = NULL; \
|
||||||
|
goto no_memory; \
|
||||||
|
} \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
snprintf(memory, sizeof(memory), "%lu", vm->def->memory/1024);
|
snprintf(memory, sizeof(memory), "%lu", vm->def->memory/1024);
|
||||||
snprintf(vcpus, sizeof(vcpus), "%lu", vm->def->vcpus);
|
snprintf(vcpus, sizeof(vcpus), "%lu", vm->def->vcpus);
|
||||||
|
|
||||||
@ -883,6 +894,18 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
|||||||
int idx = virDiskNameToIndex(disk->dst);
|
int idx = virDiskNameToIndex(disk->dst);
|
||||||
const char *bus = virDomainDiskQEMUBusTypeToString(disk->bus);
|
const char *bus = virDomainDiskQEMUBusTypeToString(disk->bus);
|
||||||
|
|
||||||
|
if (disk->bus == VIR_DOMAIN_DISK_BUS_USB) {
|
||||||
|
if (disk->device == VIR_DOMAIN_DISK_DEVICE_DISK) {
|
||||||
|
ADD_USBDISK(disk->src);
|
||||||
|
} else {
|
||||||
|
qemudReportError(conn, NULL, NULL, VIR_ERR_INTERNAL_ERROR,
|
||||||
|
_("unsupported usb disk type for '%s'"), disk->src);
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
disk = disk->next;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (idx < 0) {
|
if (idx < 0) {
|
||||||
qemudReportError(conn, NULL, NULL, VIR_ERR_INTERNAL_ERROR,
|
qemudReportError(conn, NULL, NULL, VIR_ERR_INTERNAL_ERROR,
|
||||||
_("unsupported disk type '%s'"), disk->dst);
|
_("unsupported disk type '%s'"), disk->dst);
|
||||||
@ -922,6 +945,18 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
|||||||
char dev[NAME_MAX];
|
char dev[NAME_MAX];
|
||||||
char file[PATH_MAX];
|
char file[PATH_MAX];
|
||||||
|
|
||||||
|
if (disk->bus == VIR_DOMAIN_DISK_BUS_USB) {
|
||||||
|
if (disk->device == VIR_DOMAIN_DISK_DEVICE_DISK) {
|
||||||
|
ADD_USBDISK(disk->src);
|
||||||
|
} else {
|
||||||
|
qemudReportError(conn, NULL, NULL, VIR_ERR_INTERNAL_ERROR,
|
||||||
|
_("unsupported usb disk type for '%s'"), disk->src);
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
disk = disk->next;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (STREQ(disk->dst, "hdc") &&
|
if (STREQ(disk->dst, "hdc") &&
|
||||||
disk->device == VIR_DOMAIN_DISK_DEVICE_CDROM) {
|
disk->device == VIR_DOMAIN_DISK_DEVICE_CDROM) {
|
||||||
if (disk->src) {
|
if (disk->src) {
|
||||||
|
@ -2984,6 +2984,48 @@ static int qemudDomainAttachCdromDevice(virDomainPtr dom,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int qemudDomainAttachUsbMassstorageDevice(virDomainPtr dom, virDomainDeviceDefPtr dev)
|
||||||
|
{
|
||||||
|
struct qemud_driver *driver = (struct qemud_driver *)dom->conn->privateData;
|
||||||
|
virDomainObjPtr vm = virDomainFindByUUID(driver->domains, dom->uuid);
|
||||||
|
int ret;
|
||||||
|
char *cmd, *reply;
|
||||||
|
|
||||||
|
if (!vm) {
|
||||||
|
qemudReportError(dom->conn, dom, NULL, VIR_ERR_INVALID_DOMAIN,
|
||||||
|
"%s", _("no domain with matching uuid"));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = asprintf(&cmd, "usb_add disk:%s", dev->data.disk->src);
|
||||||
|
if (ret == -1) {
|
||||||
|
qemudReportError(dom->conn, NULL, NULL, VIR_ERR_NO_MEMORY, NULL);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (qemudMonitorCommand(driver, vm, cmd, &reply) < 0) {
|
||||||
|
qemudReportError(dom->conn, dom, NULL, VIR_ERR_OPERATION_FAILED,
|
||||||
|
"%s", _("cannot attach usb device"));
|
||||||
|
VIR_FREE(cmd);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
DEBUG ("attach_usb reply: %s", reply);
|
||||||
|
/* If the command failed qemu prints:
|
||||||
|
* Could not add ... */
|
||||||
|
if (strstr(reply, "Could not add ")) {
|
||||||
|
qemudReportError (dom->conn, dom, NULL, VIR_ERR_OPERATION_FAILED,
|
||||||
|
"%s",
|
||||||
|
_("adding usb device failed"));
|
||||||
|
VIR_FREE(reply);
|
||||||
|
VIR_FREE(cmd);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
VIR_FREE(reply);
|
||||||
|
VIR_FREE(cmd);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int qemudDomainAttachHostDevice(virDomainPtr dom, virDomainDeviceDefPtr dev)
|
static int qemudDomainAttachHostDevice(virDomainPtr dom, virDomainDeviceDefPtr dev)
|
||||||
{
|
{
|
||||||
struct qemud_driver *driver = (struct qemud_driver *)dom->conn->privateData;
|
struct qemud_driver *driver = (struct qemud_driver *)dom->conn->privateData;
|
||||||
@ -3061,6 +3103,10 @@ static int qemudDomainAttachDevice(virDomainPtr dom,
|
|||||||
if (dev->type == VIR_DOMAIN_DEVICE_DISK &&
|
if (dev->type == VIR_DOMAIN_DEVICE_DISK &&
|
||||||
dev->data.disk->device == VIR_DOMAIN_DISK_DEVICE_CDROM) {
|
dev->data.disk->device == VIR_DOMAIN_DISK_DEVICE_CDROM) {
|
||||||
ret = qemudDomainAttachCdromDevice(dom, dev);
|
ret = qemudDomainAttachCdromDevice(dom, dev);
|
||||||
|
} else if (dev->type == VIR_DOMAIN_DEVICE_DISK &&
|
||||||
|
dev->data.disk->device == VIR_DOMAIN_DEVICE_DISK &&
|
||||||
|
dev->data.disk->bus == VIR_DOMAIN_DISK_BUS_USB) {
|
||||||
|
ret = qemudDomainAttachUsbMassstorageDevice(dom, dev);
|
||||||
} else if (dev->type == VIR_DOMAIN_DEVICE_HOSTDEV &&
|
} else if (dev->type == VIR_DOMAIN_DEVICE_HOSTDEV &&
|
||||||
dev->data.hostdev->mode == VIR_DOMAIN_HOSTDEV_MODE_SUBSYS &&
|
dev->data.hostdev->mode == VIR_DOMAIN_HOSTDEV_MODE_SUBSYS &&
|
||||||
dev->data.hostdev->source.subsys.type == VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_USB) {
|
dev->data.hostdev->source.subsys.type == VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_USB) {
|
||||||
|
1
tests/qemuxml2argvdata/qemuxml2argv-disk-usb.args
Normal file
1
tests/qemuxml2argvdata/qemuxml2argv-disk-usb.args
Normal file
@ -0,0 +1 @@
|
|||||||
|
/usr/bin/qemu -S -M pc -m 214 -smp 1 -nographic -monitor pty -no-acpi -boot c -hda /dev/HostVG/QEMUGuest1 -usbdevice disk:/tmp/usbdisk.img -net none -serial none -parallel none -usb
|
26
tests/qemuxml2argvdata/qemuxml2argv-disk-usb.xml
Normal file
26
tests/qemuxml2argvdata/qemuxml2argv-disk-usb.xml
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
<domain type='qemu'>
|
||||||
|
<name>QEMUGuest1</name>
|
||||||
|
<uuid>c7a5fdbd-edaf-9455-926a-d65c16db1809</uuid>
|
||||||
|
<memory>219200</memory>
|
||||||
|
<currentMemory>219200</currentMemory>
|
||||||
|
<vcpu>1</vcpu>
|
||||||
|
<os>
|
||||||
|
<type arch='i686' machine='pc'>hvm</type>
|
||||||
|
<boot dev='hd'/>
|
||||||
|
</os>
|
||||||
|
<clock offset='utc'/>
|
||||||
|
<on_poweroff>destroy</on_poweroff>
|
||||||
|
<on_reboot>restart</on_reboot>
|
||||||
|
<on_crash>destroy</on_crash>
|
||||||
|
<devices>
|
||||||
|
<emulator>/usr/bin/qemu</emulator>
|
||||||
|
<disk type='block' device='disk'>
|
||||||
|
<source dev='/dev/HostVG/QEMUGuest1'/>
|
||||||
|
<target dev='hda' bus='ide'/>
|
||||||
|
</disk>
|
||||||
|
<disk type='file' device='disk'>
|
||||||
|
<source file='/tmp/usbdisk.img'/>
|
||||||
|
<target dev='sda' bus='usb'/>
|
||||||
|
</disk>
|
||||||
|
</devices>
|
||||||
|
</domain>
|
@ -156,6 +156,7 @@ mymain(int argc, char **argv)
|
|||||||
QEMUD_CMD_FLAG_DRIVE_BOOT);
|
QEMUD_CMD_FLAG_DRIVE_BOOT);
|
||||||
DO_TEST("disk-drive-boot-cdrom", QEMUD_CMD_FLAG_DRIVE |
|
DO_TEST("disk-drive-boot-cdrom", QEMUD_CMD_FLAG_DRIVE |
|
||||||
QEMUD_CMD_FLAG_DRIVE_BOOT);
|
QEMUD_CMD_FLAG_DRIVE_BOOT);
|
||||||
|
DO_TEST("disk-usb", 0);
|
||||||
DO_TEST("graphics-vnc", 0);
|
DO_TEST("graphics-vnc", 0);
|
||||||
DO_TEST("graphics-sdl", 0);
|
DO_TEST("graphics-sdl", 0);
|
||||||
DO_TEST("input-usbmouse", 0);
|
DO_TEST("input-usbmouse", 0);
|
||||||
|
@ -95,6 +95,7 @@ mymain(int argc, char **argv)
|
|||||||
DO_TEST("disk-floppy");
|
DO_TEST("disk-floppy");
|
||||||
DO_TEST("disk-many");
|
DO_TEST("disk-many");
|
||||||
DO_TEST("disk-xenvbd");
|
DO_TEST("disk-xenvbd");
|
||||||
|
DO_TEST("disk-usb");
|
||||||
DO_TEST("graphics-vnc");
|
DO_TEST("graphics-vnc");
|
||||||
DO_TEST("graphics-sdl");
|
DO_TEST("graphics-sdl");
|
||||||
DO_TEST("input-usbmouse");
|
DO_TEST("input-usbmouse");
|
||||||
|
Loading…
Reference in New Issue
Block a user