blob: b244ab3479a267a10d053e1d790e276eacab646f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
#!/bin/bash
# SPDX-License-Identifier: GPL-2.0
# Test: shmem_zc with hugetlbfs buffer on null target
#
# kublk and fio both mmap the same hugetlbfs file (MAP_SHARED),
# so they share physical pages. The kernel PFN match enables
# zero-copy I/O without socket-based fd passing.
. "$(cd "$(dirname "$0")" && pwd)"/test_common.sh
ERR_CODE=0
_prep_test "shmem_zc" "null target hugetlbfs shmem zero-copy test"
if ! _have_program fio; then
echo "SKIP: fio not available"
exit "$UBLK_SKIP_CODE"
fi
if ! grep -q hugetlbfs /proc/filesystems; then
echo "SKIP: hugetlbfs not supported"
exit "$UBLK_SKIP_CODE"
fi
# Allocate hugepages
OLD_NR_HP=$(cat /proc/sys/vm/nr_hugepages)
echo 10 > /proc/sys/vm/nr_hugepages
NR_HP=$(cat /proc/sys/vm/nr_hugepages)
if [ "$NR_HP" -lt 2 ]; then
echo "SKIP: cannot allocate hugepages"
echo "$OLD_NR_HP" > /proc/sys/vm/nr_hugepages
exit "$UBLK_SKIP_CODE"
fi
# Mount hugetlbfs
HTLB_MNT=$(mktemp -d "${UBLK_TEST_DIR}/htlb_mnt_XXXXXX")
if ! mount -t hugetlbfs none "$HTLB_MNT"; then
echo "SKIP: cannot mount hugetlbfs"
rmdir "$HTLB_MNT"
echo "$OLD_NR_HP" > /proc/sys/vm/nr_hugepages
exit "$UBLK_SKIP_CODE"
fi
HTLB_FILE="$HTLB_MNT/ublk_buf"
fallocate -l 4M "$HTLB_FILE"
dev_id=$(_add_ublk_dev -t null --shmem_zc --htlb "$HTLB_FILE")
_check_add_dev $TID $?
fio --name=htlb_zc \
--filename=/dev/ublkb"${dev_id}" \
--ioengine=io_uring \
--rw=randwrite \
--direct=1 \
--bs=4k \
--size=4M \
--iodepth=32 \
--mem=mmaphuge:"$HTLB_FILE" \
> /dev/null 2>&1
ERR_CODE=$?
# Delete device first so daemon releases the htlb mmap
_ublk_del_dev "${dev_id}"
rm -f "$HTLB_FILE"
umount "$HTLB_MNT"
rmdir "$HTLB_MNT"
echo "$OLD_NR_HP" > /proc/sys/vm/nr_hugepages
_cleanup_test
_show_result $TID $ERR_CODE
|