hc
2024-11-01 2f529f9b558ca1c1bd74be7437a84e4711743404
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/*
 * User address space access functions.
 *
 *  For licencing details see kernel-base/COPYING
 */
 
#include <linux/uaccess.h>
#include <linux/export.h>
 
#include <asm/tlbflush.h>
 
/*
 * We rely on the nested NMI work to allow atomic faults from the NMI path; the
 * nested NMI paths are careful to preserve CR2.
 */
unsigned long
copy_from_user_nmi(void *to, const void __user *from, unsigned long n)
{
   unsigned long ret;
 
   if (running_oob() || __range_not_ok(from, n, TASK_SIZE))
       return n;
 
   if (!nmi_uaccess_okay())
       return n;
 
   /*
    * Even though this function is typically called from NMI/IRQ context
    * disable pagefaults so that its behaviour is consistent even when
    * called form other contexts.
    */
   pagefault_disable();
   ret = __copy_from_user_inatomic(to, from, n);
   pagefault_enable();
 
   return ret;
}
EXPORT_SYMBOL_GPL(copy_from_user_nmi);