搜索
bottom↓
回复: 16

基于FPGA的UART通信中的fifo问题

[复制链接]

出0入0汤圆

发表于 2011-6-8 10:14:58 | 显示全部楼层 |阅读模式

UART通信顶层程序 (原文件名:QQ截图未命名.png)
这是我的UART顶层程序,FPGA通过串口接收数据给ARM,ARM通过它发送数据。请问
1.ARM该什么时候给发送端的fifo写数据,又什么时候从接收端的fifo中读数据?这个时序怎么控制啊?
2.如果不用fifo做缓存,该用什么?寄存器吗?
谢谢!

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

你熬了10碗粥,别人一桶水倒进去,淘走90碗,剩下10碗给你,你看似没亏,其实你那10碗已经没有之前的裹腹了,人家的一桶水换90碗,继续卖。说白了,通货膨胀就是,你的钱是挣来的,他的钱是印来的,掺和在一起,你的钱就贬值了。

出0入0汤圆

发表于 2011-6-8 11:46:39 | 显示全部楼层
1.发送端的fifo非满即可往里面写数据,接收端fifo非空即可从里面读数据。当然,如果用超时的方式接收数据效率会更高些。可以用查询的方法查询fifo的空/满标志位,也可以用中断的方式。通常情况下,发送用查询方式,接收用中断方式(非空中断或超时中断)。
2.用寄存器也可以。但是资源允许的情况下,用fifo比较好,效率高些。

出0入0汤圆

发表于 2011-6-8 11:47:33 | 显示全部楼层
FIFO需要一个flag

出0入0汤圆

 楼主| 发表于 2011-6-8 19:34:55 | 显示全部楼层
回复【1楼】hjjft
-----------------------------------------------------------------------


(原文件名:lpm_fifo_transmitter_wave0.jpg)
这是fifo的时序图,里面有个时钟信号,读写使能信号如何与时钟同步啊?读写信号太短或太长可能会导致读写不到数据或读写了几遍数据。如果读写一直有效则要保证数据要随时钟及时变化,否则会读写几遍,这些都怎么控制啊?
谢谢!

出0入0汤圆

发表于 2011-6-8 21:58:21 | 显示全部楼层
干嘛不用spi?

出0入0汤圆

发表于 2011-6-9 15:07:36 | 显示全部楼层
回复【3楼】laokongzhuang
-----------------------------------------------------------------------

读写信号要与fifo的驱动时钟同步

出0入0汤圆

 楼主| 发表于 2011-6-10 12:29:38 | 显示全部楼层
回复【5楼】hjjft
-----------------------------------------------------------------------

就是不明白如何做到同步啊,读写信号是ARM传过来的,时钟是FPGA内部提供的,这个同步应该比较麻烦吧?有没有简单的方法实现缓存呢?

出0入0汤圆

发表于 2011-6-10 16:32:53 | 显示全部楼层
用fifo的驱动时钟对ARM的读写信号进行采样,然后生成同步的读写信号。

出0入0汤圆

发表于 2011-6-10 16:34:16 | 显示全部楼层
如果有将ARM的读写时钟引入FPGA的话,可以直接使用该时钟来驱动fifo,就可以很方便地实现同步

出0入0汤圆

 楼主| 发表于 2011-6-28 10:53:54 | 显示全部楼层
回复【6楼】laokongzhuang
-----------------------------------------------------------------------
请问读写信号的宽度如何和fifo的驱动时钟信号匹配?比如fifo驱动时钟周期200ns,那么读写信号的有效宽度就必须满足在第一个时钟沿时有效,在下一个时钟沿必须无效,否则就会读写两次数据,这个如何做到?谢谢!

出0入0汤圆

发表于 2011-6-28 11:01:21 | 显示全部楼层
时钟信号频率至少8或16倍波特率时钟,也就是所谓一个未采样8或16次的单片机内部做法

出0入0汤圆

发表于 2011-6-28 13:10:16 | 显示全部楼层
mark

出0入0汤圆

发表于 2012-5-6 09:08:45 | 显示全部楼层
感觉不太好弄!

出0入0汤圆

发表于 2012-9-3 22:17:21 | 显示全部楼层
楼主,FPGA的UART通信搞好了吗,可以发我一份做个参考吗?chenwg7@126.com

出0入0汤圆

发表于 2013-8-10 10:36:08 | 显示全部楼层
laokongzhuang 发表于 2011-6-28 10:53
回复【6楼】laokongzhuang
-----------------------------------------------------------------------
请 ...

这个问题你得到答案了吗?
我也有相应的问题。
是读取了二次还是一次呢?
是不是第一次读取或写入的时候没有完成,第二次不会被触发,不会执行?还是被默默挂起了,最后又执行了第二次?

出0入0汤圆

发表于 2013-8-10 11:02:24 | 显示全部楼层
UART需要配置波特率,对模块的运行时钟根据波特率寄存器用个计数器做一个采样时钟即可

出0入0汤圆

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

本版积分规则

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

GMT+8, 2024-10-3 20:56

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

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