diff options
Diffstat (limited to 'drivers/ide/pci/siimage.c')
-rw-r--r-- | drivers/ide/pci/siimage.c | 18 |
1 files changed, 10 insertions, 8 deletions
diff --git a/drivers/ide/pci/siimage.c b/drivers/ide/pci/siimage.c index 1a4444e7226a..1c3e35487893 100644 --- a/drivers/ide/pci/siimage.c +++ b/drivers/ide/pci/siimage.c | |||
@@ -933,16 +933,17 @@ static void __devinit init_iops_siimage(ide_hwif_t *hwif) | |||
933 | * interface. | 933 | * interface. |
934 | */ | 934 | */ |
935 | 935 | ||
936 | static unsigned int __devinit ata66_siimage(ide_hwif_t *hwif) | 936 | static u8 __devinit ata66_siimage(ide_hwif_t *hwif) |
937 | { | 937 | { |
938 | unsigned long addr = siimage_selreg(hwif, 0); | 938 | unsigned long addr = siimage_selreg(hwif, 0); |
939 | if (pci_get_drvdata(hwif->pci_dev) == NULL) { | 939 | u8 ata66 = 0; |
940 | u8 ata66 = 0; | 940 | |
941 | if (pci_get_drvdata(hwif->pci_dev) == NULL) | ||
941 | pci_read_config_byte(hwif->pci_dev, addr, &ata66); | 942 | pci_read_config_byte(hwif->pci_dev, addr, &ata66); |
942 | return (ata66 & 0x01) ? 1 : 0; | 943 | else |
943 | } | 944 | ata66 = hwif->INB(addr); |
944 | 945 | ||
945 | return (hwif->INB(addr) & 0x01) ? 1 : 0; | 946 | return (ata66 & 0x01) ? ATA_CBL_PATA80 : ATA_CBL_PATA40; |
946 | } | 947 | } |
947 | 948 | ||
948 | /** | 949 | /** |
@@ -988,8 +989,9 @@ static void __devinit init_hwif_siimage(ide_hwif_t *hwif) | |||
988 | hwif->atapi_dma = 1; | 989 | hwif->atapi_dma = 1; |
989 | 990 | ||
990 | hwif->ide_dma_check = &siimage_config_drive_for_dma; | 991 | hwif->ide_dma_check = &siimage_config_drive_for_dma; |
991 | if (!(hwif->udma_four)) | 992 | |
992 | hwif->udma_four = ata66_siimage(hwif); | 993 | if (hwif->cbl != ATA_CBL_PATA40_SHORT) |
994 | hwif->cbl = ata66_siimage(hwif); | ||
993 | 995 | ||
994 | if (hwif->mmio) { | 996 | if (hwif->mmio) { |
995 | hwif->ide_dma_test_irq = &siimage_mmio_ide_dma_test_irq; | 997 | hwif->ide_dma_test_irq = &siimage_mmio_ide_dma_test_irq; |