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

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

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

深入探討CAN節(jié)點錯誤管理機(jī)制

AGk5_ZLG_zhiyua ? 來源:ZLG致遠(yuǎn)電子 ? 作者: 研發(fā)部 ? 2021-10-20 09:49 ? 次閱讀

CAN節(jié)點的穩(wěn)定性、可靠性和安全性得益于其強(qiáng)大的錯誤管理機(jī)制。那么,CAN節(jié)點為什么能感知錯誤?又是如何響應(yīng)錯誤?您是否能清晰地想象出這一過程?本文將為大家詳細(xì)分析CAN節(jié)點錯誤管理的工作過程。

節(jié)點電路構(gòu)成

如圖1所示,MCU作為主控制器,完成CAN控制器和功能電路的控制。

6961e90e-30fb-11ec-82a8-dac502259ad0.jpg

圖1 CAN節(jié)點組成框圖

CAN控制器是工作于數(shù)據(jù)鏈路層的器件,集成了CAN規(guī)范中數(shù)據(jù)鏈路層的全部功能,其功能由軟件和硬件共同實現(xiàn),從設(shè)備供應(yīng)商買回來的CAN控制器已經(jīng)把相應(yīng)的邏輯固化在其硅片之中;

MCU是工作于應(yīng)用層的器件,其功能由軟件和硬件共同實現(xiàn),MCU運(yùn)行的程序可由設(shè)計者靈活設(shè)計,以實現(xiàn)CAN節(jié)點的特定功能;

CAN收發(fā)器工作于物理層,其功能完全由硬件實現(xiàn),其作用是將CAN控制器的邏輯電平轉(zhuǎn)化為CAN總線的模擬差分信號,以及把總線模擬差分信號轉(zhuǎn)換成CAN控制器的邏輯電平。

CAN節(jié)點的錯誤管理屬于CAN通信規(guī)范數(shù)據(jù)鏈路層的內(nèi)容,具體來說,錯誤管理是通過MCU和CAN控制器來實施的。可以說,CAN控制器是錯誤管理的基礎(chǔ)設(shè)施,我們可以從兩個方面理解其工作邏輯:一是如何感知錯誤,二是如何響應(yīng)錯誤。

注:

1、本文所說的CAN規(guī)范指的是德國BOSCH公司的《CAN Specification Version 2.0》。

節(jié)點如何感知錯誤?

如前文所述,節(jié)點對總線錯誤的識別是通過CAN控制器來完成的。CAN控制器輸出給收發(fā)器發(fā)送引腳TX的邏輯信號位會從收發(fā)器接收引腳RX接收,這使得CAN控制器可以在發(fā)送一個邏輯位期間同時監(jiān)測總線的實際電平值。CAN控制器檢測總線錯誤原理如圖2所示:

69fbdfc8-30fb-11ec-82a8-dac502259ad0.jpg

圖2 監(jiān)測總線錯誤原理圖

如圖2描述,CAN控制器監(jiān)測一個總線電平的電平值是在采樣點位置進(jìn)行的,判斷是否出現(xiàn)錯誤是在信息處理時間內(nèi)完成的。

綜上所述,CAN控制器對錯誤的識別可概括為:無論是作為發(fā)送器還是接收器,在采樣點位置成功監(jiān)測到當(dāng)前總線的實際電平值后,CAN控制器便按照CAN規(guī)范中描述的錯誤管理規(guī)則判斷是否出現(xiàn)錯誤。

CAN通信過程中的錯誤類型包括5種,分別是:位錯誤、填充錯誤、CRC錯誤、幀格式錯誤、應(yīng)答錯誤。接下來分別對5種錯誤的檢測識別過程進(jìn)行解析。

1、位錯誤

位錯誤是由作為發(fā)送器的節(jié)點在發(fā)送報文期間進(jìn)行檢測識別的。CAN控制器的程序邏輯發(fā)送的電平與監(jiān)測到總線的實際信號不一致即在此位期間檢測到位錯誤。

例外情況,在仲裁場或應(yīng)答間隙期間發(fā)送一“隱性”位卻監(jiān)視到一“顯性”位,以及當(dāng)發(fā)送器發(fā)送一個被動錯誤標(biāo)志但檢測到“顯性”位時,均也不被視為位錯誤,以實現(xiàn)特定的功能。

