<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>
0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

CAN報文為什么會發送失???

ZLG致遠電子 ? 2024-04-12 08:25 ? 次閱讀

CAN總線調試過程中出現報文發送失敗。很多工程師都對此只知其一不知其二,今天我們就以CAN報文發送失敗的問題來做一次探討。

在了解CAN報文為什么會發送失敗之前我們先看看一幀標準的CAN報文到底應該是怎么樣的。表1是一幀正常標準數據幀的報文組成。
表1 標準數據幀報文格式組成24143244-f863-11ee-9118-92fbcf53809c.png

24197de4-f863-11ee-9118-92fbcf53809c.jpg

圖1 標準數據幀格式CAN總線是一種基于廣播的通訊方式,為了保證總線上的每一個正常節點都能正確的接收到報文,報文的發送者要求至少一個接收節點在報文發送結束前要作出應答,這也是報文里ACK存在的原因。

一幀CAN報文中ACK段長度為2個位,包含應答間隙(ACK Slot)和應答界定符(ACK Delimter)。在應答場里,發送器發送兩個隱性位。當接收器正確地接收到有效的報文,接收器就會在應答間隙(ACK Slot)期間(發送ACK信號)向發送器發送一“顯性”的位以示應答。

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

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

241d1c2e-f863-11ee-9118-92fbcf53809c.png

圖2 正常ACK段報文

而如果總線上沒有ACK應答(即應答間隙為隱性),發送器就會發送一個錯誤標志,并且發送錯誤計數器值加8,節點就會對報文進行自動重發,若自動重發依然收不到ACK,則在發送錯誤計數器計數滿128后(即出現16幀錯誤幀),由錯誤主動轉為錯誤被動狀態,如圖3所示。那導致ACK段出錯的原因有哪些呢?下面小編總結了一些。

  • 總線上只有一個有效節點:發送報文的節點在發送出一幀報文后會檢測總線上應答間隙的狀態,如果檢測到應答間隙為隱性位,則表示該幀報文沒有得到ACK,發送失敗,需要重發,而由于發送錯誤計數器會在發送失敗后累加,直到該節點關閉。所以,當總線上只有一個有效節點時,這個節點是發不出去數據的,因為它所發出的數據幀中的ACK Slot沒有另外一個節點來填充,將永遠是隱性位,這個節點會一直重發數據直到發送成功或發送被取消。
  • 波特率不匹配或者節點沒有初始化,導致沒有ACK;
  • 總線線纜短路,斷路,接反;
  • 高速CAN總線上接的節點不是高速CAN,而是容錯低速CAN,導致不匹配。

24205d76-f863-11ee-9118-92fbcf53809c.jpg

圖3 應答界定符錯誤幀242459c6-f863-11ee-9118-92fbcf53809c.png

圖4 沒有ACK的報文

當你在調試CAN總線時出現節點發送報文失敗的情況時,一定要檢查是不是以上幾點疏漏導致你的總線上ACK異常。而借助恰當的儀器,可以在查找CAN總線錯誤時事半功倍。圖4即采用致遠電子的CANScope來對錯誤幀進行標記,同時找到錯誤幀對應的波形來查找出錯誤情況。CANScope還可以對CAN總線物理層、數據鏈路層、應用層做一系列的測試,為CAN工程師解決測試難題。

243449d0-f863-11ee-9118-92fbcf53809c.jpg

圖5 CANScope測試項目

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • CAN總線
    +關注

    關注

    145

    文章

    1812

    瀏覽量

    129592
  • 數據幀
    +關注

    關注

    0

    文章

    33

    瀏覽量

    6647
  • can報文
    +關注

    關注

    0

    文章

    3

    瀏覽量

    2287
