共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电子工程师创研计划】技术变现通道已开启~ | |
发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
【EEPW在线】E起听工程师的声音! | |
“我踩过的那些坑”主题活动——第001期 | |
高校联络员开始招募啦!有惊喜!! | |
【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
送您一块开发板,2025年“我要开发板活动”又开始了! | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
汽车+汽车电子电阻解释与分析被打赏5分 | |
分享汽车通信和多媒体总线结构被打赏20分 | |
【我踩过的那些坑】结构堵孔导致的喇叭无声问题被打赏50分 | |
NUCLEO-U083RC学习历程38+串口通过队列的方式输出两个字符串被打赏20分 | |
【我踩过的那些坑】分享一下调试一款AD芯片的遇到的“坑”被打赏50分 | |
电流检测模块MAX4080S被打赏10分 | |
【我踩过的那些坑】calloc和malloc错误使用导致跑飞问题排查被打赏50分 | |
分享电控悬架的结构与工作原理(一)被打赏20分 | |
多组DCTODC电源方案被打赏50分 | |
【我踩过的那些坑】STM32cubeMX软件的使用过程中的“坑”被打赏50分 |