187 lines
7.3 KiB
Diff
187 lines
7.3 KiB
Diff
From add833b5de202d6765dda56c8773985fbe7f40a6 Mon Sep 17 00:00:00 2001
|
|
From: Hanna Czenczek <hreitz@redhat.com>
|
|
Date: Tue, 11 Apr 2023 19:34:18 +0200
|
|
Subject: [PATCH 4/9] iotests/iov-padding: New test
|
|
|
|
RH-Author: Hanna Czenczek <hreitz@redhat.com>
|
|
RH-MergeRequest: 189: block: Split padded I/O vectors exceeding IOV_MAX
|
|
RH-Bugzilla: 2174676
|
|
RH-Acked-by: Miroslav Rezanina <mrezanin@redhat.com>
|
|
RH-Commit: [4/5] b32715b5c2a3e2add39c5ed6e8f71df56e0b91a0 (hreitz/qemu-kvm-c-9-s)
|
|
|
|
Test that even vectored IO requests with 1024 vector elements that are
|
|
not aligned to the device's request alignment will succeed.
|
|
|
|
Reviewed-by: Eric Blake <eblake@redhat.com>
|
|
Reviewed-by: Vladimir Sementsov-Ogievskiy <vsementsov@yandex-team.ru>
|
|
Signed-off-by: Hanna Czenczek <hreitz@redhat.com>
|
|
Message-Id: <20230411173418.19549-5-hreitz@redhat.com>
|
|
(cherry picked from commit d7e1905e3f54ff9512db4c7a946a8603b62b108d)
|
|
Signed-off-by: Hanna Czenczek <hreitz@redhat.com>
|
|
---
|
|
tests/qemu-iotests/tests/iov-padding | 85 ++++++++++++++++++++++++
|
|
tests/qemu-iotests/tests/iov-padding.out | 59 ++++++++++++++++
|
|
2 files changed, 144 insertions(+)
|
|
create mode 100755 tests/qemu-iotests/tests/iov-padding
|
|
create mode 100644 tests/qemu-iotests/tests/iov-padding.out
|
|
|
|
diff --git a/tests/qemu-iotests/tests/iov-padding b/tests/qemu-iotests/tests/iov-padding
|
|
new file mode 100755
|
|
index 0000000000..b9604900c7
|
|
--- /dev/null
|
|
+++ b/tests/qemu-iotests/tests/iov-padding
|
|
@@ -0,0 +1,85 @@
|
|
+#!/usr/bin/env bash
|
|
+# group: rw quick
|
|
+#
|
|
+# Check the interaction of request padding (to fit alignment restrictions) with
|
|
+# vectored I/O from the guest
|
|
+#
|
|
+# Copyright Red Hat
|
|
+#
|
|
+# This program is free software; you can redistribute it and/or modify
|
|
+# it under the terms of the GNU General Public License as published by
|
|
+# the Free Software Foundation; either version 2 of the License, or
|
|
+# (at your option) any later version.
|
|
+#
|
|
+# This program is distributed in the hope that it will be useful,
|
|
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
+# GNU General Public License for more details.
|
|
+#
|
|
+# You should have received a copy of the GNU General Public License
|
|
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
+#
|
|
+
|
|
+seq=$(basename $0)
|
|
+echo "QA output created by $seq"
|
|
+
|
|
+status=1 # failure is the default!
|
|
+
|
|
+_cleanup()
|
|
+{
|
|
+ _cleanup_test_img
|
|
+}
|
|
+trap "_cleanup; exit \$status" 0 1 2 3 15
|
|
+
|
|
+# get standard environment, filters and checks
|
|
+cd ..
|
|
+. ./common.rc
|
|
+. ./common.filter
|
|
+
|
|
+_supported_fmt raw
|
|
+_supported_proto file
|
|
+
|
|
+_make_test_img 1M
|
|
+
|
|
+IMGSPEC="driver=blkdebug,align=4096,image.driver=file,image.filename=$TEST_IMG"
|
|
+
|
|
+# Four combinations:
|
|
+# - Offset 4096, length 1023 * 512 + 512: Fully aligned to 4k
|
|
+# - Offset 4096, length 1023 * 512 + 4096: Head is aligned, tail is not
|
|
+# - Offset 512, length 1023 * 512 + 512: Neither head nor tail are aligned
|
|
+# - Offset 512, length 1023 * 512 + 4096: Tail is aligned, head is not
|
|
+for start_offset in 4096 512; do
|
|
+ for last_element_length in 512 4096; do
|
|
+ length=$((1023 * 512 + $last_element_length))
|
|
+
|
|
+ echo
|
|
+ echo "== performing 1024-element vectored requests to image (offset: $start_offset; length: $length) =="
|
|
+
|
|
+ # Fill with data for testing
|
|
+ $QEMU_IO -c 'write -P 1 0 1M' "$TEST_IMG" | _filter_qemu_io
|
|
+
|
|
+ # 1023 512-byte buffers, and then one with length $last_element_length
|
|
+ cmd_params="-P 2 $start_offset $(yes 512 | head -n 1023 | tr '\n' ' ') $last_element_length"
|
|
+ QEMU_IO_OPTIONS="$QEMU_IO_OPTIONS_NO_FMT" $QEMU_IO \
|
|
+ -c "writev $cmd_params" \
|
|
+ --image-opts \
|
|
+ "$IMGSPEC" \
|
|
+ | _filter_qemu_io
|
|
+
|
|
+ # Read all patterns -- read the part we just wrote with writev twice,
|
|
+ # once "normally", and once with a readv, so we see that that works, too
|
|
+ QEMU_IO_OPTIONS="$QEMU_IO_OPTIONS_NO_FMT" $QEMU_IO \
|
|
+ -c "read -P 1 0 $start_offset" \
|
|
+ -c "read -P 2 $start_offset $length" \
|
|
+ -c "readv $cmd_params" \
|
|
+ -c "read -P 1 $((start_offset + length)) $((1024 * 1024 - length - start_offset))" \
|
|
+ --image-opts \
|
|
+ "$IMGSPEC" \
|
|
+ | _filter_qemu_io
|
|
+ done
|
|
+done
|
|
+
|
|
+# success, all done
|
|
+echo "*** done"
|
|
+rm -f $seq.full
|
|
+status=0
|
|
diff --git a/tests/qemu-iotests/tests/iov-padding.out b/tests/qemu-iotests/tests/iov-padding.out
|
|
new file mode 100644
|
|
index 0000000000..e07a91fac7
|
|
--- /dev/null
|
|
+++ b/tests/qemu-iotests/tests/iov-padding.out
|
|
@@ -0,0 +1,59 @@
|
|
+QA output created by iov-padding
|
|
+Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=1048576
|
|
+
|
|
+== performing 1024-element vectored requests to image (offset: 4096; length: 524288) ==
|
|
+wrote 1048576/1048576 bytes at offset 0
|
|
+1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+wrote 524288/524288 bytes at offset 4096
|
|
+512 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 4096/4096 bytes at offset 0
|
|
+4 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 524288/524288 bytes at offset 4096
|
|
+512 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 524288/524288 bytes at offset 4096
|
|
+512 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 520192/520192 bytes at offset 528384
|
|
+508 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+
|
|
+== performing 1024-element vectored requests to image (offset: 4096; length: 527872) ==
|
|
+wrote 1048576/1048576 bytes at offset 0
|
|
+1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+wrote 527872/527872 bytes at offset 4096
|
|
+515.500 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 4096/4096 bytes at offset 0
|
|
+4 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 527872/527872 bytes at offset 4096
|
|
+515.500 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 527872/527872 bytes at offset 4096
|
|
+515.500 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 516608/516608 bytes at offset 531968
|
|
+504.500 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+
|
|
+== performing 1024-element vectored requests to image (offset: 512; length: 524288) ==
|
|
+wrote 1048576/1048576 bytes at offset 0
|
|
+1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+wrote 524288/524288 bytes at offset 512
|
|
+512 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 512/512 bytes at offset 0
|
|
+512 bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 524288/524288 bytes at offset 512
|
|
+512 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 524288/524288 bytes at offset 512
|
|
+512 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 523776/523776 bytes at offset 524800
|
|
+511.500 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+
|
|
+== performing 1024-element vectored requests to image (offset: 512; length: 527872) ==
|
|
+wrote 1048576/1048576 bytes at offset 0
|
|
+1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+wrote 527872/527872 bytes at offset 512
|
|
+515.500 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 512/512 bytes at offset 0
|
|
+512 bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 527872/527872 bytes at offset 512
|
|
+515.500 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 527872/527872 bytes at offset 512
|
|
+515.500 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+read 520192/520192 bytes at offset 528384
|
|
+508 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
+*** done
|
|
--
|
|
2.39.3
|
|
|