Blame view
mm/failslab.c
1.37 KB
b24413180
|
1 |
// SPDX-License-Identifier: GPL-2.0 |
773ff60e8
|
2 |
#include <linux/fault-inject.h> |
4c13dd3b4
|
3 |
#include <linux/slab.h> |
fab9963a6
|
4 5 |
#include <linux/mm.h> #include "slab.h" |
773ff60e8
|
6 7 8 |
static struct { struct fault_attr attr; |
71baba4b9
|
9 |
bool ignore_gfp_reclaim; |
621a5f7ad
|
10 |
bool cache_filter; |
773ff60e8
|
11 12 |
} failslab = { .attr = FAULT_ATTR_INITIALIZER, |
71baba4b9
|
13 |
.ignore_gfp_reclaim = true, |
621a5f7ad
|
14 |
.cache_filter = false, |
773ff60e8
|
15 |
}; |
4f6923fbb
|
16 |
bool __should_failslab(struct kmem_cache *s, gfp_t gfpflags) |
773ff60e8
|
17 |
{ |
fab9963a6
|
18 19 20 |
/* No fault-injection for bootstrap cache */ if (unlikely(s == kmem_cache)) return false; |
773ff60e8
|
21 22 |
if (gfpflags & __GFP_NOFAIL) return false; |
a9659476d
|
23 24 |
if (failslab.ignore_gfp_reclaim && (gfpflags & __GFP_DIRECT_RECLAIM)) |
773ff60e8
|
25 |
return false; |
fab9963a6
|
26 |
if (failslab.cache_filter && !(s->flags & SLAB_FAILSLAB)) |
4c13dd3b4
|
27 |
return false; |
fab9963a6
|
28 |
return should_fail(&failslab.attr, s->object_size); |
773ff60e8
|
29 30 31 32 33 34 35 36 37 |
} static int __init setup_failslab(char *str) { return setup_fault_attr(&failslab.attr, str); } __setup("failslab=", setup_failslab); #ifdef CONFIG_FAULT_INJECTION_DEBUG_FS |
773ff60e8
|
38 39 |
static int __init failslab_debugfs_init(void) { |
dd48c085c
|
40 |
struct dentry *dir; |
0825a6f98
|
41 |
umode_t mode = S_IFREG | 0600; |
773ff60e8
|
42 |
|
dd48c085c
|
43 44 45 |
dir = fault_create_debugfs_attr("failslab", NULL, &failslab.attr); if (IS_ERR(dir)) return PTR_ERR(dir); |
773ff60e8
|
46 |
|
d9f7979c9
|
47 48 49 50 |
debugfs_create_bool("ignore-gfp-wait", mode, dir, &failslab.ignore_gfp_reclaim); debugfs_create_bool("cache-filter", mode, dir, &failslab.cache_filter); |
4c13dd3b4
|
51 |
|
810f09b87
|
52 |
return 0; |
773ff60e8
|
53 54 55 56 57 |
} late_initcall(failslab_debugfs_init); #endif /* CONFIG_FAULT_INJECTION_DEBUG_FS */ |