summaryrefslogtreecommitdiffstats
path: root/mm/migrate.c
diff options
context:
space:
mode:
authorHillf Danton <dhillf@gmail.com>2011-12-08 23:34:20 +0100
committerLinus Torvalds <torvalds@linux-foundation.org>2011-12-09 16:50:28 +0100
commit09761333ed47e899cc1482c13090b95f3f711971 (patch)
treeb2563e89da16b64727b45b384dba94e1dcd8dfa2 /mm/migrate.c
parentthp: set compound tail page _count to zero (diff)
downloadlinux-09761333ed47e899cc1482c13090b95f3f711971.tar.xz
linux-09761333ed47e899cc1482c13090b95f3f711971.zip
mm/migrate.c: pair unlock_page() and lock_page() when migrating huge pages
Avoid unlocking and unlocked page if we failed to lock it. Signed-off-by: Hillf Danton <dhillf@gmail.com> Cc: Naoya Horiguchi <n-horiguchi@ah.jp.nec.com> Cc: Andrea Arcangeli <aarcange@redhat.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to '')
-rw-r--r--mm/migrate.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/mm/migrate.c b/mm/migrate.c
index 578e29174fa6..177aca424a06 100644
--- a/mm/migrate.c
+++ b/mm/migrate.c
@@ -871,9 +871,9 @@ static int unmap_and_move_huge_page(new_page_t get_new_page,
if (anon_vma)
put_anon_vma(anon_vma);
-out:
unlock_page(hpage);
+out:
if (rc != -EAGAIN) {
list_del(&hpage->lru);
put_page(hpage);