Since we have introduced hotplug info into struct numa_meminfo, we need to consider it when cleanup numa_meminfo. The original logic in numa_cleanup_meminfo() is: Merge blocks on the same node, holes between which don't overlap with memory on other nodes. This patch modifies numa_cleanup_meminfo() logic like this: Merge blocks with the same hotpluggable type on the same node, holes between which don't overlap with memory on other nodes. Signed-off-by: Tang Chen <tangchen@xxxxxxxxxxxxxx> --- arch/x86/mm/numa.c | 13 +++++++++---- 1 files changed, 9 insertions(+), 4 deletions(-) diff --git a/arch/x86/mm/numa.c b/arch/x86/mm/numa.c index 892729b..fec5ff8 100644 --- a/arch/x86/mm/numa.c +++ b/arch/x86/mm/numa.c @@ -292,18 +292,22 @@ int __init numa_cleanup_meminfo(struct numa_meminfo *mi) } /* - * Join together blocks on the same node, holes - * between which don't overlap with memory on other - * nodes. + * Join together blocks on the same node, with the same + * hotpluggable flags, holes between which don't overlap + * with memory on other nodes. */ if (bi->nid != bj->nid) continue; + if (bi->hotpluggable != bj->hotpluggable) + continue; + start = min(bi->start, bj->start); end = max(bi->end, bj->end); for (k = 0; k < mi->nr_blks; k++) { struct numa_memblk *bk = &mi->blk[k]; - if (bi->nid == bk->nid) + if (bi->nid == bk->nid && + bi->hotpluggable == bk->hotpluggable) continue; if (start < bk->end && end > bk->start) break; @@ -323,6 +327,7 @@ int __init numa_cleanup_meminfo(struct numa_meminfo *mi) for (i = mi->nr_blks; i < ARRAY_SIZE(mi->blk); i++) { mi->blk[i].start = mi->blk[i].end = 0; mi->blk[i].nid = NUMA_NO_NODE; + mi->blk[i].hotpluggable = false; } return 0; -- 1.7.1 -- 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>