Commit d15f107d authored by Andi Kleen's avatar Andi Kleen Committed by Andi Kleen

HWPOISON: Use get_user_page_fast in hwpoison madvise

The previous version didn't take the mmap_sem before calling gup(),
which is racy.

Use get_user_pages_fast() instead which doesn't need any locks.
This is also faster of course, but then it doesn't really matter
because this is just a testing path.

Based on report from Nick Piggin.
Cc: npiggin@suse.de
Signed-off-by: default avatarAndi Kleen <ak@linux.intel.com>
parent 1bfe5feb
...@@ -230,8 +230,7 @@ static int madvise_hwpoison(unsigned long start, unsigned long end) ...@@ -230,8 +230,7 @@ static int madvise_hwpoison(unsigned long start, unsigned long end)
return -EPERM; return -EPERM;
for (; start < end; start += PAGE_SIZE) { for (; start < end; start += PAGE_SIZE) {
struct page *p; struct page *p;
int ret = get_user_pages(current, current->mm, start, 1, int ret = get_user_pages_fast(start, 1, 0, &p);
0, 0, &p, NULL);
if (ret != 1) if (ret != 1)
return ret; return ret;
printk(KERN_INFO "Injecting memory failure for page %lx at %lx\n", printk(KERN_INFO "Injecting memory failure for page %lx at %lx\n",
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment