diff options
| author | Peter Zijlstra <a.p.zijlstra@chello.nl> | 2006-12-06 20:32:18 -0800 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@woody.osdl.org> | 2006-12-07 08:39:21 -0800 | 
| commit | 6edaf68a87d17570790fd55f0c451a29ec1d6703 (patch) | |
| tree | 8ea1f3509dcf3e721919471dea67ef55a3aff78f | |
| parent | 3395ee0588795b0b3bd889c260e55959cf2b61f5 (diff) | |
| download | kernel_samsung_smdk4412-6edaf68a87d17570790fd55f0c451a29ec1d6703.zip kernel_samsung_smdk4412-6edaf68a87d17570790fd55f0c451a29ec1d6703.tar.gz kernel_samsung_smdk4412-6edaf68a87d17570790fd55f0c451a29ec1d6703.tar.bz2 | |
[PATCH] mm: arch do_page_fault() vs in_atomic()
In light of the recent pagefault and filemap_copy_from_user work I've gone
through all the arch pagefault handlers to make sure the inc_preempt_count()
'feature' works as expected.
Several sections of code (including the new filemap_copy_from_user) rely on
the fact that faults do not take locks under increased preempt count.
arch/x86_64 - good
arch/powerpc - good
arch/cris - fixed
arch/i386 - good
arch/parisc - fixed
arch/sh - good
arch/sparc - good
arch/s390 - good
arch/m68k - fixed
arch/ppc - good
arch/alpha - fixed
arch/mips - good
arch/sparc64 - good
arch/ia64 - good
arch/arm - fixed
arch/um - good
arch/avr32 - good
arch/h8300 - NA
arch/m32r - good
arch/v850 - good
arch/frv - fixed
arch/m68knommu - NA
arch/arm26 - fixed
arch/sh64 - fixed
arch/xtensa - good
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by: Nick Piggin <npiggin@suse.de>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
| -rw-r--r-- | arch/alpha/mm/fault.c | 2 | ||||
| -rw-r--r-- | arch/arm/mm/fault.c | 2 | ||||
| -rw-r--r-- | arch/arm26/mm/fault.c | 2 | ||||
| -rw-r--r-- | arch/cris/mm/fault.c | 2 | ||||
| -rw-r--r-- | arch/frv/mm/fault.c | 2 | ||||
| -rw-r--r-- | arch/m68k/mm/fault.c | 2 | ||||
| -rw-r--r-- | arch/parisc/mm/fault.c | 2 | ||||
| -rw-r--r-- | arch/sh64/mm/fault.c | 2 | 
8 files changed, 8 insertions, 8 deletions
| diff --git a/arch/alpha/mm/fault.c b/arch/alpha/mm/fault.c index 8871529..8aa9db8 100644 --- a/arch/alpha/mm/fault.c +++ b/arch/alpha/mm/fault.c @@ -108,7 +108,7 @@ do_page_fault(unsigned long address, unsigned long mmcsr,  	/* If we're in an interrupt context, or have no user context,  	   we must not take the fault.  */ -	if (!mm || in_interrupt()) +	if (!mm || in_atomic())  		goto no_context;  #ifdef CONFIG_ALPHA_LARGE_VMALLOC diff --git a/arch/arm/mm/fault.c b/arch/arm/mm/fault.c index 5e658a8..9fd6d2e 100644 --- a/arch/arm/mm/fault.c +++ b/arch/arm/mm/fault.c @@ -230,7 +230,7 @@ do_page_fault(unsigned long addr, unsigned int fsr, struct pt_regs *regs)  	 * If we're in an interrupt or have no user  	 * context, we must not take the fault..  	 */ -	if (in_interrupt() || !mm) +	if (in_atomic() || !mm)  		goto no_context;  	/* diff --git a/arch/arm26/mm/fault.c b/arch/arm26/mm/fault.c index a1f6d8a..93c0cee 100644 --- a/arch/arm26/mm/fault.c +++ b/arch/arm26/mm/fault.c @@ -215,7 +215,7 @@ int do_page_fault(unsigned long addr, unsigned int fsr, struct pt_regs *regs)  	 * If we're in an interrupt or have no user  	 * context, we must not take the fault..  	 */ -	if (in_interrupt() || !mm) +	if (in_atomic() || !mm)  		goto no_context;  	down_read(&mm->mmap_sem); diff --git a/arch/cris/mm/fault.c b/arch/cris/mm/fault.c index 934c510..c73e91f 100644 --- a/arch/cris/mm/fault.c +++ b/arch/cris/mm/fault.c @@ -232,7 +232,7 @@ do_page_fault(unsigned long address, struct pt_regs *regs,  	 * context, we must not take the fault..  	 */ -	if (in_interrupt() || !mm) +	if (in_atomic() || !mm)  		goto no_context;  	down_read(&mm->mmap_sem); diff --git a/arch/frv/mm/fault.c b/arch/frv/mm/fault.c index 8b3eb50..3f12296 100644 --- a/arch/frv/mm/fault.c +++ b/arch/frv/mm/fault.c @@ -78,7 +78,7 @@ asmlinkage void do_page_fault(int datammu, unsigned long esr0, unsigned long ear  	 * If we're in an interrupt or have no user  	 * context, we must not take the fault..  	 */ -	if (in_interrupt() || !mm) +	if (in_atomic() || !mm)  		goto no_context;  	down_read(&mm->mmap_sem); diff --git a/arch/m68k/mm/fault.c b/arch/m68k/mm/fault.c index 911f2ce..2adbeb1 100644 --- a/arch/m68k/mm/fault.c +++ b/arch/m68k/mm/fault.c @@ -99,7 +99,7 @@ int do_page_fault(struct pt_regs *regs, unsigned long address,  	 * If we're in an interrupt or have no user  	 * context, we must not take the fault..  	 */ -	if (in_interrupt() || !mm) +	if (in_atomic() || !mm)  		goto no_context;  	down_read(&mm->mmap_sem); diff --git a/arch/parisc/mm/fault.c b/arch/parisc/mm/fault.c index 64785e4..641f9c9 100644 --- a/arch/parisc/mm/fault.c +++ b/arch/parisc/mm/fault.c @@ -152,7 +152,7 @@ void do_page_fault(struct pt_regs *regs, unsigned long code,  	const struct exception_table_entry *fix;  	unsigned long acc_type; -	if (in_interrupt() || !mm) +	if (in_atomic() || !mm)  		goto no_context;  	down_read(&mm->mmap_sem); diff --git a/arch/sh64/mm/fault.c b/arch/sh64/mm/fault.c index 8e2f6c2..4f72ab3 100644 --- a/arch/sh64/mm/fault.c +++ b/arch/sh64/mm/fault.c @@ -154,7 +154,7 @@ asmlinkage void do_page_fault(struct pt_regs *regs, unsigned long writeaccess,  	 * If we're in an interrupt or have no user  	 * context, we must not take the fault..  	 */ -	if (in_interrupt() || !mm) +	if (in_atomic() || !mm)  		goto no_context;  	/* TLB misses upon some cache flushes get done under cli() */ | 
