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>
This commit is contained in:
parent
cbedfe1134
commit
733d1d1a77
|
@ -222,7 +222,7 @@ static int __init do_kmem_cache_size(size_t size, bool want_ctor,
|
||||||
* Copy the buffer to check that it's not wiped on
|
* Copy the buffer to check that it's not wiped on
|
||||||
* free().
|
* free().
|
||||||
*/
|
*/
|
||||||
buf_copy = kmalloc(size, GFP_KERNEL);
|
buf_copy = kmalloc(size, GFP_ATOMIC);
|
||||||
if (buf_copy)
|
if (buf_copy)
|
||||||
memcpy(buf_copy, buf, size);
|
memcpy(buf_copy, buf, size);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue