aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/ide/ide-tape.c41
1 files changed, 26 insertions, 15 deletions
diff --git a/drivers/ide/ide-tape.c b/drivers/ide/ide-tape.c
index d67a17891786..a5f0b774527b 100644
--- a/drivers/ide/ide-tape.c
+++ b/drivers/ide/ide-tape.c
@@ -1519,12 +1519,16 @@ static void idetape_create_test_unit_ready_cmd(struct ide_atapi_pc *pc)
1519static int idetape_queue_pc_tail(ide_drive_t *drive, struct ide_atapi_pc *pc) 1519static int idetape_queue_pc_tail(ide_drive_t *drive, struct ide_atapi_pc *pc)
1520{ 1520{
1521 struct ide_tape_obj *tape = drive->driver_data; 1521 struct ide_tape_obj *tape = drive->driver_data;
1522 struct request rq; 1522 struct request *rq;
1523 int error;
1523 1524
1524 idetape_init_rq(&rq, REQ_IDETAPE_PC1); 1525 rq = blk_get_request(drive->queue, READ, __GFP_WAIT);
1525 rq.buffer = (char *) pc; 1526 rq->cmd_type = REQ_TYPE_SPECIAL;
1526 rq.rq_disk = tape->disk; 1527 rq->cmd[0] = REQ_IDETAPE_PC1;
1527 return ide_do_drive_cmd(drive, &rq, ide_wait); 1528 rq->buffer = (char *)pc;
1529 error = blk_execute_rq(drive->queue, tape->disk, rq, 0);
1530 blk_put_request(rq);
1531 return error;
1528} 1532}
1529 1533
1530static void idetape_create_load_unload_cmd(ide_drive_t *drive, 1534static void idetape_create_load_unload_cmd(ide_drive_t *drive,
@@ -1701,26 +1705,33 @@ static int idetape_queue_rw_tail(ide_drive_t *drive, int cmd, int blocks,
1701 struct idetape_bh *bh) 1705 struct idetape_bh *bh)
1702{ 1706{
1703 idetape_tape_t *tape = drive->driver_data; 1707 idetape_tape_t *tape = drive->driver_data;
1704 struct request rq; 1708 struct request *rq;
1709 int ret, errors;
1705 1710
1706 debug_log(DBG_SENSE, "%s: cmd=%d\n", __func__, cmd); 1711 debug_log(DBG_SENSE, "%s: cmd=%d\n", __func__, cmd);
1707 1712
1708 idetape_init_rq(&rq, cmd); 1713 rq = blk_get_request(drive->queue, READ, __GFP_WAIT);
1709 rq.rq_disk = tape->disk; 1714 rq->cmd_type = REQ_TYPE_SPECIAL;
1710 rq.special = (void *)bh; 1715 rq->cmd[0] = cmd;
1711 rq.sector = tape->first_frame; 1716 rq->rq_disk = tape->disk;
1712 rq.nr_sectors = blocks; 1717 rq->special = (void *)bh;
1713 rq.current_nr_sectors = blocks; 1718 rq->sector = tape->first_frame;
1714 (void) ide_do_drive_cmd(drive, &rq, ide_wait); 1719 rq->nr_sectors = blocks;
1720 rq->current_nr_sectors = blocks;
1721 blk_execute_rq(drive->queue, tape->disk, rq, 0);
1722
1723 errors = rq->errors;
1724 ret = tape->blk_size * (blocks - rq->current_nr_sectors);
1725 blk_put_request(rq);
1715 1726
1716 if ((cmd & (REQ_IDETAPE_READ | REQ_IDETAPE_WRITE)) == 0) 1727 if ((cmd & (REQ_IDETAPE_READ | REQ_IDETAPE_WRITE)) == 0)
1717 return 0; 1728 return 0;
1718 1729
1719 if (tape->merge_bh) 1730 if (tape->merge_bh)
1720 idetape_init_merge_buffer(tape); 1731 idetape_init_merge_buffer(tape);
1721 if (rq.errors == IDETAPE_ERROR_GENERAL) 1732 if (errors == IDETAPE_ERROR_GENERAL)
1722 return -EIO; 1733 return -EIO;
1723 return (tape->blk_size * (blocks-rq.current_nr_sectors)); 1734 return ret;
1724} 1735}
1725 1736
1726static void idetape_create_inquiry_cmd(struct ide_atapi_pc *pc) 1737static void idetape_create_inquiry_cmd(struct ide_atapi_pc *pc)