2018-08-29 07:11:25 +00:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
2019-06-12 07:48:32 +00:00
|
|
|
SYSTEM=$(uname -s)
|
2020-05-07 11:27:06 +00:00
|
|
|
if [ $SYSTEM = "FreeBSD" ]; then
|
|
|
|
echo "blob_io_wait.sh cannot run on FreeBSD currently."
|
|
|
|
exit 0
|
2018-08-29 07:11:25 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
testdir=$(readlink -f $(dirname $0))
|
|
|
|
rootdir=$(readlink -f $testdir/../../..)
|
|
|
|
source $rootdir/test/common/autotest_common.sh
|
|
|
|
|
|
|
|
truncate -s 64M $testdir/aio.bdev
|
|
|
|
|
2020-10-13 08:19:14 +00:00
|
|
|
$rootdir/test/app/bdev_svc/bdev_svc --wait-for-rpc &
|
2018-08-29 07:11:25 +00:00
|
|
|
bdev_svc_pid=$!
|
|
|
|
|
2020-12-09 18:10:29 +00:00
|
|
|
trap 'rm -f $testdir/bdevperf.json; rm -f $testdir/aio.bdev; killprocess $bdev_svc_pid; exit 1' SIGINT SIGTERM EXIT
|
2018-08-29 07:11:25 +00:00
|
|
|
|
|
|
|
waitforlisten $bdev_svc_pid
|
2020-10-13 08:19:14 +00:00
|
|
|
# Minimal number of bdev io pool (128) and cache (1)
|
2020-12-22 15:40:59 +00:00
|
|
|
$rpc_py bdev_set_options --bdev-io-pool-size 128 --bdev-io-cache-size 1 --small-buf-pool-size 8192 --large-buf-pool-size 1024
|
2020-10-13 08:19:14 +00:00
|
|
|
$rpc_py framework_start_init
|
2019-08-13 09:38:42 +00:00
|
|
|
$rpc_py bdev_aio_create $testdir/aio.bdev aio0 4096
|
2019-08-29 13:31:19 +00:00
|
|
|
$rpc_py bdev_lvol_create_lvstore aio0 lvs0
|
2019-08-29 11:01:30 +00:00
|
|
|
$rpc_py bdev_lvol_create -l lvs0 lvol0 32
|
2020-10-13 08:19:14 +00:00
|
|
|
$rpc_py save_config > $testdir/bdevperf.json
|
2018-08-29 07:11:25 +00:00
|
|
|
|
|
|
|
killprocess $bdev_svc_pid
|
|
|
|
|
2022-09-06 12:15:46 +00:00
|
|
|
$rootdir/build/examples/bdevperf --json $testdir/bdevperf.json -q 128 -o 4096 -w write -t 5 -r /var/tmp/spdk.sock &
|
2018-12-14 10:09:22 +00:00
|
|
|
bdev_perf_pid=$!
|
|
|
|
waitforlisten $bdev_perf_pid
|
2019-09-11 10:39:52 +00:00
|
|
|
$rpc_py bdev_enable_histogram aio0 -e
|
2018-12-14 10:09:22 +00:00
|
|
|
sleep 2
|
2019-09-11 10:54:13 +00:00
|
|
|
$rpc_py bdev_get_histogram aio0 | $rootdir/scripts/histogram.py
|
2019-09-11 10:39:52 +00:00
|
|
|
$rpc_py bdev_enable_histogram aio0 -d
|
2018-12-14 10:09:22 +00:00
|
|
|
wait $bdev_perf_pid
|
|
|
|
|
2022-09-06 12:15:46 +00:00
|
|
|
$rootdir/build/examples/bdevperf --json $testdir/bdevperf.json -q 128 -o 4096 -w read -t 5 -r /var/tmp/spdk.sock &
|
2018-12-14 10:09:22 +00:00
|
|
|
bdev_perf_pid=$!
|
|
|
|
waitforlisten $bdev_perf_pid
|
2019-09-11 10:39:52 +00:00
|
|
|
$rpc_py bdev_enable_histogram aio0 -e
|
2018-12-14 10:09:22 +00:00
|
|
|
sleep 2
|
2019-09-11 10:54:13 +00:00
|
|
|
$rpc_py bdev_get_histogram aio0 | $rootdir/scripts/histogram.py
|
2019-09-11 10:39:52 +00:00
|
|
|
$rpc_py bdev_enable_histogram aio0 -d
|
2018-12-14 10:09:22 +00:00
|
|
|
wait $bdev_perf_pid
|
|
|
|
|
2022-09-06 12:15:46 +00:00
|
|
|
$rootdir/build/examples/bdevperf --json $testdir/bdevperf.json -q 128 -o 4096 -w unmap -t 1
|
2018-08-29 07:11:25 +00:00
|
|
|
|
|
|
|
sync
|
2020-10-13 08:19:14 +00:00
|
|
|
rm -f $testdir/bdevperf.json
|
|
|
|
rm -f $testdir/aio.bdev
|
2018-08-29 07:11:25 +00:00
|
|
|
trap - SIGINT SIGTERM EXIT
|