Modernize the open coded test framework by using kunit.

Signed-off-by: Jason Gunthorpe <[email protected]>
---
 drivers/dma-buf/Makefile             |   4 +-
 drivers/dma-buf/selftests.h          |   1 -
 drivers/dma-buf/st-dma-fence-chain.c | 217 ++++++++++++---------------
 3 files changed, 98 insertions(+), 124 deletions(-)

diff --git a/drivers/dma-buf/Makefile b/drivers/dma-buf/Makefile
index 65bda1b7cc73eb..c97ab2d01a7e68 100644
--- a/drivers/dma-buf/Makefile
+++ b/drivers/dma-buf/Makefile
@@ -8,13 +8,13 @@ obj-$(CONFIG_SW_SYNC)         += sw_sync.o sync_debug.o
 obj-$(CONFIG_UDMABUF)          += udmabuf.o
 
 dmabuf_selftests-y := \
-       selftest.o \
-       st-dma-fence-chain.o
+       selftest.o
 
 obj-$(CONFIG_DMABUF_SELFTESTS) += dmabuf_selftests.o
 
 dmabuf_kunit-y := \
        st-dma-fence.o \
+       st-dma-fence-chain.o \
        st-dma-fence-unwrap.o \
        st-dma-resv.o
 
diff --git a/drivers/dma-buf/selftests.h b/drivers/dma-buf/selftests.h
index 7104cf0cce26d1..37b7251841278e 100644
--- a/drivers/dma-buf/selftests.h
+++ b/drivers/dma-buf/selftests.h
@@ -10,4 +10,3 @@
  * Tests are executed in order by igt/dmabuf_selftest
  */
 selftest(sanitycheck, __sanitycheck__) /* keep first (igt selfcheck) */
-selftest(dma_fence_chain, dma_fence_chain)
diff --git a/drivers/dma-buf/st-dma-fence-chain.c 
b/drivers/dma-buf/st-dma-fence-chain.c
index 821023dd34df68..a3023d3fedc9d8 100644
--- a/drivers/dma-buf/st-dma-fence-chain.c
+++ b/drivers/dma-buf/st-dma-fence-chain.c
@@ -4,6 +4,7 @@
  * Copyright © 2019 Intel Corporation
  */
 
+#include <kunit/test.h>
 #include <linux/delay.h>
 #include <linux/dma-fence.h>
 #include <linux/dma-fence-chain.h>
@@ -15,8 +16,6 @@
 #include <linux/spinlock.h>
 #include <linux/random.h>
 
-#include "selftest.h"
-
 #define CHAIN_SZ (4 << 10)
 
 static struct kmem_cache *slab_fences;
@@ -74,27 +73,23 @@ static struct dma_fence *mock_chain(struct dma_fence *prev,
        return &f->base;
 }
 
-static int sanitycheck(void *arg)
+static void test_sanitycheck(struct kunit *test)
 {
        struct dma_fence *f, *chain;
-       int err = 0;
 
        f = mock_fence();
-       if (!f)
-               return -ENOMEM;
+       KUNIT_ASSERT_NOT_NULL(test, f);
 
        chain = mock_chain(NULL, f, 1);
        if (chain)
                dma_fence_enable_sw_signaling(chain);
        else
-               err = -ENOMEM;
+               KUNIT_FAIL(test, "Failed to create chain");
 
        dma_fence_signal(f);
        dma_fence_put(f);
 
        dma_fence_put(chain);
-
-       return err;
 }
 
 struct fence_chains {
@@ -176,7 +171,7 @@ static void fence_chains_fini(struct fence_chains *fc)
        kvfree(fc->chains);
 }
 
