提交 2c0b3814 编写于 作者: H Hugh Dickins 提交者: Linus Torvalds

[PATCH] mm: remove_vma_list consolidation

unmap_vma doesn't amount to much, let's put it inside unmap_vma_list.  Except
it doesn't unmap anything, unmap_region just did the unmapping: rename it to
remove_vma_list.
Signed-off-by: NHugh Dickins <hugh@veritas.com>
Signed-off-by: NAndrew Morton <akpm@osdl.org>
Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
上级 ab50b8ed
...@@ -1603,35 +1603,23 @@ find_extend_vma(struct mm_struct * mm, unsigned long addr) ...@@ -1603,35 +1603,23 @@ find_extend_vma(struct mm_struct * mm, unsigned long addr)
} }
#endif #endif
/* Normal function to fix up a mapping
* This function is the default for when an area has no specific
* function. This may be used as part of a more specific routine.
*
* By the time this function is called, the area struct has been
* removed from the process mapping list.
*/
static void unmap_vma(struct mm_struct *mm, struct vm_area_struct *vma)
{
long nrpages = vma_pages(vma);
mm->total_vm -= nrpages;
if (vma->vm_flags & VM_LOCKED)
mm->locked_vm -= nrpages;
vm_stat_account(mm, vma->vm_flags, vma->vm_file, -nrpages);
remove_vm_struct(vma);
}
/* /*
* Update the VMA and inode share lists. * Ok - we have the memory areas we should free on the vma list,
*
* Ok - we have the memory areas we should free on the 'free' list,
* so release them, and do the vma updates. * so release them, and do the vma updates.
*
* Called with the mm semaphore held.
*/ */
static void unmap_vma_list(struct mm_struct *mm, struct vm_area_struct *vma) static void remove_vma_list(struct mm_struct *mm, struct vm_area_struct *vma)
{ {
do { do {
struct vm_area_struct *next = vma->vm_next; struct vm_area_struct *next = vma->vm_next;
unmap_vma(mm, vma); long nrpages = vma_pages(vma);
mm->total_vm -= nrpages;
if (vma->vm_flags & VM_LOCKED)
mm->locked_vm -= nrpages;
vm_stat_account(mm, vma->vm_flags, vma->vm_file, -nrpages);
remove_vm_struct(vma);
vma = next; vma = next;
} while (vma); } while (vma);
validate_mm(mm); validate_mm(mm);
...@@ -1799,7 +1787,7 @@ int do_munmap(struct mm_struct *mm, unsigned long start, size_t len) ...@@ -1799,7 +1787,7 @@ int do_munmap(struct mm_struct *mm, unsigned long start, size_t len)
unmap_region(mm, vma, prev, start, end); unmap_region(mm, vma, prev, start, end);
/* Fix up all other VM information */ /* Fix up all other VM information */
unmap_vma_list(mm, vma); remove_vma_list(mm, vma);
return 0; return 0;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册