这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 嵌入式开发 » MCU » SPIMasterRX如何在保持CS低位的情况下从从机接收可变字节数?

共1条 1/1 1 跳转至

SPIMasterRX如何在保持CS低位的情况下从从机接收可变字节数?

高工
2024-03-30 19:23:27     打赏

我想做以下事情:
1。通过 SPI 向 SD 卡发送 6 字节命令,在 TX Empty 上中断(当命令完全移出 FIFO 时)
2。在 ISR 中,使用 scb_spiuartClearrxBuffer () 或读取字节来清空接收 FIFO。
3。发送虚拟字节 0xFF,在 TX 空时中断,读取 RX 字节,直到收到非 0xFF 值(来自 SD 卡的响应)。
因此,假设 SD 卡对命令之后的第二个虚拟字节作出响应,我应该看到命令之后总共传输了 3 个虚拟字节。 但是,我却在代码和逻辑分析器跟踪中看到了 8:

使用调试器,我将问题范围缩小到了 ISR 中的这一部分:

遇到该断点时的总线跟踪(由于调试器暂停,SCB 会自动取消对 CS 的断言):

上面的步骤 2 是第 51-54 行,其余的就是步骤 3。 尽管我已经从 RX 缓冲区读取了所有字节,或者使用了 clearRxBuffer (),但在传输另一个字节之后,RX 缓冲区大小读取 5,尽管之前打破 do/while 循环时为 0!
为什么?如果我从 FIFO/Buffer 中读取所有 RX 字节,然后再传输一个字节,为什么接收缓冲区中还有 5 个字节? 这 5 个加上 3 个虚拟字节 = 在从 FIFO 读取响应字节之前传输的 8 个额外字节。
我认为这个问题可能是由于我向 TX 缓冲区写入 0xFF 后直接触发 TX Empty 中断所致,因为当最后一个 FIFO 元素从 FIFO 移到移位器时,空就会触发。 例如,也许空中断会触发不止一次? 有没有更好的方法来进行单字节传输/检查响应,而无需SCB自动取消对CS的断言(即 没有 SPI_DONE 中断)?
我已经附上了这个项目,它以 CY8CKIT046 为目标,SD 模块通过 PMOD 接头(端口 6)连接到 SCB。




关键词: SPI     SD卡     CS    

共1条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]