收藏 人收藏

    評論

    相關推薦

    CAN報文格式和發送總流程

    在標準格式中,報文的起始位稱為幀起始(SOF),然后是由11位標識符和遠程發送請求位(RTR)組成的仲裁場。RTR位標明是數據幀還是請求幀,在請求幀中沒有數據字節。
    發表于 04-11 10:07 ?314次閱讀
    <b class='flag-5'>CAN</b>的<b class='flag-5'>報文</b>格式和<b class='flag-5'>發送</b>總流程

    TC275多路CAN節點,報文接收時需要開啟多路的CAN接收中斷嗎?

    TC275配置使用一路CAN0時,收發都可以,收報文是開啟的CAN0接收中斷,然后接收報文;現在使用兩路CAN
    發表于 02-20 08:27

    TC387模塊CAN0的節點2作為CANA使用,CANA既收不到報文也發不出報文如何解決?

    TC387模塊CAN0的節點2作為CANA使用,CAN1的節點0作為CANB使用,配置基本相同。但CANB的通信正常,而在TJA1145正常情形下,CANA既收不到報文,也發不出報文,
    發表于 02-19 06:43

    MCU怎樣判斷CAN發送狀態?

    (); } 如此配置發現在一幀報文發送完了后,不能進入can發送中斷, 2、能有別的標志位來判斷can
    發表于 02-18 08:33

    CAN FD在發送報文時會有發不出去的現象怎么解決?

    現象描述: 在發送多幀報文數據時,出現了較為嚴重的報文丟失現象。編寫測試程序,在for循環中循環發送id為0-7ff的報文,對返回值進行了判
    發表于 02-02 07:48

    使用CYT2B75芯片CANFD模塊無法發送消息是什么原因導致的呢?

    你好,我使用SDL的example中的CANFD代碼測試CYT2B75芯片CANFD模塊,對部分代碼進行了硬件適配修改,詳見附件,配置為每秒發送一次CAN報文。 問題:消息發送
    發表于 02-02 06:57

    TC364&amp;TJA1145特定CAN報文丟失怎么解決?

    客戶現場進行急加速和急減速過程中,出現了特定ID的報文丟失,其它報文發送正常,CAN這一塊用的工具配置生成,家里進行測試Busoff后能正?;謴?,從來沒有碰到過這種丟一幀的
    發表于 01-23 06:03

    TSMaster報文發送的信號生成器操作說明

    信號生成器功能是TSMaster分析中的報文發送模塊。信號生成器用于發送和配置每個CAN/LIN信號的值變化行為,簡而言之,這是一個可以控制和調整C
    的頭像 發表于 12-23 08:21 ?321次閱讀
    TSMaster<b class='flag-5'>報文</b><b class='flag-5'>發送</b>的信號生成器操作說明

    S32K144搭載S32K1XX_MCAL4_2_RTM_1_0_6以及S32DS編譯軟件使用CAN模塊無法發送報文怎么解決?

    下的MCAL422_EB_project,編譯環境使用的是S32 Design Studio for S32 Platform 3.4,主工程如附件文件夾下的MCAL422_S32DS_project。不知是否可以檢查我的項目哪里配置或使用不當導致CAN報文
    發表于 11-13 08:29

    車載時鐘同步can_tsync同步原理

    master在t01時刻以廣播的形式發送一個sync報文,并把時間秒部分的時間放到報文上,發送到time slave;使用can conf
    的頭像 發表于 10-27 14:32 ?1055次閱讀
    車載時鐘同步<b class='flag-5'>can</b>_tsync同步原理

    求一種基于infineonPSOC62開發板的多功能CAN報文記錄儀設計方案

    在汽車領域,經常會涉及到CAN報文收發,目前應用最廣泛的就是是CAN2.0B協議。CAN報文對整車控制起著至關重要的作用。
    的頭像 發表于 07-18 16:17 ?757次閱讀
    求一種基于infineonPSOC62開發板的多功能<b class='flag-5'>CAN</b><b class='flag-5'>報文</b>記錄儀設計方案

    CAN FD報文時間計算

    1us),數據域波特率為5Mbps(位時間200ns)時,其報文時間 = 1us * 26 + 33 * 200ns = 32.6us。 那么一秒鐘最多可以發送報文呢?由于報文發送成功
    的頭像 發表于 07-18 10:49 ?1508次閱讀
    <b class='flag-5'>CAN</b> FD<b class='flag-5'>報文</b>時間計算

    一幀CAN報文多少字節

    一幀CAN FD報文位數 根據CAN FD幀結構組成,可以算出一幀CAN FD報文位數: CAN
    的頭像 發表于 07-18 10:48 ?4797次閱讀

    M453單片機的CAN中斷接力發送發送報文數量丟失怎么解決?

    1、我使用新唐M453單片機,使用CAN1進行實驗,將CAN1的后4個報文緩存RAM做為發送緩沖區來使用。通過線程啟動報文
    發表于 06-15 07:26

    CAN報文固定協議轉發教程

    CAN總線通信的應用領域中,很多客戶需要將CANID 放在CAN報文中,這樣更方便接入不同的設備,有利于用戶通過模塊更方便的組建自己的網絡,使用自定的應用協議。但是要實現這樣的應用,用戶往往需要
    的頭像 發表于 05-12 10:40 ?592次閱讀
    <b class='flag-5'>CAN</b><b class='flag-5'>報文</b>固定協議轉發教程
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>