RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

CAN總線入門知識科普

FPGA之家 ? 來源:CSDN技術(shù)社區(qū) ? 作者:CSDN技術(shù)社區(qū) ? 2022-05-14 14:29 ? 次閱讀

1、簡介

CAN總線由德國BOSCH公司開發(fā),最高速率可達(dá)到1Mbps。CAN的容錯能力特別強(qiáng),CAN控制器內(nèi)建了強(qiáng)大的檢錯和處理機(jī)制。

另外,不同于傳統(tǒng)的網(wǎng)絡(luò)(如USB或者以太網(wǎng)),CAN節(jié)點與節(jié)點之間不會傳輸大數(shù)據(jù)塊,一幀CAN消息最多傳輸8字節(jié)用戶數(shù)據(jù),采用短數(shù)據(jù)包也可以使得系統(tǒng)獲得更好的穩(wěn)定性。CAN總線具有總線仲裁機(jī)制,可以組建多主系統(tǒng)。

2、CAN標(biāo)準(zhǔn)

CAN是一個由國際化標(biāo)準(zhǔn)組織定義的串行通訊總線。最初是用于汽車工業(yè),使用兩根信號總線代替汽車內(nèi)復(fù)雜的走線。CAN總線具有高抗干擾性、自診斷和數(shù)據(jù)偵錯功能,這些特性使得CAN總線在各種工業(yè)場合廣泛使用,包括樓宇自動化、醫(yī)療和制造業(yè)。

CAN通訊協(xié)議ISO-11898:2003標(biāo)準(zhǔn)介紹網(wǎng)絡(luò)上的設(shè)備間信息是如何傳遞的,以及符合開放系統(tǒng)互聯(lián)參考模型(OSI)的哪些分層項。實際通訊是在連接設(shè)備的物理介質(zhì)中進(jìn)行,物理介質(zhì)的特性由模型中的物理層定義。ISO11898體系結(jié)構(gòu)定義七層,OSI模型中的最低兩層作為數(shù)據(jù)鏈路層和物理層,見圖2-1。

6dc78648-d31c-11ec-bce3-dac502259ad0.jpg

圖2-1:ISO 11898標(biāo)準(zhǔn)架構(gòu)分層

在圖2-1中,應(yīng)用程序?qū)咏⒘松蠈討?yīng)用特定協(xié)議,如CANopenTM協(xié)議的通訊鏈路。這個協(xié)議由全世界的用戶和廠商組織、CiA維護(hù),詳情可訪問CiA網(wǎng)站:can-cia.de。

許多協(xié)議是專用的,比如工業(yè)自動化、柴油發(fā)動機(jī)或航空。另外的工業(yè)標(biāo)準(zhǔn)例子,是基于CAN的協(xié)議的,由KVASER和Rockwell自動化開發(fā)的DeviceNetTM。

3、標(biāo)準(zhǔn)CAN和擴(kuò)展CAN

CAN通訊協(xié)議是一個載波偵聽、基于報文優(yōu)先級碰撞檢測和仲裁(CSMA/CD+AMP)的多路訪問協(xié)議。CSMA的意思是總線上的每一個節(jié)點在企圖發(fā)送報文前,必須要監(jiān)聽總線,當(dāng)總線處于空閑時,才可發(fā)送。

CD+AMP的意思是通過預(yù)定編程好的報文優(yōu)先級逐位仲裁來解決碰撞,報文優(yōu)先級位于每個報文的標(biāo)識域。更高級別優(yōu)先級標(biāo)識的報文總是能獲得總線訪問權(quán),即:標(biāo)識符中最后保持邏輯高電平的會繼續(xù)傳輸,因為它具有更高優(yōu)先級。

ISO-11898:2003標(biāo)準(zhǔn),帶有11位標(biāo)識符,提供的最高信號速率從125Kbps到1Mbps。更遲一些的修訂標(biāo)準(zhǔn)使用了擴(kuò)展的29位標(biāo)識符。標(biāo)準(zhǔn)11位標(biāo)識符位域參見圖3-1,提供2048個不同的報文標(biāo)識符,擴(kuò)展29位標(biāo)識符位域參見圖3-2,提供537百萬個不同報文標(biāo)識符。

3.1 標(biāo)準(zhǔn)CAN

標(biāo)準(zhǔn)CAN只有11位標(biāo)識符,每幀的數(shù)據(jù)長度為51+(0~64)=(51~117)位。

注:不計位填充(位填充將在本文第5節(jié)描述)。

6ddd3b96-d31c-11ec-bce3-dac502259ad0.png

圖3-1:標(biāo)準(zhǔn)CAN---11位標(biāo)識符

· SOF - 幀起始,顯性(邏輯0)表示報文的開始,并用于同步總線上的節(jié)點。

· 標(biāo)識符 - 標(biāo)準(zhǔn)CAN具有11位標(biāo)識符,用來確定報文的優(yōu)先級。此域的數(shù)值越小,優(yōu)先級越高。

