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

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

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

CAPL編程的進階應用 | Checksum算法的實現(xiàn)

北匯信息POLELINK ? 2022-10-11 09:29 ? 次閱讀

作者:北城舊巷
小編:吃不飽

CRC與Checksum區(qū)別

相信大家在CAN Msg或者ETH PDU中經(jīng)常會看到Checksum這種信號。提到Checksum,就必須要說明一下CRC校驗,很多工程師會概念混淆,認為兩者是同一個東西,實則它們有很大的區(qū)別。

01

兩者存放位置不同

CRC校驗:循環(huán)冗余檢查(CRC)是一種數(shù)據(jù)傳輸檢錯功能,對數(shù)據(jù)進行多項式計算,并將得到的結(jié)果附在幀的后面,接收設備也執(zhí)行類似的算法,以保證數(shù)據(jù)傳輸?shù)恼_性和完整性。通過CRC概念可以得知,CRC存放在CRC場,而Checksum存放在數(shù)據(jù)場之中,一般在數(shù)據(jù)場的第一個字節(jié)或者最后一個字節(jié)。
28fc3230-486e-11ed-b116-dac502259ad0.png圖1 標準數(shù)據(jù)幀格式

02

兩者應用場景不同

在CAN報文幀中,CRC校驗是發(fā)送器根據(jù)發(fā)送的bit進行多項式計算校驗,結(jié)果放在15bit長度的CRC位。接收器也是用相同的多項式計算總線上的數(shù)據(jù),與接收到的校驗值進行比較,相同則表示幀正確接收,并在ACK時隙中發(fā)送顯性狀態(tài),覆蓋發(fā)送器的隱性位;如果不同接收節(jié)點在ACK界定符之后發(fā)送錯誤幀。
292be750-486e-11ed-b116-dac502259ad0.png圖2 CRC校驗原理CRC校驗是為了保證數(shù)據(jù)從一個CAN收發(fā)器發(fā)送到另外一個收發(fā)器的信號完整性,而數(shù)據(jù)場中Checksum校驗算法是為了校驗數(shù)據(jù)被正確的打包與解包,并且Checksum算法是可以自行制定的,計算規(guī)則的靈活度高。

Checksum的應用場景

對于Checksum而言,它的應用場景有以下三點:

01

確保數(shù)據(jù)正確打包

有些ECU內(nèi)部的變量在傳遞到CAN收發(fā)器之前就有可能發(fā)生錯誤,這種類型的錯誤CAN收發(fā)器是無法檢測到的。報文中的信號和Checksum校驗是在應用層完成的,將報文中的各個字節(jié)進行校驗,報文和Checksum一起發(fā)送,并且在接收節(jié)點進行解析,從而確保數(shù)據(jù)鏈路完整和數(shù)據(jù)正確打包。

01

實現(xiàn)數(shù)據(jù)加密

CAN網(wǎng)絡是開放性的,CAN節(jié)點可以隨時加入到總線當中,為了保證通信的安全性,ECU傳輸?shù)年P(guān)鍵控制信號需要進行加密,報文的發(fā)送方和接收方使用相同的Checksum算法作為數(shù)據(jù)加密的密鑰。接收方對比秘鑰,如果不同,此條報文的數(shù)據(jù)不被使用,從而避免被其他節(jié)點的數(shù)據(jù)影響。Checksum算法不在DBC等數(shù)據(jù)庫文件中說明,可以單獨保密,從而確保了數(shù)據(jù)的加密。

03

提高數(shù)據(jù)的可信度

一幀報文在多個字節(jié)中可能出現(xiàn)位錯誤,一般情況下CRC8校驗的錯誤率為1/256,crc16校驗的錯誤率為1/65536,crc32校驗的錯誤率為1/(65536*65536)。通過Checksum校驗可以提高數(shù)據(jù)的可信度。由于Checksum的作用,其也常應用在車載以太網(wǎng)當中。

在CAPL中Checksum信號實現(xiàn)

通常情況下,Checksum和LiveCounter信號是成對出現(xiàn)的。在CANoe中使用仿真節(jié)點與真實控制器交互,需要將LiveCounter和Checksum信號仿真,這樣才能成功通信。LiveCounter長度為4bit,它是用于報文發(fā)送計數(shù)的生命信號,每發(fā)送一幀報文后就對該LiveCounter位加1,會在0~15之間循環(huán)增加。在報文其他信號沒有改變時,LiveCounter實時更新使得Checksum信號跟著更新,提高校驗的準確性。那么LiveCounter信號該如何仿真呢?下面以CAN總線DBC為例,介紹在CAPL中實現(xiàn)LiveCounter和Checksum校驗仿真。

CAPL是CANoe和CANalyzer中可用的類C的編程語言。CAPL中程序塊的執(zhí)行由事件控制,在專用的編譯器中開發(fā)和編譯,這樣可以訪問數(shù)據(jù)庫中的所有對象以及系統(tǒng)變量,被汽車電子工程師們廣泛使用。

