MicroBlaze中的XUartLite_RecvByte()函数fifo中的数据在什么地方可以找到呢

MicroBlaze中的XUartLite_RecvByte()函数fifo中的数据在什么地方可以找到呢,第1张

在中断服务函数中 调用 XUartLite_RecvByte。因为中断时每一字节产生,所以每次中断时只能得到一字节数据

数据流传输时,可以将数据分包。这样在中断服务函数中就能判断是否接受到有效数据,以及是否接收完成

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

ScibRegsSCIFFTXall=0xE040;

//Enable RXFIFO, 0 TXFIFO level, 15 RXFIFO level

ScibRegsSCIFFRXall=0x004F;

//No auto-baud, 0 FIFO transfer delay

ScibRegsSCIFFCTall=0x0;

// one stop bit, No parity, No loopback, 8 char bits, idle-line protocol

ScibRegsSCICCRall = 0x0007;

// Disable RX ERR, TXWAK, SLEEP, Eenable TX, RX

ScibRegsSCICTL1all = 0x0003;

// 9600 baud @LSPCLK = 375MHz

ScibRegsSCIHBAUD = 0x0001;

ScibRegsSCILBAUD = 0x00E7;

// Relinquish SCI from Reset

ScibRegsSCICTL1all =0x0023;

//Re-enable TX and RX FIFO

ScibRegsSCIFFTXbitTXFIFOXRESET = 1;

ScibRegsSCIFFRXbitRXFIFORESET = 1;

主查询程序如下:

if(ScibRegsSCIFFRXbitRXFFST >= 6)

{

for(i = 0; i < 6; i++)

{

u16RXBuff[i] = ScibRegsSCIRXBUFall;

}

}

以上就是关于MicroBlaze中的XUartLite_RecvByte()函数fifo中的数据在什么地方可以找到呢全部的内容,包括:MicroBlaze中的XUartLite_RecvByte()函数fifo中的数据在什么地方可以找到呢、请教SCI中接收FIFO的问题、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9744849.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存