diff options
| -rw-r--r-- | arch/x86/Kconfig | 3 | ||||
| -rw-r--r-- | arch/x86/include/asm/e820.h | 2 | ||||
| -rw-r--r-- | arch/x86/kernel/Makefile | 2 | ||||
| -rw-r--r-- | arch/x86/kernel/e820.c | 10 | ||||
| -rw-r--r-- | include/linux/early_res.h (renamed from arch/x86/include/asm/early_res.h) | 7 | ||||
| -rw-r--r-- | kernel/Makefile | 1 | ||||
| -rw-r--r-- | kernel/early_res.c (renamed from arch/x86/kernel/early_res.c) | 16 |
7 files changed, 23 insertions, 18 deletions
diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig index 29f9efb74fc7..0e9f8b10de52 100644 --- a/arch/x86/Kconfig +++ b/arch/x86/Kconfig | |||
| @@ -183,6 +183,9 @@ config ARCH_SUPPORTS_OPTIMIZED_INLINING | |||
| 183 | config ARCH_SUPPORTS_DEBUG_PAGEALLOC | 183 | config ARCH_SUPPORTS_DEBUG_PAGEALLOC |
| 184 | def_bool y | 184 | def_bool y |
| 185 | 185 | ||
| 186 | config HAVE_EARLY_RES | ||
| 187 | def_bool y | ||
| 188 | |||
| 186 | config HAVE_INTEL_TXT | 189 | config HAVE_INTEL_TXT |
| 187 | def_bool y | 190 | def_bool y |
| 188 | depends on EXPERIMENTAL && DMAR && ACPI | 191 | depends on EXPERIMENTAL && DMAR && ACPI |
diff --git a/arch/x86/include/asm/e820.h b/arch/x86/include/asm/e820.h index a8299e134437..0e22296790d3 100644 --- a/arch/x86/include/asm/e820.h +++ b/arch/x86/include/asm/e820.h | |||
| @@ -112,7 +112,7 @@ extern unsigned long end_user_pfn; | |||
| 112 | extern u64 find_e820_area(u64 start, u64 end, u64 size, u64 align); | 112 | extern u64 find_e820_area(u64 start, u64 end, u64 size, u64 align); |
| 113 | extern u64 find_e820_area_size(u64 start, u64 *sizep, u64 align); | 113 | extern u64 find_e820_area_size(u64 start, u64 *sizep, u64 align); |
| 114 | extern u64 early_reserve_e820(u64 startt, u64 sizet, u64 align); | 114 | extern u64 early_reserve_e820(u64 startt, u64 sizet, u64 align); |
| 115 | #include <asm/early_res.h> | 115 | #include <linux/early_res.h> |
| 116 | 116 | ||
| 117 | extern unsigned long e820_end_of_ram_pfn(void); | 117 | extern unsigned long e820_end_of_ram_pfn(void); |
| 118 | extern unsigned long e820_end_of_low_ram_pfn(void); | 118 | extern unsigned long e820_end_of_low_ram_pfn(void); |
diff --git a/arch/x86/kernel/Makefile b/arch/x86/kernel/Makefile index f5fb9f0b6277..d87f09bc5a52 100644 --- a/arch/x86/kernel/Makefile +++ b/arch/x86/kernel/Makefile | |||
| @@ -38,7 +38,7 @@ obj-$(CONFIG_X86_32) += probe_roms_32.o | |||
| 38 | obj-$(CONFIG_X86_32) += sys_i386_32.o i386_ksyms_32.o | 38 | obj-$(CONFIG_X86_32) += sys_i386_32.o i386_ksyms_32.o |
| 39 | obj-$(CONFIG_X86_64) += sys_x86_64.o x8664_ksyms_64.o | 39 | obj-$(CONFIG_X86_64) += sys_x86_64.o x8664_ksyms_64.o |
| 40 | obj-$(CONFIG_X86_64) += syscall_64.o vsyscall_64.o | 40 | obj-$(CONFIG_X86_64) += syscall_64.o vsyscall_64.o |
| 41 | obj-y += bootflag.o e820.o early_res.o | 41 | obj-y += bootflag.o e820.o |
| 42 | obj-y += pci-dma.o quirks.o i8237.o topology.o kdebugfs.o | 42 | obj-y += pci-dma.o quirks.o i8237.o topology.o kdebugfs.o |
| 43 | obj-y += alternative.o i8253.o pci-nommu.o hw_breakpoint.o | 43 | obj-y += alternative.o i8253.o pci-nommu.o hw_breakpoint.o |
| 44 | obj-y += tsc.o io_delay.o rtc.o | 44 | obj-y += tsc.o io_delay.o rtc.o |
diff --git a/arch/x86/kernel/e820.c b/arch/x86/kernel/e820.c index 36918d8463ab..740b440fbd73 100644 --- a/arch/x86/kernel/e820.c +++ b/arch/x86/kernel/e820.c | |||
| @@ -17,7 +17,6 @@ | |||
| 17 | #include <linux/firmware-map.h> | 17 | #include <linux/firmware-map.h> |
| 18 | 18 | ||
| 19 | #include <asm/e820.h> | 19 | #include <asm/e820.h> |
| 20 | #include <asm/early_res.h> | ||
| 21 | #include <asm/proto.h> | 20 | #include <asm/proto.h> |
| 22 | #include <asm/setup.h> | 21 | #include <asm/setup.h> |
| 23 | 22 | ||
| @@ -752,6 +751,15 @@ u64 __init find_fw_memmap_area(u64 start, u64 end, u64 size, u64 align) | |||
| 752 | { | 751 | { |
| 753 | return find_e820_area(start, end, size, align); | 752 | return find_e820_area(start, end, size, align); |
| 754 | } | 753 | } |
| 754 | |||
| 755 | u64 __init get_max_mapped(void) | ||
| 756 | { | ||
| 757 | u64 end = max_pfn_mapped; | ||
| 758 | |||
| 759 | end <<= PAGE_SHIFT; | ||
| 760 | |||
| 761 | return end; | ||
| 762 | } | ||
| 755 | /* | 763 | /* |
| 756 | * Find next free range after *start | 764 | * Find next free range after *start |
| 757 | */ | 765 | */ |
diff --git a/arch/x86/include/asm/early_res.h b/include/linux/early_res.h index 9758f3df9dad..50f7663bb8b1 100644 --- a/arch/x86/include/asm/early_res.h +++ b/include/linux/early_res.h | |||
| @@ -1,5 +1,5 @@ | |||
| 1 | #ifndef _ASM_X86_EARLY_RES_H | 1 | #ifndef _LINUX_EARLY_RES_H |
| 2 | #define _ASM_X86_EARLY_RES_H | 2 | #define _LINUX_EARLY_RES_H |
| 3 | #ifdef __KERNEL__ | 3 | #ifdef __KERNEL__ |
| 4 | 4 | ||
| 5 | extern void reserve_early(u64 start, u64 end, char *name); | 5 | extern void reserve_early(u64 start, u64 end, char *name); |
| @@ -13,9 +13,10 @@ u64 find_early_area(u64 ei_start, u64 ei_last, u64 start, u64 end, | |||
| 13 | u64 find_early_area_size(u64 ei_start, u64 ei_last, u64 start, | 13 | u64 find_early_area_size(u64 ei_start, u64 ei_last, u64 start, |
| 14 | u64 *sizep, u64 align); | 14 | u64 *sizep, u64 align); |
| 15 | u64 find_fw_memmap_area(u64 start, u64 end, u64 size, u64 align); | 15 | u64 find_fw_memmap_area(u64 start, u64 end, u64 size, u64 align); |
| 16 | u64 get_max_mapped(void); | ||
| 16 | #include <linux/range.h> | 17 | #include <linux/range.h> |
| 17 | int get_free_all_memory_range(struct range **rangep, int nodeid); | 18 | int get_free_all_memory_range(struct range **rangep, int nodeid); |
| 18 | 19 | ||
| 19 | #endif /* __KERNEL__ */ | 20 | #endif /* __KERNEL__ */ |
| 20 | 21 | ||
| 21 | #endif /* _ASM_X86_EARLY_RES_H */ | 22 | #endif /* _LINUX_EARLY_RES_H */ |
diff --git a/kernel/Makefile b/kernel/Makefile index ad47330ccf32..1292b863d667 100644 --- a/kernel/Makefile +++ b/kernel/Makefile | |||
| @@ -11,6 +11,7 @@ obj-y = sched.o fork.o exec_domain.o panic.o printk.o \ | |||
| 11 | hrtimer.o rwsem.o nsproxy.o srcu.o semaphore.o \ | 11 | hrtimer.o rwsem.o nsproxy.o srcu.o semaphore.o \ |
| 12 | notifier.o ksysfs.o pm_qos_params.o sched_clock.o cred.o \ | 12 | notifier.o ksysfs.o pm_qos_params.o sched_clock.o cred.o \ |
| 13 | async.o range.o | 13 | async.o range.o |
| 14 | obj-$(CONFIG_HAVE_EARLY_RES) += early_res.o | ||
| 14 | obj-y += groups.o | 15 | obj-y += groups.o |
| 15 | 16 | ||
| 16 | ifdef CONFIG_FUNCTION_TRACER | 17 | ifdef CONFIG_FUNCTION_TRACER |
diff --git a/arch/x86/kernel/early_res.c b/kernel/early_res.c index 1458dc022343..aa5494ac4462 100644 --- a/arch/x86/kernel/early_res.c +++ b/kernel/early_res.c | |||
| @@ -6,8 +6,7 @@ | |||
| 6 | #include <linux/init.h> | 6 | #include <linux/init.h> |
| 7 | #include <linux/bootmem.h> | 7 | #include <linux/bootmem.h> |
| 8 | #include <linux/mm.h> | 8 | #include <linux/mm.h> |
| 9 | 9 | #include <linux/early_res.h> | |
| 10 | #include <asm/early_res.h> | ||
| 11 | 10 | ||
| 12 | /* | 11 | /* |
| 13 | * Early reserved memory areas. | 12 | * Early reserved memory areas. |
| @@ -178,13 +177,6 @@ void __init reserve_early_overlap_ok(u64 start, u64 end, char *name) | |||
| 178 | __reserve_early(start, end, name, 1); | 177 | __reserve_early(start, end, name, 1); |
| 179 | } | 178 | } |
| 180 | 179 | ||
| 181 | u64 __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 | |||
| 188 | static void __init __check_and_double_early_res(u64 ex_start, u64 ex_end) | 180 | static void __init __check_and_double_early_res(u64 ex_start, u64 ex_end) |
| 189 | { | 181 | { |
| 190 | u64 start, end, size, mem; | 182 | u64 start, end, size, mem; |
| @@ -207,7 +199,7 @@ static void __init __check_and_double_early_res(u64 ex_start, u64 ex_end) | |||
| 207 | sizeof(struct early_res)); | 199 | sizeof(struct early_res)); |
| 208 | if (mem == -1ULL) { | 200 | if (mem == -1ULL) { |
| 209 | start = ex_end; | 201 | start = ex_end; |
| 210 | end = max_pfn_mapped << PAGE_SHIFT; | 202 | end = get_max_mapped(); |
| 211 | if (start + size < end) | 203 | if (start + size < end) |
| 212 | mem = find_fw_memmap_area(start, end, size, | 204 | mem = find_fw_memmap_area(start, end, size, |
| 213 | sizeof(struct early_res)); | 205 | sizeof(struct early_res)); |
| @@ -343,11 +335,11 @@ int __init get_free_all_memory_range(struct range **rangep, int nodeid) | |||
| 343 | count *= 2; | 335 | count *= 2; |
| 344 | 336 | ||
| 345 | size = sizeof(struct range) * count; | 337 | size = sizeof(struct range) * count; |
| 338 | end = get_max_mapped(); | ||
| 346 | #ifdef MAX_DMA32_PFN | 339 | #ifdef MAX_DMA32_PFN |
| 347 | if (max_pfn_mapped > MAX_DMA32_PFN) | 340 | if (end > (MAX_DMA32_PFN << PAGE_SHIFT)) |
| 348 | start = MAX_DMA32_PFN << PAGE_SHIFT; | 341 | start = MAX_DMA32_PFN << PAGE_SHIFT; |
| 349 | #endif | 342 | #endif |
| 350 | end = max_pfn_mapped << PAGE_SHIFT; | ||
| 351 | mem = find_fw_memmap_area(start, end, size, sizeof(struct range)); | 343 | mem = find_fw_memmap_area(start, end, size, sizeof(struct range)); |
| 352 | if (mem == -1ULL) | 344 | if (mem == -1ULL) |
| 353 | panic("can not find more space for range free"); | 345 | panic("can not find more space for range free"); |
