如何通過DBC文件看懂CAN通信矩陣
實(shí)現(xiàn)汽車CAN通信開發(fā),必不可少要用到DBC文件和CAN通信矩陣。
CAN通信矩陣是指用于描述 CAN 網(wǎng)絡(luò)中各個節(jié)點(diǎn)之間通信關(guān)系的表格或矩陣。它通常記錄了每個節(jié)點(diǎn)能夠發(fā)送和接收的消息標(biāo)識符(ID)以及與其他節(jié)點(diǎn)之間的通信權(quán)限。
通信矩陣在 CAN 網(wǎng)絡(luò)中具有重要作用:
通信權(quán)限管理:通過通信矩陣可以清晰地了解每個節(jié)點(diǎn)之間的通信權(quán)限,包括哪些節(jié)點(diǎn)可以向哪些節(jié)點(diǎn)發(fā)送消息,以及哪些節(jié)點(diǎn)可以接收來自哪些節(jié)點(diǎn)的消息。這有助于確保網(wǎng)絡(luò)中的數(shù)據(jù)傳輸是有序和安全的。
網(wǎng)絡(luò)配置和管理:通信矩陣可以用于配置和管理 CAN 網(wǎng)絡(luò)的通信規(guī)則。通過調(diào)整矩陣中的條目,可以靈活地修改節(jié)點(diǎn)之間的通信關(guān)系,以滿足不同的通信需求和網(wǎng)絡(luò)拓?fù)浣Y(jié)構(gòu)。
故障診斷:在出現(xiàn)通信故障或異常情況時,通信矩陣可以作為診斷工具,幫助定位問題。通過比較實(shí)際通信情況和預(yù)期的通信矩陣,可以找出通信錯誤的根本原因,并進(jìn)行相應(yīng)的修復(fù)。
DBC(DataBase Container)文件是用于描述CAN總線網(wǎng)絡(luò)中消息和信號的一種格式,是一種數(shù)據(jù)庫文件,通常由CAN網(wǎng)絡(luò)中的通信和信號定義組成,可用于配置和管理CAN總線上的通信協(xié)議。
下載CANdb++軟件可以打開DBC文件。
鏈接:https://www.vector.com/int/en/products/products-a-z/software/candb/#c104632
以下是一個DBC文件示例:
以下是 DBC 文件的主要組成部分:
消息定義:描述了在CAN總線上發(fā)送和接收的消息,包括消息的ID、周期、發(fā)送節(jié)點(diǎn)等信息。每個消息定義通常包含了一條或多條信號定義。
控制器名稱 :控制器ECU名稱
報文名稱 :每個報文消息規(guī)定的名字
報文ID :唯一標(biāo)識報文的ID號,一般規(guī)定ID范圍為0x00 - 0x7FF
報文發(fā)送類型 :分為周期報文,事件報文,周期事件報文,使能周期發(fā)送
報文周期 :周期報文的發(fā)送周期值
長度 :報文字節(jié)長度
信號定義:描述了消息中傳輸?shù)臄?shù)據(jù),如信號的名稱、起始位、長度、單位、因子、偏移量等。信號定義用于將物理數(shù)據(jù)映射到CAN消息的數(shù)據(jù)域中。
信號名稱:信號英文名稱,一般命名:ECUName_MessgeName,ECUName為發(fā)送節(jié)點(diǎn)的名字簡寫,MessgeName為具體的報文名稱
信號描述:信號中文名稱描述
信號類型:信號的數(shù)據(jù)類型,比如布爾類型Boolean,無符號 Unsigned,有符號Signed
信號長度:信號的長度,即占多少個bit 位的長度
字節(jié)次序 :規(guī)定信號的大小端位置和布局layout,有Motorola格式和Intel格式
起始字節(jié)位置:起始位所在的字節(jié)序號
起始位位置:信號起始位所在的bit位置編號
精度/偏移量:描述信號值如何轉(zhuǎn)變成信號物理值,計算公式:真實(shí)物理值 = 信號值 * 精度 + 偏移量
Range范圍 :信號數(shù)值的范圍
信號單位 :信號數(shù)值的單位,比如可為:m ,km
信號值描述:信號數(shù)值含義
初始值:信號默認(rèn)的初始值
無效值 :信號無任何含義的無效值狀態(tài)
備注:信號備注內(nèi)容
打開DBC文件后,我們主要關(guān)注:Tx Messages和Rx Messages,這里面是CAN發(fā)送和接收的信息。
寫程序時候,最容易搞錯的就是起始位和信號長度,如果發(fā)送或者接收的信號沒有對齊,數(shù)據(jù)解析就會存在問題。
可以使用CANdb++軟件打開Layout,通過可視化的方式看清楚報文的字節(jié)排序,例如以下0X342報文的字節(jié)排序:
以一個8byte的報文為例,8byte即為64個bit位,會將每一個bit位編號為0 - 63,信號起始位數(shù)值即為起始位位置所在的編號值,信號長度表示從起始位開始,連續(xù)占用的bit位長度。
根據(jù)具體的布局安排,以及數(shù)據(jù)的大小端規(guī)定,DBC中CAN字節(jié)排序有兩種格式:Motorola格式和Intel格式。
Intel格式:也稱為小端序。在Intel格式中,數(shù)據(jù)的低位字節(jié)存儲在低地址,高位字節(jié)存儲在高地址。與Motorola格式相反,數(shù)據(jù)的最低有效字節(jié)存儲在地址最低的位置,而最高有效字節(jié)存儲在地址最高的位置。大多數(shù)個人計算機(jī)和x86架構(gòu)的處理器都使用小端序。
Intel格式規(guī)定的布局安排規(guī)定示例如下,起始位位置規(guī)定了位于64bit(編號0-63)具體的那個位置,如下示例起始位置為12;信號長度規(guī)定了從起始位編號位置開始,連續(xù)占用的bit位長度,如下示例信號長度為12。
Motorola格式:也稱為大端序。在Motorola格式中,數(shù)據(jù)的高位字節(jié)存儲在低地址,低位字節(jié)存儲在高地址。這意味著數(shù)據(jù)的最高有效字節(jié)存儲在地址最低的位置,而最低有效字節(jié)存儲在地址最高的位置。這種格式通常用于一些嵌入式系統(tǒng)和網(wǎng)絡(luò)協(xié)議中。起始位表示信號的大小端規(guī)定不同,又可以分成 Motorola MSB格式 和 Motorola LSB格式。
Motorola MSB格式布局示例如下,起始位位置表示的是大端位置。
Motorola LSB格式布局示例如下,起始位位置表示的是小端位置。
使用Intel格式設(shè)置續(xù)航里程998KM, 它的信號值在整條報文中為3E、60、00、00、00、00、00、00,在DBC文件中設(shè)置如下:
信號以低字節(jié)低位起始,此處占了12bit,以第一字節(jié)的低bit 0位算起,計12個bit總長度,信號是非連續(xù)的(發(fā)送的字節(jié)序體現(xiàn)出的信號值非連續(xù),但是bit位是由低到高連續(xù)的)。
使用Motorola格式設(shè)置續(xù)航里程998KM, 它的信號值在整條報文中為3E、60、00、00、00、00、00、00,在DBC文件中設(shè)置如下:
信號以高字節(jié)低位起始,此處占了12bit,以第二字節(jié)的低bit 12位算起,計12個bit總長度,信號是連續(xù)的(此處連續(xù)針對低字節(jié)在前的字節(jié)發(fā)送序,參看LSB與MSB)。
報文發(fā)送類型可分為:周期,事件,周期事件,使能周期。
周期 :報文按照固定的周期發(fā)送,例如周期為100ms,則每隔100ms發(fā)送一幀報文。
事件 :當(dāng)事件觸發(fā)后,發(fā)送出數(shù)據(jù)報文,一般規(guī)定連續(xù)發(fā)送3幀,間隔20ms。
周期事件 :周期和事件的結(jié)合,報文以周期時間發(fā)送每幀報文,當(dāng)某個事件信號觸發(fā)后,按照事件的形式立馬發(fā)送出來,之后恢復(fù)到固定周期發(fā)送。
使能周期 :報文以周期時間發(fā)送每幀報文,當(dāng)某個事件觸發(fā)后并且達(dá)到下一個發(fā)送周期時,這個時刻按照事件發(fā)送,一般規(guī)定連續(xù)發(fā)送3幀,間隔20ms。
周期事件報文中的事件信號,在實(shí)際應(yīng)用中,有事件保持和事件不保持兩種。
事件保持 :觸發(fā)信號發(fā)送后,信號一直保持之前的狀態(tài)。
事件不保持 :觸發(fā)信號發(fā)送后,信號恢復(fù)到默認(rèn)值狀態(tài)。
有些報文規(guī)定了兩個特殊的信號:RollingCounter信號 和 CheckSum信號,為CAN報文添加安全加密屬性,保護(hù)CAN報文信號數(shù)據(jù)。
RollingCounter信號 :滾動計數(shù)值,例如示例信號從0 - 15,循環(huán)滾動,每發(fā)送一幀報文,該信號值累加1。
CheckSum信號 :檢驗(yàn)值,基于某種校驗(yàn)算法,將報文數(shù)據(jù)進(jìn)行加密處理,加密算法一般使用的是CRC算法。
參考資料:
1、https://www.cnblogs.com/yao-zhang/p/10220665.html
2、https://blog.csdn.net/PlutoZuo/article/details/133043032
3、https://blog.csdn.net/CJohn1994/article/details/124105213
4、https://blog.csdn.net/wteruiycbqqvwt/article/details/102929488
5、https://mp.weixin.qq.com/s/5x0-JqTKx6Uv_3yz9p4K0g
*博客內(nèi)容為網(wǎng)友個人發(fā)布,僅代表博主個人觀點(diǎn),如有侵權(quán)請聯(lián)系工作人員刪除。