Hi, On Tue, Apr 30, 2013 at 05:21:20PM +0800, Tang Chen wrote: > We mark out movable memory ranges and reserve them with MEMBLK_HOTPLUGGABLE flag in > memblock.reserved. This should be done after the memory mapping is initialized > because the kernel now supports allocate pagetable pages on local node, which > are kernel pages. > > The reserved hotpluggable will be freed to buddy when memory initialization > is done. > > This idea is from Wen Congyang <wency@xxxxxxxxxxxxxx> and Jiang Liu <jiang.liu@xxxxxxxxxx>. > > Suggested-by: Jiang Liu <jiang.liu@xxxxxxxxxx> > Suggested-by: Wen Congyang <wency@xxxxxxxxxxxxxx> > Signed-off-by: Tang Chen <tangchen@xxxxxxxxxxxxxx> > --- > arch/x86/mm/numa.c | 28 ++++++++++++++++++++++++++++ > include/linux/memblock.h | 3 +++ > mm/memblock.c | 19 +++++++++++++++++++ > 3 files changed, 50 insertions(+), 0 deletions(-) > > diff --git a/arch/x86/mm/numa.c b/arch/x86/mm/numa.c > index 1367fe4..a1f1f90 100644 > --- a/arch/x86/mm/numa.c > +++ b/arch/x86/mm/numa.c > @@ -731,6 +731,32 @@ static void __init early_x86_numa_init_mapping(void) > } > #endif > > +#ifdef CONFIG_HAVE_MEMBLOCK_NODE_MAP > +static void __init early_mem_hotplug_init() > +{ > + int i, nid; > + phys_addr_t start, end; > + > + if (!movablecore_enable_srat) > + return; > + > + for (i = 0; i < numa_meminfo.nr_blks; i++) { > + if (!numa_meminfo.blk[i].hotpluggable) > + continue; > + > + nid = numa_meminfo.blk[i].nid; Should we skip ranges on nodes that the kernel uses? e.g. with if (memblock_is_kernel_node(nid)) continue; > + start = numa_meminfo.blk[i].start; > + end = numa_meminfo.blk[i].end; > + > + memblock_reserve_hotpluggable(start, end - start, nid); > + } > +} - I am getting a "PANIC: early exception" when rebooting with movablecore=acpi after hotplugging memory on node0 or node1 of a 2-node VM. The guest kernel is based on git://git.kernel.org/pub/scm/linux/kernel/git/yinghai/linux-yinghai.git for-x86-mm (e9058baf) + these v2 patches. This happens with or without the above memblock_is_kernel_node(nid) check. Perhaps I am missing something or I need a newer "ACPI, numa: Parse numa info early" patch-set? A general question: Disabling hot-pluggability/zone-movable eligibility for a whole node sounds a bit inflexible, if the machine only has one node to begin with. Would it be possible to keep movable information per SRAT entry? I.e if the BIOS presents multiple SRAT entries for one node/PXM (say node 0), and there is no memblock/kernel allocation on one of these SRAT entries, could we still mark this SRAT entry's range as hot-pluggable/movable? Not sure if many real machine BIOSes would do this, but seabios could. This implies that SRAT entries are processed for movable-zone eligilibity before they are merged on node/PXM basis entry-granularity (I think numa_cleanup_meminfo currently does this merge). Of course the kernel should still have enough memory(i.e. non movable zone) to boot. Can we ensure that at least certain amount of memory is non-movable, and then, given more separate SRAT entries for node0 not used by kernel, treat these rest entries as movable? thanks, - Vasilis -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>