|
|
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 |
|