diff options
-rw-r--r-- | drivers/ide/ide-timing.h | 24 | ||||
-rw-r--r-- | drivers/ide/pci/cs5535.c | 4 |
2 files changed, 8 insertions, 20 deletions
diff --git a/drivers/ide/ide-timing.h b/drivers/ide/ide-timing.h index 724879910ac8..a401d8f82b50 100644 --- a/drivers/ide/ide-timing.h +++ b/drivers/ide/ide-timing.h | |||
@@ -70,11 +70,6 @@ static struct ide_timing ide_timing[] = { | |||
70 | #define ENOUGH(v,unit) (((v)-1)/(unit)+1) | 70 | #define ENOUGH(v,unit) (((v)-1)/(unit)+1) |
71 | #define EZ(v,unit) ((v)?ENOUGH(v,unit):0) | 71 | #define EZ(v,unit) ((v)?ENOUGH(v,unit):0) |
72 | 72 | ||
73 | #define XFER_MODE 0xf0 | ||
74 | #define XFER_MWDMA 0x20 | ||
75 | #define XFER_EPIO 0x01 | ||
76 | #define XFER_PIO 0x00 | ||
77 | |||
78 | static void ide_timing_quantize(struct ide_timing *t, struct ide_timing *q, int T, int UT) | 73 | static void ide_timing_quantize(struct ide_timing *t, struct ide_timing *q, int T, int UT) |
79 | { | 74 | { |
80 | q->setup = EZ(t->setup * 1000, T); | 75 | q->setup = EZ(t->setup * 1000, T); |
@@ -137,17 +132,12 @@ static int ide_timing_compute(ide_drive_t *drive, u8 speed, | |||
137 | 132 | ||
138 | memset(&p, 0, sizeof(p)); | 133 | memset(&p, 0, sizeof(p)); |
139 | 134 | ||
140 | switch (speed & XFER_MODE) { | 135 | if (speed <= XFER_PIO_2) |
141 | 136 | p.cycle = p.cyc8b = id->eide_pio; | |
142 | case XFER_PIO: | 137 | else if (speed <= XFER_PIO_5) |
143 | if (speed <= XFER_PIO_2) p.cycle = p.cyc8b = id->eide_pio; | 138 | p.cycle = p.cyc8b = id->eide_pio_iordy; |
144 | else p.cycle = p.cyc8b = id->eide_pio_iordy; | 139 | else if (speed >= XFER_MW_DMA_0 && speed <= XFER_MW_DMA_2) |
145 | break; | 140 | p.cycle = id->eide_dma_min; |
146 | |||
147 | case XFER_MWDMA: | ||
148 | p.cycle = id->eide_dma_min; | ||
149 | break; | ||
150 | } | ||
151 | 141 | ||
152 | ide_timing_merge(&p, t, t, IDE_TIMING_CYCLE | IDE_TIMING_CYC8B); | 142 | ide_timing_merge(&p, t, t, IDE_TIMING_CYCLE | IDE_TIMING_CYC8B); |
153 | } | 143 | } |
@@ -164,7 +154,7 @@ static int ide_timing_compute(ide_drive_t *drive, u8 speed, | |||
164 | * slower/equal than the fastest PIO timing. | 154 | * slower/equal than the fastest PIO timing. |
165 | */ | 155 | */ |
166 | 156 | ||
167 | if ((speed & XFER_MODE) != XFER_PIO) { | 157 | if (speed >= XFER_SW_DMA_0) { |
168 | u8 pio = ide_get_best_pio_mode(drive, 255, 5); | 158 | u8 pio = ide_get_best_pio_mode(drive, 255, 5); |
169 | ide_timing_compute(drive, XFER_PIO_0 + pio, &p, T, UT); | 159 | ide_timing_compute(drive, XFER_PIO_0 + pio, &p, T, UT); |
170 | ide_timing_merge(&p, t, t, IDE_TIMING_ALL); | 160 | ide_timing_merge(&p, t, t, IDE_TIMING_ALL); |
diff --git a/drivers/ide/pci/cs5535.c b/drivers/ide/pci/cs5535.c index 99fe91a191b8..2a2cb4911905 100644 --- a/drivers/ide/pci/cs5535.c +++ b/drivers/ide/pci/cs5535.c | |||
@@ -75,13 +75,11 @@ static unsigned int cs5535_udma_timings[5] = | |||
75 | */ | 75 | */ |
76 | static void cs5535_set_speed(ide_drive_t *drive, const u8 speed) | 76 | static void cs5535_set_speed(ide_drive_t *drive, const u8 speed) |
77 | { | 77 | { |
78 | |||
79 | u32 reg = 0, dummy; | 78 | u32 reg = 0, dummy; |
80 | int unit = drive->select.b.unit; | 79 | int unit = drive->select.b.unit; |
81 | 80 | ||
82 | |||
83 | /* Set the PIO timings */ | 81 | /* Set the PIO timings */ |
84 | if ((speed & XFER_MODE) == XFER_PIO) { | 82 | if (speed < XFER_SW_DMA_0) { |
85 | ide_drive_t *pair = ide_get_paired_drive(drive); | 83 | ide_drive_t *pair = ide_get_paired_drive(drive); |
86 | u8 cmd, pioa; | 84 | u8 cmd, pioa; |
87 | 85 | ||