打印

怎么有效清空FIFO

[复制链接]
3453|30
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
Rangar|  楼主 | 2018-2-27 14:46 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
最近在F28035最小系统板子上开发一个DA卡系统,一块板子发送数据,另一块板子接收数据,需要通过发送和接收FIFO收发数据,接受和发送FIFO都能存放4个字节的数据,所以我的设计的是接收FIFO每接收到4个字节数据就产生一个接收中断读取FIFO中的数据。但是这样的话会有缺陷,如果发送数据和接收数据都在不间断进行,数据收发都不会产生错误,如果中断,比如信号传输线断开又连接上,这时候数据接收就会错误,我的解决方法是每当发送一个数据块(4个字节)时,就对接收FIFO进行清空,这样就不会因数据接收错位而错误接收数据了,问题出来了,如何有效的清空FIFO??

相关帖子

沙发
Stannis| | 2018-2-27 15:03 | 只看该作者
队头和队尾指针重合

使用特权

评论回复
板凳
Brand2| | 2018-2-27 15:12 | 只看该作者
FIFO是一个寄存器,没有什么指针啊

使用特权

评论回复
地板
Soraka| | 2018-2-27 15:23 | 只看该作者
不管内容,只动指针

使用特权

评论回复
5
Garen2| | 2018-2-27 15:31 | 只看该作者
“对接收FIFO清空”,手册上明确说明使用读的办法。

占了几个FIFO也可以知道。

使用特权

评论回复
6
Ryze| | 2018-2-27 15:39 | 只看该作者
楼主应该使用全双工功能,我觉得这样更好,

不管你指的是SCI还是SPI,都可以这样使用。

使用特权

评论回复
7
Varus| | 2018-2-27 15:52 | 只看该作者
ScibRegs.SCIFFRX.bit.RXFIFORESET=0;       //复位FIFO指针为0
ScibRegs.SCIFFRX.bit.RXFIFORESET=1;       //重新启用FIFO

这样岂不是更简单?

使用特权

评论回复
8
Snow7| | 2018-2-27 16:45 | 只看该作者
这样是简单,但还要重新设置FIFO。

使用特权

评论回复
9
android2| | 2018-2-27 16:58 | 只看该作者
如果FIFO里面的数据不使用,还清它干吗?
如果FIFO的数据是有用,那么必须要读它,一读不就自动清除了吗?

使用特权

评论回复
10
拉克丝| | 2018-2-27 17:07 | 只看该作者
Sci*Regs.SCIFFRX.bit.RXFIFORESET=0;
Sci*Regs.SCIFFRX.bit.RXFIFORESET=1;
这两句是可以使用的,但记得不能在SCI中断里面调用。

使用特权

评论回复
11
zhangmangui| | 2018-2-27 22:32 | 只看该作者
FIFO芯片应该有专门的引脚处理啊

使用特权

评论回复
12
lzbf| | 2018-3-3 22:25 | 只看该作者
FIFO是一个寄存器

使用特权

评论回复
13
houjiakai| | 2018-3-3 22:25 | 只看该作者
这个还真不知道。

使用特权

评论回复
14
youtome| | 2018-3-3 22:26 | 只看该作者
没有相关的寄存器吗?

使用特权

评论回复
15
cemaj| | 2018-3-3 22:26 | 只看该作者
ScibRegs.SCIFFRX.bit.RXFIFORESET=0;

使用特权

评论回复
16
sanfuzi| | 2018-3-3 22:26 | 只看该作者
如果FIFO里面的数据不使用,还清它干吗?

使用特权

评论回复
17
lzbf| | 2018-3-3 22:27 | 只看该作者
这个怎么清除呢?

使用特权

评论回复
18
houjiakai| | 2018-3-3 22:27 | 只看该作者
FIFO应该写入数据之后就会清除吧。

使用特权

评论回复
19
sanfuzi| | 2018-3-3 22:27 | 只看该作者
一读不就自动清除了吗?

使用特权

评论回复
20
cemaj| | 2018-3-3 22:27 | 只看该作者
ScibRegs.SCIFFRX.bit.RXFIFORESET=1;       //重新启用FIFO

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

154

主题

763

帖子

0

粉丝