diff options
author | Pekka Enberg <penberg@cs.helsinki.fi> | 2009-03-04 04:46:40 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-03-04 05:40:04 -0500 |
commit | 540aca06b737cc38965b52eeceefba3d24376461 (patch) | |
tree | 0231f664033a2f3ad7632e4030e54a6b7a848447 /arch/x86/mm/init.c | |
parent | 8b0e5860cb099d7958d13b00ffbc35ad02735700 (diff) |
x86: move devmem_is_allowed() to common mm/init.c
Impact: cleanup
The function is identical on 32-bit and 64-bit configurations so move
it to the common mm/init.c file.
Signed-off-by: Pekka Enberg <penberg@cs.helsinki.fi>
LKML-Reference: <1236160001.29024.29.camel@penberg-laptop>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/mm/init.c')
-rw-r--r-- | arch/x86/mm/init.c | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/arch/x86/mm/init.c b/arch/x86/mm/init.c index ce6a722587d8..f89df52683c5 100644 --- a/arch/x86/mm/init.c +++ b/arch/x86/mm/init.c | |||
@@ -1,9 +1,33 @@ | |||
1 | #include <linux/ioport.h> | ||
1 | #include <linux/swap.h> | 2 | #include <linux/swap.h> |
3 | |||
2 | #include <asm/cacheflush.h> | 4 | #include <asm/cacheflush.h> |
3 | #include <asm/page.h> | 5 | #include <asm/page.h> |
6 | #include <asm/page_types.h> | ||
4 | #include <asm/sections.h> | 7 | #include <asm/sections.h> |
5 | #include <asm/system.h> | 8 | #include <asm/system.h> |
6 | 9 | ||
10 | /* | ||
11 | * devmem_is_allowed() checks to see if /dev/mem access to a certain address | ||
12 | * is valid. The argument is a physical page number. | ||
13 | * | ||
14 | * | ||
15 | * On x86, access has to be given to the first megabyte of ram because that area | ||
16 | * contains bios code and data regions used by X and dosemu and similar apps. | ||
17 | * Access has to be given to non-kernel-ram areas as well, these contain the PCI | ||
18 | * mmio resources as well as potential bios/acpi data regions. | ||
19 | */ | ||
20 | int devmem_is_allowed(unsigned long pagenr) | ||
21 | { | ||
22 | if (pagenr <= 256) | ||
23 | return 1; | ||
24 | if (iomem_is_exclusive(pagenr << PAGE_SHIFT)) | ||
25 | return 0; | ||
26 | if (!page_is_ram(pagenr)) | ||
27 | return 1; | ||
28 | return 0; | ||
29 | } | ||
30 | |||
7 | void free_init_pages(char *what, unsigned long begin, unsigned long end) | 31 | void free_init_pages(char *what, unsigned long begin, unsigned long end) |
8 | { | 32 | { |
9 | unsigned long addr = begin; | 33 | unsigned long addr = begin; |