From: Luis Chamberlain <mcgrof@kernel.org>
To: shinichiro.kawasaki@wdc.com
Cc: linux-block@vger.kernel.org, hare@suse.de,
patches@lists.linux.dev, gost.dev@samsung.com, mcgrof@kernel.org
Subject: [PATCH blktests v3 3/6] common: add and use min io for fio
Date: Wed, 12 Feb 2025 12:54:45 -0800 [thread overview]
Message-ID: <20250212205448.2107005-4-mcgrof@kernel.org> (raw)
In-Reply-To: <20250212205448.2107005-1-mcgrof@kernel.org>
When using fio we should not issue IOs smaller than the device supports.
Today a lot of places have in place 4k, but soon we will have devices
which support bs > ps. For those devices we should check the minimum
supported IO.
However, since we also have a min optimal IO, we might as well use that
as well. By using this we can also leverage the same lookup with stat
whether or not the target file is a block device or a file.
Signed-off-by: Luis Chamberlain <mcgrof@kernel.org>
---
common/fio | 26 ++++++++++++++++++++++++--
common/rc | 24 ++++++++++++++++++++++++
2 files changed, 48 insertions(+), 2 deletions(-)
diff --git a/common/fio b/common/fio
index b9ea087fc6c5..d147214f3d16 100644
--- a/common/fio
+++ b/common/fio
@@ -189,15 +189,37 @@ _run_fio() {
return $rc
}
+_fio_opts_to_min_io() {
+ local arg path
+ local -i min_io=4096
+
+ for arg in "$@"; do
+ [[ "$arg" =~ ^--filename= || "$arg" =~ --directory= ]] || continue
+ path="${arg##*=}"
+ min_io=$(_min_io "$path")
+ # Keep 4K minimum IO size for historical consistency
+ ((min_io < 4096)) && min_io=4096
+ break
+ done
+
+ echo "$min_io"
+}
+
# Wrapper around _run_fio used if you need some I/O but don't really care much
# about the details
_run_fio_rand_io() {
- _run_fio --bs=4k --rw=randread --norandommap --numjobs="$(nproc)" \
+ local bs
+
+ bs=$(_fio_opts_to_min_io "$@") || return 1
+ _run_fio --bs="$bs" --rw=randread --norandommap --numjobs="$(nproc)" \
--name=reads --direct=1 "$@"
}
_run_fio_verify_io() {
- _run_fio --name=verify --rw=randwrite --direct=1 --ioengine=libaio --bs=4k \
+ local bs
+
+ bs=$(_fio_opts_to_min_io "$@") || return 1
+ _run_fio --name=verify --rw=randwrite --direct=1 --ioengine=libaio --bs="$bs" \
--iodepth=16 --verify=crc32c --verify_state_save=0 "$@"
}
diff --git a/common/rc b/common/rc
index a7e899cfb419..6e7bddc844bf 100644
--- a/common/rc
+++ b/common/rc
@@ -400,6 +400,30 @@ _test_dev_is_partition() {
[[ -n ${TEST_DEV_PART_SYSFS} ]]
}
+_min_io() {
+ local path_or_dev=$1
+ local min_io=4096
+ if [ -z "$path_or_dev" ]; then
+ echo "path for min_io does not exist"
+ return 1
+ fi
+
+ if [ -c "$path_or_dev" ]; then
+ if [[ "$path_or_dev" == /dev/ng* ]]; then
+ path_or_dev="${path_or_dev/ng/nvme}"
+ fi
+ fi
+
+ if [ -e "$path_or_dev" ]; then
+ min_io=$(stat --printf=%o "$path_or_dev")
+ ((min_io < 4096)) && min_io=4096
+ echo "$min_io"
+ else
+ echo "Error: '$path_or_dev' does not exist or is not accessible"
+ return 1
+ fi
+}
+
# Return max open zones or max active zones of the test target device.
# If the device has both, return smaller value.
_test_dev_max_open_active_zones() {
--
2.45.2
next prev parent reply other threads:[~2025-02-12 20:54 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-02-12 20:54 [PATCH blktests v3 0/6] enable bs > ps device testing Luis Chamberlain
2025-02-12 20:54 ` [PATCH blktests v3 1/6] common/xfs: ignore first umount error on _xfs_mkfs_and_mount() Luis Chamberlain
2025-02-12 20:58 ` Bart Van Assche
2025-02-12 21:07 ` Luis Chamberlain
2025-02-14 11:02 ` Shinichiro Kawasaki
2025-02-12 20:54 ` [PATCH blktests v3 2/6] block/032: make error messages clearer if mkfs or mount fails Luis Chamberlain
2025-02-14 11:06 ` Shinichiro Kawasaki
2025-02-12 20:54 ` Luis Chamberlain [this message]
2025-02-14 11:24 ` [PATCH blktests v3 3/6] common: add and use min io for fio Shinichiro Kawasaki
2025-02-12 20:54 ` [PATCH blktests v3 4/6] common/xfs: use min io for fs blocksize Luis Chamberlain
2025-02-12 20:54 ` [PATCH blktests v3 5/6] tests: use test device min io to support bs > ps Luis Chamberlain
2025-02-12 20:54 ` [PATCH blktests v3 6/6] common/xfs: add _test_dev_suits_xfs() to verify logical block size will work Luis Chamberlain
2025-02-14 11:28 ` Shinichiro Kawasaki
2025-02-14 11:34 ` [PATCH blktests v3 0/6] enable bs > ps device testing Shinichiro Kawasaki
2025-02-14 18:54 ` Luis Chamberlain
2025-02-21 9:55 ` Shinichiro Kawasaki
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250212205448.2107005-4-mcgrof@kernel.org \
--to=mcgrof@kernel.org \
--cc=gost.dev@samsung.com \
--cc=hare@suse.de \
--cc=linux-block@vger.kernel.org \
--cc=patches@lists.linux.dev \
--cc=shinichiro.kawasaki@wdc.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).