CAN 通信備忘(基本概念)

背景介紹

CAN 是控制器局域網(wǎng)絡(luò)(Controller Area Network,CAN)的簡稱浓冒,是一種能夠?qū)崿F(xiàn)分布式實時控制的串行通信網(wǎng)絡(luò)

CAN 的發(fā)展歷史節(jié)點(diǎn):

  • 1983年笋颤,BOSCH開始著手開發(fā)CAN總線;
  • 1986 年,在SAE會議上,CAN總線正式發(fā)布
  • 1987 年诡必,Intel和Philips 推出第一款CAN控制器芯片
  • 1991年脊框,奔馳 500E 是世界上第一款基于CAN總線系統(tǒng)的量產(chǎn)車型
  • 1991年,Bosch發(fā)布CAN 2.0標(biāo)準(zhǔn)单雾,分 CAN 2.0A (11位標(biāo)識符)和 CAN 2.0B (29位標(biāo)識符)赚哗;
  • 1991年, ISO發(fā)布CAN總線標(biāo)準(zhǔn)(ISO 11898)硅堆,隨后該標(biāo)準(zhǔn)主要有三部分:
    • ISO 11898-1:數(shù)據(jù)鏈路層協(xié)議
    • ISO 11898-2:高速CAN總線物理層協(xié)議屿储,通信速度為 125kbps-1Mbps。
    • ISO 11898-3:(整合了ISO11519)低速CAN總線物理層協(xié)議硬萍,通信速度為 125kbps 以下扩所。
  • 2011 年,開始CAN FD協(xié)議的開發(fā)朴乖。
  • 2015年祖屏,ISO11898-1進(jìn)行了修訂,將CAN FD加入其中买羞。

CAN 總線協(xié)議介紹

CAN總線協(xié)議有CAN1.0袁勺、CAN2.0(CAN2.0A,CAN2.0B),其中CAN2.0對比1.0,主要是增加了CAN的擴(kuò)展幀定義⌒笃眨現(xiàn)在我們所說的CAN通常都是指CAN2.0標(biāo)準(zhǔn)的總線
CAN-FD協(xié)議在原有的CAN協(xié)議基礎(chǔ)上期丰,增加了可變波特率、擴(kuò)大數(shù)據(jù)場吃挑、提升校驗算法安全性等改進(jìn)钝荡。

本文主要講述CAN的數(shù)據(jù)通信

CAN 的物理通信形式

通過兩條通信線(雙絞線)產(chǎn)生的電壓差傳輸數(shù)據(jù),一個CAN網(wǎng)絡(luò)里的所有節(jié)點(diǎn)都掛在這兩條通信線上舶衬,使用差分信號半雙工通信埠通。


1696754073524.jpg

CAN 使用稱為CANH/CANL 的通信線程執(zhí)行傳輸和接收。電位差較小的電信號稱為隱性(Recessive)信號逛犹,其邏輯值為1 端辱。電位差較大的電信號稱為顯性(Dominant)信號,其邏輯值0.如果通信總線上發(fā)生顯性和隱性沖突虽画,則顯性優(yōu)先舞蔽。總線空閑時保持隱性码撰。

CAN總線的物理層邏輯電平渗柿,分為高速ISO11898標(biāo)準(zhǔn)(125kbps ~ 1Mbps)和低速ISO11519標(biāo)準(zhǔn)(10kbps ~ 125kbps);
低速的物理電平如圖

image.png

而我們現(xiàn)在通常使用的CAN2.0脖岛,都是使用高速CAN標(biāo)準(zhǔn)做祝,其物理層電平如圖:

image.png

對于高速CAN,總結(jié)一下砾省,也就是:

  • CAN_H - CAN_L < 0.5V 時候為隱性的,邏輯信號表現(xiàn)為 “邏輯1”- 高電平
  • CAN_H - CAN_L > 0.9V 時候為顯性的混槐,邏輯信號表現(xiàn)為 “邏輯0”-低電平
    關(guān)于CAN 通信的電平傳輸编兄,一個重要概念就是:
    CAN 總線在電平 傳輸上,具有判斷邏輯声登,優(yōu)先級為:顯性(低電平)> 隱性(高電平)
    在理解CAN總線傳輸過程中狠鸳,要清楚這一規(guī)則在傳輸時的靈活運(yùn)用,及便理解各種幀形式的優(yōu)先級

CAN的數(shù)據(jù)格式

CAN的數(shù)據(jù)定義了有5種幀類型

幀用途
數(shù)據(jù)幀 用于節(jié)點(diǎn)向外傳送數(shù)據(jù)
遙控幀 用于向運(yùn)端節(jié)點(diǎn)請求數(shù)據(jù)
錯誤幀 用于向遠(yuǎn)端節(jié)點(diǎn)通知校驗錯誤悯嗓,請求重新發(fā)送上一個數(shù)據(jù)
過載幀 用于通知遠(yuǎn)端節(jié)點(diǎn):本節(jié)點(diǎn)尚未做好接收準(zhǔn)備
幀間隔 用于將數(shù)據(jù)幀及遙控幀與前面的幀分離開來

