diff options
author | Mel Gorman <mgorman@suse.de> | 2013-12-18 20:08:38 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-12-18 22:04:51 -0500 |
commit | c3a489cac38d43ea6dc4ac240473b44b46deecf7 (patch) | |
tree | 3a9dd7e524a784904c3e05cab0586bff349c45d6 /mm | |
parent | 0c5f83c23ca703d32f930393825487257a5cde6d (diff) |
mm: numa: ensure anon_vma is locked to prevent parallel THP splits
The anon_vma lock prevents parallel THP splits and any associated
complexity that arises when handling splits during THP migration. This
patch checks if the lock was successfully acquired and bails from THP
migration if it failed for any reason.
Signed-off-by: Mel Gorman <mgorman@suse.de>
Reviewed-by: Rik van Riel <riel@redhat.com>
Cc: Alex Thorlton <athorlton@sgi.com>
Cc: <stable@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm')
-rw-r--r-- | mm/huge_memory.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/mm/huge_memory.c b/mm/huge_memory.c index 420826efda48..dbafffa5e2ee 100644 --- a/mm/huge_memory.c +++ b/mm/huge_memory.c | |||
@@ -1359,6 +1359,13 @@ int do_huge_pmd_numa_page(struct mm_struct *mm, struct vm_area_struct *vma, | |||
1359 | goto out_unlock; | 1359 | goto out_unlock; |
1360 | } | 1360 | } |
1361 | 1361 | ||
1362 | /* Bail if we fail to protect against THP splits for any reason */ | ||
1363 | if (unlikely(!anon_vma)) { | ||
1364 | put_page(page); | ||
1365 | page_nid = -1; | ||
1366 | goto clear_pmdnuma; | ||
1367 | } | ||
1368 | |||
1362 | /* | 1369 | /* |
1363 | * Migrate the THP to the requested node, returns with page unlocked | 1370 | * Migrate the THP to the requested node, returns with page unlocked |
1364 | * and pmd_numa cleared. | 1371 | * and pmd_numa cleared. |