aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/ide/ide-taskfile.c34
1 files changed, 20 insertions, 14 deletions
diff --git a/drivers/ide/ide-taskfile.c b/drivers/ide/ide-taskfile.c
index ab545ffa1549..b6a1c4b51129 100644
--- a/drivers/ide/ide-taskfile.c
+++ b/drivers/ide/ide-taskfile.c
@@ -492,11 +492,12 @@ static ide_startstop_t pre_task_out_intr(ide_drive_t *drive, struct request *rq)
492 492
493int ide_raw_taskfile(ide_drive_t *drive, ide_task_t *task, u8 *buf, u16 nsect) 493int ide_raw_taskfile(ide_drive_t *drive, ide_task_t *task, u8 *buf, u16 nsect)
494{ 494{
495 struct request rq; 495 struct request *rq;
496 int error;
496 497
497 blk_rq_init(NULL, &rq); 498 rq = blk_get_request(drive->queue, READ, __GFP_WAIT);
498 rq.cmd_type = REQ_TYPE_ATA_TASKFILE; 499 rq->cmd_type = REQ_TYPE_ATA_TASKFILE;
499 rq.buffer = buf; 500 rq->buffer = buf;
500 501
501 /* 502 /*
502 * (ks) We transfer currently only whole sectors. 503 * (ks) We transfer currently only whole sectors.
@@ -504,16 +505,19 @@ int ide_raw_taskfile(ide_drive_t *drive, ide_task_t *task, u8 *buf, u16 nsect)
504 * if we would find a solution to transfer any size. 505 * if we would find a solution to transfer any size.
505 * To support special commands like READ LONG. 506 * To support special commands like READ LONG.
506 */ 507 */
507 rq.hard_nr_sectors = rq.nr_sectors = nsect; 508 rq->hard_nr_sectors = rq->nr_sectors = nsect;
508 rq.hard_cur_sectors = rq.current_nr_sectors = nsect; 509 rq->hard_cur_sectors = rq->current_nr_sectors = nsect;
509 510
510 if (task->tf_flags & IDE_TFLAG_WRITE) 511 if (task->tf_flags & IDE_TFLAG_WRITE)
511 rq.cmd_flags |= REQ_RW; 512 rq->cmd_flags |= REQ_RW;
512 513
513 rq.special = task; 514 rq->special = task;
514 task->rq = &rq; 515 task->rq = rq;
515 516
516 return ide_do_drive_cmd(drive, &rq, ide_wait); 517 error = blk_execute_rq(drive->queue, NULL, rq, 0);
518 blk_put_request(rq);
519
520 return error;
517} 521}
518 522
519EXPORT_SYMBOL(ide_raw_taskfile); 523EXPORT_SYMBOL(ide_raw_taskfile);
@@ -739,12 +743,14 @@ int ide_cmd_ioctl (ide_drive_t *drive, unsigned int cmd, unsigned long arg)
739 struct hd_driveid *id = drive->id; 743 struct hd_driveid *id = drive->id;
740 744
741 if (NULL == (void *) arg) { 745 if (NULL == (void *) arg) {
742 struct request rq; 746 struct request *rq;
743 747
744 ide_init_drive_cmd(&rq); 748 rq = blk_get_request(drive->queue, READ, __GFP_WAIT);
745 rq.cmd_type = REQ_TYPE_ATA_TASKFILE; 749 rq->cmd_type = REQ_TYPE_ATA_TASKFILE;
750 err = blk_execute_rq(drive->queue, NULL, rq, 0);
751 blk_put_request(rq);
746 752
747 return ide_do_drive_cmd(drive, &rq, ide_wait); 753 return err;
748 } 754 }
749 755
750 if (copy_from_user(args, (void __user *)arg, 4)) 756 if (copy_from_user(args, (void __user *)arg, 4))