cregit-Linux how code gets into the kernel

Release 4.11 arch/x86/include/asm/uaccess_32.h

#ifndef _ASM_X86_UACCESS_32_H

#define _ASM_X86_UACCESS_32_H

/*
 * User space memory access functions
 */
#include <linux/errno.h>
#include <linux/thread_info.h>
#include <linux/string.h>
#include <asm/asm.h>
#include <asm/page.h>

unsigned long __must_check __copy_to_user_ll
		(void __user *to, const void *from, unsigned long n);
unsigned long __must_check __copy_from_user_ll
		(void *to, const void __user *from, unsigned long n);
unsigned long __must_check __copy_from_user_ll_nozero
		(void *to, const void __user *from, unsigned long n);
unsigned long __must_check __copy_from_user_ll_nocache
		(void *to, const void __user *from, unsigned long n);
unsigned long __must_check __copy_from_user_ll_nocache_nozero
		(void *to, const void __user *from, unsigned long n);

/**
 * __copy_to_user_inatomic: - Copy a block of data into user space, with less checking.
 * @to:   Destination address, in user space.
 * @from: Source address, in kernel space.
 * @n:    Number of bytes to copy.
 *
 * Context: User context only.
 *
 * Copy data from kernel space to user space.  Caller must check
 * the specified block with access_ok() before calling this function.
 * The caller should also make sure he pins the user space address
 * so that we don't result in page fault and sleep.
 */

static __always_inline unsigned long __must_check __copy_to_user_inatomic(void __user *to, const void *from, unsigned long n) { check_object_size(from, n, true); return __copy_to_user_ll(to, from, n); }

Contributors

PersonTokensPropCommitsCommitProp
Linus Torvalds (pre-git)1638.10%114.29%
Andrew Morton1433.33%228.57%
Kees Cook921.43%114.29%
Ingo Molnar24.76%228.57%
Linus Torvalds12.38%114.29%
Total42100.00%7100.00%

/** * __copy_to_user: - Copy a block of data into user space, with less checking. * @to: Destination address, in user space. * @from: Source address, in kernel space. * @n: Number of bytes to copy. * * Context: User context only. This function may sleep if pagefaults are * enabled. * * Copy data from kernel space to user space. Caller must check * the specified block with access_ok() before calling this function. * * Returns number of bytes that could not be copied. * On success, this will be zero. */
static __always_inline unsigned long __must_check __copy_to_user(void __user *to, const void *from, unsigned long n) { might_fault(); return __copy_to_user_inatomic(to, from, n); }

Contributors

PersonTokensPropCommitsCommitProp
Ingo Molnar3494.44%250.00%
Andrew Morton12.78%125.00%
Nicholas Piggin12.78%125.00%
Total36100.00%4100.00%


static __always_inline unsigned long __copy_from_user_inatomic(void *to, const void __user *from, unsigned long n) { return __copy_from_user_ll_nozero(to, from, n); }

Contributors

PersonTokensPropCommitsCommitProp
Linus Torvalds (pre-git)1650.00%116.67%
Andrew Morton1237.50%116.67%
Ingo Molnar26.25%233.33%
Neil Brown13.12%116.67%
Linus Torvalds13.12%116.67%
Total32100.00%6100.00%

/** * __copy_from_user: - Copy a block of data from user space, with less checking. * @to: Destination address, in kernel space. * @from: Source address, in user space. * @n: Number of bytes to copy. * * Context: User context only. This function may sleep if pagefaults are * enabled. * * Copy data from user space to kernel space. Caller must check * the specified block with access_ok() before calling this function. * * Returns number of bytes that could not be copied. * On success, this will be zero. * * If some data could not be copied, this function will pad the copied * data to the requested size using zero bytes. * * An alternate version - __copy_from_user_inatomic() - may be called from * atomic context and will fail rather than sleep. In this case the * uncopied bytes will *NOT* be padded with zeros. See fs/filemap.h * for explanation of why this is needed. */
static __always_inline unsigned long __copy_from_user(void *to, const void __user *from, unsigned long n) { might_fault(); check_object_size(to, n, false); if (__builtin_constant_p(n)) { unsigned long ret; switch (n) { case 1: __uaccess_begin(); __get_user_size(*(u8 *)to, from, 1, ret, 1); __uaccess_end(); return ret; case 2: __uaccess_begin(); __get_user_size(*(u16 *)to, from, 2, ret, 2); __uaccess_end(); return ret; case 4: __uaccess_begin(); __get_user_size(*(u32 *)to, from, 4, ret, 4); __uaccess_end(); return ret; } } return __copy_from_user_ll(to, from, n); }

Contributors

PersonTokensPropCommitsCommitProp
Hiro Yoshioka12179.08%120.00%
Linus Torvalds1811.76%120.00%
Kees Cook95.88%120.00%
Neil Brown42.61%120.00%
Nicholas Piggin10.65%120.00%
Total153100.00%5100.00%


static __always_inline unsigned long __copy_from_user_nocache(void *to, const void __user *from, unsigned long n) { might_fault(); if (__builtin_constant_p(n)) { unsigned long ret; switch (n) { case 1: __uaccess_begin(); __get_user_size(*(u8 *)to, from, 1, ret, 1); __uaccess_end(); return ret; case 2: __uaccess_begin(); __get_user_size(*(u16 *)to, from, 2, ret, 2); __uaccess_end(); return ret; case 4: __uaccess_begin(); __get_user_size(*(u32 *)to, from, 4, ret, 4); __uaccess_end(); return ret; } } return __copy_from_user_ll_nocache(to, from, n); }

Contributors

PersonTokensPropCommitsCommitProp
Neil Brown9364.58%120.00%
Ingo Molnar3222.22%240.00%
Linus Torvalds1812.50%120.00%
Nicholas Piggin10.69%120.00%
Total144100.00%5100.00%


static __always_inline unsigned long __copy_from_user_inatomic_nocache(void *to, const void __user *from, unsigned long n) { return __copy_from_user_ll_nocache_nozero(to, from, n); }

Contributors

PersonTokensPropCommitsCommitProp
Hiro Yoshioka3093.75%150.00%
Neil Brown26.25%150.00%
Total32100.00%2100.00%

#endif /* _ASM_X86_UACCESS_32_H */

Overall Contributors

PersonTokensPropCommitsCommitProp
Hiro Yoshioka17130.16%14.55%
Neil Brown14024.69%14.55%
Linus Torvalds (pre-git)7713.58%418.18%
Ingo Molnar7012.35%29.09%
Linus Torvalds417.23%313.64%
Andrew Morton356.17%418.18%
Kees Cook183.17%14.55%
H. Peter Anvin61.06%29.09%
Dave Jones30.53%14.55%
Nicholas Piggin30.53%14.55%
David Hildenbrand20.35%14.55%
Arnaldo Carvalho de Melo10.18%14.55%
Total567100.00%22100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.