2、填充錯誤

在CAN幀的位場中,幀起始、仲裁場、控制場、數(shù)據(jù)場以及CRC序列,均通過位填充的方法編碼。無論何時,發(fā)送器只要檢測到這些位場對應(yīng)位流里有5個連續(xù)相同值的位,便自動在接著的下一位插入一個補(bǔ)碼位。CAN控制器在監(jiān)測總線電平值的同時對連續(xù)相同的位電平值會進(jìn)行計數(shù),如果在使用位填充法進(jìn)行編碼的信息中,出現(xiàn)了第6個連續(xù)相同的位電平值時,便檢測到一個填充錯誤。

3、CRC錯誤

CRC錯誤是由作為接收器的節(jié)點進(jìn)行檢測識別的。CRC序列共15位(不包含填充位),其內(nèi)容由幀起始、仲裁場、控制場、數(shù)據(jù)場(如果有)的無填充位流計算而來。

CRC序列計算使用CAN規(guī)范規(guī)定的方法。作為發(fā)送器的節(jié)點發(fā)送CAN報文時CRC序列由規(guī)定的計算方法確定,作為接收器的節(jié)點從總線上接收完數(shù)據(jù)場最后一個數(shù)據(jù)位(沒有數(shù)據(jù)場時是接收完控制場的最后一個位)后,如果接下來接收到實際的CRC序列與接收器的計算結(jié)果不一致,便檢測到CRC錯誤。

4、格式錯誤

節(jié)點無論是作為發(fā)送器的還是作為接收器均可在監(jiān)測報文期間檢測識別格式錯誤。由于CAN通信嚴(yán)格按照CAN規(guī)范定義的幀格式進(jìn)行報文封裝傳輸,CAN控制器在監(jiān)測總線電平位時明確知道當(dāng)前位、后續(xù)位屬于幀格式中哪個位場,以及屬于位場的第幾個位,當(dāng)接收到一個屬于幀格式固定形式的位時,如果實際電平值與幀格式定義不一致,則檢測到一個格式錯誤。

例外情況,對于接收器來說,幀結(jié)束最后的位被置于“不重要”狀態(tài),監(jiān)測到的幀結(jié)束最后一位期間的顯性位不被當(dāng)作幀錯誤。

5、應(yīng)答錯誤應(yīng)答錯誤是由作為發(fā)送器的節(jié)點檢測識別的。在發(fā)送報文時,只要在發(fā)送應(yīng)答間隙(隱性)期間所監(jiān)測到的位不為“顯性”,則發(fā)送器會檢測到一個應(yīng)答錯誤。

注:

1、上述5種錯誤不會相互排斥,也就是說CAN幀中的某個錯誤有可能同屬一種以上的錯誤類型。

2、如上所述,作為發(fā)送器或接收器的不同角色時,直接能檢測到的錯誤類型是不一樣的。

節(jié)點如何響應(yīng)錯誤?

CAN規(guī)范中規(guī)定每個CAN控制器中實現(xiàn)一個發(fā)送錯誤計數(shù)器和一個接收錯誤計數(shù)器。根據(jù)計數(shù)值不同,節(jié)點會處于不同的節(jié)點狀態(tài),并根據(jù)計數(shù)值的變化進(jìn)行狀態(tài)轉(zhuǎn)換,狀態(tài)轉(zhuǎn)換如圖3所示。

6a87abe8-30fb-11ec-82a8-dac502259ad0.png

圖3 節(jié)點轉(zhuǎn)態(tài)轉(zhuǎn)換圖

當(dāng)CAN控制器檢測到總線錯誤后通過發(fā)送錯誤標(biāo)志指示錯誤。對于“錯誤主動”的節(jié)點,錯誤標(biāo)志表現(xiàn)為“主動錯誤標(biāo)志”,對于“錯誤被動”的節(jié)點,錯誤標(biāo)志表現(xiàn)為“被動錯誤標(biāo)志”。

