diff options
author | Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> | 2008-04-26 16:25:14 -0400 |
---|---|---|
committer | Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> | 2008-04-26 16:25:14 -0400 |
commit | ac95beedf8bc97b24f9540d4da9952f07221c023 (patch) | |
tree | c29837142c8083b6fcaf1767abcb0a4533676cd1 /drivers/ide/pci/cmd64x.c | |
parent | 4a27214d7be31e122db4102166f49ec15958e8e9 (diff) |
ide: add struct ide_port_ops (take 2)
* Move hooks for port/host specific methods from ide_hwif_t to
'struct ide_port_ops'.
* Add 'const struct ide_port_ops *port_ops' to 'struct ide_port_info'
and ide_hwif_t.
* Update host drivers and core code accordingly.
While at it:
* Rename ata66_*() cable detect functions to *_cable_detect() to match
the standard naming. (Suggested by Sergei Shtylyov)
v2:
* Fix build for bast-ide. (Noticed by Andrew Morton)
Acked-by: Sergei Shtylyov <sshtylyov@ru.mvista.com>
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
Diffstat (limited to 'drivers/ide/pci/cmd64x.c')
-rw-r--r-- | drivers/ide/pci/cmd64x.c | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/drivers/ide/pci/cmd64x.c b/drivers/ide/pci/cmd64x.c index 8baccfef237f..5411ded791bb 100644 --- a/drivers/ide/pci/cmd64x.c +++ b/drivers/ide/pci/cmd64x.c | |||
@@ -370,7 +370,7 @@ static unsigned int __devinit init_chipset_cmd64x(struct pci_dev *dev, const cha | |||
370 | return 0; | 370 | return 0; |
371 | } | 371 | } |
372 | 372 | ||
373 | static u8 __devinit ata66_cmd64x(ide_hwif_t *hwif) | 373 | static u8 __devinit cmd64x_cable_detect(ide_hwif_t *hwif) |
374 | { | 374 | { |
375 | struct pci_dev *dev = to_pci_dev(hwif->dev); | 375 | struct pci_dev *dev = to_pci_dev(hwif->dev); |
376 | u8 bmidecsr = 0, mask = hwif->channel ? 0x02 : 0x01; | 376 | u8 bmidecsr = 0, mask = hwif->channel ? 0x02 : 0x01; |
@@ -389,11 +389,6 @@ static void __devinit init_hwif_cmd64x(ide_hwif_t *hwif) | |||
389 | { | 389 | { |
390 | struct pci_dev *dev = to_pci_dev(hwif->dev); | 390 | struct pci_dev *dev = to_pci_dev(hwif->dev); |
391 | 391 | ||
392 | hwif->set_pio_mode = &cmd64x_set_pio_mode; | ||
393 | hwif->set_dma_mode = &cmd64x_set_dma_mode; | ||
394 | |||
395 | hwif->cable_detect = ata66_cmd64x; | ||
396 | |||
397 | if (!hwif->dma_base) | 392 | if (!hwif->dma_base) |
398 | return; | 393 | return; |
399 | 394 | ||
@@ -433,12 +428,19 @@ static void __devinit init_hwif_cmd64x(ide_hwif_t *hwif) | |||
433 | } | 428 | } |
434 | } | 429 | } |
435 | 430 | ||
431 | static const struct ide_port_ops cmd64x_port_ops = { | ||
432 | .set_pio_mode = cmd64x_set_pio_mode, | ||
433 | .set_dma_mode = cmd64x_set_dma_mode, | ||
434 | .cable_detect = cmd64x_cable_detect, | ||
435 | }; | ||
436 | |||
436 | static const struct ide_port_info cmd64x_chipsets[] __devinitdata = { | 437 | static const struct ide_port_info cmd64x_chipsets[] __devinitdata = { |
437 | { /* 0 */ | 438 | { /* 0 */ |
438 | .name = "CMD643", | 439 | .name = "CMD643", |
439 | .init_chipset = init_chipset_cmd64x, | 440 | .init_chipset = init_chipset_cmd64x, |
440 | .init_hwif = init_hwif_cmd64x, | 441 | .init_hwif = init_hwif_cmd64x, |
441 | .enablebits = {{0x00,0x00,0x00}, {0x51,0x08,0x08}}, | 442 | .enablebits = {{0x00,0x00,0x00}, {0x51,0x08,0x08}}, |
443 | .port_ops = &cmd64x_port_ops, | ||
442 | .host_flags = IDE_HFLAG_CLEAR_SIMPLEX | | 444 | .host_flags = IDE_HFLAG_CLEAR_SIMPLEX | |
443 | IDE_HFLAG_ABUSE_PREFETCH, | 445 | IDE_HFLAG_ABUSE_PREFETCH, |
444 | .pio_mask = ATA_PIO5, | 446 | .pio_mask = ATA_PIO5, |
@@ -450,6 +452,7 @@ static const struct ide_port_info cmd64x_chipsets[] __devinitdata = { | |||
450 | .init_hwif = init_hwif_cmd64x, | 452 | .init_hwif = init_hwif_cmd64x, |
451 | .enablebits = {{0x51,0x04,0x04}, {0x51,0x08,0x08}}, | 453 | .enablebits = {{0x51,0x04,0x04}, {0x51,0x08,0x08}}, |
452 | .chipset = ide_cmd646, | 454 | .chipset = ide_cmd646, |
455 | .port_ops = &cmd64x_port_ops, | ||
453 | .host_flags = IDE_HFLAG_ABUSE_PREFETCH, | 456 | .host_flags = IDE_HFLAG_ABUSE_PREFETCH, |
454 | .pio_mask = ATA_PIO5, | 457 | .pio_mask = ATA_PIO5, |
455 | .mwdma_mask = ATA_MWDMA2, | 458 | .mwdma_mask = ATA_MWDMA2, |
@@ -459,6 +462,7 @@ static const struct ide_port_info cmd64x_chipsets[] __devinitdata = { | |||
459 | .init_chipset = init_chipset_cmd64x, | 462 | .init_chipset = init_chipset_cmd64x, |
460 | .init_hwif = init_hwif_cmd64x, | 463 | .init_hwif = init_hwif_cmd64x, |
461 | .enablebits = {{0x51,0x04,0x04}, {0x51,0x08,0x08}}, | 464 | .enablebits = {{0x51,0x04,0x04}, {0x51,0x08,0x08}}, |
465 | .port_ops = &cmd64x_port_ops, | ||
462 | .host_flags = IDE_HFLAG_ABUSE_PREFETCH, | 466 | .host_flags = IDE_HFLAG_ABUSE_PREFETCH, |
463 | .pio_mask = ATA_PIO5, | 467 | .pio_mask = ATA_PIO5, |
464 | .mwdma_mask = ATA_MWDMA2, | 468 | .mwdma_mask = ATA_MWDMA2, |
@@ -468,6 +472,7 @@ static const struct ide_port_info cmd64x_chipsets[] __devinitdata = { | |||
468 | .init_chipset = init_chipset_cmd64x, | 472 | .init_chipset = init_chipset_cmd64x, |
469 | .init_hwif = init_hwif_cmd64x, | 473 | .init_hwif = init_hwif_cmd64x, |
470 | .enablebits = {{0x51,0x04,0x04}, {0x51,0x08,0x08}}, | 474 | .enablebits = {{0x51,0x04,0x04}, {0x51,0x08,0x08}}, |
475 | .port_ops = &cmd64x_port_ops, | ||
471 | .host_flags = IDE_HFLAG_ABUSE_PREFETCH, | 476 | .host_flags = IDE_HFLAG_ABUSE_PREFETCH, |
472 | .pio_mask = ATA_PIO5, | 477 | .pio_mask = ATA_PIO5, |
473 | .mwdma_mask = ATA_MWDMA2, | 478 | .mwdma_mask = ATA_MWDMA2, |