Blame 0616-xhci-fix-cleanup-msi.patch

5544c1
From e97e63460859a74cf53c85e97a6d60633a92cc64 Mon Sep 17 00:00:00 2001
c8dfc6
From: Gerd Hoffmann <kraxel@redhat.com>
c8dfc6
Date: Thu, 30 Aug 2012 10:57:12 +0200
5544c1
Subject: [PATCH] xhci: fix & cleanup msi.
c8dfc6
c8dfc6
Drop custom write_config function which isn't needed any more.
c8dfc6
Make the msi property a bit property so it accepts 'on' & 'off'.
c8dfc6
Enable MSI by default.
c8dfc6
c8dfc6
TODO: add compat property to disable on old machine types.
c8dfc6
c8dfc6
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
c8dfc6
---
c8dfc6
 hw/usb/hcd-xhci.c | 27 +++++++++------------------
c8dfc6
 1 file changed, 9 insertions(+), 18 deletions(-)
c8dfc6
c8dfc6
diff --git a/hw/usb/hcd-xhci.c b/hw/usb/hcd-xhci.c
5544c1
index 5813b4a..d2e6ee6 100644
c8dfc6
--- a/hw/usb/hcd-xhci.c
c8dfc6
+++ b/hw/usb/hcd-xhci.c
c8dfc6
@@ -386,7 +386,7 @@ struct XHCIState {
c8dfc6
     /* properties */
c8dfc6
     uint32_t numports_2;
c8dfc6
     uint32_t numports_3;
c8dfc6
-    uint32_t msi;
c8dfc6
+    uint32_t flags;
c8dfc6
 
c8dfc6
     /* Operational Registers */
c8dfc6
     uint32_t usbcmd;
c8dfc6
@@ -435,6 +435,10 @@ typedef struct XHCIEvRingSeg {
c8dfc6
     uint32_t rsvd;
c8dfc6
 } XHCIEvRingSeg;
c8dfc6
 
c8dfc6
+enum xhci_flags {
c8dfc6
+    XHCI_FLAG_USE_MSI = 1,
c8dfc6
+};
c8dfc6
+
c8dfc6
 static void xhci_kick_ep(XHCIState *xhci, unsigned int slotid,
c8dfc6
                          unsigned int epid);
c8dfc6
 static void xhci_event(XHCIState *xhci, XHCIEvent *event);
c8dfc6
@@ -617,7 +621,7 @@ static void xhci_irq_update(XHCIState *xhci)
c8dfc6
         level = 1;
c8dfc6
     }
c8dfc6
 
c8dfc6
-    if (xhci->msi && msi_enabled(&xhci->pci_dev)) {
c8dfc6
+    if (msi_enabled(&xhci->pci_dev)) {
c8dfc6
         if (level) {
c8dfc6
             trace_usb_xhci_irq_msi(0);
c8dfc6
             msi_notify(&xhci->pci_dev, 0);
c8dfc6
@@ -2859,32 +2863,20 @@ static int usb_xhci_initfn(struct PCIDevice *dev)
c8dfc6
     ret = pcie_cap_init(&xhci->pci_dev, 0xa0, PCI_EXP_TYPE_ENDPOINT, 0);
c8dfc6
     assert(ret >= 0);
c8dfc6
 
c8dfc6
-    if (xhci->msi) {
c8dfc6
-        ret = msi_init(&xhci->pci_dev, 0x70, 1, true, false);
c8dfc6
-        assert(ret >= 0);
c8dfc6
+    if (xhci->flags & (1 << XHCI_FLAG_USE_MSI)) {
c8dfc6
+        msi_init(&xhci->pci_dev, 0x70, MAXINTRS, true, false);
c8dfc6
     }
c8dfc6
 
c8dfc6
     return 0;
c8dfc6
 }
c8dfc6
 
c8dfc6
-static void xhci_write_config(PCIDevice *dev, uint32_t addr, uint32_t val,
c8dfc6
-                              int len)
c8dfc6
-{
c8dfc6
-    XHCIState *xhci = DO_UPCAST(XHCIState, pci_dev, dev);
c8dfc6
-
c8dfc6
-    pci_default_write_config(dev, addr, val, len);
c8dfc6
-    if (xhci->msi) {
c8dfc6
-        msi_write_config(dev, addr, val, len);
c8dfc6
-    }
c8dfc6
-}
c8dfc6
-
c8dfc6
 static const VMStateDescription vmstate_xhci = {
c8dfc6
     .name = "xhci",
c8dfc6
     .unmigratable = 1,
c8dfc6
 };
c8dfc6
 
c8dfc6
 static Property xhci_properties[] = {
c8dfc6
-    DEFINE_PROP_UINT32("msi", XHCIState, msi, 0),
c8dfc6
+    DEFINE_PROP_BIT("msi",    XHCIState, flags, XHCI_FLAG_USE_MSI, true),
c8dfc6
     DEFINE_PROP_UINT32("p2",  XHCIState, numports_2, 4),
c8dfc6
     DEFINE_PROP_UINT32("p3",  XHCIState, numports_3, 4),
c8dfc6
     DEFINE_PROP_END_OF_LIST(),
c8dfc6
@@ -2904,7 +2896,6 @@ static void xhci_class_init(ObjectClass *klass, void *data)
c8dfc6
     k->class_id     = PCI_CLASS_SERIAL_USB;
c8dfc6
     k->revision     = 0x03;
c8dfc6
     k->is_express   = 1;
c8dfc6
-    k->config_write = xhci_write_config;
c8dfc6
 }
c8dfc6
 
c8dfc6
 static TypeInfo xhci_info = {
c8dfc6
-- 
5544c1
1.7.12.1
c8dfc6