下圖為LiveCounter計算的代碼,為了保證數(shù)據(jù)的準確性,進行一次Checksum計算,這樣就可以實現(xiàn)LiveCounter信號的仿真。
294e6bfe-486e-11ed-b116-dac502259ad0.png圖3 LiveCounter計算代碼下圖為示例報文中各個信號位置排布關(guān)系,在此報文中,Checksum校驗方式為前七個字節(jié)異或運算,將運算結(jié)果存放到最后一個字節(jié)。排布圖中共有8個信號,它們的格式為Motorola格式,也就是俗稱的大端模式。
296dd994-486e-11ed-b116-dac502259ad0.png圖4 報文中信號排布

CAPL只能訪問到報文中的信號,無法訪問到報文中的每個字節(jié),要進行Checksum計算,需要根據(jù)信號排布把前七個字節(jié)的真實值重新組合存放在一個byte類型的數(shù)組當中,然后對這個數(shù)組異或運算獲取的結(jié)果為該報文中Checksum信號值。

對于不同長度的信號,需要聲明不同類型的數(shù)組來存放不同的信號。byte類型長度為1字節(jié),聲明兩個byte *[8]類型的數(shù)組(*為省略的數(shù)組名稱)分別存放長度小于一字節(jié)的信號和重組后每個字節(jié)的真實值;int類型長度為2字節(jié),聲明int *[8]類型的數(shù)組存放長度為1-2字節(jié)的信號;long類型長度為4字節(jié),聲明long *[8]類型的數(shù)組存放長度為2-4字節(jié)的信號。下圖為Checksum中信號長度小于1字節(jié)的字節(jié)重組示例代碼。
29a81b4a-486e-11ed-b116-dac502259ad0.png圖5 Checksum字節(jié)重組示例代碼另外,參與Checksum計算的是信號的真實值而不是物理值,如果信號中有偏移量和比例因子,在賦值時需要將信號加上偏移量,并除以比例因子以獲得真實值。
2a24616e-486e-11ed-b116-dac502259ad0.png圖6 信號描述為了保證和真實控制器通信正常,Checksum數(shù)據(jù)必須準確,Checksum計算步驟一般寫成無返回值函數(shù)(void),在LiveCounter信號改變或者其他信號改變時調(diào)用計算。正確計算的LiveCounter和Checksum信號曲線如下圖所示。
2a3c4aea-486e-11ed-b116-dac502259ad0.png圖7 LiveCounter和Checksum信號曲線

總結(jié)

本文重點描述了CRC和Checksum信號的區(qū)別以及Checksum信號在CAPL中實現(xiàn)的方法。CAPL編程作為CANoe的靈魂,使CANoe滿足仿真、分析、測試和診斷的各種復雜的要求,同時使CANoe的功能得以不斷擴展。
北匯信息作為Vector中國的合作伙伴,致力于為中國汽車客戶提供優(yōu)質(zhì)的工具支持、解決方案以及測試服務。

注:圖片來自于Vector。

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

    關(guān)注

    88

    文章

    3523

    瀏覽量

    93277
