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

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

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

為什么發(fā)送CANFD加速報文要開啟發(fā)送延遲補償(TDC)?

ZLG致遠電子 ? 2022-07-11 16:49 ? 次閱讀

CANFD協(xié)議中,有個重要的概念TDC(Transmitter Delay Compensation)即發(fā)送延遲補償,字面意思就是對發(fā)送延遲進行補償。那么為什么會存在發(fā)送延遲,又為什么CANFD要對發(fā)送延遲做補償?

為什么存在發(fā)送延遲

td_loopback.jpg

眾所周知,CAN控制器發(fā)送信號時,是經(jīng)過收發(fā)器后發(fā)往CAN總線后,再經(jīng)過收發(fā)器反饋總線信號。那么發(fā)送過程中,控制器發(fā)送位信號到接收位信號就不可避免的存在環(huán)路延遲。發(fā)送延遲時間的總和如下:

CAN控制器內(nèi)部產(chǎn)生TX信號到Tx引腳的傳播延遲;

Tx引腳到收發(fā)器TxD引腳的傳播延遲;

收發(fā)器環(huán)路延遲TxD到RxD;

收發(fā)器RxD引腳到CAN控制器Rx引腳延遲;

CAN控制器Rx引腳到控制器內(nèi)部收到Rx信號的延遲。

CAN協(xié)議中規(guī)定:發(fā)送方發(fā)送位時,需檢測接收到的位與發(fā)送是否一致,若不一致則產(chǎn)生錯誤幀(位錯誤)。如果發(fā)送延遲過長,則將直接導(dǎo)致發(fā)送與接收位不一致而產(chǎn)生錯誤幀。由于傳統(tǒng)CAN協(xié)議規(guī)定最高波特率為1Mbps,即位寬1us,正常情況下,傳輸延遲不會超過位寬的采樣點(當然具體延遲取決于收發(fā)器環(huán)路延遲、傳輸距離、傳輸線纜質(zhì)量等),因此不會因為發(fā)送延遲而產(chǎn)生錯誤。

為什么CANFD要對發(fā)送延遲做補償

在CANFD中,數(shù)據(jù)段的波特率是比CAN更高的(BRS位為隱性時),此時波特率越高,位寬越小,在發(fā)送報文時發(fā)送延遲影響越大,越容易產(chǎn)生位錯誤。由于發(fā)送延遲無法避免,此時就需要一種機制來保證發(fā)送與接收的位對應(yīng)上,以避免產(chǎn)生位錯誤。這種機制就是發(fā)送延遲補償了。

發(fā)送延遲補償(TDC)

TDC實際上就是在發(fā)送BRS位為隱性的CANFD報文時(BRS隱性即開啟數(shù)據(jù)域波特率),在發(fā)送時延遲一定時間后,在第二采樣點采樣接收位,以正確采樣到發(fā)送位對應(yīng)的接收位。

發(fā)送延遲測量

