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/mips | |
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/mips')
-rw-r--r-- | drivers/ide/mips/au1xxx-ide.c | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/drivers/ide/mips/au1xxx-ide.c b/drivers/ide/mips/au1xxx-ide.c index a8cd0035936d..51dddc0f154e 100644 --- a/drivers/ide/mips/au1xxx-ide.c +++ b/drivers/ide/mips/au1xxx-ide.c | |||
@@ -543,7 +543,16 @@ static void auide_setup_ports(hw_regs_t *hw, _auide_hwif *ahwif) | |||
543 | *ata_regs = ahwif->regbase + (14 << AU1XXX_ATA_REG_OFFSET); | 543 | *ata_regs = ahwif->regbase + (14 << AU1XXX_ATA_REG_OFFSET); |
544 | } | 544 | } |
545 | 545 | ||
546 | static const struct ide_port_ops au1xxx_port_ops = { | ||
547 | .set_pio_mode = au1xxx_set_pio_mode, | ||
548 | .set_dma_mode = auide_set_dma_mode, | ||
549 | #ifdef CONFIG_BLK_DEV_IDE_AU1XXX_MDMA2_DBDMA | ||
550 | .mdma_filter = auide_mdma_filter, | ||
551 | #endif | ||
552 | }; | ||
553 | |||
546 | static const struct ide_port_info au1xxx_port_info = { | 554 | static const struct ide_port_info au1xxx_port_info = { |
555 | .port_ops = &au1xxx_port_ops, | ||
547 | .host_flags = IDE_HFLAG_POST_SET_MODE | | 556 | .host_flags = IDE_HFLAG_POST_SET_MODE | |
548 | IDE_HFLAG_NO_DMA | /* no SFF-style DMA */ | 557 | IDE_HFLAG_NO_DMA | /* no SFF-style DMA */ |
549 | IDE_HFLAG_NO_IO_32BIT | | 558 | IDE_HFLAG_NO_IO_32BIT | |
@@ -625,15 +634,8 @@ static int au_ide_probe(struct device *dev) | |||
625 | hwif->INSW = auide_insw; | 634 | hwif->INSW = auide_insw; |
626 | hwif->OUTSW = auide_outsw; | 635 | hwif->OUTSW = auide_outsw; |
627 | #endif | 636 | #endif |
628 | |||
629 | hwif->set_pio_mode = &au1xxx_set_pio_mode; | ||
630 | hwif->set_dma_mode = &auide_set_dma_mode; | ||
631 | |||
632 | #ifdef CONFIG_BLK_DEV_IDE_AU1XXX_MDMA2_DBDMA | 637 | #ifdef CONFIG_BLK_DEV_IDE_AU1XXX_MDMA2_DBDMA |
633 | hwif->dma_timeout = &auide_dma_timeout; | 638 | hwif->dma_timeout = &auide_dma_timeout; |
634 | |||
635 | hwif->mdma_filter = &auide_mdma_filter; | ||
636 | |||
637 | hwif->dma_host_set = &auide_dma_host_set; | 639 | hwif->dma_host_set = &auide_dma_host_set; |
638 | hwif->dma_exec_cmd = &auide_dma_exec_cmd; | 640 | hwif->dma_exec_cmd = &auide_dma_exec_cmd; |
639 | hwif->dma_start = &auide_dma_start; | 641 | hwif->dma_start = &auide_dma_start; |