diff options
Diffstat (limited to 'arch/x86/kernel/setup.c')
| -rw-r--r-- | arch/x86/kernel/setup.c | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c index 5d9e40c58628..cb42109a55b4 100644 --- a/arch/x86/kernel/setup.c +++ b/arch/x86/kernel/setup.c | |||
| @@ -121,7 +121,9 @@ | |||
| 121 | unsigned long max_low_pfn_mapped; | 121 | unsigned long max_low_pfn_mapped; |
| 122 | unsigned long max_pfn_mapped; | 122 | unsigned long max_pfn_mapped; |
| 123 | 123 | ||
| 124 | #ifdef CONFIG_DMI | ||
| 124 | RESERVE_BRK(dmi_alloc, 65536); | 125 | RESERVE_BRK(dmi_alloc, 65536); |
| 126 | #endif | ||
| 125 | 127 | ||
| 126 | unsigned int boot_cpu_id __read_mostly; | 128 | unsigned int boot_cpu_id __read_mostly; |
| 127 | 129 | ||
| @@ -667,6 +669,23 @@ static struct dmi_system_id __initdata bad_bios_dmi_table[] = { | |||
| 667 | {} | 669 | {} |
| 668 | }; | 670 | }; |
| 669 | 671 | ||
| 672 | static void __init trim_bios_range(void) | ||
| 673 | { | ||
| 674 | /* | ||
| 675 | * A special case is the first 4Kb of memory; | ||
| 676 | * This is a BIOS owned area, not kernel ram, but generally | ||
| 677 | * not listed as such in the E820 table. | ||
| 678 | */ | ||
| 679 | e820_update_range(0, PAGE_SIZE, E820_RAM, E820_RESERVED); | ||
| 680 | /* | ||
| 681 | * special case: Some BIOSen report the PC BIOS | ||
| 682 | * area (640->1Mb) as ram even though it is not. | ||
| 683 | * take them out. | ||
| 684 | */ | ||
| 685 | e820_remove_range(BIOS_BEGIN, BIOS_END - BIOS_BEGIN, E820_RAM, 1); | ||
| 686 | sanitize_e820_map(e820.map, ARRAY_SIZE(e820.map), &e820.nr_map); | ||
| 687 | } | ||
| 688 | |||
| 670 | /* | 689 | /* |
| 671 | * Determine if we were loaded by an EFI loader. If so, then we have also been | 690 | * Determine if we were loaded by an EFI loader. If so, then we have also been |
| 672 | * passed the efi memmap, systab, etc., so we should use these data structures | 691 | * passed the efi memmap, systab, etc., so we should use these data structures |
| @@ -830,7 +849,7 @@ void __init setup_arch(char **cmdline_p) | |||
| 830 | insert_resource(&iomem_resource, &data_resource); | 849 | insert_resource(&iomem_resource, &data_resource); |
| 831 | insert_resource(&iomem_resource, &bss_resource); | 850 | insert_resource(&iomem_resource, &bss_resource); |
| 832 | 851 | ||
| 833 | 852 | trim_bios_range(); | |
| 834 | #ifdef CONFIG_X86_32 | 853 | #ifdef CONFIG_X86_32 |
| 835 | if (ppro_with_ram_bug()) { | 854 | if (ppro_with_ram_bug()) { |
| 836 | e820_update_range(0x70000000ULL, 0x40000ULL, E820_RAM, | 855 | e820_update_range(0x70000000ULL, 0x40000ULL, E820_RAM, |
