搜索
bottom↓
回复: 21

请问在NIOS2 中的函数IOWR_ALTERA_AVALON_PIO_DATA(LED_PIO_BASE,led)是什么意思呀

[复制链接]

出0入0汤圆

发表于 2007-12-11 10:49:43 | 显示全部楼层 |阅读模式
刚学习fpga,看到例程里的IOWR_ALTERA_AVALON_PIO_DATA(LED_PIO_BASE,led)这句不太
理解,特别是LED_PIO_BASE这个变量是什么,怎么来的?请哪位大侠解释一下

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

发表于 2007-12-11 12:15:50 | 显示全部楼层
声称NIOS以后会把所有的中断.PIO等做成地址形式.你可以去看看系统配置的文件.

出0入0汤圆

发表于 2007-12-11 18:51:21 | 显示全部楼层
IOWR_ALTERA_AVALON_PIO_DATA(LED_PIO_BASE,led)  等于 单片机里的 LED_PIO_BASE = led

出0入0汤圆

发表于 2007-12-11 23:02:58 | 显示全部楼层
IOWR_ALTERA_AVALON_PIO_DATA是一个宏定义,其位置在altera_avalon_pio_regs.h中,另外还要参考io.h头文件。NiosII IDE为了避开NiosII的Cache以及简化IO端口操作程序的编写,定义了两类基本的宏(以IOWR_开头的为写PIO操作,以IORD_开头的为读PIO操作),其效果与使用指针的效果不完全一样。
LED_PIO_BASE是在system.h中定义的一个宏,是LED_PIO端口的基地址。
IOWR_ALTERA_AVALON_PIO_DATA(LED_PIO_BASE,led)的含义就是往LED_PIO端口的数据输出寄存器写入led,
具体可以参考 Altera_embeded_peripherals 一文,这里讲解了一个PIO端口包含了那些寄存器。参考NiosII_software_developer's_handbook 进行驱动设计。这两个文件可以在Altera的官方网站上下载。

出0入0汤圆

 楼主| 发表于 2007-12-12 10:51:44 | 显示全部楼层
谢谢楼上各位兄弟的热情解答!

出0入0汤圆

发表于 2009-7-26 11:34:09 | 显示全部楼层
学习了

出0入0汤圆

发表于 2009-8-17 16:32:24 | 显示全部楼层
LED_PIO_BASE 是你构建的SOPC上的LED对应的基地址,led是你C语言里对应的led变量名,就是把led的值写入LED中去

出0入0汤圆

发表于 2010-7-15 09:31:46 | 显示全部楼层
IOWR_ALTERA_AVALON_PIO_EDGE_CAP(BUTTON_PIO_BASE,0x0);是什么意思?

出0入0汤圆

发表于 2010-7-15 10:12:24 | 显示全部楼层
回复【7楼】number007cool
-----------------------------------------------------------------------

回到你自己贴子去看

出0入0汤圆

发表于 2010-7-15 14:53:01 | 显示全部楼层
可以看看《niosii那些事儿》

出0入0汤圆

发表于 2010-9-28 12:48:40 | 显示全部楼层
回复【9楼】avic
-----------------------------------------------------------------------

《niosii那些事儿》 我看过 但是感觉效果不是很好啊

出0入0汤圆

发表于 2010-9-28 19:39:17 | 显示全部楼层
向某一个端口写一个高或低

出0入0汤圆

发表于 2010-9-29 10:03:29 | 显示全部楼层
回复【楼主位】eagle1979
-----------------------------------------------------------------------

函数原型:IORD(BASE, REGNUM)
输入参数:BASE为寄存器的基地址,REGNUM为寄存器的偏移量
函数说明:从基地址为BASE的设备中读取寄存器中偏移量为REGNUM的单元里面的值。寄存器的值在地址总线的范围之内。
返回值: -

函数原型:IOWR(BASE, REGNUM, DATA)
输入参数:BASE为寄存器的基地址,REGNUM为寄存器的偏移量,DATA为要写入的数据
函数说明:往偏移量为REGNUM寄存器中写入数据。寄存器的值在地址总线的范围之内。
返回值: -

我想看到这个你就知道什么意思了

出0入0汤圆

发表于 2010-10-10 21:39:20 | 显示全部楼层
学习了!

出0入0汤圆

发表于 2011-4-8 23:55:09 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-12-7 09:54:37 | 显示全部楼层
受益匪浅,有详细的解释和简单明了介绍。好贴

出0入0汤圆

发表于 2012-5-28 16:57:42 | 显示全部楼层
1. 怎样在NIOSII中操作PIO?

  答:hello_led.c是这样写IO口的:
IOWR_ALTERA_AVALON_PIO_DATA(LED_PIO_BASE, led);
首先在altera_avalon_pio_regs.h找到定义
#i nclude
#define IORD_ALTERA_AVALON_PIO_DATA(base) IORD(base, 0)
#define IOWR_ALTERA_AVALON_PIO_DATA(base, data) IOWR(base, 0, data)
因此在NIOSII中可以调用#i nclude库函数IORD/IOWR来操作PIO。
在smallsoftwarehello_led_0_syslibDebugsystem_des cription下的system.h
中,有以下内容:
#define LED_PIO_TYPE "altera_avalon_pio"
#define LED_PIO_BASE 0x00004000
其中LED_PIO_BASE(IO寄存器地址?)为0x00004000同SOPCBuilder中设置一致!
(其实在SopcBuilder中有关NiosII的配置,就是通过system.h来传送给IDE的!)
最后用IOWR(0x00004000, 0, led);替代
IOWR_ALTERA_AVALON_PIO_DATA(LED_PIO_BASE, led);编译,下载到开发板上,运行成功!

出0入0汤圆

发表于 2012-5-28 16:58:16 | 显示全部楼层
2.IOWR_ALTERA_AVALON_PIO_DATA怎么使用?

    答:IOWR_ALTERA_AVALON_PIO_DATA是一个宏定义,其位置在altera_avalon_pio_regs.h中,另外还要参考io.h头文件。NiosII IDE为了避开NiosII的Cache以及简化IO端口操作程序的编写,定义了两类基本的宏(以IOWR_开头的为写PIO操作,以IORD_开头的为读PIO操作),其效果与使用指针的效果不完全一样。
LED_PIO_BASE是在system.h中定义的一个宏,是LED_PIO端口的基地址。
IOWR_ALTERA_AVALON_PIO_DATA(LED_PIO_BASE,led)的含义就是往LED_PIO端口的数据输出寄存器写入led,
具体可以参考 Altera_embeded_peripherals 一文,这里讲解了一个PIO端口包含了那些寄存器。参考NiosII_software_developer's_handbook 进行驱动设计。这两个文件可以在Altera的官方网站上下载。

出0入0汤圆

发表于 2012-5-28 17:04:45 | 显示全部楼层
上传两篇文档:





本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

出0入0汤圆

发表于 2012-7-26 13:08:45 | 显示全部楼层
努力学习!!!!

出0入0汤圆

发表于 2014-4-21 14:00:46 | 显示全部楼层
11111111111

出0入0汤圆

发表于 2014-4-21 14:02:46 | 显示全部楼层
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-24 03:21

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表