|
@@ -291,8 +291,12 @@ fast_ata_pio:
|
|
|
|
|
|
static void __devinit init_hwif_atiixp(ide_hwif_t *hwif)
|
|
|
{
|
|
|
+ u8 udma_mode = 0;
|
|
|
+ u8 ch = hwif->channel;
|
|
|
+ struct pci_dev *pdev = hwif->pci_dev;
|
|
|
+
|
|
|
if (!hwif->irq)
|
|
|
- hwif->irq = hwif->channel ? 15 : 14;
|
|
|
+ hwif->irq = ch ? 15 : 14;
|
|
|
|
|
|
hwif->autodma = 0;
|
|
|
hwif->tuneproc = &atiixp_tuneproc;
|
|
@@ -308,8 +312,12 @@ static void __devinit init_hwif_atiixp(ide_hwif_t *hwif)
|
|
|
hwif->mwdma_mask = 0x06;
|
|
|
hwif->swdma_mask = 0x04;
|
|
|
|
|
|
- /* FIXME: proper cable detection needed */
|
|
|
- hwif->udma_four = 1;
|
|
|
+ pci_read_config_byte(pdev, ATIIXP_IDE_UDMA_MODE + ch, &udma_mode);
|
|
|
+ if ((udma_mode & 0x07) >= 0x04 || (udma_mode & 0x70) >= 0x40)
|
|
|
+ hwif->udma_four = 1;
|
|
|
+ else
|
|
|
+ hwif->udma_four = 0;
|
|
|
+
|
|
|
hwif->ide_dma_host_on = &atiixp_ide_dma_host_on;
|
|
|
hwif->ide_dma_host_off = &atiixp_ide_dma_host_off;
|
|
|
hwif->ide_dma_check = &atiixp_dma_check;
|
|
@@ -320,19 +328,6 @@ static void __devinit init_hwif_atiixp(ide_hwif_t *hwif)
|
|
|
hwif->drives[0].autodma = hwif->autodma;
|
|
|
}
|
|
|
|
|
|
-static void __devinit init_hwif_sb600_legacy(ide_hwif_t *hwif)
|
|
|
-{
|
|
|
-
|
|
|
- hwif->atapi_dma = 1;
|
|
|
- hwif->ultra_mask = 0x7f;
|
|
|
- hwif->mwdma_mask = 0x07;
|
|
|
- hwif->swdma_mask = 0x07;
|
|
|
-
|
|
|
- if (!noautodma)
|
|
|
- hwif->autodma = 1;
|
|
|
- hwif->drives[0].autodma = hwif->autodma;
|
|
|
- hwif->drives[1].autodma = hwif->autodma;
|
|
|
-}
|
|
|
|
|
|
static ide_pci_device_t atiixp_pci_info[] __devinitdata = {
|
|
|
{ /* 0 */
|
|
@@ -343,12 +338,13 @@ static ide_pci_device_t atiixp_pci_info[] __devinitdata = {
|
|
|
.enablebits = {{0x48,0x01,0x00}, {0x48,0x08,0x00}},
|
|
|
.bootable = ON_BOARD,
|
|
|
},{ /* 1 */
|
|
|
- .name = "ATI SB600 SATA Legacy IDE",
|
|
|
- .init_hwif = init_hwif_sb600_legacy,
|
|
|
- .channels = 2,
|
|
|
+ .name = "SB600_PATA",
|
|
|
+ .init_hwif = init_hwif_atiixp,
|
|
|
+ .channels = 1,
|
|
|
.autodma = AUTODMA,
|
|
|
- .bootable = ON_BOARD,
|
|
|
- }
|
|
|
+ .enablebits = {{0x48,0x01,0x00}, {0x00,0x00,0x00}},
|
|
|
+ .bootable = ON_BOARD,
|
|
|
+ },
|
|
|
};
|
|
|
|
|
|
/**
|
|
@@ -369,7 +365,7 @@ static struct pci_device_id atiixp_pci_tbl[] = {
|
|
|
{ PCI_VENDOR_ID_ATI, PCI_DEVICE_ID_ATI_IXP200_IDE, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
|
|
|
{ PCI_VENDOR_ID_ATI, PCI_DEVICE_ID_ATI_IXP300_IDE, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
|
|
|
{ PCI_VENDOR_ID_ATI, PCI_DEVICE_ID_ATI_IXP400_IDE, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
|
|
|
- { PCI_VENDOR_ID_ATI, PCI_DEVICE_ID_ATI_IXP600_IDE, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
|
|
|
+ { PCI_VENDOR_ID_ATI, PCI_DEVICE_ID_ATI_IXP600_IDE, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 1},
|
|
|
{ 0, },
|
|
|
};
|
|
|
MODULE_DEVICE_TABLE(pci, atiixp_pci_tbl);
|
|
@@ -380,7 +376,7 @@ static struct pci_driver driver = {
|
|
|
.probe = atiixp_init_one,
|
|
|
};
|
|
|
|
|
|
-static int atiixp_ide_init(void)
|
|
|
+static int __init atiixp_ide_init(void)
|
|
|
{
|
|
|
return ide_pci_register_driver(&driver);
|
|
|
}
|