Chinaunix
标题:
关于godbach的帖子--内核和用户空间共享内存的实现例程-proc和mmap
[打印本页]
作者:
snriyt
时间:
2010-06-07 22:49
标题:
关于godbach的帖子--内核和用户空间共享内存的实现例程-proc和mmap
测试失败,原因如下:
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <sys/mman.h>
int main(int argc, char* argv[])
{
char *map_addr;
char s[256];
int map_fd = open("/dev/mem", O_RDONLY);
if(map_fd < 0)
{
printf("cannot open file /dev/mem\n");
return 0;
}
unsigned long phymem_addr = 0;
unsigned long phymem_size = sysconf(_SC_PAGE_SIZE);
while(1)
{
phymem_addr += sysconf(_SC_PAGE_SIZE);
map_addr = mmap(0, phymem_size, PROT_READ, MAP_SHARED, map_fd, phymem_addr);
if(map_addr == -1){
perror("map error : ");
printf("%p\n", phymem_addr);
return 0;
}
munmap(map_addr, phymem_size);
}
close(map_fd);
return 0;
}
复制代码
执行结果:
yz@yz-desktop:~/code/mm$ sudo ./mmap_mem
map error : : Operation not permitted
0x101000
复制代码
当mmap物理内存的0x101000以上的内存时就不行了,为什么?当如何操作?
anybody給解釋解釋??
跟這個CONFIG_STRICT_DEVMEM有木有關系??
作者:
aaaaa5aa
时间:
2010-06-08 07:23
请问楼主用的哪个用户
作者:
snriyt
时间:
2010-06-08 13:41
回复
2#
aaaaa5aa
sudo應當算是root吧?
作者:
aaaaa5aa
时间:
2010-06-08 20:41
回复
3#
snriyt
sudo算是root,不过建议楼主还是直接用root用户,有可能环境变量导致这里出问题
作者:
Godbach
时间:
2010-06-09 14:02
直接使用root试试。
另外,也需要明确你的/dev/mem是否让读写。
作者:
dreamice
时间:
2010-06-09 14:11
最好不要映射到有冲突的地址空间了
欢迎光临 Chinaunix (http://bbs.chinaunix.net/)
Powered by Discuz! X3.2