加入星計(jì)劃,您可以享受以下權(quán)益:

  • 創(chuàng)作內(nèi)容快速變現(xiàn)
  • 行業(yè)影響力擴(kuò)散
  • 作品版權(quán)保護(hù)
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質(zhì)創(chuàng)作者
  • 5000+ 長(zhǎng)期合作伙伴
立即加入
  • 正文
  • 推薦器件
  • 相關(guān)推薦
  • 電子產(chǎn)業(yè)圖譜
申請(qǐng)入駐 產(chǎn)業(yè)圖譜

技術(shù)分享 | CAN報(bào)文為什么會(huì)發(fā)送失敗?

04/11 15:45
2963
閱讀需 4 分鐘
加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點(diǎn)資訊討論

CAN總線調(diào)試過程中出現(xiàn)報(bào)文發(fā)送失敗。很多工程師都對(duì)此只知其一不知其二,今天我們就以CAN報(bào)文發(fā)送失敗的問題來做一次探討。

在了解CAN報(bào)文為什么會(huì)發(fā)送失敗之前我們先看看一幀標(biāo)準(zhǔn)的CAN報(bào)文到底應(yīng)該是怎么樣的。表1是一幀正常標(biāo)準(zhǔn)數(shù)據(jù)幀的報(bào)文組成。

表1 標(biāo)準(zhǔn)數(shù)據(jù)幀報(bào)文格式組成

圖1 標(biāo)準(zhǔn)數(shù)據(jù)幀格式CAN總線是一種基于廣播的通訊方式,為了保證總線上的每一個(gè)正常節(jié)點(diǎn)都能正確的接收到報(bào)文,報(bào)文的發(fā)送者要求至少一個(gè)接收節(jié)點(diǎn)在報(bào)文發(fā)送結(jié)束前要作出應(yīng)答,這也是報(bào)文里ACK存在的原因。

一幀CAN報(bào)文中ACK段長(zhǎng)度為2個(gè)位,包含應(yīng)答間隙(ACK Slot)和應(yīng)答界定符(ACK Delimter)。在應(yīng)答場(chǎng)里,發(fā)送器發(fā)送兩個(gè)隱性位。當(dāng)接收器正確地接收到有效的報(bào)文,接收器就會(huì)在應(yīng)答間隙(ACK Slot)期間(發(fā)送ACK信號(hào))向發(fā)送器發(fā)送一“顯性”的位以示應(yīng)答。

應(yīng)答間隙:所有接收到匹配CRC序列(CRC SEQUENCE)的站會(huì)在應(yīng)答間隙(ACK Slot)期間用一顯性的位寫入發(fā)送器的隱性位來作出回答。

應(yīng)答界定符:ACK界定符是ACK場(chǎng)的第二個(gè)位,并且是一個(gè)必須為隱性的位。因此,應(yīng)答間隙(ACK Slot)被兩個(gè)隱性的位所包圍,也就是CRC界定符(CRC Delimter)和ACK界定符(ACK Delimter)。

圖2 正常ACK段報(bào)文

而如果總線上沒有ACK應(yīng)答(即應(yīng)答間隙為隱性),發(fā)送器就會(huì)發(fā)送一個(gè)錯(cuò)誤標(biāo)志,并且發(fā)送錯(cuò)誤計(jì)數(shù)器值加8,節(jié)點(diǎn)就會(huì)對(duì)報(bào)文進(jìn)行自動(dòng)重發(fā),若自動(dòng)重發(fā)依然收不到ACK,則在發(fā)送錯(cuò)誤計(jì)數(shù)器計(jì)數(shù)滿128后(即出現(xiàn)16幀錯(cuò)誤幀),由錯(cuò)誤主動(dòng)轉(zhuǎn)為錯(cuò)誤被動(dòng)狀態(tài),如圖3所示。那導(dǎo)致ACK段出錯(cuò)的原因有哪些呢?下面小編總結(jié)了一些。

