2017-11-15 19:43:15 +01:00
|
|
|
: ${SPDK_AUTOTEST_X=true}; export SPDK_AUTOTEST_X
|
|
|
|
|
|
|
|
if $SPDK_AUTOTEST_X; then
|
|
|
|
set -x
|
|
|
|
fi
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
2018-04-04 12:38:39 -04:00
|
|
|
# Export flag to skip the known bug that exists in librados
|
|
|
|
# Bug is reported on ceph bug tracker with number 24078
|
|
|
|
export ASAN_OPTIONS=new_delete_type_mismatch=0
|
|
|
|
|
2017-08-09 14:55:17 -07:00
|
|
|
PS4=' \t \$ '
|
2015-09-21 08:52:41 -07:00
|
|
|
ulimit -c unlimited
|
|
|
|
|
2018-01-04 10:08:03 -07:00
|
|
|
: ${RUN_NIGHTLY:=0}
|
|
|
|
export RUN_NIGHTLY
|
2016-03-23 13:34:31 -07:00
|
|
|
|
2018-03-15 19:40:13 +01:00
|
|
|
: ${RUN_NIGHTLY_FAILING:=0}
|
|
|
|
export RUN_NIGHTLY_FAILING
|
|
|
|
|
2017-05-01 17:34:15 -07:00
|
|
|
if [[ ! -z $1 ]]; then
|
|
|
|
if [ -f $1 ]; then
|
|
|
|
source $1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2018-04-25 10:00:20 -07:00
|
|
|
# If certain utilities are not installed, preemptively disable the tests
|
|
|
|
if ! hash ceph; then
|
|
|
|
SPDK_TEST_RBD=0
|
|
|
|
fi
|
|
|
|
|
|
|
|
if ! hash pmempool; then
|
|
|
|
SPDK_TEST_PMDK=0
|
|
|
|
fi
|
|
|
|
|
2017-05-01 17:34:15 -07:00
|
|
|
# Set defaults for missing test config options
|
2017-05-01 17:38:42 -07:00
|
|
|
: ${SPDK_BUILD_DOC=1}; export SPDK_BUILD_DOC
|
2018-09-06 13:35:25 -07:00
|
|
|
: ${SPDK_BUILD_SHARED_OBJECT=1}; export SPDK_BUILD_SHARED_OBJECT
|
2017-06-29 14:38:10 -07:00
|
|
|
: ${SPDK_RUN_CHECK_FORMAT=1}; export SPDK_RUN_CHECK_FORMAT
|
2017-05-31 16:48:02 -07:00
|
|
|
: ${SPDK_RUN_SCANBUILD=1}; export SPDK_RUN_SCANBUILD
|
|
|
|
: ${SPDK_RUN_VALGRIND=1}; export SPDK_RUN_VALGRIND
|
2017-05-24 09:25:45 -07:00
|
|
|
: ${SPDK_TEST_UNITTEST=1}; export SPDK_TEST_UNITTEST
|
2017-05-01 17:34:15 -07:00
|
|
|
: ${SPDK_TEST_ISCSI=1}; export SPDK_TEST_ISCSI
|
2018-03-16 19:49:11 +08:00
|
|
|
: ${SPDK_TEST_ISCSI_INITIATOR=1}; export SPDK_TEST_ISCSI_INITIATOR
|
2017-05-01 17:34:15 -07:00
|
|
|
: ${SPDK_TEST_NVME=1}; export SPDK_TEST_NVME
|
2018-07-10 09:32:30 -07:00
|
|
|
: ${SPDK_TEST_NVME_CLI=1}; export SPDK_TEST_NVME_CLI
|
2017-05-01 17:34:15 -07:00
|
|
|
: ${SPDK_TEST_NVMF=1}; export SPDK_TEST_NVMF
|
2017-07-19 16:22:38 -07:00
|
|
|
: ${SPDK_TEST_RBD=1}; export SPDK_TEST_RBD
|
2017-05-01 17:34:15 -07:00
|
|
|
: ${SPDK_TEST_VHOST=1}; export SPDK_TEST_VHOST
|
|
|
|
: ${SPDK_TEST_BLOCKDEV=1}; export SPDK_TEST_BLOCKDEV
|
|
|
|
: ${SPDK_TEST_IOAT=1}; export SPDK_TEST_IOAT
|
|
|
|
: ${SPDK_TEST_EVENT=1}; export SPDK_TEST_EVENT
|
|
|
|
: ${SPDK_TEST_BLOBFS=1}; export SPDK_TEST_BLOBFS
|
2018-02-23 10:30:59 -05:00
|
|
|
: ${SPDK_TEST_VHOST_INIT=1}; export SPDK_TEST_VHOST_INIT
|
2018-04-03 16:07:39 -07:00
|
|
|
: ${SPDK_TEST_PMDK=1}; export SPDK_TEST_PMDK
|
2017-10-23 17:03:18 +02:00
|
|
|
: ${SPDK_TEST_LVOL=1}; export SPDK_TEST_LVOL
|
2018-07-25 21:32:05 -04:00
|
|
|
: ${SPDK_TEST_JSON=1}; export SPDK_TEST_JSON
|
2017-08-08 15:58:45 -07:00
|
|
|
: ${SPDK_RUN_ASAN=1}; export SPDK_RUN_ASAN
|
2017-06-29 16:11:35 -07:00
|
|
|
: ${SPDK_RUN_UBSAN=1}; export SPDK_RUN_UBSAN
|
2018-09-04 12:32:17 -07:00
|
|
|
: ${SPDK_RUN_INSTALLED_DPDK=1}; export SPDK_RUN_INSTALLED_DPDK
|
2018-03-07 16:44:06 -07:00
|
|
|
: ${SPDK_TEST_CRYPTO=1}; export SPDK_TEST_CRYPTO
|
2017-05-01 17:34:15 -07:00
|
|
|
|
2018-06-22 02:16:10 -07:00
|
|
|
if [ -z "$DEPENDENCY_DIR" ]; then
|
|
|
|
export DEPENDENCY_DIR=/home/sys_sgsw
|
|
|
|
else
|
|
|
|
export DEPENDENCY_DIR
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ ! -z "$HUGEMEM" ]; then
|
|
|
|
export HUGEMEM
|
|
|
|
fi
|
|
|
|
|
2017-07-11 09:56:52 -07:00
|
|
|
# pass our valgrind desire on to unittest.sh
|
|
|
|
if [ $SPDK_RUN_VALGRIND -eq 0 ]; then
|
|
|
|
export valgrind=''
|
|
|
|
fi
|
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
config_params='--enable-debug --enable-werror'
|
2015-10-22 11:26:21 -07:00
|
|
|
|
2018-07-18 21:08:17 +02:00
|
|
|
if echo -e "#include <libunwind.h>\nint main(int argc, char *argv[]) {return 0;}\n" | \
|
|
|
|
gcc -o /dev/null -lunwind -x c - 2>/dev/null; then
|
|
|
|
config_params+=' --enable-log-bt=ERROR'
|
|
|
|
fi
|
|
|
|
|
2018-07-27 11:59:14 -07:00
|
|
|
# RAID is marked experimental and not built by default currently, since it does not
|
|
|
|
# support iov (meaning vhost will not work). But enable it in the build here, to make
|
|
|
|
# sure it gets built and run against a limited set of use cases for now.
|
|
|
|
config_params+=' --with-raid'
|
|
|
|
|
2018-03-07 16:44:06 -07:00
|
|
|
if [ $SPDK_TEST_CRYPTO -eq 1 ]; then
|
|
|
|
config_params+=' --with-crypto'
|
|
|
|
fi
|
|
|
|
|
2017-03-23 14:15:38 -07:00
|
|
|
export UBSAN_OPTIONS='halt_on_error=1:print_stacktrace=1:abort_on_error=1'
|
2016-11-30 11:20:32 -07:00
|
|
|
|
2018-06-20 01:21:17 -07:00
|
|
|
# On Linux systems, override the default HUGEMEM in scripts/setup.sh to
|
|
|
|
# allocate 8GB in hugepages.
|
|
|
|
# FreeBSD runs a much more limited set of tests, so keep the default 2GB.
|
|
|
|
if [ `uname -s` = "Linux" ]; then
|
|
|
|
export HUGEMEM=8192
|
|
|
|
fi
|
2017-03-06 17:50:39 -07:00
|
|
|
|
2017-11-09 16:33:29 -07:00
|
|
|
DEFAULT_RPC_ADDR=/var/tmp/spdk.sock
|
|
|
|
|
2015-10-02 17:11:56 -07:00
|
|
|
case `uname` in
|
|
|
|
FreeBSD)
|
2017-05-08 15:07:13 -07:00
|
|
|
DPDK_FREEBSD_DIR=/usr/local/share/dpdk/x86_64-native-bsdapp-clang
|
2018-09-04 12:32:17 -07:00
|
|
|
if [ -d $DPDK_FREEBSD_DIR ] && [ $SPDK_RUN_INSTALLED_DPDK -eq 1 ]; then
|
2017-05-08 15:07:13 -07:00
|
|
|
WITH_DPDK_DIR=$DPDK_FREEBSD_DIR
|
|
|
|
fi
|
2015-10-02 17:11:56 -07:00
|
|
|
MAKE=gmake
|
2015-12-31 10:28:18 -07:00
|
|
|
MAKEFLAGS=${MAKEFLAGS:--j$(sysctl -a | egrep -i 'hw.ncpu' | awk '{print $2}')}
|
2017-12-18 17:01:45 -07:00
|
|
|
SPDK_RUN_ASAN=0
|
|
|
|
SPDK_RUN_UBSAN=0
|
2015-10-02 17:11:56 -07:00
|
|
|
;;
|
|
|
|
Linux)
|
2018-09-04 12:32:17 -07:00
|
|
|
DPDK_LINUX_DIR=/usr/share/dpdk/x86_64-default-linuxapp-gcc
|
|
|
|
if [ -d $DPDK_LINUX_DIR ] && [ $SPDK_RUN_INSTALLED_DPDK -eq 1 ]; then
|
2017-05-08 15:07:13 -07:00
|
|
|
WITH_DPDK_DIR=$DPDK_LINUX_DIR
|
|
|
|
fi
|
2015-10-02 17:11:56 -07:00
|
|
|
MAKE=make
|
2015-12-31 10:28:18 -07:00
|
|
|
MAKEFLAGS=${MAKEFLAGS:--j$(nproc)}
|
2017-03-30 12:06:49 -07:00
|
|
|
config_params+=' --enable-coverage'
|
2017-06-29 16:11:35 -07:00
|
|
|
if [ $SPDK_RUN_UBSAN -eq 1 ]; then
|
|
|
|
config_params+=' --enable-ubsan'
|
|
|
|
fi
|
2017-06-12 13:08:19 +08:00
|
|
|
if [ $SPDK_RUN_ASAN -eq 1 ]; then
|
2017-11-15 19:43:15 +01:00
|
|
|
if ldconfig -p | grep -q asan; then
|
2017-06-12 13:08:19 +08:00
|
|
|
config_params+=' --enable-asan'
|
|
|
|
else
|
|
|
|
SPDK_RUN_ASAN=0
|
|
|
|
fi
|
|
|
|
fi
|
2015-10-02 17:11:56 -07:00
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo "Unknown OS in $0"
|
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2017-05-08 15:07:13 -07:00
|
|
|
# By default, --with-dpdk is not set meaning the SPDK build will use the DPDK submodule.
|
|
|
|
# If a DPDK installation is found in a well-known location though, WITH_DPDK_DIR will be
|
|
|
|
# set which will override the default and use that DPDK installation instead.
|
|
|
|
if [ ! -z "$WITH_DPDK_DIR" ]; then
|
|
|
|
config_params+=" --with-dpdk=$WITH_DPDK_DIR"
|
|
|
|
fi
|
|
|
|
|
2016-06-06 14:44:30 -07:00
|
|
|
if [ -f /usr/include/infiniband/verbs.h ]; then
|
2017-03-30 12:06:49 -07:00
|
|
|
config_params+=' --with-rdma'
|
2016-06-06 14:44:30 -07:00
|
|
|
fi
|
|
|
|
|
2017-09-29 10:49:51 +02:00
|
|
|
if [ -f /usr/include/libpmemblk.h ]; then
|
2018-04-03 16:07:39 -07:00
|
|
|
config_params+=' --with-pmdk'
|
|
|
|
else
|
|
|
|
# PMDK not installed so disable PMDK tests explicitly here
|
|
|
|
SPDK_TEST_PMDK=0; export SPDK_TEST_PMDK
|
2017-09-29 10:49:51 +02:00
|
|
|
fi
|
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
if [ -d /usr/src/fio ]; then
|
|
|
|
config_params+=' --with-fio=/usr/src/fio'
|
|
|
|
fi
|
|
|
|
|
2018-06-22 02:16:10 -07:00
|
|
|
if [ -d ${DEPENDENCY_DIR}/vtune_codes ]; then
|
|
|
|
config_params+=' --with-vtune='${DEPENDENCY_DIR}'/vtune_codes'
|
2017-12-21 04:20:11 +08:00
|
|
|
fi
|
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
if [ -d /usr/include/rbd ] && [ -d /usr/include/rados ]; then
|
|
|
|
config_params+=' --with-rbd'
|
|
|
|
fi
|
|
|
|
|
2017-12-04 10:07:04 -07:00
|
|
|
if [ -d /usr/include/iscsi ]; then
|
|
|
|
libiscsi_version=`grep LIBISCSI_API_VERSION /usr/include/iscsi/iscsi.h | head -1 | awk '{print $3}' | awk -F '(' '{print $2}' | awk -F ')' '{print $1}'`
|
|
|
|
if [ $libiscsi_version -ge 20150621 ]; then
|
|
|
|
config_params+=' --with-iscsi-initiator'
|
2018-03-16 19:49:11 +08:00
|
|
|
else
|
|
|
|
export SPDK_TEST_ISCSI_INITIATOR=0
|
2017-12-04 10:07:04 -07:00
|
|
|
fi
|
2018-03-16 19:49:11 +08:00
|
|
|
else
|
|
|
|
export SPDK_TEST_ISCSI_INITIATOR=0
|
2017-12-04 10:07:04 -07:00
|
|
|
fi
|
2018-03-16 19:49:11 +08:00
|
|
|
|
2018-07-10 09:32:30 -07:00
|
|
|
if [ ! -d "${DEPENDENCY_DIR}/nvme-cli" ]; then
|
|
|
|
export SPDK_TEST_NVME_CLI=0
|
|
|
|
fi
|
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
export config_params
|
|
|
|
|
2015-10-08 17:22:39 -07:00
|
|
|
if [ -z "$output_dir" ]; then
|
|
|
|
if [ -z "$rootdir" ] || [ ! -d "$rootdir/../output" ]; then
|
|
|
|
output_dir=.
|
|
|
|
else
|
|
|
|
output_dir=$rootdir/../output
|
|
|
|
fi
|
|
|
|
export output_dir
|
2015-09-21 08:52:41 -07:00
|
|
|
fi
|
|
|
|
|
|
|
|
function timing() {
|
|
|
|
direction="$1"
|
|
|
|
testname="$2"
|
|
|
|
|
|
|
|
now=$(date +%s)
|
|
|
|
|
|
|
|
if [ "$direction" = "enter" ]; then
|
2015-10-08 12:40:44 -07:00
|
|
|
export timing_stack="${timing_stack};${now}"
|
|
|
|
export test_stack="${test_stack};${testname}"
|
2015-09-21 08:52:41 -07:00
|
|
|
else
|
2015-10-08 12:40:44 -07:00
|
|
|
child_time=$(grep "^${test_stack:1};" $output_dir/timing.txt | awk '{s+=$2} END {print s}')
|
2015-09-21 08:52:41 -07:00
|
|
|
|
2015-10-08 12:40:44 -07:00
|
|
|
start_time=$(echo "$timing_stack" | sed -e 's@^.*;@@')
|
|
|
|
timing_stack=$(echo "$timing_stack" | sed -e 's@;[^;]*$@@')
|
2015-09-21 08:52:41 -07:00
|
|
|
|
2015-10-08 12:40:44 -07:00
|
|
|
elapsed=$((now - start_time - child_time))
|
|
|
|
echo "${test_stack:1} $elapsed" >> $output_dir/timing.txt
|
|
|
|
|
|
|
|
test_stack=$(echo "$test_stack" | sed -e 's@;[^;]*$@@')
|
2015-09-21 08:52:41 -07:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
function timing_enter() {
|
2016-12-02 11:26:28 -07:00
|
|
|
set +x
|
2015-09-21 08:52:41 -07:00
|
|
|
timing "enter" "$1"
|
2016-12-02 11:26:28 -07:00
|
|
|
set -x
|
2015-09-21 08:52:41 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
function timing_exit() {
|
2016-12-02 11:26:28 -07:00
|
|
|
set +x
|
2015-09-21 08:52:41 -07:00
|
|
|
timing "exit" "$1"
|
2016-12-02 11:26:28 -07:00
|
|
|
set -x
|
2015-09-21 08:52:41 -07:00
|
|
|
}
|
|
|
|
|
2015-10-08 12:40:44 -07:00
|
|
|
function timing_finish() {
|
|
|
|
flamegraph='/usr/local/FlameGraph/flamegraph.pl'
|
|
|
|
if [ -x "$flamegraph" ]; then
|
|
|
|
"$flamegraph" \
|
|
|
|
--title 'Build Timing' \
|
|
|
|
--nametype 'Step:' \
|
|
|
|
--countname seconds \
|
|
|
|
$output_dir/timing.txt \
|
|
|
|
>$output_dir/timing.svg
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2017-12-18 14:20:41 -07:00
|
|
|
function create_test_list() {
|
|
|
|
grep -rsh --exclude="autotest_common.sh" --exclude="$rootdir/test/common/autotest_common.sh" -e "report_test_completion" $rootdir | sed 's/report_test_completion//g; s/[[:blank:]]//g; s/"//g;' > $output_dir/all_tests.txt || true
|
|
|
|
}
|
|
|
|
|
|
|
|
function report_test_completion() {
|
|
|
|
echo "$1" >> $output_dir/test_completions.txt
|
|
|
|
}
|
|
|
|
|
2015-09-21 08:52:41 -07:00
|
|
|
function process_core() {
|
|
|
|
ret=0
|
2017-03-21 11:22:11 -07:00
|
|
|
for core in $(find . -type f \( -name 'core*' -o -name '*.core' \)); do
|
2015-12-02 13:10:54 -07:00
|
|
|
exe=$(eu-readelf -n "$core" | grep psargs | sed "s/.*psargs: \([^ \'\" ]*\).*/\1/")
|
2018-08-02 13:34:59 +02:00
|
|
|
if [[ ! -f "$exe" ]]; then
|
|
|
|
exe=$(eu-readelf -n "$core" | grep -oP -m1 "$exe.+")
|
|
|
|
fi
|
2015-09-21 08:52:41 -07:00
|
|
|
echo "exe for $core is $exe"
|
|
|
|
if [[ ! -z "$exe" ]]; then
|
|
|
|
if hash gdb; then
|
2017-06-06 16:13:29 -07:00
|
|
|
gdb -batch -ex "thread apply all bt full" $exe $core
|
2015-09-21 08:52:41 -07:00
|
|
|
fi
|
|
|
|
cp $exe $output_dir
|
|
|
|
fi
|
|
|
|
mv $core $output_dir
|
|
|
|
chmod a+r $output_dir/$core
|
|
|
|
ret=1
|
|
|
|
done
|
|
|
|
return $ret
|
|
|
|
}
|
|
|
|
|
2018-09-10 09:32:09 +02:00
|
|
|
function process_shm() {
|
|
|
|
type=$1
|
|
|
|
id=$2
|
|
|
|
if [ "$type" = "--pid" ]; then
|
|
|
|
id="pid${id}"
|
|
|
|
elif [ "$type" = "--id" ]; then
|
|
|
|
id="${id}"
|
|
|
|
else
|
|
|
|
echo "Please specify to search for pid or shared memory id."
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
shm_files=$(find /dev/shm -name "*.${id}" -printf "%f\n")
|
|
|
|
|
|
|
|
if [[ -z $shm_files ]]; then
|
|
|
|
echo "SHM File for specified PID or shared memory id: ${id} not found!"
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
for n in $shm_files; do
|
|
|
|
tar -C /dev/shm/ -cvzf $output_dir/${n}_shm.tar.gz ${n}
|
|
|
|
done
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2016-08-03 14:37:16 -07:00
|
|
|
function waitforlisten() {
|
2017-11-09 16:33:29 -07:00
|
|
|
# $1 = process pid
|
|
|
|
if [ -z "$1" ]; then
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2017-11-20 10:54:53 -07:00
|
|
|
rpc_addr="${2:-$DEFAULT_RPC_ADDR}"
|
|
|
|
|
|
|
|
echo "Waiting for process to start up and listen on UNIX domain socket $rpc_addr..."
|
2017-11-09 16:33:29 -07:00
|
|
|
# turn off trace for this loop
|
|
|
|
set +x
|
|
|
|
ret=1
|
|
|
|
while [ $ret -ne 0 ]; do
|
|
|
|
# if the process is no longer running, then exit the script
|
|
|
|
# since it means the application crashed
|
|
|
|
if ! kill -s 0 $1; then
|
2018-03-07 19:27:02 +01:00
|
|
|
exit 1
|
2017-11-09 16:33:29 -07:00
|
|
|
fi
|
2018-04-25 12:16:08 -04:00
|
|
|
|
|
|
|
namespace=$(ip netns identify $1)
|
|
|
|
if [ -n "$namespace" ]; then
|
|
|
|
ns_cmd="ip netns exec $namespace"
|
|
|
|
fi
|
|
|
|
|
2018-04-04 12:47:52 -07:00
|
|
|
if hash ss; then
|
2018-04-25 12:16:08 -04:00
|
|
|
if $ns_cmd ss -lx | grep -q $rpc_addr; then
|
2018-04-04 12:47:52 -07:00
|
|
|
ret=0
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
# if system doesn't have ss, just assume it has netstat
|
2018-04-25 12:16:08 -04:00
|
|
|
if $ns_cmd netstat -an -x | grep -iw LISTENING | grep -q $rpc_addr; then
|
2018-04-04 12:47:52 -07:00
|
|
|
ret=0
|
|
|
|
fi
|
2016-08-03 14:37:16 -07:00
|
|
|
fi
|
|
|
|
done
|
|
|
|
set -x
|
|
|
|
}
|
|
|
|
|
2017-11-03 11:22:05 -07:00
|
|
|
function waitfornbd() {
|
|
|
|
nbd_name=$1
|
2017-07-06 10:41:57 +08:00
|
|
|
|
2017-11-03 11:22:05 -07:00
|
|
|
for ((i=1; i<=20; i++)); do
|
|
|
|
if grep -q -w $nbd_name /proc/partitions; then
|
2017-11-06 11:33:48 -07:00
|
|
|
break
|
|
|
|
else
|
|
|
|
sleep 0.1
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
# The nbd device is now recognized as a block device, but there can be
|
|
|
|
# a small delay before we can start I/O to that block device. So loop
|
|
|
|
# here trying to read the first block of the nbd block device to a temp
|
|
|
|
# file. Note that dd returns success when reading an empty file, so we
|
|
|
|
# need to check the size of the output file instead.
|
|
|
|
for ((i=1; i<=20; i++)); do
|
|
|
|
dd if=/dev/$nbd_name of=/tmp/nbdtest bs=4096 count=1 iflag=direct
|
|
|
|
size=`stat -c %s /tmp/nbdtest`
|
|
|
|
rm -f /tmp/nbdtest
|
|
|
|
if [ "$size" != "0" ]; then
|
2017-07-06 10:41:57 +08:00
|
|
|
return 0
|
|
|
|
else
|
|
|
|
sleep 0.1
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
2016-06-07 08:49:44 -07:00
|
|
|
function killprocess() {
|
|
|
|
# $1 = process pid
|
|
|
|
if [ -z "$1" ]; then
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2018-09-12 09:58:28 +02:00
|
|
|
if kill -0 $1; then
|
|
|
|
echo "killing process with pid $1"
|
|
|
|
kill $1
|
|
|
|
wait $1
|
|
|
|
fi
|
2016-06-07 08:49:44 -07:00
|
|
|
}
|
2016-07-21 15:54:23 -07:00
|
|
|
|
2016-08-03 14:37:16 -07:00
|
|
|
function iscsicleanup() {
|
|
|
|
echo "Cleaning up iSCSI connection"
|
|
|
|
iscsiadm -m node --logout || true
|
|
|
|
iscsiadm -m node -o delete || true
|
|
|
|
}
|
|
|
|
|
|
|
|
function stop_iscsi_service() {
|
|
|
|
if cat /etc/*-release | grep Ubuntu; then
|
|
|
|
service open-iscsi stop
|
|
|
|
else
|
|
|
|
service iscsid stop
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
function start_iscsi_service() {
|
|
|
|
if cat /etc/*-release | grep Ubuntu; then
|
|
|
|
service open-iscsi start
|
|
|
|
else
|
|
|
|
service iscsid start
|
|
|
|
fi
|
|
|
|
}
|
2016-10-06 09:57:09 -07:00
|
|
|
|
2016-11-16 11:18:40 -07:00
|
|
|
function rbd_setup() {
|
2018-04-16 09:12:23 -04:00
|
|
|
# $1 = monitor ip address
|
2018-04-25 12:16:08 -04:00
|
|
|
# $2 = name of the namespace
|
2018-04-16 09:12:23 -04:00
|
|
|
if [ -z "$1" ]; then
|
|
|
|
echo "No monitor IP address provided for ceph"
|
|
|
|
exit 1
|
|
|
|
fi
|
2018-04-25 12:16:08 -04:00
|
|
|
if [ -n "$2" ]; then
|
|
|
|
if ip netns list | grep "$2"; then
|
|
|
|
NS_CMD="ip netns exec $2"
|
|
|
|
else
|
|
|
|
echo "No namespace $2 exists"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
2018-04-16 09:12:23 -04:00
|
|
|
|
2017-08-08 17:21:24 -07:00
|
|
|
if hash ceph; then
|
2018-03-28 14:47:11 -07:00
|
|
|
export PG_NUM=128
|
2017-07-19 16:22:38 -07:00
|
|
|
export RBD_POOL=rbd
|
|
|
|
export RBD_NAME=foo
|
2018-04-25 12:16:08 -04:00
|
|
|
$NS_CMD $rootdir/scripts/ceph/start.sh $1
|
2018-03-28 14:47:11 -07:00
|
|
|
|
2018-04-25 12:16:08 -04:00
|
|
|
$NS_CMD ceph osd pool create $RBD_POOL $PG_NUM || true
|
|
|
|
$NS_CMD rbd create $RBD_NAME --size 1000
|
2016-11-16 11:18:40 -07:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
function rbd_cleanup() {
|
2017-08-08 17:21:24 -07:00
|
|
|
if hash ceph; then
|
2018-02-27 10:30:22 -07:00
|
|
|
$rootdir/scripts/ceph/stop.sh || true
|
2016-11-16 11:18:40 -07:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2017-05-24 20:58:35 -07:00
|
|
|
function start_stub() {
|
2018-04-16 17:34:01 -07:00
|
|
|
# Disable ASLR for multi-process testing. SPDK does support using DPDK multi-process,
|
2018-06-21 01:15:17 -07:00
|
|
|
# but ASLR can still be unreliable in some cases.
|
|
|
|
# We will reenable it again after multi-process testing is complete in kill_stub()
|
2018-04-16 17:34:01 -07:00
|
|
|
echo 0 > /proc/sys/kernel/randomize_va_space
|
2017-05-24 20:58:35 -07:00
|
|
|
$rootdir/test/app/stub/stub $1 &
|
|
|
|
stubpid=$!
|
|
|
|
echo Waiting for stub to ready for secondary processes...
|
2017-05-25 15:26:18 -07:00
|
|
|
while ! [ -e /var/run/spdk_stub0 ]; do
|
|
|
|
sleep 1s
|
2017-05-24 20:58:35 -07:00
|
|
|
done
|
2018-04-16 16:57:42 -07:00
|
|
|
# dump process memory map contents to help debug random ASLR failures
|
2018-05-18 10:45:36 -07:00
|
|
|
pmap -pX $stubpid || pmap -x $stubpid || true
|
2017-05-24 20:58:35 -07:00
|
|
|
echo done.
|
|
|
|
}
|
|
|
|
|
|
|
|
function kill_stub() {
|
|
|
|
kill $stubpid
|
2017-06-30 07:48:53 -07:00
|
|
|
wait $stubpid
|
2017-06-21 23:30:02 -07:00
|
|
|
rm -f /var/run/spdk_stub0
|
2018-04-16 17:34:01 -07:00
|
|
|
# Re-enable ASLR now that we are done with multi-process testing
|
|
|
|
# Note: "1" enables ASLR w/o randomizing data segments, "2" adds data segment
|
|
|
|
# randomizing and is the default on all recent Linux kernels
|
|
|
|
echo 2 > /proc/sys/kernel/randomize_va_space
|
2017-05-24 20:58:35 -07:00
|
|
|
}
|
|
|
|
|
2016-10-06 09:57:09 -07:00
|
|
|
function run_test() {
|
2016-12-02 11:26:28 -07:00
|
|
|
set +x
|
2018-03-13 13:57:41 +08:00
|
|
|
local test_type="$(echo $1 | tr 'a-z' 'A-Z')"
|
|
|
|
shift
|
2016-10-06 09:57:09 -07:00
|
|
|
echo "************************************"
|
2018-03-13 13:57:41 +08:00
|
|
|
echo "START TEST $test_type $@"
|
2016-10-06 09:57:09 -07:00
|
|
|
echo "************************************"
|
2016-12-02 11:26:28 -07:00
|
|
|
set -x
|
2016-12-07 10:21:23 +08:00
|
|
|
time "$@"
|
2016-12-02 11:26:28 -07:00
|
|
|
set +x
|
2016-10-06 09:57:09 -07:00
|
|
|
echo "************************************"
|
2018-03-13 13:57:41 +08:00
|
|
|
echo "END TEST $test_type $@"
|
2016-10-06 09:57:09 -07:00
|
|
|
echo "************************************"
|
2016-12-02 11:26:28 -07:00
|
|
|
set -x
|
2016-10-06 09:57:09 -07:00
|
|
|
}
|
2017-02-20 20:32:49 +01:00
|
|
|
|
|
|
|
function print_backtrace() {
|
2018-08-29 09:01:10 -07:00
|
|
|
# if errexit is not enabled, don't print a backtrace
|
|
|
|
[[ "$-" =~ e ]] || return 0
|
|
|
|
|
2017-11-15 19:43:15 +01:00
|
|
|
local shell_options="$-"
|
2017-02-20 20:32:49 +01:00
|
|
|
set +x
|
|
|
|
echo "========== Backtrace start: =========="
|
|
|
|
echo ""
|
|
|
|
for i in $(seq 1 $((${#FUNCNAME[@]} - 1))); do
|
|
|
|
local func="${FUNCNAME[$i]}"
|
|
|
|
local line_nr="${BASH_LINENO[$((i - 1))]}"
|
2017-10-25 21:32:37 +02:00
|
|
|
local src="${BASH_SOURCE[$i]}"
|
2017-02-20 20:32:49 +01:00
|
|
|
echo "in $src:$line_nr -> $func()"
|
|
|
|
echo " ..."
|
2017-11-15 19:43:15 +01:00
|
|
|
nl -w 4 -ba -nln $src | grep -B 5 -A 5 "^$line_nr[^0-9]" | \
|
2017-03-08 20:46:31 +01:00
|
|
|
sed "s/^/ /g" | sed "s/^ $line_nr /=> $line_nr /g"
|
2017-02-20 20:32:49 +01:00
|
|
|
echo " ..."
|
|
|
|
done
|
|
|
|
echo ""
|
|
|
|
echo "========== Backtrace end =========="
|
2017-11-15 19:43:15 +01:00
|
|
|
[[ "$shell_options" =~ x ]] && set -x
|
2017-02-20 20:32:49 +01:00
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2017-07-17 15:45:46 +08:00
|
|
|
function part_dev_by_gpt () {
|
2018-02-01 11:36:49 -07:00
|
|
|
if [ $(uname -s) = Linux ] && hash sgdisk && modprobe nbd; then
|
2017-07-17 15:45:46 +08:00
|
|
|
conf=$1
|
|
|
|
devname=$2
|
|
|
|
rootdir=$3
|
2017-08-11 15:06:17 -07:00
|
|
|
operation=$4
|
2017-12-11 01:56:40 -05:00
|
|
|
local nbd_path=/dev/nbd0
|
|
|
|
local rpc_server=/var/tmp/spdk-gpt-bdevs.sock
|
2017-07-17 15:45:46 +08:00
|
|
|
|
|
|
|
if [ ! -e $conf ]; then
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
2017-08-11 15:06:17 -07:00
|
|
|
if [ -z "$operation" ]; then
|
|
|
|
operation="create"
|
|
|
|
fi
|
|
|
|
|
2017-07-17 15:45:46 +08:00
|
|
|
cp $conf ${conf}.gpt
|
|
|
|
echo "[Gpt]" >> ${conf}.gpt
|
|
|
|
echo " Disable Yes" >> ${conf}.gpt
|
|
|
|
|
2017-12-11 01:56:40 -05:00
|
|
|
$rootdir/test/app/bdev_svc/bdev_svc -r $rpc_server -i 0 -c ${conf}.gpt &
|
2017-07-17 15:45:46 +08:00
|
|
|
nbd_pid=$!
|
|
|
|
echo "Process nbd pid: $nbd_pid"
|
2017-12-11 01:56:40 -05:00
|
|
|
waitforlisten $nbd_pid $rpc_server
|
|
|
|
|
|
|
|
# Start bdev as a nbd device
|
|
|
|
$rootdir/scripts/rpc.py -s "$rpc_server" start_nbd_disk $devname $nbd_path
|
|
|
|
|
|
|
|
waitfornbd ${nbd_path:5}
|
2017-11-03 11:22:05 -07:00
|
|
|
|
|
|
|
if [ "$operation" = create ]; then
|
2017-12-11 01:56:40 -05:00
|
|
|
parted -s $nbd_path mklabel gpt mkpart first '0%' '50%' mkpart second '50%' '100%'
|
2017-11-29 09:18:30 -07:00
|
|
|
|
2017-11-03 11:22:05 -07:00
|
|
|
# change the GUID to SPDK GUID value
|
2017-11-29 09:18:30 -07:00
|
|
|
SPDK_GPT_GUID=`grep SPDK_GPT_PART_TYPE_GUID $rootdir/lib/bdev/gpt/gpt.h \
|
|
|
|
| awk -F "(" '{ print $2}' | sed 's/)//g' \
|
|
|
|
| awk -F ", " '{ print $1 "-" $2 "-" $3 "-" $4 "-" $5}' | sed 's/0x//g'`
|
2017-12-11 01:56:40 -05:00
|
|
|
sgdisk -t 1:$SPDK_GPT_GUID $nbd_path
|
|
|
|
sgdisk -t 2:$SPDK_GPT_GUID $nbd_path
|
2017-11-03 11:22:05 -07:00
|
|
|
elif [ "$operation" = reset ]; then
|
|
|
|
# clear the partition table
|
2017-12-11 01:56:40 -05:00
|
|
|
dd if=/dev/zero of=$nbd_path bs=4096 count=8 oflag=direct
|
2017-07-17 15:45:46 +08:00
|
|
|
fi
|
2017-11-03 11:22:05 -07:00
|
|
|
|
2018-07-23 10:39:50 +09:00
|
|
|
$rootdir/scripts/rpc.py -s "$rpc_server" stop_nbd_disk $nbd_path
|
|
|
|
|
2017-07-17 15:45:46 +08:00
|
|
|
killprocess $nbd_pid
|
|
|
|
rm -f ${conf}.gpt
|
|
|
|
fi
|
|
|
|
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2017-07-20 07:11:47 -07:00
|
|
|
function discover_bdevs()
|
|
|
|
{
|
|
|
|
local rootdir=$1
|
|
|
|
local config_file=$2
|
2017-12-04 14:30:34 -07:00
|
|
|
local rpc_server=/var/tmp/spdk-discover-bdevs.sock
|
2017-07-20 07:11:47 -07:00
|
|
|
|
|
|
|
if [ ! -e $config_file ]; then
|
|
|
|
echo "Invalid Configuration File: $config_file"
|
|
|
|
return -1
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Start the bdev service to query for the list of available
|
|
|
|
# bdevs.
|
2018-03-19 13:40:58 +01:00
|
|
|
$rootdir/test/app/bdev_svc/bdev_svc -r $rpc_server -i 0 -s 1024 -g \
|
|
|
|
-c $config_file &>/dev/null &
|
2017-07-20 07:11:47 -07:00
|
|
|
stubpid=$!
|
|
|
|
while ! [ -e /var/run/spdk_bdev0 ]; do
|
|
|
|
sleep 1
|
|
|
|
done
|
|
|
|
|
|
|
|
# Get all of the bdevs
|
2017-11-20 10:28:59 -07:00
|
|
|
if [ -z "$rpc_server" ]; then
|
2017-09-12 15:47:30 +02:00
|
|
|
$rootdir/scripts/rpc.py get_bdevs
|
|
|
|
else
|
2017-11-20 10:28:59 -07:00
|
|
|
$rootdir/scripts/rpc.py -s "$rpc_server" get_bdevs
|
2017-09-12 15:47:30 +02:00
|
|
|
fi
|
2017-07-20 07:11:47 -07:00
|
|
|
|
|
|
|
# Shut down the bdev service
|
|
|
|
kill $stubpid
|
|
|
|
wait $stubpid
|
|
|
|
rm -f /var/run/spdk_bdev0
|
|
|
|
}
|
|
|
|
|
2018-04-16 13:28:16 -07:00
|
|
|
function waitforblk()
|
|
|
|
{
|
|
|
|
local i=0
|
|
|
|
while ! lsblk -l -o NAME | grep -q -w $1; do
|
|
|
|
[ $i -lt 15 ] || break
|
|
|
|
i=$[$i+1]
|
|
|
|
sleep 1
|
|
|
|
done
|
|
|
|
|
|
|
|
if ! lsblk -l -o NAME | grep -q -w $1; then
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2017-07-14 16:31:43 -07:00
|
|
|
function fio_config_gen()
|
|
|
|
{
|
|
|
|
local config_file=$1
|
|
|
|
local workload=$2
|
|
|
|
|
|
|
|
if [ -e "$config_file" ]; then
|
|
|
|
echo "Configuration File Already Exists!: $config_file"
|
|
|
|
return -1
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z "$workload" ]; then
|
|
|
|
workload=randrw
|
|
|
|
fi
|
|
|
|
|
|
|
|
touch $1
|
|
|
|
|
|
|
|
cat > $1 << EOL
|
|
|
|
[global]
|
|
|
|
thread=1
|
|
|
|
group_reporting=1
|
|
|
|
direct=1
|
|
|
|
norandommap=1
|
|
|
|
percentile_list=50:99:99.9:99.99:99.999
|
|
|
|
time_based=1
|
|
|
|
ramp_time=0
|
|
|
|
EOL
|
|
|
|
|
|
|
|
if [ "$workload" == "verify" ]; then
|
|
|
|
echo "verify=sha1" >> $config_file
|
|
|
|
echo "rw=randwrite" >> $config_file
|
2017-07-19 14:55:03 -07:00
|
|
|
elif [ "$workload" == "trim" ]; then
|
|
|
|
echo "rw=trimwrite" >> $config_file
|
2017-07-14 16:31:43 -07:00
|
|
|
else
|
|
|
|
echo "rw=$workload" >> $config_file
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
function fio_config_add_job()
|
|
|
|
{
|
|
|
|
config_file=$1
|
|
|
|
filename=$2
|
|
|
|
|
|
|
|
if [ ! -e "$config_file" ]; then
|
|
|
|
echo "Configuration File Doesn't Exist: $config_file"
|
|
|
|
return -1
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z "$filename" ]; then
|
|
|
|
echo "No filename provided"
|
|
|
|
return -1
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "[job_$filename]" >> $config_file
|
|
|
|
echo "filename=$filename" >> $config_file
|
|
|
|
}
|
|
|
|
|
2017-12-08 15:56:31 +01:00
|
|
|
function get_lvs_free_mb()
|
|
|
|
{
|
|
|
|
local lvs_uuid=$1
|
|
|
|
local lvs_info=$($rpc_py get_lvol_stores)
|
|
|
|
local fc=$(jq ".[] | select(.uuid==\"$lvs_uuid\") .free_clusters" <<< "$lvs_info")
|
|
|
|
local cs=$(jq ".[] | select(.uuid==\"$lvs_uuid\") .cluster_size" <<< "$lvs_info")
|
|
|
|
|
|
|
|
# Change to MB's
|
|
|
|
free_mb=$((fc*cs/1024/1024))
|
|
|
|
echo "$free_mb"
|
|
|
|
}
|
|
|
|
|
|
|
|
function get_bdev_size()
|
|
|
|
{
|
|
|
|
local bdev_name=$1
|
|
|
|
local bdev_info=$($rpc_py get_bdevs -b $bdev_name)
|
|
|
|
local bs=$(jq ".[] .block_size" <<< "$bdev_info")
|
|
|
|
local nb=$(jq ".[] .num_blocks" <<< "$bdev_info")
|
|
|
|
|
|
|
|
# Change to MB's
|
|
|
|
bdev_size=$((bs*nb/1024/1024))
|
|
|
|
echo "$bdev_size"
|
|
|
|
}
|
|
|
|
|
2018-02-28 09:42:12 -07:00
|
|
|
function autotest_cleanup()
|
|
|
|
{
|
|
|
|
$rootdir/scripts/setup.sh reset
|
2018-09-10 09:32:09 +02:00
|
|
|
$rootdir/scripts/setup.sh cleanup
|
2018-02-28 09:42:12 -07:00
|
|
|
}
|
|
|
|
|
2018-04-26 16:46:08 -07:00
|
|
|
function freebsd_update_contigmem_mod()
|
|
|
|
{
|
|
|
|
if [ `uname` = FreeBSD ]; then
|
|
|
|
kldunload contigmem.ko || true
|
|
|
|
cp -f $rootdir/dpdk/build/kmod/contigmem.ko /boot/modules/
|
|
|
|
cp -f $rootdir/dpdk/build/kmod/contigmem.ko /boot/kernel/
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2017-02-20 20:32:49 +01:00
|
|
|
set -o errtrace
|
|
|
|
trap "trap - ERR; print_backtrace >&2" ERR
|