那么延遲采樣的延遲時間是多久呢?實際上,開啟TDC后,控制器將自動測量Tx信號線上FDF位到r0位下降沿與Rx信號線上FDF位到r0位邊沿的之間的延遲時間,如下圖中所示,TDCV即為延遲時間。發(fā)送延遲測量的時間單位為CAN控制器時鐘(TDC寄存器中一般對TDCV的值有限制,若超過寄存器最大位數(shù),則發(fā)送延遲測量失?。?。

tdcv.png

第二采樣點(SSP)

在達到延遲時間后,控制器此時需要采樣接收位,該采樣點我們稱為第二采樣點(SSP=Second Sample Point),以區(qū)別未延遲之前的采樣點(SP),如下圖所示。

SSP.png

SSP等于測量延遲TDCV+發(fā)送延遲補償偏移TDCO(TDC Offset)之和。一般TDCO設(shè)置與第一采樣點一致,即(PROP+TSEG1) * DBRP。主要注意是:實際填入寄存器的波特率參數(shù)一般為實際值減一,具體可參考控制器手冊說明。

此外,ISO11898-1:2015中還對TDC做了一些規(guī)定:

開啟TDC后,數(shù)據(jù)段波特率的預(yù)分頻值(DBRP)應(yīng)設(shè)置為1或2;

控制器實現(xiàn)TDC機制應(yīng)能補償至少兩個位時間。

TDC配置建議

當CANFD數(shù)據(jù)域波特率大于1Mbps時,應(yīng)開啟TDC。

數(shù)據(jù)段波特率的預(yù)分頻值(DBRP)建議設(shè)置為1或2。

第二采樣點SSP=發(fā)送延遲測量值TD + Offset, 其中Offset設(shè)置與第一采樣點一致或早1Tq。

當然,USBCANFD-200U系列CANFD卡的TDC也同樣遵循上述配置,用戶使用時,無需再手動配置。

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

    關(guān)注

    0

    文章

    40

    瀏覽量

    13954
收藏 人收藏

    評論

    相關(guān)推薦
    熱點推薦

    ATS失效請求報文問題的故障排除步驟

    本篇文章提供了解決 ATS 失效請求報文問題的故障排除步驟,主要聚焦在 CQ 接口上未顯示主機發(fā)送報文的情況。
    的頭像 發(fā)表于 06-09 15:17 ?435次閱讀
    ATS失效請求<b class='flag-5'>報文</b>問題的故障排除步驟

    STM32G473 CAN發(fā)送數(shù)據(jù)出現(xiàn)丟幀怎么解決?

    配置CAN以FIFO模式發(fā)送,單片機周期發(fā)送不同ID的CAN報文,同時使用軟件ZCANPRO周期發(fā)送不同ID的報文到CAN總線上來模擬總線上
    發(fā)表于 03-11 08:30

    TDC1000能否用于多普勒測流?

    你好,我想問下TDC1000能否用于多普勒測流?就是通過STOP的頻率計算出回波的頻率?根據(jù)發(fā)送頻率和STOP頻率來計算頻差,使用TDC1000的方案能滿足這個技術(shù)要求嗎?
    發(fā)表于 12-25 07:19

    rk3588 canfd發(fā)送部分數(shù)據(jù)失敗的問題

    在使用rk3588的板子進行canfd通信時,有些數(shù)據(jù)發(fā)送必然失?。?1,cansend can0 200##065.68.00.00.96.00.00.01 必然成功 2,cansend can0
    發(fā)表于 12-18 10:53

    如何在CANtest上通過報文發(fā)送實現(xiàn)CCP指令的發(fā)送

    如題,我在CANtest上通過CAN報文發(fā)送了CCP指令\'CONNECT\'、\'SET-MTA\'和‘Upload’。前兩個指令的返回均沒有報錯,可\'Upload\'的返回直接
    發(fā)表于 08-13 10:46

    基于VB6.0 實現(xiàn) CAN信號收發(fā) Demo

    本文主要講的是,基于TSMaster實現(xiàn)TOSUN系列CAN/CANFD,LIN設(shè)備的操作。主要給大家介紹在TSMaster軟件里如何實現(xiàn)CAN信號收發(fā)Demo工程。本文關(guān)鍵詞:CAN報文
    的頭像 發(fā)表于 07-27 08:21 ?1262次閱讀
    基于VB6.0 實現(xiàn) CAN信號收發(fā) Demo

    CYT2BL和SDL v8.0.0是否有可能實現(xiàn)以相同ID發(fā)送和接收CAN報文(RxID、TxID)的功能?

    我使用的是 CYT2BL 和 SDL v8.0.0。 我想發(fā)送和接收具有相同 ID 的 CAN 報文。 1.是否有可能實現(xiàn)以相同 ID 發(fā)送和接收 CAN 報文(RxID、TxID)
    發(fā)表于 07-23 06:12

    北斗短報文終端如何進行雙向通信?

    北斗短報文終端的雙向通信功能是基于中國北斗衛(wèi)星導(dǎo)航系統(tǒng)(BDS)的衛(wèi)星通信能力實現(xiàn)的。以下是北斗短報文終端進行雙向通信的具體過程和特點:北斗短報文終端一、雙向通信過程發(fā)送
    的頭像 發(fā)表于 07-12 11:19 ?1389次閱讀
    北斗短<b class='flag-5'>報文</b>終端如何進行雙向通信?

    UDP發(fā)送延遲非常慢,如何提高?

    我們正在測試發(fā)送一流 UPD 包,每個包只有 8 個字節(jié)的權(quán)重,但我們每秒發(fā)送大約 4 到 5 個包。 有什么方法可以提高這個比率嗎?
    發(fā)表于 07-12 09:36

    使用ESP8266模塊進行UDP傳輸,重新連接路由后發(fā)送數(shù)據(jù)有延遲怎么避免?

    );wifi_station_set_reconnect_policy(1),設(shè)置成自動連接路由,UDP每1S發(fā)送一條數(shù)據(jù)(100字節(jié)),如果正在正常發(fā)送數(shù)據(jù)的時候路由器斷電,UDP服務(wù)器收不到數(shù)據(jù),路由再上電后,從模塊WIFI GOT IP到UDP服務(wù)器再次收到數(shù)據(jù)有差
    發(fā)表于 07-12 06:06

    TC3XX can發(fā)送報文,周期上下波動嚴重怎么解決?

    使用FULL CAN發(fā)送,周期調(diào)用Can_17_McmCan_lWriteMsgObj發(fā)送報文,查看周期是穩(wěn)定的,但到發(fā)出來和中斷觸發(fā)的時間會上下波動,而且波動越來越大。
    發(fā)表于 07-11 08:00

    長時間發(fā)送344個字節(jié)的UDP報文,出現(xiàn)overflow the heap_size并導(dǎo)致系統(tǒng)異常重啟怎么解決?

    Jan8 2013,rst cause:2, boot mode:(3,0) 請問這個協(xié)議棧有問題??什么原因?qū)е逻@個問題??? 另外的現(xiàn)象,就是sendto的地方掛死。 之前在sendto地方加了一個select 判斷是否能夠發(fā)送報文,短一點的報文,不會出現(xiàn)異常
    發(fā)表于 07-11 07:55

    使用UDP廣播在兩個ESP8266之間進行通信,發(fā)送會存在延遲是怎么回事?

    我正在使用 UDP 廣播在兩個ESP8266 (wemos) 之間進行通信。 作為測試,我只是從第一個設(shè)備發(fā)送 10 個字節(jié),第二個設(shè)備只是回顯它。 發(fā)送方在 200 毫秒延遲之前沒有得到他的響應(yīng)。 這種
    發(fā)表于 07-11 06:27

    試圖從CAN卡向TC375發(fā)送報文時,TC375始終收不到,為什么?

    我試圖在TC375上進行CAN收發(fā)測試,測試目的是完成TC375和CAN卡的通訊,現(xiàn)在我已經(jīng)成功地將CAN報文從TC375發(fā)送到了CAN卡,但是當我試圖從CAN卡向TC375發(fā)送報文時,TC375始終收不到,下面是我的一些代碼,
    發(fā)表于 07-04 06:04

    CANFD_TopFIFO無法正常工作的原因?

    我閃爍了 CANFD_TopFIFO 示例代碼,但沒有得到預(yù)期的輸出。 在 FIFO 模式下測試 CAN Rx 時,即使接收多個報文,F(xiàn)IFO 編號也始終顯示為 0。 雖然我能正確接收報文
    發(fā)表于 07-03 08:06

    電子發(fā)燒友

    中國電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會員交流學(xué)習
    • 獲取您個性化的科技前沿技術(shù)信息
    • 參加活動獲取豐厚的禮品