mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-25 10:00:33 +00:00 
			
		
		
		
	 4522d58275
			
		
	
	
		4522d58275
		
	
	
	
	
		
			
			* 'for-linus' of git://one.firstfloor.org/home/andi/git/linux-2.6: (156 commits) [PATCH] x86-64: Export smp_call_function_single [PATCH] i386: Clean up smp_tune_scheduling() [PATCH] unwinder: move .eh_frame to RODATA [PATCH] unwinder: fully support linker generated .eh_frame_hdr section [PATCH] x86-64: don't use set_irq_regs() [PATCH] x86-64: check vector in setup_ioapic_dest to verify if need setup_IO_APIC_irq [PATCH] x86-64: Make ix86 default to HIGHMEM4G instead of NOHIGHMEM [PATCH] i386: replace kmalloc+memset with kzalloc [PATCH] x86-64: remove remaining pc98 code [PATCH] x86-64: remove unused variable [PATCH] x86-64: Fix constraints in atomic_add_return() [PATCH] x86-64: fix asm constraints in i386 atomic_add_return [PATCH] x86-64: Correct documentation for bzImage protocol v2.05 [PATCH] x86-64: replace kmalloc+memset with kzalloc in MTRR code [PATCH] x86-64: Fix numaq build error [PATCH] x86-64: include/asm-x86_64/cpufeature.h isn't a userspace header [PATCH] unwinder: Add debugging output to the Dwarf2 unwinder [PATCH] x86-64: Clarify error message in GART code [PATCH] x86-64: Fix interrupt race in idle callback (3rd try) [PATCH] x86-64: Remove unwind stack pointer alignment forcing again ... Fixed conflict in include/linux/uaccess.h manually Signed-off-by: Linus Torvalds <torvalds@osdl.org>
		
			
				
	
	
		
			88 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef __LINUX_UACCESS_H__
 | |
| #define __LINUX_UACCESS_H__
 | |
| 
 | |
| #include <linux/preempt.h>
 | |
| #include <asm/uaccess.h>
 | |
| 
 | |
| /*
 | |
|  * These routines enable/disable the pagefault handler in that
 | |
|  * it will not take any locks and go straight to the fixup table.
 | |
|  *
 | |
|  * They have great resemblance to the preempt_disable/enable calls
 | |
|  * and in fact they are identical; this is because currently there is
 | |
|  * no other way to make the pagefault handlers do this. So we do
 | |
|  * disable preemption but we don't necessarily care about that.
 | |
|  */
 | |
| static inline void pagefault_disable(void)
 | |
| {
 | |
| 	inc_preempt_count();
 | |
| 	/*
 | |
| 	 * make sure to have issued the store before a pagefault
 | |
| 	 * can hit.
 | |
| 	 */
 | |
| 	barrier();
 | |
| }
 | |
| 
 | |
| static inline void pagefault_enable(void)
 | |
| {
 | |
| 	/*
 | |
| 	 * make sure to issue those last loads/stores before enabling
 | |
| 	 * the pagefault handler again.
 | |
| 	 */
 | |
| 	barrier();
 | |
| 	dec_preempt_count();
 | |
| 	/*
 | |
| 	 * make sure we do..
 | |
| 	 */
 | |
| 	barrier();
 | |
| 	preempt_check_resched();
 | |
| }
 | |
| 
 | |
| #ifndef ARCH_HAS_NOCACHE_UACCESS
 | |
| 
 | |
| static inline unsigned long __copy_from_user_inatomic_nocache(void *to,
 | |
| 				const void __user *from, unsigned long n)
 | |
| {
 | |
| 	return __copy_from_user_inatomic(to, from, n);
 | |
| }
 | |
| 
 | |
| static inline unsigned long __copy_from_user_nocache(void *to,
 | |
| 				const void __user *from, unsigned long n)
 | |
| {
 | |
| 	return __copy_from_user(to, from, n);
 | |
| }
 | |
| 
 | |
| #endif		/* ARCH_HAS_NOCACHE_UACCESS */
 | |
| 
 | |
| /**
 | |
|  * probe_kernel_address(): safely attempt to read from a location
 | |
|  * @addr: address to read from - its type is type typeof(retval)*
 | |
|  * @retval: read into this variable
 | |
|  *
 | |
|  * Safely read from address @addr into variable @revtal.  If a kernel fault
 | |
|  * happens, handle that and return -EFAULT.
 | |
|  * We ensure that the __get_user() is executed in atomic context so that
 | |
|  * do_page_fault() doesn't attempt to take mmap_sem.  This makes
 | |
|  * probe_kernel_address() suitable for use within regions where the caller
 | |
|  * already holds mmap_sem, or other locks which nest inside mmap_sem.
 | |
|  * This must be a macro because __get_user() needs to know the types of the
 | |
|  * args.
 | |
|  *
 | |
|  * We don't include enough header files to be able to do the set_fs().  We
 | |
|  * require that the probe_kernel_address() caller will do that.
 | |
|  */
 | |
| #define probe_kernel_address(addr, retval)		\
 | |
| 	({						\
 | |
| 		long ret;				\
 | |
| 		mm_segment_t old_fs = get_fs();		\
 | |
| 							\
 | |
| 		set_fs(KERNEL_DS);			\
 | |
| 		pagefault_disable();			\
 | |
| 		ret = __get_user(retval, (__force typeof(retval) __user *)(addr));		\
 | |
| 		pagefault_enable();			\
 | |
| 		set_fs(old_fs);				\
 | |
| 		ret;					\
 | |
| 	})
 | |
| 
 | |
| #endif		/* __LINUX_UACCESS_H__ */
 |