bdevperf application is utilized in multiple test scenarios and most prominently in SPDK performance reports. Similar to perf and fio_plugins, it is used to measure performance. It is intended to represent the expected behavior of users application that use SPDK bdev layer. Applications under --enable-tests are intended for specific test scenarios and user interaction is usually via a test scripts. Meanwhile --enable-examples are used more broadly to teach and show usage of SPDK libraries. As an added benefit with this patch, its possible to compile bdevperf without need to satisfy additional requirements to compile all the test applications. Change-Id: I9aaec1f9d729a1cdee89b5fdc365d61c19b03f82 Signed-off-by: Krzysztof Karas <krzysztof.karas@intel.com> Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/14558 Reviewed-by: Tomasz Zawadzki <tomasz.zawadzki@intel.com> Reviewed-by: Aleksey Marchuk <alexeymar@nvidia.com> Reviewed-by: Paul Luse <paul.e.luse@intel.com> Tested-by: SPDK CI Jenkins <sys_sgci@intel.com> Community-CI: Mellanox Build Bot
124 lines
3.4 KiB
Bash
Executable File
124 lines
3.4 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
set -e
|
|
|
|
testdir=$(readlink -f $(dirname $0))
|
|
rootdir=$(readlink -f $testdir/../..)
|
|
plugindir=$rootdir/examples/bdev/fio_plugin
|
|
source "$rootdir/scripts/common.sh"
|
|
source "$rootdir/test/common/autotest_common.sh"
|
|
source "$rootdir/test/nvmf/common.sh"
|
|
|
|
# Declare rpc_py here, because its default value points to rpc_cmd function,
|
|
# which does not tolerate piping arguments into it.
|
|
rpc_py="$rootdir/scripts/rpc.py"
|
|
|
|
function error_cleanup() {
|
|
# force delete pmem file and wipe on-disk metadata
|
|
rm -rf /tmp/pmem
|
|
$SPDK_EXAMPLE_DIR/perf -q 1 -o 131072 -w write -t 2
|
|
}
|
|
|
|
function destroy_vols() {
|
|
# Gracefully destroy the vols via bdev_compress_delete API.
|
|
# bdev_compress_delete will delete the on-disk metadata as well as
|
|
# the persistent memory file containing its metadata.
|
|
$rpc_py bdev_compress_delete COMP_lvs0/lv0
|
|
$rpc_py bdev_lvol_delete_lvstore -l lvs0
|
|
}
|
|
|
|
function create_vols() {
|
|
$rootdir/scripts/gen_nvme.sh | $rpc_py load_subsystem_config
|
|
waitforbdev Nvme0n1
|
|
|
|
$rpc_py bdev_lvol_create_lvstore Nvme0n1 lvs0
|
|
$rpc_py bdev_lvol_create -t -l lvs0 lv0 100
|
|
waitforbdev lvs0/lv0
|
|
|
|
$rpc_py bdev_compress_set_pmd -p "$pmd"
|
|
if [ -z "$1" ]; then
|
|
$rpc_py bdev_compress_create -b lvs0/lv0 -p /tmp/pmem
|
|
else
|
|
$rpc_py bdev_compress_create -b lvs0/lv0 -p /tmp/pmem -l $1
|
|
fi
|
|
waitforbdev COMP_lvs0/lv0
|
|
}
|
|
|
|
function run_bdevio() {
|
|
$rootdir/test/bdev/bdevio/bdevio -w &
|
|
bdevio_pid=$!
|
|
trap 'killprocess $bdevio_pid; error_cleanup; exit 1' SIGINT SIGTERM EXIT
|
|
waitforlisten $bdevio_pid
|
|
create_vols
|
|
$rootdir/test/bdev/bdevio/tests.py perform_tests
|
|
destroy_vols
|
|
trap - SIGINT SIGTERM EXIT
|
|
killprocess $bdevio_pid
|
|
}
|
|
|
|
function run_bdevperf() {
|
|
$rootdir/build/examples/bdevperf -z -q $1 -o $2 -w verify -t $3 -C -m 0x6 &
|
|
bdevperf_pid=$!
|
|
trap 'killprocess $bdevperf_pid; error_cleanup; exit 1' SIGINT SIGTERM EXIT
|
|
waitforlisten $bdevperf_pid
|
|
create_vols $4
|
|
$rootdir/examples/bdev/bdevperf/bdevperf.py perform_tests
|
|
destroy_vols
|
|
trap - SIGINT SIGTERM EXIT
|
|
killprocess $bdevperf_pid
|
|
}
|
|
|
|
test_type=$1
|
|
case "$test_type" in
|
|
qat)
|
|
pmd=1
|
|
;;
|
|
isal)
|
|
pmd=2
|
|
;;
|
|
*)
|
|
echo "invalid pmd name"
|
|
exit 1
|
|
;;
|
|
esac
|
|
|
|
mkdir -p /tmp/pmem
|
|
|
|
# per patch bdevperf uses slightly different params than nightly
|
|
# logical block size same as underlying device, then 512 then 4096
|
|
run_bdevperf 32 4096 3
|
|
run_bdevperf 32 4096 3 512
|
|
run_bdevperf 32 4096 3 4096
|
|
run_bdevio
|
|
|
|
if [ $RUN_NIGHTLY -eq 1 ]; then
|
|
run_bdevperf 64 16384 30
|
|
|
|
# run perf on nvmf target w/compressed vols
|
|
export TEST_TRANSPORT=tcp
|
|
NET_TYPE=virt nvmftestinit
|
|
nvmfappstart -m 0x7
|
|
trap "nvmftestfini; error_cleanup; exit 1" SIGINT SIGTERM EXIT
|
|
|
|
# Create an NVMe-oF subsystem and add compress bdevs as namespaces
|
|
$rpc_py nvmf_create_transport -t $TEST_TRANSPORT -u 8192
|
|
create_vols
|
|
$rpc_py nvmf_create_subsystem nqn.2016-06.io.spdk:cnode0 -a -s SPDK0
|
|
$rpc_py nvmf_subsystem_add_ns nqn.2016-06.io.spdk:cnode0 COMP_lvs0/lv0
|
|
$rpc_py nvmf_subsystem_add_listener nqn.2016-06.io.spdk:cnode0 -t $TEST_TRANSPORT -a $NVMF_FIRST_TARGET_IP -s $NVMF_PORT
|
|
|
|
# Start random read writes in the background
|
|
$SPDK_EXAMPLE_DIR/perf -r "trtype:$TEST_TRANSPORT adrfam:IPv4 traddr:$NVMF_FIRST_TARGET_IP trsvcid:$NVMF_PORT" -o 4096 -q 64 -s 512 -w randrw -t 30 -c 0x18 -M 50 &
|
|
perf_pid=$!
|
|
|
|
# Wait for I/O to complete
|
|
trap 'killprocess $perf_pid; compress_err_cleanup; exit 1' SIGINT SIGTERM EXIT
|
|
wait $perf_pid
|
|
destroy_vols
|
|
|
|
trap - SIGINT SIGTERM EXIT
|
|
nvmftestfini
|
|
fi
|
|
|
|
rm -rf /tmp/pmem
|