CAN波特率计算

Can控制器器只需要进行少量的设置就可以进行通信,就可以像RS232/48那样使用。
其中较难设置的部分就是通信波特率的计算。CAN总线能够在一定的范围内容忍总线上CAN节点的通信波特率的偏差,这种机能使得CAN总线有很强的容错性,同时也降低了对每个节点的振荡器精度。


实际上,CAN总线的波特率是一个范围。假设定义的波特率是250KB/S,但是实际上根据对寄存器的设置,实际的波特率可能为200~300KB/S(具体值取决于寄存器的设置)。

简单介绍一个波特率的计算,在CAN的底层协议里将CAN数据的每一位时间(TBit)分为许多的时间段(Tscl),这些时间段包括:

A. 位同步时间(Tsync)
B. 时间段1(Tseg1)
C. 时间段2(Tseg2)
其中位同步时间占用1个Tscl;时间段1占用(Tseg1+1)个Tscl;时间段2占用(Tseg2+1)个Tscl,所以CAN控制器的位时间 (TBit)就是:

TBit=Tseg1+Tseg2+Tsync=(TSEG1+TSEG2+3)*Tscl,那么CAN的波特率(CANbps)就是1/TBit。


但是这样计算出的值是一个理论值。在实际的网络通信中由于存在传输的延时、不同节点的晶体的误差等因素,使得网络CAN的波特率的计算变得复杂起来。CAN在技术上便引入了重同步的概念,以更好的解决这些问题。

这样重同步带来的结果就是要么时间段1(Tseg1)增加TSJW(同步跳转宽度SJW+1),要么时间段减少TSJW,因此CAN的波特率实际上有一个范围:
1/(Tbit+Tsjw)  ≤ CANbps ≤ 1/(Tbit-Tsjw)


CAN波特率的值四以下几个元素决定:
A. 最小时间段Tscl;
B. 时间段1 TSEG1;
C. 时间段2 TSEG2;
D. 同步跳转宽度 SJW


那么Tscl又是怎么计算的呢?
这是总总线时序寄存器中的预分频寄存器BRP派上了用场,Tscl=(BRP+1)/FVBP。
FVBP为微处理器的外设时钟。


而TSEG1与TSEG2又是怎么划分的呢?

TSEG1与TSEG2的长度决定了CAN数据的采样点,这种方式允许宽范围的数据传输延迟和晶体的误差。其中TSEG1用来调整数据传输延迟时间造成的误差,而TSEG2则用来调整不同点节点晶体频率的误差。

但是他们由于过于灵活,而使初次接触CAN的人有点无所适从。TSEG1与TSEG2的是分大体遵循以下规则: Tseg2≥Tscl2,Tseg2≥2TSJW,Tseg1≥Tseg2

