diff options
author | Alexander Potapenko <glider@google.com> | 2019-08-03 00:49:22 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2019-08-03 10:02:01 -0400 |
commit | 733d1d1a7745113e2b6a1761300e7e26b6eb6009 (patch) | |
tree | f7338a50f56560461c195820e98a9ddee1b350fc /lib | |
parent | cbedfe11347fe418621bd188d58a206beb676218 (diff) |
lib/test_meminit.c: use GFP_ATOMIC in RCU critical section
kmalloc() shouldn't sleep while in RCU critical section, therefore use
GFP_ATOMIC instead of GFP_KERNEL.
The bug was spotted by the 0day kernel testing robot.
Link: http://lkml.kernel.org/r/20190725121703.210874-1-glider@google.com
Fixes: 7e659650cbda ("lib: introduce test_meminit module")
Signed-off-by: Alexander Potapenko <glider@google.com>
Reviewed-by: Andrew Morton <akpm@linux-foundation.org>
Reported-by: kernel test robot <lkp@intel.com>
Cc: Kees Cook <keescook@chromium.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'lib')
-rw-r--r-- | lib/test_meminit.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/lib/test_meminit.c b/lib/test_meminit.c index 62d19f270cad..9729f271d150 100644 --- a/lib/test_meminit.c +++ b/lib/test_meminit.c | |||
@@ -222,7 +222,7 @@ static int __init do_kmem_cache_size(size_t size, bool want_ctor, | |||
222 | * Copy the buffer to check that it's not wiped on | 222 | * Copy the buffer to check that it's not wiped on |
223 | * free(). | 223 | * free(). |
224 | */ | 224 | */ |
225 | buf_copy = kmalloc(size, GFP_KERNEL); | 225 | buf_copy = kmalloc(size, GFP_ATOMIC); |
226 | if (buf_copy) | 226 | if (buf_copy) |
227 | memcpy(buf_copy, buf, size); | 227 | memcpy(buf_copy, buf, size); |
228 | 228 | ||