When test for overflow do iterate the buffer length in a range
0 .. BUF_SIZE.

Signed-off-by: Andy Shevchenko <[email protected]>
---
 lib/test_hexdump.c | 20 ++++++++++----------
 1 file changed, 10 insertions(+), 10 deletions(-)

diff --git a/lib/test_hexdump.c b/lib/test_hexdump.c
index ed7c6a7..15a6440 100644
--- a/lib/test_hexdump.c
+++ b/lib/test_hexdump.c
@@ -126,17 +126,17 @@ static void __init test_hexdump_set(int rowsize, bool 
ascii)
        test_hexdump(len, rowsize, 1, ascii);
 }
 
-static void __init test_hexdump_overflow(bool ascii)
+static void __init test_hexdump_overflow(size_t buflen, bool ascii)
 {
-       char buf[56];
+       char buf[TEST_HEXDUMP_BUF_SIZE];
        const char *t = test_data_1_le[0];
-       size_t l = get_random_int() % sizeof(buf);
+       size_t l = buflen;
        bool a;
        int e, r;
 
        memset(buf, ' ', sizeof(buf));
 
-       r = hex_dump_to_buffer(data_b, 1, 16, 1, buf, l, ascii);
+       r = hex_dump_to_buffer(data_b, 1, 16, 1, buf, buflen, ascii);
 
        if (ascii)
                e = 50;
@@ -144,7 +144,7 @@ static void __init test_hexdump_overflow(bool ascii)
                e = 2;
        buf[e + 2] = '\0';
 
-       if (!l) {
+       if (!buflen) {
                a = r == e && buf[0] == ' ';
        } else if (l < 3) {
                a = r == e && buf[0] == '\0';
@@ -160,7 +160,7 @@ static void __init test_hexdump_overflow(bool ascii)
        }
 
        if (!a) {
-               pr_err("Len: %zu rc: %u strlen: %zu\n", l, r, strlen(buf));
+               pr_err("Len: %zu rc: %u strlen: %zu\n", buflen, r, strlen(buf));
                pr_err("Result: '%s'\n", buf);
        }
 }
@@ -180,11 +180,11 @@ static int __init test_hexdump_init(void)
        for (i = 0; i < 16; i++)
                test_hexdump_set(rowsize, true);
 
-       for (i = 0; i < 16; i++)
-               test_hexdump_overflow(false);
+       for (i = 0; i <= TEST_HEXDUMP_BUF_SIZE; i++)
+               test_hexdump_overflow(i, false);
 
-       for (i = 0; i < 16; i++)
-               test_hexdump_overflow(true);
+       for (i = 0; i <= TEST_HEXDUMP_BUF_SIZE; i++)
+               test_hexdump_overflow(i, true);
 
        return -EINVAL;
 }
-- 
2.6.2

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to