The introduction of the for_each_set_clump8 macro warrants test cases to
verify the implementation. This patch adds test case checks for whether
an out-of-bounds clump index is returned, a zero clump is returned, or
the returned clump value differs from the expected clump value.

Cc: Andrew Morton <a...@linux-foundation.org>
Cc: Rasmus Villemoes <li...@rasmusvillemoes.dk>
Reviewed-by: Andy Shevchenko <andy.shevche...@gmail.com>
Reviewed-by: Linus Walleij <linus.wall...@linaro.org>
Signed-off-by: William Breathitt Gray <vilhelm.g...@gmail.com>
---
 lib/test_bitmap.c | 65 +++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 65 insertions(+)

diff --git a/lib/test_bitmap.c b/lib/test_bitmap.c
index 6cd7d0740005..66ddb3fb98cb 100644
--- a/lib/test_bitmap.c
+++ b/lib/test_bitmap.c
@@ -88,6 +88,36 @@ __check_eq_u32_array(const char *srcfile, unsigned int line,
        return true;
 }
 
+static bool __init __check_eq_clump8(const char *srcfile, unsigned int line,
+                                   const unsigned int offset,
+                                   const unsigned int size,
+                                   const unsigned char *const clump_exp,
+                                   const unsigned long *const clump)
+{
+       unsigned long exp;
+
+       if (offset >= size) {
+               pr_warn("[%s:%u] bit offset for clump out-of-bounds: expected 
less than %u, got %u\n",
+                       srcfile, line, size, offset);
+               return false;
+       }
+
+       exp = clump_exp[offset / 8];
+       if (!exp) {
+               pr_warn("[%s:%u] bit offset for zero clump: expected nonzero 
clump, got bit offset %u with clump value 0",
+                       srcfile, line, offset);
+               return false;
+       }
+
+       if (*clump != exp) {
+               pr_warn("[%s:%u] expected clump value of 0x%lX, got clump value 
of 0x%lX",
+                       srcfile, line, exp, *clump);
+               return false;
+       }
+
+       return true;
+}
+
 #define __expect_eq(suffix, ...)                                       \
        ({                                                              \
                int result = 0;                                         \
@@ -104,6 +134,7 @@ __check_eq_u32_array(const char *srcfile, unsigned int line,
 #define expect_eq_bitmap(...)          __expect_eq(bitmap, ##__VA_ARGS__)
 #define expect_eq_pbl(...)             __expect_eq(pbl, ##__VA_ARGS__)
 #define expect_eq_u32_array(...)       __expect_eq(u32_array, ##__VA_ARGS__)
+#define expect_eq_clump8(...)          __expect_eq(clump8, ##__VA_ARGS__)
 
 static void __init test_zero_clear(void)
 {
@@ -361,6 +392,39 @@ static void noinline __init test_mem_optimisations(void)
        }
 }
 
+static const unsigned char clump_exp[] __initconst = {
+       0x01,   /* 1 bit set */
+       0x02,   /* non-edge 1 bit set */
+       0x00,   /* zero bits set */
+       0x28,   /* 3 bits set across 4-bit boundary */
+       0x28,   /* Repeated clump */
+       0x0F,   /* 4 bits set */
+       0xFF,   /* all bits set */
+       0x05,   /* non-adjacent 2 bits set */
+};
+
+static void __init test_for_each_set_clump8(void)
+{
+#define CLUMP_EXP_NUMBITS 64
+       DECLARE_BITMAP(bits, CLUMP_EXP_NUMBITS);
+       unsigned int start;
+       unsigned long clump;
+
+       /* set bitmap to test case */
+       bitmap_zero(bits, CLUMP_EXP_NUMBITS);
+       bitmap_set(bits, 0, 1);         /* 0x01 */
+       bitmap_set(bits, 8, 1);         /* 0x02 */
+       bitmap_set(bits, 27, 3);        /* 0x28 */
+       bitmap_set(bits, 35, 3);        /* 0x28 */
+       bitmap_set(bits, 40, 4);        /* 0x0F */
+       bitmap_set(bits, 48, 8);        /* 0xFF */
+       bitmap_set(bits, 56, 1);        /* 0x05 - part 1 */
+       bitmap_set(bits, 58, 1);        /* 0x05 - part 2 */
+
+       for_each_set_clump8(start, clump, bits, CLUMP_EXP_NUMBITS)
+               expect_eq_clump8(start, CLUMP_EXP_NUMBITS, clump_exp, &clump);
+}
+
 static int __init test_bitmap_init(void)
 {
        test_zero_clear();
@@ -369,6 +433,7 @@ static int __init test_bitmap_init(void)
        test_bitmap_arr32();
        test_bitmap_parselist();
        test_mem_optimisations();
+       test_for_each_set_clump8();
 
        if (failed_tests == 0)
                pr_info("all %u tests passed\n", total_tests);
-- 
2.21.0

Reply via email to