ide-atapi: use local sense buffer
authorBorislav Petkov <petkovbb@gmail.com>
Sat, 2 May 2009 08:58:17 +0000 (10:58 +0200)
committerBorislav Petkov <petkovbb@gmail.com>
Fri, 15 May 2009 04:44:23 +0000 (06:44 +0200)
Access the sense buffer through the bio in ->pc_callback method thus
alleviating the need for the pc->buf pointer.

There should be no functional change resulting from this patch.

Signed-off-by: Borislav Petkov <petkovbb@gmail.com>
drivers/ide/ide-atapi.c
drivers/ide/ide-floppy.c
drivers/ide/ide-tape.c

index b12be1f17f14e24f20ede7f4d846da9b6dbee284..66ea1e7774fd388a5a51889b1231bc6813430658 100644 (file)
@@ -253,7 +253,9 @@ void ide_retry_pc(ide_drive_t *drive)
        /* init pc from sense_rq */
        ide_init_pc(pc);
        memcpy(pc->c, sense_rq->cmd, 12);
-       pc->buf = bio_data(sense_rq->bio);      /* pointer to mapped address */
+
+       /* pointer to mapped address */
+       pc->buf = bio_data(sense_rq->bio);
        pc->req_xfer = blk_rq_bytes(sense_rq);
 
        if (drive->media == ide_tape)
index 060c893820c3e42115c6053cdcd0d6c620dc8556..14e5e9ca2ad9703e6ac75a76d488be3685efd380 100644 (file)
@@ -77,7 +77,8 @@ static int ide_floppy_callback(ide_drive_t *drive, int dsc)
            (rq && blk_pc_request(rq)))
                uptodate = 1; /* FIXME */
        else if (pc->c[0] == GPCMD_REQUEST_SENSE) {
-               u8 *buf = pc->buf;
+
+               u8 *buf = bio_data(rq->bio);
 
                if (!pc->error) {
                        floppy->sense_key = buf[2] & 0x0F;
index 1f7f50473a4f5009d9f4294b201bd0869f89c7e5..ef5f342914377c75a0ca17f15b3d43593e4e3d56 100644 (file)
@@ -288,11 +288,12 @@ static struct ide_tape_obj *ide_tape_chrdev_get(unsigned int i)
  * called on each failed packet command retry to analyze the request sense. We
  * currently do not utilize this information.
  */
-static void idetape_analyze_error(ide_drive_t *drive, u8 *sense)
+static void idetape_analyze_error(ide_drive_t *drive)
 {
        idetape_tape_t *tape = drive->driver_data;
        struct ide_atapi_pc *pc = drive->failed_pc;
        struct request *rq = drive->hwif->rq;
+       u8 *sense = bio_data(rq->bio);
 
        tape->sense_key = sense[2] & 0xF;
        tape->asc       = sense[12];
@@ -362,7 +363,7 @@ static int ide_tape_callback(ide_drive_t *drive, int dsc)
 
        if (pc->c[0] == REQUEST_SENSE) {
                if (uptodate)
-                       idetape_analyze_error(drive, pc->buf);
+                       idetape_analyze_error(drive);
                else
                        printk(KERN_ERR "ide-tape: Error in REQUEST SENSE "
                                        "itself - Aborting request!\n");