我想做以下事情:
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。
共2条
1/1 1 跳转至页
SPIMasterRX如何在保持CS低位的情况下从从机接收可变字节数?

关键词: SPI SD卡 CS

2楼
SPI Master RX的工作原理是主机通过SPI总线发送数据给从机,并且可以通过从机传输回来的数据接收到主机。在保持CS低位的情况下,SPI主机可以接收可变字节数的数据。
你已经完成了发送命令和接收从机响应的代码。你期望只接收3个虚拟字节,但实际上接收了8个字节。
这个问题可能是由于数据的传输速度过快导致的。当实际传输的数据长度小于预期时,原因可能是以下几点:
1. 主机在接收到最后一个字节之前停止接收数据。这可能是由于主机设备读取数据的速度比从机设备发送数据的速度快。
2. 从机没有及时停止数据传输。这可能导致数据在从机中缓冲,并继续发送到主机,直到缓冲区满为止。
为了解决这个问题,你可以尝试以下几个方法:
1. 增加适当的延时,以便主机设备有足够的时间来接收数据。可以通过延长CS低位的时间或在发送命令之后增加适当的延时来实现。
2. 在接收到预期数量的字节后,主动停止从机发送数据。可以在接收到预期数量的字节后,通过设置SPI控制器的控制寄存器来停止数据传输。
3. 检查使用的硬件和软件配置是否正确。确保SPI主机和从机的时钟和模式设置正确。
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
分享开发笔记,赚取电动螺丝刀(便携轻巧与无刷电机两款可选) | |
看《关键跃升》,聊聊工作心法、动力、能力、沟通与协作,从五个方面深入交流你的工作心得 | |
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
我要给自己挣一部逻辑分析仪 | |
用知识换取送给亲朋的礼物,做个浪漫的开发者 | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 |
打赏帖 | |
---|---|
Buck电路工作在CCM模式下电感电流的计算公式是什么?被打赏5分 | |
buck电路工作原理被打赏5分 | |
基于MSPM0L1306的MODBUS-RTU协议通讯实验被打赏100分 | |
我想要一部加热台+多合一调试工具被打赏18分 | |
每周了解几个硬件知识+485硬件知识分享被打赏10分 | |
【换取手持数字示波器】树莓派PICO调试器官方固件本地化部署实践被打赏24分 | |
【换取手持数字示波器】分享一个KEIL无法识别CMSIS-DAP调试器的解决办法被打赏20分 | |
【换取手持数字示波器】分享一个自制的ArduinoNano扩展板底板被打赏23分 | |
【换取手持示波器】树莓派PICOW网页烟花被打赏18分 | |
【换取手持示波器】树莓派PICO逻辑分析仪被打赏16分 |