Chuck Ebbert b5010d0
--- linux-2.6.20/arch/ia64/kernel/quirks.c	1969-12-31 19:00:00.000000000 -0500
Chuck Ebbert b5010d0
+++ linux-2.6.20_fix/arch/ia64/kernel/quirks.c	2007-02-13 13:56:34.000000000 -0500
Chuck Ebbert b5010d0
@@ -0,0 +1,45 @@
Chuck Ebbert b5010d0
+/*
Chuck Ebbert b5010d0
+ * This file contains work-arounds for ia64 platform bugs.
Chuck Ebbert b5010d0
+ */
Chuck Ebbert b5010d0
+#include <linux/pci.h>
Chuck Ebbert b5010d0
+
Chuck Ebbert b5010d0
+/*
Chuck Ebbert b5010d0
+ * quirk_intel_ide_controller: If an ide/ata controller is
Chuck Ebbert b5010d0
+ * at legacy mode, BIOS might initiates BAR(bar 0~3 and 5)
Chuck Ebbert b5010d0
+ * with incorrect value. This quirk will reset the incorrect
Chuck Ebbert b5010d0
+ * value to 0.
Chuck Ebbert b5010d0
+ */
Chuck Ebbert b5010d0
+static void __devinit quirk_intel_ide_controller(struct pci_dev *dev)
Chuck Ebbert b5010d0
+{
Chuck Ebbert b5010d0
+	unsigned int pos;
Chuck Ebbert b5010d0
+	struct resource *res;
Chuck Ebbert b5010d0
+	int fixed = 0;
Chuck Ebbert b5010d0
+	u8 tmp8;
Chuck Ebbert b5010d0
+
Chuck Ebbert b5010d0
+	if ((dev->class >> 8) != PCI_CLASS_STORAGE_IDE)
Chuck Ebbert b5010d0
+		return;
Chuck Ebbert b5010d0
+
Chuck Ebbert b5010d0
+	/* TODO: What if one channel is in native mode ... */
Chuck Ebbert b5010d0
+	pci_read_config_byte(dev, PCI_CLASS_PROG, &tmp8);
Chuck Ebbert b5010d0
+	if ((tmp8 & 5) == 5)
Chuck Ebbert b5010d0
+		return;
Chuck Ebbert b5010d0
+
Chuck Ebbert b5010d0
+	for( pos = 0; pos < 6; pos ++ ) {
Chuck Ebbert b5010d0
+		res = &dev->resource[pos];
Chuck Ebbert b5010d0
+		if (!(res->flags & (IORESOURCE_IO | IORESOURCE_MEM)))
Chuck Ebbert b5010d0
+			continue;
Chuck Ebbert b5010d0
+
Chuck Ebbert b5010d0
+		if (!res->start && res->end) {
Chuck Ebbert b5010d0
+			res->start = res->end = 0;
Chuck Ebbert b5010d0
+			res->flags = 0;
Chuck Ebbert b5010d0
+			fixed = 1;
Chuck Ebbert b5010d0
+		}
Chuck Ebbert b5010d0
+	}
Chuck Ebbert b5010d0
+	if (fixed)
Chuck Ebbert b5010d0
+		printk(KERN_WARNING
Chuck Ebbert b5010d0
+			"PCI device %s: BIOS resource configuration fixed.\n",
Chuck Ebbert b5010d0
+			pci_name(dev));
Chuck Ebbert b5010d0
+}
Chuck Ebbert b5010d0
+
Chuck Ebbert b5010d0
+DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801DB_11, quirk_intel_ide_controller);
Chuck Ebbert b5010d0
+
Chuck Ebbert b5010d0
--- linux-2.6.21.noarch/arch/ia64/kernel/Makefile~	2007-05-27 23:23:36.000000000 -0400
Chuck Ebbert b5010d0
+++ linux-2.6.21.noarch/arch/ia64/kernel/Makefile	2007-05-27 23:23:48.000000000 -0400
Chuck Ebbert b5010d0
@@ -33,6 +33,7 @@ obj-$(CONFIG_CRASH_DUMP)	+= crash_dump.o
Chuck Ebbert b5010d0
 obj-$(CONFIG_IA64_UNCACHED_ALLOCATOR)	+= uncached.o
Chuck Ebbert b5010d0
 obj-$(CONFIG_AUDIT)		+= audit.o
Chuck Ebbert b5010d0
 obj-$(CONFIG_PCI_MSI)		+= msi_ia64.o
Chuck Ebbert b5010d0
+obj-$(CONFIG_PCI)		+= quirks.o
Chuck Ebbert b5010d0
 mca_recovery-y			+= mca_drv.o mca_drv_asm.o
Chuck Ebbert b5010d0
 obj-$(CONFIG_IA64_MC_ERR_INJECT)+= err_inject.o
Chuck Ebbert b5010d0