]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
lib: kunit_iov_iter: improve error detection
authorChristian A. Ehrhardt <lk@c--e.de>
Thu, 26 Mar 2026 21:49:04 +0000 (22:49 +0100)
committerAndrew Morton <akpm@linux-foundation.org>
Fri, 3 Apr 2026 06:36:23 +0000 (23:36 -0700)
In the kunit_iov_iter test prevent the kernel buffer from being a single
physically contiguous region.

Additionally, make sure that the test pattern written to a page in the
buffer depends on the offset of the page within the buffer.

Link: https://lkml.kernel.org/r/20260326214905.818170-5-lk@c--e.de
Signed-off-by: Christian A. Ehrhardt <lk@c--e.de>
Cc: David Howells <dhowells@redhat.com>
Cc: David Gow <davidgow@google.com>
Cc: Kees Cook <kees@kernel.org>
Cc: Petr Mladek <pmladek@suse.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
lib/tests/kunit_iov_iter.c

index d16449bdb8334a3556ce1cc4f3c9b68e90da2ca7..64a4e2f3eafa9850ebee8c84509bc6786363c466 100644 (file)
@@ -13,6 +13,7 @@
 #include <linux/uio.h>
 #include <linux/bvec.h>
 #include <linux/folio_queue.h>
+#include <linux/minmax.h>
 #include <kunit/test.h>
 
 MODULE_DESCRIPTION("iov_iter testing");
@@ -37,7 +38,7 @@ static const struct kvec_test_range kvec_test_ranges[] = {
 
 static inline u8 pattern(unsigned long x)
 {
-       return x & 0xff;
+       return (u8)x + (u8)(x >> 8) + (u8)(x >> 16);
 }
 
 static void iov_kunit_unmap(void *data)
@@ -52,6 +53,7 @@ static void *__init iov_kunit_create_buffer(struct kunit *test,
        struct page **pages;
        unsigned long got;
        void *buffer;
+       unsigned int i;
 
        pages = kzalloc_objs(struct page *, npages, GFP_KERNEL);
        KUNIT_ASSERT_NOT_ERR_OR_NULL(test, pages);
@@ -63,6 +65,9 @@ static void *__init iov_kunit_create_buffer(struct kunit *test,
                kvfree(pages);
                KUNIT_ASSERT_EQ(test, got, npages);
        }
+       /* Make sure that we don't get a physically contiguous buffer. */
+       for (i = 0; i < npages / 4; ++i)
+               swap(pages[i], pages[i + npages / 2]);
 
        buffer = vmap(pages, npages, VM_MAP | VM_MAP_PUT_PAGES, PAGE_KERNEL);
        if (buffer == NULL) {