-static int find_seqno(void *arg)
+static void test_find_seqno(struct kunit *test)
 {
        struct fence_chains fc;
        struct dma_fence *fence;
@@ -184,14 +179,13 @@ static int find_seqno(void *arg)
        int i;
 
        err = fence_chains_init(&fc, 64, seqno_inc);
-       if (err)
-               return err;
+       KUNIT_ASSERT_EQ_MSG(test, err, 0, "Failed to init fence chains");
 
        fence = dma_fence_get(fc.tail);
        err = dma_fence_chain_find_seqno(&fence, 0);
        dma_fence_put(fence);
        if (err) {
-               pr_err("Reported %d for find_seqno(0)!\n", err);
+               KUNIT_FAIL(test, "Reported %d for find_seqno(0)!", err);
                goto err;
        }
 
@@ -200,14 +194,13 @@ static int find_seqno(void *arg)
                err = dma_fence_chain_find_seqno(&fence, i + 1);
                dma_fence_put(fence);
                if (err) {
-                       pr_err("Reported %d for find_seqno(%d:%d)!\n",
-                              err, fc.chain_length + 1, i + 1);
+                       KUNIT_FAIL(test, "Reported %d for find_seqno(%d:%d)!",
+                                  err, fc.chain_length + 1, i + 1);
                        goto err;
                }
                if (fence != fc.chains[i]) {
-                       pr_err("Incorrect fence reported by 
find_seqno(%d:%d)\n",
-                              fc.chain_length + 1, i + 1);
-                       err = -EINVAL;
+                       KUNIT_FAIL(test, "Incorrect fence reported by 
find_seqno(%d:%d)",
+                                  fc.chain_length + 1, i + 1);
                        goto err;
                }
 
@@ -215,12 +208,11 @@ static int find_seqno(void *arg)
                err = dma_fence_chain_find_seqno(&fence, i + 1);
                dma_fence_put(fence);
                if (err) {
-                       pr_err("Error reported for finding self\n");
+                       KUNIT_FAIL(test, "Error reported for finding self");
                        goto err;
                }
                if (fence != fc.chains[i]) {
-                       pr_err("Incorrect fence reported by find self\n");
-                       err = -EINVAL;
+                       KUNIT_FAIL(test, "Incorrect fence reported by find 
self");
                        goto err;
                }
 
@@ -228,9 +220,8 @@ static int find_seqno(void *arg)
                err = dma_fence_chain_find_seqno(&fence, i + 2);
                dma_fence_put(fence);
                if (!err) {
-                       pr_err("Error not reported for future fence: 
find_seqno(%d:%d)!\n",
-                              i + 1, i + 2);
-                       err = -EINVAL;
+                       KUNIT_FAIL(test, "Error not reported for future fence: 
find_seqno(%d:%d)!",
+                                  i + 1, i + 2);
                        goto err;
                }
 
@@ -238,31 +229,28 @@ static int find_seqno(void *arg)
                err = dma_fence_chain_find_seqno(&fence, i);
                dma_fence_put(fence);
                if (err) {
-                       pr_err("Error reported for previous fence!\n");
+                       KUNIT_FAIL(test, "Error reported for previous fence!");
                        goto err;
                }
                if (i > 0 && fence != fc.chains[i - 1]) {
-                       pr_err("Incorrect fence reported by 
find_seqno(%d:%d)\n",
-                              i + 1, i);
-                       err = -EINVAL;
+                       KUNIT_FAIL(test, "Incorrect fence reported by 
find_seqno(%d:%d)",
+                                  i + 1, i);
                        goto err;
                }
        }
 
 err:
        fence_chains_fini(&fc);
-       return err;
 }
 
-static int find_signaled(void *arg)
+static void test_find_signaled(struct kunit *test)
 {
        struct fence_chains fc;
        struct dma_fence *fence;
        int err;
 
        err = fence_chains_init(&fc, 2, seqno_inc);
-       if (err)
-               return err;
+       KUNIT_ASSERT_EQ_MSG(test, err, 0, "Failed to init fence chains");
 
        dma_fence_signal(fc.fences[0]);
 
@@ -270,37 +258,33 @@ static int find_signaled(void *arg)
        err = dma_fence_chain_find_seqno(&fence, 1);
        dma_fence_put(fence);
        if (err) {
-               pr_err("Reported %d for find_seqno()!\n", err);
+               KUNIT_FAIL(test, "Reported %d for find_seqno()!", err);
                goto err;
        }
 
        if (fence && fence != fc.chains[0]) {
-               pr_err("Incorrect chain-fence.seqno:%lld reported for completed 
seqno:1\n",
-                      fence->seqno);
+               KUNIT_FAIL(test, "Incorrect chain-fence.seqno:%lld reported for 
completed seqno:1",
+                          fence->seqno);
 
                dma_fence_get(fence);
                err = dma_fence_chain_find_seqno(&fence, 1);
                dma_fence_put(fence);
                if (err)
-                       pr_err("Reported %d for finding self!\n", err);
-
-               err = -EINVAL;
+                       KUNIT_FAIL(test, "Reported %d for finding self!", err);
        }
 
 err:
        fence_chains_fini(&fc);
-       return err;
 }
 
