|
@@ -154,10 +154,12 @@ hugetlb_get_unmapped_area(struct file *file, unsigned long addr,
|
|
|
return addr;
|
|
|
}
|
|
|
|
|
|
- start_addr = mm->free_area_cache;
|
|
|
-
|
|
|
- if (len <= mm->cached_hole_size)
|
|
|
+ if (len > mm->cached_hole_size)
|
|
|
+ start_addr = mm->free_area_cache;
|
|
|
+ else {
|
|
|
start_addr = TASK_UNMAPPED_BASE;
|
|
|
+ mm->cached_hole_size = 0;
|
|
|
+ }
|
|
|
|
|
|
full_search:
|
|
|
addr = ALIGN(start_addr, huge_page_size(h));
|
|
@@ -171,13 +173,18 @@ full_search:
|
|
|
*/
|
|
|
if (start_addr != TASK_UNMAPPED_BASE) {
|
|
|
start_addr = TASK_UNMAPPED_BASE;
|
|
|
+ mm->cached_hole_size = 0;
|
|
|
goto full_search;
|
|
|
}
|
|
|
return -ENOMEM;
|
|
|
}
|
|
|
|
|
|
- if (!vma || addr + len <= vma->vm_start)
|
|
|
+ if (!vma || addr + len <= vma->vm_start) {
|
|
|
+ mm->free_area_cache = addr + len;
|
|
|
return addr;
|
|
|
+ }
|
|
|
+ if (addr + mm->cached_hole_size < vma->vm_start)
|
|
|
+ mm->cached_hole_size = vma->vm_start - addr;
|
|
|
addr = ALIGN(vma->vm_end, huge_page_size(h));
|
|
|
}
|
|
|
}
|