perf/x86: Check user address explicitly in copy_from_user_nmi()
authorArun Sharma <asharma@fb.com>
Fri, 20 Apr 2012 22:41:36 +0000 (15:41 -0700)
committerIngo Molnar <mingo@kernel.org>
Wed, 6 Jun 2012 15:08:04 +0000 (17:08 +0200)
Signed-off-by: Arun Sharma <asharma@fb.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: linux-kernel@vger.kernel.org
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Link: http://lkml.kernel.org/r/1334961696-19580-5-git-send-email-asharma@fb.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>
arch/x86/lib/usercopy.c

index f61ee67ec00f0dc6d61b6165e087ba248f81df2c..677b1ed184c9004f8a51b5432f4e29ecb2c24f81 100644 (file)
@@ -8,6 +8,7 @@
 #include <linux/module.h>
 
 #include <asm/word-at-a-time.h>
+#include <linux/sched.h>
 
 /*
  * best effort, GUP based copy_from_user() that is NMI-safe
@@ -21,6 +22,9 @@ copy_from_user_nmi(void *to, const void __user *from, unsigned long n)
        void *map;
        int ret;
 
+       if (__range_not_ok(from, n, TASK_SIZE) == 0)
+               return len;
+
        do {
                ret = __get_user_pages_fast(addr, 1, 0, &page);
                if (!ret)