我试图在用户空间中使用mmap来读取’mem_map’开始的物理内存.它是一个包含所有物理页面的数组.这是运行3.0内核的i386机器.
代码是这样的:
....
//define page size
//
#define PAGE_SIZE 0x1000 //4096 bytes
#define PAGE_MASK (PAGE_SIZE - 1)
....
/* open /dev/mem file*/
if((fd = open("/dev/mem",O_RDWR | O_SYNC)) == -1) {
printf("/dev/mem could not be opened.\n");
perror("open");
exit(1);
} else {
printf("/dev/mem opened.\n");
}
/* Map one page */
printf(" mem_map is at physical addr: 0x%x\n",mem_map_phy_addr);
map_base = mmap(0,PAGE_SIZE,PROT_READ,MAP_SHARED,fd,(mem_map_phy_addr & ~PAGE_MASK)); //mem_map_phy_addr is at 0x356f2000
if(map_base == (void *) -1) {
printf("Memory map failed. err num = %d\n",errno);
perror("mmap"); //failed here
} else {
printf("Memory mapped at address %p.\n",map_base);
}
我把它作为根运行.输出是:
/dev/mem opened.
mem_map is at physical addr: 0x356f2000
Memory map failed. err num = 1
mmap: Operation not permitted
可以肯定的是,我搜索了问题并将以下行添加到我的/etc/sysctl.conf文件中:
vm.mmap_min_addr = 0
但这也不起作用.
任何人都知道为什么不允许这样的mem_map操作以及我如何绕过它?
谢谢.
最佳答案
听起来内核已经使用CONFIG_STRICT_DEVMEM进行编译.这是一项安全功能,可防止用户空间访问超过1MB(IIRC)的(可能是敏感的)物理内存.您可以使用sysctl dev.mem.restricted禁用此功能.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。