virBufferAsprintf(buf, "<bus>%d</bus>\n", data->usb_dev.bus);
virBufferAsprintf(buf, "<device>%d</device>\n",
data->usb_dev.device);
+ if (data->usb_dev.port)
+ virBufferEscapeString(buf, "<port>%s</port>\n",
+ data->usb_dev.port);
virBufferAsprintf(buf, "<product id='0x%04x'",
data->usb_dev.product);
if (data->usb_dev.product_name)
_("invalid USB product ID supplied for '%1$s'")) < 0)
return -1;
+ usb_dev->port = virXPathString("string(./port[1])", ctxt);
usb_dev->vendor_name = virXPathString("string(./vendor[1])", ctxt);
usb_dev->product_name = virXPathString("string(./product[1])", ctxt);
case VIR_NODE_DEV_CAP_USB_DEV:
g_free(data->usb_dev.product_name);
g_free(data->usb_dev.vendor_name);
+ g_free(data->usb_dev.port);
break;
case VIR_NODE_DEV_CAP_USB_INTERFACE:
g_free(data->usb_if.description);
struct _virNodeDevCapUSBDev {
unsigned int bus;
unsigned int device;
+ char *port;
unsigned int product;
unsigned int vendor;
char *product_name;
</choice>
</define>
+ <define name="usbIdDefault">
+ <data type="string">
+ <param name="pattern">-1</param>
+ </data>
+ </define>
+ <define name="usbId">
+ <data type="string">
+ <param name="pattern">(0x)?[0-9a-fA-F]{1,4}</param>
+ </data>
+ </define>
+ <define name="usbVersion">
+ <data type="string">
+ <param name="pattern">[0-9]{1,2}.[0-9]{1,2}</param>
+ </data>
+ </define>
+ <define name="usbAddr">
+ <data type="string">
+ <param name="pattern">(0x)?[0-9a-fA-F]{1,3}</param>
+ </data>
+ </define>
+ <define name="usbClass">
+ <data type="string">
+ <param name="pattern">(0x)?[0-9a-fA-F]{1,2}</param>
+ </data>
+ </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="wwn">
<data type="string">
<param name="pattern">(0x)?[0-9a-fA-F]{16}</param>
<ref name="dnsName"/>
</choice>
</define>
- <define name="usbIdDefault">
- <data type="string">
- <param name="pattern">-1</param>
- </data>
- </define>
- <define name="usbId">
- <data type="string">
- <param name="pattern">(0x)?[0-9a-fA-F]{1,4}</param>
- </data>
- </define>
- <define name="usbVersion">
- <data type="string">
- <param name="pattern">[0-9]{1,2}.[0-9]{1,2}</param>
- </data>
- </define>
- <define name="usbAddr">
- <data type="string">
- <param name="pattern">(0x)?[0-9a-fA-F]{1,3}</param>
- </data>
- </define>
- <define name="usbClass">
- <data type="string">
- <param name="pattern">(0x)?[0-9a-fA-F]{1,2}</param>
- </data>
- </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="driveController">
<data type="string">
<param name="pattern">[0-9]{1,2}</param>
<element name="device">
<ref name="unsignedLong"/>
</element>
+ <element name="port">
+ <ref name="unsignedLong"/>
+ </element>
<element name="product">
<attribute name="id">
return -1;
if (udevGetUintProperty(device, "ID_VENDOR_ID", &usb_dev->vendor, 16) < 0)
return -1;
+ if (!usb_dev->port) {
+ udevGetStringSysfsAttr(device, "devpath",
+ &usb_dev->port);
+ }
udevGetStringProperty(device,
"ID_VENDOR_FROM_DATABASE",
<capability type='usb_device'>
<bus>2</bus>
<device>1</device>
+ <port>3</port>
<product id='0x0001'>1.1 root hub</product>
<vendor id='0x1d6b'>Linux Foundation</vendor>
</capability>