]> git.kernelconcepts.de Git - karo-tx-linux.git/commitdiff
iscsi-target: Ignore ICF_GOT_LAST_DATAOUT during Data-Out ITT lookup
authorNicholas Bellinger <nab@linux-iscsi.org>
Tue, 8 Jul 2014 01:25:04 +0000 (18:25 -0700)
committerNicholas Bellinger <nab@linux-iscsi.org>
Mon, 15 Sep 2014 21:03:06 +0000 (14:03 -0700)
This patch adds a explicit check in iscsit_find_cmd_from_itt_or_dump()
to ignore commands with ICF_GOT_LAST_DATAOUT set.  This is done to
address the case where an ITT is being reused for DataOUT, but the
previous command with the same ITT has not yet been acknowledged by
ExpStatSN and removed from the per connection command list.

This issue was originally manifesting itself by referencing the
previous command during ITT lookup, and subsequently hitting the
check in iscsit_check_dataout_hdr() for ICF_GOT_LAST_DATAOUT, that
resulted in the DataOUT PDU + associated payload being silently
dumped.

Reported-by: Arshad Hussain <arshad.hussain@calsoftinc.com>
Tested-by: Arshad Hussain <arshad.hussain@calsoftinc.com>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
drivers/target/iscsi/iscsi_target_util.c

index fd90b28f1d94358db7361899b32928b0d1b5fee2..73355f4fca745a71d0fa3cb66956148c64e41f11 100644 (file)
@@ -400,6 +400,8 @@ struct iscsi_cmd *iscsit_find_cmd_from_itt_or_dump(
 
        spin_lock_bh(&conn->cmd_lock);
        list_for_each_entry(cmd, &conn->conn_cmd_list, i_conn_node) {
+               if (cmd->cmd_flags & ICF_GOT_LAST_DATAOUT)
+                       continue;
                if (cmd->init_task_tag == init_task_tag) {
                        spin_unlock_bh(&conn->cmd_lock);
                        return cmd;