總線上只有一個(gè)有效節(jié)點(diǎn)

    • :發(fā)送報(bào)文的節(jié)點(diǎn)在發(fā)送出一幀報(bào)文后會(huì)檢測(cè)總線上應(yīng)答間隙的狀態(tài),如果檢測(cè)到應(yīng)答間隙為隱性位,則表示該幀報(bào)文沒有得到ACK,發(fā)送失敗,需要重發(fā),而由于發(fā)送錯(cuò)誤計(jì)數(shù)器會(huì)在發(fā)送失敗后累加,直到該節(jié)點(diǎn)關(guān)閉。所以,當(dāng)總線上只有一個(gè)有效節(jié)點(diǎn)時(shí),這個(gè)節(jié)點(diǎn)是發(fā)不出去數(shù)據(jù)的,因?yàn)樗l(fā)出的數(shù)據(jù)幀中的ACK Slot沒有另外一個(gè)節(jié)點(diǎn)來填充,將永遠(yuǎn)是隱性位,這個(gè)節(jié)點(diǎn)會(huì)一直重發(fā)數(shù)據(jù)直到發(fā)送成功或發(fā)送被取消。

波特率不匹配或者節(jié)點(diǎn)沒有初始化

    • ,導(dǎo)致沒有ACK;

總線線纜短路,斷路,接反高速CAN總線上接的節(jié)點(diǎn)不是高速CAN,而是容錯(cuò)低速CAN,導(dǎo)致不匹配。

圖3 應(yīng)答界定符錯(cuò)誤幀

圖4 沒有ACK的報(bào)文

當(dāng)你在調(diào)試CAN總線時(shí)出現(xiàn)節(jié)點(diǎn)發(fā)送報(bào)文失敗的情況時(shí),一定要檢查是不是以上幾點(diǎn)疏漏導(dǎo)致你的總線上ACK異常。而借助恰當(dāng)?shù)膬x器,可以在查找CAN總線錯(cuò)誤時(shí)事半功倍。圖4即采用致遠(yuǎn)電子的CANScope來對(duì)錯(cuò)誤幀進(jìn)行標(biāo)記,同時(shí)找到錯(cuò)誤幀對(duì)應(yīng)的波形來查找出錯(cuò)誤情況。CANScope還可以對(duì)CAN總線物理層、數(shù)據(jù)鏈路層、應(yīng)用層做一系列的測(cè)試,為CAN工程師解決測(cè)試難題。

圖5 CANScope測(cè)試項(xiàng)目

推薦器件

更多器件
器件型號(hào) 數(shù)量 器件廠商 器件描述 數(shù)據(jù)手冊(cè) ECAD模型 風(fēng)險(xiǎn)等級(jí) 參考價(jià)格 更多信息
AD73311ARSZ 1 Analog Devices Inc Single-Channel, 3 V and 5 V Front-End Processor for General Purpose Applications Including Speech and Telephony

ECAD模型

下載ECAD模型
$10.72 查看
KSZ9031RNXCA 1 Microchip Technology Inc DATACOM, ETHERNET TRANSCEIVER

ECAD模型

下載ECAD模型
$5.5 查看
KSZ9031RNXVB-VAO 1 Microchip Technology Inc Ethernet Transceiver

ECAD模型

下載ECAD模型
暫無數(shù)據(jù) 查看
致遠(yuǎn)電子

致遠(yuǎn)電子

廣州致遠(yuǎn)電子股份有限公司成立于2001年,注冊(cè)資金5000萬元,國(guó)家級(jí)高新技術(shù)認(rèn)證企業(yè),廣州市高端工控測(cè)量?jī)x器工程技術(shù)研究開發(fā)中心,Intel ECA全球合作伙伴和微軟嵌入式系統(tǒng)金牌合作伙伴。

廣州致遠(yuǎn)電子股份有限公司成立于2001年,注冊(cè)資金5000萬元,國(guó)家級(jí)高新技術(shù)認(rèn)證企業(yè),廣州市高端工控測(cè)量?jī)x器工程技術(shù)研究開發(fā)中心,Intel ECA全球合作伙伴和微軟嵌入式系統(tǒng)金牌合作伙伴。收起

查看更多

相關(guān)推薦

電子產(chǎn)業(yè)圖譜

ZLG官方賬號(hào),一個(gè)匯聚500名工程師的研發(fā)測(cè)試分享平臺(tái),為您提供電子世界領(lǐng)先的產(chǎn)品技術(shù)與行業(yè)解決方案.