diff options
Diffstat (limited to 'arch/cris/mm')
-rw-r--r-- | arch/cris/mm/fault.c | 23 |
1 files changed, 12 insertions, 11 deletions
diff --git a/arch/cris/mm/fault.c b/arch/cris/mm/fault.c index c73e91f1299a..8672ab7d7978 100644 --- a/arch/cris/mm/fault.c +++ b/arch/cris/mm/fault.c | |||
@@ -179,6 +179,7 @@ do_page_fault(unsigned long address, struct pt_regs *regs, | |||
179 | struct mm_struct *mm; | 179 | struct mm_struct *mm; |
180 | struct vm_area_struct * vma; | 180 | struct vm_area_struct * vma; |
181 | siginfo_t info; | 181 | siginfo_t info; |
182 | int fault; | ||
182 | 183 | ||
183 | D(printk("Page fault for %lX on %X at %lX, prot %d write %d\n", | 184 | D(printk("Page fault for %lX on %X at %lX, prot %d write %d\n", |
184 | address, smp_processor_id(), instruction_pointer(regs), | 185 | address, smp_processor_id(), instruction_pointer(regs), |
@@ -283,18 +284,18 @@ do_page_fault(unsigned long address, struct pt_regs *regs, | |||
283 | * the fault. | 284 | * the fault. |
284 | */ | 285 | */ |
285 | 286 | ||
286 | switch (handle_mm_fault(mm, vma, address, writeaccess & 1)) { | 287 | fault = handle_mm_fault(mm, vma, address, writeaccess & 1); |
287 | case VM_FAULT_MINOR: | 288 | if (unlikely(fault & VM_FAULT_ERROR)) { |
288 | tsk->min_flt++; | 289 | if (fault & VM_FAULT_OOM) |
289 | break; | 290 | goto out_of_memory; |
290 | case VM_FAULT_MAJOR: | 291 | else if (fault & VM_FAULT_SIGBUS) |
291 | tsk->maj_flt++; | 292 | goto do_sigbus; |
292 | break; | 293 | BUG(); |
293 | case VM_FAULT_SIGBUS: | ||
294 | goto do_sigbus; | ||
295 | default: | ||
296 | goto out_of_memory; | ||
297 | } | 294 | } |
295 | if (fault & VM_FAULT_MAJOR) | ||
296 | tsk->maj_flt++; | ||
297 | else | ||
298 | tsk->min_flt++; | ||
298 | 299 | ||
299 | up_read(&mm->mmap_sem); | 300 | up_read(&mm->mmap_sem); |
300 | return; | 301 | return; |