can的波特率

can的波特率

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

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

简单介绍一下波特率的计算,在can的底层协议里将can数据的每一位时间(TBit)分为许多的时间段(Tscl),这些时间段包括:位同步时间Tsync,时间段1Tseg1,时间段2Tseg2.

其中位同步时间占用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波特率的值由以下几个元素决定:

1. 最小时间段Tscl

2. 时间段1  Tseg1

3. 时间段2  Tseg2

4. 同步跳转宽度 SJW

那么Tscl是怎么计算的呢?

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

tscl = pclk。

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总线有两个总线时钟寄存器BTR0、BTR1。


can的波特率_第1张图片

can系统时钟公式:

tscl = 2*tclk*(32*BRP.5 + 16*BRP.4 + 8*BRP.3 + 4*BRP.2 + 2*BRP.1 +BRP.0 + 1)

其中tclk=1/晶振频率=pclk。

同步跳转宽度:

Tsjw = “tscl”*(2*SJW.1 + SJW.0 + 1)

位周期T

TBit = Tseg1+Tseg2+Tsync=(Tseg1+Tseg2+3)*Tscl

Tseg1 = tscl*(8*TSEG1.3 + 4*TSEG1.2 +2*TSEG1.1 + TSEG1.0 + 1)

Tseg2 = tscl*(4*TSEG2.2 +2*TSEG2.1 + TSEG2.0 + 1)

CAN波特率=APB总线频率/BRP分频器/(1+tBS1+tBS2)。

比如:

总线时钟寄存器BTR0:0x2,;总线时钟寄存器BTR1:0x14。

TBit = tscl(1+5+2)=8tscl

tscl = 2tclk*(3) = 6tclk

TBit =48tclk

tclk = 1/48000000

TBit = 1/1000000

即can的波特率canbps就是1/TBit=1MHz。

你可能感兴趣的:(can的波特率)