总的来说,对于CAN的波特率计算问题,把握一个大的方向就行了,其计算公式可了规结为: BitRate = Fpclk/( (BRP+1) * ((Tseg1+1)+(Tseg2+1)+1)

此外,CAN协议还允许用户指定位采样模式SAM,分别是单次采样和三次采样模式(在3个采样结果中选出1个)。在单次采样模式中,采样点是在TESG1段的末端,而三次采样模式比单次采样多取两个采样点,它们在TSEG1段的末端的前面,之间相差一个TQ。

缩写的含义如下:
NBT: 位定时
BRP: 波特率预设值
SAM: 采样模式
SJW: 同步跳转宽度
SYNC—SEG: 同步段,固定值是1
TSEG1: 位定时段1
TSEG2: 位定时段2

采样点计算
采样点在位定时中的位置完全由TSEG2决定,如果用位定时的百分数来表示采样点的位置可以用下面的方程定义:
T_sample_point = (NBT-TSEG2)/NBT *100%

这些参数是用来做什么的?
在总线同步方式中的重同步中使用。
注:
CAN总线规范中定义的同步保证了报文可以不管节点间积累的相位误差正确地译码,振荡器漂移、空间地分布在网络的节点间的传播延迟或者噪声干扰都会产生相位误差,CAN规范定义了两种类型的同步:硬同步和重同步。
      
硬同步只在报文贞的开始执行,在空闲周期后,网路中每个CAN控制器会用接收到的SYNC_SEG第一个隐性到显性跳变沿初始化它当前的位周期定时。

重 同步是在随后的报文剩余部分每接收到一个隐性到显性的跳变沿就执行一次。如果这个边沿在TSEG1中接收到,即在SYNC_SEG后但在接收器的采样点 前,接收器就会把它解释成是一个慢速的发送器发送的滞后边沿,因此接收器会将TSEG1段延长到最匹配发送器的时间。相反,若果边沿在采样点之后接收器的 SYNC_SEG前收到,即在TSEG2中,接收器会将它解释成一个快的发送器发送的下一个位周期的提前边沿,这种情况下,接收器会将TSEG2段缩短到 最匹配发送器的时间。

重同步的位间隔可以被增长或者缩短的最大TQ数量由SJW的值指定。由于CAN位周期的所有段都被量化,即由整数个TQ组成,重同步只在绝对的相位误差大于1个TQ时产生,因此,甚至在有相同振荡器基准频率的两个网络节点间,也不能确定有一个TQ同步。
  • 0
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: GD32是一款单片机芯片,支持CAN通信协议。而CAN通信需要设置波特率才能实现数据传输,因此需要对GD32进行波特率计算。 首先,波特率是指数据传输时每秒钟传输的位数。在CAN通信中,波特率计算需要考虑以下几个因素: 1. Tq:CAN通信周期的时间,通常是由时间触发器提供的,可通过预设分频系数调整周期长度。 2. Bit time:每个传输单位的时间,可通过时序控制器进行设置,通常由同步段、传输段和重复段组成。 3. Sync Seg:同步段的长度,通常是Bit time的1/4到1/8。 4. Prop Seg:传输段的长度,表示在信号从发射器传输到接收器时的时延,通常为1-8个Tq。 5. Phase Seg1:第一重传输段的长度,通常为1-8个Tq。 6. Phase Seg2:第二重传输段的长度,通常为1-8个Tq。 根据上述参数,GD32的CAN波特率计算公式为: 波特率 = 时钟频率 / (Tq x (Sync Seg + Prop Seg + Phase Seg1 + Phase Seg2 + 1)) 其中,时钟频率指GD32的主频,Sync Seg、Prop Seg、Phase Seg1和Phase Seg2为通过寄存器设置的参数,Tq为CAN周期的时长。在实际应用中,可以根据需要调整参数值,以满足不同的波特率需求。 总结来说,GD32的CAN波特率计算需要考虑多个参数,其中包括时钟频率、CAN周期时长和各个传输段的长度等。通过设置这些参数,可以实现不同波特率的CAN数据传输。 ### 回答2: GD32是一种微控制器芯片系列,它支持CAN总线通信协议。在使用GD32进行CAN总线通信时,需要设置正确的波特率来保证正常的数据传输。一般来讲,GD32支持的CAN波特率范围为1Mbps到125Kbps。如果需要计算具体的波特率数值,可以使用以下公式: CAN波特率 = 系统时钟频率 / (分频器系数 * (时间段1 + 时间段2 + 1)) 其中,系统时钟频率是GD32的主时钟频率,分频器系数可以设定为1到1024之间的整数,时间段1和时间段2分别表示CAN总线的两个时间段,它们的值也可以设定为1到16之间的整数。 具体地,可以通过以下步骤来计算GD32的CAN波特率: 1. 确定系统时钟频率。在GD32的时钟配置中,可以设置CPU时钟频率、AHB总线时钟频率和APB总线时钟频率。需要根据具体的需求来选择合适的时钟频率。 2. 选择合适的分频器系数。GD32的CAN模块支持的分频器系数为1到1024之间的整数,选择哪一个分频器系数,可以根据需要得到的波特率范围来决定。一般来说,分频器系数越小,得到的波特率就越高。 3. 设定时间段1和时间段2的值。时间段1和时间段2的值决定了CAN总线的两个时间段的长度,一般来说,这两个值要尽量相等,可以设定为1到16之间的整数。 通过以上步骤,可以得到一个合适的CAN波特率。在设置CAN模块的波特率时,需要把计算出的数值配置到相应的寄存器中,以确保CAN总线的正常通信

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值