diff options
author | Joonsoo Kim <iamjoonsoo.kim@lge.com> | 2016-07-26 18:23:49 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2016-07-26 19:19:19 -0400 |
commit | a9627bc5e34e79ae80a33241b8a1501cc498e191 (patch) | |
tree | f3ecdabcbbbcbcc5b53c1aef2a24d3feab3be0d4 /mm/page_alloc.c | |
parent | a8efe1c982a22c95884dee1ddf2e721567d1f483 (diff) |
mm/page_owner: introduce split_page_owner and replace manual handling
split_page() calls set_page_owner() to set up page_owner to each pages.
But, it has a drawback that head page and the others have different
stacktrace because callsite of set_page_owner() is slightly differnt.
To avoid this problem, this patch copies head page's page_owner to the
others. It needs to introduce new function, split_page_owner() but it
also remove the other function, get_page_owner_gfp() so looks good to
do.
Link: http://lkml.kernel.org/r/1464230275-25791-4-git-send-email-iamjoonsoo.kim@lge.com
Signed-off-by: Joonsoo Kim <iamjoonsoo.kim@lge.com>
Acked-by: Vlastimil Babka <vbabka@suse.cz>
Cc: Mel Gorman <mgorman@techsingularity.net>
Cc: Minchan Kim <minchan@kernel.org>
Cc: Alexander Potapenko <glider@google.com>
Cc: Hugh Dickins <hughd@google.com>
Cc: Michal Hocko <mhocko@kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm/page_alloc.c')
-rw-r--r-- | mm/page_alloc.c | 8 |
1 files changed, 2 insertions, 6 deletions
diff --git a/mm/page_alloc.c b/mm/page_alloc.c index f07552fc43e1..a82b303c19b1 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c | |||
@@ -2461,7 +2461,6 @@ void free_hot_cold_page_list(struct list_head *list, bool cold) | |||
2461 | void split_page(struct page *page, unsigned int order) | 2461 | void split_page(struct page *page, unsigned int order) |
2462 | { | 2462 | { |
2463 | int i; | 2463 | int i; |
2464 | gfp_t gfp_mask; | ||
2465 | 2464 | ||
2466 | VM_BUG_ON_PAGE(PageCompound(page), page); | 2465 | VM_BUG_ON_PAGE(PageCompound(page), page); |
2467 | VM_BUG_ON_PAGE(!page_count(page), page); | 2466 | VM_BUG_ON_PAGE(!page_count(page), page); |
@@ -2475,12 +2474,9 @@ void split_page(struct page *page, unsigned int order) | |||
2475 | split_page(virt_to_page(page[0].shadow), order); | 2474 | split_page(virt_to_page(page[0].shadow), order); |
2476 | #endif | 2475 | #endif |
2477 | 2476 | ||
2478 | gfp_mask = get_page_owner_gfp(page); | 2477 | for (i = 1; i < (1 << order); i++) |
2479 | set_page_owner(page, 0, gfp_mask); | ||
2480 | for (i = 1; i < (1 << order); i++) { | ||
2481 | set_page_refcounted(page + i); | 2478 | set_page_refcounted(page + i); |
2482 | set_page_owner(page + i, 0, gfp_mask); | 2479 | split_page_owner(page, order); |
2483 | } | ||
2484 | } | 2480 | } |
2485 | EXPORT_SYMBOL_GPL(split_page); | 2481 | EXPORT_SYMBOL_GPL(split_page); |
2486 | 2482 | ||