diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-07-30 20:25:34 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-07-30 20:25:34 -0400 |
commit | 27c1ee3f929555b71fa39ec0d81a7e7185de1b16 (patch) | |
tree | 42e40bdfe4efac660d650658019391536ce67a42 /lib/pSeries-reconfig-notifier-error-inject.c | |
parent | 37cd9600a9e20359b0283983c9e3a55d84347168 (diff) | |
parent | 086ff4b3a7fb9cdf41e6a5d0ccd99b86d84633a1 (diff) |
Merge branch 'akpm' (Andrew's patch-bomb)
Merge Andrew's first set of patches:
"Non-MM patches:
- lots of misc bits
- tree-wide have_clk() cleanups
- quite a lot of printk tweaks. I draw your attention to "printk:
convert the format for KERN_<LEVEL> to a 2 byte pattern" which
looks a bit scary. But afaict it's solid.
- backlight updates
- lib/ feature work (notably the addition and use of memweight())
- checkpatch updates
- rtc updates
- nilfs updates
- fatfs updates (partial, still waiting for acks)
- kdump, proc, fork, IPC, sysctl, taskstats, pps, etc
- new fault-injection feature work"
* Merge emailed patches from Andrew Morton <akpm@linux-foundation.org>: (128 commits)
drivers/misc/lkdtm.c: fix missing allocation failure check
lib/scatterlist: do not re-write gfp_flags in __sg_alloc_table()
fault-injection: add tool to run command with failslab or fail_page_alloc
fault-injection: add selftests for cpu and memory hotplug
powerpc: pSeries reconfig notifier error injection module
memory: memory notifier error injection module
PM: PM notifier error injection module
cpu: rewrite cpu-notifier-error-inject module
fault-injection: notifier error injection
c/r: fcntl: add F_GETOWNER_UIDS option
resource: make sure requested range is included in the root range
include/linux/aio.h: cpp->C conversions
fs: cachefiles: add support for large files in filesystem caching
pps: return PTR_ERR on error in device_create
taskstats: check nla_reserve() return
sysctl: suppress kmemleak messages
ipc: use Kconfig options for __ARCH_WANT_[COMPAT_]IPC_PARSE_VERSION
ipc: compat: use signed size_t types for msgsnd and msgrcv
ipc: allow compat IPC version field parsing if !ARCH_WANT_OLD_COMPAT_IPC
ipc: add COMPAT_SHMLBA support
...
Diffstat (limited to 'lib/pSeries-reconfig-notifier-error-inject.c')
-rw-r--r-- | lib/pSeries-reconfig-notifier-error-inject.c | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/lib/pSeries-reconfig-notifier-error-inject.c b/lib/pSeries-reconfig-notifier-error-inject.c new file mode 100644 index 000000000000..7f7c98dcd5c4 --- /dev/null +++ b/lib/pSeries-reconfig-notifier-error-inject.c | |||
@@ -0,0 +1,51 @@ | |||
1 | #include <linux/kernel.h> | ||
2 | #include <linux/module.h> | ||
3 | |||
4 | #include <asm/pSeries_reconfig.h> | ||
5 | |||
6 | #include "notifier-error-inject.h" | ||
7 | |||
8 | static int priority; | ||
9 | module_param(priority, int, 0); | ||
10 | MODULE_PARM_DESC(priority, "specify pSeries reconfig notifier priority"); | ||
11 | |||
12 | static struct notifier_err_inject reconfig_err_inject = { | ||
13 | .actions = { | ||
14 | { NOTIFIER_ERR_INJECT_ACTION(PSERIES_RECONFIG_ADD) }, | ||
15 | { NOTIFIER_ERR_INJECT_ACTION(PSERIES_RECONFIG_REMOVE) }, | ||
16 | { NOTIFIER_ERR_INJECT_ACTION(PSERIES_DRCONF_MEM_ADD) }, | ||
17 | { NOTIFIER_ERR_INJECT_ACTION(PSERIES_DRCONF_MEM_REMOVE) }, | ||
18 | {} | ||
19 | } | ||
20 | }; | ||
21 | |||
22 | static struct dentry *dir; | ||
23 | |||
24 | static int err_inject_init(void) | ||
25 | { | ||
26 | int err; | ||
27 | |||
28 | dir = notifier_err_inject_init("pSeries-reconfig", | ||
29 | notifier_err_inject_dir, &reconfig_err_inject, priority); | ||
30 | if (IS_ERR(dir)) | ||
31 | return PTR_ERR(dir); | ||
32 | |||
33 | err = pSeries_reconfig_notifier_register(&reconfig_err_inject.nb); | ||
34 | if (err) | ||
35 | debugfs_remove_recursive(dir); | ||
36 | |||
37 | return err; | ||
38 | } | ||
39 | |||
40 | static void err_inject_exit(void) | ||
41 | { | ||
42 | pSeries_reconfig_notifier_unregister(&reconfig_err_inject.nb); | ||
43 | debugfs_remove_recursive(dir); | ||
44 | } | ||
45 | |||
46 | module_init(err_inject_init); | ||
47 | module_exit(err_inject_exit); | ||
48 | |||
49 | MODULE_DESCRIPTION("pSeries reconfig notifier error injection module"); | ||
50 | MODULE_LICENSE("GPL"); | ||
51 | MODULE_AUTHOR("Akinobu Mita <akinobu.mita@gmail.com>"); | ||