我正在尝试通过 PCI 总线将 VME 地址空间映射到用户空间,以便可以对内存执行定期读/写操作。我已经用另一个这样的 PCI 设备做到了这一点:-
unsigned long *mapArea(unsigned int barAddr, unsigned int mapSize, int *fd)
{
unsigned long *mem;
*fd = open("/dev/mem", O_RDWR);
if ( *fd<0 ) {
printf("Cannot open /dev/vme_mem\n");
exit(-1);
}
unsigned long *mem = (unsigned long*) mmap ( 0, mapSize, PROT_READ | PROT_WRITE, MAP_FILE | MAP_SHARED, *fd, barAddr);
if ( (mem == NULL) || (mem == (unsigned long*)-1) ) {
printf ( "Cannot map memory, error is %s\n", strerror(errno) );
exit(-1);
}
return mem;
}
volatile unsigned long *bar = (volatile unsigned long *)mapArea(barAddr, mapSize, &fd);
然后“bar”可以正常用于读/写。
所以对于 VME,以及 Tundra Universe II PCI-VME 桥芯片:-
我应该打开“/dev/vme_m0” 我从哪里映射我的 BAR?lspci -vv:“区域 1:80020000 处的内存”
VME BUS中的地址也偏移了0x20000000,那么访问/映射它是如何工作的?!
(使用 Linux 2.6.18-128.el5 #1 SMP)(需要新标签“vme”!)