EXPORT_SYMBOL(get_unmapped_area);
/**
- * mt_find_vma() - Find the VMA for a given address, or the next vma. May return
+ * find_vma() - Find the VMA for a given address, or the next vma. May return
* NULL in the case of no vma at addr or above
* @mm The mm_struct to check
* @addr: The address
* Returns: The VMA assoicated with addr, or the next vma.
* May return NULL in the case of no vma at addr or above.
*/
-struct vm_area_struct *mt_find_vma(struct mm_struct *mm, unsigned long addr)
+struct vm_area_struct *find_vma(struct mm_struct *mm, unsigned long addr)
{
struct vm_area_struct *vma;
return vma;
vma = mt_find(&mm->mm_mt, &addr, ULONG_MAX);
-
if (vma)
vmacache_update(addr, vma);
- return vma;
-}
-
-/* Look up the first VMA which satisfies addr < vm_end, NULL if none. */
-struct vm_area_struct *rb_find_vma(struct mm_struct *mm, unsigned long addr)
-{
- struct rb_node *rb_node;
- struct vm_area_struct *vma;
- /* Check the cache first. */
- vma = vmacache_find(mm, addr);
- if (likely(vma))
- return vma;
-
- rb_node = mm->mm_rb.rb_node;
-
- while (rb_node) {
- struct vm_area_struct *tmp;
-
- tmp = rb_entry(rb_node, struct vm_area_struct, vm_rb);
-
- if (tmp->vm_end > addr) {
- vma = tmp;
- if (tmp->vm_start <= addr)
- break;
- rb_node = rb_node->rb_left;
- } else
- rb_node = rb_node->rb_right;
- }
-
- if (vma)
- vmacache_update(addr, vma);
return vma;
}
-struct vm_area_struct *find_vma(struct mm_struct *mm, unsigned long addr)
-{
- struct vm_area_struct *ret = rb_find_vma(mm, addr);
- struct vm_area_struct *mt_ret = mt_find_vma(mm, addr);
- if (ret != mt_ret) {
- pr_err("Looking for %lu\n", addr);
- mt_dump(&mm->mm_mt);
- pr_err("%px %lu: ret %px mt_ret %px\n", mm, addr, ret, mt_ret);
- }
- VM_BUG_ON_VMA((unsigned long)ret != (unsigned long)mt_ret , ret);
- return ret;
-}
EXPORT_SYMBOL(find_vma);
/**