diff options
Diffstat (limited to 'drivers/ide')
-rw-r--r-- | drivers/ide/ide-atapi.c | 41 | ||||
-rw-r--r-- | drivers/ide/ide-cd.c | 38 | ||||
-rw-r--r-- | drivers/ide/ide-cd.h | 4 | ||||
-rw-r--r-- | drivers/ide/ide-floppy.c | 2 | ||||
-rw-r--r-- | drivers/ide/ide-tape.c | 2 |
5 files changed, 43 insertions, 44 deletions
diff --git a/drivers/ide/ide-atapi.c b/drivers/ide/ide-atapi.c index 8c5cf68fbd79..c110329ccb13 100644 --- a/drivers/ide/ide-atapi.c +++ b/drivers/ide/ide-atapi.c | |||
@@ -3,6 +3,7 @@ | |||
3 | */ | 3 | */ |
4 | 4 | ||
5 | #include <linux/kernel.h> | 5 | #include <linux/kernel.h> |
6 | #include <linux/cdrom.h> | ||
6 | #include <linux/delay.h> | 7 | #include <linux/delay.h> |
7 | #include <linux/ide.h> | 8 | #include <linux/ide.h> |
8 | #include <scsi/scsi.h> | 9 | #include <scsi/scsi.h> |
@@ -252,6 +253,38 @@ int ide_scsi_expiry(ide_drive_t *drive) | |||
252 | } | 253 | } |
253 | EXPORT_SYMBOL_GPL(ide_scsi_expiry); | 254 | EXPORT_SYMBOL_GPL(ide_scsi_expiry); |
254 | 255 | ||
256 | int ide_cd_expiry(ide_drive_t *drive) | ||
257 | { | ||
258 | struct request *rq = HWGROUP(drive)->rq; | ||
259 | unsigned long wait = 0; | ||
260 | |||
261 | debug_log("%s: rq->cmd[0]: 0x%x\n", __func__, rq->cmd[0]); | ||
262 | |||
263 | /* | ||
264 | * Some commands are *slow* and normally take a long time to complete. | ||
265 | * Usually we can use the ATAPI "disconnect" to bypass this, but not all | ||
266 | * commands/drives support that. Let ide_timer_expiry keep polling us | ||
267 | * for these. | ||
268 | */ | ||
269 | switch (rq->cmd[0]) { | ||
270 | case GPCMD_BLANK: | ||
271 | case GPCMD_FORMAT_UNIT: | ||
272 | case GPCMD_RESERVE_RZONE_TRACK: | ||
273 | case GPCMD_CLOSE_TRACK: | ||
274 | case GPCMD_FLUSH_CACHE: | ||
275 | wait = ATAPI_WAIT_PC; | ||
276 | break; | ||
277 | default: | ||
278 | if (!(rq->cmd_flags & REQ_QUIET)) | ||
279 | printk(KERN_INFO "cmd 0x%x timed out\n", | ||
280 | rq->cmd[0]); | ||
281 | wait = 0; | ||
282 | break; | ||
283 | } | ||
284 | return wait; | ||
285 | } | ||
286 | EXPORT_SYMBOL_GPL(ide_cd_expiry); | ||
287 | |||
255 | int ide_cd_get_xferlen(struct request *rq) | 288 | int ide_cd_get_xferlen(struct request *rq) |
256 | { | 289 | { |
257 | if (blk_fs_request(rq)) | 290 | if (blk_fs_request(rq)) |
@@ -562,11 +595,11 @@ static ide_startstop_t ide_transfer_pc(ide_drive_t *drive) | |||
562 | return ide_started; | 595 | return ide_started; |
563 | } | 596 | } |
564 | 597 | ||
565 | ide_startstop_t ide_issue_pc(ide_drive_t *drive, unsigned int timeout, | 598 | ide_startstop_t ide_issue_pc(ide_drive_t *drive, unsigned int timeout) |
566 | ide_expiry_t *expiry) | ||
567 | { | 599 | { |
568 | struct ide_atapi_pc *pc = drive->pc; | 600 | struct ide_atapi_pc *pc = drive->pc; |
569 | ide_hwif_t *hwif = drive->hwif; | 601 | ide_hwif_t *hwif = drive->hwif; |
602 | ide_expiry_t *expiry = NULL; | ||
570 | u32 tf_flags; | 603 | u32 tf_flags; |
571 | u16 bcount; | 604 | u16 bcount; |
572 | u8 scsi = !!(drive->dev_flags & IDE_DFLAG_SCSI); | 605 | u8 scsi = !!(drive->dev_flags & IDE_DFLAG_SCSI); |
@@ -578,9 +611,11 @@ ide_startstop_t ide_issue_pc(ide_drive_t *drive, unsigned int timeout, | |||
578 | if (dev_is_idecd(drive)) { | 611 | if (dev_is_idecd(drive)) { |
579 | tf_flags = IDE_TFLAG_OUT_NSECT | IDE_TFLAG_OUT_LBAL; | 612 | tf_flags = IDE_TFLAG_OUT_NSECT | IDE_TFLAG_OUT_LBAL; |
580 | bcount = ide_cd_get_xferlen(hwif->hwgroup->rq); | 613 | bcount = ide_cd_get_xferlen(hwif->hwgroup->rq); |
614 | expiry = ide_cd_expiry; | ||
581 | } else if (scsi) { | 615 | } else if (scsi) { |
582 | tf_flags = 0; | 616 | tf_flags = 0; |
583 | bcount = min(pc->req_xfer, 63 * 1024); | 617 | bcount = min(pc->req_xfer, 63 * 1024); |
618 | expiry = ide_scsi_expiry; | ||
584 | } else { | 619 | } else { |
585 | tf_flags = IDE_TFLAG_OUT_DEVICE; | 620 | tf_flags = IDE_TFLAG_OUT_DEVICE; |
586 | bcount = ((drive->media == ide_tape) ? | 621 | bcount = ((drive->media == ide_tape) ? |
@@ -613,7 +648,7 @@ ide_startstop_t ide_issue_pc(ide_drive_t *drive, unsigned int timeout, | |||
613 | if (drive->dma) | 648 | if (drive->dma) |
614 | drive->waiting_for_dma = 0; | 649 | drive->waiting_for_dma = 0; |
615 | ide_execute_command(drive, ATA_CMD_PACKET, ide_transfer_pc, | 650 | ide_execute_command(drive, ATA_CMD_PACKET, ide_transfer_pc, |
616 | timeout, NULL); | 651 | timeout, expiry); |
617 | return ide_started; | 652 | return ide_started; |
618 | } else { | 653 | } else { |
619 | ide_execute_pkt_cmd(drive); | 654 | ide_execute_pkt_cmd(drive); |
diff --git a/drivers/ide/ide-cd.c b/drivers/ide/ide-cd.c index 8d3c7714682e..105e4d855e6e 100644 --- a/drivers/ide/ide-cd.c +++ b/drivers/ide/ide-cd.c | |||
@@ -511,38 +511,6 @@ end_request: | |||
511 | return 1; | 511 | return 1; |
512 | } | 512 | } |
513 | 513 | ||
514 | static int cdrom_timer_expiry(ide_drive_t *drive) | ||
515 | { | ||
516 | struct request *rq = HWGROUP(drive)->rq; | ||
517 | unsigned long wait = 0; | ||
518 | |||
519 | ide_debug_log(IDE_DBG_RQ, "Call %s: rq->cmd[0]: 0x%x\n", __func__, | ||
520 | rq->cmd[0]); | ||
521 | |||
522 | /* | ||
523 | * Some commands are *slow* and normally take a long time to complete. | ||
524 | * Usually we can use the ATAPI "disconnect" to bypass this, but not all | ||
525 | * commands/drives support that. Let ide_timer_expiry keep polling us | ||
526 | * for these. | ||
527 | */ | ||
528 | switch (rq->cmd[0]) { | ||
529 | case GPCMD_BLANK: | ||
530 | case GPCMD_FORMAT_UNIT: | ||
531 | case GPCMD_RESERVE_RZONE_TRACK: | ||
532 | case GPCMD_CLOSE_TRACK: | ||
533 | case GPCMD_FLUSH_CACHE: | ||
534 | wait = ATAPI_WAIT_PC; | ||
535 | break; | ||
536 | default: | ||
537 | if (!(rq->cmd_flags & REQ_QUIET)) | ||
538 | printk(KERN_INFO PFX "cmd 0x%x timed out\n", | ||
539 | rq->cmd[0]); | ||
540 | wait = 0; | ||
541 | break; | ||
542 | } | ||
543 | return wait; | ||
544 | } | ||
545 | |||
546 | /* | 514 | /* |
547 | * Set up the device registers for transferring a packet command on DEV, | 515 | * Set up the device registers for transferring a packet command on DEV, |
548 | * expecting to later transfer XFERLEN bytes. HANDLER is the routine | 516 | * expecting to later transfer XFERLEN bytes. HANDLER is the routine |
@@ -574,7 +542,7 @@ static ide_startstop_t cdrom_start_packet_command(ide_drive_t *drive, | |||
574 | 542 | ||
575 | /* packet command */ | 543 | /* packet command */ |
576 | ide_execute_command(drive, ATA_CMD_PACKET, handler, | 544 | ide_execute_command(drive, ATA_CMD_PACKET, handler, |
577 | ATAPI_WAIT_PC, cdrom_timer_expiry); | 545 | ATAPI_WAIT_PC, ide_cd_expiry); |
578 | return ide_started; | 546 | return ide_started; |
579 | } else { | 547 | } else { |
580 | ide_execute_pkt_cmd(drive); | 548 | ide_execute_pkt_cmd(drive); |
@@ -621,7 +589,7 @@ static ide_startstop_t cdrom_transfer_packet_command(ide_drive_t *drive, | |||
621 | } | 589 | } |
622 | 590 | ||
623 | /* arm the interrupt handler */ | 591 | /* arm the interrupt handler */ |
624 | ide_set_handler(drive, handler, rq->timeout, cdrom_timer_expiry); | 592 | ide_set_handler(drive, handler, rq->timeout, ide_cd_expiry); |
625 | 593 | ||
626 | /* ATAPI commands get padded out to 12 bytes minimum */ | 594 | /* ATAPI commands get padded out to 12 bytes minimum */ |
627 | cmd_len = COMMAND_SIZE(rq->cmd[0]); | 595 | cmd_len = COMMAND_SIZE(rq->cmd[0]); |
@@ -1088,7 +1056,7 @@ static ide_startstop_t cdrom_newpc_intr(ide_drive_t *drive) | |||
1088 | } else { | 1056 | } else { |
1089 | timeout = ATAPI_WAIT_PC; | 1057 | timeout = ATAPI_WAIT_PC; |
1090 | if (!blk_fs_request(rq)) | 1058 | if (!blk_fs_request(rq)) |
1091 | expiry = cdrom_timer_expiry; | 1059 | expiry = ide_cd_expiry; |
1092 | } | 1060 | } |
1093 | 1061 | ||
1094 | ide_set_handler(drive, cdrom_newpc_intr, timeout, expiry); | 1062 | ide_set_handler(drive, cdrom_newpc_intr, timeout, expiry); |
diff --git a/drivers/ide/ide-cd.h b/drivers/ide/ide-cd.h index 389faa42eaa1..bf676b262181 100644 --- a/drivers/ide/ide-cd.h +++ b/drivers/ide/ide-cd.h | |||
@@ -16,10 +16,6 @@ | |||
16 | #define ide_debug_log(lvl, fmt, args...) do {} while (0) | 16 | #define ide_debug_log(lvl, fmt, args...) do {} while (0) |
17 | #endif | 17 | #endif |
18 | 18 | ||
19 | /* | ||
20 | * typical timeout for packet command | ||
21 | */ | ||
22 | #define ATAPI_WAIT_PC (60 * HZ) | ||
23 | #define ATAPI_WAIT_WRITE_BUSY (10 * HZ) | 19 | #define ATAPI_WAIT_WRITE_BUSY (10 * HZ) |
24 | 20 | ||
25 | /************************************************************************/ | 21 | /************************************************************************/ |
diff --git a/drivers/ide/ide-floppy.c b/drivers/ide/ide-floppy.c index 1f07f3818938..fdec729d0e49 100644 --- a/drivers/ide/ide-floppy.c +++ b/drivers/ide/ide-floppy.c | |||
@@ -197,7 +197,7 @@ static ide_startstop_t idefloppy_issue_pc(ide_drive_t *drive, | |||
197 | 197 | ||
198 | pc->retries++; | 198 | pc->retries++; |
199 | 199 | ||
200 | return ide_issue_pc(drive, WAIT_FLOPPY_CMD, NULL); | 200 | return ide_issue_pc(drive, WAIT_FLOPPY_CMD); |
201 | } | 201 | } |
202 | 202 | ||
203 | void ide_floppy_create_read_capacity_cmd(struct ide_atapi_pc *pc) | 203 | void ide_floppy_create_read_capacity_cmd(struct ide_atapi_pc *pc) |
diff --git a/drivers/ide/ide-tape.c b/drivers/ide/ide-tape.c index a2d470eb2b55..ac9e29a4991f 100644 --- a/drivers/ide/ide-tape.c +++ b/drivers/ide/ide-tape.c | |||
@@ -694,7 +694,7 @@ static ide_startstop_t idetape_issue_pc(ide_drive_t *drive, | |||
694 | 694 | ||
695 | pc->retries++; | 695 | pc->retries++; |
696 | 696 | ||
697 | return ide_issue_pc(drive, WAIT_TAPE_CMD, NULL); | 697 | return ide_issue_pc(drive, WAIT_TAPE_CMD); |
698 | } | 698 | } |
699 | 699 | ||
700 | /* A mode sense command is used to "sense" tape parameters. */ | 700 | /* A mode sense command is used to "sense" tape parameters. */ |