在STM32CubeIDE 中用sprintf,printf总感觉差点什么
使用CUB进行调试或者下载固件时候均出现下面的报错,使用的工具是J-LINK,尝试重新给工具上电,重启IDE,重启电脑,更新配置均是一样问题点,请问这个是为什么呢
STM32H743使用Keil V6(AC6)编译FreeRTOS报错__forceinline未定义及CMSIS-RTOS2配置错误,如何解决?
NUCLEOh753zi
STM32U385的PB1引脚设置推挽输出,外部接电阻上拉时,断掉MCU的电源,MCU仍然运行的问题
CubeMX lwip支持的phy芯片型号只支持一个吗?
stm32 usb hid设备能发数据给PC,但不能接收PC的数据!!!
stm32H745 M4核不能调试和下载
关于H750VB的SDMMC开启DMA读写SD卡
FDCAN如何处理大于64帧字节的数据
微信公众号
手机版
KIMI:
根据您的描述和搜索结果,我分析这是典型的位时序和波特率切换(BRS)配置不匹配 问题。外部/内部环回模式能成功,因为它们不依赖真实的ACK应答,而正常模式需要严格的总线时序同步。
错误码分析
lasterrorcode = 5:仲裁阶段发生Bit0Error (发送'1'但回读为'0')datalasterrcode = 7:数据阶段NoChange (无新错误)这表明仲裁阶段就出现ACK失败或总线冲突 ,数据阶段根本未执行。外部环回模式绕过了ACK检查,所以能正常工作
。
核心原因与解决方案
1. 主从设备波特率配置不一致
这是最常见的原因。虽然您提到"有变速",但很可能是:
检查清单:
NominalPrescaler,NominalSyncJumpWidth,NominalTimeSeg1,NominalTimeSeg2(仲裁阶段)DataPrescaler,DataSyncJumpWidth,DataTimeSeg1,DataTimeSeg2(数据阶段,CAN FD BRS模式)2. 从设备ACK响应问题
正常模式下,发送方需要收到ACK才能认为成功。可能原因:
HAL_FDCAN_Start())验证方法:
c复制
3. 总线物理层问题
虽然60Ω终端电阻正常,但需确认:
4. GPIO和时钟配置
根据STM32H723参考手册,检查:
GPIO_AF9_FDCAN1GPIO_SPEED_FREQ_VERY_HIGHhfdcan1.Init.NominalPrescaler计算基于正确的时钟频率调试步骤建议
PSR(Protocol Status Register)寄存器,查看LEC和DLEC详细状态c复制
总结 :问题根源在于正常模式需要真实的总线握手和时序匹配 。先统一主从配置,从经典CAN模式开始验证,再逐步启用CAN FD和BRS功能。
如果确定硬件没问题,会不会是配置方面问题,比方两端的波特率配置不一致?
还有,如果接收时关闭过滤试试?
降低速率或改为经典CAN试试。
你的另外一端节点设备,是否支持CANFD?