diff options
author | Roland Dreier <roland@purestorage.com> | 2013-06-05 18:54:17 +0200 |
---|---|---|
committer | Nicholas Bellinger <nab@linux-iscsi.org> | 2013-06-14 10:12:56 +0200 |
commit | b5aff3d2747bea08b386edd070941a45611ffe51 (patch) | |
tree | c08e9c472d39f54580f310c65b6030c276eca908 /kernel/rcutiny_plugin.h | |
parent | target/iscsi: don't corrupt bh_count in iscsit_stop_time2retain_timer() (diff) | |
download | linux-b5aff3d2747bea08b386edd070941a45611ffe51.tar.xz linux-b5aff3d2747bea08b386edd070941a45611ffe51.zip |
tcm_qla2xxx: Fix residual for underrun commands that fail
Suppose an initiator sends a DATA IN command with an allocation length
shorter than the FC transfer length -- we get a target message like
TARGET_CORE[qla2xxx]: Expected Transfer Length: 256 does not match SCSI CDB Length: 0 for SAM Opcode: 0x12
In that case, the target core adjusts the data_length and sets
se_cmd->residual_count for the underrun. But now suppose that command
fails and we end up in tcm_qla2xxx_queue_status() -- that function
unconditionally overwrites residual_count with the already adjusted
data_length, and the initiator will burp with a message like
qla2xxx [0000:00:06.0]-301d:0: Dropped frame(s) detected (0x100 of 0x100 bytes).
Fix this by adding on to the existing underflow residual count instead.
Signed-off-by: Roland Dreier <roland@purestorage.com>
Cc: Giridhar Malavali <giridhar.malavali@qlogic.com>
Cc: Chad Dupuis <chad.dupuis@qlogic.com>
Cc: stable <stable@vger.kernel.org>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
Diffstat (limited to 'kernel/rcutiny_plugin.h')
0 files changed, 0 insertions, 0 deletions