test_cache_destroy();
 }
 
-static struct kunit_suite kfence_test_suite = {
-       .name = "kfence",
-       .test_cases = kfence_test_cases,
-       .init = test_init,
-       .exit = test_exit,
-};
-static struct kunit_suite *kfence_test_suites[] = { &kfence_test_suite, NULL };
-
 static void register_tracepoints(struct tracepoint *tp, void *ignore)
 {
        check_trace_callback_type_console(probe_console);
                tracepoint_probe_unregister(tp, probe_console, NULL);
 }
 
-/*
- * We only want to do tracepoints setup and teardown once, therefore we have to
- * customize the init and exit functions and cannot rely on kunit_test_suite().
- */
-static int __init kfence_test_init(void)
+static int kfence_suite_init(struct kunit_suite *suite)
 {
        /*
         * Because we want to be able to build the test as a module, we need to
         * won't work here.
         */
        for_each_kernel_tracepoint(register_tracepoints, NULL);
-       return __kunit_test_suites_init(kfence_test_suites);
+       return 0;
 }
 
-static void kfence_test_exit(void)
+static void kfence_suite_exit(struct kunit_suite *suite)
 {
-       __kunit_test_suites_exit(kfence_test_suites);
        for_each_kernel_tracepoint(unregister_tracepoints, NULL);
        tracepoint_synchronize_unregister();
 }
 
-late_initcall_sync(kfence_test_init);
-module_exit(kfence_test_exit);
+static struct kunit_suite kfence_test_suite = {
+       .name = "kfence",
+       .test_cases = kfence_test_cases,
+       .init = test_init,
+       .exit = test_exit,
+       .suite_init = kfence_suite_init,
+       .suite_exit = kfence_suite_exit,
+};
+
+kunit_test_suites(&kfence_test_suite);
 
 MODULE_LICENSE("GPL v2");
 MODULE_AUTHOR("Alexander Potapenko <glider@google.com>, Marco Elver <elver@google.com>");