summaryrefslogtreecommitdiff
path: root/src/southbridge/intel/bd82x6x
diff options
context:
space:
mode:
Diffstat (limited to 'src/southbridge/intel/bd82x6x')
-rw-r--r--src/southbridge/intel/bd82x6x/chip.h5
-rw-r--r--src/southbridge/intel/bd82x6x/usb_xhci.c4
2 files changed, 9 insertions, 0 deletions
diff --git a/src/southbridge/intel/bd82x6x/chip.h b/src/southbridge/intel/bd82x6x/chip.h
index 290bb058ac..f4be82d81f 100644
--- a/src/southbridge/intel/bd82x6x/chip.h
+++ b/src/southbridge/intel/bd82x6x/chip.h
@@ -89,6 +89,11 @@ struct southbridge_intel_bd82x6x_config {
int docking_supported;
uint8_t pcie_hotplug_map[8];
+
+ /* Ports which can be routed to either EHCI or xHCI. */
+ uint32_t xhci_switchable_ports;
+ /* Ports which support SuperSpeed (USB 3.0 additional lanes). */
+ uint32_t superspeed_capable_ports;
};
#endif /* SOUTHBRIDGE_INTEL_BD82X6X_CHIP_H */
diff --git a/src/southbridge/intel/bd82x6x/usb_xhci.c b/src/southbridge/intel/bd82x6x/usb_xhci.c
index 19c419facb..eb89a7d64f 100644
--- a/src/southbridge/intel/bd82x6x/usb_xhci.c
+++ b/src/southbridge/intel/bd82x6x/usb_xhci.c
@@ -29,6 +29,7 @@
static void usb_xhci_init(struct device *dev)
{
u32 reg32;
+ struct southbridge_intel_bd82x6x_config *config = dev->chip_info;
printk(BIOS_DEBUG, "XHCI: Setting up controller.. ");
@@ -37,6 +38,9 @@ static void usb_xhci_init(struct device *dev)
reg32 |= 1;
pci_write_config32(dev, 0x44, reg32);
+ pci_write_config32(dev, 0xd4, config->xhci_switchable_ports);
+ pci_write_config32(dev, 0xdc, config->superspeed_capable_ports);
+
/* Enable clock gating */
reg32 = pci_read_config32(dev, 0x40);
reg32 &= ~((1 << 20) | (1 << 21));