mm, memory_hotplug: drop zone from build_all_zonelists
build_all_zonelists gets a zone parameter to initialize zone's pagesets.
There is only a single user which gives a non-NULL zone parameter and
that one doesn't really need the rest of the build_all_zonelists (see
commit 6dcd73d701 ("memory-hotplug: allocate zone's pcp before
onlining pages")).
Therefore remove setup_zone_pageset from build_all_zonelists and call it
from its only user directly. This will also remove a pointless zonlists
rebuilding which is always good.
Link: http://lkml.kernel.org/r/20170721143915.14161-5-mhocko@kernel.org
Signed-off-by: Michal Hocko <mhocko@suse.com>
Acked-by: Vlastimil Babka <vbabka@suse.cz>
Cc: Johannes Weiner <hannes@cmpxchg.org>
Cc: Joonsoo Kim <js1304@gmail.com>
Cc: Mel Gorman <mgorman@suse.de>
Cc: Shaohua Li <shaohua.li@intel.com>
Cc: Toshi Kani <toshi.kani@hpe.com>
Cc: Wen Congyang <wency@cn.fujitsu.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
committed by
Linus Torvalds
parent
d9c9a0b972
commit
72675e131e
@@ -5129,7 +5129,6 @@ static void build_zonelists(pg_data_t *pgdat)
|
||||
static void setup_pageset(struct per_cpu_pageset *p, unsigned long batch);
|
||||
static DEFINE_PER_CPU(struct per_cpu_pageset, boot_pageset);
|
||||
static DEFINE_PER_CPU(struct per_cpu_nodestat, boot_nodestats);
|
||||
static void setup_zone_pageset(struct zone *zone);
|
||||
|
||||
/*
|
||||
* Global mutex to protect against size modification of zonelists
|
||||
@@ -5209,20 +5208,14 @@ build_all_zonelists_init(void)
|
||||
* Called with zonelists_mutex held always
|
||||
* unless system_state == SYSTEM_BOOTING.
|
||||
*
|
||||
* __ref due to (1) call of __meminit annotated setup_zone_pageset
|
||||
* [we're only called with non-NULL zone through __meminit paths] and
|
||||
* (2) call of __init annotated helper build_all_zonelists_init
|
||||
* __ref due to call of __init annotated helper build_all_zonelists_init
|
||||
* [protected by SYSTEM_BOOTING].
|
||||
*/
|
||||
void __ref build_all_zonelists(pg_data_t *pgdat, struct zone *zone)
|
||||
void __ref build_all_zonelists(pg_data_t *pgdat)
|
||||
{
|
||||
if (system_state == SYSTEM_BOOTING) {
|
||||
build_all_zonelists_init();
|
||||
} else {
|
||||
#ifdef CONFIG_MEMORY_HOTPLUG
|
||||
if (zone)
|
||||
setup_zone_pageset(zone);
|
||||
#endif
|
||||
/* we have to stop all cpus to guarantee there is no user
|
||||
of zonelist */
|
||||
stop_machine_cpuslocked(__build_all_zonelists, pgdat, NULL);
|
||||
@@ -5496,7 +5489,7 @@ static void __meminit zone_pageset_init(struct zone *zone, int cpu)
|
||||
pageset_set_high_and_batch(zone, pcp);
|
||||
}
|
||||
|
||||
static void __meminit setup_zone_pageset(struct zone *zone)
|
||||
void __meminit setup_zone_pageset(struct zone *zone)
|
||||
{
|
||||
int cpu;
|
||||
zone->pageset = alloc_percpu(struct per_cpu_pageset);
|
||||
|
||||
Reference in New Issue
Block a user