無論檢測到位錯誤、填充錯誤、幀格式錯誤、還是應(yīng)答錯誤,CAN控制器會在緊鄰的下一位發(fā)送錯誤標(biāo)志。如果檢測到的錯誤類型是CRC錯誤,錯誤標(biāo)志的發(fā)送開始于ACK定界符之后的位,即幀結(jié)尾。

綜上所述,CAN控制器對錯誤的響應(yīng)可概括為:根據(jù)當(dāng)前的節(jié)點狀態(tài)在位流序列相應(yīng)的位置用錯誤標(biāo)志標(biāo)示錯誤,并按照CAN規(guī)范更新錯誤計數(shù)值,進(jìn)行節(jié)點狀態(tài)轉(zhuǎn)換。并且是每成功監(jiān)測到一次錯誤便進(jìn)行一次響應(yīng)。

注:

1、由于篇幅有限,關(guān)于錯誤計數(shù)的詳細(xì)規(guī)則、節(jié)點狀態(tài)轉(zhuǎn)換以及錯誤幀格式等細(xì)節(jié)均不在本文進(jìn)行討論,請讀者查閱CAN協(xié)議規(guī)范。

2、上述分析可知道,錯誤響應(yīng)的關(guān)鍵要素包括錯誤標(biāo)志的類型和響應(yīng)的位置。

錯誤管理機(jī)制的作用

錯誤管理機(jī)制的作用主要體現(xiàn)在對錯誤的響應(yīng)過程。

作為發(fā)送器發(fā)送錯誤標(biāo)志時,無論“主動錯誤”還是“被動錯誤”都必然包括6個連續(xù)同極性的位,使其他節(jié)點也識別到總線錯誤,進(jìn)而使所有節(jié)點都能丟棄當(dāng)前出錯的幀。

作為接收器發(fā)送錯誤標(biāo)志時,“主動錯誤”標(biāo)志使其他節(jié)點也識別到總線錯誤從而使所有節(jié)點(包括作為發(fā)送器的節(jié)點)都能丟棄當(dāng)前出錯的幀;“被動錯誤”標(biāo)志不影響總線通信從而使其他節(jié)點都能成功接收當(dāng)前幀,處于“被動錯誤”狀態(tài)的節(jié)點屬于“不可信”狀態(tài),其檢測到錯誤僅是自己丟棄當(dāng)前幀,這也是錯誤管理的靈活性所在,即錯誤響應(yīng)并不是嚴(yán)格在任何情況下都使所有節(jié)點丟棄同一幀報文。

綜上所述,錯誤管理機(jī)制可以使所有的節(jié)點同時接收或丟棄總線的同一幀報文,又可以使作為接收器的被動錯誤狀態(tài)的節(jié)點僅自己丟棄當(dāng)前報文而不影響其他節(jié)點。因此,錯誤管理是實現(xiàn)CAN通信數(shù)據(jù)一致性的機(jī)制之一。

總結(jié)

CAN節(jié)點錯誤管理功能是由CAN節(jié)點組成中的CAN控制器負(fù)責(zé)的,對錯誤管理的工作過程可以從“錯誤識別”和“錯誤響應(yīng)”兩個方面進(jìn)行理解。錯誤管理是實現(xiàn)CAN通信數(shù)據(jù)的一致性的機(jī)制之一。

ZPS-CANFD是致遠(yuǎn)電子總線分析儀第二代CAN總線開發(fā)輔助工具,適用于CANFD、CAN、LIN總線的測量及測試儀器,支持總線數(shù)據(jù)的發(fā)送和接收,高層協(xié)議解析及診斷,能對CANFD、CAN總線物理層電氣信號實時采集和記錄,并附帶有高速模擬通道、通用數(shù)字IO及模擬IO,通過提供的硬件接口及軟件功能,用戶能夠便捷地構(gòu)建總線信號測量與分析、節(jié)點功能仿真及測試、網(wǎng)絡(luò)可靠性診斷及評估的自動化系統(tǒng)。ZPS-CANFD可實現(xiàn)CAN/CANFD報文和波形的同步監(jiān)測,可以直觀的定位排查節(jié)點錯誤問題,以及更高效的錯誤干擾等模擬測試。

