summaryrefslogtreecommitdiffstats
path: root/drivers/target/target_core_xcopy.h
diff options
context:
space:
mode:
authorDavid Disseldorp2017-01-02 18:04:08 +0100
committerBart Van Assche2017-01-10 17:41:27 +0100
commitf94fd098f674b78c29f482da1999d8de0c93c74e (patch)
treea3d8c3c7bccadd4b9ed6e16fd59ea1e7d69e249c /drivers/target/target_core_xcopy.h
parenttarget: use XCOPY segment descriptor CSCD IDs (diff)
downloadkernel-qcow2-linux-f94fd098f674b78c29f482da1999d8de0c93c74e.tar.gz
kernel-qcow2-linux-f94fd098f674b78c29f482da1999d8de0c93c74e.tar.xz
kernel-qcow2-linux-f94fd098f674b78c29f482da1999d8de0c93c74e.zip
target: check for XCOPY parameter truncation
Check for XCOPY header, CSCD descriptor and segment descriptor list truncation, and respond accordingly. SPC4r37 6.4.1 EXTENDED COPY(LID4) states (also applying to LID1 reqs): If the parameter list length causes truncation of the parameter list, then the copy manager shall transfer no data and shall terminate the EXTENDED COPY command with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to PARAMETER LIST LENGTH ERROR. This behaviour can be tested using the libiscsi ExtendedCopy.ParamHdr test. Signed-off-by: David Disseldorp <ddiss@suse.de> Reviewed-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Bart Van Assche <bart.vanassche@sandisk.com>
Diffstat (limited to 'drivers/target/target_core_xcopy.h')
-rw-r--r--drivers/target/target_core_xcopy.h1
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/target/target_core_xcopy.h b/drivers/target/target_core_xcopy.h
index e2d141140342..7c0b105cbe1b 100644
--- a/drivers/target/target_core_xcopy.h
+++ b/drivers/target/target_core_xcopy.h
@@ -1,5 +1,6 @@
#include <target/target_core_base.h>
+#define XCOPY_HDR_LEN 16
#define XCOPY_TARGET_DESC_LEN 32
#define XCOPY_SEGMENT_DESC_LEN 28
#define XCOPY_NAA_IEEE_REGEX_LEN 16