aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/ide/ide-lib.c7
-rw-r--r--drivers/ide/pci/sl82c105.c10
-rw-r--r--include/linux/ide.h6
3 files changed, 13 insertions, 10 deletions
diff --git a/drivers/ide/ide-lib.c b/drivers/ide/ide-lib.c
index d45bbad9ffe7..d5cc96bb4298 100644
--- a/drivers/ide/ide-lib.c
+++ b/drivers/ide/ide-lib.c
@@ -267,18 +267,15 @@ u8 ide_get_best_pio_mode (ide_drive_t *drive, u8 mode_wanted, u8 max_mode, ide_p
267{ 267{
268 int pio_mode; 268 int pio_mode;
269 int cycle_time = 0; 269 int cycle_time = 0;
270 int use_iordy = 0;
271 struct hd_driveid* id = drive->id; 270 struct hd_driveid* id = drive->id;
272 int overridden = 0; 271 int overridden = 0;
273 272
274 if (mode_wanted != 255) { 273 if (mode_wanted != 255) {
275 pio_mode = mode_wanted; 274 pio_mode = mode_wanted;
276 use_iordy = (pio_mode > 2);
277 } else if (!drive->id) { 275 } else if (!drive->id) {
278 pio_mode = 0; 276 pio_mode = 0;
279 } else if ((pio_mode = ide_scan_pio_blacklist(id->model)) != -1) { 277 } else if ((pio_mode = ide_scan_pio_blacklist(id->model)) != -1) {
280 printk(KERN_INFO "%s: is on PIO blacklist\n", drive->name); 278 printk(KERN_INFO "%s: is on PIO blacklist\n", drive->name);
281 use_iordy = (pio_mode > 2);
282 } else { 279 } else {
283 pio_mode = id->tPIO; 280 pio_mode = id->tPIO;
284 if (pio_mode > 2) { /* 2 is maximum allowed tPIO value */ 281 if (pio_mode > 2) { /* 2 is maximum allowed tPIO value */
@@ -286,8 +283,7 @@ u8 ide_get_best_pio_mode (ide_drive_t *drive, u8 mode_wanted, u8 max_mode, ide_p
286 overridden = 1; 283 overridden = 1;
287 } 284 }
288 if (id->field_valid & 2) { /* drive implements ATA2? */ 285 if (id->field_valid & 2) { /* drive implements ATA2? */
289 if (id->capability & 8) { /* drive supports use_iordy? */ 286 if (id->capability & 8) { /* IORDY supported? */
290 use_iordy = 1;
291 cycle_time = id->eide_pio_iordy; 287 cycle_time = id->eide_pio_iordy;
292 if (id->eide_pio_modes & 7) { 288 if (id->eide_pio_modes & 7) {
293 overridden = 0; 289 overridden = 0;
@@ -325,7 +321,6 @@ u8 ide_get_best_pio_mode (ide_drive_t *drive, u8 mode_wanted, u8 max_mode, ide_p
325 if (d) { 321 if (d) {
326 d->pio_mode = pio_mode; 322 d->pio_mode = pio_mode;
327 d->cycle_time = cycle_time ? cycle_time : ide_pio_timings[pio_mode].cycle_time; 323 d->cycle_time = cycle_time ? cycle_time : ide_pio_timings[pio_mode].cycle_time;
328 d->use_iordy = use_iordy;
329 } 324 }
330 return pio_mode; 325 return pio_mode;
331} 326}
diff --git a/drivers/ide/pci/sl82c105.c b/drivers/ide/pci/sl82c105.c
index a7323d278c49..f2156ee7e2bd 100644
--- a/drivers/ide/pci/sl82c105.c
+++ b/drivers/ide/pci/sl82c105.c
@@ -52,9 +52,10 @@
52 * Convert a PIO mode and cycle time to the required on/off times 52 * Convert a PIO mode and cycle time to the required on/off times
53 * for the interface. This has protection against runaway timings. 53 * for the interface. This has protection against runaway timings.
54 */ 54 */
55static unsigned int get_pio_timings(ide_pio_data_t *p) 55static unsigned int get_pio_timings(ide_drive_t *drive, ide_pio_data_t *p)
56{ 56{
57 unsigned int cmd_on, cmd_off; 57 unsigned int cmd_on, cmd_off;
58 u8 iordy = 0;
58 59
59 cmd_on = (ide_pio_timings[p->pio_mode].active_time + 29) / 30; 60 cmd_on = (ide_pio_timings[p->pio_mode].active_time + 29) / 30;
60 cmd_off = (p->cycle_time - 30 * cmd_on + 29) / 30; 61 cmd_off = (p->cycle_time - 30 * cmd_on + 29) / 30;
@@ -65,7 +66,10 @@ static unsigned int get_pio_timings(ide_pio_data_t *p)
65 if (cmd_off == 0) 66 if (cmd_off == 0)
66 cmd_off = 1; 67 cmd_off = 1;
67 68
68 return (cmd_on - 1) << 8 | (cmd_off - 1) | (p->use_iordy ? 0x40 : 0x00); 69 if (p->pio_mode > 2 || ide_dev_has_iordy(drive->id))
70 iordy = 0x40;
71
72 return (cmd_on - 1) << 8 | (cmd_off - 1) | iordy;
69} 73}
70 74
71/* 75/*
@@ -82,7 +86,7 @@ static u8 sl82c105_tune_pio(ide_drive_t *drive, u8 pio)
82 86
83 pio = ide_get_best_pio_mode(drive, pio, 5, &p); 87 pio = ide_get_best_pio_mode(drive, pio, 5, &p);
84 88
85 drv_ctrl = get_pio_timings(&p); 89 drv_ctrl = get_pio_timings(drive, &p);
86 90
87 /* 91 /*
88 * Store the PIO timings so that we can restore them 92 * Store the PIO timings so that we can restore them
diff --git a/include/linux/ide.h b/include/linux/ide.h
index 83a117d673c7..349c22a1fbc5 100644
--- a/include/linux/ide.h
+++ b/include/linux/ide.h
@@ -1363,6 +1363,11 @@ extern void ide_toggle_bounce(ide_drive_t *drive, int on);
1363extern int ide_set_xfer_rate(ide_drive_t *drive, u8 rate); 1363extern int ide_set_xfer_rate(ide_drive_t *drive, u8 rate);
1364int ide_use_fast_pio(ide_drive_t *); 1364int ide_use_fast_pio(ide_drive_t *);
1365 1365
1366static inline int ide_dev_has_iordy(struct hd_driveid *id)
1367{
1368 return ((id->field_valid & 2) && (id->capability & 8)) ? 1 : 0;
1369}
1370
1366u8 ide_dump_status(ide_drive_t *, const char *, u8); 1371u8 ide_dump_status(ide_drive_t *, const char *, u8);
1367 1372
1368typedef struct ide_pio_timings_s { 1373typedef struct ide_pio_timings_s {
@@ -1374,7 +1379,6 @@ typedef struct ide_pio_timings_s {
1374 1379
1375typedef struct ide_pio_data_s { 1380typedef struct ide_pio_data_s {
1376 u8 pio_mode; 1381 u8 pio_mode;
1377 u8 use_iordy;
1378 unsigned int cycle_time; 1382 unsigned int cycle_time;
1379} ide_pio_data_t; 1383} ide_pio_data_t;
1380 1384