aboutsummaryrefslogtreecommitdiff
path: root/hw/usb/host-stub.c
diff options
context:
space:
mode:
authorThomas Huth <thuth@redhat.com>2016-12-14 22:44:17 +0100
committerDavid Gibson <david@gibson.dropbear.id.au>2017-01-31 10:10:13 +1100
commitb99260ebbb5844da9e77fbcaa73b7b6980a68acf (patch)
tree2601a8e3e96d534805a01ed5787b3b00c6143a69 /hw/usb/host-stub.c
parente122090df3e681b42d19a55486ff5c54f2c1e717 (diff)
downloadqemu-b99260ebbb5844da9e77fbcaa73b7b6980a68acf.zip
qemu-b99260ebbb5844da9e77fbcaa73b7b6980a68acf.tar.gz
qemu-b99260ebbb5844da9e77fbcaa73b7b6980a68acf.tar.bz2
hw/ppc/spapr: Fix boot path of usb-host storage devices
When passing through an USB storage device to a pseries guest, it is currently not possible to automatically boot from the device if the "bootindex" property has been specified, too (e.g. when using "-device nec-usb-xhci -device usb-host,hostbus=1,hostaddr=2,bootindex=0" at the command line). The problem is that QEMU builds a device tree path like "/pci@800000020000000/usb@0/usb-host@1" and passes it to SLOF in the /chosen/qemu,boot-list property. SLOF, however, probes the USB device, recognizes that it is a storage device and thus changes its name to "storage", and additionally adds a child node for the SCSI LUN, so the correct boot path in SLOF is something like "/pci@800000020000000/usb@0/storage@1/disk@101000000000000" instead. So when we detect an USB mass storage device with SCSI interface, we've got to adjust the firmware boot-device path properly that SLOF can automatically boot from the device. Buglink: https://bugzilla.redhat.com/show_bug.cgi?id=1354177 Signed-off-by: Thomas Huth <thuth@redhat.com> Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Diffstat (limited to 'hw/usb/host-stub.c')
-rw-r--r--hw/usb/host-stub.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/hw/usb/host-stub.c b/hw/usb/host-stub.c
index 6ba65a1..d0268ba 100644
--- a/hw/usb/host-stub.c
+++ b/hw/usb/host-stub.c
@@ -46,3 +46,8 @@ USBDevice *usb_host_device_open(USBBus *bus, const char *devname)
{
return NULL;
}
+
+bool usb_host_dev_is_scsi_storage(USBDevice *ud)
+{
+ return false;
+}