diff options
Diffstat (limited to 'lib/cpu-notifier-error-inject.c')
| -rw-r--r-- | lib/cpu-notifier-error-inject.c | 63 |
1 files changed, 25 insertions, 38 deletions
diff --git a/lib/cpu-notifier-error-inject.c b/lib/cpu-notifier-error-inject.c index 4dc20321b0d5..707ca24f7b18 100644 --- a/lib/cpu-notifier-error-inject.c +++ b/lib/cpu-notifier-error-inject.c | |||
| @@ -1,58 +1,45 @@ | |||
| 1 | #include <linux/kernel.h> | 1 | #include <linux/kernel.h> |
| 2 | #include <linux/cpu.h> | ||
| 3 | #include <linux/module.h> | 2 | #include <linux/module.h> |
| 4 | #include <linux/notifier.h> | 3 | #include <linux/cpu.h> |
| 5 | 4 | ||
| 6 | static int priority; | 5 | #include "notifier-error-inject.h" |
| 7 | static int cpu_up_prepare_error; | ||
| 8 | static int cpu_down_prepare_error; | ||
| 9 | 6 | ||
| 7 | static int priority; | ||
| 10 | module_param(priority, int, 0); | 8 | module_param(priority, int, 0); |
| 11 | MODULE_PARM_DESC(priority, "specify cpu notifier priority"); | 9 | MODULE_PARM_DESC(priority, "specify cpu notifier priority"); |
| 12 | 10 | ||
| 13 | module_param(cpu_up_prepare_error, int, 0644); | 11 | static struct notifier_err_inject cpu_notifier_err_inject = { |
| 14 | MODULE_PARM_DESC(cpu_up_prepare_error, | 12 | .actions = { |
| 15 | "specify error code to inject CPU_UP_PREPARE action"); | 13 | { NOTIFIER_ERR_INJECT_ACTION(CPU_UP_PREPARE) }, |
| 16 | 14 | { NOTIFIER_ERR_INJECT_ACTION(CPU_UP_PREPARE_FROZEN) }, | |
| 17 | module_param(cpu_down_prepare_error, int, 0644); | 15 | { NOTIFIER_ERR_INJECT_ACTION(CPU_DOWN_PREPARE) }, |
| 18 | MODULE_PARM_DESC(cpu_down_prepare_error, | 16 | { NOTIFIER_ERR_INJECT_ACTION(CPU_DOWN_PREPARE_FROZEN) }, |
| 19 | "specify error code to inject CPU_DOWN_PREPARE action"); | 17 | {} |
| 20 | |||
| 21 | static int err_inject_cpu_callback(struct notifier_block *nfb, | ||
| 22 | unsigned long action, void *hcpu) | ||
| 23 | { | ||
| 24 | int err = 0; | ||
| 25 | |||
| 26 | switch (action) { | ||
| 27 | case CPU_UP_PREPARE: | ||
| 28 | case CPU_UP_PREPARE_FROZEN: | ||
| 29 | err = cpu_up_prepare_error; | ||
| 30 | break; | ||
| 31 | case CPU_DOWN_PREPARE: | ||
| 32 | case CPU_DOWN_PREPARE_FROZEN: | ||
| 33 | err = cpu_down_prepare_error; | ||
| 34 | break; | ||
| 35 | } | 18 | } |
| 36 | if (err) | ||
| 37 | printk(KERN_INFO "Injecting error (%d) at cpu notifier\n", err); | ||
| 38 | |||
| 39 | return notifier_from_errno(err); | ||
| 40 | } | ||
| 41 | |||
| 42 | static struct notifier_block err_inject_cpu_notifier = { | ||
| 43 | .notifier_call = err_inject_cpu_callback, | ||
| 44 | }; | 19 | }; |
| 45 | 20 | ||
| 21 | static struct dentry *dir; | ||
| 22 | |||
| 46 | static int err_inject_init(void) | 23 | static int err_inject_init(void) |
| 47 | { | 24 | { |
| 48 | err_inject_cpu_notifier.priority = priority; | 25 | int err; |
| 26 | |||
| 27 | dir = notifier_err_inject_init("cpu", notifier_err_inject_dir, | ||
| 28 | &cpu_notifier_err_inject, priority); | ||
| 29 | if (IS_ERR(dir)) | ||
| 30 | return PTR_ERR(dir); | ||
| 31 | |||
| 32 | err = register_hotcpu_notifier(&cpu_notifier_err_inject.nb); | ||
| 33 | if (err) | ||
| 34 | debugfs_remove_recursive(dir); | ||
| 49 | 35 | ||
| 50 | return register_hotcpu_notifier(&err_inject_cpu_notifier); | 36 | return err; |
| 51 | } | 37 | } |
| 52 | 38 | ||
| 53 | static void err_inject_exit(void) | 39 | static void err_inject_exit(void) |
| 54 | { | 40 | { |
| 55 | unregister_hotcpu_notifier(&err_inject_cpu_notifier); | 41 | unregister_hotcpu_notifier(&cpu_notifier_err_inject.nb); |
| 42 | debugfs_remove_recursive(dir); | ||
| 56 | } | 43 | } |
| 57 | 44 | ||
| 58 | module_init(err_inject_init); | 45 | module_init(err_inject_init); |
