2017-07-25 10:27:43 +00:00
|
|
|
#!/usr/bin/env bash
|
2022-11-02 15:49:40 +00:00
|
|
|
# SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
# Copyright (C) 2017 Intel Corporation
|
|
|
|
# All rights reserved.
|
|
|
|
#
|
2019-05-10 17:54:24 +00:00
|
|
|
testdir=$(readlink -f $(dirname $0))
|
|
|
|
rootdir=$(readlink -f $testdir/../../..)
|
|
|
|
source $rootdir/test/common/autotest_common.sh
|
|
|
|
source $rootdir/test/vhost/common.sh
|
|
|
|
source $rootdir/scripts/common.sh
|
2018-01-02 21:44:48 +00:00
|
|
|
|
2019-06-04 20:55:21 +00:00
|
|
|
rpc_py="$rootdir/scripts/rpc.py -s $(get_vhost_dir 0)/rpc.sock"
|
2017-07-25 10:27:43 +00:00
|
|
|
|
|
|
|
vm_count=1
|
2017-12-28 16:00:44 +00:00
|
|
|
ctrl_type="spdk_vhost_scsi"
|
2017-07-25 10:27:43 +00:00
|
|
|
use_fs=false
|
2017-09-27 12:11:48 +00:00
|
|
|
distribute_cores=false
|
2017-07-25 10:27:43 +00:00
|
|
|
|
2020-05-07 11:27:06 +00:00
|
|
|
function usage() {
|
|
|
|
[[ -n $2 ]] && (
|
|
|
|
echo "$2"
|
|
|
|
echo ""
|
|
|
|
)
|
|
|
|
echo "Shortcut script for doing automated test"
|
|
|
|
echo "Usage: $(basename $1) [OPTIONS]"
|
|
|
|
echo
|
|
|
|
echo "-h, --help Print help and exit"
|
|
|
|
echo " --fio-bin=PATH Path to FIO binary.;"
|
|
|
|
echo " --vm-count=INT Virtual machines to use in test;"
|
|
|
|
echo " Each VM will get one lvol bdev on each NVMe."
|
|
|
|
echo " Default: 1"
|
|
|
|
echo " --ctrl-type=TYPE Controller type to use for test:"
|
|
|
|
echo " spdk_vhost_scsi - use spdk vhost scsi"
|
|
|
|
echo " spdk_vhost_blk - use spdk vhost block"
|
|
|
|
echo " --thin-provisioning Create lvol bdevs thin provisioned instead of"
|
|
|
|
echo " allocating space up front"
|
|
|
|
echo " --distribute-cores Use custom config file and run vhost controllers"
|
|
|
|
echo " on different CPU cores instead of single core."
|
|
|
|
echo " Default: False"
|
|
|
|
echo "-x set -x for script debug"
|
|
|
|
exit 0
|
2017-07-25 10:27:43 +00:00
|
|
|
}
|
|
|
|
|
2020-05-07 11:27:06 +00:00
|
|
|
function clean_lvol_cfg() {
|
|
|
|
notice "Removing lvol bdevs"
|
|
|
|
for lvol_bdev in "${lvol_bdevs[@]}"; do
|
|
|
|
$rpc_py bdev_lvol_delete $lvol_bdev
|
|
|
|
notice "lvol bdev $lvol_bdev removed"
|
|
|
|
done
|
|
|
|
|
|
|
|
notice "Removing lvol stores"
|
2021-02-24 12:28:21 +00:00
|
|
|
$rpc_py bdev_lvol_delete_lvstore -u "$ls_guid"
|
|
|
|
notice "lvol store $ls_guid removed"
|
2017-12-20 07:54:03 +00:00
|
|
|
}
|
|
|
|
|
2017-07-25 10:27:43 +00:00
|
|
|
while getopts 'xh-:' optchar; do
|
2020-05-07 11:27:06 +00:00
|
|
|
case "$optchar" in
|
|
|
|
-)
|
|
|
|
case "$OPTARG" in
|
|
|
|
help) usage $0 ;;
|
|
|
|
fio-bin=*) fio_bin="--fio-bin=${OPTARG#*=}" ;;
|
|
|
|
vm-count=*) vm_count="${OPTARG#*=}" ;;
|
|
|
|
ctrl-type=*) ctrl_type="${OPTARG#*=}" ;;
|
|
|
|
distribute-cores) distribute_cores=true ;;
|
|
|
|
thin-provisioning) thin=" -t " ;;
|
|
|
|
*) usage $0 "Invalid argument '$OPTARG'" ;;
|
|
|
|
esac
|
|
|
|
;;
|
|
|
|
h) usage $0 ;;
|
|
|
|
x)
|
|
|
|
set -x
|
|
|
|
x="-x"
|
|
|
|
;;
|
|
|
|
*) usage $0 "Invalid argument '$OPTARG'" ;;
|
|
|
|
esac
|
2017-07-25 10:27:43 +00:00
|
|
|
done
|
|
|
|
|
2019-05-17 21:09:40 +00:00
|
|
|
vhosttestinit
|
|
|
|
|
2021-03-05 08:36:20 +00:00
|
|
|
spdk_mask=$vhost_0_reactor_mask
|
2017-09-27 12:11:48 +00:00
|
|
|
if $distribute_cores; then
|
2020-05-07 11:27:06 +00:00
|
|
|
source $testdir/autotest.config
|
2021-03-05 08:36:20 +00:00
|
|
|
# Adjust the mask so vhost runs on separate cpus than qemu instances.
|
|
|
|
# We know that .config sets qemus to run on single cpu so simply take
|
|
|
|
# the next cpu and add some extra.
|
|
|
|
# FIXME: Rewrite this so the config is more aware of what cpu topology
|
|
|
|
# is actually available on the host system.
|
|
|
|
spdk_mask=$((1 << vm_count))
|
|
|
|
((spdk_mask |= 1 << (vm_count + 1)))
|
|
|
|
((spdk_mask |= 1 << (vm_count + 2)))
|
|
|
|
((spdk_mask |= 1 << (vm_count + 3)))
|
|
|
|
spdk_mask=$(printf '0x%x' "$spdk_mask")
|
2017-09-27 12:11:48 +00:00
|
|
|
fi
|
|
|
|
|
2017-12-20 07:54:03 +00:00
|
|
|
trap 'error_exit "${FUNCNAME}" "${LINENO}"' SIGTERM SIGABRT ERR
|
2017-07-25 10:27:43 +00:00
|
|
|
|
|
|
|
vm_kill_all
|
|
|
|
|
2017-12-18 19:45:33 +00:00
|
|
|
notice "running SPDK vhost"
|
2021-03-03 17:34:59 +00:00
|
|
|
vhost_run -n "0" -a "--cpumask $spdk_mask"
|
2017-12-18 19:45:33 +00:00
|
|
|
notice "..."
|
2017-07-25 10:27:43 +00:00
|
|
|
|
2017-12-20 07:54:03 +00:00
|
|
|
trap 'clean_lvol_cfg; error_exit "${FUNCNAME}" "${LINENO}"' SIGTERM SIGABRT ERR
|
|
|
|
|
2017-07-25 10:27:43 +00:00
|
|
|
lvol_bdevs=()
|
|
|
|
used_vms=""
|
|
|
|
|
2021-02-24 12:28:21 +00:00
|
|
|
id=0
|
|
|
|
# Create base lvol store on NVMe
|
|
|
|
notice "Creating lvol store on device Nvme${id}n1"
|
|
|
|
ls_guid=$($rpc_py bdev_lvol_create_lvstore Nvme0n1 lvs_$id -c 4194304)
|
|
|
|
# Create base lvol bdevs
|
|
|
|
for ((j = 0; j < vm_count; j++)); do
|
|
|
|
notice "Creating lvol bdev for VM $id on lvol store $ls_guid"
|
|
|
|
free_mb=$(get_lvs_free_mb "$ls_guid")
|
|
|
|
size=$((free_mb / (vm_count - j)))
|
|
|
|
lb_name=$($rpc_py bdev_lvol_create -u $ls_guid lbd_vm_$j $size $thin)
|
|
|
|
lvol_bdevs+=("$lb_name")
|
2017-12-08 14:56:31 +00:00
|
|
|
done
|
2017-07-25 10:27:43 +00:00
|
|
|
|
2019-09-11 09:29:55 +00:00
|
|
|
bdev_info=$($rpc_py bdev_get_bdevs)
|
2017-12-18 19:45:33 +00:00
|
|
|
notice "Configuration after initial set-up:"
|
2019-08-26 11:54:05 +00:00
|
|
|
$rpc_py bdev_lvol_get_lvstores
|
2017-12-08 14:56:31 +00:00
|
|
|
echo "$bdev_info"
|
|
|
|
|
|
|
|
# Set up VMs
|
2020-05-07 11:27:06 +00:00
|
|
|
for ((i = 0; i < vm_count; i++)); do
|
|
|
|
vm="vm_$i"
|
2017-12-08 14:56:31 +00:00
|
|
|
|
2020-05-07 11:27:06 +00:00
|
|
|
# Get all lvol bdevs associated with this VM number
|
|
|
|
bdevs=$(jq -r "map(select(.aliases[] | contains(\"$vm\")) | \
|
2018-01-10 10:02:27 +00:00
|
|
|
.aliases[]) | join(\" \")" <<< "$bdev_info")
|
2020-05-07 11:27:06 +00:00
|
|
|
bdevs=($bdevs)
|
|
|
|
|
|
|
|
setup_cmd="vm_setup --disk-type=$ctrl_type --force=$i"
|
2021-02-24 10:09:41 +00:00
|
|
|
setup_cmd+=" --os=$VM_IMAGE"
|
2020-05-07 11:27:06 +00:00
|
|
|
|
|
|
|
# Create single SCSI controller or multiple BLK controllers for this VM
|
2021-03-05 08:36:20 +00:00
|
|
|
mask_arg="--cpumask $spdk_mask"
|
2020-05-07 11:27:06 +00:00
|
|
|
|
|
|
|
if [[ "$ctrl_type" == "spdk_vhost_scsi" ]]; then
|
|
|
|
$rpc_py vhost_create_scsi_controller naa.0.$i $mask_arg
|
|
|
|
for ((j = 0; j < ${#bdevs[@]}; j++)); do
|
|
|
|
$rpc_py vhost_scsi_controller_add_target naa.0.$i $j ${bdevs[$j]}
|
|
|
|
done
|
|
|
|
setup_cmd+=" --disks=0"
|
|
|
|
elif [[ "$ctrl_type" == "spdk_vhost_blk" ]]; then
|
|
|
|
disk=""
|
|
|
|
for ((j = 0; j < ${#bdevs[@]}; j++)); do
|
|
|
|
$rpc_py vhost_create_blk_controller naa.$j.$i ${bdevs[$j]} $mask_arg
|
|
|
|
disk+="${j}:"
|
|
|
|
done
|
|
|
|
disk="${disk::-1}"
|
|
|
|
setup_cmd+=" --disks=$disk"
|
|
|
|
fi
|
|
|
|
|
|
|
|
$setup_cmd
|
|
|
|
used_vms+=" $i"
|
2017-07-25 10:27:43 +00:00
|
|
|
done
|
|
|
|
|
2019-09-30 12:00:12 +00:00
|
|
|
$rpc_py vhost_get_controllers
|
2017-07-25 10:27:43 +00:00
|
|
|
|
|
|
|
# Run VMs
|
2017-12-28 15:24:44 +00:00
|
|
|
vm_run $used_vms
|
2019-03-25 13:14:55 +00:00
|
|
|
vm_wait_for_boot 300 $used_vms
|
2017-07-25 10:27:43 +00:00
|
|
|
|
|
|
|
# Get disk names from VMs and run FIO traffic
|
|
|
|
|
2017-12-15 15:11:02 +00:00
|
|
|
fio_disks=""
|
2017-07-25 10:27:43 +00:00
|
|
|
for vm_num in $used_vms; do
|
2020-05-07 11:27:06 +00:00
|
|
|
qemu_mask_param="VM_${vm_num}_qemu_mask"
|
2017-07-25 10:27:43 +00:00
|
|
|
|
2020-05-07 11:27:06 +00:00
|
|
|
host_name="VM-$vm_num-${!qemu_mask_param}"
|
|
|
|
vm_exec $vm_num "hostname $host_name"
|
|
|
|
vm_start_fio_server $fio_bin $vm_num
|
2017-07-25 10:27:43 +00:00
|
|
|
|
2020-05-07 11:27:06 +00:00
|
|
|
if [[ "$ctrl_type" == "spdk_vhost_scsi" ]]; then
|
|
|
|
vm_check_scsi_location $vm_num
|
|
|
|
elif [[ "$ctrl_type" == "spdk_vhost_blk" ]]; then
|
|
|
|
vm_check_blk_location $vm_num
|
|
|
|
fi
|
2017-07-25 10:27:43 +00:00
|
|
|
|
2020-05-07 11:27:06 +00:00
|
|
|
fio_disks+=" --vm=${vm_num}$(printf ':/dev/%s' $SCSI_DISK)"
|
2017-07-25 10:27:43 +00:00
|
|
|
done
|
|
|
|
|
2017-11-27 16:47:15 +00:00
|
|
|
if [[ $RUN_NIGHTLY -eq 1 ]]; then
|
2020-05-07 11:27:06 +00:00
|
|
|
job_file="default_integrity_nightly.job"
|
2017-11-27 16:47:15 +00:00
|
|
|
else
|
2020-05-07 11:27:06 +00:00
|
|
|
job_file="default_integrity.job"
|
2017-11-27 16:47:15 +00:00
|
|
|
fi
|
2017-07-25 10:27:43 +00:00
|
|
|
# Run FIO traffic
|
2019-06-04 20:29:27 +00:00
|
|
|
run_fio $fio_bin --job-file=$rootdir/test/vhost/common/fio_jobs/$job_file --out="$VHOST_DIR/fio_results" $fio_disks
|
2017-07-25 10:27:43 +00:00
|
|
|
|
2017-12-18 19:45:33 +00:00
|
|
|
notice "Shutting down virtual machines..."
|
2017-07-25 10:27:43 +00:00
|
|
|
vm_shutdown_all
|
|
|
|
sleep 2
|
|
|
|
|
2017-12-18 19:45:33 +00:00
|
|
|
notice "Cleaning up vhost - remove LUNs, controllers, lvol bdevs and lvol stores"
|
2017-12-28 16:00:44 +00:00
|
|
|
if [[ "$ctrl_type" == "spdk_vhost_scsi" ]]; then
|
2020-05-07 11:27:06 +00:00
|
|
|
for ((i = 0; i < vm_count; i++)); do
|
|
|
|
notice "Removing devices from vhost SCSI controller naa.0.$i"
|
|
|
|
for ((j = 0; j < ${#bdevs[@]}; j++)); do
|
|
|
|
$rpc_py vhost_scsi_controller_remove_target naa.0.$i $j
|
|
|
|
notice "Removed device $j"
|
|
|
|
done
|
|
|
|
notice "Removing vhost SCSI controller naa.0.$i"
|
|
|
|
$rpc_py vhost_delete_controller naa.0.$i
|
|
|
|
done
|
2017-12-28 16:00:44 +00:00
|
|
|
elif [[ "$ctrl_type" == "spdk_vhost_blk" ]]; then
|
2020-05-07 11:27:06 +00:00
|
|
|
for ((i = 0; i < vm_count; i++)); do
|
|
|
|
for ((j = 0; j < ${#bdevs[@]}; j++)); do
|
|
|
|
notice "Removing vhost BLK controller naa.$j.$i"
|
|
|
|
$rpc_py vhost_delete_controller naa.$j.$i
|
|
|
|
notice "Removed naa.$j.$i"
|
|
|
|
done
|
|
|
|
done
|
2017-07-25 10:27:43 +00:00
|
|
|
fi
|
|
|
|
|
2017-12-20 07:54:03 +00:00
|
|
|
clean_lvol_cfg
|
2017-07-25 10:27:43 +00:00
|
|
|
|
2019-08-26 11:54:05 +00:00
|
|
|
$rpc_py bdev_lvol_get_lvstores
|
2019-09-11 09:29:55 +00:00
|
|
|
$rpc_py bdev_get_bdevs
|
2019-09-30 12:00:12 +00:00
|
|
|
$rpc_py vhost_get_controllers
|
2017-07-25 10:27:43 +00:00
|
|
|
|
2017-12-18 19:45:33 +00:00
|
|
|
notice "Shutting down SPDK vhost app..."
|
2019-06-04 20:55:21 +00:00
|
|
|
vhost_kill 0
|
2019-05-17 21:09:40 +00:00
|
|
|
|
|
|
|
vhosttestfini
|