收藏 人收藏

    評論

    相關(guān)推薦

    TI電量計Checksum功能的介紹

    電子發(fā)燒友網(wǎng)站提供《TI電量計Checksum功能的介紹.pdf》資料免費下載
    發(fā)表于 09-05 11:19 ?0次下載
    TI電量計<b class='flag-5'>Checksum</b>功能的介紹

    神經(jīng)網(wǎng)絡的基本原理及Python編程實現(xiàn)

    神經(jīng)網(wǎng)絡作為深度學習算法的基本構(gòu)建模塊,模擬了人腦的行為,通過互相連接的節(jié)點(也稱為“神經(jīng)元”)實現(xiàn)對輸入數(shù)據(jù)的處理、模式識別和結(jié)果預測等功能。本文將深入探討神經(jīng)網(wǎng)絡的基本原理,并結(jié)合Python編程
    的頭像 發(fā)表于 07-03 16:11 ?225次閱讀

    CAPL腳本使用介紹

    CAPL中也有類似于C語言中的回調(diào)函數(shù)的機制,如檢測報文周期和錯誤幀的函數(shù)中就可以使用,當周期超界或者總線出現(xiàn)錯誤幀就會自動調(diào)用回調(diào)函數(shù)執(zhí)行一些操作
    的頭像 發(fā)表于 04-01 11:23 ?1200次閱讀

    使用ST-LINK Utility進行編程勾選Full Flash Memory Checksum和設置讀出保護后LSE不起振的原因?

    使用ST-LINK Utility對F105RB進行編程,在編程中勾選了Full Flash Memory Checksum,最后操作OP字節(jié)設置讀出保護,發(fā)現(xiàn)LSE晶振不起振了,而沒有勾選的全部
    發(fā)表于 03-12 06:35

    RK3568驅(qū)動指南|驅(qū)動基礎進階篇-進階5 自定義實現(xiàn)insmod命令實驗

    RK3568驅(qū)動指南|驅(qū)動基礎進階篇-進階5 自定義實現(xiàn)insmod命令實驗
    的頭像 發(fā)表于 02-20 14:10 ?489次閱讀
    RK3568驅(qū)動指南|驅(qū)動基礎<b class='flag-5'>進階</b>篇-<b class='flag-5'>進階</b>5 自定義<b class='flag-5'>實現(xiàn)</b>insmod命令實驗

    求助,關(guān)于PSOC4模擬EEPROM的checksum問題求解

    咨詢個問題,當我們用PSOC4的Em_EEPROM組件時,工程生成的Hex1文件的checksum是不包含了EEPROM的部分吧(通過Custom Linker Script調(diào)用cm0gcc.ld
    發(fā)表于 02-02 08:48

    RK3568驅(qū)動指南|驅(qū)動基礎進階篇-進階8 內(nèi)核運行ko文件總結(jié)

    RK3568驅(qū)動指南|驅(qū)動基礎進階篇-進階8 內(nèi)核運行ko文件總結(jié)
    的頭像 發(fā)表于 01-31 14:58 ?955次閱讀
    RK3568驅(qū)動指南|驅(qū)動基礎<b class='flag-5'>進階</b>篇-<b class='flag-5'>進階</b>8 內(nèi)核運行ko文件總結(jié)

    在IAR Embedded Workbench中計算多個地址區(qū)間的Checksum

    。但是在IDE里面的Linker > Checksum選項里面只能配置一個地址區(qū)間并且只能生成一個Checksum。如果有多個地址空間,那么IDE里面的Linker > Checksum選項沒有辦法滿足需求,需要使用命令行的方式
    的頭像 發(fā)表于 01-05 12:33 ?1235次閱讀
    在IAR Embedded Workbench中計算多個地址區(qū)間的<b class='flag-5'>Checksum</b>

    虹科技術(shù)|保障數(shù)據(jù)傳輸穩(wěn)定性:BabyLIN產(chǎn)品的CRC算法實現(xiàn)

    文章將以CRC8校驗為例,介紹在BabyLIN產(chǎn)品中如何使用CRC校驗算法。 CRC校驗原理 在CAN報文中,增加Checksum校驗,能夠用來檢測和校驗數(shù)據(jù)傳輸或保存后可能出現(xiàn)的錯誤。它是利用除法及余數(shù)的原理來作錯誤偵測的。CRC8校驗
    的頭像 發(fā)表于 01-02 10:45 ?359次閱讀
    虹科技術(shù)|保障數(shù)據(jù)傳輸穩(wěn)定性:BabyLIN產(chǎn)品的CRC<b class='flag-5'>算法</b><b class='flag-5'>實現(xiàn)</b>

    浮點LMS算法的FPGA實現(xiàn)

    引言 LMS(最小均方)算法因其收斂速度快及算法實現(xiàn)簡單等特點在自適應濾波器、自適應天線陣技術(shù)等領(lǐng)域得到了十分廣泛的應用。為了發(fā)揮算法的最佳性能,必須采用具有大動態(tài)范圍及運算精度的浮點
    的頭像 發(fā)表于 12-21 16:40 ?598次閱讀

    你了解步進階梯指令嗎?

    進階梯指令是一種在編程中常用的控制結(jié)構(gòu),它允許程序按照一定的順序執(zhí)行一系列操作。
    的頭像 發(fā)表于 12-14 17:17 ?728次閱讀
    你了解步<b class='flag-5'>進階</b>梯指令嗎?

    C語言進階之嵌入式系統(tǒng)高級C語言編程

    電子發(fā)燒友網(wǎng)站提供《C語言進階之嵌入式系統(tǒng)高級C語言編程.rar》資料免費下載
    發(fā)表于 11-18 10:32 ?1次下載
    C語言<b class='flag-5'>進階</b>之嵌入式系統(tǒng)高級C語言<b class='flag-5'>編程</b>

    CAN通信協(xié)議里一種checksum校驗和的方法

    看到了一種checksum校驗和的方法,分享給大家。
    的頭像 發(fā)表于 10-31 12:58 ?3665次閱讀
    CAN通信協(xié)議里一種<b class='flag-5'>checksum</b>校驗和的方法

    密碼算法實現(xiàn)的SCA防護

    對于安全控制器而言,密碼算法實現(xiàn)與安全性緊密相關(guān),密碼算法實現(xiàn)
    的頭像 發(fā)表于 10-11 09:12 ?511次閱讀

    北醒CTO疏達:算法和算力的進階將促進激光雷達、高階智能駕駛的發(fā)展

    近日,在“2023世界智能網(wǎng)聯(lián)汽車大會”上,北醒(北京)光子科技有限公司的CTO疏達博士表示,在“重感知、輕地圖”的形勢下,融合感知的算法、算力以及感知數(shù)據(jù)組成了驅(qū)動智駕能力升級的鐵三角,算法和算力
    的頭像 發(fā)表于 10-07 09:43 ?629次閱讀
    北醒CTO疏達:<b class='flag-5'>算法</b>和算力的<b class='flag-5'>進階</b>將促進激光雷達、高階智能駕駛的發(fā)展