]> www.infradead.org Git - users/jedix/linux-maple.git/commit
mm: replace vma_lock_anon_vma with anon_vma_lock_read/write
authorKonstantin Khlebnikov <koct9i@gmail.com>
Fri, 5 Feb 2016 23:36:50 +0000 (15:36 -0800)
committerChuck Anderson <chuck.anderson@oracle.com>
Thu, 26 May 2016 22:44:47 +0000 (15:44 -0700)
commit7dcf6cd4c84f6e4ddb9f1dac6aa15e78021c3b36
treea0ec4b5ea4a9f201428d8780da6464e183c4fdbf
parent2bde9a4df028b450fc41ba7d710f6ad966d06cb0
mm: replace vma_lock_anon_vma with anon_vma_lock_read/write

Orabug: 23330819

[ Upstream commit 12352d3cae2cebe18805a91fab34b534d7444231 ]

Sequence vma_lock_anon_vma() - vma_unlock_anon_vma() isn't safe if
anon_vma appeared between lock and unlock.  We have to check anon_vma
first or call anon_vma_prepare() to be sure that it's here.  There are
only few users of these legacy helpers.  Let's get rid of them.

This patch fixes anon_vma lock imbalance in validate_mm().  Write lock
isn't required here, read lock is enough.

And reorders expand_downwards/expand_upwards: security_mmap_addr() and
wrapping-around check don't have to be under anon vma lock.

Link: https://lkml.kernel.org/r/CACT4Y+Y908EjM2z=706dv4rV6dWtxTLK9nFg9_7DhRMLppBo2g@mail.gmail.com
Signed-off-by: Konstantin Khlebnikov <koct9i@gmail.com>
Reported-by: Dmitry Vyukov <dvyukov@google.com>
Acked-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
Cc: Andrea Arcangeli <aarcange@redhat.com>
Cc: <stable@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Sasha Levin <sasha.levin@oracle.com>
(cherry picked from commit 4b5eaa857d64ea737c3bed1eb9b3dd201dd2cecf)

Signed-off-by: Dan Duval <dan.duval@oracle.com>
include/linux/rmap.h
mm/mmap.c