STM32F4 CAN 配置注意的细节问题

本文详细介绍了STM32中CAN总线的配置参数,包括CAN_SJW、CAN_BS1、CAN_BS2和CAN_Prescaler,以及如何计算波特率。同时,解释了在启用CAN2时需要先启用CAN1时钟的原因,因为CAN2作为从设备不能直接访问SRAM,两者共享存储器。此外,还讨论了CAN2筛选器组的范围和配置,强调了CAN1和CAN2在滤波器使用上的关系。
摘要由CSDN通过智能技术生成

CAN总线通信的各节点通信时会产生相位差,所以要进行位同步,两个节点保持步调一致。
CAN_SJW:重新同步跳跃宽度(SJW) 。定义了在每位中可以延长或缩短多少个时间单元的上限。其值可以编程为1到4个时间单元。
CAN_BS1:时间段1(BS1):定义采样点的位置。其值可以编程为1到16个时间单元,但也可以被自动延长,以补偿因为网络中不同节点的频率差异所造成的相位的正向漂移。
CAN_BS2:时间段2(BS2):定义发送点的位置。其值可以编程为1到8个时间单元,但也可以被自动缩短以补偿相位的负向漂移。
CAN_Prescaler:直观理解就是分频率。
CAN总线的波特率是取自于总线APB1(PCLK1),通过函数RCC_PCLK1ConfigPCLK1配置频率。设置了以上的四个值之后,
CAN总线的波特率=
PCLK1/((CAN_SJW +CAN_BS1 + CAN_BS2)*CAN_Prescaler)
假设PCLK1=36MHz、CAN_SJW=1、CAN_BS1=8、CAN_BS2=7、CAN_Prescaler=9则CAN总线的波特率=PCLK1/((1 + 8 + 7) * 9) = 36MHz / 16 / 9 = 250Kbits
能解释的就这么多,对照着芯片手册和程序例程看看就懂了!!!!

1.在使能CAN2时钟之前,需要先使能CAN1的时钟

RCC_APB1PeriphClockCmd(RCC_APB1Periph_CAN1, ENABLE); //先使能CAN1

RCC_APB1PeriphClockCmd(RCC_APB1Periph_CAN2, ENABLE); //再使能CAN2

2.can2筛选器组从14开始 范围为14-27
CAN_FilterInitStructure.CAN_FilterNumber=15;
原理介绍:
CAN1:是主bxCAN,它负责管理在从bxCAN和512字节的SRAM存储器之间的通信
CAN2:是从bxCAN,它不能直接访问SRAM存储器 (见图195)
● 这 2个bxCAN模块共享512字节的SRAM存储器

《STM32中文参考手册V10》423页

问题1原理:CAN2作为从设备无法直接访问SRAM,因此在使能CAN2时钟时,首先要使能CAN1时钟才可以。

在这里插入图片描述

我们看这个CAN框图,在①处可以看到SRAM存储器在CAN1处,所以使用CAN2(从)时需要先使能CAN1的时钟,使CAN1工作,SRAM存储器才能被CAN2读到

同时我们看到③处:主滤波器(0~n) 从滤波器(n~27) 同时看到②处 这个n的设置是配置CAN FMR寄存器可以修改

STM32中CAN1和CAN2共用滤波器,在CAN1所用滤波器之后才是CAN2的滤波器,需在CAN 筛选器主寄存器 (CAN_FMR)中配置CAN2 起始存储区后CAN2才能使用筛选器。

一共个5位 设置CAN(2)接口的开始组 范围是0~27 而默认开始组是14

这就是为什么can2筛选器组从14开始 范围为14-27 的原因 ,当然你也可以修改该寄存器的值,使得can2的范围为0~27。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

%Zero%

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值