-static int find_out_of_order(void *arg)
+static void test_find_out_of_order(struct kunit *test)
 {
        struct fence_chains fc;
        struct dma_fence *fence;
        int err;
 
        err = fence_chains_init(&fc, 3, seqno_inc);
-       if (err)
-               return err;
+       KUNIT_ASSERT_EQ_MSG(test, err, 0, "Failed to init fence chains");
 
        dma_fence_signal(fc.fences[1]);
 
@@ -308,7 +292,7 @@ static int find_out_of_order(void *arg)
        err = dma_fence_chain_find_seqno(&fence, 2);
        dma_fence_put(fence);
        if (err) {
-               pr_err("Reported %d for find_seqno()!\n", err);
+               KUNIT_FAIL(test, "Reported %d for find_seqno()!", err);
                goto err;
        }
 
@@ -319,16 +303,12 @@ static int find_out_of_order(void *arg)
         * we should get as fence to wait upon (fence 2 being garbage
         * collected during the traversal of the chain).
         */
-       if (fence != fc.chains[0]) {
-               pr_err("Incorrect chain-fence.seqno:%lld reported for completed 
seqno:2\n",
-                      fence ? fence->seqno : 0);
-
-               err = -EINVAL;
-       }
+       if (fence != fc.chains[0])
+               KUNIT_FAIL(test, "Incorrect chain-fence.seqno:%lld reported for 
completed seqno:2",
+                          fence ? fence->seqno : 0);
 
 err:
        fence_chains_fini(&fc);
-       return err;
 }
 
 static uint64_t seqno_inc2(unsigned int i)
@@ -336,7 +316,7 @@ static uint64_t seqno_inc2(unsigned int i)
        return 2 * i + 2;
 }
 
