gpt4 book ai didi

c - mmap : Operation not permitted

转载 作者:IT王子 更新时间:2023-10-29 01:07:57 35 4
gpt4 key购买 nike

我正在尝试在用户空间中使用 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);
}

我以 root 身份运行它。输出是:

/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 禁用它。

关于c - mmap : Operation not permitted,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8213671/

35 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com