Skip to content

Commit

Permalink
[SCSI] st: move st_request initialization to st_allocate_request form…
Browse files Browse the repository at this point in the history
… st_do_scsi

This moves st_request initialization code to st_allocate_request()
form st_do_scsi(). This is a preparation for making
st_allocate_request() usable for everyone, not only st_do_scsi().

Signed-off-by: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
Acked-by: Kai Makisara <Kai.Makisara@kolumbus.fi>
Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
  • Loading branch information
FUJITA Tomonori authored and James Bottomley committed Dec 29, 2008
1 parent 5d2711c commit 4deba24
Showing 1 changed file with 19 additions and 13 deletions.
32 changes: 19 additions & 13 deletions drivers/scsi/st.c
Original file line number Diff line number Diff line change
Expand Up @@ -451,9 +451,23 @@ static void st_sleep_done(void *data, char *sense, int result, int resid)
complete(SRpnt->waiting);
}

static struct st_request *st_allocate_request(void)
static struct st_request *st_allocate_request(struct scsi_tape *stp)
{
return kzalloc(sizeof(struct st_request), GFP_KERNEL);
struct st_request *streq;

streq = kzalloc(sizeof(*streq), GFP_KERNEL);
if (streq)
streq->stp = stp;
else {
DEBC(printk(KERN_ERR "%s: Can't get SCSI request.\n",
tape_name(stp)););
if (signal_pending(current))
stp->buffer->syscall_result = -EINTR;
else
stp->buffer->syscall_result = -EBUSY;
}

return streq;
}

static void st_release_request(struct st_request *streq)
Expand Down Expand Up @@ -481,18 +495,10 @@ st_do_scsi(struct st_request * SRpnt, struct scsi_tape * STp, unsigned char *cmd
return NULL;
}

if (SRpnt == NULL) {
SRpnt = st_allocate_request();
if (SRpnt == NULL) {
DEBC( printk(KERN_ERR "%s: Can't get SCSI request.\n",
tape_name(STp)); );
if (signal_pending(current))
(STp->buffer)->syscall_result = (-EINTR);
else
(STp->buffer)->syscall_result = (-EBUSY);
if (!SRpnt) {
SRpnt = st_allocate_request(STp);
if (!SRpnt)
return NULL;
}
SRpnt->stp = STp;
}

/* If async IO, set last_SRpnt. This ptr tells write_behind_check
Expand Down

0 comments on commit 4deba24

Please sign in to comment.