mirror of
https://github.com/SCST-project/scst.git
synced 2026-05-16 10:11:28 +00:00
svn+ssh://yanb123@svn.code.sf.net/p/scst/svn/trunk
........
r5409 | bvassche | 2014-04-06 23:13:53 +0300 (Sun, 06 Apr 2014) | 4 lines
scstadmin: Restore LUNs in "scstadmin -list_sessions" output
Signed-off-by: Dave Butler <tears.the@gmail.com>
........
r5410 | bvassche | 2014-04-06 23:26:08 +0300 (Sun, 06 Apr 2014) | 1 line
scstadmin: List keys alphabetically in the -list_sessions output
........
r5411 | vlnb | 2014-04-10 02:58:20 +0300 (Thu, 10 Apr 2014) | 10 lines
vdisk_blockio: Specify REQ_SYNC for synchronous I/O requests
Using READ_SYNC instead of READ increases the priority of read requests.
Using WRITE_SYNC instead of REQ_WRITE increases the priority of write
requests and avoids that the CFQ scheduler queues such writes waiting
for further write requests.
Signed-off-by: Bart Van Assche <bvanassche@acm.org>
........
r5412 | vlnb | 2014-04-10 02:59:02 +0300 (Thu, 10 Apr 2014) | 18 lines
vdisk_blockio: Reenable COMPARE AND WRITE
The COMPARE AND WRITE implementation has been tested as follows against
an SCST vdisk_blockio device:
lba=7
bdev=$bdev
for ((i=0;i<4;i++)); do dd if=/dev/urandom of=b$i bs=8k count=1; done
for p in "0 1" "1 2" "2 3" "3 0"; do set $p; cat b$1 b$2 >b$1$2; done
dd if=/dev/urandom of=$bdev
dd if=b0 of=$bdev seek=$lba
md5sum $bdev
for ((i=0;i<10000;i++)); do for f in b01 b12 b23 b30; do sg_compare_and_write -l $lba -i $f -n 16 -x 16384 $bdev; done; done
md5sum $bdev
Signed-off-by: Bart Van Assche <bvanassche@acm.org>
........
r5413 | bvassche | 2014-04-15 09:03:59 +0300 (Tue, 15 Apr 2014) | 1 line
ib_srpt: Fix a sparse warning
........
r5414 | vlnb | 2014-04-16 00:26:06 +0300 (Wed, 16 Apr 2014) | 5 lines
Fix READ(6)/WRITE(6)
LBA in those commands is 3 bytes long, not 2.
........
r5415 | vlnb | 2014-04-16 00:30:26 +0300 (Wed, 16 Apr 2014) | 3 lines
Add SYNCHRONIZE_CACHE(16)
........
r5416 | vlnb | 2014-04-16 01:04:54 +0300 (Wed, 16 Apr 2014) | 6 lines
Make HEAD OF QUEUE requests sync
Since the block layer has no way to specify bio as HQ, there's no
choice, but to use every measure to approximate it as close as possible.
........
r5417 | vlnb | 2014-04-16 01:17:34 +0300 (Wed, 16 Apr 2014) | 3 lines
Add NULLIO VERIFY
........
r5418 | vlnb | 2014-04-16 04:02:50 +0300 (Wed, 16 Apr 2014) | 3 lines
REPORT SUPPORTED OPERATION CODES added
........
r5419 | vlnb | 2014-04-16 04:05:49 +0300 (Wed, 16 Apr 2014) | 3 lines
Cleanup
........
r5420 | vlnb | 2014-04-16 05:24:44 +0300 (Wed, 16 Apr 2014) | 3 lines
Follow up for r5418: some cleanups and fixes
........
r5421 | bvassche | 2014-04-16 09:17:19 +0300 (Wed, 16 Apr 2014) | 6 lines
scst_targ: Fix a checkpatch complaint
Avoid that checkpatch reports the following message:
ERROR: space required before the open parenthesis '('
........
r5422 | bvassche | 2014-04-16 09:35:19 +0300 (Wed, 16 Apr 2014) | 1 line
scst_vdisk: Build fix for kernels < 2.6.36 (see also r5416)
........
r5423 | bvassche | 2014-04-16 10:30:34 +0300 (Wed, 16 Apr 2014) | 6 lines
ib_srpt: Disable RDMA access by the initiator
With the SRP protocol all RDMA operations are initiated by the target.
Since no RDMA operations are initiated by the initiator, do not grant
the initiator permission to submit RDMA reads or writes to the target.
........
r5424 | bvassche | 2014-04-16 11:01:58 +0300 (Wed, 16 Apr 2014) | 1 line
ib_srpt: Constify two arguments of srpt_get_nexus()
........
r5425 | bvassche | 2014-04-16 11:08:50 +0300 (Wed, 16 Apr 2014) | 1 line
ib_srpt: Clean up the code that prints the dgid during login
........
r5426 | bvassche | 2014-04-16 11:23:11 +0300 (Wed, 16 Apr 2014) | 1 line
ib_srpt: Cache P_Key lookups
........
r5427 | bvassche | 2014-04-16 12:14:31 +0300 (Wed, 16 Apr 2014) | 1 line
ib_srpt: Remove a superfluous assignment
........
r5428 | bvassche | 2014-04-16 12:31:56 +0300 (Wed, 16 Apr 2014) | 1 line
scst_vdisk: Avoid that checkpatch complains about unnecessary line continuations
........
r5429 | bvassche | 2014-04-16 12:35:18 +0300 (Wed, 16 Apr 2014) | 1 line
scst_lib: Avoid that checkpatch complains about unnecessary line continuations
........
r5430 | bvassche | 2014-04-17 09:09:41 +0300 (Thu, 17 Apr 2014) | 1 line
scst_vdisk: Kernel 2.6.27 build fix
........
r5431 | bvassche | 2014-04-17 09:12:07 +0300 (Thu, 17 Apr 2014) | 5 lines
scst_vdisk: Fix a kernel 2.6.27 compiler warning
Avoid that the compiler reports that variables 'start_sector' and 'nr_sects'
are set but not used when building against kernel 2.6.27.
........
r5432 | vlnb | 2014-04-18 03:32:51 +0300 (Fri, 18 Apr 2014) | 3 lines
Update to kernels 3.14
........
r5433 | bvassche | 2014-04-18 08:50:04 +0300 (Fri, 18 Apr 2014) | 1 line
nightly build: Add kernel 3.14 build infrastructure
........
r5434 | bvassche | 2014-04-18 08:54:29 +0300 (Fri, 18 Apr 2014) | 1 line
nightly build: Add kernel version 3.14.1 and update other kernel versions
........
r5435 | bvassche | 2014-04-18 08:56:35 +0300 (Fri, 18 Apr 2014) | 6 lines
iscsi-scst: Fix a checkpatch warning
Fix the following checkpatch 3.14 warning:
Unnecessary parentheses - maybe == should be = ?
........
r5436 | bvassche | 2014-04-18 09:03:34 +0300 (Fri, 18 Apr 2014) | 6 lines
scst.h: Fix a checkpatch warning
Fix the following checkpatch 3.14 warning:
Unnecessary space after function pointer name
........
r5437 | bvassche | 2014-04-18 09:08:07 +0300 (Fri, 18 Apr 2014) | 6 lines
scst: Fix a checkpatch warning
Fix the following checkpatch 3.14 warning:
Unnecessary space after function pointer name
........
r5438 | bvassche | 2014-04-18 09:13:03 +0300 (Fri, 18 Apr 2014) | 6 lines
scst: Fix a checkpatch 3.14 warning about whitespace
Fix the following checkpatch 3.14 warning:
missing space after return type
........
r5439 | bvassche | 2014-04-18 14:09:55 +0300 (Fri, 18 Apr 2014) | 1 line
ib_srpt: Update README
........
r5440 | bvassche | 2014-04-18 15:04:05 +0300 (Fri, 18 Apr 2014) | 2 lines
ib_srpt: Move IB/CM knowledge out of srpt_cm_req_recv()
........
r5441 | bvassche | 2014-04-18 15:08:00 +0300 (Fri, 18 Apr 2014) | 6 lines
ib_srpt: Remove a superfluous check from the REQ handler
ib_send_cm_rep() checks the connection state before sending a response.
Hence checking ch->state before calling ib_send_cm_rep() is superfluous,
so remove that check and also the locking that is no longer needed.
........
r5442 | bvassche | 2014-04-18 15:09:33 +0300 (Fri, 18 Apr 2014) | 5 lines
ib_srpt: Prepare RDMA/CM support
Move IB/CM members into a new struct. Report channel pointer instead of CM ID
pointer in diagnostic messages.
........
r5443 | bvassche | 2014-04-18 15:10:47 +0300 (Fri, 18 Apr 2014) | 5 lines
ib_srpt: Use a mutex instead of a spinlock to protect the channel list
This is allowed because all CM callback functions are invoked from thread
context.
........
r5444 | bvassche | 2014-04-18 15:11:18 +0300 (Fri, 18 Apr 2014) | 2 lines
ib_srpt: Move the code for checking the QP timeout
........
r5445 | bvassche | 2014-04-18 15:22:30 +0300 (Fri, 18 Apr 2014) | 4 lines
ib_srpt: Add RDMA/CM support
Or in other words, add RoCE and iWARP support.
........
r5446 | bvassche | 2014-04-18 15:38:39 +0300 (Fri, 18 Apr 2014) | 1 line
ib_srpt: Build fix for kernel versions < 3.0
........
r5447 | bvassche | 2014-04-18 15:44:48 +0300 (Fri, 18 Apr 2014) | 1 line
ib_srpt: RHEL 6.5 build fix
........
r5448 | bvassche | 2014-04-19 14:48:33 +0300 (Sat, 19 Apr 2014) | 1 line
scst_vdisk, COMPARE AND WRITE: Convert a kernel warning into a SCSI sense code
........
r5449 | bvassche | 2014-04-19 14:52:34 +0300 (Sat, 19 Apr 2014) | 33 lines
vdisk_blockio: Make COMPARE AND WRITE compatible with the scsi_debug driver
This patch fixes the following kernel oops:
BUG: unable to handle kernel paging request at ffffeae380000690
Call Trace:
[<ffffffff812f69f9>] sg_miter_next+0x9/0xd0
[<ffffffff812f6b60>] sg_copy_buffer+0xa0/0x100
[<ffffffffa0507fc6>] do_device_access.isra.8+0xa6/0x150 [scsi_debug]
[<ffffffffa05085f4>] resp_read+0xe4/0x240 [scsi_debug]
[<ffffffffa050b285>] scsi_debug_queuecommand_lck+0x11e5/0x2060 [scsi_debug]
[<ffffffffa050c130>] scsi_debug_queuecommand+0x30/0x48 [scsi_debug]
[<ffffffff813fe23f>] scsi_dispatch_cmd+0xaf/0x260
[<ffffffff814068ed>] scsi_request_fn+0x32d/0x540
[<ffffffff812bda2a>] __blk_run_queue+0x2a/0x40
[<ffffffff812c25a4>] blk_queue_bio+0x274/0x350
[<ffffffff812bd878>] generic_make_request+0xa8/0xf0
[<ffffffff812bd92c>] submit_bio+0x6c/0x140
[<ffffffffa06247f6>] blockio_rw_sync.isra.29+0x106/0x170 [scst_vdisk]
[<ffffffffa0629bf9>] vdisk_exec_caw+0xd9/0x3c0 [scst_vdisk]
[<ffffffffa061ff5e>] vdev_do_job+0x9e/0x320 [scst_vdisk]
[<ffffffffa0622c47>] non_fileio_exec+0x57/0xd0 [scst_vdisk]
[<ffffffffa054cde2>] scst_do_real_exec+0x92/0x3b0 [scst]
[<ffffffffa05502d2>] scst_exec_check_blocking+0xe2/0x300 [scst]
[<ffffffffa055066b>] scst_exec_check_sn+0x17b/0x2d0 [scst]
[<ffffffffa0553231>] scst_process_active_cmd+0x431/0x770 [scst]
[<ffffffffa0554a0a>] scst_do_job_active+0xea/0x180 [scst]
[<ffffffffa0554bc6>] scst_cmd_thread+0x126/0x290 [scst]
[<ffffffff81075241>] kthread+0xc1/0xe0
[<ffffffff81598ccc>] ret_from_fork+0x7c/0xb0
Reported-by: Sebastian Herbszt <herbszt@gmx.de>
........
r5450 | bvassche | 2014-04-20 09:24:23 +0300 (Sun, 20 Apr 2014) | 1 line
iscsi-scst/kernel/patches/put_page_callback-3.2.57.patch: Add
........
r5451 | bvassche | 2014-04-22 09:56:37 +0300 (Tue, 22 Apr 2014) | 1 line
scst: Revert r5438, a whitespace-only change
........
r5452 | bvassche | 2014-04-22 10:05:21 +0300 (Tue, 22 Apr 2014) | 1 line
scripts/run-regression-tests: Suppress the checkpatch warning "missing space after return type"
........
r5454 | bvassche | 2014-04-22 10:32:44 +0300 (Tue, 22 Apr 2014) | 1 line
scst/README: Update the section about Linux initiator ALUA support
........
git-svn-id: http://svn.code.sf.net/p/scst/svn/branches/iser@5455 d57e44dd-8a1f-0410-8b47-8ef2f437770f
773 lines
24 KiB
Bash
Executable File
773 lines
24 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
############################################################################
|
|
#
|
|
# Script for converting the SCST source tree as it exists in the Subversion
|
|
# repository to a Linux kernel patch.
|
|
#
|
|
# Copyright (C) 2008-2009 Bart Van Assche <bvanassche@acm.org>
|
|
#
|
|
# This program is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU General Public License
|
|
# as published by the Free Software Foundation, version 2
|
|
# of the License.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
############################################################################
|
|
|
|
########################
|
|
# Function definitions #
|
|
########################
|
|
|
|
source $(dirname $0)/kernel-functions
|
|
|
|
function usage {
|
|
echo "Usage: $0 [-d] [-h] [-m] [-n] [-p <dir>] [-s] [-u] <kernel version>"
|
|
echo "where: "
|
|
echo " -d - enable patch specialization debugging"
|
|
echo " -h - show this text"
|
|
echo " -m - add mpt target driver"
|
|
echo " -n - do not delete code disabled via preprocessor statements"
|
|
echo " -p - generate multiple patches instead of one big patch into"\
|
|
"the specified directory."
|
|
echo " -s - disable patch specialization."
|
|
echo " -u - enables #define GENERATING_UPSTREAM_PATCH."
|
|
}
|
|
|
|
# Convert an existing patch.
|
|
# $1: path of patch to be added.
|
|
# $2: path in kernel tree of file to be patched.
|
|
function add_patch {
|
|
if [ ! -e "$1" ]; then
|
|
echo "Error: could not find $1." >&2
|
|
exit 1
|
|
fi
|
|
|
|
sed -e "s:^--- [^ ]*:--- orig/linux-${kver}/$2:" \
|
|
-e "s:^+++ [^ ]*:+++ linux-${kver}/$2:" \
|
|
< "$1"
|
|
}
|
|
|
|
# Generate a patch for a file to be added to the kernel source tree, and strip
|
|
# trailing whitespace from C source files while converting the file to patch
|
|
# format.
|
|
# $1: path of file to be added.
|
|
# $2: path in kernel tree where file should be added.
|
|
function add_file {
|
|
local a b
|
|
|
|
if [ ! -e "$1" ]; then
|
|
echo "Error: could not find $1." >&2
|
|
exit 1
|
|
fi
|
|
|
|
# Only include files that were not generated by the build process
|
|
# -- skip *.mod.c.
|
|
if [ "$1" = "${1%.mod.c}" -a "$1" ]; then
|
|
cat <<EOF
|
|
diff -uprN orig/linux-${kver}/$2 linux-${kver}/$2
|
|
--- orig/linux-${kver}/$2
|
|
+++ linux-${kver}/$2
|
|
@@ -0,0 +1,$(wc -l "$1" | { read a b; echo $a; }) @@
|
|
EOF
|
|
# Insert a '+'-sign at the start of each line.
|
|
sed -e 's/^/+/' < "$1" | \
|
|
if [ "${replace_sbug_by_bug}" = "true" ]; then
|
|
sed -e 's/sBUG(\([^)]*\)/BUG(\1/g' -e 's/sBUG_ON(\([^)]*\)/BUG_ON(\1/g'
|
|
else
|
|
cat
|
|
fi \
|
|
| \
|
|
if [ "${2%.[ch]}" != "$2" ]; then
|
|
# Make sure that labels (goto-targets) are left-aligned.
|
|
sed -e 's/^ \([^ ]*:\)$/\1/'
|
|
else
|
|
cat
|
|
fi
|
|
fi
|
|
}
|
|
|
|
function add_empty_file {
|
|
local a b
|
|
|
|
cat <<EOF
|
|
diff -uprN orig/linux-${kver}/$1 linux-${kver}/$1
|
|
--- orig/linux-${kver}/$1
|
|
+++ linux-${kver}/$1
|
|
@@ -0,0 +1,1 @@
|
|
+
|
|
EOF
|
|
}
|
|
|
|
# Run the script specialize_patch with appropriate options on the patch
|
|
# passed via stdin and send the specialized patch to stdout.
|
|
function specialize_patch {
|
|
if [ "${enable_specialize}" = "true" ]; then
|
|
"$(dirname $0)/specialize-patch" \
|
|
${specialize_patch_options} \
|
|
-v kernel_version="${kver3}" \
|
|
-v SCSI_EXEC_REQ_FIFO_DEFINED="${scsi_exec_req_fifo_defined}" \
|
|
-v SCST_IO_CONTEXT="${scst_io_context}" \
|
|
| if [ "${generating_upstream_patch}" = "true" ]; then
|
|
scripts/filter-trace-entry-exit
|
|
else
|
|
cat
|
|
fi
|
|
else
|
|
cat
|
|
fi
|
|
}
|
|
|
|
# Read a patch from stdin, specialize it for kernel version ${kver}
|
|
# and write the output either to stdout or to the file $1 (if not empty),
|
|
# depending on the value of the variable ${multiple_patches}.
|
|
function process_patch {
|
|
local tmppatch
|
|
if [ "${multiple_patches}" = "true" ]; then
|
|
if [ "$1" != "" ]; then
|
|
if [ -e "${patchdir}/$1" ]; then
|
|
echo "Warning: overwriting ${patchdir}/$1"
|
|
fi
|
|
tmppatch="$(/bin/mktemp)"
|
|
(
|
|
specialize_patch
|
|
) >"${tmppatch}"
|
|
touch "${tmppatch}"
|
|
{
|
|
if [ -e /usr/bin/diffstat ]; then
|
|
awk 'BEGIN{h=1}/^diff/{h=0}/^---/{h=0}h!=0{print}' < "${tmppatch}"
|
|
echo "---"
|
|
diffstat "${tmppatch}"
|
|
echo ""
|
|
awk 'BEGIN{h=1}/^diff/{h=0}/^---/{h=0}h==0{print}' < "${tmppatch}"
|
|
fi
|
|
} \
|
|
> "${patchdir}/$(basename $1)"
|
|
rm -f "${tmppatch}"
|
|
else
|
|
# echo "Discarded $(wc -l) lines."
|
|
true
|
|
fi
|
|
else
|
|
specialize_patch
|
|
fi
|
|
}
|
|
|
|
# Returns 0 (true) if SCST core file "$1" should be added in a separate patch,
|
|
# and 1 (false) if not.
|
|
function in_separate_patch {
|
|
echo "${source_files_in_separate_patch}" | grep -qE "^$1 | $1 | $1\$|^$1\$"
|
|
}
|
|
|
|
|
|
#########################
|
|
# Argument verification #
|
|
#########################
|
|
|
|
debug_specialize="false"
|
|
enable_specialize="true"
|
|
generating_upstream_patch="false"
|
|
mpt_scst="false"
|
|
multiple_patches="false"
|
|
patchdir=""
|
|
qla2x00t="true"
|
|
replace_sbug_by_bug="true"
|
|
specialize_patch_options="-v delete_disabled_code=1"
|
|
srpt="true"
|
|
|
|
if [ ! -e scst -o ! -e iscsi-scst -o ! -e srpt -o ! -e scst_local ]; then
|
|
echo "Please run this script from inside the SCST subversion source tree."
|
|
exit 1
|
|
fi
|
|
|
|
set -- $(/usr/bin/getopt dhlmnp:su "$@")
|
|
while [ "$1" != "${1#-}" ]
|
|
do
|
|
case "$1" in
|
|
'-d') debug_specialize="true"; shift;;
|
|
'-h') usage; exit 1;;
|
|
'-l') shift;;
|
|
'-m') mpt_scst="true"; shift;;
|
|
'-n') specialize_patch_options="-v blank_deleted_code=1"
|
|
shift
|
|
;;
|
|
'-p') multiple_patches="true"; patchdir="$2"; shift; shift;;
|
|
'-s') enable_specialize="false"; shift;;
|
|
'-u') generating_upstream_patch="true"; shift;;
|
|
'--') shift;;
|
|
*) usage; exit 1;;
|
|
esac
|
|
done
|
|
|
|
if [ $# != 1 ]; then
|
|
usage
|
|
exit 1
|
|
fi
|
|
|
|
# Strip patch level from the kernel version number.
|
|
kver="$(kernel_version "$1")"
|
|
# kver3: first three components of the version number.
|
|
if [ "${1#2.}" != "$1" ]; then
|
|
kver3="$kver"
|
|
else
|
|
kver3="$1"
|
|
fi
|
|
|
|
# Include fcst in the patch for kernel versions 2.6.33 and later.
|
|
if [ "${kver}" ">" "2.6.32" ]; then
|
|
include_fcst="true"
|
|
else
|
|
include_fcst="false"
|
|
fi
|
|
|
|
# Make sure that for kernel 2.6.26 and later the line
|
|
# "#define CONFIG_SCST_PROC" is removed from scst/include/scst.h.
|
|
if grep -qw scst_sysfs scst/kernel/in-tree/Makefile.scst-${kver} \
|
|
|| [ "${generating_upstream_patch}" = "true" ];
|
|
then
|
|
specialize_patch_options="${specialize_patch_options} -v config_scst_proc_undefined=1"
|
|
else
|
|
include_proc_impl="true"
|
|
fi
|
|
if [ "${debug_specialize}" = "true" ]; then
|
|
specialize_patch_options="${specialize_patch_options} -v debug=1"
|
|
fi
|
|
if [ "${generating_upstream_patch}" = "true" ]; then
|
|
specialize_patch_options="${specialize_patch_options} -v generating_upstream_patch_defined=1 -v config_tcp_zero_copy_transfer_completion_notification_undefined=1"
|
|
fi
|
|
|
|
if [ "${multiple_patches}" = "true" ]; then
|
|
if [ -e "${patchdir}" ]; then
|
|
echo "Patch output directory ${patchdir} already exists."
|
|
fi
|
|
mkdir -p "${patchdir}"
|
|
if [ ! -d "${patchdir}" ]; then
|
|
echo "Error: ${patchdir} is not a directory."
|
|
fi
|
|
fi
|
|
|
|
|
|
####################
|
|
# Patch Generation #
|
|
####################
|
|
|
|
for f in fcst/linux-patches/series-${kver}*
|
|
do
|
|
if [ -e "$f" ]; then
|
|
fcst_patch_series="$f"
|
|
fi
|
|
done
|
|
|
|
|
|
# General kernel patches.
|
|
|
|
scsi_exec_req_fifo_defined=0
|
|
scst_io_context=0
|
|
for p in scst/kernel/*-${kver}.patch \
|
|
$(if [ "${1#3.2.}" != "$1" ] && [ "${1#3.2.}" -ge 57 ]; then
|
|
echo iscsi-scst/kernel/patches/*-3.2.57.patch;
|
|
elif [ "${1#3.7.}" != "$1" ] && [ "${1#3.7.}" -ge 10 ]; then
|
|
echo iscsi-scst/kernel/patches/*-3.7.10.patch;
|
|
elif [ "${1#3.10.}" != "$1" ] && [ "${1#3.10.}" -ge 30 ]; then
|
|
echo iscsi-scst/kernel/patches/*-3.10.30.patch;
|
|
elif [ "${1#3.12.}" != "$1" ] && [ "${1#3.12.}" -ge 11 ]; then
|
|
echo iscsi-scst/kernel/patches/*-3.12.11.patch;
|
|
elif [ "${1#3.13.}" != "$1" ] && [ "${1#3.13.}" -ge 3 ]; then
|
|
echo iscsi-scst/kernel/patches/*-3.13.3.patch;
|
|
else
|
|
echo iscsi-scst/kernel/patches/*-${kver}.patch;
|
|
fi)
|
|
do
|
|
# Exclude the put_page_callback patch when command-line option -u has been
|
|
# specified since the current approach is not considered acceptable for
|
|
# upstream kernel inclusion. See also http://lkml.org/lkml/2008/12/11/213.
|
|
if [ "${generating_upstream_patch}" = "false" \
|
|
-o "${p#iscsi-scst/kernel/patches/put_page_callback}" = "$p" ]
|
|
then
|
|
if grep -q '^\+#define SCSI_EXEC_REQ_FIFO_DEFINED$' "${p}"; then
|
|
scsi_exec_req_fifo_defined=1
|
|
fi
|
|
if grep -q '^\+#define SCST_IO_CONTEXT$' "${p}"; then
|
|
scst_io_context=1
|
|
fi
|
|
diffname="${p#scst/kernel/}"
|
|
diffname="${p%-${kver}.patch}.diff"
|
|
process_patch < "$p" "${diffname}"
|
|
fi
|
|
done
|
|
|
|
|
|
scst_03_public_headers="scst/include/scst.h scst/include/scst_const.h"
|
|
scst_04_main="scst/src/scst_main.c scst/src/scst_module.c scst/src/scst_priv.h"
|
|
scst_05_targ="scst/src/scst_targ.c"
|
|
scst_06_lib="scst/src/scst_lib.c"
|
|
scst_07_pres="scst/src/scst_pres.h scst/src/scst_pres.c"
|
|
scst_08_sysfs="scst/src/scst_sysfs.c"
|
|
scst_09_debug="scst/include/scst_debug.h scst/src/scst_debug.c"
|
|
scst_proc="scst/src/scst_proc.c"
|
|
scst_10_sgv="scst/include/scst_sgv.h scst/src/scst_mem.h scst/src/scst_mem.c doc/sgv_cache.sgml"
|
|
scst_user="scst/include/scst_user.h scst/src/dev_handlers/scst_user.c"
|
|
scst_13_vdisk="scst/src/dev_handlers/scst_vdisk.c"
|
|
scst_14_tg="scst/src/scst_tg.c"
|
|
separate_patches="scst_03_public_headers scst_04_main scst_05_targ scst_06_lib scst_07_pres scst_08_sysfs scst_09_debug scst_10_sgv scst_user scst_13_vdisk scst_14_tg"
|
|
|
|
if [ "$include_proc_impl" = "true" ]; then
|
|
separate_patches+=" scst_proc"
|
|
fi
|
|
source_files_in_separate_patch=""
|
|
for s in ${separate_patches}
|
|
do
|
|
source_files_in_separate_patch+=" $(set | \
|
|
sed -n -e "s/^$s='\(.*\)'$/\1/p" -e "s/^$s=\(.*\)$/\1/p")"
|
|
done
|
|
|
|
|
|
# Directory drivers/
|
|
|
|
(
|
|
add_patch "scst/kernel/in-tree/Kconfig.drivers.Linux-${kver}.patch" \
|
|
"drivers/Kconfig"
|
|
|
|
add_patch "scst/kernel/in-tree/Makefile.drivers.Linux-${kver}.patch"\
|
|
"drivers/Makefile"
|
|
) \
|
|
| process_patch "scst_01_drivers_kbuild.diff"
|
|
|
|
|
|
# Directory drivers/scst/
|
|
|
|
(
|
|
tmpdir="/tmp/scst-$$"
|
|
mkdir -p "${tmpdir}"
|
|
|
|
tmp_Kconfig="${tmpdir}/Kconfig.scst-${kver}"
|
|
cat "scst/kernel/in-tree/Kconfig.scst" | \
|
|
if [ "${include_fcst}" ]; then
|
|
cat
|
|
else
|
|
grep -v '^source "drivers/scst/fcst/Kconfig"$'
|
|
fi >"${tmp_Kconfig}"
|
|
add_file "${tmp_Kconfig}" "drivers/scst/Kconfig"
|
|
|
|
tmp_Makefile="${tmpdir}/Makefile.scst-${kver}"
|
|
cat "scst/kernel/in-tree/Makefile.scst-${kver}" | \
|
|
if [ "$include_proc_impl" != "true" ]; then
|
|
grep -v 'scst_proc'
|
|
else
|
|
cat
|
|
fi | \
|
|
if [ "${include_fcst}" -a "${kver}" != "2.6.37" -a "${kver}" != "2.6.38" ]; then
|
|
cat
|
|
else
|
|
sed -e 's: fcst/* : :'
|
|
fi >"$tmp_Makefile"
|
|
add_file "$tmp_Makefile" "drivers/scst/Makefile"
|
|
|
|
rm -rf "${tmpdir}"
|
|
) \
|
|
| process_patch "scst_02_scst_kbuild.diff"
|
|
|
|
for s in ${separate_patches}
|
|
do
|
|
fileset=$s
|
|
for f in $(set | grep "^$s=" | sed -e "s/^$s='\(.*\)'\$/\1/" -e "s/^$s=\(.*\)\$/\1/")
|
|
do
|
|
if [ "${f#scst/include}" != "${f}" ]; then
|
|
add_file "${f}" "include/scst/${f#scst/include/}"
|
|
elif [ "${f#doc}" != "${f}" ]; then
|
|
add_file "${f}" "Documentation/scst/${f#doc/}"
|
|
else
|
|
add_file "${f}" "drivers/scst/${f#scst/src/}"
|
|
fi
|
|
done \
|
|
| process_patch "${s}.diff"
|
|
done
|
|
|
|
{
|
|
add_file "scst/README_in-tree" "Documentation/scst/README.scst"
|
|
add_file "scst/SysfsRules" "Documentation/scst/SysfsRules"
|
|
} | process_patch "scst_11_core_doc.diff"
|
|
|
|
|
|
# Directory drivers/scst/dev_handlers/
|
|
|
|
add_file "scst/kernel/in-tree/Makefile.dev_handlers-${kver}" \
|
|
"drivers/scst/dev_handlers/Makefile" \
|
|
| process_patch "scst_11_dev_handlers_makefile.diff"
|
|
|
|
for f in $(ls scst/src/dev_handlers/*.[ch] 2>/dev/null)
|
|
do
|
|
if ! in_separate_patch "${f}"; then
|
|
add_file "${f}" "drivers/scst/dev_handlers/${f#scst/src/dev_handlers/}"
|
|
fi
|
|
done \
|
|
| process_patch "scst_14_passthrough.diff"
|
|
|
|
|
|
# Directory drivers/scst/fcst/
|
|
|
|
{
|
|
if [ -e "${fcst_patch_series}" ]; then
|
|
for f in $(grep -v '^#' "${fcst_patch_series}")
|
|
do
|
|
cat "fcst/linux-patches/${f}"
|
|
done
|
|
fi
|
|
|
|
add_file "fcst/Makefile_in-tree" \
|
|
"drivers/scst/fcst/Makefile"
|
|
|
|
add_file "fcst/Kconfig" "drivers/scst/fcst/Kconfig"
|
|
|
|
for f in $(ls fcst/*.[ch] 2>/dev/null)
|
|
do
|
|
add_file "${f}" "drivers/scst/fcst/${f#fcst/}"
|
|
done
|
|
} \
|
|
| process_patch "fcst.diff"
|
|
|
|
add_file "fcst/README" "Documentation/scst/README.fcst" \
|
|
| process_patch "fcst-doc.diff"
|
|
|
|
|
|
# Directory drivers/scst/iscsi-scst/
|
|
|
|
# Make sure the file iscsi-scst/iscsi_scst_itf_ver.h is up to date.
|
|
make -s -C iscsi-scst include/iscsi_scst_itf_ver.h
|
|
|
|
(
|
|
for f in $(ls iscsi-scst/include/*h 2>/dev/null)
|
|
do
|
|
if [ "${f}" != "iscsi-scst/include/iscsi_scst_itf_ver.h" ]; then
|
|
add_file "${f}" "include/scst/${f#iscsi-scst/include/}"
|
|
fi
|
|
done
|
|
|
|
add_file "iscsi-scst/include/iscsi_scst_itf_ver.h" "include/scst/iscsi_scst_itf_ver.h"
|
|
|
|
add_file "iscsi-scst/kernel/Makefile.in-kernel" \
|
|
"drivers/scst/iscsi-scst/Makefile"
|
|
|
|
add_file "iscsi-scst/kernel/Kconfig" "drivers/scst/iscsi-scst/Kconfig"
|
|
|
|
for f in $(ls iscsi-scst/kernel/*.[ch] 2>/dev/null)
|
|
do
|
|
add_file "${f}" "drivers/scst/iscsi-scst/${f#iscsi-scst/kernel/}"
|
|
done
|
|
) \
|
|
| process_patch "iscsi-scst.diff"
|
|
|
|
add_file "iscsi-scst/README_in-tree" "Documentation/scst/README.iscsi" \
|
|
| process_patch "iscsi-scst-doc.diff"
|
|
|
|
|
|
# Directory drivers/scst/qla2x00-target/
|
|
|
|
if [ "${qla2x00t}" = "true" ]; then
|
|
|
|
( cd qla2x00t && ./generate-in-tree-patches "$1" )
|
|
|
|
for f in $(ls qla2x00t/in-tree-patches/"$1"/*.patch 2>/dev/null)
|
|
do
|
|
g="${f#qla2x00t/in-tree-patches/$1/}"
|
|
g="${g%.patch}"
|
|
add_patch "${f}" "drivers/scsi/qla2xxx/${g}"
|
|
done
|
|
|
|
add_file "qla2x00t/qla2x_tgt.h" \
|
|
"drivers/scsi/qla2xxx/qla2x_tgt.h"
|
|
|
|
add_file "qla2x00t/qla2x_tgt_def.h" \
|
|
"drivers/scsi/qla2xxx/qla2x_tgt_def.h"
|
|
|
|
add_file "qla2x00t/qla2x00-target/Makefile_in-tree-${kver}" \
|
|
"drivers/scst/qla2xxx-target/Makefile"
|
|
|
|
add_file "qla2x00t/qla2x00-target/Kconfig" \
|
|
"drivers/scst/qla2xxx-target/Kconfig"
|
|
|
|
for f in $(ls qla2x00t/qla2x00-target/*.[ch] 2>/dev/null)
|
|
do
|
|
add_file "${f}" "drivers/scst/qla2xxx-target/${f#qla2x00t/qla2x00-target/}"
|
|
done
|
|
|
|
add_file "qla2x00t/qla2x00-target/README" \
|
|
"Documentation/scst/README.qla2x00t" \
|
|
| process_patch "qla2x00t-doc.diff"
|
|
|
|
else
|
|
|
|
add_empty_file "drivers/scst/qla2xxx-target/Makefile"
|
|
|
|
add_empty_file "drivers/scst/qla2xxx-target/Kconfig"
|
|
|
|
fi \
|
|
| process_patch "qla2x00t.diff"
|
|
|
|
|
|
# Directory drivers/scst/srpt
|
|
|
|
{
|
|
|
|
cat <<EOF
|
|
This patch adds the kernel module ib_srpt, which is a SCSI RDMA Protocol (SRP)
|
|
target implementation. This driver uses the InfiniBand stack and the SCST core.
|
|
|
|
It is a high performance driver capable of handling 600K+ 4K random write
|
|
IOPS by a single target as well as 2.5+ GB/s sequential throughput over
|
|
a single QDR IB port.
|
|
|
|
It was originally developed by Vu Pham (Mellanox) and has been optimized by
|
|
Bart Van Assche.
|
|
|
|
Signed-off-by: Bart Van Assche <bvanassche@acm.org>
|
|
Cc: Vu Pham <vu@mellanox.com>
|
|
Cc: Roland Dreier <rdreier@cisco.com>
|
|
Cc: David Dillow <dillowda@ornl.gov>
|
|
EOF
|
|
if [ "$srpt" = "true" ]; then
|
|
|
|
add_file "srpt/README_in-tree" "Documentation/scst/README.srpt"
|
|
|
|
add_file "srpt/src/Kconfig" "drivers/scst/srpt/Kconfig"
|
|
|
|
add_file "srpt/src/Makefile.in_kernel" "drivers/scst/srpt/Makefile"
|
|
|
|
for f in $(ls srpt/src/*.[ch] 2>/dev/null)
|
|
do
|
|
add_file "${f}" "drivers/scst/srpt/${f#srpt/src/}"
|
|
done
|
|
|
|
else
|
|
|
|
add_empty_file "drivers/scst/srpt/Kconfig"
|
|
|
|
add_empty_file "drivers/scst/srpt/Makefile"
|
|
|
|
fi \
|
|
} | process_patch "scst_17_srpt.diff"
|
|
|
|
|
|
# Directory drivers/message/fusion/mpt_scst
|
|
|
|
if [ "$mpt_scst" = "true" ]; then
|
|
|
|
(
|
|
add_patch "mpt/in-tree/Kconfig-2.6.24.diff" "drivers/message/fusion/Kconfig"
|
|
|
|
add_patch "mpt/in-tree/Makefile.diff" "drivers/message/fusion/Makefile"
|
|
|
|
add_file "mpt/in-tree/Makefile" "drivers/message/fusion/mpt_scst/Makefile"
|
|
|
|
add_file "mpt/in-tree/Kconfig" "drivers/message/fusion/mpt_scst/Kconfig"
|
|
|
|
for f in $(ls mpt/*.[ch] 2>/dev/null)
|
|
do
|
|
add_file "${f}" "drivers/message/fusion/mpt_scst/${f#mpt/}"
|
|
done
|
|
) \
|
|
| process_patch "mpt_scst.diff"
|
|
|
|
fi
|
|
|
|
|
|
# Directory drivers/scst/scst_local
|
|
|
|
(
|
|
add_file "scst_local/README" "Documentation/scst/README.scst_local"
|
|
|
|
add_file "scst_local/in-tree/Kconfig" "drivers/scst/scst_local/Kconfig"
|
|
|
|
add_file "scst_local/in-tree/Makefile-${kver}" "drivers/scst/scst_local/Makefile"
|
|
|
|
add_file "scst_local/scst_local.c" "drivers/scst/scst_local/scst_local.c"
|
|
) \
|
|
| process_patch "scst_16_local.diff"
|
|
|
|
|
|
|
|
# Directory drivers/scsi/ibmvstgt
|
|
|
|
{
|
|
( cd ibmvstgt && ./generate-in-tree-patches "${kver}" )
|
|
if [ -e "ibmvstgt/in-tree-patches/${kver}" ]; then
|
|
if [ "${multiple_patches}" = "true" ]; then
|
|
cat <<EOF
|
|
[SCSI] ibmvstgt: Port from tgt to SCST
|
|
|
|
The ibmvstgt and libsrp kernel modules as included in the 2.6.37 kernel are
|
|
based on the tgt SCSI target framework. Both kernel modules need the scsi_tgt
|
|
kernel module and the tgtd user space process in order to function
|
|
properly. This patch modifies the ibmvstgt and libsrp kernel modules such that
|
|
both use the SCST storage target framework instead of tgt. As a result,
|
|
neither the scsi_tgt kernel module nor the tgtd user space process are any
|
|
more necessary when using the ibmvstgt driver.
|
|
|
|
This patch introduces one backwards-incompatible change, namely that the path
|
|
of the ibmvstgt sysfs attributes is modified. This change is unavoidable
|
|
because this patch dissociates ibmvstgt SRP sessions from a SCSI host
|
|
instance. Since the user space STGT driver ibmvio was the only user of
|
|
these attributes, that shouldn't be an issue.
|
|
|
|
Changes in ibmvstgt compared to kernel 2.6.36:
|
|
- Increased maximum data size for a single SRP command from 128 KB to 64 MB
|
|
such that an initiator is not forced to split large transfers into
|
|
multiple SCSI commands.
|
|
- The maximum RDMA transfer size supported by a single H_COPY_RDMA call is
|
|
queried at driver initialization time from the open firmware tree / larger
|
|
transfers than 128 KB are now supported too.
|
|
- If DMA mapping fails while handling a READ or WRITE command, the offending
|
|
command is retried until the associated data has been transferred instead of
|
|
reporting to the ibmvscsi client that the SCSI command failed.
|
|
- VSCSI command/response queue: one element has been reserved for management
|
|
datagrams since these fall outside the SRP credit mechanism. Added a compile-
|
|
time check whether the size of this queue is a power of two.
|
|
- Fixed a race condition which in theory could have caused the VSCSI receive
|
|
queue to overflow: srp_iu_put() is now invoked before a response is sent back
|
|
to the initiator instead of after.
|
|
- Moved enum iue_flags from libsrp to ibmvstgt because it is ibmvstgt-specific.
|
|
- Removed a variable that was modified but never read from ibmvstgt_rdma().
|
|
- ibmvstgt_probe(): changed the datatype of the variable "dma" from
|
|
unsigned * into const unsigned * such that a cast could be removed.
|
|
- Fixed all compiler and sparse warnings (C=2 CF=-D__CHECK_ENDIAN__).
|
|
|
|
Changes in libsrp compared to kernel 2.6.36:
|
|
- Renamed vscsis_data_length() into srp_data_length() and exported
|
|
this function.
|
|
- All error messages reported via printk() do now have prefix KERN_ERR.
|
|
- modified srp_target_alloc() and srp_target_free() such that the
|
|
driver-private data reflects whether or not target data has been allocated.
|
|
This change was necessary to avoid that ibmvstgt_remove() triggers a
|
|
NULL-pointer dereference if ibmvstgt_probe() failed.
|
|
- srp_transfer_data(): All three return statements related to DMA mapping
|
|
failure do now return -ENOMEM instead of 0, -EIO and -ENOMEM.
|
|
- srp_direct_data(): Removed the ext_desc argument since not used.
|
|
- srp_direct_data() and srp_indirect_data(): Use DMA_TO/FROM_DEVICE
|
|
instead of DMA_BIDIRECTIONAL for the buffers mapped for transferring data
|
|
via DMA.
|
|
- struct srp_target: eliminated the information unit linked list and also the
|
|
V_FLYING flag since both were duplicating information managed by the SCST
|
|
core.
|
|
- Fixed all compiler and sparse warnings (C=2 CF=-D__CHECK_ENDIAN__).
|
|
|
|
Tests performed on a backport to kernel version 2.6.18 of this driver with a
|
|
Linux initiator system:
|
|
- Verified that the kernel module ibmvstgt loads and initializes successfully
|
|
and also that the client connects after loading.
|
|
- Verified that all virtual disks configured in scst_vdisk were discovered by
|
|
the client after rescanning the SCSI bus.
|
|
- Verified that after unloading and reloading ibmvstgt and after client
|
|
recovery that the initiator devices were functioning normally.
|
|
- Verified that after a client reboot ibmvscsic reconnected with the target
|
|
and that the target devices were again usable.
|
|
- Performed IO stress testing on the device.
|
|
- Verified that SCSI task abortion works correctly.
|
|
- Performed basic I/O performance testing. With a RAM disk as target linear
|
|
direct I/O throughput was above 2 GB/s and a random I/O test resulted in
|
|
about 30000 IOPS for all block sizes between 512 bytes and 16 KB.
|
|
Both initiator and target were dual core POWER6 LPAR systems.
|
|
|
|
Note: ibmvstgt is the only user of libsrp.
|
|
|
|
Signed-off-by: Bart Van Assche <bvanassche@acm.org>
|
|
Cc: Fujita Tomonori <fujita.tomonori@lab.ntt.co.jp>
|
|
Cc: Brian King <brking@linux.vnet.ibm.com>
|
|
Cc: Robert Jennings <rcj@linux.vnet.ibm.com>
|
|
|
|
EOF
|
|
fi
|
|
for f in \
|
|
drivers/scsi/ibmvscsi/ibmvstgt.c \
|
|
drivers/scsi/libsrp.c \
|
|
include/scsi/libsrp.h \
|
|
include/scsi/srp.h
|
|
do
|
|
patch="ibmvstgt/in-tree-patches/${kver}/$(basename $f).patch"
|
|
if [ -e "${patch}" ]; then
|
|
add_patch "${patch}" $f
|
|
fi
|
|
done
|
|
add_file "ibmvstgt/README.sysfs" "Documentation/powerpc/ibmvstgt.txt"
|
|
fi
|
|
} \
|
|
| process_patch "scst_18_ibmvstgt.diff"
|
|
|
|
{
|
|
( cd ibmvstgt && ./generate-in-tree-patches "${kver}" )
|
|
if [ -e "ibmvstgt/in-tree-patches/${kver}" ]; then
|
|
if [ "${multiple_patches}" = "true" ]; then
|
|
cat <<EOF
|
|
[SCSI] tgt: Removal
|
|
|
|
Because of the conversion of the ibmvstgt driver from tgt to SCST, and because
|
|
the ibmvstgt driver was the only user of scsi_tgt, the scsi_tgt kernel module,
|
|
the CONFIG_SCSI_TGT, CONFIG_SCSI_SRP_TGT_ATTRS and CONFIG_SCSI_FC_TGT_ATTRS
|
|
kbuild variable, the scsi_host_template member variables transfer_response,
|
|
supportedmode and active_mode and the constants MODE_UNKNOWN, MODE_INITIATOR
|
|
and MODE_TARGET are no longer needed.
|
|
|
|
Note: this patch applies cleanly on a 2.6.35 kernel tree. The patch tool
|
|
however complains about the defconfig changes when trying to apply this patch
|
|
on a 2.6.36 kernel tree.
|
|
|
|
Signed-off-by: Bart Van Assche <bvanassche@acm.org>
|
|
|
|
EOF
|
|
fi
|
|
for f in \
|
|
arch/arm/configs/at572d940hfek_defconfig \
|
|
arch/arm/configs/cam60_defconfig \
|
|
arch/arm/configs/s3c2410_defconfig \
|
|
arch/m68k/configs/amiga_defconfig \
|
|
arch/m68k/configs/apollo_defconfig \
|
|
arch/m68k/configs/atari_defconfig \
|
|
arch/m68k/configs/bvme6000_defconfig \
|
|
arch/m68k/configs/hp300_defconfig \
|
|
arch/m68k/configs/mac_defconfig \
|
|
arch/m68k/configs/multi_defconfig \
|
|
arch/m68k/configs/mvme147_defconfig \
|
|
arch/m68k/configs/mvme16x_defconfig \
|
|
arch/m68k/configs/q40_defconfig \
|
|
arch/m68k/configs/sun3_defconfig \
|
|
arch/m68k/configs/sun3x_defconfig \
|
|
arch/mips/configs/bcm47xx_defconfig \
|
|
arch/mips/configs/decstation_defconfig \
|
|
arch/mips/configs/ip22_defconfig \
|
|
arch/mips/configs/ip27_defconfig \
|
|
arch/mips/configs/ip32_defconfig \
|
|
arch/mips/configs/jazz_defconfig \
|
|
arch/mips/configs/malta_defconfig \
|
|
arch/mips/configs/markeins_defconfig \
|
|
arch/mips/configs/pnx8550-jbs_defconfig \
|
|
arch/mips/configs/pnx8550-stb810_defconfig \
|
|
arch/mips/configs/rm200_defconfig \
|
|
arch/mips/configs/tb0226_defconfig \
|
|
arch/mips/configs/tb0287_defconfig \
|
|
arch/powerpc/configs/52xx/motionpro_defconfig \
|
|
arch/powerpc/configs/86xx/mpc8610_hpcd_defconfig \
|
|
arch/powerpc/configs/mpc5200_defconfig \
|
|
drivers/scsi/Kconfig \
|
|
drivers/scsi/Makefile \
|
|
drivers/scsi/hosts.c \
|
|
drivers/scsi/scsi_sysfs.c \
|
|
drivers/scsi/scsi_tgt_if.c \
|
|
drivers/scsi/scsi_tgt_lib.c \
|
|
drivers/scsi/scsi_tgt_priv.h \
|
|
drivers/scsi/scsi_transport_fc.c \
|
|
drivers/scsi/scsi_transport_fc_internal.h \
|
|
drivers/scsi/scsi_transport_srp.c \
|
|
drivers/scsi/scsi_transport_srp_internal.h \
|
|
include/scsi/scsi_host.h \
|
|
include/scsi/scsi_tgt.h \
|
|
include/scsi/scsi_tgt_if.h
|
|
do
|
|
add_patch "ibmvstgt/in-tree-patches/${kver}/$(basename $f).patch" $f
|
|
done
|
|
fi
|
|
} \
|
|
| process_patch "scst_19_scsi_tgt.diff"
|