关于STM32Cubemx 6.15版本生成工程的文件编码的问题
STM32H7A3 怎样配置MDMA的硬件触发MDMA_REQUEST_DMA1_Stream0_TC将数据再次转运
stm32h7s78-dk烧录
有没有大佬更新了CubeIDE2.0.0,在软件内更新后体积大了一倍
STM32H7 USB3300底层寄存器问题
STM32H725S没有硬件双缓冲吗?
为什么用cubemax生成f103c8t6的freertos在编译时会报错
MC Workbench无法生成ioc文件,报错无法比较两个不同的数据类型
STM32U5进入standby模式时,待机电流有时候大的离谱,有时候却正常
使用stm32cubeide开发h743,准备采用spi flash的方式下载外部norflash
微信公众号
手机版
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试试。