dcavalca / rpms / qemu

Forked from rpms/qemu a year ago
Clone

Blame 0344-usb-storage-usb3-support.patch

c8dfc6
From 4a6f1fdf12d8b03633dad54dadc12781a77fbf6b Mon Sep 17 00:00:00 2001
c8dfc6
From: Gerd Hoffmann <kraxel@redhat.com>
c8dfc6
Date: Tue, 28 Aug 2012 17:29:15 +0200
c8dfc6
Subject: [PATCH 344/366] usb-storage: usb3 support
c8dfc6
c8dfc6
Add usb3 descriptors to usb-storage, so it shows up as superspeed
c8dfc6
device when connected to xhci.
c8dfc6
c8dfc6
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
c8dfc6
---
c8dfc6
 hw/usb/dev-storage.c | 46 +++++++++++++++++++++++++++++++++++++++++++---
c8dfc6
 1 file changed, 43 insertions(+), 3 deletions(-)
c8dfc6
c8dfc6
diff --git a/hw/usb/dev-storage.c b/hw/usb/dev-storage.c
c8dfc6
index ff48d91..e732191 100644
c8dfc6
--- a/hw/usb/dev-storage.c
c8dfc6
+++ b/hw/usb/dev-storage.c
c8dfc6
@@ -78,6 +78,7 @@ enum {
c8dfc6
     STR_SERIALNUMBER,
c8dfc6
     STR_CONFIG_FULL,
c8dfc6
     STR_CONFIG_HIGH,
c8dfc6
+    STR_CONFIG_SUPER,
c8dfc6
 };
c8dfc6
 
c8dfc6
 static const USBDescStrings desc_strings = {
c8dfc6
@@ -86,6 +87,7 @@ static const USBDescStrings desc_strings = {
c8dfc6
     [STR_SERIALNUMBER] = "1",
c8dfc6
     [STR_CONFIG_FULL]  = "Full speed config (usb 1.1)",
c8dfc6
     [STR_CONFIG_HIGH]  = "High speed config (usb 2.0)",
c8dfc6
+    [STR_CONFIG_SUPER] = "Super speed config (usb 3.0)",
c8dfc6
 };
c8dfc6
 
c8dfc6
 static const USBDescIface desc_iface_full = {
c8dfc6
@@ -158,6 +160,43 @@ static const USBDescDevice desc_device_high = {
c8dfc6
     },
c8dfc6
 };
c8dfc6
 
c8dfc6
+static const USBDescIface desc_iface_super = {
c8dfc6
+    .bInterfaceNumber              = 0,
c8dfc6
+    .bNumEndpoints                 = 2,
c8dfc6
+    .bInterfaceClass               = USB_CLASS_MASS_STORAGE,
c8dfc6
+    .bInterfaceSubClass            = 0x06, /* SCSI */
c8dfc6
+    .bInterfaceProtocol            = 0x50, /* Bulk */
c8dfc6
+    .eps = (USBDescEndpoint[]) {
c8dfc6
+        {
c8dfc6
+            .bEndpointAddress      = USB_DIR_IN | 0x01,
c8dfc6
+            .bmAttributes          = USB_ENDPOINT_XFER_BULK,
c8dfc6
+            .wMaxPacketSize        = 1024,
c8dfc6
+            .bMaxBurst             = 15,
c8dfc6
+        },{
c8dfc6
+            .bEndpointAddress      = USB_DIR_OUT | 0x02,
c8dfc6
+            .bmAttributes          = USB_ENDPOINT_XFER_BULK,
c8dfc6
+            .wMaxPacketSize        = 1024,
c8dfc6
+            .bMaxBurst             = 15,
c8dfc6
+        },
c8dfc6
+    }
c8dfc6
+};
c8dfc6
+
c8dfc6
+static const USBDescDevice desc_device_super = {
c8dfc6
+    .bcdUSB                        = 0x0300,
c8dfc6
+    .bMaxPacketSize0               = 9,
c8dfc6
+    .bNumConfigurations            = 1,
c8dfc6
+    .confs = (USBDescConfig[]) {
c8dfc6
+        {
c8dfc6
+            .bNumInterfaces        = 1,
c8dfc6
+            .bConfigurationValue   = 1,
c8dfc6
+            .iConfiguration        = STR_CONFIG_SUPER,
c8dfc6
+            .bmAttributes          = 0xc0,
c8dfc6
+            .nif = 1,
c8dfc6
+            .ifs = &desc_iface_super,
c8dfc6
+        },
c8dfc6
+    },
c8dfc6
+};
c8dfc6
+
c8dfc6
 static const USBDesc desc = {
c8dfc6
     .id = {
c8dfc6
         .idVendor          = 0x46f4, /* CRC16() of "QEMU" */
c8dfc6
@@ -167,9 +206,10 @@ static const USBDesc desc = {
c8dfc6
         .iProduct          = STR_PRODUCT,
c8dfc6
         .iSerialNumber     = STR_SERIALNUMBER,
c8dfc6
     },
c8dfc6
-    .full = &desc_device_full,
c8dfc6
-    .high = &desc_device_high,
c8dfc6
-    .str  = desc_strings,
c8dfc6
+    .full  = &desc_device_full,
c8dfc6
+    .high  = &desc_device_high,
c8dfc6
+    .super = &desc_device_super,
c8dfc6
+    .str   = desc_strings,
c8dfc6
 };
c8dfc6
 
c8dfc6
 static void usb_msd_copy_data(MSDState *s, USBPacket *p)
c8dfc6
-- 
c8dfc6
1.7.12
c8dfc6