aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/mm/init_64.c
diff options
context:
space:
mode:
authorArjan van de Ven <arjan@linux.intel.com>2008-04-24 17:40:47 -0400
committerIngo Molnar <mingo@elte.hu>2008-04-24 17:40:47 -0400
commitae531c26c5c2a28ca1b35a75b39b3b256850f2c8 (patch)
treee4c2f3ec25bdb0e2e5f7f15f79a60c3175f03718 /arch/x86/mm/init_64.c
parent94bc891b00e40cbec375feb4568780af183fd7f4 (diff)
x86: introduce /dev/mem restrictions with a config option
This patch introduces a restriction on /dev/mem: Only non-memory can be read or written unless the newly introduced config option is set. The X server needs access to /dev/mem for the PCI space, but it doesn't need access to memory; both the file permissions and SELinux permissions of /dev/mem just make X effectively super-super powerful. With the exception of the BIOS area, there's just no valid app that uses /dev/mem on actual memory. Other popular users of /dev/mem are rootkits and the like. (note: mmap access of memory via /dev/mem was already not allowed since a really long time) People who want to use /dev/mem for kernel debugging can enable the config option. The restrictions of this patch have been in the Fedora and RHEL kernels for at least 4 years without any problems. Signed-off-by: Arjan van de Ven <arjan@linux.intel.com> Signed-off-by: Ingo Molnar <mingo@elte.hu> Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'arch/x86/mm/init_64.c')
-rw-r--r--arch/x86/mm/init_64.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/arch/x86/mm/init_64.c b/arch/x86/mm/init_64.c
index 1ff7906a9a4d..49c274ee2fba 100644
--- a/arch/x86/mm/init_64.c
+++ b/arch/x86/mm/init_64.c
@@ -664,6 +664,26 @@ EXPORT_SYMBOL_GPL(memory_add_physaddr_to_nid);
664 664
665#endif /* CONFIG_MEMORY_HOTPLUG */ 665#endif /* CONFIG_MEMORY_HOTPLUG */
666 666
667/*
668 * devmem_is_allowed() checks to see if /dev/mem access to a certain address
669 * is valid. The argument is a physical page number.
670 *
671 *
672 * On x86, access has to be given to the first megabyte of ram because that area
673 * contains bios code and data regions used by X and dosemu and similar apps.
674 * Access has to be given to non-kernel-ram areas as well, these contain the PCI
675 * mmio resources as well as potential bios/acpi data regions.
676 */
677int devmem_is_allowed(unsigned long pagenr)
678{
679 if (pagenr <= 256)
680 return 1;
681 if (!page_is_ram(pagenr))
682 return 1;
683 return 0;
684}
685
686
667static struct kcore_list kcore_mem, kcore_vmalloc, kcore_kernel, 687static struct kcore_list kcore_mem, kcore_vmalloc, kcore_kernel,
668 kcore_modules, kcore_vsyscall; 688 kcore_modules, kcore_vsyscall;
669 689