diff options
-rw-r--r-- | lib/Kconfig.debug | 24 | ||||
-rw-r--r-- | lib/Makefile | 1 | ||||
-rw-r--r-- | lib/pm-notifier-error-inject.c | 49 |
3 files changed, 74 insertions, 0 deletions
diff --git a/lib/Kconfig.debug b/lib/Kconfig.debug index 20341480bb54..c2024d86fb12 100644 --- a/lib/Kconfig.debug +++ b/lib/Kconfig.debug | |||
@@ -1119,6 +1119,30 @@ config CPU_NOTIFIER_ERROR_INJECT | |||
1119 | 1119 | ||
1120 | If unsure, say N. | 1120 | If unsure, say N. |
1121 | 1121 | ||
1122 | config PM_NOTIFIER_ERROR_INJECT | ||
1123 | tristate "PM notifier error injection module" | ||
1124 | depends on PM && NOTIFIER_ERROR_INJECTION | ||
1125 | default m if PM_DEBUG | ||
1126 | help | ||
1127 | This option provides the ability to inject artifical errors to | ||
1128 | PM notifier chain callbacks. It is controlled through debugfs | ||
1129 | interface /sys/kernel/debug/notifier-error-inject/pm | ||
1130 | |||
1131 | If the notifier call chain should be failed with some events | ||
1132 | notified, write the error code to "actions/<notifier event>/error". | ||
1133 | |||
1134 | Example: Inject PM suspend error (-12 = -ENOMEM) | ||
1135 | |||
1136 | # cd /sys/kernel/debug/notifier-error-inject/pm/ | ||
1137 | # echo -12 > actions/PM_SUSPEND_PREPARE/error | ||
1138 | # echo mem > /sys/power/state | ||
1139 | bash: echo: write error: Cannot allocate memory | ||
1140 | |||
1141 | To compile this code as a module, choose M here: the module will | ||
1142 | be called pm-notifier-error-inject. | ||
1143 | |||
1144 | If unsure, say N. | ||
1145 | |||
1122 | config FAULT_INJECTION | 1146 | config FAULT_INJECTION |
1123 | bool "Fault-injection framework" | 1147 | bool "Fault-injection framework" |
1124 | depends on DEBUG_KERNEL | 1148 | depends on DEBUG_KERNEL |
diff --git a/lib/Makefile b/lib/Makefile index 71acfa4489f3..c32c66473ba1 100644 --- a/lib/Makefile +++ b/lib/Makefile | |||
@@ -92,6 +92,7 @@ obj-$(CONFIG_IOMMU_HELPER) += iommu-helper.o | |||
92 | obj-$(CONFIG_FAULT_INJECTION) += fault-inject.o | 92 | obj-$(CONFIG_FAULT_INJECTION) += fault-inject.o |
93 | obj-$(CONFIG_NOTIFIER_ERROR_INJECTION) += notifier-error-inject.o | 93 | obj-$(CONFIG_NOTIFIER_ERROR_INJECTION) += notifier-error-inject.o |
94 | obj-$(CONFIG_CPU_NOTIFIER_ERROR_INJECT) += cpu-notifier-error-inject.o | 94 | obj-$(CONFIG_CPU_NOTIFIER_ERROR_INJECT) += cpu-notifier-error-inject.o |
95 | obj-$(CONFIG_PM_NOTIFIER_ERROR_INJECT) += pm-notifier-error-inject.o | ||
95 | 96 | ||
96 | lib-$(CONFIG_GENERIC_BUG) += bug.o | 97 | lib-$(CONFIG_GENERIC_BUG) += bug.o |
97 | 98 | ||
diff --git a/lib/pm-notifier-error-inject.c b/lib/pm-notifier-error-inject.c new file mode 100644 index 000000000000..c094b2dedc23 --- /dev/null +++ b/lib/pm-notifier-error-inject.c | |||
@@ -0,0 +1,49 @@ | |||
1 | #include <linux/kernel.h> | ||
2 | #include <linux/module.h> | ||
3 | #include <linux/suspend.h> | ||
4 | |||
5 | #include "notifier-error-inject.h" | ||
6 | |||
7 | static int priority; | ||
8 | module_param(priority, int, 0); | ||
9 | MODULE_PARM_DESC(priority, "specify PM notifier priority"); | ||
10 | |||
11 | static struct notifier_err_inject pm_notifier_err_inject = { | ||
12 | .actions = { | ||
13 | { NOTIFIER_ERR_INJECT_ACTION(PM_HIBERNATION_PREPARE) }, | ||
14 | { NOTIFIER_ERR_INJECT_ACTION(PM_SUSPEND_PREPARE) }, | ||
15 | { NOTIFIER_ERR_INJECT_ACTION(PM_RESTORE_PREPARE) }, | ||
16 | {} | ||
17 | } | ||
18 | }; | ||
19 | |||
20 | static struct dentry *dir; | ||
21 | |||
22 | static int err_inject_init(void) | ||
23 | { | ||
24 | int err; | ||
25 | |||
26 | dir = notifier_err_inject_init("pm", notifier_err_inject_dir, | ||
27 | &pm_notifier_err_inject, priority); | ||
28 | if (IS_ERR(dir)) | ||
29 | return PTR_ERR(dir); | ||
30 | |||
31 | err = register_pm_notifier(&pm_notifier_err_inject.nb); | ||
32 | if (err) | ||
33 | debugfs_remove_recursive(dir); | ||
34 | |||
35 | return err; | ||
36 | } | ||
37 | |||
38 | static void err_inject_exit(void) | ||
39 | { | ||
40 | unregister_pm_notifier(&pm_notifier_err_inject.nb); | ||
41 | debugfs_remove_recursive(dir); | ||
42 | } | ||
43 | |||
44 | module_init(err_inject_init); | ||
45 | module_exit(err_inject_exit); | ||
46 | |||
47 | MODULE_DESCRIPTION("PM notifier error injection module"); | ||
48 | MODULE_LICENSE("GPL"); | ||
49 | MODULE_AUTHOR("Akinobu Mita <akinobu.mita@gmail.com>"); | ||