mmap:不允许操作

use*_*159 6 c linux

我试图在用户空间中使用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);
  }
Run Code Online (Sandbox Code Playgroud)

我把它作为根运行.输出是:

/dev/mem opened.
 mem_map is at physical addr: 0x356f2000
Memory map failed. err num = 1
mmap: Operation not permitted
Run Code Online (Sandbox Code Playgroud)

可以肯定的是,我搜索了问题并将以下行添加到我的/etc/sysctl.conf文件中:

vm.mmap_min_addr = 0
Run Code Online (Sandbox Code Playgroud)

但这也不起作用.

任何人都知道为什么不允许这样的mem_map操作以及我如何绕过它?

谢谢.

Bre*_*ale 10

听起来内核已经CONFIG_STRICT_DEVMEM启用了编译.这是一项安全功能,可防止用户空间访问超过1MB(IIRC)的(可能是敏感的)物理内存.您可以使用sysctl dev.mem.restricted禁用此功能.


Ben*_*ibr 5

我在使用Arch Linux的APU2c4板上尝试使用flashrom时遇到了类似的问题。

sysctl选项dev.mem.restricted在我的系统中不可用,对我来说,使用自编译内核是不可行的。

我通过将iomemKernelparameter 设置为relaxedvia Grub 解决了这个问题:

# /boot/grub/grub.cfg
linux   /boot/vmlinuz-linux iomem=relaxed
Run Code Online (Sandbox Code Playgroud)

当然,此解决方案需要重新启动。

参考:
https : //www.reddit.com/r/libreboot/comments/6wvyry/flashrom_failures_to_access/
https://www.flashrom.org/FAQ
https://www.kernel.org/doc/Documentation/admin-guide /kernel-parameters.txt