-static int find_gap(void *arg)
+static void test_find_gap(struct kunit *test)
 {
        struct fence_chains fc;
        struct dma_fence *fence;
@@ -344,24 +324,22 @@ static int find_gap(void *arg)
        int i;
 
        err = fence_chains_init(&fc, 64, seqno_inc2);
-       if (err)
-               return err;
+       KUNIT_ASSERT_EQ_MSG(test, err, 0, "Failed to init fence chains");
 
        for (i = 0; i < fc.chain_length; i++) {
                fence = dma_fence_get(fc.tail);
                err = dma_fence_chain_find_seqno(&fence, 2 * i + 1);
                dma_fence_put(fence);
                if (err) {
-                       pr_err("Reported %d for find_seqno(%d:%d)!\n",
-                              err, fc.chain_length + 1, 2 * i + 1);
+                       KUNIT_FAIL(test, "Reported %d for find_seqno(%d:%d)!",
+                                  err, fc.chain_length + 1, 2 * i + 1);
                        goto err;
                }
                if (fence != fc.chains[i]) {
-                       pr_err("Incorrect fence.seqno:%lld reported by 
find_seqno(%d:%d)\n",
-                              fence->seqno,
-                              fc.chain_length + 1,
-                              2 * i + 1);
-                       err = -EINVAL;
+                       KUNIT_FAIL(test, "Incorrect fence.seqno:%lld reported 
by find_seqno(%d:%d)",
+                                  fence->seqno,
+                                  fc.chain_length + 1,
+                                  2 * i + 1);
                        goto err;
                }
 
@@ -369,19 +347,17 @@ static int find_gap(void *arg)
                err = dma_fence_chain_find_seqno(&fence, 2 * i + 2);
                dma_fence_put(fence);
                if (err) {
-                       pr_err("Error reported for finding self\n");
+                       KUNIT_FAIL(test, "Error reported for finding self");
                        goto err;
                }
                if (fence != fc.chains[i]) {
-                       pr_err("Incorrect fence reported by find self\n");
-                       err = -EINVAL;
+                       KUNIT_FAIL(test, "Incorrect fence reported by find 
self");
                        goto err;
                }
        }
 
 err:
        fence_chains_fini(&fc);
-       return err;
 }
 
 struct find_race {
@@ -437,7 +413,7 @@ static int __find_race(void *arg)
        return err;
 }
 
-static int find_race(void *arg)
+static void test_find_race(struct kunit *test)
 {
        struct find_race data;
        int ncpus = num_online_cpus();
@@ -447,12 +423,11 @@ static int find_race(void *arg)
        int i;
 
        err = fence_chains_init(&data.fc, CHAIN_SZ, seqno_inc);
-       if (err)
-               return err;
+       KUNIT_ASSERT_EQ_MSG(test, err, 0, "Failed to init fence chains");
 
        threads = kmalloc_objs(*threads, ncpus);
        if (!threads) {
-               err = -ENOMEM;
+               KUNIT_FAIL(test, "Failed to allocate threads array");
                goto err;
        }
 
@@ -486,74 +461,67 @@ static int find_race(void *arg)
                        count++;
        pr_info("Completed %lu cycles\n", count);
 
+       KUNIT_EXPECT_EQ(test, err, 0);
+
 err:
        fence_chains_fini(&data.fc);
-       return err;
 }
 
-static int signal_forward(void *arg)
+static void test_signal_forward(struct kunit *test)
 {
        struct fence_chains fc;
        int err;
        int i;
 
        err = fence_chains_init(&fc, 64, seqno_inc);
-       if (err)
-               return err;
+       KUNIT_ASSERT_EQ_MSG(test, err, 0, "Failed to init fence chains");
 
        for (i = 0; i < fc.chain_length; i++) {
                dma_fence_signal(fc.fences[i]);
 
                if (!dma_fence_is_signaled(fc.chains[i])) {
-                       pr_err("chain[%d] not signaled!\n", i);
-                       err = -EINVAL;
+                       KUNIT_FAIL(test, "chain[%d] not signaled!", i);
                        goto err;
                }
 
                if (i + 1 < fc.chain_length &&
                    dma_fence_is_signaled(fc.chains[i + 1])) {
-                       pr_err("chain[%d] is signaled!\n", i);
-                       err = -EINVAL;
+                       KUNIT_FAIL(test, "chain[%d] is signaled!", i);
                        goto err;
                }
        }
 
 err:
        fence_chains_fini(&fc);
-       return err;
 }
 
-static int signal_backward(void *arg)
+static void test_signal_backward(struct kunit *test)
 {
        struct fence_chains fc;
        int err;
        int i;
 
        err = fence_chains_init(&fc, 64, seqno_inc);
-       if (err)
-               return err;
+       KUNIT_ASSERT_EQ_MSG(test, err, 0, "Failed to init fence chains");
 
        for (i = fc.chain_length; i--; ) {
                dma_fence_signal(fc.fences[i]);
 
                if (i > 0 && dma_fence_is_signaled(fc.chains[i])) {
-                       pr_err("chain[%d] is signaled!\n", i);
-                       err = -EINVAL;
+                       KUNIT_FAIL(test, "chain[%d] is signaled!", i);
                        goto err;
                }
        }
 
        for (i = 0; i < fc.chain_length; i++) {
                if (!dma_fence_is_signaled(fc.chains[i])) {
-                       pr_err("chain[%d] was not signaled!\n", i);
-                       err = -EINVAL;
+                       KUNIT_FAIL(test, "chain[%d] was not signaled!", i);
                        goto err;
                }
        }
 
 err:
        fence_chains_fini(&fc);
-       return err;
 }
 
 static int __wait_fence_chains(void *arg)
@@ -566,7 +534,7 @@ static int __wait_fence_chains(void *arg)
        return 0;
 }
 
-static int wait_forward(void *arg)
+static void test_wait_forward(struct kunit *test)
 {
        struct fence_chains fc;
        struct task_struct *tsk;
@@ -574,12 +542,11 @@ static int wait_forward(void *arg)
        int i;
 
        err = fence_chains_init(&fc, CHAIN_SZ, seqno_inc);
-       if (err)
-               return err;
+       KUNIT_ASSERT_EQ_MSG(test, err, 0, "Failed to init fence chains");
 
        tsk = kthread_run(__wait_fence_chains, &fc, "dmabuf/wait");
        if (IS_ERR(tsk)) {
-               err = PTR_ERR(tsk);
+               KUNIT_FAIL(test, "Failed to create kthread");
                goto err;
        }
        get_task_struct(tsk);
@@ -589,13 +556,13 @@ static int wait_forward(void *arg)
                dma_fence_signal(fc.fences[i]);
 
        err = kthread_stop_put(tsk);
+       KUNIT_EXPECT_EQ(test, err, 0);
 
 err:
        fence_chains_fini(&fc);
-       return err;
 }
 
