提交 3cae8631 编写于 作者: V Vlastimil Babka 提交者: Zheng Zengkai

mm, page_alloc: remove setup_pageset()

mainline inclusion
from mainline-5.11-rc1
commit 69a8396a
category: bugfix
bugzilla: https://gitee.com/openeuler/kernel/issues/I4MWJF
CVE: NA

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

We initialize boot-time pagesets with setup_pageset(), which sets high and
batch values that effectively disable pcplists.

We can remove this wrapper if we just set these values for all pagesets in
pageset_init().  Non-boot pagesets then subsequently update them to the
proper values.

No functional change.

Link: https://lkml.kernel.org/r/20201111092812.11329-4-vbabka@suse.czSigned-off-by: NVlastimil Babka <vbabka@suse.cz>
Reviewed-by: NDavid Hildenbrand <david@redhat.com>
Reviewed-by: NOscar Salvador <osalvador@suse.de>
Acked-by: NMichal Hocko <mhocko@suse.com>
Acked-by: NPankaj Gupta <pankaj.gupta@cloud.ionos.com>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
(cherry picked from commit 69a8396a)
Signed-off-by: NGuilei Xie <xieguilei@huawei.com>
Reviewed-by: NKefeng Wang <wangkefeng.wang@huawei.com>
Signed-off-by: NZheng Zengkai <zhengzengkai@huawei.com>
上级 3148740e
...@@ -6112,7 +6112,7 @@ static void build_zonelists(pg_data_t *pgdat) ...@@ -6112,7 +6112,7 @@ static void build_zonelists(pg_data_t *pgdat)
* not check if the processor is online before following the pageset pointer. * not check if the processor is online before following the pageset pointer.
* Other parts of the kernel may not check if the zone is available. * Other parts of the kernel may not check if the zone is available.
*/ */
static void setup_pageset(struct per_cpu_pageset *p); static void pageset_init(struct per_cpu_pageset *p);
static DEFINE_PER_CPU(struct per_cpu_pageset, boot_pageset); static DEFINE_PER_CPU(struct per_cpu_pageset, boot_pageset);
static DEFINE_PER_CPU(struct per_cpu_nodestat, boot_nodestats); static DEFINE_PER_CPU(struct per_cpu_nodestat, boot_nodestats);
...@@ -6180,7 +6180,7 @@ build_all_zonelists_init(void) ...@@ -6180,7 +6180,7 @@ build_all_zonelists_init(void)
* (a chicken-egg dilemma). * (a chicken-egg dilemma).
*/ */
for_each_possible_cpu(cpu) for_each_possible_cpu(cpu)
setup_pageset(&per_cpu(boot_pageset, cpu)); pageset_init(&per_cpu(boot_pageset, cpu));
mminit_verify_zonelist(); mminit_verify_zonelist();
cpuset_init_current_mems_allowed(); cpuset_init_current_mems_allowed();
...@@ -6600,12 +6600,15 @@ static void pageset_init(struct per_cpu_pageset *p) ...@@ -6600,12 +6600,15 @@ static void pageset_init(struct per_cpu_pageset *p)
pcp = &p->pcp; pcp = &p->pcp;
for (migratetype = 0; migratetype < MIGRATE_PCPTYPES; migratetype++) for (migratetype = 0; migratetype < MIGRATE_PCPTYPES; migratetype++)
INIT_LIST_HEAD(&pcp->lists[migratetype]); INIT_LIST_HEAD(&pcp->lists[migratetype]);
}
static void setup_pageset(struct per_cpu_pageset *p) /*
{ * Set batch and high values safe for a boot pageset. A true percpu
pageset_init(p); * pageset's initialization will update them subsequently. Here we don't
pageset_update(&p->pcp, 0, 1); * need to be as careful as pageset_update() as nobody can access the
* pageset yet.
*/
pcp->high = 0;
pcp->batch = 1;
} }
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册