]> git.hungrycats.org Git - linux/commit
mm: fix new crash in unmapped_area_topdown()
authorHugh Dickins <hughd@google.com>
Tue, 20 Jun 2017 09:10:44 +0000 (02:10 -0700)
committerSasha Levin <alexander.levin@verizon.com>
Wed, 28 Jun 2017 22:57:50 +0000 (18:57 -0400)
commitdcda279dede75d5cb4e6af18ba90eb4ca1e813ee
tree1edf46758ba919ca6dea9ca5dc3c5e6bcbf19208
parent8b18c6b2a0dde5186ed83a60c4915c0909cbeb0a
mm: fix new crash in unmapped_area_topdown()

[ Upstream commit f4cb767d76cf7ee72f97dd76f6cfa6c76a5edc89 ]

Trinity gets kernel BUG at mm/mmap.c:1963! in about 3 minutes of
mmap testing.  That's the VM_BUG_ON(gap_end < gap_start) at the
end of unmapped_area_topdown().  Linus points out how MAP_FIXED
(which does not have to respect our stack guard gap intentions)
could result in gap_end below gap_start there.  Fix that, and
the similar case in its alternative, unmapped_area().

Cc: stable@vger.kernel.org
Fixes: 1be7107fbe18 ("mm: larger stack guard gap, between vmas")
Reported-by: Dave Jones <davej@codemonkey.org.uk>
Debugged-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Hugh Dickins <hughd@google.com>
Acked-by: Michal Hocko <mhocko@suse.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Sasha Levin <alexander.levin@verizon.com>
mm/mmap.c