mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-27 06:55:18 +00:00
Modify USB port to be defined as a port path
So that devices can be attached to hubs. Example, to attach to first port of a usb-hub on port 1. <hub type='usb'> <address type='usb' bus='0' port='1'/> </hub> <input type='mouse' type='usb'> <address type='usb' bus='0' port='1.1'/> </hub> also add a test entry
This commit is contained in:
parent
fdabeb3c5f
commit
31710a5389
@ -2041,7 +2041,7 @@
|
|||||||
<ref name="usbAddr"/>
|
<ref name="usbAddr"/>
|
||||||
</attribute>
|
</attribute>
|
||||||
<attribute name="device">
|
<attribute name="device">
|
||||||
<ref name="usbAddr"/>
|
<ref name="usbPort"/>
|
||||||
</attribute>
|
</attribute>
|
||||||
</element>
|
</element>
|
||||||
</define>
|
</define>
|
||||||
@ -2050,7 +2050,7 @@
|
|||||||
<ref name="usbAddr"/>
|
<ref name="usbAddr"/>
|
||||||
</attribute>
|
</attribute>
|
||||||
<attribute name="port">
|
<attribute name="port">
|
||||||
<ref name="usbAddr"/>
|
<ref name="usbPort"/>
|
||||||
</attribute>
|
</attribute>
|
||||||
</define>
|
</define>
|
||||||
<define name="pciaddress">
|
<define name="pciaddress">
|
||||||
@ -2398,7 +2398,7 @@
|
|||||||
<define name="usbmaster">
|
<define name="usbmaster">
|
||||||
<element name="master">
|
<element name="master">
|
||||||
<attribute name="startport">
|
<attribute name="startport">
|
||||||
<ref name="usbAddr"/>
|
<ref name="usbPort"/>
|
||||||
</attribute>
|
</attribute>
|
||||||
<empty/>
|
<empty/>
|
||||||
</element>
|
</element>
|
||||||
@ -2549,6 +2549,11 @@
|
|||||||
<param name="pattern">(0x)?[0-9a-fA-F]{1,3}</param>
|
<param name="pattern">(0x)?[0-9a-fA-F]{1,3}</param>
|
||||||
</data>
|
</data>
|
||||||
</define>
|
</define>
|
||||||
|
<define name="usbPort">
|
||||||
|
<data type="string">
|
||||||
|
<param name="pattern">((0x)?[0-9a-fA-F]{1,3}\.){0,3}(0x)?[0-9a-fA-F]{1,3}</param>
|
||||||
|
</data>
|
||||||
|
</define>
|
||||||
<define name="pciDomain">
|
<define name="pciDomain">
|
||||||
<data type="string">
|
<data type="string">
|
||||||
<param name="pattern">(0x)?[0-9a-fA-F]{1,4}</param>
|
<param name="pattern">(0x)?[0-9a-fA-F]{1,4}</param>
|
||||||
|
@ -1444,12 +1444,9 @@ int virDomainDeviceDriveAddressIsValid(virDomainDeviceDriveAddressPtr addr ATTRI
|
|||||||
return 1; /* 0 is valid for all fields, so any successfully parsed addr is valid */
|
return 1; /* 0 is valid for all fields, so any successfully parsed addr is valid */
|
||||||
}
|
}
|
||||||
|
|
||||||
int virDomainDeviceUSBAddressIsValid(virDomainDeviceUSBAddressPtr addr)
|
int virDomainDeviceUSBAddressIsValid(virDomainDeviceUSBAddressPtr addr ATTRIBUTE_UNUSED)
|
||||||
{
|
{
|
||||||
if (addr->port >= 128) /* FIXME: is this correct */
|
return 1; /* FIXME.. any successfully parsed addr is valid */
|
||||||
return 0;
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int virDomainDeviceVirtioSerialAddressIsValid(
|
int virDomainDeviceVirtioSerialAddressIsValid(
|
||||||
@ -1472,6 +1469,10 @@ virDomainDeviceInfoIsSet(virDomainDeviceInfoPtr info, unsigned int flags)
|
|||||||
|
|
||||||
void virDomainDeviceInfoClear(virDomainDeviceInfoPtr info)
|
void virDomainDeviceInfoClear(virDomainDeviceInfoPtr info)
|
||||||
{
|
{
|
||||||
|
VIR_FREE(info->alias);
|
||||||
|
if (info->type == VIR_DOMAIN_DEVICE_ADDRESS_TYPE_USB) {
|
||||||
|
VIR_FREE(info->addr.usb.port);
|
||||||
|
}
|
||||||
VIR_FREE(info->alias);
|
VIR_FREE(info->alias);
|
||||||
memset(&info->addr, 0, sizeof(info->addr));
|
memset(&info->addr, 0, sizeof(info->addr));
|
||||||
info->type = VIR_DOMAIN_DEVICE_ADDRESS_TYPE_NONE;
|
info->type = VIR_DOMAIN_DEVICE_ADDRESS_TYPE_NONE;
|
||||||
@ -1621,7 +1622,7 @@ virDomainDeviceInfoFormat(virBufferPtr buf,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_DEVICE_ADDRESS_TYPE_USB:
|
case VIR_DOMAIN_DEVICE_ADDRESS_TYPE_USB:
|
||||||
virBufferAsprintf(buf, " bus='%d' port='%d'",
|
virBufferAsprintf(buf, " bus='%d' port='%s'",
|
||||||
info->addr.usb.bus,
|
info->addr.usb.bus,
|
||||||
info->addr.usb.port);
|
info->addr.usb.port);
|
||||||
break;
|
break;
|
||||||
@ -1837,7 +1838,8 @@ static int
|
|||||||
virDomainDeviceUSBAddressParseXML(xmlNodePtr node,
|
virDomainDeviceUSBAddressParseXML(xmlNodePtr node,
|
||||||
virDomainDeviceUSBAddressPtr addr)
|
virDomainDeviceUSBAddressPtr addr)
|
||||||
{
|
{
|
||||||
char *port, *bus;
|
char *port, *bus, *tmp;
|
||||||
|
unsigned int p;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
memset(addr, 0, sizeof(*addr));
|
memset(addr, 0, sizeof(*addr));
|
||||||
@ -1846,12 +1848,18 @@ virDomainDeviceUSBAddressParseXML(xmlNodePtr node,
|
|||||||
bus = virXMLPropString(node, "bus");
|
bus = virXMLPropString(node, "bus");
|
||||||
|
|
||||||
if (port &&
|
if (port &&
|
||||||
virStrToLong_ui(port, NULL, 10, &addr->port) < 0) {
|
((virStrToLong_ui(port, &tmp, 10, &p) < 0 || (*tmp != '\0' && *tmp != '.')) ||
|
||||||
|
(*tmp == '.' && (virStrToLong_ui(tmp + 1, &tmp, 10, &p) < 0 || (*tmp != '\0' && *tmp != '.'))) ||
|
||||||
|
(*tmp == '.' && (virStrToLong_ui(tmp + 1, &tmp, 10, &p) < 0 || (*tmp != '\0' && *tmp != '.'))) ||
|
||||||
|
(*tmp == '.' && (virStrToLong_ui(tmp + 1, &tmp, 10, &p) < 0 || (*tmp != '\0'))))) {
|
||||||
virDomainReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
virDomainReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
||||||
_("Cannot parse <address> 'port' attribute"));
|
_("Cannot parse <address> 'port' attribute"));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
addr->port = port;
|
||||||
|
port = NULL;
|
||||||
|
|
||||||
if (bus &&
|
if (bus &&
|
||||||
virStrToLong_ui(bus, NULL, 10, &addr->bus) < 0) {
|
virStrToLong_ui(bus, NULL, 10, &addr->bus) < 0) {
|
||||||
virDomainReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
virDomainReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
||||||
|
@ -110,7 +110,7 @@ typedef struct _virDomainDeviceUSBAddress virDomainDeviceUSBAddress;
|
|||||||
typedef virDomainDeviceUSBAddress *virDomainDeviceUSBAddressPtr;
|
typedef virDomainDeviceUSBAddress *virDomainDeviceUSBAddressPtr;
|
||||||
struct _virDomainDeviceUSBAddress {
|
struct _virDomainDeviceUSBAddress {
|
||||||
unsigned int bus;
|
unsigned int bus;
|
||||||
unsigned int port;
|
char *port;
|
||||||
};
|
};
|
||||||
|
|
||||||
enum virDomainControllerMaster {
|
enum virDomainControllerMaster {
|
||||||
|
@ -1334,7 +1334,7 @@ qemuBuildDeviceAddressStr(virBufferPtr buf,
|
|||||||
virBufferAsprintf(buf, ",addr=0x%x", info->addr.pci.slot);
|
virBufferAsprintf(buf, ",addr=0x%x", info->addr.pci.slot);
|
||||||
} else if (info->type == VIR_DOMAIN_DEVICE_ADDRESS_TYPE_USB) {
|
} else if (info->type == VIR_DOMAIN_DEVICE_ADDRESS_TYPE_USB) {
|
||||||
virBufferAsprintf(buf, ",bus=usb%d.0", info->addr.usb.bus);
|
virBufferAsprintf(buf, ",bus=usb%d.0", info->addr.usb.bus);
|
||||||
virBufferAsprintf(buf, ",port=%d", info->addr.usb.port);
|
virBufferAsprintf(buf, ",port=%s", info->addr.usb.port);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
1
tests/qemuxml2argvdata/qemuxml2argv-usb-ports.args
Normal file
1
tests/qemuxml2argvdata/qemuxml2argv-usb-ports.args
Normal file
@ -0,0 +1 @@
|
|||||||
|
LC_ALL=C PATH=/bin HOME=/home/test USER=test LOGNAME=test /usr/bin/qemu -S -M pc -m 214 -smp 1 -nographic -nodefconfig -nodefaults -chardev socket,id=charmonitor,path=/tmp/test-monitor,server,nowait -mon chardev=charmonitor,id=monitor,mode=readline -no-acpi -boot c -usb -device usb-hub,id=hub0,bus=usb0.0,port=1 -device usb-hub,id=hub1,bus=usb0.0,port=1.2 -device usb-mouse,id=input0,bus=usb0.0,port=1.1 -device usb-mouse,id=input1,bus=usb0.0,port=1.2.1 -device usb-mouse,id=input2,bus=usb0.0,port=1.2.2 -device virtio-balloon-pci,id=balloon0,bus=pci.0,addr=0x4
|
31
tests/qemuxml2argvdata/qemuxml2argv-usb-ports.xml
Normal file
31
tests/qemuxml2argvdata/qemuxml2argv-usb-ports.xml
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
<domain type='qemu'>
|
||||||
|
<name>QEMUGuest1</name>
|
||||||
|
<uuid>c7a5fdbd-edaf-9455-926a-d65c16db1809</uuid>
|
||||||
|
<memory>219136</memory>
|
||||||
|
<currentMemory>219200</currentMemory>
|
||||||
|
<vcpu>1</vcpu>
|
||||||
|
<os>
|
||||||
|
<type arch='i686' machine='pc'>hvm</type>
|
||||||
|
<boot dev='hd'/>
|
||||||
|
</os>
|
||||||
|
<devices>
|
||||||
|
<emulator>/usr/bin/qemu</emulator>
|
||||||
|
<controller type='usb' index='0'/>
|
||||||
|
<memballoon model='virtio'/>
|
||||||
|
<hub type='usb'>
|
||||||
|
<address type='usb' bus='0' port='1'/>
|
||||||
|
</hub>
|
||||||
|
<input type='mouse' bus='usb'>
|
||||||
|
<address type='usb' bus='0' port='1.1'/>
|
||||||
|
</input>
|
||||||
|
<hub type='usb'>
|
||||||
|
<address type='usb' bus='0' port='1.2'/>
|
||||||
|
</hub>
|
||||||
|
<input type='mouse' bus='usb'>
|
||||||
|
<address type='usb' bus='0' port='1.2.1'/>
|
||||||
|
</input>
|
||||||
|
<input type='mouse' bus='usb'>
|
||||||
|
<address type='usb' bus='0' port='1.2.2'/>
|
||||||
|
</input>
|
||||||
|
</devices>
|
||||||
|
</domain>
|
@ -504,6 +504,9 @@ mymain(void)
|
|||||||
DO_TEST("usb-hub", false,
|
DO_TEST("usb-hub", false,
|
||||||
QEMU_CAPS_CHARDEV, QEMU_CAPS_DEVICE, QEMU_CAPS_USB_HUB,
|
QEMU_CAPS_CHARDEV, QEMU_CAPS_DEVICE, QEMU_CAPS_USB_HUB,
|
||||||
QEMU_CAPS_NODEFCONFIG);
|
QEMU_CAPS_NODEFCONFIG);
|
||||||
|
DO_TEST("usb-ports", false,
|
||||||
|
QEMU_CAPS_CHARDEV, QEMU_CAPS_DEVICE, QEMU_CAPS_USB_HUB,
|
||||||
|
QEMU_CAPS_NODEFCONFIG);
|
||||||
|
|
||||||
DO_TEST("smbios", false, QEMU_CAPS_SMBIOS_TYPE);
|
DO_TEST("smbios", false, QEMU_CAPS_SMBIOS_TYPE);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user