xref: /spdk/test/nvme/cuse/spdk_smartctl_cuse.sh (revision 7192849ed24874f3e9cc31e8a33a9b32c49b9506)
1#!/usr/bin/env bash
2
3testdir=$(readlink -f $(dirname $0))
4rootdir=$(readlink -f $testdir/../../..)
5source $rootdir/scripts/common.sh
6source $rootdir/test/common/autotest_common.sh
7
8SMARTCTL_CMD='smartctl -d nvme'
9rpc_py=$rootdir/scripts/rpc.py
10
11bdf=$(get_first_nvme_bdf)
12
13PCI_WHITELIST="${bdf}" $rootdir/scripts/setup.sh reset
14sleep 1
15nvme_name=$(get_nvme_ctrlr_from_bdf ${bdf})
16if [[ -z "$nvme_name" ]]; then
17	echo "setup.sh failed bind kernel driver to ${bdf}"
18	exit 1
19fi
20
21KERNEL_SMART_JSON=$(${SMARTCTL_CMD} --json=g -a /dev/${nvme_name} | grep -v "/dev/${nvme_name}" | sort || true)
22
23${SMARTCTL_CMD} -i /dev/${nvme_name}n1
24
25# logs are not provided by json output
26KERNEL_SMART_ERRLOG=$(${SMARTCTL_CMD} -l error /dev/${nvme_name})
27
28$rootdir/scripts/setup.sh
29
30$SPDK_BIN_DIR/spdk_tgt -m 0x3 &
31spdk_tgt_pid=$!
32trap 'kill -9 ${spdk_tgt_pid}; exit 1' SIGINT SIGTERM EXIT
33
34waitforlisten $spdk_tgt_pid
35
36$rpc_py bdev_nvme_attach_controller -b Nvme0 -t PCIe -a ${bdf}
37$rpc_py bdev_nvme_cuse_register -n Nvme0
38
39sleep 5
40
41if [ ! -c /dev/spdk/nvme0 ]; then
42	exit 1
43fi
44
45CUSE_SMART_JSON=$(${SMARTCTL_CMD} --json=g -a /dev/spdk/nvme0 | grep -v "/dev/spdk/nvme0" | sort || true)
46
47DIFF_SMART_JSON=$(diff --changed-group-format='%<' --unchanged-group-format='' <(echo "$KERNEL_SMART_JSON") <(echo "$CUSE_SMART_JSON") || true)
48
49# Mask values can change
50ERR_SMART_JSON=$(grep -v "json\.nvme_smart_health_information_log\.\|json\.local_time\.\|json\.temperature\.\|json\.power_on_time\.hours" <<< $DIFF_SMART_JSON || true)
51
52if [ -n "$ERR_SMART_JSON" ]; then
53	echo "Wrong values for: $ERR_SMART_JSON"
54	exit 1
55fi
56
57CUSE_SMART_ERRLOG=$(${SMARTCTL_CMD} -l error /dev/spdk/nvme0)
58if [ "$CUSE_SMART_ERRLOG" != "$KERNEL_SMART_ERRLOG" ]; then
59	echo "Wrong values in NVMe Error log"
60	exit 1
61fi
62
63# Data integity was checked before, now make sure other commads didn't fail
64${SMARTCTL_CMD} -i /dev/spdk/nvme0n1
65${SMARTCTL_CMD} -c /dev/spdk/nvme0
66${SMARTCTL_CMD} -A /dev/spdk/nvme0
67
68# Health test can fail
69${SMARTCTL_CMD} -x /dev/spdk/nvme0 || true
70${SMARTCTL_CMD} -H /dev/spdk/nvme0 || true
71
72$rpc_py bdev_nvme_detach_controller Nvme0
73sleep 1
74if [ -c /dev/spdk/nvme1 ]; then
75	exit 1
76fi
77
78trap - SIGINT SIGTERM EXIT
79killprocess $spdk_tgt_pid
80