[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20220511010530.60962-1-zhouguanghui1@huawei.com>
Date: Wed, 11 May 2022 01:05:30 +0000
From: Zhou Guanghui <zhouguanghui1@...wei.com>
To: <akpm@...ux-foundation.org>, <rppt@...nel.org>
CC: <linux-kernel@...r.kernel.org>, <linux-mm@...ck.org>,
<xuqiang36@...wei.com>, <zhouguanghui1@...wei.com>
Subject: [PATCH] memblock: config the number of init memblock regions
During early boot, the number of memblocks may exceed 128(some memory
areas are not reported to the kernel due to test failures. As a result,
contiguous memory is divided into multiple parts for reporting). If
the size of the init memblock regions is exceeded before the array size
can be resized, the excess memory will be lost.
Signed-off-by: Zhou Guanghui <zhouguanghui1@...wei.com>
---
mm/Kconfig | 8 ++++++++
mm/memblock.c | 2 +-
2 files changed, 9 insertions(+), 1 deletion(-)
diff --git a/mm/Kconfig b/mm/Kconfig
index 034d87953600..c6881802cccc 100644
--- a/mm/Kconfig
+++ b/mm/Kconfig
@@ -89,6 +89,14 @@ config SPARSEMEM_VMEMMAP
pfn_to_page and page_to_pfn operations. This is the most
efficient option when sufficient kernel resources are available.
+config MEMBLOCK_INIT_REGIONS
+ int "Number of init memblock regions"
+ range 128 1024
+ default 128
+ help
+ The number of init memblock regions which used to track "memory" and
+ "reserved" memblocks during early boot.
+
config HAVE_MEMBLOCK_PHYS_MAP
bool
diff --git a/mm/memblock.c b/mm/memblock.c
index e4f03a6e8e56..6893d26b750e 100644
--- a/mm/memblock.c
+++ b/mm/memblock.c
@@ -22,7 +22,7 @@
#include "internal.h"
-#define INIT_MEMBLOCK_REGIONS 128
+#define INIT_MEMBLOCK_REGIONS CONFIG_MEMBLOCK_INIT_REGIONS
#define INIT_PHYSMEM_REGIONS 4
#ifndef INIT_MEMBLOCK_RESERVED_REGIONS
--
2.17.1
Powered by blists - more mailing lists