其中件舵,遙控幀也常被稱為遠(yuǎn)程幀。CAN的應(yīng)用開發(fā)者只能使用“數(shù)據(jù)幀”和“遙控幀”脯厨,其他的3種幀類型是由CAN的底層固件自動幫我們在特定場景下進(jìn)行收發(fā)铅祸,開發(fā)者無需擔(dān)心也無法直接參與控制。

所以合武,本文把“數(shù)據(jù)幀”和“遙控幀”與其他的3種幀類型分別進(jìn)行介紹临梗。

數(shù)據(jù)幀與遙控幀

關(guān)于數(shù)據(jù)幀,也就是我們最常用的幀類型稼跳,用于數(shù)據(jù)的收發(fā)盟庞;也是CAN通信里最主要的內(nèi)容。

而遙控幀汤善,只是CAN網(wǎng)絡(luò)里的某一節(jié)點(diǎn)發(fā)送一個遙控幀請求其他的節(jié)點(diǎn)反饋數(shù)據(jù)給自己什猖,關(guān)于遙控幀其實在實際使用中,顯得很雞肋红淡,原因有:

1不狮、CAN通信作為一種半雙工通信形式,在實際使用中的應(yīng)用層通信協(xié)議往往會定義好數(shù)據(jù)的應(yīng)答機(jī)制與時間間隔在旱,節(jié)點(diǎn)與節(jié)點(diǎn)之間只要按照協(xié)議規(guī)定進(jìn)行數(shù)據(jù)的收發(fā)即可摇零。

2、遙控幀與數(shù)據(jù)幀對比颈渊,其實就是一條數(shù)據(jù)長度為0的數(shù)據(jù)幀而已,只是在幀格式里的仲裁段RTR位為隱性终佛。那么俊嗽,似乎有數(shù)據(jù)幀就足夠了。

3铃彰、遙控幀的概念定義只是一個預(yù)定義绍豁,所謂的請求其他節(jié)點(diǎn)給自己發(fā)送數(shù)據(jù)并不是強(qiáng)制的,與數(shù)據(jù)幀一樣完全根據(jù)應(yīng)用層協(xié)議來規(guī)定其具體的使用牙捉。

綜上所述竹揍,CAN里定義的遙控幀實際作用不大敬飒,而且可以用數(shù)據(jù)幀配合應(yīng)用協(xié)議的定義,進(jìn)行替代芬位。所以在后來的CAN-FD中已經(jīng)取消了遙控幀的定義了无拗。

數(shù)據(jù)幀 與 遙控幀的數(shù)據(jù)格式

不管理Classic CAN Frame 還是CANFD Frame ,其幀結(jié)構(gòu)都由以下7個段組成:
-- SOF 幀起始
-- arbitration field 仲裁段
-- control field 控制段
-- data field 數(shù)據(jù)段
-- CRC field CRC段
-- ACK field ACK段
-- EOF 幀結(jié)束

依次排序為

幀起始 仲裁段 控制段 數(shù)據(jù)段 CRC段 ACK段 結(jié)束段

這7個段昧碉,每個段里又都 有自已的格式細(xì)分英染,有兩種格式:標(biāo)準(zhǔn)備格式和擴(kuò)展格展格式。


image.png

CAN的應(yīng)用開發(fā)者只使用其中的仲裁段被饿、控制段和數(shù)據(jù)段四康。其他部分都由CAN底層固件自動封裝!

由上圖可以看到狭握,對于仲裁段和控制段在標(biāo)準(zhǔn)幀與擴(kuò)展幀里有不同的定義闪金,其他段一致。

幀起始與幀結(jié)束

  • SOF 幀起始:由一個顯性位(低電平)組成论颅,發(fā)送節(jié)點(diǎn)發(fā)送幀起始哎垦,其他節(jié)點(diǎn)同步于幀起始
  • EOF幀結(jié)束:由7個隱形位(高電平)組成
image.png

仲裁段內(nèi)容

  • RTR位:用于指于這包數(shù)據(jù)是遙控幀還是數(shù)據(jù)幀,數(shù)據(jù)幀的RTR 位為顯性電平(值為0)嗅辣,遠(yuǎn)程幀為隱性電平(值為1)

所以幀格式和幀ID相同的懷脫 下撼泛,數(shù)據(jù)幀優(yōu)先于遠(yuǎn)程幀

  • IDE : 用于指于這包數(shù)據(jù)是標(biāo)準(zhǔn)幀還是擴(kuò)展幀,標(biāo)準(zhǔn)幀的IDE位為顯性電平(值為0)澡谭,擴(kuò)展幀的IDE位為隱性電平愿题。

對于前11位ID相同的標(biāo)準(zhǔn)幀和擴(kuò)展幀,標(biāo)準(zhǔn)幀優(yōu)先級比擴(kuò)展幀高

數(shù)據(jù)段

一個數(shù)據(jù)幀傳輸?shù)臄?shù)據(jù)量為0~8個字節(jié)蛙奖,遙控幀的數(shù)據(jù)長度固定為0


image.png

參考(引用)資料

CAN通信講解

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末潘酗,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子雁仲,更是在濱河造成了極大的恐慌仔夺,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,888評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件攒砖,死亡現(xiàn)場離奇詭異缸兔,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)吹艇,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,677評論 3 399
  • 文/潘曉璐 我一進(jìn)店門惰蜜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人受神,你說我怎么就攤上這事抛猖。” “怎么了?”我有些...
    開封第一講書人閱讀 168,386評論 0 360
  • 文/不壞的土叔 我叫張陵财著,是天一觀的道長联四。 經(jīng)常有香客問我,道長撑教,這世上最難降的妖魔是什么朝墩? 我笑而不...
    開封第一講書人閱讀 59,726評論 1 297
  • 正文 為了忘掉前任,我火速辦了婚禮驮履,結(jié)果婚禮上鱼辙,老公的妹妹穿的比我還像新娘。我一直安慰自己玫镐,他們只是感情好倒戏,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,729評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著恐似,像睡著了一般杜跷。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上矫夷,一...
    開封第一講書人閱讀 52,337評論 1 310
  • 那天葛闷,我揣著相機(jī)與錄音,去河邊找鬼双藕。 笑死淑趾,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的忧陪。 我是一名探鬼主播扣泊,決...
    沈念sama閱讀 40,902評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼嘶摊!你這毒婦竟也來了延蟹?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,807評論 0 276
  • 序言:老撾萬榮一對情侶失蹤叶堆,失蹤者是張志新(化名)和其女友劉穎阱飘,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體虱颗,經(jīng)...
    沈念sama閱讀 46,349評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡沥匈,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,439評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了忘渔。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片高帖。...
    茶點(diǎn)故事閱讀 40,567評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖辨萍,靈堂內(nèi)的尸體忽然破棺而出棋恼,到底是詐尸還是另有隱情,我是刑警寧澤锈玉,帶...
    沈念sama閱讀 36,242評論 5 350
  • 正文 年R本政府宣布爪飘,位于F島的核電站,受9級特大地震影響拉背,放射性物質(zhì)發(fā)生泄漏师崎。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,933評論 3 334
  • 文/蒙蒙 一椅棺、第九天 我趴在偏房一處隱蔽的房頂上張望犁罩。 院中可真熱鬧,春花似錦两疚、人聲如沸床估。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,420評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽丐巫。三九已至,卻和暖如春勺美,著一層夾襖步出監(jiān)牢的瞬間递胧,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,531評論 1 272
  • 我被黑心中介騙來泰國打工赡茸, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留缎脾,地道東北人。 一個月前我還...
    沈念sama閱讀 48,995評論 3 377
  • 正文 我出身青樓占卧,卻偏偏與公主長得像遗菠,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子屉栓,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,585評論 2 359

推薦閱讀更多精彩內(nèi)容

  • 摘要 CAN總線是為解決現(xiàn)代汽車中眾多的控制與測試儀器之間的數(shù)據(jù)交換而開發(fā)的一種串行數(shù)據(jù)通信協(xié)議域滥,它是一種多主總線...
    艾瑞敗類閱讀 444評論 0 1
  • 介紹 在汽車產(chǎn)業(yè)中纵柿,各種各樣的ECU被開發(fā)出來,來提高汽車的安全性启绰、舒適性昂儒、方便性,同時滿足對低公害委可、低成本的要求...
    有機(jī)會一起種地OT閱讀 4,663評論 1 4
  • 一渊跋、com口(轉(zhuǎn)) 1腊嗡、實物圖 2、介紹 COM口( cluster communication port)即串行...
    MakeSomeChange閱讀 3,994評論 0 0
  • 大家好啊拾酝,今天雨很大燕少,回來的比較早,有點(diǎn)時間蒿囤,總結(jié)一下近期學(xué)的CAN通訊的知識客们! 作為一個車輛畢業(yè)的大學(xué)生,這個東...
    那個混子閱讀 955評論 0 1
  • CAN簡介 CAN網(wǎng)絡(luò):是目前在汽車上廣泛應(yīng)用的高速網(wǎng)絡(luò)系統(tǒng)材诽,但還有比如CANFD和以太網(wǎng)更高效的網(wǎng)絡(luò)系統(tǒng)底挫。 在C...
    CHPanda閱讀 851評論 0 0