[PATCH v4 0/4] Refactor free_area_init_core and add free_area_init_core_hotplug

From: osalvador
Date: Fri Jul 27 2018 - 10:03:36 EST


From: Oscar Salvador <osalvador@xxxxxxx>

Changes:

v3 -> v4:
- Unify patch-5 and patch-4
- Make free_area_init_core __init (Suggested by Michal)
- Make zone_init_internals __paginginit (Suggested by Pavel)
- Add Reviewed-by/Acked-by:

v2 -> v3:
- Think better about split free_area_init_core for
memhotplug/early init context (Suggested by Michal)

This patchset does three things:

1) Clean up/refactor free_area_init_core/free_area_init_node
by moving the ifdefery out of the functions.
2) Move the pgdat/zone initialization in free_area_init_core to its
own function.
3) Introduce free_area_init_core_hotplug, a small subset of free_area_init_core,
which is only called from memhotlug code path.
In this way, we have:

free_area_init_core: called during early initialization
free_area_init_core_hotplug: called whenever a new node is allocated/re-used (memhotplug path)

Oscar Salvador (3):
mm/page_alloc: Move ifdefery out of free_area_init_core
mm/page_alloc: Inline function to handle
CONFIG_DEFERRED_STRUCT_PAGE_INIT
mm/page_alloc: Introduce free_area_init_core_hotplug

Pavel Tatashin (1):
mm: access zone->node via zone_to_nid() and zone_set_nid()

include/linux/mm.h | 13 ++---
include/linux/mmzone.h | 26 +++++++---
mm/memory_hotplug.c | 16 ++----
mm/mempolicy.c | 4 +-
mm/mm_init.c | 9 +---
mm/page_alloc.c | 134 +++++++++++++++++++++++++++++++++++--------------
6 files changed, 130 insertions(+), 72 deletions(-)

--
2.13.6