请教SCI中接收FIFO的问题

 我来答
匿名用户
2017-05-16
展开全部
1、手册上说“With the FIFO enabled, TXSHF is directly loaded after an optional delay value (SCIFFCT), TXBUF is not used.”意思是使能发送FIFO之后,TXSHF直接装载数据而不使用TXBUF,是说从FIFO直接装载吗?这样的话TXBUF这个寄存器就用不到了,但是我看TI的例程里仍然把要发送的数据先放到SCITXBUF这个寄存器里,而FIFO里并没有一个专门用来装载要发送数据的地方,这是为什么?接收FIFO也有同样的问题,还是都要从SCIRXBUF中读取。

2、我自己写了一个用FIFO接收的程序,用串口调试助手给SCI重复发送同一个数比如12,当RXFIFO中的值大于6时开始读FIFO的值,也就是想一次性读6次的值,但是从初始化完成到RXFFST中的值大于等于6,观察SCIRXBUF的值全部是0XFF,根本没有变过,请问这里我要读FIFO的数据应该怎么读,SCIRXBUF中的值一直是0XFF有可能是什么原因造成的?代码如下
初始化程序:
//Resume FIFO, enable FIFO, enable TXFIFO, 0 TXFIFO level
ScibRegs.SCIFFTX.all=0xE040;
//Enable RXFIFO, 0 TXFIFO level, 15 RXFIFO level
ScibRegs.SCIFFRX.all=0x004F;
//No auto-baud, 0 FIFO transfer delay
ScibRegs.SCIFFCT.all=0x0;
// one stop bit, No parity, No loopback, 8 char bits, idle-line protocol
ScibRegs.SCICCR.all = 0x0007;
// Disable RX ERR, TXWAK, SLEEP, Eenable TX, RX
ScibRegs.SCICTL1.all = 0x0003;
// 9600 baud @LSPCLK = 37.5MHz.
ScibRegs.SCIHBAUD = 0x0001;
ScibRegs.SCILBAUD = 0x00E7;
// Relinquish SCI from Reset
ScibRegs.SCICTL1.all =0x0023;
//Re-enable TX and RX FIFO
ScibRegs.SCIFFTX.bit.TXFIFOXRESET = 1;
ScibRegs.SCIFFRX.bit.RXFIFORESET = 1;
主查询程序如下:
if(ScibRegs.SCIFFRX.bit.RXFFST >= 6)
{
for(i = 0; i < 6; i++)
{
u16RXBuff[i] = ScibRegs.SCIRXBUF.all;
}
}
清彩秋1B
2017-04-16 · TA获得超过371个赞
知道小有建树答主
回答量:370
采纳率:0%
帮助的人:91万
展开全部
因为所用的485收发芯片需要另外对发送和接收使能进行分别控制,控制了之后就能够接收了。
但是又发现偶尔会接收到错误的信息,比如应该接收4个数分别是12、34、56、78,结果可能接收到了0X8015这样很大数,或者可能4个数的接收顺序有错乱。对于像0x8015这样的数,最高位是1,按照SCIRXBUF的位定义是发生了帧错误。
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式