aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/x86/include/asm/early_res.h1
-rw-r--r--arch/x86/kernel/e820.c4
-rw-r--r--arch/x86/kernel/early_res.c17
3 files changed, 16 insertions, 6 deletions
diff --git a/arch/x86/include/asm/early_res.h b/arch/x86/include/asm/early_res.h
index 5a4d2eb8e79c..9758f3df9dad 100644
--- a/arch/x86/include/asm/early_res.h
+++ b/arch/x86/include/asm/early_res.h
@@ -12,6 +12,7 @@ u64 find_early_area(u64 ei_start, u64 ei_last, u64 start, u64 end,
12 u64 size, u64 align); 12 u64 size, u64 align);
13u64 find_early_area_size(u64 ei_start, u64 ei_last, u64 start, 13u64 find_early_area_size(u64 ei_start, u64 ei_last, u64 start,
14 u64 *sizep, u64 align); 14 u64 *sizep, u64 align);
15u64 find_fw_memmap_area(u64 start, u64 end, u64 size, u64 align);
15#include <linux/range.h> 16#include <linux/range.h>
16int get_free_all_memory_range(struct range **rangep, int nodeid); 17int get_free_all_memory_range(struct range **rangep, int nodeid);
17 18
diff --git a/arch/x86/kernel/e820.c b/arch/x86/kernel/e820.c
index b4e512b03aa7..36918d8463ab 100644
--- a/arch/x86/kernel/e820.c
+++ b/arch/x86/kernel/e820.c
@@ -748,6 +748,10 @@ u64 __init find_e820_area(u64 start, u64 end, u64 size, u64 align)
748 return -1ULL; 748 return -1ULL;
749} 749}
750 750
751u64 __init find_fw_memmap_area(u64 start, u64 end, u64 size, u64 align)
752{
753 return find_e820_area(start, end, size, align);
754}
751/* 755/*
752 * Find next free range after *start 756 * Find next free range after *start
753 */ 757 */
diff --git a/arch/x86/kernel/early_res.c b/arch/x86/kernel/early_res.c
index 656cdf86a2fa..1458dc022343 100644
--- a/arch/x86/kernel/early_res.c
+++ b/arch/x86/kernel/early_res.c
@@ -7,16 +7,14 @@
7#include <linux/bootmem.h> 7#include <linux/bootmem.h>
8#include <linux/mm.h> 8#include <linux/mm.h>
9 9
10#include <asm/e820.h>
11#include <asm/early_res.h> 10#include <asm/early_res.h>
12#include <asm/proto.h>
13 11
14/* 12/*
15 * Early reserved memory areas. 13 * Early reserved memory areas.
16 */ 14 */
17/* 15/*
18 * need to make sure this one is bigger enough before 16 * need to make sure this one is bigger enough before
19 * find_e820_area could be used 17 * find_fw_memmap_area could be used
20 */ 18 */
21#define MAX_EARLY_RES_X 32 19#define MAX_EARLY_RES_X 32
22 20
@@ -180,6 +178,13 @@ void __init reserve_early_overlap_ok(u64 start, u64 end, char *name)
180 __reserve_early(start, end, name, 1); 178 __reserve_early(start, end, name, 1);
181} 179}
182 180
181u64 __init __weak find_fw_memmap_area(u64 start, u64 end, u64 size, u64 align)
182{
183 panic("should have find_fw_memmap_area defined with arch");
184
185 return -1ULL;
186}
187
183static void __init __check_and_double_early_res(u64 ex_start, u64 ex_end) 188static void __init __check_and_double_early_res(u64 ex_start, u64 ex_end)
184{ 189{
185 u64 start, end, size, mem; 190 u64 start, end, size, mem;
@@ -198,13 +203,13 @@ static void __init __check_and_double_early_res(u64 ex_start, u64 ex_end)
198 start = early_res[0].end; 203 start = early_res[0].end;
199 end = ex_start; 204 end = ex_start;
200 if (start + size < end) 205 if (start + size < end)
201 mem = find_e820_area(start, end, size, 206 mem = find_fw_memmap_area(start, end, size,
202 sizeof(struct early_res)); 207 sizeof(struct early_res));
203 if (mem == -1ULL) { 208 if (mem == -1ULL) {
204 start = ex_end; 209 start = ex_end;
205 end = max_pfn_mapped << PAGE_SHIFT; 210 end = max_pfn_mapped << PAGE_SHIFT;
206 if (start + size < end) 211 if (start + size < end)
207 mem = find_e820_area(start, end, size, 212 mem = find_fw_memmap_area(start, end, size,
208 sizeof(struct early_res)); 213 sizeof(struct early_res));
209 } 214 }
210 if (mem == -1ULL) 215 if (mem == -1ULL)
@@ -343,7 +348,7 @@ int __init get_free_all_memory_range(struct range **rangep, int nodeid)
343 start = MAX_DMA32_PFN << PAGE_SHIFT; 348 start = MAX_DMA32_PFN << PAGE_SHIFT;
344#endif 349#endif
345 end = max_pfn_mapped << PAGE_SHIFT; 350 end = max_pfn_mapped << PAGE_SHIFT;
346 mem = find_e820_area(start, end, size, sizeof(struct range)); 351 mem = find_fw_memmap_area(start, end, size, sizeof(struct range));
347 if (mem == -1ULL) 352 if (mem == -1ULL)
348 panic("can not find more space for range free"); 353 panic("can not find more space for range free");
349 354