7295|1

1377

帖子

2

TA的资源

五彩晶圆(初级)

楼主
 

安路SparkRoad开发板测评(6) FIFO IP的使用 [复制链接]

 

  FPGA中FIFO IP,作为数据传输中的缓冲来用是个重要角色。特别是异步FIFO,可以方便地解决跨时钟同步的问题。

 

  TD中提供了FIFO IP资源,不过相对于我最熟悉的altera cyclone系列的FIFO IP,配置方面简略太多。IP Generator对话框中,有FIFO和RAMFIFO两种IP.

 

  先来看下FIFO IP选择,

  可以配置成同步或者异步FIFO. 输入数据位宽选择余地大,输入输出可以不等宽度。FIFO深度有五挡,最小512,最大8192. 除了empty和full标志输出,还可以选择almost full, almost empty标志,但是没有当前FIFO数据量输出。

  综合一个8位宽,深度512的FIFO,结果资源占用:

  在bram组下面,使用了一个fifo9k资源,这是不同于bram9k的资源。此外LE的用量很少。看来FIFO的实现是用了一种特殊资源,在我用过的altera FPGA里面并没有,后者是用RAM加逻辑实现的。因此安路FPGA中FIFO的实现可能效率更高。

 

  另外一种RAMFIFO IP是怎样的呢?

  同样是异步FIFO,但配置界面不一样了,简单了,输入和输出数据位必须相等,实现方式是用block RAM, 这里提供了FIFO数据量的输出。可以推断实现方式与前一个IP有所不同。

  综合一个同样是8x512的RAMFIFO,看看资源使用情况:

  这次LE资源就用了很多了,的确是用RAM加逻辑搭出来的。由于多了数据量输出,额外还会多用逻辑。

 

  做个简单的演示吧,为了利用SparkRoad板子自身演示FIFO的效果,用开关来指定FIFO输入,数码管显示FIFO输出数据。

  读写FIFO的时钟严格异步,所以我还用了一个PLL,并且将读写时钟都降频以便观察。

  设计是每按一下按钮,就往FIFO写一批数据:用开关设定写多少个(1~255),以及第一个数据的值(0~255),后面数据值依次递增。

  当FIFO有数据时就读数据,以十进值形式显示在数码管上。


 

  两种IP分别实现的异步FIFO运行效果是一样的,整个项目的资源使用情况会有所不同:

 

 

最新回复

两种IP分别实现的异步FIFO都好用,各有优势   详情 回复 发表于 2022-5-1 08:44
点赞 关注
 
 

回复
举报

6802

帖子

0

TA的资源

五彩晶圆(高级)

沙发
 

两种IP分别实现的异步FIFO都好用,各有优势

 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表