1、硬件配置:RT1176开发板 2、软件源码:MIMXRT1170-EVK\boards\evkmimxrt1170\driver_examples\lpspi\polling_b2b_transfer\master\cm7 3、应用环境:使用SPI驱动FRAM芯片 4、异常现象:FRAM理论支持最大频率为40MHz,可是实际配置到1MHz以上时,就是出现程序停留在函数LPSPI_MasterTransferBlocking中无法退出。 5、原因分析:此函数在处理SPI发送时,存在逻辑上的问题,即用户待发送数据全部写入TxFIFO中,可是TxFIFO未全部发送完成,就停止发送,导致接收不到理论长度的字节数。具体如下,SPI发送出去的字节数和接收到的字节数是相同的,当SPI控制器的TxFIFO中可以填写数据时,就写入字节,然后读取出接收到的字节,此部分(879行)退出的条件是将数据写入TxFIFO中就退出,而进入(967行)的接收时,并没有判断TxFIFO中的数据全部发送完,就会存在频率特别高的情况下,TxFIFO中数据尚未发送完成,就停止发送,导致接收中的死循环一直收不到指定长度的字节数。 6、解决方案: 修改代码:891行:while (LPSPI_GetTxFifoCount(base) == (fifoSize-1)) 952行:while (LPSPI_GetTxFifoCount(base) != 0)
个人愚见,如有问题,敬请指正!
|