xhci PCIe endpoint migration compatibility fix
-----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.22 (GNU/Linux) iQIcBAABAgAGBQJUD+MYAAoJEEy22O7T6HE4uooQANH8K9VA2JCOakJ69plcTJ1e LM1tJaKajLvDyWL9kBl4oUzDMgt/wcJmVUM+diaWE1WjG3U1KSyAdtG1bxNqOwJo elB7jA4YckLV17Y5knXU4hAnhRZteVttPbebjOfnLGGqaO1qFqp01l507hjMw0g7 IqjuRJSKLTedj/Xory+qN+/H9hWAXGGbh0MZpafm9DEJ6rKIJY+kREyWbxar763M rkFbHtG5pRk8MNMkNtaRZALnoZiHixeQWjkgqJEDWbHulim8o9KSuMVH7SpDIpDB wBnHbb53a8cfdri+fhzQSDphK04Ng3GJ2nOQcRGw8589LinWjlFXA4iYF1BfWCDp mlqzxKMzaS3cIto1+KkYwNcDdRopxeTCB7l2F0y6Bzg2tDelNb6VfIWOsA3NG6Hy 5FGqHsXpzOr3RjZimG2yK+s1RVG5Qam8OhAcTXW1ni9AnvejVj5bTPknqRGT1nf0 Ws+D/wIKKvl4pUzUD8A1MSS8WKgsQ3VbcbW4ZxpPh9rmUpjuP+CVDsVHpbdknazf vbeZv8PBhJr4NtMUgIkBiUUTzUJo/gW1c3MW+FU0/wX7YQLfppqSImDi4uoKmRX9 Y67ivZkYatU2JdNxG7lkwG7aILMYR5KYSB8yz/tlIZKCoqDYzN3J5pvn8rZgMRsY uEZUjb2T5yTXyDZ8+NCU =vtWW -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/kraxel/tags/pull-usb-20140910-1' into staging xhci PCIe endpoint migration compatibility fix # gpg: Signature made Wed 10 Sep 2014 06:35:20 BST using RSA key ID D3E87138 # gpg: Good signature from "Gerd Hoffmann (work) <kraxel@redhat.com>" # gpg: aka "Gerd Hoffmann <gerd@kraxel.org>" # gpg: aka "Gerd Hoffmann (private) <kraxel@gmail.com>" * remotes/kraxel/tags/pull-usb-20140910-1: xhci PCIe endpoint migration compatibility fix Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
fc3b9aa876
@ -499,6 +499,7 @@ enum xhci_flags {
|
|||||||
XHCI_FLAG_USE_MSI = 1,
|
XHCI_FLAG_USE_MSI = 1,
|
||||||
XHCI_FLAG_USE_MSI_X,
|
XHCI_FLAG_USE_MSI_X,
|
||||||
XHCI_FLAG_SS_FIRST,
|
XHCI_FLAG_SS_FIRST,
|
||||||
|
XHCI_FLAG_FORCE_PCIE_ENDCAP,
|
||||||
};
|
};
|
||||||
|
|
||||||
static void xhci_kick_ep(XHCIState *xhci, unsigned int slotid,
|
static void xhci_kick_ep(XHCIState *xhci, unsigned int slotid,
|
||||||
@ -3626,7 +3627,8 @@ static int usb_xhci_initfn(struct PCIDevice *dev)
|
|||||||
PCI_BASE_ADDRESS_SPACE_MEMORY|PCI_BASE_ADDRESS_MEM_TYPE_64,
|
PCI_BASE_ADDRESS_SPACE_MEMORY|PCI_BASE_ADDRESS_MEM_TYPE_64,
|
||||||
&xhci->mem);
|
&xhci->mem);
|
||||||
|
|
||||||
if (pci_bus_is_express(dev->bus)) {
|
if (pci_bus_is_express(dev->bus) ||
|
||||||
|
xhci_get_flag(xhci, XHCI_FLAG_FORCE_PCIE_ENDCAP)) {
|
||||||
ret = pcie_endpoint_cap_init(dev, 0xa0);
|
ret = pcie_endpoint_cap_init(dev, 0xa0);
|
||||||
assert(ret >= 0);
|
assert(ret >= 0);
|
||||||
}
|
}
|
||||||
@ -3855,6 +3857,8 @@ static Property xhci_properties[] = {
|
|||||||
DEFINE_PROP_BIT("msix", XHCIState, flags, XHCI_FLAG_USE_MSI_X, true),
|
DEFINE_PROP_BIT("msix", XHCIState, flags, XHCI_FLAG_USE_MSI_X, true),
|
||||||
DEFINE_PROP_BIT("superspeed-ports-first",
|
DEFINE_PROP_BIT("superspeed-ports-first",
|
||||||
XHCIState, flags, XHCI_FLAG_SS_FIRST, true),
|
XHCIState, flags, XHCI_FLAG_SS_FIRST, true),
|
||||||
|
DEFINE_PROP_BIT("force-pcie-endcap", XHCIState, flags,
|
||||||
|
XHCI_FLAG_FORCE_PCIE_ENDCAP, false),
|
||||||
DEFINE_PROP_UINT32("intrs", XHCIState, numintrs, MAXINTRS),
|
DEFINE_PROP_UINT32("intrs", XHCIState, numintrs, MAXINTRS),
|
||||||
DEFINE_PROP_UINT32("slots", XHCIState, numslots, MAXSLOTS),
|
DEFINE_PROP_UINT32("slots", XHCIState, numslots, MAXSLOTS),
|
||||||
DEFINE_PROP_UINT32("p2", XHCIState, numports_2, 4),
|
DEFINE_PROP_UINT32("p2", XHCIState, numports_2, 4),
|
||||||
|
@ -329,6 +329,11 @@ bool e820_get_entry(int, uint32_t, uint64_t *, uint64_t *);
|
|||||||
.property = "superspeed-ports-first",\
|
.property = "superspeed-ports-first",\
|
||||||
.value = "off",\
|
.value = "off",\
|
||||||
},\
|
},\
|
||||||
|
{\
|
||||||
|
.driver = "nec-usb-xhci",\
|
||||||
|
.property = "force-pcie-endcap",\
|
||||||
|
.value = "on",\
|
||||||
|
},\
|
||||||
{\
|
{\
|
||||||
.driver = "pci-serial",\
|
.driver = "pci-serial",\
|
||||||
.property = "prog_if",\
|
.property = "prog_if",\
|
||||||
|
Loading…
Reference in New Issue
Block a user