Message ID | 20241014090116.125500-3-kanie@linux.alibaba.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | Test the NVMe reservation feature | expand |
On Mon, Oct 14, 2024 at 05:01:16PM GMT, Guixin Liu wrote: > +resv_report() { > + local test_dev=$1 > + local report_arg=$2 > + > + nvme resv-report "${test_dev}" "${report_arg}" | grep -v "hostid" | \ > + grep -E "gen|rtype|regctl|regctlext|cntlid|rcsts|rkey" okay, let's see how this goes. > +test_resv() { > + local nvmedev=$1 > + local report_arg="--cdw11=1" > + test_dev="/dev/${nvmedev}n1" Please use the namespace lookup helper and don't hardcode the namespace id. > + > + if nvme resv-report --help 2>&1 | grep -- '--eds' > /dev/null; then > + report_arg="--eds" > + fi > + > + echo "Register" > + resv_report "${test_dev}" "${report_arg}" > + nvme resv-register "${test_dev}" --nrkey=4 --rrega=0 > + resv_report "${test_dev}" "${report_arg}" > + > + echo "Replace" > + nvme resv-register "${test_dev}" --crkey=4 --nrkey=5 --rrega=2 > + resv_report "${test_dev}" "${report_arg}" > + > + echo "Unregister" > + nvme resv-register "${test_dev}" --crkey=5 --rrega=1 > + resv_report "${test_dev}" "${report_arg}" > + > + echo "Acquire" > + nvme resv-register "${test_dev}" --nrkey=4 --rrega=0 > + nvme resv-acquire "${test_dev}" --crkey=4 --rtype=1 --racqa=0 > + resv_report "${test_dev}" "${report_arg}" > + > + echo "Preempt" > + nvme resv-acquire "${test_dev}" --crkey=4 --rtype=2 --racqa=1 > + resv_report "${test_dev}" "${report_arg}" > + > + echo "Release" > + nvme resv-release "${test_dev}" --crkey=4 --rtype=2 --rrela=0 > + resv_report "${test_dev}" "${report_arg}" > + > + echo "Clear" > + nvme resv-register "${test_dev}" --nrkey=4 --rrega=0 > + nvme resv-acquire "${test_dev}" --crkey=4 --rtype=1 --racqa=0 > + resv_report "${test_dev}" "${report_arg}" > + nvme resv-release "${test_dev}" --crkey=4 --rrela=1 > +} > + > +test() { > + echo "Running ${TEST_NAME}" > + > + _setup_nvmet > + > + local nvmedev > + local skipped=false > + local subsys_path="" > + local ns_path="" > + > + _nvmet_target_setup --blkdev file --resv_enable > + subsys_path="${NVMET_CFS}/subsystems/${def_subsysnqn}" > + ns_path="${subsys_path}/namespaces/1" Again here, it's better not to hardcode the nsid.
在 2024/10/14 19:44, Daniel Wagner 写道: > On Mon, Oct 14, 2024 at 05:01:16PM GMT, Guixin Liu wrote: >> +resv_report() { >> + local test_dev=$1 >> + local report_arg=$2 >> + >> + nvme resv-report "${test_dev}" "${report_arg}" | grep -v "hostid" | \ >> + grep -E "gen|rtype|regctl|regctlext|cntlid|rcsts|rkey" > okay, let's see how this goes. > >> +test_resv() { >> + local nvmedev=$1 >> + local report_arg="--cdw11=1" >> + test_dev="/dev/${nvmedev}n1" > Please use the namespace lookup helper and don't hardcode the namespace > id. > OK, changed in v5, thanks. Best Regards, Guixin Liu >> + >> + if nvme resv-report --help 2>&1 | grep -- '--eds' > /dev/null; then >> + report_arg="--eds" >> + fi >> + >> + echo "Register" >> + resv_report "${test_dev}" "${report_arg}" >> + nvme resv-register "${test_dev}" --nrkey=4 --rrega=0 >> + resv_report "${test_dev}" "${report_arg}" >> + >> + echo "Replace" >> + nvme resv-register "${test_dev}" --crkey=4 --nrkey=5 --rrega=2 >> + resv_report "${test_dev}" "${report_arg}" >> + >> + echo "Unregister" >> + nvme resv-register "${test_dev}" --crkey=5 --rrega=1 >> + resv_report "${test_dev}" "${report_arg}" >> + >> + echo "Acquire" >> + nvme resv-register "${test_dev}" --nrkey=4 --rrega=0 >> + nvme resv-acquire "${test_dev}" --crkey=4 --rtype=1 --racqa=0 >> + resv_report "${test_dev}" "${report_arg}" >> + >> + echo "Preempt" >> + nvme resv-acquire "${test_dev}" --crkey=4 --rtype=2 --racqa=1 >> + resv_report "${test_dev}" "${report_arg}" >> + >> + echo "Release" >> + nvme resv-release "${test_dev}" --crkey=4 --rtype=2 --rrela=0 >> + resv_report "${test_dev}" "${report_arg}" >> + >> + echo "Clear" >> + nvme resv-register "${test_dev}" --nrkey=4 --rrega=0 >> + nvme resv-acquire "${test_dev}" --crkey=4 --rtype=1 --racqa=0 >> + resv_report "${test_dev}" "${report_arg}" >> + nvme resv-release "${test_dev}" --crkey=4 --rrela=1 >> +} >> + >> +test() { >> + echo "Running ${TEST_NAME}" >> + >> + _setup_nvmet >> + >> + local nvmedev >> + local skipped=false >> + local subsys_path="" >> + local ns_path="" >> + >> + _nvmet_target_setup --blkdev file --resv_enable >> + subsys_path="${NVMET_CFS}/subsystems/${def_subsysnqn}" >> + ns_path="${subsys_path}/namespaces/1" > Again here, it's better not to hardcode the nsid.
diff --git a/tests/nvme/054 b/tests/nvme/054 new file mode 100644 index 0000000..dc674a7 --- /dev/null +++ b/tests/nvme/054 @@ -0,0 +1,101 @@ +#!/bin/bash +# SPDX-License-Identifier: GPL-3.0+ +# Copyright (C) 2024 Guixin Liu +# Copyright (C) 2024 Alibaba Group. +# +# Test the NVMe reservation feature +# +. tests/nvme/rc + +DESCRIPTION="Test the NVMe reservation feature" +QUICK=1 +nvme_trtype="loop" + +requires() { + _nvme_requires +} + +resv_report() { + local test_dev=$1 + local report_arg=$2 + + nvme resv-report "${test_dev}" "${report_arg}" | grep -v "hostid" | \ + grep -E "gen|rtype|regctl|regctlext|cntlid|rcsts|rkey" +} + +test_resv() { + local nvmedev=$1 + local report_arg="--cdw11=1" + test_dev="/dev/${nvmedev}n1" + + if nvme resv-report --help 2>&1 | grep -- '--eds' > /dev/null; then + report_arg="--eds" + fi + + echo "Register" + resv_report "${test_dev}" "${report_arg}" + nvme resv-register "${test_dev}" --nrkey=4 --rrega=0 + resv_report "${test_dev}" "${report_arg}" + + echo "Replace" + nvme resv-register "${test_dev}" --crkey=4 --nrkey=5 --rrega=2 + resv_report "${test_dev}" "${report_arg}" + + echo "Unregister" + nvme resv-register "${test_dev}" --crkey=5 --rrega=1 + resv_report "${test_dev}" "${report_arg}" + + echo "Acquire" + nvme resv-register "${test_dev}" --nrkey=4 --rrega=0 + nvme resv-acquire "${test_dev}" --crkey=4 --rtype=1 --racqa=0 + resv_report "${test_dev}" "${report_arg}" + + echo "Preempt" + nvme resv-acquire "${test_dev}" --crkey=4 --rtype=2 --racqa=1 + resv_report "${test_dev}" "${report_arg}" + + echo "Release" + nvme resv-release "${test_dev}" --crkey=4 --rtype=2 --rrela=0 + resv_report "${test_dev}" "${report_arg}" + + echo "Clear" + nvme resv-register "${test_dev}" --nrkey=4 --rrega=0 + nvme resv-acquire "${test_dev}" --crkey=4 --rtype=1 --racqa=0 + resv_report "${test_dev}" "${report_arg}" + nvme resv-release "${test_dev}" --crkey=4 --rrela=1 +} + +test() { + echo "Running ${TEST_NAME}" + + _setup_nvmet + + local nvmedev + local skipped=false + local subsys_path="" + local ns_path="" + + _nvmet_target_setup --blkdev file --resv_enable + subsys_path="${NVMET_CFS}/subsystems/${def_subsysnqn}" + ns_path="${subsys_path}/namespaces/1" + + if [[ -f "${ns_path}/resv_enable" ]] ; then + _nvme_connect_subsys + + nvmedev=$(_find_nvme_dev "${def_subsysnqn}") + + test_resv "${nvmedev}" + _nvme_disconnect_subsys + else + SKIP_REASONS+=("missing reservation feature") + skipped=true + fi + + _nvmet_target_cleanup + + if [[ "${skipped}" = true ]] ; then + return 1 + fi + + echo "Test complete" +} diff --git a/tests/nvme/054.out b/tests/nvme/054.out new file mode 100644 index 0000000..5adb30d --- /dev/null +++ b/tests/nvme/054.out @@ -0,0 +1,68 @@ +Running nvme/054 +Register +gen : 0 +rtype : 0 +regctl : 0 +NVME Reservation success +gen : 1 +rtype : 0 +regctl : 1 +regctlext[0] : + cntlid : ffff + rcsts : 0 + rkey : 4 +Replace +NVME Reservation success +gen : 2 +rtype : 0 +regctl : 1 +regctlext[0] : + cntlid : ffff + rcsts : 0 + rkey : 5 +Unregister +NVME Reservation success +gen : 3 +rtype : 0 +regctl : 0 +Acquire +NVME Reservation success +NVME Reservation Acquire success +gen : 4 +rtype : 1 +regctl : 1 +regctlext[0] : + cntlid : ffff + rcsts : 1 + rkey : 4 +Preempt +NVME Reservation Acquire success +gen : 5 +rtype : 2 +regctl : 1 +regctlext[0] : + cntlid : ffff + rcsts : 1 + rkey : 4 +Release +NVME Reservation Release success +gen : 5 +rtype : 0 +regctl : 1 +regctlext[0] : + cntlid : ffff + rcsts : 0 + rkey : 4 +Clear +NVME Reservation success +NVME Reservation Acquire success +gen : 6 +rtype : 1 +regctl : 1 +regctlext[0] : + cntlid : ffff + rcsts : 1 + rkey : 4 +NVME Reservation Release success +disconnected 1 controller(s) +Test complete