[PATCH blktests v2 2/2] md: add regression test for "md/md-bitmap: fix writing non bitmap pages"
Daniel Wagner
dwagner at suse.de
Tue Jun 25 08:01:46 PDT 2024
On Mon, Jun 24, 2024 at 01:46:18PM GMT, Ofir Gal wrote:
> +#restrict test to nvme-tcp only
> +nvme_trtype=tcp
> +nvmet_blkdev_type="device"
> +
> +requires() {
> + # Require dm-stripe
> + _have_program dmsetup
> + _have_driver dm-mod
> +
> + _require_nvme_trtype tcp
> + _have_brd
> +}
> +
> +# Sets up a brd device of 1G with optimal-io-size of 256K
> +setup_underlying_device() {
> + if ! _init_brd rd_size=1048576 rd_nr=1; then
> + return 1
> + fi
> +
> + dmsetup create ram0_big_optio --table \
> + "0 $(blockdev --getsz /dev/ram0) striped 1 512 /dev/ram0 0"
> +}
> +
> +cleanup_underlying_device() {
> + dmsetup remove ram0_big_optio
> + _cleanup_brd
> +}
> +
> +# Sets up a local host nvme over tcp
> +setup_nvme_over_tcp() {
> + _setup_nvmet
> +
> + local port
> + port="$(_create_nvmet_port "${nvme_trtype}")"
> +
> + _create_nvmet_subsystem "blktests-subsystem-0" "/dev/mapper/ram0_big_optio"
> + _add_nvmet_subsys_to_port "${port}" "blktests-subsystem-0"
Use the defaults from blktests, e.g. ${def_subsysnqn}"
> +
> + _create_nvmet_host "blktests-subsystem-0" "${def_hostnqn}"
> +
> + _nvme_connect_subsys --subsysnqn "blktests-subsystem-0"
> +
> + local nvmedev
> + nvmedev=$(_find_nvme_dev "blktests-subsystem-0")
here too
> + echo "${nvmedev}"
> +}
> +
> +cleanup_nvme_over_tcp() {
> + local nvmedev=$1
> + _nvme_disconnect_ctrl "${nvmedev}"
> + _nvmet_target_cleanup --subsysnqn "blktests-subsystem-0"
same here
> +}
> +
> +test() {
> + echo "Running ${TEST_NAME}"
> +
> + setup_underlying_device
> + local nvmedev
> + nvmedev=$(setup_nvme_over_tcp)
> +
> + # Hangs here without the fix
> + mdadm --quiet --create /dev/md/blktests_md --level=1 --bitmap=internal \
> + --bitmap-chunk=1024K --assume-clean --run --raid-devices=2 \
> + /dev/"${nvmedev}"n1 missing
Instead hard coding the namespace ID, this should be made a bit more
robust by looking it up with _find_nvme_ns.
More information about the Linux-nvme
mailing list