vm: fix vm_pgoff wrap in stack expansion

Commit 982134ba62 ("mm: avoid wrapping vm_pgoff in mremap()") fixed
the case of a expanding mapping causing vm_pgoff wrapping when you used
mremap.  But there was another case where we expand mappings hiding in
plain sight: the automatic stack expansion.

This fixes that case too.

This one also found by Robert Święcki, using his nasty system call
fuzzer tool.  Good job.

Reported-and-tested-by: Robert Święcki <robert@swiecki.net>
Cc: stable@kernel.org
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
Linus Torvalds 2011-04-13 08:07:28 -07:00
parent 60d48c1e67
commit a626ca6a65

View File

@ -1814,11 +1814,14 @@ static int expand_downwards(struct vm_area_struct *vma,
size = vma->vm_end - address; size = vma->vm_end - address;
grow = (vma->vm_start - address) >> PAGE_SHIFT; grow = (vma->vm_start - address) >> PAGE_SHIFT;
error = acct_stack_growth(vma, size, grow); error = -ENOMEM;
if (!error) { if (grow <= vma->vm_pgoff) {
vma->vm_start = address; error = acct_stack_growth(vma, size, grow);
vma->vm_pgoff -= grow; if (!error) {
perf_event_mmap(vma); vma->vm_start = address;
vma->vm_pgoff -= grow;
perf_event_mmap(vma);
}
} }
} }
vma_unlock_anon_vma(vma); vma_unlock_anon_vma(vma);