numam-spdk/test/nvme/cmb/cmb.sh
Michal Berger 0b55bf715e test/nvme: Add basic test covering cmb_copy functionality
Change-Id: I083ce9560c37b0f0bd39c9dce3cf97e4038b5e31
Signed-off-by: Michal Berger <michalx.berger@intel.com>
Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/2006
Tested-by: SPDK CI Jenkins <sys_sgci@intel.com>
Community-CI: Broadcom CI <spdk-ci.pdl@broadcom.com>
Reviewed-by: Ben Walker <benjamin.walker@intel.com>
Reviewed-by: Shuhei Matsumoto <shuhei.matsumoto.xt@hitachi.com>
2021-07-20 07:59:43 +00:00

110 lines
2.6 KiB
Bash
Executable File

#!/usr/bin/env bash
testdir=$(readlink -f "$(dirname "$0")")
rootdir=$(readlink -f "$testdir/../../../")
source "$rootdir/test/common/autotest_common.sh"
shopt -s extglob nullglob
decode_cmb_regs() {
local cmb=$1
local cmbs
local cmbl
mapfile -t cmb < "$cmb"
cmb=("${cmb[@]##* }")
cmbl=0${cmb[0]}
cmbs=0${cmb[1]}
local szu szu_unit
szu[0]=4 szu_unit[0]=KiB
szu[1]=64 szu_unit[1]=KiB
szu[2]=1 szu_unit[2]=MiB
szu[3]=16 szu_unit[3]=MiB
szu[4]=256 szu_unit[4]=MiB
szu[5]=4 szu_unit[5]=GiB
szu[6]=64 szu_unit[6]=GiB
local bool
bool[0]="not set"
bool[1]="set"
local size size_m
local ofst bir
size=$(((cmbs >> 12) & 0x0fffff))
size_m=$(((cmbs >> 8) & 0xf))
((size *= szu[size_m]))
size="$size ${szu_unit[size_m]}"
ofst=$(printf '0x%x' $(((cmbl >> 12) & 0x0fffff)))
bir=$(printf '0x%x' $((cmbl & 0x7)))
cat <<- CMBSZ
SZ: $size
SZU: ${szu[size_m]} ${szu_unit[size_m]}
WDS: ${bool[cmbs & 1 << 4 ? 1 : 0]}
RDS: ${bool[cmbs & 1 << 3 ? 1 : 0]}
LISTS: ${bool[cmbs & 1 << 2 ? 1 : 0]}
CQS: ${bool[cmbs & 1 << 1 ? 1 : 0]}
SQS: ${bool[cmbs & 1 << 0 ? 1 : 0]}
CMBSZ
cat <<- CMBLOC
OFST: $ofst
CQDA: ${bool[cmbl & 1 << 8 ? 1 : 0]}
CDMMMS: ${bool[cmbl & 1 << 7 ? 1 : 0]}
CDPCILS: ${bool[cmbl & 1 << 6 ? 1 : 0]}
CDPMLS: ${bool[cmbl & 1 << 5 ? 1 : 0]}
CQPDS: ${bool[cmbl & 1 << 4 ? 1 : 0]}
CQMMS: ${bool[cmbl & 1 << 3 ? 1 : 0]}
BIR: $bir
CMBLOC
}
"$rootdir/scripts/setup.sh" reset
xtrace_disable
# Look for all the nvme controllers which support CMB. The easiest, and
# fastest, way to do it is by checking if the cmb attr under sysfs has
# been created. If it doesn't exist, than the nvme driver must have
# read 0 from the CMBSZ register (meaning CMB is either not supported
# or the CMBMSC.CRE bit was cleared).
cmb_nvmes=()
for nvme in /sys/class/nvme/nvme+([0-9]); do
[[ -e $nvme/cmb ]] || continue
cmb_nvmes+=("$(< "$nvme/address")")
printf '* %s (%s:%s:%s:%s) CMB:\n' \
"${nvme##*/}" \
"$(< "$nvme/address")" \
"$(< "$nvme/model")" \
"$(< "$nvme/serial")" \
"$(< "$nvme/transport")"
decode_cmb_regs "$nvme/cmb"
done
xtrace_restore
"$rootdir/scripts/setup.sh"
# Check if controllers which we found have been taken out from the nvme
# driver. If yes then we may safely use it for our tests.
for nvme in "${!cmb_nvmes[@]}"; do
if [[ -e /sys/bus/pci/drivers/nvme/${cmb_nvmes[nvme]} ]]; then
printf '%s device still in use, skipping\n' "${cmb_nvmes[nvme]}"
unset -v "cmb_nvmes[nvme]"
fi >&2
done
if ((${#cmb_nvmes[@]} == 0)); then
printf 'No suitable nvme devices found, aborting CMB tests\n' >&2
exit 1
fi
run_test "cmb_copy" "$testdir/cmb_copy.sh" "${cmb_nvmes[@]}"