diff options
-rw-r--r-- | drivers/scsi/st.c | 27 |
1 files changed, 21 insertions, 6 deletions
diff --git a/drivers/scsi/st.c b/drivers/scsi/st.c index 084a967b2e78..390689d5fdf3 100644 --- a/drivers/scsi/st.c +++ b/drivers/scsi/st.c | |||
@@ -537,6 +537,8 @@ st_do_scsi(struct st_request * SRpnt, struct scsi_tape * STp, unsigned char *cmd | |||
537 | int bytes, int direction, int timeout, int retries, int do_wait) | 537 | int bytes, int direction, int timeout, int retries, int do_wait) |
538 | { | 538 | { |
539 | struct completion *waiting; | 539 | struct completion *waiting; |
540 | struct rq_map_data *mdata = &STp->buffer->map_data; | ||
541 | int ret; | ||
540 | 542 | ||
541 | /* if async, make sure there's no command outstanding */ | 543 | /* if async, make sure there's no command outstanding */ |
542 | if (!do_wait && ((STp->buffer)->last_SRpnt)) { | 544 | if (!do_wait && ((STp->buffer)->last_SRpnt)) { |
@@ -564,21 +566,34 @@ st_do_scsi(struct st_request * SRpnt, struct scsi_tape * STp, unsigned char *cmd | |||
564 | init_completion(waiting); | 566 | init_completion(waiting); |
565 | SRpnt->waiting = waiting; | 567 | SRpnt->waiting = waiting; |
566 | 568 | ||
567 | if (!STp->buffer->do_dio) | 569 | if (!STp->buffer->do_dio) { |
568 | buf_to_sg(STp->buffer, bytes); | 570 | buf_to_sg(STp->buffer, bytes); |
569 | 571 | ||
572 | mdata->nr_entries = | ||
573 | DIV_ROUND_UP(bytes, PAGE_SIZE << mdata->page_order); | ||
574 | STp->buffer->map_data.pages = STp->buffer->reserved_pages; | ||
575 | STp->buffer->map_data.offset = 0; | ||
576 | } | ||
577 | |||
570 | memcpy(SRpnt->cmd, cmd, sizeof(SRpnt->cmd)); | 578 | memcpy(SRpnt->cmd, cmd, sizeof(SRpnt->cmd)); |
571 | STp->buffer->cmdstat.have_sense = 0; | 579 | STp->buffer->cmdstat.have_sense = 0; |
572 | STp->buffer->syscall_result = 0; | 580 | STp->buffer->syscall_result = 0; |
573 | 581 | ||
574 | if (scsi_execute_async(STp->device, cmd, COMMAND_SIZE(cmd[0]), direction, | 582 | if (STp->buffer->do_dio) |
575 | &((STp->buffer)->sg[0]), bytes, (STp->buffer)->sg_segs, | 583 | ret = scsi_execute_async(STp->device, cmd, COMMAND_SIZE(cmd[0]), |
576 | timeout, retries, SRpnt, st_sleep_done, GFP_KERNEL)) { | 584 | direction, &((STp->buffer)->sg[0]), |
585 | bytes, (STp->buffer)->sg_segs, timeout, | ||
586 | retries, SRpnt, st_sleep_done, | ||
587 | GFP_KERNEL); | ||
588 | else | ||
589 | ret = st_scsi_execute(SRpnt, cmd, direction, NULL, bytes, | ||
590 | timeout, retries); | ||
591 | |||
592 | if (ret) { | ||
577 | /* could not allocate the buffer or request was too large */ | 593 | /* could not allocate the buffer or request was too large */ |
578 | (STp->buffer)->syscall_result = (-EBUSY); | 594 | (STp->buffer)->syscall_result = (-EBUSY); |
579 | (STp->buffer)->last_SRpnt = NULL; | 595 | (STp->buffer)->last_SRpnt = NULL; |
580 | } | 596 | } else if (do_wait) { |
581 | else if (do_wait) { | ||
582 | wait_for_completion(waiting); | 597 | wait_for_completion(waiting); |
583 | SRpnt->waiting = NULL; | 598 | SRpnt->waiting = NULL; |
584 | (STp->buffer)->syscall_result = st_chk_result(STp, SRpnt); | 599 | (STp->buffer)->syscall_result = st_chk_result(STp, SRpnt); |