編輯:jq

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

    關(guān)注

    146

    文章

    16885

    瀏覽量

    349915
  • 計數(shù)器
    +關(guān)注

    關(guān)注

    32

    文章

    2253

    瀏覽量

    94278
  • 發(fā)送器
    +關(guān)注

    關(guān)注

    1

    文章

    258

    瀏覽量

    26782
  • CAN控制器
    +關(guān)注

    關(guān)注

    3

    文章

    74

    瀏覽量

    14995

原文標(biāo)題:【原理解析】一文讀懂CAN節(jié)點錯誤管理機(jī)制

文章出處:【微信號:ZLG_zhiyuan,微信公眾號:ZLG致遠(yuǎn)電子】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    CAN總線錯誤狀態(tài)的種類

    CAN總線錯誤狀態(tài)的種類主要包括以下幾種,每種狀態(tài)都反映了CAN總線網(wǎng)絡(luò)中節(jié)點或總線的不同錯誤情況,以及相應(yīng)的通信能力和限制。
    的頭像 發(fā)表于 09-03 14:17 ?693次閱讀

    深入探討Linux的進(jìn)程調(diào)度器

    ,以及其運(yùn)行的順序。這篇文章將詳細(xì)探討Linux進(jìn)程調(diào)度器的工作原理、主要算法、調(diào)度策略以及其在實際操作中的應(yīng)用。
    的頭像 發(fā)表于 08-13 13:36 ?876次閱讀
    <b class='flag-5'>深入探討</b>Linux的進(jìn)程調(diào)度器

    康謀分享 | ADTF在CAN方面技術(shù)的深入探討

    在當(dāng)今汽車電子系統(tǒng)的開發(fā)中,CAN總線作為車輛內(nèi)部通信的骨干,承載著大量關(guān)鍵信號的傳輸。ADTF為汽車電子領(lǐng)域總線方面提供了一套工具鏈,不僅提高開發(fā)效率,也確保汽車電子系統(tǒng)的穩(wěn)定性和可靠性。
    的頭像 發(fā)表于 07-02 15:12 ?3173次閱讀
    康謀分享 | ADTF在<b class='flag-5'>CAN</b>方面技術(shù)的<b class='flag-5'>深入探討</b>

    一文讀懂CAN通訊錯誤

    CAN總線通信技術(shù)廣泛應(yīng)用于多個行業(yè),是每個總線設(shè)計工程師必學(xué)的一個通訊網(wǎng)絡(luò)。然而,對于CAN通信中的錯誤幀,許多人僅停留在表面了解,缺乏深入理解,這導(dǎo)致許多工程師在面對總線通信故障時
    的頭像 發(fā)表于 06-12 08:24 ?2436次閱讀
    一文讀懂<b class='flag-5'>CAN</b>通訊<b class='flag-5'>錯誤</b>幀

    虹科培訓(xùn) | CiA協(xié)會CAN總線實訓(xùn)開班,新一代CAN網(wǎng)絡(luò)CAN XL

    暌違5年之久,國際CiA協(xié)會培訓(xùn)再次落地國內(nèi)!你是否渴望與國際CAN領(lǐng)域的權(quán)威專家面對面交流,深入探討CAN技術(shù)的最新發(fā)展與應(yīng)用?你是否想站在行業(yè)前沿,領(lǐng)略CAN技術(shù)的最新動態(tài)?機(jī)會就
    的頭像 發(fā)表于 05-16 08:04 ?344次閱讀
    虹科培訓(xùn) | CiA協(xié)會<b class='flag-5'>CAN</b>總線實訓(xùn)開班,新一代<b class='flag-5'>CAN</b>網(wǎng)絡(luò)<b class='flag-5'>CAN</b> XL

    CAN-bus應(yīng)用筆記:節(jié)點

    CAN-bus電路設(shè)計中,理論上收發(fā)器支持節(jié)點數(shù)最多可做到110個,但實際應(yīng)用中往往達(dá)不到這個數(shù)量。今天我們就來談?wù)勅绾瓮ㄟ^合理的CAN-bus總線設(shè)計,保證CAN網(wǎng)絡(luò)中的通訊的可靠
    的頭像 發(fā)表于 05-12 08:24 ?484次閱讀
    <b class='flag-5'>CAN</b>-bus應(yīng)用筆記:<b class='flag-5'>節(jié)點</b>篇

    一文讀懂CAN控制器錯誤處理的原理

    CAN通訊的錯誤幀到底是如何被界定的?本文帶你輕松了解!錯誤標(biāo)定檢測到錯誤條件的站通過發(fā)送錯誤標(biāo)志指示
    的頭像 發(fā)表于 04-26 08:25 ?1487次閱讀
    一文讀懂<b class='flag-5'>CAN</b>控制器<b class='flag-5'>錯誤</b>處理的原理

    9個Can節(jié)點中一個節(jié)點錯誤引發(fā)的巨大問題求解

    最近做的一個項目,我設(shè)備有9個can,一個can作主機(jī)去循環(huán)召喚下面8個can作從機(jī)的數(shù)據(jù)(所有設(shè)備能正常收發(fā))。當(dāng)人為把從機(jī)的一個can通訊線給斷掉,再把它重新接上之后,會出現(xiàn)主機(jī)
    發(fā)表于 04-10 07:40

    深入理解Java 8內(nèi)存管理機(jī)制及故障排查實戰(zhàn)指南

    Java的自動內(nèi)存管理機(jī)制是由 JVM 中的垃圾收集器來實現(xiàn)的,垃圾收集器會定期掃描堆內(nèi)存中的對象,檢測并清除不再使用的對象,以釋放內(nèi)存資源。
    的頭像 發(fā)表于 04-04 08:10 ?955次閱讀
    <b class='flag-5'>深入</b>理解Java 8內(nèi)存<b class='flag-5'>管理機(jī)制</b>及故障排查實戰(zhàn)指南

    CAN數(shù)據(jù)傳輸錯誤的常見原因有哪些?

    電源波動或其他電氣問題可能會影響CAN信號的質(zhì)量并導(dǎo)致“幀錯誤”。例如,波特率不匹配或者節(jié)點沒有初始化,也可能導(dǎo)致沒有ACK(應(yīng)答)信號。
    發(fā)表于 04-02 09:30 ?955次閱讀

    深入探討電源變壓器在儲能設(shè)備中的應(yīng)用

    深入探討電源變壓器在儲能設(shè)備中的應(yīng)用? 電源變壓器在儲能設(shè)備中的應(yīng)用已經(jīng)成為當(dāng)代能源儲備和利用的關(guān)鍵技術(shù)之一。隨著可再生能源的不斷發(fā)展和應(yīng)用,儲能設(shè)備的需求也越來越大。電源變壓器作為儲能設(shè)備中的關(guān)鍵
    的頭像 發(fā)表于 02-02 09:44 ?1172次閱讀

    CAN總線最大能夠帶多少節(jié)點?CANFD相對于CAN2.0有哪些差異呢?

    CAN總線最大能夠帶多少節(jié)點?CANFD相對于CAN2.0有哪些差異呢? CAN總線最大能夠帶多少節(jié)點?
    的頭像 發(fā)表于 01-31 14:08 ?3127次閱讀

    詳解zookeeper的session管理機(jī)制

    使用過zookeeper的都知道,當(dāng)我們使用zookeeper創(chuàng)建一個節(jié)點時,我們能選擇節(jié)點的類型是“臨時節(jié)點”還是“永久節(jié)點”。臨時節(jié)點
    的頭像 發(fā)表于 01-08 09:46 ?970次閱讀
    詳解zookeeper的session<b class='flag-5'>管理機(jī)制</b>

    常見PCIe電源管理簡介

    電源管理主要包含兩個部分:PCI-PM電源管理機(jī)制和ASPM電源管理機(jī)制。
    的頭像 發(fā)表于 12-16 16:29 ?3362次閱讀
    常見PCIe電源<b class='flag-5'>管理</b>簡介

    如何用示波器排查CAN的各種錯誤幀呢?

    ,在CAN通信中,錯誤幀可能會導(dǎo)致設(shè)備故障和通信中斷,因此排查CAN錯誤幀非常重要。本文將詳細(xì)介紹如何使用示波器排查CAN的各種
    的頭像 發(fā)表于 12-07 11:09 ?1070次閱讀