* [PATCH 0/4] treewide, mm: initialize node_possible_map like the other node maps
@ 2026-07-01 17:18 Sang-Heon Jeon
2026-07-01 17:18 ` [PATCH 2/4] sh: set node_possible_map in do_init_bootmem() Sang-Heon Jeon
0 siblings, 1 reply; 2+ messages in thread
From: Sang-Heon Jeon @ 2026-07-01 17:18 UTC (permalink / raw)
To: akpm, Andreas Larsson, David S. Miller, John Paul Adrian Glaubitz,
Madhavan Srinivasan, Michael Ellerman, Rich Felker,
Vlastimil Babka, Yoshinori Sato, Yury Norov
Cc: linux-mm, Sang-Heon Jeon, Brendan Jackman,
Christophe Leroy (CS GROUP), Johannes Weiner, linux-kernel,
linuxppc-dev, linux-sh, Michal Hocko, Nicholas Piggin,
Rasmus Villemoes, sparclinux, Suren Baghdasaryan, Zi Yan
While reviewing an earlier series [1], Andrew asked why we carefully
initialize node_possible_map at compile time, then zero it within __init
code anyway.
node_possible_map, aliased by node_states[N_POSSIBLE], is initialized to
NODE_MASK_ALL at compile time, unlike the other entries, which are
initialized with only node 0 set.
Architectures that use numa_memblks set node_possible_map from
numa_nodes_parsed, so the compile-time value is meaningless for them.
However, a few architectures that do not use numa_memblks do not set
node_possible_map on their own. Once these architectures set
node_possible_map to match their own topology, the NODE_MASK_ALL
initialization can be removed.
Patches 1-2 handle sparc64 and sh, which do not set node_possible_map
themselves. Both set node_online_map from their topology, so set
node_possible_map from node_online_map.
Patch 3 handles powerpc, which sets node_possible_map by intersecting it
with node_online_map. Nothing sets node_possible_map before this, so it is
still NODE_MASK_ALL and the intersection is just node_online_map. Once
patch 4 changes that initial value, the intersection would no longer be
node_online_map, so assign node_online_map directly.
Patch 4 initializes node_possible_map with only node 0 set, like the other
node_states[] entries. NODE_MASK_ALL is then no longer used, so remove it
and its only helper NODE_MASK_LAST_WORD.
[1] https://lore.kernel.org/all/20260624204030.3c8baa67713b6ca1d537baba@linux-foundation.org/
Sang-Heon Jeon (4):
sparc64: set node_possible_map in bootmem_init_numa()
sh: set node_possible_map in do_init_bootmem()
powerpc/numa: set node_possible_map from node_online_map
mm/page_alloc: initialize node_possible_map like the other node maps
arch/powerpc/mm/numa.c | 2 +-
arch/sh/mm/init.c | 2 ++
arch/sparc/mm/init_64.c | 2 ++
include/linux/nodemask.h | 20 --------------------
mm/page_alloc.c | 2 +-
5 files changed, 6 insertions(+), 22 deletions(-)
--
2.43.0
^ permalink raw reply [flat|nested] 2+ messages in thread
* [PATCH 2/4] sh: set node_possible_map in do_init_bootmem()
2026-07-01 17:18 [PATCH 0/4] treewide, mm: initialize node_possible_map like the other node maps Sang-Heon Jeon
@ 2026-07-01 17:18 ` Sang-Heon Jeon
0 siblings, 0 replies; 2+ messages in thread
From: Sang-Heon Jeon @ 2026-07-01 17:18 UTC (permalink / raw)
To: akpm, Yoshinori Sato, Rich Felker, John Paul Adrian Glaubitz
Cc: linux-mm, Sang-Heon Jeon, Andreas Larsson, David S. Miller,
linux-kernel, linux-sh, Madhavan Srinivasan, Michael Ellerman,
Vlastimil Babka, Yury Norov
Unlike other NUMA architectures, sh never sets node_possible_map.
do_init_bootmem() marks node 0 online and plat_mem_setup() marks the
rest online, after which node_online_map does not change, so set
node_possible_map from node_online_map.
Signed-off-by: Sang-Heon Jeon <ekffu200098@gmail.com>
---
arch/sh/mm/init.c | 2 ++
1 file changed, 2 insertions(+)
diff --git a/arch/sh/mm/init.c b/arch/sh/mm/init.c
index 110308bdef01..13954d7bbdae 100644
--- a/arch/sh/mm/init.c
+++ b/arch/sh/mm/init.c
@@ -227,6 +227,8 @@ static void __init do_init_bootmem(void)
node_set_online(0);
plat_mem_setup();
+
+ node_possible_map = node_online_map;
}
static void __init early_reserve_mem(void)
--
2.43.0
^ permalink raw reply related [flat|nested] 2+ messages in thread
end of thread, other threads:[~2026-07-01 17:19 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-07-01 17:18 [PATCH 0/4] treewide, mm: initialize node_possible_map like the other node maps Sang-Heon Jeon
2026-07-01 17:18 ` [PATCH 2/4] sh: set node_possible_map in do_init_bootmem() Sang-Heon Jeon
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox