#include #include #include #include #include #include "amd8111.h" static void ide_init(struct device *dev) { /* Enable ide devices so the linux ide driver will work */ uint16_t word; int enable_a=1, enable_b=1; printk_debug("ide_init\n"); word = pci_read_config16(dev, 0x40); /* Ensure prefetch is disabled */ word &= ~((1 << 15) | (1 << 13)); if (enable_b) { /* Enable secondary ide interface */ word |= (1<<0); printk_debug("IDE1 "); } if (enable_a) { /* Enable primary ide interface */ word |= (1<<1); printk_debug("IDE0 "); } word |= (1<<12); word |= (1<<14); pci_write_config16(dev, 0x40, word); word = 0x0f; pci_write_config16(dev, 0x42, word); /* The AMD768 has a bug where the BM DMA address must be * 256 byte aligned while it is only 16 bytes long. * Hard code this to a valid address below 0x1000 * where automatic port address assignment starts. * FIXME: I assume the 8111 does the same thing. We should * clarify. stepan@suse.de */ pci_write_config32(dev, 0x20, 0xf01); pci_write_config32(dev, 0x48, 0x205e5e5e); word = 0x06a; pci_write_config16(dev, 0x4c, word); } static struct device_operations ide_ops = { .read_resources = pci_dev_read_resources, .set_resources = pci_dev_set_resources, .enable_resources = pci_dev_enable_resources, .init = ide_init, .scan_bus = 0, }; static struct pci_driver ide_driver __pci_driver = { .ops = &ide_ops, .vendor = PCI_VENDOR_ID_AMD, .device = PCI_DEVICE_ID_AMD_8111_IDE, };