diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2008-01-30 07:34:06 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-01-30 07:34:06 -0500 |
commit | 950f9d95bed1a366434d3597ea75f5b9d772d74f (patch) | |
tree | 900c548d99c14aacc31888a3483545f8352aea22 /arch/x86/mm/ioremap.c | |
parent | 5f5192b9feeff6a96c97c143c3ca558fdbe2dc8e (diff) |
x86: fix the missing BIOS area check in page_is_ram
page_is_ram has a FIXME since ages, which reminds to sanity check the
BIOS area between 640k and 1M, which is sometimes falsely reported as
RAM in the e820 tables.
Implement the sanity check. Move the BIOS range defines from
pageattr.c into e820.h to avoid duplicate defines.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/mm/ioremap.c')
-rw-r--r-- | arch/x86/mm/ioremap.c | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/arch/x86/mm/ioremap.c b/arch/x86/mm/ioremap.c index d3026e1906f9..24e42cab8d58 100644 --- a/arch/x86/mm/ioremap.c +++ b/arch/x86/mm/ioremap.c | |||
@@ -42,13 +42,18 @@ int page_is_ram(unsigned long pagenr) | |||
42 | */ | 42 | */ |
43 | if (e820.map[i].type != E820_RAM) | 43 | if (e820.map[i].type != E820_RAM) |
44 | continue; | 44 | continue; |
45 | /* | ||
46 | * !!!FIXME!!! Some BIOSen report areas as RAM that | ||
47 | * are not. Notably the 640->1Mb area. We need a sanity | ||
48 | * check here. | ||
49 | */ | ||
50 | addr = (e820.map[i].addr + PAGE_SIZE-1) >> PAGE_SHIFT; | 45 | addr = (e820.map[i].addr + PAGE_SIZE-1) >> PAGE_SHIFT; |
51 | end = (e820.map[i].addr + e820.map[i].size) >> PAGE_SHIFT; | 46 | end = (e820.map[i].addr + e820.map[i].size) >> PAGE_SHIFT; |
47 | |||
48 | /* | ||
49 | * Sanity check: Some BIOSen report areas as RAM that | ||
50 | * are not. Notably the 640->1Mb area, which is the | ||
51 | * PCI BIOS area. | ||
52 | */ | ||
53 | if (addr >= (BIOS_BEGIN >> PAGE_SHIFT) && | ||
54 | end < (BIOS_END >> PAGE_SHIFT)) | ||
55 | continue; | ||
56 | |||
52 | if ((pagenr >= addr) && (pagenr < end)) | 57 | if ((pagenr >= addr) && (pagenr < end)) |
53 | return 1; | 58 | return 1; |
54 | } | 59 | } |