diff options
Diffstat (limited to 'arch/ia64/mm/fault.c')
| -rw-r--r-- | arch/ia64/mm/fault.c | 34 | 
1 files changed, 7 insertions, 27 deletions
| diff --git a/arch/ia64/mm/fault.c b/arch/ia64/mm/fault.c index 3c32af910d60..af7eb087dca7 100644 --- a/arch/ia64/mm/fault.c +++ b/arch/ia64/mm/fault.c | |||
| @@ -20,32 +20,6 @@ | |||
| 20 | extern void die (char *, struct pt_regs *, long); | 20 | extern void die (char *, struct pt_regs *, long); | 
| 21 | 21 | ||
| 22 | /* | 22 | /* | 
| 23 | * This routine is analogous to expand_stack() but instead grows the | ||
| 24 | * register backing store (which grows towards higher addresses). | ||
| 25 | * Since the register backing store is access sequentially, we | ||
| 26 | * disallow growing the RBS by more than a page at a time. Note that | ||
| 27 | * the VM_GROWSUP flag can be set on any VM area but that's fine | ||
| 28 | * because the total process size is still limited by RLIMIT_STACK and | ||
| 29 | * RLIMIT_AS. | ||
| 30 | */ | ||
| 31 | static inline long | ||
| 32 | expand_backing_store (struct vm_area_struct *vma, unsigned long address) | ||
| 33 | { | ||
| 34 | unsigned long grow; | ||
| 35 | |||
| 36 | grow = PAGE_SIZE >> PAGE_SHIFT; | ||
| 37 | if (address - vma->vm_start > current->signal->rlim[RLIMIT_STACK].rlim_cur | ||
| 38 | || (((vma->vm_mm->total_vm + grow) << PAGE_SHIFT) > current->signal->rlim[RLIMIT_AS].rlim_cur)) | ||
| 39 | return -ENOMEM; | ||
| 40 | vma->vm_end += PAGE_SIZE; | ||
| 41 | vma->vm_mm->total_vm += grow; | ||
| 42 | if (vma->vm_flags & VM_LOCKED) | ||
| 43 | vma->vm_mm->locked_vm += grow; | ||
| 44 | __vm_stat_account(vma->vm_mm, vma->vm_flags, vma->vm_file, grow); | ||
| 45 | return 0; | ||
| 46 | } | ||
| 47 | |||
| 48 | /* | ||
| 49 | * Return TRUE if ADDRESS points at a page in the kernel's mapped segment | 23 | * Return TRUE if ADDRESS points at a page in the kernel's mapped segment | 
| 50 | * (inside region 5, on ia64) and that page is present. | 24 | * (inside region 5, on ia64) and that page is present. | 
| 51 | */ | 25 | */ | 
| @@ -185,7 +159,13 @@ ia64_do_page_fault (unsigned long address, unsigned long isr, struct pt_regs *re | |||
| 185 | if (REGION_NUMBER(address) != REGION_NUMBER(vma->vm_start) | 159 | if (REGION_NUMBER(address) != REGION_NUMBER(vma->vm_start) | 
| 186 | || REGION_OFFSET(address) >= RGN_MAP_LIMIT) | 160 | || REGION_OFFSET(address) >= RGN_MAP_LIMIT) | 
| 187 | goto bad_area; | 161 | goto bad_area; | 
| 188 | if (expand_backing_store(vma, address)) | 162 | /* | 
| 163 | * Since the register backing store is accessed sequentially, | ||
| 164 | * we disallow growing it by more than a page at a time. | ||
| 165 | */ | ||
| 166 | if (address > vma->vm_end + PAGE_SIZE - sizeof(long)) | ||
| 167 | goto bad_area; | ||
| 168 | if (expand_upwards(vma, address)) | ||
| 189 | goto bad_area; | 169 | goto bad_area; | 
| 190 | } | 170 | } | 
| 191 | goto good_area; | 171 | goto good_area; | 
