2017-03-02 14:12:20 +00:00
|
|
|
#!/usr/bin/env bash
|
2022-11-02 15:49:40 +00:00
|
|
|
# SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
# Copyright (C) 2016 Intel Corporation
|
|
|
|
# All rights reserved.
|
|
|
|
#
|
2016-12-14 20:34:03 +00:00
|
|
|
set -xe
|
2017-03-02 14:12:20 +00:00
|
|
|
|
2023-03-17 01:48:50 +00:00
|
|
|
cleanup() {
|
|
|
|
local _devs=()
|
2021-04-12 10:20:36 +00:00
|
|
|
|
2023-03-17 01:48:50 +00:00
|
|
|
((${#devs[@]} > 0)) || return 0
|
|
|
|
|
|
|
|
_devs=("${devs[@]/#//dev/}")
|
2021-04-12 10:20:36 +00:00
|
|
|
|
|
|
|
umount "${_devs[@]}" || :
|
2023-03-17 01:48:50 +00:00
|
|
|
wipefs --all --force "${_devs[@]}" || :
|
2021-04-12 10:20:36 +00:00
|
|
|
}
|
|
|
|
|
2020-05-07 11:27:06 +00:00
|
|
|
MAKE="make -j$(($(nproc) * 2))"
|
2017-03-02 14:12:20 +00:00
|
|
|
|
2023-03-17 01:48:50 +00:00
|
|
|
devs=()
|
2018-02-06 11:20:21 +00:00
|
|
|
if [[ $1 == "spdk_vhost_scsi" ]]; then
|
|
|
|
for entry in /sys/block/sd*; do
|
2023-03-17 01:48:50 +00:00
|
|
|
if [[ $(< "$entry/device/vendor") =~ (INTEL|RAWSCSI|LIO-ORG) ]]; then
|
|
|
|
devs+=("${entry##*/}")
|
2018-02-06 11:20:21 +00:00
|
|
|
fi
|
|
|
|
done
|
|
|
|
elif [[ $1 == "spdk_vhost_blk" ]]; then
|
2023-03-17 01:48:50 +00:00
|
|
|
devs=(/sys/block/vd*)
|
2017-08-09 10:38:11 +00:00
|
|
|
fi
|
2017-03-02 14:12:20 +00:00
|
|
|
|
2018-02-06 11:20:21 +00:00
|
|
|
fs=$2
|
2023-03-17 01:48:50 +00:00
|
|
|
devs=("${devs[@]##*/}")
|
2018-02-06 11:20:21 +00:00
|
|
|
|
2023-03-17 01:48:50 +00:00
|
|
|
trap "cleanup; exit 1" SIGINT SIGTERM EXIT
|
2016-12-14 20:34:03 +00:00
|
|
|
|
2017-12-07 11:14:29 +00:00
|
|
|
for fs in $fs; do
|
2023-03-17 01:48:50 +00:00
|
|
|
for dev in "${devs[@]}"; do
|
|
|
|
[[ -b /dev/$dev ]]
|
|
|
|
wipefs --all --force "/dev/$dev"
|
|
|
|
echo "INFO: Creating partition table on $dev disk"
|
|
|
|
parted "/dev/$dev" -s mklabel gpt mkpart SPDK_TEST 2048s 100%
|
|
|
|
sleep 1s
|
|
|
|
wipefs --all --force "/dev/${dev}1"
|
|
|
|
echo "INFO: Creating filesystem on /dev/${dev}1"
|
|
|
|
|
|
|
|
if [[ $fs == ext4 ]]; then
|
|
|
|
"mkfs.$fs" -F "/dev/${dev}1"
|
|
|
|
else
|
|
|
|
"mkfs.$fs" -f "/dev/${dev}1"
|
2018-02-06 11:20:21 +00:00
|
|
|
fi
|
2016-12-14 20:34:03 +00:00
|
|
|
|
2018-02-06 11:20:21 +00:00
|
|
|
mkdir -p /mnt/${dev}dir
|
|
|
|
mount -o sync /dev/${dev}1 /mnt/${dev}dir
|
2017-03-02 14:12:20 +00:00
|
|
|
|
2018-02-06 11:20:21 +00:00
|
|
|
fio --name="integrity" --bsrange=4k-512k --iodepth=128 --numjobs=1 --direct=1 \
|
2020-05-07 11:27:06 +00:00
|
|
|
--thread=1 --group_reporting=1 --rw=randrw --rwmixread=70 \
|
|
|
|
--filename=/mnt/${dev}dir/test_file --verify=md5 --do_verify=1 \
|
2022-06-13 09:36:46 +00:00
|
|
|
--verify_backlog=1024 --fsync_on_close=1 --runtime=20 --time_based=1 \
|
|
|
|
--size=512m --verify_state_save=0
|
2017-12-07 11:14:29 +00:00
|
|
|
|
2018-02-06 11:20:21 +00:00
|
|
|
# Print out space consumed on target device
|
|
|
|
df -h /dev/$dev
|
2017-03-02 14:12:20 +00:00
|
|
|
|
2018-02-06 11:20:21 +00:00
|
|
|
umount /mnt/${dev}dir
|
|
|
|
rm -rf /mnt/${dev}dir
|
2020-05-07 11:27:06 +00:00
|
|
|
stats=($(cat /sys/block/$dev/stat))
|
2018-02-06 11:20:21 +00:00
|
|
|
echo ""
|
|
|
|
echo "$dev stats"
|
|
|
|
printf "READ IO cnt: % 8u merges: % 8u sectors: % 8u ticks: % 8u\n" \
|
2020-05-07 11:27:06 +00:00
|
|
|
${stats[0]} ${stats[1]} ${stats[2]} ${stats[3]}
|
2018-02-06 11:20:21 +00:00
|
|
|
printf "WRITE IO cnt: % 8u merges: % 8u sectors: % 8u ticks: % 8u\n" \
|
2020-05-07 11:27:06 +00:00
|
|
|
${stats[4]} ${stats[5]} ${stats[6]} ${stats[7]}
|
2018-02-06 11:20:21 +00:00
|
|
|
printf "in flight: % 8u io ticks: % 8u time in queue: % 8u\n" \
|
2020-05-07 11:27:06 +00:00
|
|
|
${stats[8]} ${stats[9]} ${stats[10]}
|
2018-02-06 11:20:21 +00:00
|
|
|
echo ""
|
|
|
|
done
|
2017-03-02 14:12:20 +00:00
|
|
|
done
|
|
|
|
|
|
|
|
trap - SIGINT SIGTERM EXIT
|
2023-03-17 01:48:50 +00:00
|
|
|
cleanup
|