diff options
author | Yinghai Lu <yhlu.kernel@gmail.com> | 2008-09-22 05:52:26 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-09-22 06:04:38 -0400 |
commit | 2216d199b1430d1c0affb1498a9ebdbd9c0de439 (patch) | |
tree | 48e953025fe789449a20fe06fd2090fb33d7cc20 | |
parent | 5871c6b0a52bb052c3891a787655043b90ae18e3 (diff) |
x86: fix CONFIG_X86_RESERVE_LOW_64K=y
The bad_bios_dmi_table() quirk never triggered because we do DMI setup
too late. Move it a bit earlier.
Also change the CONFIG_X86_RESERVE_LOW_64K quirk to operate on the e820
table directly instead of messing with early reservations - this handles
overlaps (which do occur in this low range of RAM) more gracefully.
Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r-- | arch/x86/kernel/setup.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c index 161f1b33ecec..d29951c11be0 100644 --- a/arch/x86/kernel/setup.c +++ b/arch/x86/kernel/setup.c | |||
@@ -735,7 +735,8 @@ static int __init dmi_low_memory_corruption(const struct dmi_system_id *d) | |||
735 | "%s detected: BIOS may corrupt low RAM, working it around.\n", | 735 | "%s detected: BIOS may corrupt low RAM, working it around.\n", |
736 | d->ident); | 736 | d->ident); |
737 | 737 | ||
738 | reserve_early_overlap_ok(0x0, 0x10000, "BIOS quirk"); | 738 | e820_update_range(0, 0x10000, E820_RAM, E820_RESERVED); |
739 | sanitize_e820_map(e820.map, ARRAY_SIZE(e820.map), &e820.nr_map); | ||
739 | 740 | ||
740 | return 0; | 741 | return 0; |
741 | } | 742 | } |
@@ -784,8 +785,6 @@ void __init setup_arch(char **cmdline_p) | |||
784 | printk(KERN_INFO "Command line: %s\n", boot_command_line); | 785 | printk(KERN_INFO "Command line: %s\n", boot_command_line); |
785 | #endif | 786 | #endif |
786 | 787 | ||
787 | dmi_check_system(bad_bios_dmi_table); | ||
788 | |||
789 | early_cpu_init(); | 788 | early_cpu_init(); |
790 | early_ioremap_init(); | 789 | early_ioremap_init(); |
791 | 790 | ||
@@ -880,6 +879,10 @@ void __init setup_arch(char **cmdline_p) | |||
880 | 879 | ||
881 | finish_e820_parsing(); | 880 | finish_e820_parsing(); |
882 | 881 | ||
882 | dmi_scan_machine(); | ||
883 | |||
884 | dmi_check_system(bad_bios_dmi_table); | ||
885 | |||
883 | #ifdef CONFIG_X86_32 | 886 | #ifdef CONFIG_X86_32 |
884 | probe_roms(); | 887 | probe_roms(); |
885 | #endif | 888 | #endif |
@@ -967,8 +970,6 @@ void __init setup_arch(char **cmdline_p) | |||
967 | vsmp_init(); | 970 | vsmp_init(); |
968 | #endif | 971 | #endif |
969 | 972 | ||
970 | dmi_scan_machine(); | ||
971 | |||
972 | io_delay_init(); | 973 | io_delay_init(); |
973 | 974 | ||
974 | /* | 975 | /* |