On Thu, 2014-10-02 at 09:30 +0200, Hannes Reinecke wrote: > The SCSI command tag is set to the tag assigned from the block > layer, not the SCSI-II tag message. So we need to convert > it into the correct SCSI-II tag message based on the > device flags, not the tag value itself. > > Signed-off-by: Hannes Reinecke <h...@suse.de> > --- > drivers/target/loopback/tcm_loop.c | 23 ++++++++--------------- > 1 file changed, 8 insertions(+), 15 deletions(-) > > diff --git a/drivers/target/loopback/tcm_loop.c > b/drivers/target/loopback/tcm_loop.c > index 340de9d..c2a9370 100644 > --- a/drivers/target/loopback/tcm_loop.c > +++ b/drivers/target/loopback/tcm_loop.c > @@ -153,18 +153,11 @@ static int tcm_loop_change_queue_type(struct > scsi_device *sdev, int tag) > /* > * Locate the SAM Task Attr from struct scsi_cmnd * > */ > -static int tcm_loop_sam_attr(struct scsi_cmnd *sc) > -{ > - if (sc->device->tagged_supported) { > - switch (sc->tag) { > - case HEAD_OF_QUEUE_TAG: > - return MSG_HEAD_TAG; > - case ORDERED_QUEUE_TAG: > - return MSG_ORDERED_TAG; > - default: > - break; > - } > - } > +static int tcm_loop_sam_attr(struct scsi_cmnd *sc, int tag) > +{ > + if (sc->device->tagged_supported && > + sc->device->ordered_tags && tag >= 0) > + return MSG_ORDERED_TAG; > > return MSG_SIMPLE_TAG; > } > @@ -227,7 +220,7 @@ static void tcm_loop_submission_work(struct work_struct > *work) > > rc = target_submit_cmd_map_sgls(se_cmd, tl_nexus->se_sess, sc->cmnd, > &tl_cmd->tl_sense_buf[0], tl_cmd->sc->device->lun, > - transfer_length, tcm_loop_sam_attr(sc), > + transfer_length, tcm_loop_sam_attr(sc, > tl_cmd->sc_cmd_tag), > sc->sc_data_direction, 0, > scsi_sglist(sc), scsi_sg_count(sc), > sgl_bidi, sgl_bidi_count, > @@ -266,7 +259,7 @@ static int tcm_loop_queuecommand(struct Scsi_Host *sh, > struct scsi_cmnd *sc) > } > > tl_cmd->sc = sc; > - tl_cmd->sc_cmd_tag = sc->tag; > + tl_cmd->sc_cmd_tag = sc->request->tag; > INIT_WORK(&tl_cmd->work, tcm_loop_submission_work); > queue_work(tcm_loop_workqueue, &tl_cmd->work); > return 0; > @@ -370,7 +363,7 @@ static int tcm_loop_abort_task(struct scsi_cmnd *sc) > */ > tl_tpg = &tl_hba->tl_hba_tpgs[sc->device->id]; > ret = tcm_loop_issue_tmr(tl_tpg, tl_nexus, sc->device->lun, > - sc->tag, TMR_ABORT_TASK); > + sc->request->tag, TMR_ABORT_TASK); > return (ret == TMR_FUNCTION_COMPLETE) ? SUCCESS : FAILED; > } >
Applied. Thanks Hannes! -- To unsubscribe from this list: send the line "unsubscribe linux-scsi" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html