· RTR - 遠(yuǎn)程發(fā)送請求位,當(dāng)需要從另一個節(jié)點請求信息時,此位為顯性(邏輯0)。所有節(jié)點都能接收這個請求,但是幀標(biāo)識符確定被指定的節(jié)點。響應(yīng)數(shù)據(jù)幀同樣被所有節(jié)點接收,可以被有興趣的節(jié)點使用。

· IDE - 標(biāo)識符擴(kuò)展位為顯性時表示這是一個標(biāo)準(zhǔn)CAN格式,為隱形表示這是擴(kuò)展CAN格式。

· r0 - 保留位(可能將來標(biāo)準(zhǔn)修訂會使用)

· DLC - 4位數(shù)據(jù)長度代碼表示傳輸數(shù)據(jù)的字節(jié)數(shù)目,一幀CAN最多傳輸8字節(jié)用戶數(shù)據(jù)

· 數(shù)據(jù)0~8 – 最多可以傳輸8字節(jié)用戶數(shù)據(jù)

· CRC - 16位(包括1位定界符)CRC校驗碼用來校驗用戶數(shù)據(jù)區(qū)之前的(包含數(shù)據(jù)區(qū))傳輸數(shù)據(jù)段。

· ACK - 2位,包含應(yīng)答位和應(yīng)答界定符。發(fā)送節(jié)點的報文幀中,ACK兩位是隱性位,當(dāng)接收器正確地接收到有效的報文,接收器會在應(yīng)答位期間向發(fā)送節(jié)點發(fā)送一個顯性位,表示應(yīng)答。如果接收器發(fā)現(xiàn)這幀數(shù)據(jù)有錯誤,則不向發(fā)送節(jié)點發(fā)送ACK應(yīng)答,發(fā)送節(jié)點會稍后重傳這幀數(shù)據(jù)。

· EOF – 7位幀結(jié)束標(biāo)志位,全部為隱性位。如果這7位出現(xiàn)顯性位,則會引起填充錯誤。

· IFS – 7位幀間隔標(biāo)志位,CAN控制器將接收到的幀正確的放入消息緩沖區(qū)是需要一定時間的,幀間隔可以提供這個時間。

3.2 擴(kuò)展CAN

擴(kuò)展CAN具有29位標(biāo)識符,每幀數(shù)據(jù)長度為71+(0~64)=(71~135)位。

注:不計位填充(位填充將在本文第5節(jié)描述)。

6e0ddc60-d31c-11ec-bce3-dac502259ad0.png

圖3-2:擴(kuò)展CAN---29位標(biāo)識符

擴(kuò)展CAN消息相對于標(biāo)準(zhǔn)CAN消息增加的內(nèi)容如下:

· SRR – 代替遠(yuǎn)程請求位,為隱性。所以當(dāng)標(biāo)準(zhǔn)幀與擴(kuò)展幀發(fā)送相互沖突并且擴(kuò)展幀的基本標(biāo)識符與標(biāo)準(zhǔn)幀的標(biāo)識符相同時,標(biāo)準(zhǔn)幀優(yōu)先級高于擴(kuò)展幀。

· IDE – 為隱性位表示標(biāo)志位擴(kuò)展幀,18位擴(kuò)展標(biāo)識符緊跟著IDE位。

· r1 – 保留

4、CAN消息

4.1 仲裁

典型CAN的基本原理見圖4-1所示,從圖中可以看出,總線邏輯狀態(tài)與驅(qū)動器輸入和接收器輸出邏輯是相反的。

正常情況下,邏輯高電平為1,邏輯低電平為0,但是CAN總線卻是邏輯高電平為0,稱為顯性,邏輯低電平為1,稱為隱性。所以,很多收發(fā)器的驅(qū)動器輸入端都會內(nèi)置上拉電阻,在沒有任何輸入時,CAN總線就會表現(xiàn)為隱性(邏輯低電平)。

6e22d408-d31c-11ec-bce3-dac502259ad0.png

圖4-1:反轉(zhuǎn)的CAN總線邏輯

在總線空閑時,最先開始發(fā)送報文的節(jié)點獲得發(fā)送權(quán)。

如果多個節(jié)點同時訪問總線,CAN使用非破壞式、逐位仲裁的方式?jīng)Q定哪個節(jié)點使用總線:各發(fā)送節(jié)點從仲裁域(標(biāo)識符和RTR域)的第1位開始進(jìn)行仲裁,連續(xù)輸出顯性電平(0)最多的節(jié)點可以繼續(xù)發(fā)送。

因此,標(biāo)識符數(shù)值越低的CAN報文,優(yōu)先級越高。標(biāo)識符數(shù)值為0的CAN報文,具有最高優(yōu)先級,因為它輸出的顯性電平最多。

4.2 消息類型

