scsi: cxlflash: Cleanup send_tmf()
authorMatthew R. Ochs <mrochs@linux.vnet.ibm.com>
Tue, 29 Nov 2016 00:42:50 +0000 (18:42 -0600)
committerMartin K. Petersen <martin.petersen@oracle.com>
Thu, 1 Dec 2016 00:53:02 +0000 (19:53 -0500)
The send_tmf() routine includes some copy/paste cruft that can be
removed as well as the setting of an AFU command-specific while
holding the tmf_slock. While not a bug, it is out of place and
should be shifted down alongside the other command initialization
statements for clarity.

Signed-off-by: Matthew R. Ochs <mrochs@linux.vnet.ibm.com>
Acked-by: Uma Krishnan <ukrishn@linux.vnet.ibm.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/cxlflash/main.c

index db770301c30a4800b9bfb31a684da8a639776e70..b7636993a097c24d3063fdfa4a1715ecc9dd5390 100644 (file)
@@ -299,12 +299,10 @@ static int wait_resp(struct afu *afu, struct afu_cmd *cmd)
  */
 static int send_tmf(struct afu *afu, struct scsi_cmnd *scp, u64 tmfcmd)
 {
-       struct afu_cmd *cmd = sc_to_afucz(scp);
-
        u32 port_sel = scp->device->channel + 1;
-       short lflag = 0;
        struct Scsi_Host *host = scp->device->host;
        struct cxlflash_cfg *cfg = (struct cxlflash_cfg *)host->hostdata;
+       struct afu_cmd *cmd = sc_to_afucz(scp);
        struct device *dev = &cfg->dev->dev;
        ulong lock_flags;
        int rc = 0;
@@ -317,27 +315,21 @@ static int send_tmf(struct afu *afu, struct scsi_cmnd *scp, u64 tmfcmd)
                                                  !cfg->tmf_active,
                                                  cfg->tmf_slock);
        cfg->tmf_active = true;
-       cmd->cmd_tmf = true;
        spin_unlock_irqrestore(&cfg->tmf_slock, lock_flags);
 
+       cmd->rcb.scp = scp;
+       cmd->parent = afu;
+       cmd->cmd_tmf = true;
+
        cmd->rcb.ctx_id = afu->ctx_hndl;
        cmd->rcb.msi = SISL_MSI_RRQ_UPDATED;
        cmd->rcb.port_sel = port_sel;
        cmd->rcb.lun_id = lun_to_lunid(scp->device->lun);
-
-       lflag = SISL_REQ_FLAGS_TMF_CMD;
-
        cmd->rcb.req_flags = (SISL_REQ_FLAGS_PORT_LUN_ID |
-                             SISL_REQ_FLAGS_SUP_UNDERRUN | lflag);
-
-       /* Stash the scp in the command, for reuse during interrupt */
-       cmd->rcb.scp = scp;
-       cmd->parent = afu;
-
-       /* Copy the CDB from the cmd passed in */
+                             SISL_REQ_FLAGS_SUP_UNDERRUN |
+                             SISL_REQ_FLAGS_TMF_CMD);
        memcpy(cmd->rcb.cdb, &tmfcmd, sizeof(tmfcmd));
 
-       /* Send the command */
        rc = send_cmd(afu, cmd);
        if (unlikely(rc)) {
                spin_lock_irqsave(&cfg->tmf_slock, lock_flags);