SPI的TXE问题。

[复制链接]
5045|6
 楼主| redlake 发表于 2012-4-2 18:17 | 显示全部楼层 |阅读模式
在MDK下仿真STM32的SPI,发现无论在何种状态下TXE始终为1,照理说TXE为发送缓冲器为空的标志位,向SPI DR写入一个数,即可将清0,但实际却不是这样。
在这句SPI1->DR = 0x01;处设置断点,然后单步执行,观察SPI1外设窗口发现TXE没有改变,依然是1,但RXNE由0变成1。
这是怎么一回事?
aozima 发表于 2012-4-2 19:17 | 显示全部楼层
"但RXNE由0变成1。“
说明接收到一个数据,这也表明刚才的数据已经发走了。那么?
 楼主| redlake 发表于 2012-4-2 23:07 | 显示全部楼层
是这样的,我程序原先是判断TXE位为1,就进行下一个数据的发送,但是发送总不正常,改为判断Busy位就正常,后来查找原因,发现TXE始终是1,这样发第2个字节数据的时候,实际上第1个字节并没有发送完毕,但因为TXE是1,就接着向DR寄存器写第2个字节,导致该字节丢失。而判断Busy位为0再发送第2、第3个字节则一切正常。
banyai 发表于 2012-4-3 08:36 | 显示全部楼层
TXE为1表示发送缓冲区为空。因为前面没有发送,当第一个字节写入发送缓冲区后,立即被送到了移位寄存器,所以还可以再写一个字节进发送缓冲区,只用当第二个字节写进去后,因为移位寄存器的数据还没发完,字节仍保存在发送缓冲区中等待,TXE才会为0。平常没有发送的情况下,这个也一定是1。
willwu0327 发表于 2012-4-3 08:38 | 显示全部楼层
我覺得應該先看看硬體訊號是否正常
wonderfullly 发表于 2012-4-23 14:00 | 显示全部楼层
我也碰到这个问题,你那解决了吗?
lut1lut 发表于 2012-4-23 16:39 | 显示全部楼层
TXE为1表示发送缓冲区为空。因为前面没有发送,当第一个字节写入发送缓冲区后,立即被送到了移位寄存器,所以还可以再写一个字节进发送缓冲区,只用当第二个字节写进去后,因为移位寄存器的数据还没发完,字节仍保存 ...
banyai 发表于 2012-4-3 08:36


4楼是正解。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

9

主题

14

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部