CAN有四種不同的報文類型:數(shù)據(jù)幀、遠(yuǎn)程幀、錯誤幀和過載幀。

5、位填充機(jī)制

幀起始、仲裁域、控制域、數(shù)據(jù)域以及CRC校驗和域,均通過位填充方法編碼。位填充是指,無論何時,發(fā)送器只要檢測到位流中有5個連續(xù)相同邏輯的位,便會自動在位流中插入一個補(bǔ)碼位。

舉例來說,如果連續(xù)5個顯性位,則在5個顯性位之后自動插入1個隱性位。接收器會自動刪除這個插入的填充位。

數(shù)據(jù)幀或遠(yuǎn)程幀的剩余位域(CRC界定符、應(yīng)答域和幀結(jié)尾域)形式固定,不填充。錯誤幀和過載幀也不填充。

CAN網(wǎng)絡(luò)同步需要足夠多的上升沿,這是CAN協(xié)議規(guī)定位填充的目的之一。位填充的其它作用:確保數(shù)據(jù)幀不會被當(dāng)作錯誤幀(由6個連續(xù)的顯性或隱性位組成)、確保正確識別幀結(jié)束標(biāo)志(7個連續(xù)隱性位)。

6、錯誤檢測和故障界定

CAN總線具有很高的健壯性,這可能要歸功于CAN具有多種錯誤檢查機(jī)制。CAN協(xié)議制定了5種錯誤檢測方法:三種位于報文層,兩種位于位流層。

如果一個數(shù)據(jù)幀出現(xiàn)錯誤,那么這個幀會被丟棄,并且接收節(jié)點還會發(fā)送一個錯誤幀。這會強(qiáng)制發(fā)送節(jié)點重復(fù)發(fā)送出錯的報文,直到接收節(jié)點正確接收。如果同一個報文重復(fù)出錯,達(dá)到一定次數(shù)后,發(fā)送節(jié)點可以關(guān)閉發(fā)送功能以降低對總線的影響。

報文層的錯誤檢測包括CRC和ACK。16位的CRC域包含15位校驗和、1位界定符。ACK域包括1位應(yīng)答位、1位界定符。

CRC校驗錯誤很好理解,它對數(shù)據(jù)域以及數(shù)據(jù)域之前的位生產(chǎn)CRC校驗。由于一幀CAN報文數(shù)據(jù)流很小(最多8個用戶數(shù)據(jù)),所以15位CRC的偵錯能力非常優(yōu)秀。

那么,ACK域是怎么起作用的呢?這是由CAN協(xié)議規(guī)定的,即發(fā)送節(jié)點發(fā)送一幀數(shù)據(jù)后,接收節(jié)點必須向發(fā)送節(jié)點應(yīng)答,如果發(fā)送節(jié)點沒有收到接收節(jié)點的應(yīng)答信號,就會認(rèn)為自己發(fā)送失敗,從而重傳數(shù)據(jù)。

報文層的第三種錯誤檢查方法是格式檢查。這種檢查會監(jiān)控報文中那些一定為隱性位的域,如果這些域中出現(xiàn)顯性位,則檢測到格式錯誤。這些域包括SOF、EOF、ACK的界定符和CRC的界定符。

位流層的錯誤檢測之一是發(fā)送到總線上的每一個數(shù)據(jù)位,都會被監(jiān)視,如果發(fā)現(xiàn)發(fā)送的位和總線上的位不相同時,產(chǎn)生位錯誤。這種監(jiān)視機(jī)制并不會監(jiān)視仲裁域的位,這是因為多個節(jié)點同時競爭總線時,優(yōu)先級高的節(jié)點可能會覆寫總線上的仲裁域位。

位流層的另外一個錯誤檢測機(jī)制是位填充規(guī)則:5個連續(xù)相同邏輯位之后,如果第6個位的邏輯還和前五個相同,則產(chǎn)生位填充錯誤。

7、網(wǎng)絡(luò)拓?fù)?/p>

CAN使用差分信號,需要一對信號線,推薦使用雙絞線,網(wǎng)絡(luò)拓?fù)淙鐖D7-1所示。使用差分信號可以抑制共模干擾、能夠增加系統(tǒng)可靠性,允許使用更高的速率。

高速ISO 11898標(biāo)準(zhǔn)規(guī)定了CAN傳輸最高速率為1Mbps,在這個速率下,傳輸距離最長40米(掛接30個節(jié)點,CAN信號不隔離)。推薦節(jié)點分支長度最大為0.3米、推薦使用帶屏蔽或不帶屏蔽的雙絞線,線纜特性阻抗為120歐姆。

6e3fb866-d31c-11ec-bce3-dac502259ad0.jpg

圖7-1:CAN總線網(wǎng)絡(luò)拓?fù)浣Y(jié)構(gòu)圖

8、終端匹配

終端匹配電阻大小等于傳輸電纜特性阻抗,傳輸電纜特性阻抗由電纜供應(yīng)商提供,一般近似為Z=√(L/C)。其中L為電纜單位長度感抗,C為電纜單位長度電容

由于CAN收發(fā)器結(jié)構(gòu),從隱性變成顯性由晶體管驅(qū)動,所以都是很陡的,但是從顯性回到隱性,卻需要終端電阻來放電,否則就會由于導(dǎo)線分布電容,緩慢放電,導(dǎo)致位寬錯誤。所以所謂的近距離、低波特率CAN總線不加終端電阻的做法,都是錯誤的。

RS485與CAN總線不同,由于RS485收發(fā)器中一般都內(nèi)置失效保護(hù)電路,在近距離、低波特率下允許不加終端匹配電阻。

9、電纜與接線

CAN總線采用差分信號傳輸,如果使用帶屏蔽雙絞線,屏蔽層應(yīng)單點接地。

圖9-11列出帶單屏蔽層的CAN電纜剖析與連接線示范。

6e736742-d31c-11ec-bce3-dac502259ad0.jpg

圖9-1:電纜信號分配、接地和終端匹配

通常情況下,電纜截面積越小,其分布電容、分布電感和直流電阻越大。當(dāng)通訊距離較遠(yuǎn)時,電容、電感和直流電阻會引起信號衰減,波形失真和抖動。

一般而言,電纜供應(yīng)商會提供信號衰減圖表。圖9-2所示的曲線顯示了24-AWG電纜衰減和頻率的關(guān)系:

6f1071fe-d31c-11ec-bce3-dac502259ad0.jpg

圖9-2:信號衰減

10、差分信號電壓幅值

如圖10-1所示,兩條信號線CAN_H和CAN_L靜態(tài)時均為2.5V左右,此時狀態(tài)表示邏輯1,稱作隱性;CAN_H比CAN_L高表示邏輯0,稱為顯性,此時通常CAN_H電壓3.5V、CAN_L電壓1.5V。

6f23eee6-d31c-11ec-bce3-dac502259ad0.png

圖10-1:CAN電平幅值

CAN標(biāo)準(zhǔn)規(guī)定,CAN總線上的差分電壓>0.9V才能被識別成顯性電平,<0.5V才能被識別成隱性電平,0.5~0.9之間的電平不能確定電平極性。如表10-1所示:

6f43b6d6-d31c-11ec-bce3-dac502259ad0.png

表10-1:差分電壓幅值與電平極性關(guān)系

在實際項目布線時,容易漏加或者多加終端匹配電阻。我們可以通過測量CAN差分電壓幅值來評估是否漏加或多加終端匹配電阻。如果不計導(dǎo)線電阻,終端電阻固定為120歐姆,單節(jié)點CAN總線差分電壓如表10-2所示:

6f5458a6-d31c-11ec-bce3-dac502259ad0.png

表10-2:終端匹配電阻數(shù)目與差分電壓幅值關(guān)系

11、電纜截面積與通訊距離

電纜截面積對通訊距離影響很大,特別是遠(yuǎn)距離通訊。遠(yuǎn)距離傳輸線上的分布電容、分布電感和直流參數(shù)會引起信號衰減。很多CAN通訊應(yīng)用都具有距離遠(yuǎn)、波特率低的特性。

比如,本公司的KTC161通訊控制系統(tǒng)使用10kpbs,傳輸距離要不小于3km。在這種情況下,傳輸電纜的直流電阻對傳輸距離影響非常大,因為這個直流電阻會和終端匹配電阻分壓。

如圖11-1所示,1號節(jié)點與2號節(jié)點相隔5km,使用的傳輸電纜直流電阻12.8歐姆/km,終端匹配電阻為124歐姆。1號節(jié)點發(fā)送的波形差分電壓幅值為2V,經(jīng)過5km傳輸電纜到2號節(jié)點時,差分電壓幅值大約為1V,信號衰減了一半!

需要指出的是,CAN總線上的差分電壓>0.9V才能被識別成顯性電平,現(xiàn)在2號節(jié)點只有1V差分電壓,其可靠性已經(jīng)變的較低。

為了保證可靠的數(shù)據(jù)通訊,一個有用的經(jīng)驗法則是:最末端節(jié)點差分電壓幅值不小于1.2V。

需要注意的是,圖中故意忽略了分布電容和分布電感的影響,因此傳輸?shù)牟ㄐ螞]有畸變。

6f66303a-d31c-11ec-bce3-dac502259ad0.jpg

圖11-1:傳輸電纜直流電阻分壓示意圖

對于雙絞線,假設(shè)其終端匹配電阻與電纜特性阻抗相同,則截面積與最大通訊距離可參考表11-1:

6f959d7a-d31c-11ec-bce3-dac502259ad0.png

表11-1:截面積與最大通訊距離關(guān)系

為了把電纜直流電阻引起的電壓衰減降到最小,較大的終端電阻值(150~300歐姆)有助于增加總線長度。比如,使用截面積為1.5 mm2的雙絞線電纜,電纜特性阻抗為120歐姆。傳輸波特率為5kpbs的數(shù)據(jù)時,使用120歐姆的匹配電阻最遠(yuǎn)可以傳輸5km,但使用300歐姆的匹配電阻則可以傳輸7km!

12、波特率、終端匹配電阻與通訊距離

上文第11節(jié)講述了傳輸線截面積與通訊距離的關(guān)系,本小節(jié)將保持傳輸線截面積不變,查看其它參數(shù)對通訊距離的影響。以截面積為1.5 mm2屏蔽雙絞線為例,其波特率、終端匹配電阻與通訊距離的關(guān)系如圖12-1所示。

其中,當(dāng)波特率較高,通訊距離有限。比如1Mbps,信號隔離后的CAN通訊距離大約為25~30米(大部分的實際項目中都會對CAN通訊模塊電氣隔離,隔離器件會降低通訊距離)。波特率較低并且將終端匹配電阻增大,可遠(yuǎn)距離通訊。比如5kbps、終端匹配電阻為390歐姆時,通訊距離可達(dá)10km!

6fc8b624-d31c-11ec-bce3-dac502259ad0.jpg

圖12-1:波特率、終端匹配電阻和通訊距離關(guān)系圖

13、信號延遲與通訊距離

高波特率情況下,制約CAN通訊距離的,是信號延遲。信號經(jīng)過隔離光耦、傳輸電纜、ESD器件時,都會引起信號延遲。如果CAN的重同步也不足以彌補(bǔ)這個延遲,就會導(dǎo)致采樣錯誤,最終CRC校驗錯誤。

圖12-1給出了截面積為1.5mm2傳輸電纜,在不同波特率和終端匹配電阻下的最大通訊距離。其中當(dāng)波特率為1Mbps時,通訊距離大約為30米。30米的通訊電纜,其傳輸損耗可以忽略不計,此時影響通訊距離的主要是信號延遲。

通常,傳輸電纜延時為5ns/m、高速光耦延時可達(dá)25ns、磁耦合隔離器件延遲3~5ns。在CAN通訊系統(tǒng)中,一個優(yōu)良的延遲標(biāo)準(zhǔn)是:

70190c46-d31c-11ec-bce3-dac502259ad0.png

其中,tl_MAX為最大延遲時間,tBIT為位時間。

以1Mbps為例,其位時間為1us,則tl_MAX < 0.245 × tBIT = 0.245 × 1us = 245ns。信號在1.5mm2傳輸電纜上傳輸49米就能達(dá)到這個延遲時間。另外,再加上信號上升/下降沿時間以及隔離器件、ESD器件、PCB走線延時,實際項目中,1Mbps波特率在1.5mm2傳輸電纜上只能傳輸30米。

這也是為什么RS485波特率可以達(dá)到10Mbps甚至50Mbps,而CAN標(biāo)準(zhǔn)最大速率只有1Mbps的原因。

表13-1給出了判定延遲的參考標(biāo)準(zhǔn),在實際項目中,推薦信號延遲處于良好一欄標(biāo)準(zhǔn)。

7035978a-d31c-11ec-bce3-dac502259ad0.png

表13-1:最大延遲參考標(biāo)準(zhǔn)

14、節(jié)點最小間距

CAN總線是分布式參數(shù)電路,其電氣特性和響應(yīng)主要由沿物理介質(zhì)分布的電感和電容所決定。這里物理介質(zhì)包括連接電纜、連接器、終端和沿總線掛接的CAN設(shè)備。

空載情況下,傳輸電纜的特性阻抗近似為Z=√(L/C),其中L為電纜單位長度感抗,C為電纜單位長度電容。隨著負(fù)載的增加,傳輸線上的電容增加(負(fù)載電容、負(fù)載與總線連接線電容),傳輸電纜特性阻抗相比空載情況下變小。如果負(fù)載比較集中,則負(fù)載區(qū)傳輸電纜特性阻抗和空閑區(qū)電纜特性阻抗相差較大,從而會引起阻抗不匹配。如圖14-1所示。

70746758-d31c-11ec-bce3-dac502259ad0.png

圖14-1:負(fù)載不均衡的CAN總線原理示意圖

CAN總線阻抗不匹配會產(chǎn)生信號反射,雪上加霜的是CAN的仲裁機(jī)制:在仲裁期間,兩個或更多個節(jié)點可能同時發(fā)送多個顯性位。

如圖14-1所示,當(dāng)開關(guān)S1在t=0時刻從顯性狀態(tài)切換到隱性狀態(tài),CAN驅(qū)動器差分輸出電壓為Vs,總線上的差分信號會由顯性狀態(tài)(Vs)變成穩(wěn)定的隱性狀態(tài)(0V)。這個信號波形會沿著總線向下傳播,到達(dá)總線的負(fù)載區(qū)時,阻抗不匹配引起的反射電壓將返回到源端。

負(fù)載與負(fù)載之間的最小安全距離d是設(shè)備集總負(fù)載電容CL和電纜的單位長度分布電容C的函數(shù),定義如下:

708e7026-d31c-11ec-bce3-dac502259ad0.png

設(shè)備集總負(fù)載電容CL包括CAN收發(fā)器引腳、連接器、隔離器件、保護(hù)器件、印制電路板走線以及其它物理連線的電容總和。

3.3V的CAN收發(fā)器一般能達(dá)到16pF電容,具體可以參考收發(fā)器數(shù)據(jù)手冊;印制板走線一般0.5pF~0.8pF/cm,這取決于電路板的材質(zhì)和結(jié)構(gòu);連接器和保護(hù)裝置(比如ESD器件)的電容值可能范圍會很大,具體要參考設(shè)備數(shù)據(jù)手冊;非屏蔽雙絞線介質(zhì)的分布電容大約在40pF/m~70pF/m。

圖14-2給出了更明了的圖表顯示:

70ab01b4-d31c-11ec-bce3-dac502259ad0.jpg

圖14-2:最小CAN設(shè)備間距

15、信號位采樣點位置

信號位采樣點是指CAN節(jié)點識別一個電平邏輯的位置。CAN標(biāo)準(zhǔn)把總線上的每一位都細(xì)分為不同的階段,如圖15-1所示。

在圖中可以看到,每個位被分為同步段、傳播段、相位緩沖段1和相位緩沖段2四個連續(xù)部分。其中,采樣點位于相位緩沖段1之后,同步段、傳播段、相位緩沖段1和相位緩沖段2的持續(xù)時間都是可以編程的,因此采樣點位置也是間接可編程的。

70c2ce34-d31c-11ec-bce3-dac502259ad0.png

圖15-1:每一個數(shù)據(jù)位的分段示意圖

一般CAN節(jié)點是每個位采樣一次(也可以采樣3次,多用于低速場合),采樣點位置都在一個位的50%以后的區(qū)域,這是為了讓信號電平趨于穩(wěn)定。采樣點越靠后,波形越穩(wěn)定。但也不是越靠后越好,采樣點位置超過95%時,因為傳輸過程中的位偏差,可能會引起錯誤。

CIA推薦采樣點為一個位時間的87.5%處,在實際項目中,一般設(shè)置為70%~90%,大部分汽車廠商規(guī)定采樣點為70~80%。

采樣點略靠后,比如80~90%,有利于遠(yuǎn)距離傳輸。提高節(jié)點波特率寄存器中的同步跳轉(zhuǎn)寬度SJW值(加大到3個單位時間),可以加大位寬度和采樣點的容忍度。

16、波特率偏差

由于受到晶振影響,CAN通訊波特率實際值與理論值會有偏差。如果兩個節(jié)點之間波特率偏差較大,容易造成誤碼率增大或通訊失敗等問題。

CAN標(biāo)準(zhǔn)規(guī)定,設(shè)定的理論波特率與實際波特率偏差不得超過±1%;節(jié)點需要容忍的波特率偏差不得小于±3%。

17、節(jié)點容抗

在CAN通訊電路設(shè)計過程中,節(jié)點容抗是容易被忽略的。節(jié)點容抗包括收發(fā)器引腳電容、PCB走線電容、ESD器件電容以及其它連線電容。

CAN標(biāo)準(zhǔn)對節(jié)點容抗有嚴(yán)格定義,容抗影響上升沿下降沿斜率,節(jié)點容抗增大,上升沿和下降沿會變緩,導(dǎo)致位時間畸變,誤碼率增加。上升沿和下降沿變緩會使得信號延遲變大,在高波特率下,影響信號傳輸質(zhì)量和通訊距離。

節(jié)點容抗不易測量,需要專門儀器。在電路設(shè)計時,要對結(jié)合數(shù)據(jù)手冊中給出的典型值,對CAN接口電路使用的器件總電容值進(jìn)行估算。對于高波特率情況下,單節(jié)點電容推薦<100pF,多節(jié)點電容推薦值見表17-1所示。低波特率應(yīng)用可以放寬要求。

70d21ca4-d31c-11ec-bce3-dac502259ad0.png

表17-1:單節(jié)點電容最大值

18、節(jié)點數(shù)量

可以連接到網(wǎng)絡(luò)上的節(jié)點數(shù)量由收發(fā)器可以驅(qū)動的最小負(fù)載阻抗來決定。最大節(jié)點數(shù)量由下面的公式給出(考慮最壞情況):

7101105e-d31c-11ec-bce3-dac502259ad0.png

其中,Rdiff_min為收發(fā)器差動輸入阻抗最小值,RL_min為收發(fā)器可驅(qū)動的負(fù)載電阻最小值,RT_min為終端匹配電阻最小值。

在上式中,收發(fā)器差動輸入阻抗最小值(Rdiff_min)和收發(fā)器可驅(qū)動的負(fù)載阻抗最小值(RL_min)由收發(fā)器芯片決定,終端匹配電阻最小值(RT_min)由傳輸電纜特性阻抗以及具體應(yīng)用決定。

以本公司使用的PCA82C251收發(fā)器為例,其收發(fā)器差動輸入阻抗最小值Rdiff_min = 20K歐姆,收發(fā)器可驅(qū)動的負(fù)載阻抗最小值RL_min = 45歐姆,假設(shè)終端匹配電阻最小值RT_min = 120歐姆,則最大節(jié)點數(shù)量為112個。

19、共模電壓范圍

共模電壓是指總線上的發(fā)送節(jié)點地和接收節(jié)點地之間的電勢差。過高的共模電壓會對系統(tǒng)造成影響,可能造成間歇重啟、死鎖、誤碼率增高甚至損害設(shè)備。在遠(yuǎn)距離通訊系統(tǒng)中,共模干擾的問題會更加突出,因為隨著通訊線距離的增加,地環(huán)路會拾取更多的噪聲,使得共模電壓增大。

目前的CAN收發(fā)器都可以容忍一定的共模電壓,ISO 11898標(biāo)準(zhǔn)規(guī)定,CAN收發(fā)器必須能容忍-2V~7V的共模電壓。對于長達(dá)數(shù)千米的CAN通訊系統(tǒng)來說,標(biāo)準(zhǔn)規(guī)定的共模電壓容忍能力遠(yuǎn)遠(yuǎn)達(dá)不到實際要求。因此,電流隔離對于遠(yuǎn)距離數(shù)據(jù)傳輸系統(tǒng)來說仍是必須的。

20、總線短路保護(hù)和熱關(guān)斷保護(hù)

總線短路保護(hù)是指總線與電源或地短路后,CAN收發(fā)器不會損壞,短路故障解除后,CAN收發(fā)器能繼續(xù)工作。這個特性可以在總線極性反接、電纜絕緣層失效、意外短路到高壓源時對收發(fā)器提供保護(hù)。

熱關(guān)斷電路用于幫助CAN收發(fā)器防御因短路產(chǎn)生破壞性電流和高溫。一旦激活熱關(guān)斷電路,設(shè)備會進(jìn)入關(guān)斷模式。當(dāng)設(shè)備冷卻到正常操作溫度時,設(shè)備自動恢復(fù)運(yùn)行。

本公司使用的PCA82C251收發(fā)器具有短路保護(hù)和熱關(guān)斷保護(hù)。短路保護(hù)允許總線與24V電源短接。

21、電流隔離

遠(yuǎn)距離數(shù)據(jù)傳輸可能會有較大的地電勢差、地環(huán)流等問題,會在CAN總線上形成高共模電壓。如果共模電壓超出CAN收發(fā)器容忍的最大限度,數(shù)據(jù)鏈路就會不正常。

解決這些問題的一個方法是使用電流隔離:隔離變壓器為系統(tǒng)提供電源,光耦或數(shù)字隔離器件提供數(shù)據(jù)隔離。電流隔離可以去除地環(huán)流,抑制噪聲電壓。采用電流隔離的電路如圖21-1所示,本公司CAN接口電路也采用了電流隔離處理。

712d345e-d31c-11ec-bce3-dac502259ad0.jpg

圖21-1:遠(yuǎn)距離通訊電流隔離電路示意圖

22、CAN接口電路與RS485接口電路

CAN總線和RS485總線都是采用差分信號傳輸數(shù)據(jù),它們在總線拓?fù)?、終端匹配、信號衰減、隔離與接地、波特率與通訊距離關(guān)系等方面都是相似的。但是CAN有自己的一些特性,在接口設(shè)計中,不能照抄RS485接口電路。

CAN總線對信號延遲敏感,因此信號隔離必須使用高速光耦或者磁耦合器件,以減少信號延遲。公司大量使用的TLP521光耦因為延遲時間過大(微秒級)不可以用于CAN接口電路。

CAN總線對電容敏感,在設(shè)計CAN接口電路時,需要使用CAN專用共模電感、專業(yè)ESD器件;需要根據(jù)應(yīng)用的最大波特率和通訊距離,來決定是否在CAN總線上增加濾波電容以及濾波電容的大小。

原文標(biāo)題:新手必看!嵌入式CAN總線入門篇(底層細(xì)節(jié))

文章出處:【微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 控制器
    +關(guān)注

    關(guān)注

    112

    文章

    16332

    瀏覽量

    177803
  • CAN總線
    +關(guān)注

    關(guān)注

    145

    文章

    1946

    瀏覽量

    130726
  • CAN標(biāo)準(zhǔn)
    +關(guān)注

    關(guān)注

    0

    文章

    4

    瀏覽量

    7470

原文標(biāo)題:新手必看!嵌入式CAN總線入門篇(底層細(xì)節(jié))

文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    CAN總線協(xié)議知識科普

    本文說的CAN即是一種總線,也是一種協(xié)議。因此,我們常聽見CAN總線,也常聽見CAN協(xié)議。
    發(fā)表于 09-15 12:47 ?3294次閱讀

    CAN總線入門知識

    最近在調(diào)試一個CAN總線的設(shè)備遇到一些問題,簡單總結(jié)一下。本文會對CAN總線進(jìn)行簡單介紹,CAN的硬件鏈路層,協(xié)議層,以及調(diào)試的一些心得。
    發(fā)表于 09-15 15:32 ?2100次閱讀

    CAN總線入門知識

    CAN總線由德國BOSCH公司開發(fā),最高速率可達(dá)到1Mbps。CAN的容錯能力特別強(qiáng),CAN控制器內(nèi)建了強(qiáng)大的檢錯和處理機(jī)制。另外不同于傳統(tǒng)的網(wǎng)絡(luò)(比如USB或者以太網(wǎng)),
    發(fā)表于 01-13 09:25 ?962次閱讀

    科普一下CAN總線的基礎(chǔ)知識

    CAN總線是一種常用的總線,對于剛開始接觸CAN總線的,面對著各式各樣的資料,可能不知道從何看起,今天
    發(fā)表于 05-16 09:49 ?3251次閱讀
    <b class='flag-5'>科普</b>一下<b class='flag-5'>CAN</b><b class='flag-5'>總線</b>的基礎(chǔ)<b class='flag-5'>知識</b>

    CAN總線入門教程

    本資料是面向CAN 總線初學(xué)者的CAN 入門書。對CAN 是什么、CAN 的特征、標(biāo)準(zhǔn)規(guī)格下的位
    發(fā)表于 07-19 21:17 ?2138次下載

    CAN入門書_CAN總線初學(xué)者入門

    本資料是面向 CAN 總線初學(xué)者的 CAN 入門書。對 CAN 是什么、CAN 的特征、標(biāo)準(zhǔn)規(guī)格
    發(fā)表于 12-17 17:18 ?0次下載

    CAN總線快速入門

    CAN總線快速入門
    發(fā)表于 12-13 17:15 ?22次下載

    CAN總線協(xié)議是什么?CAN總線協(xié)議有哪些?CAN總線協(xié)議知識分析

    屬于軟件協(xié)議。本篇文章先概述一下CAN網(wǎng)絡(luò),讓大家對CAN總線協(xié)議有一個全局的概念,再到底層的CAN總線協(xié)議
    的頭像 發(fā)表于 10-03 19:53 ?7.5w次閱讀
    <b class='flag-5'>CAN</b><b class='flag-5'>總線</b>協(xié)議是什么?<b class='flag-5'>CAN</b><b class='flag-5'>總線</b>協(xié)議有哪些?<b class='flag-5'>CAN</b><b class='flag-5'>總線</b>協(xié)議<b class='flag-5'>知識</b>分析

    CAN總線教程之CAN總線快速入門資料免費(fèi)下載

    本文檔額度主要內(nèi)容詳細(xì)介紹的是CAN總線教程之CAN總線快速入門資料免費(fèi)下載主要內(nèi)容包括了:CAN
    發(fā)表于 12-07 17:20 ?214次下載

    CAN總線入門書》pdf

    CAN總線入門書》pdf
    發(fā)表于 01-24 17:03 ?411次下載

    CAN總線的基礎(chǔ)知識詳細(xì)講解

    CAN總線的基礎(chǔ)知識詳細(xì)講解。
    發(fā)表于 04-02 17:44 ?14次下載

    CAN總線入門資料分享

      本資料是面向CAN總線初學(xué)者的CAN入門書。對CAN是什么、CAN的特征、標(biāo)準(zhǔn)規(guī)格下的位置分
    發(fā)表于 04-02 16:35 ?27次下載

    關(guān)于CAN總線錯誤的相關(guān)知識

    在本系列文章中,我們將為您詳細(xì)介紹CAN總線錯誤的相關(guān)知識,包括CAN總線錯誤的基礎(chǔ)概念、CAN
    的頭像 發(fā)表于 05-27 17:56 ?3096次閱讀

    CAN總線基礎(chǔ)知識

    CAN總線是一種常用的總線,對于剛開始接觸CAN總線的,面對著各式各樣的資料,可能不知道從何看起,今天
    的頭像 發(fā)表于 02-09 15:43 ?3989次閱讀

    詳解常用的CAN總線(上):報文幀

    CAN總線是一種常用的總線,對于剛開始接觸CAN總線的,面對著各式各樣的資料,可能不知道從何看起,今天
    發(fā)表于 06-19 17:20 ?2739次閱讀
    詳解常用的<b class='flag-5'>CAN</b><b class='flag-5'>總線</b>(上):報文幀
    RM新时代网站-首页