scsi: target/core: Simplify the LUN RESET implementation
authorBart Van Assche <bvanassche@acm.org>
Fri, 25 Jan 2019 18:34:45 +0000 (10:34 -0800)
committerMartin K. Petersen <martin.petersen@oracle.com>
Tue, 5 Feb 2019 02:26:24 +0000 (21:26 -0500)
Due to the task management handling rework it is safe to wait for a TMF
that is not in the active state. Hence remove the CMD_T_ACTIVE test from
core_tmr_drain_tmr_list(). Additionally, call __target_check_io_state()
instead of open coding it.

Reviewed-by: Hannes Reinecke <hare@suse.com>
Cc: Nicholas Bellinger <nab@linux-iscsi.org>
Cc: Mike Christie <mchristi@redhat.com>
Cc: Christoph Hellwig <hch@lst.de>
Signed-off-by: Bart Van Assche <bvanassche@acm.org>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/target/target_core_tmr.c

index df1ca827de683cc40a00e0089b155cbdfc148577..3a1bb799a9ab304860777b22c3948a11d5f0194b 100644 (file)
@@ -217,23 +217,13 @@ static void core_tmr_drain_tmr_list(
                        continue;
 
                spin_lock(&sess->sess_cmd_lock);
-               spin_lock(&cmd->t_state_lock);
-               if (!(cmd->transport_state & CMD_T_ACTIVE) ||
-                    (cmd->transport_state & CMD_T_FABRIC_STOP)) {
-                       spin_unlock(&cmd->t_state_lock);
-                       spin_unlock(&sess->sess_cmd_lock);
-                       continue;
-               }
-               cmd->transport_state |= CMD_T_ABORTED;
-               spin_unlock(&cmd->t_state_lock);
+               rc = __target_check_io_state(cmd, sess, 0);
+               spin_unlock(&sess->sess_cmd_lock);
 
-               rc = kref_get_unless_zero(&cmd->cmd_kref);
                if (!rc) {
                        printk("LUN_RESET TMR: non-zero kref_get_unless_zero\n");
-                       spin_unlock(&sess->sess_cmd_lock);
                        continue;
                }
-               spin_unlock(&sess->sess_cmd_lock);
 
                list_move_tail(&tmr_p->tmr_list, &drain_tmr_list);
        }