mm: use vm_unmapped_area() on frv architecture
[linux-3.10.git] / arch / frv / mm / elf-fdpic.c
index 385fd30..836f147 100644 (file)
@@ -60,7 +60,7 @@ unsigned long arch_get_unmapped_area(struct file *filp, unsigned long addr, unsi
                                     unsigned long pgoff, unsigned long flags)
 {
        struct vm_area_struct *vma;
-       unsigned long limit;
+       struct vm_unmapped_area_info info;
 
        if (len > TASK_SIZE)
                return -ENOMEM;
@@ -79,39 +79,24 @@ unsigned long arch_get_unmapped_area(struct file *filp, unsigned long addr, unsi
        }
 
        /* search between the bottom of user VM and the stack grow area */
-       addr = PAGE_SIZE;
-       limit = (current->mm->start_stack - 0x00200000);
-       if (addr + len <= limit) {
-               limit -= len;
-
-               if (addr <= limit) {
-                       vma = find_vma(current->mm, PAGE_SIZE);
-                       for (; vma; vma = vma->vm_next) {
-                               if (addr > limit)
-                                       break;
-                               if (addr + len <= vma->vm_start)
-                                       goto success;
-                               addr = vma->vm_end;
-                       }
-               }
-       }
+       info.flags = 0;
+       info.length = len;
+       info.low_limit = PAGE_SIZE;
+       info.high_limit = (current->mm->start_stack - 0x00200000);
+       info.align_mask = 0;
+       info.align_offset = 0;
+       addr = vm_unmapped_area(&info);
+       if (!(addr & ~PAGE_MASK))
+               goto success;
+       VM_BUG_ON(addr != -ENOMEM);
 
        /* search from just above the WorkRAM area to the top of memory */
-       addr = PAGE_ALIGN(0x80000000);
-       limit = TASK_SIZE - len;
-       if (addr <= limit) {
-               vma = find_vma(current->mm, addr);
-               for (; vma; vma = vma->vm_next) {
-                       if (addr > limit)
-                               break;
-                       if (addr + len <= vma->vm_start)
-                               goto success;
-                       addr = vma->vm_end;
-               }
-
-               if (!vma && addr <= limit)
-                       goto success;
-       }
+       info.low_limit = PAGE_ALIGN(0x80000000);
+       info.high_limit = TASK_SIZE;
+       addr = vm_unmapped_area(&info);
+       if (!(addr & ~PAGE_MASK))
+               goto success;
+       VM_BUG_ON(addr != -ENOMEM);
 
 #if 0
        printk("[area] l=%lx (ENOMEM) f='%s'\n",