return;
}
printk_spew("for IRQ, reg 0x%08x value 0x%08x 0x%08x\n",
- a->reg, a->value_low, a->value_high);
+ a->reg, a->value_low, a->value_high);
}
}
byte = pci_read_config8(dev, 0x46);
pci_write_config8(dev, 0x46, byte | (1<<0));
- /* power after power fail */
+ /* Enable 5Mib Rom window */
byte = pci_read_config8(dev, 0x43);
- if (pwr_on) {
- byte &= ~(1<<6);
- } else {
- byte |= (1<<6);
- }
+ byte |= 0xC0;
pci_write_config8(dev, 0x43, byte);
/* Enable Port 92 fast reset */
static void lpci_set_subsystem(device_t dev, unsigned vendor, unsigned device)
{
pci_write_config32(dev, 0x70,
- ((device & 0xffff) << 16) | (vendor & 0xffff));
+ ((device & 0xffff) << 16) | (vendor & 0xffff));
}
static struct pci_operations lops_pci = {
#include <device/pci_ops.h>
#include "amd8111.h"
-static void usb2_init(struct device *dev)
-{
- uint32_t cmd;
-
#if 0
- printk_debug("USB: Setting up controller.. ");
- cmd = pci_read_config32(dev, PCI_COMMAND);
- pci_write_config32(dev, PCI_COMMAND,
- cmd | PCI_COMMAND_IO | PCI_COMMAND_MEMORY |
- PCI_COMMAND_MASTER | PCI_COMMAND_INVALIDATE);
-
-
- printk_debug("done.\n");
-#endif
-}
static void lpci_set_subsystem(device_t dev, unsigned vendor, unsigned device)
{
.set_subsystem = lpci_set_subsystem,
};
+#endif
+
+static void amd8111_usb2_enable(device_t dev)
+{
+ // Due to buggy USB2 we force it to disable.
+ dev->enable = 0;
+ amd8111_enable(dev);
+ printk_debug("USB2 disabled.\n");
+}
+
static struct device_operations usb2_ops = {
.read_resources = pci_dev_read_resources,
.set_resources = pci_dev_set_resources,
.enable_resources = pci_dev_enable_resources,
- .init = usb2_init,
.scan_bus = 0,
- .enable = amd8111_enable,
- .ops_pci = &lops_pci,
+ .enable = amd8111_usb2_enable,
+ // .ops_pci = &lops_pci,
};
static struct pci_driver usb2_driver __pci_driver = {