This fixes an issue in scsi command initialization from a request where sd, sr, st, and scsi_lib all fail to copy the request's cmd_len to the scsi command's cmd_len field. Signed-off-by: Timothy Thelin <timothy.thelin@xxxxxxx> diff -pu linux-2.6.14-rc1.orig/drivers/scsi/scsi_lib.c linux-2.6.14-rc1/drivers/scsi/scsi_lib.c --- linux-2.6.14-rc1.orig/drivers/scsi/scsi_lib.c 2005-09-12 20:12:09.000000000 -0700 +++ linux-2.6.14-rc1/drivers/scsi/scsi_lib.c 2005-09-13 16:28:58.000000000 -0700 @@ -1268,6 +1268,7 @@ static int scsi_prep_fn(struct request_q } } else { memcpy(cmd->cmnd, req->cmd, sizeof(cmd->cmnd)); + cmd->cmd_len = req->cmd_len; if (rq_data_dir(req) == WRITE) cmd->sc_data_direction = DMA_TO_DEVICE; else if (req->data_len) diff -pu linux-2.6.14-rc1.orig/drivers/scsi/sd.c linux-2.6.14-rc1/drivers/scsi/sd.c --- linux-2.6.14-rc1.orig/drivers/scsi/sd.c 2005-09-12 20:12:09.000000000 -0700 +++ linux-2.6.14-rc1/drivers/scsi/sd.c 2005-09-13 16:03:20.000000000 -0700 @@ -235,6 +235,7 @@ static int sd_init_command(struct scsi_c return 0; memcpy(SCpnt->cmnd, rq->cmd, sizeof(SCpnt->cmnd)); + SCpnt->cmd_len = rq->cmd_len; if (rq_data_dir(rq) == WRITE) SCpnt->sc_data_direction = DMA_TO_DEVICE; else if (rq->data_len) diff -pu linux-2.6.14-rc1.orig/drivers/scsi/sr.c linux-2.6.14-rc1/drivers/scsi/sr.c --- linux-2.6.14-rc1.orig/drivers/scsi/sr.c 2005-09-12 20:12:09.000000000 -0700 +++ linux-2.6.14-rc1/drivers/scsi/sr.c 2005-09-13 16:05:47.000000000 -0700 @@ -326,6 +326,7 @@ static int sr_init_command(struct scsi_c return 0; memcpy(SCpnt->cmnd, rq->cmd, sizeof(SCpnt->cmnd)); + SCpnt->cmd_len = rq->cmd_len; if (!rq->data_len) SCpnt->sc_data_direction = DMA_NONE; else if (rq_data_dir(rq) == WRITE) diff -pu linux-2.6.14-rc1.orig/drivers/scsi/st.c linux-2.6.14-rc1/drivers/scsi/st.c --- linux-2.6.14-rc1.orig/drivers/scsi/st.c 2005-09-12 20:12:09.000000000 -0700 +++ linux-2.6.14-rc1/drivers/scsi/st.c 2005-09-13 16:04:10.000000000 -0700 @@ -4206,6 +4206,7 @@ static int st_init_command(struct scsi_c return 0; memcpy(SCpnt->cmnd, rq->cmd, sizeof(SCpnt->cmnd)); + SCpnt->cmd_len = rq->cmd_len; if (rq_data_dir(rq) == WRITE) SCpnt->sc_data_direction = DMA_TO_DEVICE; - : send the line "unsubscribe linux-scsi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html