diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/ide/pci/cmd640.c | 72 |
1 files changed, 30 insertions, 42 deletions
diff --git a/drivers/ide/pci/cmd640.c b/drivers/ide/pci/cmd640.c index ab7d7274d8b1..1ad1e23e3105 100644 --- a/drivers/ide/pci/cmd640.c +++ b/drivers/ide/pci/cmd640.c | |||
@@ -611,11 +611,40 @@ static void cmd640_set_pio_mode(ide_drive_t *drive, const u8 pio) | |||
611 | 611 | ||
612 | display_clocks(index); | 612 | display_clocks(index); |
613 | } | 613 | } |
614 | #endif /* CONFIG_BLK_DEV_CMD640_ENHANCED */ | ||
615 | |||
616 | static void cmd640_init_dev(ide_drive_t *drive) | ||
617 | { | ||
618 | unsigned int i = drive->hwif->channel * 2 + drive->select.b.unit; | ||
619 | |||
620 | #ifdef CONFIG_BLK_DEV_CMD640_ENHANCED | ||
621 | /* | ||
622 | * Reset timing to the slowest speed and turn off prefetch. | ||
623 | * This way, the drive identify code has a better chance. | ||
624 | */ | ||
625 | setup_counts[i] = 4; /* max possible */ | ||
626 | active_counts[i] = 16; /* max possible */ | ||
627 | recovery_counts[i] = 16; /* max possible */ | ||
628 | program_drive_counts(drive, i); | ||
629 | set_prefetch_mode(drive, i, 0); | ||
630 | printk(KERN_INFO DRV_NAME ": drive%d timings/prefetch cleared\n", i); | ||
631 | #else | ||
632 | /* | ||
633 | * Set the drive unmask flags to match the prefetch setting. | ||
634 | */ | ||
635 | check_prefetch(drive, i); | ||
636 | printk(KERN_INFO DRV_NAME ": drive%d timings/prefetch(%s) preserved\n", | ||
637 | i, drive->no_io_32bit ? "off" : "on"); | ||
638 | #endif /* CONFIG_BLK_DEV_CMD640_ENHANCED */ | ||
639 | } | ||
640 | |||
614 | 641 | ||
615 | static const struct ide_port_ops cmd640_port_ops = { | 642 | static const struct ide_port_ops cmd640_port_ops = { |
643 | .init_dev = cmd640_init_dev, | ||
644 | #ifdef CONFIG_BLK_DEV_CMD640_ENHANCED | ||
616 | .set_pio_mode = cmd640_set_pio_mode, | 645 | .set_pio_mode = cmd640_set_pio_mode, |
646 | #endif | ||
617 | }; | 647 | }; |
618 | #endif /* CONFIG_BLK_DEV_CMD640_ENHANCED */ | ||
619 | 648 | ||
620 | static int pci_conf1(void) | 649 | static int pci_conf1(void) |
621 | { | 650 | { |
@@ -658,10 +687,8 @@ static const struct ide_port_info cmd640_port_info __initdata = { | |||
658 | IDE_HFLAG_NO_DMA | | 687 | IDE_HFLAG_NO_DMA | |
659 | IDE_HFLAG_ABUSE_PREFETCH | | 688 | IDE_HFLAG_ABUSE_PREFETCH | |
660 | IDE_HFLAG_ABUSE_FAST_DEVSEL, | 689 | IDE_HFLAG_ABUSE_FAST_DEVSEL, |
661 | #ifdef CONFIG_BLK_DEV_CMD640_ENHANCED | ||
662 | .port_ops = &cmd640_port_ops, | 690 | .port_ops = &cmd640_port_ops, |
663 | .pio_mask = ATA_PIO5, | 691 | .pio_mask = ATA_PIO5, |
664 | #endif | ||
665 | }; | 692 | }; |
666 | 693 | ||
667 | static int cmd640x_init_one(unsigned long base, unsigned long ctl) | 694 | static int cmd640x_init_one(unsigned long base, unsigned long ctl) |
@@ -689,7 +716,6 @@ static int __init cmd640x_init(void) | |||
689 | { | 716 | { |
690 | int second_port_cmd640 = 0, rc; | 717 | int second_port_cmd640 = 0, rc; |
691 | const char *bus_type, *port2; | 718 | const char *bus_type, *port2; |
692 | unsigned int index; | ||
693 | u8 b, cfr; | 719 | u8 b, cfr; |
694 | u8 idx[4] = { 0xff, 0xff, 0xff, 0xff }; | 720 | u8 idx[4] = { 0xff, 0xff, 0xff, 0xff }; |
695 | hw_regs_t hw[2]; | 721 | hw_regs_t hw[2]; |
@@ -813,44 +839,6 @@ static int __init cmd640x_init(void) | |||
813 | printk(KERN_INFO "cmd640: %sserialized, secondary interface %s\n", | 839 | printk(KERN_INFO "cmd640: %sserialized, secondary interface %s\n", |
814 | second_port_cmd640 ? "" : "not ", port2); | 840 | second_port_cmd640 ? "" : "not ", port2); |
815 | 841 | ||
816 | /* | ||
817 | * Establish initial timings/prefetch for all drives. | ||
818 | * Do not unnecessarily disturb any prior BIOS setup of these. | ||
819 | */ | ||
820 | for (index = 0; index < (2 + (second_port_cmd640 << 1)); index++) { | ||
821 | ide_drive_t *drive; | ||
822 | |||
823 | if (index > 1) { | ||
824 | if (cmd_hwif1 == NULL) | ||
825 | continue; | ||
826 | drive = &cmd_hwif1->drives[index & 1]; | ||
827 | } else { | ||
828 | if (cmd_hwif0 == NULL) | ||
829 | continue; | ||
830 | drive = &cmd_hwif0->drives[index & 1]; | ||
831 | } | ||
832 | |||
833 | #ifdef CONFIG_BLK_DEV_CMD640_ENHANCED | ||
834 | /* | ||
835 | * Reset timing to the slowest speed and turn off prefetch. | ||
836 | * This way, the drive identify code has a better chance. | ||
837 | */ | ||
838 | setup_counts [index] = 4; /* max possible */ | ||
839 | active_counts [index] = 16; /* max possible */ | ||
840 | recovery_counts [index] = 16; /* max possible */ | ||
841 | program_drive_counts(drive, index); | ||
842 | set_prefetch_mode(drive, index, 0); | ||
843 | printk("cmd640: drive%d timings/prefetch cleared\n", index); | ||
844 | #else | ||
845 | /* | ||
846 | * Set the drive unmask flags to match the prefetch setting | ||
847 | */ | ||
848 | check_prefetch(drive, index); | ||
849 | printk("cmd640: drive%d timings/prefetch(%s) preserved\n", | ||
850 | index, drive->no_io_32bit ? "off" : "on"); | ||
851 | #endif /* CONFIG_BLK_DEV_CMD640_ENHANCED */ | ||
852 | } | ||
853 | |||
854 | #ifdef CMD640_DUMP_REGS | 842 | #ifdef CMD640_DUMP_REGS |
855 | cmd640_dump_regs(); | 843 | cmd640_dump_regs(); |
856 | #endif | 844 | #endif |