共2条
1/1 1 跳转至页
请教最简单的在用户空间对物理地址进行读写的方法
问
我的硬件平台是at91rm9200,跑着linux-2.4.27.我把at91rm9200的ncs2 ,a2...a9,d0..d15都引到一个fpga的i/o上.现在需要和fga通信,就是需要对ncs2片选控制的物理地址进行读写.
我想能不能写个简单的程序,里面对上述要求初始化后,然后调用系统调用mmap,对地址进行重影射后,就可以在用户空间直接对地址为0x30000000的内存进行操作.
高手请说说这能不能实现,如果能,能否指点一下流程和要点,或者有更简单的办法.
如果不能,应该怎么办? 答 1: 可以 答 2: 就是你说的这种方法,完全没问题。 答 3: 谢谢两位,但是实际上谢谢两位。不好意思,我现在遇到实际问题,我不想用驱动的方式去实现,只想在应用程序中映射。但是,我没有在/kernel/sys.c上找到sys_mmap()系统调用,可在/include/asm-ARM/unistd.h确实有sys_mmap()的定义。我是linux菜鸟,连sys_mmap()源码都找不到,那根本不会调用它。而且我在网上又查到说要用ioremap()系统调用来实现,都晕了!
不过在/arch/parisc/kernel/sys_parisc.c里找到了asmlinkage unsigned long sys_mmap(
unsigned long addr, unsigned long len,unsigned long prot,
unsigned long flags,unsigned long fd,unsigned long offset)
{}
头大啊,这些参数我的设想一点不粘边。倒是/kernel/mm/memory.c里定义remap_page_range(
unsigned long virt_add, unsigned long phys_add,
unsigned long size, pgprot_t prot)
{}
这个函数和我的要求还相近。virt_add重映射起始的用户虚礼地址,phys_add虚拟地址所映射的物理地址,size被重映射的区域大小,prot新VMA的保证标志。我是不是可以这样填充参数:virt_add=0x00000000;
phys_add=0x30000000 ,size=0x20000 ,但是prot是什么意思啊?但是/arch/parisc/kernel/sys_parisc.c里的asmlinkage unsigned long sys_mmap不调用这个函数啊?
急!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 答 4: 给你几个关键语句example 1:
void *map_base; //phy 0xffff f000 virtual address
map_base = mmap(0, MAP_SIZE, PROT_READ | PROT_WRITE, MAP_SHARED, fd, AT91_SYS);//AT91_SYS = 0xffff f000
ch1=*(unsigned int*)(map_base + ((PIOB_OFFSET + AT91_PIO_PDSR )));//PA0...PA5
ch2=*(unsigned int*)(map_base + ((PIOC_OFFSET + AT91_PIO_PDSR )));//PC14,PC15
example 2:
volatile unsigned int *map_base_KEYLE; //(0x60000000 virtual address
(*map_base_KEYLE)=(~(0x1<<i))&(~(0x1<<i+16));
(*map_base_KEYLE)=0x0;
我想能不能写个简单的程序,里面对上述要求初始化后,然后调用系统调用mmap,对地址进行重影射后,就可以在用户空间直接对地址为0x30000000的内存进行操作.
高手请说说这能不能实现,如果能,能否指点一下流程和要点,或者有更简单的办法.
如果不能,应该怎么办? 答 1: 可以 答 2: 就是你说的这种方法,完全没问题。 答 3: 谢谢两位,但是实际上谢谢两位。不好意思,我现在遇到实际问题,我不想用驱动的方式去实现,只想在应用程序中映射。但是,我没有在/kernel/sys.c上找到sys_mmap()系统调用,可在/include/asm-ARM/unistd.h确实有sys_mmap()的定义。我是linux菜鸟,连sys_mmap()源码都找不到,那根本不会调用它。而且我在网上又查到说要用ioremap()系统调用来实现,都晕了!
不过在/arch/parisc/kernel/sys_parisc.c里找到了asmlinkage unsigned long sys_mmap(
unsigned long addr, unsigned long len,unsigned long prot,
unsigned long flags,unsigned long fd,unsigned long offset)
{}
头大啊,这些参数我的设想一点不粘边。倒是/kernel/mm/memory.c里定义remap_page_range(
unsigned long virt_add, unsigned long phys_add,
unsigned long size, pgprot_t prot)
{}
这个函数和我的要求还相近。virt_add重映射起始的用户虚礼地址,phys_add虚拟地址所映射的物理地址,size被重映射的区域大小,prot新VMA的保证标志。我是不是可以这样填充参数:virt_add=0x00000000;
phys_add=0x30000000 ,size=0x20000 ,但是prot是什么意思啊?但是/arch/parisc/kernel/sys_parisc.c里的asmlinkage unsigned long sys_mmap不调用这个函数啊?
急!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 答 4: 给你几个关键语句example 1:
void *map_base; //phy 0xffff f000 virtual address
map_base = mmap(0, MAP_SIZE, PROT_READ | PROT_WRITE, MAP_SHARED, fd, AT91_SYS);//AT91_SYS = 0xffff f000
ch1=*(unsigned int*)(map_base + ((PIOB_OFFSET + AT91_PIO_PDSR )));//PA0...PA5
ch2=*(unsigned int*)(map_base + ((PIOC_OFFSET + AT91_PIO_PDSR )));//PC14,PC15
example 2:
volatile unsigned int *map_base_KEYLE; //(0x60000000 virtual address
(*map_base_KEYLE)=(~(0x1<<i))&(~(0x1<<i+16));
(*map_base_KEYLE)=0x0;
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |