Subject: khugepaged vma merge From: Andrea Arcangeli register in khugepaged if the vma grows. Signed-off-by: Andrea Arcangeli --- diff --git a/mm/mmap.c b/mm/mmap.c --- a/mm/mmap.c +++ b/mm/mmap.c @@ -28,6 +28,7 @@ #include #include #include +#include #include #include @@ -814,6 +815,7 @@ struct vm_area_struct *vma_merge(struct end, prev->vm_pgoff, NULL); if (err) return NULL; + khugepaged_enter_vma_merge(prev); return prev; } @@ -832,6 +834,7 @@ struct vm_area_struct *vma_merge(struct next->vm_pgoff - pglen, NULL); if (err) return NULL; + khugepaged_enter_vma_merge(area); return area; } @@ -1759,6 +1762,7 @@ int expand_upwards(struct vm_area_struct } } vma_unlock_anon_vma(vma); + khugepaged_enter_vma_merge(vma); return error; } #endif /* CONFIG_STACK_GROWSUP || CONFIG_IA64 */ @@ -1806,6 +1810,7 @@ static int expand_downwards(struct vm_ar } } vma_unlock_anon_vma(vma); + khugepaged_enter_vma_merge(vma); return error; }