Commit 2a6526c4 authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'linux_kselftest-kunit-fixes-6.8-rc3' of...

Merge tag 'linux_kselftest-kunit-fixes-6.8-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest

Pull kunit fixes from Shuah Khan:
 "NULL vs IS_ERR() bug fixes, documentation update, MAINTAINERS file
  update to add Rae Moar as a reviewer, and a fix to run test suites
  only after module initialization completes"

* tag 'linux_kselftest-kunit-fixes-6.8-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest:
  Documentation: KUnit: Update the instructions on how to test static functions
  kunit: run test suites only after module initialization completes
  MAINTAINERS: kunit: Add Rae Moar as a reviewer
  kunit: device: Fix a NULL vs IS_ERR() check in init()
  kunit: Fix a NULL vs IS_ERR() bug
parents d1d873a9 1a9f2c77
...@@ -671,8 +671,23 @@ Testing Static Functions ...@@ -671,8 +671,23 @@ Testing Static Functions
------------------------ ------------------------
If we do not want to expose functions or variables for testing, one option is to If we do not want to expose functions or variables for testing, one option is to
conditionally ``#include`` the test file at the end of your .c file. For conditionally export the used symbol. For example:
example:
.. code-block:: c
/* In my_file.c */
VISIBLE_IF_KUNIT int do_interesting_thing();
EXPORT_SYMBOL_IF_KUNIT(do_interesting_thing);
/* In my_file.h */
#if IS_ENABLED(CONFIG_KUNIT)
int do_interesting_thing(void);
#endif
Alternatively, you could conditionally ``#include`` the test file at the end of
your .c file. For example:
.. code-block:: c .. code-block:: c
......
...@@ -11725,6 +11725,7 @@ F: fs/smb/server/ ...@@ -11725,6 +11725,7 @@ F: fs/smb/server/
KERNEL UNIT TESTING FRAMEWORK (KUnit) KERNEL UNIT TESTING FRAMEWORK (KUnit)
M: Brendan Higgins <brendanhiggins@google.com> M: Brendan Higgins <brendanhiggins@google.com>
M: David Gow <davidgow@google.com> M: David Gow <davidgow@google.com>
R: Rae Moar <rmoar@google.com>
L: linux-kselftest@vger.kernel.org L: linux-kselftest@vger.kernel.org
L: kunit-dev@googlegroups.com L: kunit-dev@googlegroups.com
S: Maintained S: Maintained
......
...@@ -45,8 +45,8 @@ int kunit_bus_init(void) ...@@ -45,8 +45,8 @@ int kunit_bus_init(void)
int error; int error;
kunit_bus_device = root_device_register("kunit"); kunit_bus_device = root_device_register("kunit");
if (!kunit_bus_device) if (IS_ERR(kunit_bus_device))
return -ENOMEM; return PTR_ERR(kunit_bus_device);
error = bus_register(&kunit_bus_type); error = bus_register(&kunit_bus_type);
if (error) if (error)
......
...@@ -146,6 +146,10 @@ void kunit_free_suite_set(struct kunit_suite_set suite_set) ...@@ -146,6 +146,10 @@ void kunit_free_suite_set(struct kunit_suite_set suite_set)
kfree(suite_set.start); kfree(suite_set.start);
} }
/*
* Filter and reallocate test suites. Must return the filtered test suites set
* allocated at a valid virtual address or NULL in case of error.
*/
struct kunit_suite_set struct kunit_suite_set
kunit_filter_suites(const struct kunit_suite_set *suite_set, kunit_filter_suites(const struct kunit_suite_set *suite_set,
const char *filter_glob, const char *filter_glob,
......
...@@ -720,7 +720,7 @@ static void kunit_device_cleanup_test(struct kunit *test) ...@@ -720,7 +720,7 @@ static void kunit_device_cleanup_test(struct kunit *test)
long action_was_run = 0; long action_was_run = 0;
test_device = kunit_device_register(test, "my_device"); test_device = kunit_device_register(test, "my_device");
KUNIT_ASSERT_NOT_NULL(test, test_device); KUNIT_ASSERT_NOT_ERR_OR_NULL(test, test_device);
/* Add an action to verify cleanup. */ /* Add an action to verify cleanup. */
devm_add_action(test_device, test_dev_action, &action_was_run); devm_add_action(test_device, test_dev_action, &action_was_run);
......
...@@ -17,6 +17,7 @@ ...@@ -17,6 +17,7 @@
#include <linux/panic.h> #include <linux/panic.h>
#include <linux/sched/debug.h> #include <linux/sched/debug.h>
#include <linux/sched.h> #include <linux/sched.h>
#include <linux/mm.h>
#include "debugfs.h" #include "debugfs.h"
#include "device-impl.h" #include "device-impl.h"
...@@ -801,12 +802,19 @@ static void kunit_module_exit(struct module *mod) ...@@ -801,12 +802,19 @@ static void kunit_module_exit(struct module *mod)
}; };
const char *action = kunit_action(); const char *action = kunit_action();
/*
* Check if the start address is a valid virtual address to detect
* if the module load sequence has failed and the suite set has not
* been initialized and filtered.
*/
if (!suite_set.start || !virt_addr_valid(suite_set.start))
return;
if (!action) if (!action)
__kunit_test_suites_exit(mod->kunit_suites, __kunit_test_suites_exit(mod->kunit_suites,
mod->num_kunit_suites); mod->num_kunit_suites);
if (suite_set.start) kunit_free_suite_set(suite_set);
kunit_free_suite_set(suite_set);
} }
static int kunit_module_notify(struct notifier_block *nb, unsigned long val, static int kunit_module_notify(struct notifier_block *nb, unsigned long val,
...@@ -816,12 +824,12 @@ static int kunit_module_notify(struct notifier_block *nb, unsigned long val, ...@@ -816,12 +824,12 @@ static int kunit_module_notify(struct notifier_block *nb, unsigned long val,
switch (val) { switch (val) {
case MODULE_STATE_LIVE: case MODULE_STATE_LIVE:
kunit_module_init(mod);
break; break;
case MODULE_STATE_GOING: case MODULE_STATE_GOING:
kunit_module_exit(mod); kunit_module_exit(mod);
break; break;
case MODULE_STATE_COMING: case MODULE_STATE_COMING:
kunit_module_init(mod);
break; break;
case MODULE_STATE_UNFORMED: case MODULE_STATE_UNFORMED:
break; break;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment