109c434b8SThomas Gleixner // SPDX-License-Identifier: GPL-2.0-only
2d526e85fSBenjamin Herrenschmidt #include <linux/kernel.h>
3d526e85fSBenjamin Herrenschmidt #include <linux/module.h>
4d526e85fSBenjamin Herrenschmidt #include <linux/of.h>
5d526e85fSBenjamin Herrenschmidt 
6d526e85fSBenjamin Herrenschmidt #include "notifier-error-inject.h"
7d526e85fSBenjamin Herrenschmidt 
8d526e85fSBenjamin Herrenschmidt static int priority;
9d526e85fSBenjamin Herrenschmidt module_param(priority, int, 0);
10d526e85fSBenjamin Herrenschmidt MODULE_PARM_DESC(priority, "specify OF reconfig notifier priority");
11d526e85fSBenjamin Herrenschmidt 
12d526e85fSBenjamin Herrenschmidt static struct notifier_err_inject reconfig_err_inject = {
13d526e85fSBenjamin Herrenschmidt 	.actions = {
14d526e85fSBenjamin Herrenschmidt 		{ NOTIFIER_ERR_INJECT_ACTION(OF_RECONFIG_ATTACH_NODE) },
15d526e85fSBenjamin Herrenschmidt 		{ NOTIFIER_ERR_INJECT_ACTION(OF_RECONFIG_DETACH_NODE) },
16d526e85fSBenjamin Herrenschmidt 		{ NOTIFIER_ERR_INJECT_ACTION(OF_RECONFIG_ADD_PROPERTY) },
17d526e85fSBenjamin Herrenschmidt 		{ NOTIFIER_ERR_INJECT_ACTION(OF_RECONFIG_REMOVE_PROPERTY) },
18d526e85fSBenjamin Herrenschmidt 		{ NOTIFIER_ERR_INJECT_ACTION(OF_RECONFIG_UPDATE_PROPERTY) },
19d526e85fSBenjamin Herrenschmidt 		{}
20d526e85fSBenjamin Herrenschmidt 	}
21d526e85fSBenjamin Herrenschmidt };
22d526e85fSBenjamin Herrenschmidt 
23d526e85fSBenjamin Herrenschmidt static struct dentry *dir;
24d526e85fSBenjamin Herrenschmidt 
err_inject_init(void)25d526e85fSBenjamin Herrenschmidt static int err_inject_init(void)
26d526e85fSBenjamin Herrenschmidt {
27d526e85fSBenjamin Herrenschmidt 	int err;
28d526e85fSBenjamin Herrenschmidt 
29d526e85fSBenjamin Herrenschmidt 	dir = notifier_err_inject_init("OF-reconfig",
30d526e85fSBenjamin Herrenschmidt 		notifier_err_inject_dir, &reconfig_err_inject, priority);
31d526e85fSBenjamin Herrenschmidt 	if (IS_ERR(dir))
32d526e85fSBenjamin Herrenschmidt 		return PTR_ERR(dir);
33d526e85fSBenjamin Herrenschmidt 
34d526e85fSBenjamin Herrenschmidt 	err = of_reconfig_notifier_register(&reconfig_err_inject.nb);
35d526e85fSBenjamin Herrenschmidt 	if (err)
36d526e85fSBenjamin Herrenschmidt 		debugfs_remove_recursive(dir);
37d526e85fSBenjamin Herrenschmidt 
38d526e85fSBenjamin Herrenschmidt 	return err;
39d526e85fSBenjamin Herrenschmidt }
40d526e85fSBenjamin Herrenschmidt 
err_inject_exit(void)41d526e85fSBenjamin Herrenschmidt static void err_inject_exit(void)
42d526e85fSBenjamin Herrenschmidt {
43d526e85fSBenjamin Herrenschmidt 	of_reconfig_notifier_unregister(&reconfig_err_inject.nb);
44d526e85fSBenjamin Herrenschmidt 	debugfs_remove_recursive(dir);
45d526e85fSBenjamin Herrenschmidt }
46d526e85fSBenjamin Herrenschmidt 
47d526e85fSBenjamin Herrenschmidt module_init(err_inject_init);
48d526e85fSBenjamin Herrenschmidt module_exit(err_inject_exit);
49d526e85fSBenjamin Herrenschmidt 
50d526e85fSBenjamin Herrenschmidt MODULE_DESCRIPTION("OF reconfig notifier error injection module");
51d526e85fSBenjamin Herrenschmidt MODULE_LICENSE("GPL");
52d526e85fSBenjamin Herrenschmidt MODULE_AUTHOR("Akinobu Mita <akinobu.mita@gmail.com>");
53