mmap:不允许操作

我正在尝试在用户空间中使用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禁用它。

以上是 mmap:不允许操作 的全部内容, 来源链接: utcz.com/qa/425793.html

回到顶部