-static int wait_backward(void *arg)
+static void test_wait_backward(struct kunit *test)
 {
        struct fence_chains fc;
        struct task_struct *tsk;
@@ -603,12 +570,11 @@ static int wait_backward(void *arg)
        int i;
 
        err = fence_chains_init(&fc, CHAIN_SZ, seqno_inc);
-       if (err)
-               return err;
+       KUNIT_ASSERT_EQ_MSG(test, err, 0, "Failed to init fence chains");
 
        tsk = kthread_run(__wait_fence_chains, &fc, "dmabuf/wait");
        if (IS_ERR(tsk)) {
-               err = PTR_ERR(tsk);
+               KUNIT_FAIL(test, "Failed to create kthread");
                goto err;
        }
        get_task_struct(tsk);
@@ -618,10 +584,10 @@ static int wait_backward(void *arg)
                dma_fence_signal(fc.fences[i]);
 
        err = kthread_stop_put(tsk);
+       KUNIT_EXPECT_EQ(test, err, 0);
 
 err:
        fence_chains_fini(&fc);
-       return err;
 }
 
 static void randomise_fences(struct fence_chains *fc)
@@ -640,7 +606,7 @@ static void randomise_fences(struct fence_chains *fc)
        }
 }
 
-static int wait_random(void *arg)
+static void test_wait_random(struct kunit *test)
 {
        struct fence_chains fc;
        struct task_struct *tsk;
@@ -648,14 +614,13 @@ static int wait_random(void *arg)
        int i;
 
        err = fence_chains_init(&fc, CHAIN_SZ, seqno_inc);
-       if (err)
-               return err;
+       KUNIT_ASSERT_EQ_MSG(test, err, 0, "Failed to init fence chains");
 
        randomise_fences(&fc);
 
        tsk = kthread_run(__wait_fence_chains, &fc, "dmabuf/wait");
        if (IS_ERR(tsk)) {
-               err = PTR_ERR(tsk);
+               KUNIT_FAIL(test, "Failed to create kthread");
                goto err;
        }
        get_task_struct(tsk);
@@ -665,29 +630,14 @@ static int wait_random(void *arg)
                dma_fence_signal(fc.fences[i]);
 
        err = kthread_stop_put(tsk);
+       KUNIT_EXPECT_EQ(test, err, 0);
 
 err:
        fence_chains_fini(&fc);
-       return err;
 }
 
-int dma_fence_chain(void)
+static int dma_fence_chain_suite_init(struct kunit_suite *suite)
 {
-       static const struct subtest tests[] = {
-               SUBTEST(sanitycheck),
-               SUBTEST(find_seqno),
-               SUBTEST(find_signaled),
-               SUBTEST(find_out_of_order),
-               SUBTEST(find_gap),
-               SUBTEST(find_race),
-               SUBTEST(signal_forward),
-               SUBTEST(signal_backward),
-               SUBTEST(wait_forward),
-               SUBTEST(wait_backward),
-               SUBTEST(wait_random),
-       };
-       int ret;
-
        pr_info("sizeof(dma_fence_chain)=%zu\n",
                sizeof(struct dma_fence_chain));
 
@@ -696,9 +646,34 @@ int dma_fence_chain(void)
                                 SLAB_HWCACHE_ALIGN);
        if (!slab_fences)
                return -ENOMEM;
-
-       ret = subtests(tests, NULL);
-
-       kmem_cache_destroy(slab_fences);
-       return ret;
+       return 0;
 }
+
+static void dma_fence_chain_suite_exit(struct kunit_suite *suite)
+{
+       kmem_cache_destroy(slab_fences);
+}
+
+static struct kunit_case dma_fence_chain_cases[] = {
+       KUNIT_CASE(test_sanitycheck),
+       KUNIT_CASE(test_find_seqno),
+       KUNIT_CASE(test_find_signaled),
+       KUNIT_CASE(test_find_out_of_order),
+       KUNIT_CASE(test_find_gap),
+       KUNIT_CASE(test_find_race),
+       KUNIT_CASE(test_signal_forward),
+       KUNIT_CASE(test_signal_backward),
+       KUNIT_CASE(test_wait_forward),
+       KUNIT_CASE(test_wait_backward),
+       KUNIT_CASE(test_wait_random),
+       {}
+};
+
+static struct kunit_suite dma_fence_chain_test_suite = {
+       .name = "dma-buf-fence-chain",
+       .suite_init = dma_fence_chain_suite_init,
+       .suite_exit = dma_fence_chain_suite_exit,
+       .test_cases = dma_fence_chain_cases,
+};
+
+kunit_test_suite(dma_fence_chain_test_suite);
-- 
2.43.0

Reply via email to