diff options
Diffstat (limited to 'lib')
| -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>"); | ||
