summaryrefslogtreecommitdiff
path: root/include/linux/mqueue.h
diff options
context:
space:
mode:
authorAndrea Arcangeli <aarcange@redhat.com>2016-02-27 02:19:28 +0300
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2016-09-11 10:59:59 +0300
commit09a2499466dc69d1e54e8e879d4591cdd0ca17c8 (patch)
tree6ded058db8cffa190aecdfbd48f7abdfbd159580 /include/linux/mqueue.h
parent7cac57a69919afdf3bdda5242afdd535b2d9a2b0 (diff)
downloadlinux-09a2499466dc69d1e54e8e879d4591cdd0ca17c8.tar.xz
mm: thp: fix SMP race condition between THP page fault and MADV_DONTNEED
commit ad33bb04b2a6cee6c1f99fabb15cddbf93ff0433 upstream. pmd_trans_unstable()/pmd_none_or_trans_huge_or_clear_bad() were introduced to locklessy (but atomically) detect when a pmd is a regular (stable) pmd or when the pmd is unstable and can infinitely transition from pmd_none() and pmd_trans_huge() from under us, while only holding the mmap_sem for reading (for writing not). While holding the mmap_sem only for reading, MADV_DONTNEED can run from under us and so before we can assume the pmd to be a regular stable pmd we need to compare it against pmd_none() and pmd_trans_huge() in an atomic way, with pmd_trans_unstable(). The old pmd_trans_huge() left a tiny window for a race. Useful applications are unlikely to notice the difference as doing MADV_DONTNEED concurrently with a page fault would lead to undefined behavior. [js] 3.12 backport: no pmd_devmap in 3.12 yet. [akpm@linux-foundation.org: tidy up comment grammar/layout] Signed-off-by: Andrea Arcangeli <aarcange@redhat.com> Reported-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Cc: Vlastimil Babka <vbabka@suse.cz> Signed-off-by: Jiri Slaby <jslaby@suse.cz> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'include/linux/mqueue.h')
0 files changed, 0 insertions, 0 deletions