diff options
author | Akinobu Mita <akinobu.mita@gmail.com> | 2006-12-08 05:39:48 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.osdl.org> | 2006-12-08 11:29:03 -0500 |
commit | 329409aeda064c4aff00c51f837fcd3bbdaeeba6 (patch) | |
tree | d22890da0d4f8d9f37bb1e9344cf41387a0a23f9 /include | |
parent | f4f154fd920b2178382a6a24a236348e4429ebc1 (diff) |
[PATCH] fault injection: stacktrace filtering
This patch provides stacktrace filtering feature.
The stacktrace filter allows failing only for the caller you are
interested in.
For example someone may want to inject kmalloc() failures into
only e100 module. they want to inject not only direct kmalloc() call,
but also indirect allocation, too.
- e100_poll --> netif_receive_skb --> packet_rcv_spkt --> skb_clone
--> kmem_cache_alloc
This patch enables to detect function calls like this by stacktrace
and inject failures. The script Documentaion/fault-injection/failmodule.sh
helps it.
The range of text section of loaded e100 is expected to be
[/sys/module/e100/sections/.text, /sys/module/e100/sections/.exit.text)
So failmodule.sh stores these values into /debug/failslab/address-start
and /debug/failslab/address-end. The maximum stacktrace depth is specified
by /debug/failslab/stacktrace-depth.
Please see the example that demonstrates how to inject slab allocation
failures only for a specific module
in Documentation/fault-injection/fault-injection.txt
[dwm@meer.net: reject failure if any caller lies within specified range]
Signed-off-by: Akinobu Mita <akinobu.mita@gmail.com>
Signed-off-by: Don Mullis <dwm@meer.net>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'include')
-rw-r--r-- | include/linux/fault-inject.h | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/include/linux/fault-inject.h b/include/linux/fault-inject.h index a525f9b9f015..9bb584e89399 100644 --- a/include/linux/fault-inject.h +++ b/include/linux/fault-inject.h | |||
@@ -18,6 +18,11 @@ struct fault_attr { | |||
18 | atomic_t space; | 18 | atomic_t space; |
19 | unsigned long verbose; | 19 | unsigned long verbose; |
20 | u32 task_filter; | 20 | u32 task_filter; |
21 | unsigned long stacktrace_depth; | ||
22 | unsigned long require_start; | ||
23 | unsigned long require_end; | ||
24 | unsigned long reject_start; | ||
25 | unsigned long reject_end; | ||
21 | 26 | ||
22 | unsigned long count; | 27 | unsigned long count; |
23 | 28 | ||
@@ -32,6 +37,11 @@ struct fault_attr { | |||
32 | struct dentry *space_file; | 37 | struct dentry *space_file; |
33 | struct dentry *verbose_file; | 38 | struct dentry *verbose_file; |
34 | struct dentry *task_filter_file; | 39 | struct dentry *task_filter_file; |
40 | struct dentry *stacktrace_depth_file; | ||
41 | struct dentry *require_start_file; | ||
42 | struct dentry *require_end_file; | ||
43 | struct dentry *reject_start_file; | ||
44 | struct dentry *reject_end_file; | ||
35 | } dentries; | 45 | } dentries; |
36 | 46 | ||
37 | #endif | 47 | #endif |
@@ -40,6 +50,8 @@ struct fault_attr { | |||
40 | #define FAULT_ATTR_INITIALIZER { \ | 50 | #define FAULT_ATTR_INITIALIZER { \ |
41 | .interval = 1, \ | 51 | .interval = 1, \ |
42 | .times = ATOMIC_INIT(1), \ | 52 | .times = ATOMIC_INIT(1), \ |
53 | .require_end = ULONG_MAX, \ | ||
54 | .stacktrace_depth = 32, \ | ||
43 | } | 55 | } |
44 | 56 | ||
45 | #define DECLARE_FAULT_ATTR(name) struct fault_attr name = FAULT_ATTR_INITIALIZER | 57 | #define DECLARE_FAULT_ATTR(name) struct fault_attr name = FAULT_ATTR_INITIALIZER |