diff options
Diffstat (limited to 'drivers/ide/pci/sis5513.c')
| -rw-r--r-- | drivers/ide/pci/sis5513.c | 30 | 
1 files changed, 18 insertions, 12 deletions
| diff --git a/drivers/ide/pci/sis5513.c b/drivers/ide/pci/sis5513.c index 181b647e5ca9..4b0b85d8faf5 100644 --- a/drivers/ide/pci/sis5513.c +++ b/drivers/ide/pci/sis5513.c | |||
| @@ -347,7 +347,7 @@ static void sis_set_dma_mode(ide_drive_t *drive, const u8 speed) | |||
| 347 | sis_program_timings(drive, speed); | 347 | sis_program_timings(drive, speed); | 
| 348 | } | 348 | } | 
| 349 | 349 | ||
| 350 | static u8 sis5513_ata133_udma_filter(ide_drive_t *drive) | 350 | static u8 sis_ata133_udma_filter(ide_drive_t *drive) | 
| 351 | { | 351 | { | 
| 352 | struct pci_dev *dev = to_pci_dev(drive->hwif->dev); | 352 | struct pci_dev *dev = to_pci_dev(drive->hwif->dev); | 
| 353 | u32 regdw = 0; | 353 | u32 regdw = 0; | 
| @@ -514,7 +514,7 @@ static const struct sis_laptop sis_laptop[] = { | |||
| 514 | { 0, } | 514 | { 0, } | 
| 515 | }; | 515 | }; | 
| 516 | 516 | ||
| 517 | static u8 __devinit ata66_sis5513(ide_hwif_t *hwif) | 517 | static u8 __devinit sis_cable_detect(ide_hwif_t *hwif) | 
| 518 | { | 518 | { | 
| 519 | struct pci_dev *pdev = to_pci_dev(hwif->dev); | 519 | struct pci_dev *pdev = to_pci_dev(hwif->dev); | 
| 520 | const struct sis_laptop *lap = &sis_laptop[0]; | 520 | const struct sis_laptop *lap = &sis_laptop[0]; | 
| @@ -543,21 +543,22 @@ static u8 __devinit ata66_sis5513(ide_hwif_t *hwif) | |||
| 543 | return ata66 ? ATA_CBL_PATA80 : ATA_CBL_PATA40; | 543 | return ata66 ? ATA_CBL_PATA80 : ATA_CBL_PATA40; | 
| 544 | } | 544 | } | 
| 545 | 545 | ||
| 546 | static void __devinit init_hwif_sis5513(ide_hwif_t *hwif) | 546 | static const struct ide_port_ops sis_port_ops = { | 
| 547 | { | 547 | .set_pio_mode = sis_set_pio_mode, | 
| 548 | hwif->set_pio_mode = &sis_set_pio_mode; | 548 | .set_dma_mode = sis_set_dma_mode, | 
| 549 | hwif->set_dma_mode = &sis_set_dma_mode; | 549 | .cable_detect = sis_cable_detect, | 
| 550 | 550 | }; | |
| 551 | if (chipset_family >= ATA_133) | ||
| 552 | hwif->udma_filter = sis5513_ata133_udma_filter; | ||
| 553 | 551 | ||
| 554 | hwif->cable_detect = ata66_sis5513; | 552 | static const struct ide_port_ops sis_ata133_port_ops = { | 
| 555 | } | 553 | .set_pio_mode = sis_set_pio_mode, | 
| 554 | .set_dma_mode = sis_set_dma_mode, | ||
| 555 | .udma_filter = sis_ata133_udma_filter, | ||
| 556 | .cable_detect = sis_cable_detect, | ||
| 557 | }; | ||
| 556 | 558 | ||
| 557 | static const struct ide_port_info sis5513_chipset __devinitdata = { | 559 | static const struct ide_port_info sis5513_chipset __devinitdata = { | 
| 558 | .name = "SIS5513", | 560 | .name = "SIS5513", | 
| 559 | .init_chipset = init_chipset_sis5513, | 561 | .init_chipset = init_chipset_sis5513, | 
| 560 | .init_hwif = init_hwif_sis5513, | ||
| 561 | .enablebits = { {0x4a, 0x02, 0x02}, {0x4a, 0x04, 0x04} }, | 562 | .enablebits = { {0x4a, 0x02, 0x02}, {0x4a, 0x04, 0x04} }, | 
| 562 | .host_flags = IDE_HFLAG_LEGACY_IRQS | IDE_HFLAG_NO_AUTODMA, | 563 | .host_flags = IDE_HFLAG_LEGACY_IRQS | IDE_HFLAG_NO_AUTODMA, | 
| 563 | .pio_mask = ATA_PIO4, | 564 | .pio_mask = ATA_PIO4, | 
| @@ -572,6 +573,11 @@ static int __devinit sis5513_init_one(struct pci_dev *dev, const struct pci_devi | |||
| 572 | if (sis_find_family(dev) == 0) | 573 | if (sis_find_family(dev) == 0) | 
| 573 | return -ENOTSUPP; | 574 | return -ENOTSUPP; | 
| 574 | 575 | ||
| 576 | if (chipset_family >= ATA_133) | ||
| 577 | d.port_ops = &sis_ata133_port_ops; | ||
| 578 | else | ||
| 579 | d.port_ops = &sis_port_ops; | ||
| 580 | |||
| 575 | d.udma_mask = udma_rates[chipset_family]; | 581 | d.udma_mask = udma_rates[chipset_family]; | 
| 576 | 582 | ||
| 577 | return ide_setup_pci_device(dev, &d); | 583 | return ide_setup_pci_device(dev, &d); | 
