RT1176开发板源码中LPSPI驱动问题

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)

个人愚见,如有问题,敬请指正!

版权声明:本文为CSDN博主「ttxs5000」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/ttxs5000/article/details/122756099

生成海报
点赞 0

ttxs5000

我还没有学会写个人说明!

暂无评论

发表评论

相关推荐

STM32CubeMx hal 驱动sg90舵机

一、舵机的控制原理 舵机通过接收PWM信号,使其进入内部电路产生一个偏置电压,触发电机通过减速齿轮带动电位器移动,使电压差为零时,电机停转,从而达到伺服的效果。即给舵机一个

TM1650芯片驱动四位数码管

自言自语 今天上班被丢了块4位数码管过来,还有一份驱动数码管的芯片资料。还好只有十几页,哈哈哈。 大致浏览下手册,了解到这个芯片叫TM1650,然后是使用模拟IIC协议的。那也就是说&#

STM32F1xx HAL库 中文详解 之 ADC篇

本文主要从ADC中用到的结构体、函数以及用法讲解。 目录 一、结构体 1.ADC_InitTypeDef 2.ADC_ChannelConfTypeDef 3.ADC_AnalogWDGConfTypeDef 4.ADC_Handl