PIIX5 Doesn't work on IA64 (2.6.0-test9)

From: Peter Chubb
Date: Thu Nov 20 2003 - 17:36:54 EST



Hi,
The PIIX5 IDE controller on I2000 IA64 boxen using the 460GX
chipset will hang on startup if an ordinary harddrive is plugged into
it (it seems to workj for the LSI120 and the CDROM drives).

This is because the 460GX chipset contains a PCI expanssion bridge
that works like the 450NX PXB, and has the same PCI ID (but a later
revision). The PIIX driver, to work around interactions between PIIX4
and the 450NX PXB, tries to disable DMA.

Unfortunately, the way it tries to disable DMA doesn't work, and the
higher layers think that DMA is still on, and so timeout waiting for
DMA, and then hang on bootup.

A simple workaround is to tighten the check for the buggy chipset, as
in the attached patch. However, someone with more time (and who
actually *understands* the IDE subsystem) needs to fix the real bug as
well.

===== piix.c 1.20 vs edited =====
--- 1.20/drivers/ide/pci/piix.c Wed Oct 22 09:27:24 2003
+++ edited/piix.c Fri Nov 21 09:28:43 2003
@@ -768,8 +768,8 @@
/* Only on the original revision: IDE DMA can hang */
if(rev == 0x00)
no_piix_dma = 1;
- /* On all revisions PXB bus lock must be disabled for IDE */
- else if(cfg & (1<<14))
+ /* On all revisions below 5 PXB bus lock must be disabled for IDE */
+ else if(cfg & (1<<14) && rev < 5)
no_piix_dma = 2;
}
if(no_piix_dma)



-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/