提交 f07111db 编写于 作者: Z Zhenhua Huang 提交者: Zheng Zengkai

mm: fix page_owner initializing issue for arm32

mainline inclusion
from mainline-v5.11-rc1
commit 7fb7ab6d
category: bugfix
bugzilla: https://gitee.com/openeuler/kernel/issues/I49LXW
CVE: NA

-------------------------------------------------

Page owner of pages used by page owner itself used is missing on arm32
targets.  The reason is dummy_handle and failure_handle is not initialized
correctly.  Buddy allocator is used to initialize these two handles.
However, buddy allocator is not ready when page owner calls it.  This
change fixed that by initializing page owner after buddy initialization.

The working flow before and after this change are:
original logic:
 1. allocated memory for page_ext(using memblock).
 2. invoke the init callback of page_ext_ops like page_owner(using buddy
    allocator).
 3. initialize buddy.

after this change:
 1. allocated memory for page_ext(using memblock).
 2. initialize buddy.
 3. invoke the init callback of page_ext_ops like page_owner(using buddy
    allocator).

with the change, failure/dummy_handle can get its correct value and page
owner output for example has the one for page owner itself:

  Page allocated via order 2, mask 0x6202c0(GFP_USER|__GFP_NOWARN),
  pid 1006, ts 67278156558 ns
  PFN 543776 type Unmovable Block 531 type Unmovable Flags 0x0()
    init_page_owner+0x28/0x2f8
    invoke_init_callbacks_flatmem+0x24/0x34
    start_kernel+0x33c/0x5d8

Link: https://lkml.kernel.org/r/1603104925-5888-1-git-send-email-zhenhuah@codeaurora.orgSigned-off-by: NZhenhua Huang <zhenhuah@codeaurora.org>
Acked-by: NVlastimil Babka <vbabka@suse.cz>
Cc: Joonsoo Kim <iamjoonsoo.kim@lge.com>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
(cherry picked from commit 7fb7ab6d)
Signed-off-by: NKefeng Wang <wangkefeng.wang@huawei.com>
Signed-off-by: NYuanzheng Song <songyuanzheng@huawei.com>
Reviewed-by: NKefeng Wang <wangkefeng.wang@huawei.com>
Signed-off-by: NZheng Zengkai <zhengzengkai@huawei.com>
上级 e1881ad5
...@@ -44,8 +44,12 @@ static inline void page_ext_init_flatmem(void) ...@@ -44,8 +44,12 @@ static inline void page_ext_init_flatmem(void)
{ {
} }
extern void page_ext_init(void); extern void page_ext_init(void);
static inline void page_ext_init_flatmem_late(void)
{
}
#else #else
extern void page_ext_init_flatmem(void); extern void page_ext_init_flatmem(void);
extern void page_ext_init_flatmem_late(void);
static inline void page_ext_init(void) static inline void page_ext_init(void)
{ {
} }
...@@ -76,6 +80,10 @@ static inline void page_ext_init(void) ...@@ -76,6 +80,10 @@ static inline void page_ext_init(void)
{ {
} }
static inline void page_ext_init_flatmem_late(void)
{
}
static inline void page_ext_init_flatmem(void) static inline void page_ext_init_flatmem(void)
{ {
} }
......
...@@ -830,6 +830,8 @@ static void __init mm_init(void) ...@@ -830,6 +830,8 @@ static void __init mm_init(void)
init_debug_pagealloc(); init_debug_pagealloc();
report_meminit(); report_meminit();
mem_init(); mem_init();
/* page_owner must be initialized after buddy is ready */
page_ext_init_flatmem_late();
kmem_cache_init(); kmem_cache_init();
kmemleak_init(); kmemleak_init();
pgtable_init(); pgtable_init();
......
...@@ -99,12 +99,19 @@ static void __init invoke_init_callbacks(void) ...@@ -99,12 +99,19 @@ static void __init invoke_init_callbacks(void)
} }
} }
#ifndef CONFIG_SPARSEMEM
void __init page_ext_init_flatmem_late(void)
{
invoke_init_callbacks();
}
#endif
static inline struct page_ext *get_entry(void *base, unsigned long index) static inline struct page_ext *get_entry(void *base, unsigned long index)
{ {
return base + page_ext_size * index; return base + page_ext_size * index;
} }
#if !defined(CONFIG_SPARSEMEM) #ifndef CONFIG_SPARSEMEM
void __meminit pgdat_page_ext_init(struct pglist_data *pgdat) void __meminit pgdat_page_ext_init(struct pglist_data *pgdat)
...@@ -177,7 +184,6 @@ void __init page_ext_init_flatmem(void) ...@@ -177,7 +184,6 @@ void __init page_ext_init_flatmem(void)
goto fail; goto fail;
} }
pr_info("allocated %ld bytes of page_ext\n", total_usage); pr_info("allocated %ld bytes of page_ext\n", total_usage);
invoke_init_callbacks();
return; return;
fail: fail:
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册