LPC21xx CAN 波特率計算
CAN波特率的計算公式如下:

其中tcan是CAN系統時(shí)鐘的一個(gè)周期,tbit是一個(gè)CAN位周期。
以VPB時(shí)鐘Fpclk=24MHz,選擇采樣點(diǎn)位置在85%左右為佳,即使TESG1/(TESG1+TESG2)在85%左右,2

當VPB時(shí)鐘為4*11059200Hz時(shí),常用波特率與總線(xiàn)時(shí)序器對照表(周立功給的,11059200kHz的波特率都是近似的,有誤差)BPS = (SAM << 23)|(TSEG2 << 20)|(TSEG1 << 16)|(SJW << 14)| BRP
#define BPS_5K
#define BPS_10K
#define BPS_20K
#define BPS_40K
#define BPS_50K
#define BPS_80K
#define BPS_100K
#define BPS_125K
#define BPS_200K
#define BPS_250K
#define BPS_400K
#define BPS_500K
#define BPS_666K
#define BPS_800K
#define BPS_1000K
以下是我自己推導的(僅供參考)
CANBTR(0xE00xx014)
31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | SAM | TSEG2 | TSEG1 | SJW | 0 | 0 | 0 | 0 | BRP |
SAM
Can控制器器只需要進(jìn)行少量的設置就可以進(jìn)行通信,就可以像RS232/48那樣使用。
其中較難設置的部分就是通信波特率的計算。CAN總線(xiàn)能夠在一定的范圍內容忍總線(xiàn)上CAN節點(diǎn)的通信波特率的偏差,這種機能使得CAN總線(xiàn)有很強的容錯性,同時(shí)也降低了對每個(gè)節點(diǎn)的振蕩器精度。
實(shí)際上,CAN總線(xiàn)的波特率是一個(gè)范圍。假設定義的波特率是250KB/S,但是實(shí)際上根據對寄存器的設置,實(shí)際的波特率可能為200~300KB/S(具體值取決于寄存器的設置)。
簡(jiǎn)單介紹一個(gè)波特率的計算,在CAN的底層協(xié)議里將CAN數據的每一位時(shí)間(TBit)分為許多的時(shí)間段(Tscl),這些時(shí)間段包括:
A. 位同步時(shí)間(Tsync)
B. 時(shí)間段1(Tseg1)
C. 時(shí)間段2(Tseg2)
其中位同步時(shí)間占用1個(gè)Tscl;時(shí)間段2占用(Tseg1+1)個(gè)Tscl;時(shí)間段2占用(Tseg2+1)個(gè)Tscl,所以CAN控制器的位時(shí)間(TBit)就是:
TBit=Tseg1+Tseg2+Tsync=(TSEG1+TSEG2+3)*Tscl,
那么CAN的波特率(CANbps)就是1/TBit。
但是這樣計算出的值是一個(gè)理論值。在實(shí)際的網(wǎng)絡(luò )通信中由于存在傳輸的延時(shí)、不同節點(diǎn)的晶體的誤差等因素,使得網(wǎng)絡(luò )CAN的波特率的計算變得復雜起來(lái)。CAN在技術(shù)上便引入了重同步的概念,以更好的解決這些問(wèn)題。這樣重同步帶來(lái)的結果就是要么時(shí)間段1(Tseg1)增加TSJW(同步跳轉寬度SJW+1),要么時(shí)間段減少TSJW,因此CAN的波特率實(shí)際上有一個(gè)范圍:
1/(Tbit+Tsjw) ≤CANbps≤1/(Tbit-Tsjw)
CAN有波特率的值四以下幾個(gè)元素決定:
A. 最小時(shí)間段Tscl;
B. 時(shí)間段1 TSEG1;
C. 時(shí)間段2 TSEG2;
D. 同步跳轉寬度 SJW
那么Tscl又是怎么計算的呢?這是總線(xiàn)時(shí)序寄存器中的預分頻寄存器BRP派上了用場(chǎng),Tscl=(BRP+1)/FVBP。FVBP為微處理器的外設時(shí)鐘Fpclk。
而TSEG1與TSEG2又是怎么劃分的呢?TSEG1與TSEG2的長(cháng)度決定了CAN數據的采樣點(diǎn),這種方式允許寬范圍的數據傳輸延遲和晶體的誤差。其中TSEG1用來(lái)調整數據傳輸延遲時(shí)間造成的誤差,而TSEG2則用來(lái)調整不同點(diǎn)節點(diǎn)晶體頻率的誤差。但是他們由于過(guò)于靈活,而使初次接觸CAN的人有點(diǎn)無(wú)所適從。TSEG1與TSEG2的是分大體遵循以下規則: Tseg2≥Tscl2,Tseg2≥2TSJW,Tseg1≥Tseg2
總的來(lái)說(shuō),對于CAN的波特率計算問(wèn)題,把握一個(gè)大的方向就行了,其計算公式可以規結為:
BitRate = Fpclk/( (BRP+1) * ((Tseg1+1)+(Tseg2+1)+1)
關(guān)于CAN的波特率的計算,在數據手冊上已經(jīng)有很詳細的說(shuō)明。在此,簡(jiǎn)要的把計算方法給出來(lái):
Tcsc :bit位每一編碼的時(shí)間長(cháng)度,每bit可以配置為8~25位編碼,常設為16 。
Tcsc=1/波特率/編碼長(cháng)度 ;按上面計算 Tcsc="1/1MHz/16"=62.5ns (取63) 。
BRP = (Tcsc x MCK) - 1=6.3-1 (可以取 5)
各種延遲(Tprs :)
Delay of the bus driver: 50 ns
Delay of the receiver: 30ns
Delay of the bus line (20m): 110ns
Tprs = 2 * (50+30+110) ns = 380 ns
PROPAG= 380 ns/ Tcsc-1 =6.08Tcsc-1 (可取 6)
Tphs1 + Tphs2 = bit time - Tcsc - Tprs = (16 - 1 - 7)Tcsc= 8
常取 Tphs1 = Tphs2 ,所以 Tphs1 = Tphs2 =4 ;
Tsjw = Min(4 Tcsc,Tphs1) = 4 Tcsc (From 1 to Tphs1 )
SJW = Tsjw/Tcsc - 1 = 3 ;
現在CAN_BR 中的各個(gè)參數就都有了(BRP=5 ;SJW=3;PROPAG=6;PHASE1=PHASE=4),填進(jìn)去就應該OK了 。
假設我們先不考慮BTR0中的SJW位和BTR1中的SAM位。那么,BTR0和BTR1就是2個(gè)分頻系數寄存器;它們的乘積是一個(gè)擴展的分頻系數。即:
(1)式中,當晶振為16M時(shí),F_BASE=8000K
同步段+相位緩沖段1+相位緩沖段2 =1+5+4
則(2)式簡(jiǎn)化為
評論