Skip to content

Commit fe1679e

Browse files
lorenzo-stoakesakpm00
authored andcommitted
mm/debug: prefer VM_WARN_ON_VMG() to report VMG debug warnings
Now we have VM_WARN_ON_VMG() to provide us with considerably more debug output when a debug assert fails, utilise it everywhere we can. This allows us to have considerably more information to go on when things go wrong, especially when a non-repro issue occurs as reported by syzkaller or the like. Link: https://lkml.kernel.org/r/986e45e9549e71284ac7a7fa878688568a94d58b.1735932169.git.lorenzo.stoakes@oracle.com Signed-off-by: Lorenzo Stoakes <[email protected]> Cc: David Hildenbrand <[email protected]> Cc: Jann Horn <[email protected]> Cc: Liam R. Howlett <[email protected]> Cc: Matthew Wilcox (Oracle) <[email protected]> Cc: Vlastimil Babka <[email protected]> Signed-off-by: Andrew Morton <[email protected]>
1 parent b0d66d8 commit fe1679e

File tree

1 file changed

+17
-16
lines changed

1 file changed

+17
-16
lines changed

mm/vma.c

Lines changed: 17 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -729,19 +729,20 @@ static __must_check struct vm_area_struct *vma_merge_existing_range(
729729
bool expanded;
730730

731731
mmap_assert_write_locked(vmg->mm);
732-
VM_WARN_ON(!vma); /* We are modifying a VMA, so caller must specify. */
733-
VM_WARN_ON(vmg->next); /* We set this. */
734-
VM_WARN_ON(prev && start <= prev->vm_start);
735-
VM_WARN_ON(start >= end);
732+
VM_WARN_ON_VMG(!vma, vmg); /* We are modifying a VMA, so caller must specify. */
733+
VM_WARN_ON_VMG(vmg->next, vmg); /* We set this. */
734+
VM_WARN_ON_VMG(prev && start <= prev->vm_start, vmg);
735+
VM_WARN_ON_VMG(start >= end, vmg);
736+
736737
/*
737738
* If vma == prev, then we are offset into a VMA. Otherwise, if we are
738739
* not, we must span a portion of the VMA.
739740
*/
740-
VM_WARN_ON(vma && ((vma != prev && vmg->start != vma->vm_start) ||
741-
vmg->end > vma->vm_end));
741+
VM_WARN_ON_VMG(vma && ((vma != prev && vmg->start != vma->vm_start) ||
742+
vmg->end > vma->vm_end), vmg);
742743
/* The vmi must be positioned within vmg->vma. */
743-
VM_WARN_ON(vma && !(vma_iter_addr(vmg->vmi) >= vma->vm_start &&
744-
vma_iter_addr(vmg->vmi) < vma->vm_end));
744+
VM_WARN_ON_VMG(vma && !(vma_iter_addr(vmg->vmi) >= vma->vm_start &&
745+
vma_iter_addr(vmg->vmi) < vma->vm_end), vmg);
745746

746747
vmg->state = VMA_MERGE_NOMERGE;
747748

@@ -858,9 +859,9 @@ static __must_check struct vm_area_struct *vma_merge_existing_range(
858859

859860
pgoff_t pglen = PHYS_PFN(vmg->end - vmg->start);
860861

861-
VM_WARN_ON(!merge_right);
862+
VM_WARN_ON_VMG(!merge_right, vmg);
862863
/* If we are offset into a VMA, then prev must be vma. */
863-
VM_WARN_ON(vmg->start > vma->vm_start && prev && vma != prev);
864+
VM_WARN_ON_VMG(vmg->start > vma->vm_start && prev && vma != prev, vmg);
864865

865866
if (merge_will_delete_vma) {
866867
vmg->vma = next;
@@ -972,9 +973,9 @@ struct vm_area_struct *vma_merge_new_range(struct vma_merge_struct *vmg)
972973
bool just_expand = vmg->merge_flags & VMG_FLAG_JUST_EXPAND;
973974

974975
mmap_assert_write_locked(vmg->mm);
975-
VM_WARN_ON(vmg->vma);
976+
VM_WARN_ON_VMG(vmg->vma, vmg);
976977
/* vmi must point at or before the gap. */
977-
VM_WARN_ON(vma_iter_addr(vmg->vmi) > end);
978+
VM_WARN_ON_VMG(vma_iter_addr(vmg->vmi) > end, vmg);
978979

979980
vmg->state = VMA_MERGE_NOMERGE;
980981

@@ -1056,18 +1057,18 @@ int vma_expand(struct vma_merge_struct *vmg)
10561057

10571058
remove_next = true;
10581059
/* This should already have been checked by this point. */
1059-
VM_WARN_ON(!can_merge_remove_vma(next));
1060+
VM_WARN_ON_VMG(!can_merge_remove_vma(next), vmg);
10601061
vma_start_write(next);
10611062
ret = dup_anon_vma(vma, next, &anon_dup);
10621063
if (ret)
10631064
return ret;
10641065
}
10651066

10661067
/* Not merging but overwriting any part of next is not handled. */
1067-
VM_WARN_ON(next && !remove_next &&
1068-
next != vma && vmg->end > next->vm_start);
1068+
VM_WARN_ON_VMG(next && !remove_next &&
1069+
next != vma && vmg->end > next->vm_start, vmg);
10691070
/* Only handles expanding */
1070-
VM_WARN_ON(vma->vm_start < vmg->start || vma->vm_end > vmg->end);
1071+
VM_WARN_ON_VMG(vma->vm_start < vmg->start || vma->vm_end > vmg->end, vmg);
10711072

10721073
if (commit_merge(vmg, NULL, remove_next ? next : NULL, NULL, 0, true))
10731074
goto nomem;

0 commit comments

Comments
 (0)