diff options
author | Johannes Weiner <hannes@cmpxchg.org> | 2016-03-15 17:57:54 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2016-03-15 19:55:16 -0400 |
commit | 74485cf2bc85d2a10c3653fff4fe956db67ce2a9 (patch) | |
tree | cf5923bce0b30a95c88a096cf33557336767848d /mm | |
parent | 7cf91a98e607c2f935dbcc177d70011e95b8faff (diff) |
mm: migrate: consolidate mem_cgroup_migrate() calls
Rather than scattering mem_cgroup_migrate() calls all over the place,
have a single call from a safe place where every migration operation
eventually ends up in - migrate_page_copy().
Signed-off-by: Johannes Weiner <hannes@cmpxchg.org>
Suggested-by: Hugh Dickins <hughd@google.com>
Acked-by: Vladimir Davydov <vdavydov@virtuozzo.com>
Acked-by: Michal Hocko <mhocko@suse.com>
Cc: Mateusz Guzik <mguzik@redhat.com>
Cc: Sergey Senozhatsky <sergey.senozhatsky.work@gmail.com>
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/migrate.c | 9 |
1 files changed, 2 insertions, 7 deletions
diff --git a/mm/migrate.c b/mm/migrate.c index 848327d4a7ed..568284ec75d4 100644 --- a/mm/migrate.c +++ b/mm/migrate.c | |||
@@ -331,8 +331,6 @@ int migrate_page_move_mapping(struct address_space *mapping, | |||
331 | if (PageSwapBacked(page)) | 331 | if (PageSwapBacked(page)) |
332 | SetPageSwapBacked(newpage); | 332 | SetPageSwapBacked(newpage); |
333 | 333 | ||
334 | mem_cgroup_migrate(page, newpage); | ||
335 | |||
336 | return MIGRATEPAGE_SUCCESS; | 334 | return MIGRATEPAGE_SUCCESS; |
337 | } | 335 | } |
338 | 336 | ||
@@ -428,8 +426,6 @@ int migrate_page_move_mapping(struct address_space *mapping, | |||
428 | } | 426 | } |
429 | local_irq_enable(); | 427 | local_irq_enable(); |
430 | 428 | ||
431 | mem_cgroup_migrate(page, newpage); | ||
432 | |||
433 | return MIGRATEPAGE_SUCCESS; | 429 | return MIGRATEPAGE_SUCCESS; |
434 | } | 430 | } |
435 | 431 | ||
@@ -471,8 +467,6 @@ int migrate_huge_page_move_mapping(struct address_space *mapping, | |||
471 | 467 | ||
472 | spin_unlock_irq(&mapping->tree_lock); | 468 | spin_unlock_irq(&mapping->tree_lock); |
473 | 469 | ||
474 | mem_cgroup_migrate(page, newpage); | ||
475 | |||
476 | return MIGRATEPAGE_SUCCESS; | 470 | return MIGRATEPAGE_SUCCESS; |
477 | } | 471 | } |
478 | 472 | ||
@@ -586,6 +580,8 @@ void migrate_page_copy(struct page *newpage, struct page *page) | |||
586 | end_page_writeback(newpage); | 580 | end_page_writeback(newpage); |
587 | 581 | ||
588 | copy_page_owner(page, newpage); | 582 | copy_page_owner(page, newpage); |
583 | |||
584 | mem_cgroup_migrate(page, newpage); | ||
589 | } | 585 | } |
590 | 586 | ||
591 | /************************************************************ | 587 | /************************************************************ |
@@ -1846,7 +1842,6 @@ fail_putback: | |||
1846 | } | 1842 | } |
1847 | 1843 | ||
1848 | mlock_migrate_page(new_page, page); | 1844 | mlock_migrate_page(new_page, page); |
1849 | mem_cgroup_migrate(page, new_page); | ||
1850 | page_remove_rmap(page, true); | 1845 | page_remove_rmap(page, true); |
1851 | set_page_owner_migrate_reason(new_page, MR_NUMA_MISPLACED); | 1846 | set_page_owner_migrate_reason(new_page, MR_NUMA_MISPLACED); |
1852 | 1847 | ||