2018-01-04 23:11:45 +00:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
testdir=$(readlink -f $(dirname $0))
|
|
|
|
rootdir=$(readlink -f $testdir/../../..)
|
2018-02-27 22:14:08 +00:00
|
|
|
source $rootdir/test/common/autotest_common.sh
|
2018-01-04 23:11:45 +00:00
|
|
|
source $rootdir/test/iscsi_tgt/common.sh
|
|
|
|
|
2020-08-11 10:36:11 +00:00
|
|
|
iscsitestinit
|
2019-05-06 22:46:30 +00:00
|
|
|
|
2018-04-18 08:36:46 +00:00
|
|
|
function node_login_fio_logout() {
|
|
|
|
for arg in "$@"; do
|
2018-03-27 13:39:38 +00:00
|
|
|
iscsiadm -m node -p $TARGET_IP:$ISCSI_PORT -o update -n node.conn[0].iscsi.$arg
|
2018-02-28 09:12:53 +00:00
|
|
|
done
|
2018-03-27 13:39:38 +00:00
|
|
|
iscsiadm -m node --login -p $TARGET_IP:$ISCSI_PORT
|
2019-06-17 07:23:20 +00:00
|
|
|
waitforiscsidevices 1
|
2019-05-24 22:58:19 +00:00
|
|
|
$fio_py -p iscsi -i 512 -d 1 -t write -r 2
|
|
|
|
$fio_py -p iscsi -i 512 -d 1 -t read -r 2
|
2018-03-27 13:39:38 +00:00
|
|
|
iscsiadm -m node --logout -p $TARGET_IP:$ISCSI_PORT
|
2019-06-17 07:23:20 +00:00
|
|
|
waitforiscsidevices 0
|
2018-01-04 23:11:45 +00:00
|
|
|
}
|
|
|
|
|
2018-04-18 08:36:46 +00:00
|
|
|
function iscsi_header_digest_test() {
|
2018-01-24 02:31:07 +00:00
|
|
|
# Enable HeaderDigest to CRC32C
|
2018-02-28 09:12:53 +00:00
|
|
|
node_login_fio_logout "HeaderDigest -v CRC32C"
|
2018-01-24 02:31:07 +00:00
|
|
|
|
|
|
|
# Let iscsi target to decide its preference on
|
|
|
|
# HeaderDigest based on its capability.
|
2018-02-28 09:12:53 +00:00
|
|
|
node_login_fio_logout "HeaderDigest -v CRC32C,None"
|
2018-01-24 02:31:07 +00:00
|
|
|
}
|
|
|
|
|
2018-04-18 08:36:46 +00:00
|
|
|
function iscsi_header_data_digest_test() {
|
2018-01-24 02:31:07 +00:00
|
|
|
# Only enable HeaderDigest to CRC32C
|
2018-02-28 09:12:53 +00:00
|
|
|
node_login_fio_logout "HeaderDigest -v CRC32C" "DataDigest -v None"
|
2018-01-24 02:31:07 +00:00
|
|
|
|
|
|
|
# Only enable DataDigest to CRC32C
|
2018-02-28 09:12:53 +00:00
|
|
|
node_login_fio_logout "HeaderDigest -v None" "DataDigest -v CRC32C"
|
2018-01-24 02:31:07 +00:00
|
|
|
|
|
|
|
# Let iscsi target to decide its preference on both
|
|
|
|
# HeaderDigest and DataDigest based on its capability.
|
2018-02-28 09:12:53 +00:00
|
|
|
node_login_fio_logout "HeaderDigest -v CRC32C,None" "DataDigest -v CRC32C,None"
|
2018-01-24 02:31:07 +00:00
|
|
|
|
|
|
|
# Enable HeaderDigest and DataDigest both.
|
2018-02-28 09:12:53 +00:00
|
|
|
node_login_fio_logout "HeaderDigest -v CRC32C" "DataDigest -v CRC32C"
|
2018-01-24 02:31:07 +00:00
|
|
|
}
|
|
|
|
|
2018-01-04 23:11:45 +00:00
|
|
|
MALLOC_BDEV_SIZE=64
|
|
|
|
MALLOC_BLOCK_SIZE=512
|
|
|
|
|
2018-09-11 13:26:14 +00:00
|
|
|
rpc_py="$rootdir/scripts/rpc.py"
|
|
|
|
fio_py="$rootdir/scripts/fio.py"
|
2018-01-04 23:11:45 +00:00
|
|
|
|
|
|
|
timing_enter start_iscsi_tgt
|
|
|
|
|
2020-02-20 10:24:53 +00:00
|
|
|
"${ISCSI_APP[@]}" -m $ISCSI_TEST_CORE_MASK --wait-for-rpc &
|
2018-01-04 23:11:45 +00:00
|
|
|
pid=$!
|
|
|
|
echo "Process pid: $pid"
|
|
|
|
|
2020-08-11 10:36:11 +00:00
|
|
|
trap 'killprocess $pid; iscsitestfini; exit 1' SIGINT SIGTERM EXIT
|
2018-01-04 23:11:45 +00:00
|
|
|
|
|
|
|
waitforlisten $pid
|
2019-09-11 11:15:34 +00:00
|
|
|
$rpc_py iscsi_set_options -o 30 -a 16
|
2019-09-11 13:30:14 +00:00
|
|
|
$rpc_py framework_start_init
|
2018-01-04 23:11:45 +00:00
|
|
|
echo "iscsi_tgt is listening. Running tests..."
|
|
|
|
|
|
|
|
timing_exit start_iscsi_tgt
|
|
|
|
|
2019-09-09 10:35:30 +00:00
|
|
|
$rpc_py iscsi_create_portal_group $PORTAL_TAG $TARGET_IP:$ISCSI_PORT
|
2019-09-03 08:53:37 +00:00
|
|
|
$rpc_py iscsi_create_initiator_group $INITIATOR_TAG $INITIATOR_NAME $NETMASK
|
2019-08-09 11:15:35 +00:00
|
|
|
$rpc_py bdev_malloc_create $MALLOC_BDEV_SIZE $MALLOC_BLOCK_SIZE
|
2018-01-04 23:11:45 +00:00
|
|
|
# "Malloc0:0" ==> use Malloc0 blockdev for LUN0
|
|
|
|
# "1:2" ==> map PortalGroup1 to InitiatorGroup2
|
|
|
|
# "64" ==> iSCSI queue depth 64
|
2018-03-12 04:41:21 +00:00
|
|
|
# "-d" ==> disable CHAP authentication
|
2019-09-05 10:35:18 +00:00
|
|
|
$rpc_py iscsi_create_target_node Target3 Target3_alias 'Malloc0:0' $PORTAL_TAG:$INITIATOR_TAG 64 -d
|
2018-01-04 23:11:45 +00:00
|
|
|
sleep 1
|
|
|
|
|
2018-03-27 13:39:38 +00:00
|
|
|
iscsiadm -m discovery -t sendtargets -p $TARGET_IP:$ISCSI_PORT
|
2018-01-04 23:11:45 +00:00
|
|
|
|
2019-07-10 07:05:55 +00:00
|
|
|
# iscsiadm installed by some Fedora releases loses the ability to set DataDigest parameter.
|
2018-01-24 02:31:07 +00:00
|
|
|
# Check and avoid setting DataDigest.
|
2019-07-10 07:05:55 +00:00
|
|
|
DataDigestAbility=$(iscsiadm -m node -p $TARGET_IP:$ISCSI_PORT -o update -n node.conn[0].iscsi.DataDigest -v None 2>&1 || true)
|
|
|
|
if [ "$DataDigestAbility"x != x ]; then
|
2019-12-19 23:03:30 +00:00
|
|
|
run_test "iscsi_tgt_digest" iscsi_header_digest_test
|
2018-01-24 02:31:07 +00:00
|
|
|
else
|
2019-12-19 23:03:30 +00:00
|
|
|
run_test "iscsi_tgt_data_digest" iscsi_header_data_digest_test
|
2018-01-24 02:31:07 +00:00
|
|
|
fi
|
2018-01-04 23:11:45 +00:00
|
|
|
|
|
|
|
trap - SIGINT SIGTERM EXIT
|
|
|
|
|
|
|
|
iscsicleanup
|
|
|
|
killprocess $pid
|
2020-08-11 10:36:11 +00:00
|
|
|
iscsitestfini
|