色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

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

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

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

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

CRC與Checksum區(qū)別

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

01

兩者存放位置不同

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

02

兩者應(yīng)用場景不同

在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的應(yīng)用場景

對于Checksum而言,它的應(yīng)用場景有以下三點:

01

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

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

01

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

CAN網(wǎng)絡(luò)是開放性的,CAN節(jié)點可以隨時加入到總線當(dāng)中,為了保證通信的安全性,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的作用,其也常應(yīng)用在車載以太網(wǎng)當(dā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信號跟著更新,提高校驗的準(zhǔn)確性。那么LiveCounter信號該如何仿真呢?下面以CAN總線DBC為例,介紹在CAPL中實現(xiàn)LiveCounter和Checksum校驗仿真。

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

下圖為LiveCounter計算的代碼,為了保證數(shù)據(jù)的準(zhǔn)確性,進行一次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ù)組當(dāng)中,然后對這個數(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ù)必須準(zhǔn)確,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滿足仿真、分析、測試和診斷的各種復(fù)雜的要求,同時使CANoe的功能得以不斷擴展。
北匯信息作為Vector中國的合作伙伴,致力于為中國汽車客戶提供優(yōu)質(zhì)的工具支持、解決方案以及測試服務(wù)。

注:圖片來自于Vector。

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

    關(guān)注

    88

    文章

    3614

    瀏覽量

    93686
收藏 人收藏

    評論

    相關(guān)推薦

    【「從算法到電路—數(shù)字芯片算法的電路實現(xiàn)」閱讀體驗】+內(nèi)容簡介

    內(nèi)容簡介這是一本深入解讀基礎(chǔ)算法及其電路設(shè)計,以打通算法研發(fā)到數(shù)字IC設(shè)計的實現(xiàn)屏障,以及指導(dǎo)芯片設(shè)計工程師從底層掌握復(fù)雜電路設(shè)計與優(yōu)化方法為目標(biāo)的專業(yè)技術(shù)書。任何芯片(如WiFi芯片、5G芯片
    發(fā)表于 11-21 17:14

    【「從算法到電路—數(shù)字芯片算法的電路實現(xiàn)」閱讀體驗】+介紹基礎(chǔ)硬件算法模塊

    作為嵌入式開發(fā)者往往比較關(guān)注硬件和軟件的協(xié)調(diào)。本書介紹了除法器,信號發(fā)生器,濾波器,分頻器等基本算法的電路實現(xiàn),雖然都是基礎(chǔ)內(nèi)容,但是也是最常用到的基本模塊。 隨著逆全球化趨勢的出現(xiàn),過去的研發(fā)
    發(fā)表于 11-21 17:05

    【「從算法到電路—數(shù)字芯片算法的電路實現(xiàn)」閱讀體驗】+一本介紹基礎(chǔ)硬件算法模塊實現(xiàn)的好書

    作為嵌入式開發(fā)者往往比較關(guān)注硬件和軟件的協(xié)調(diào)。本書介紹了除法器,信號發(fā)生器,濾波器,分頻器等基本算法的電路實現(xiàn),雖然都是基礎(chǔ)內(nèi)容,但是也是最常用到的基本模塊,本書的內(nèi)容比較對本人胃口。 我們先來
    發(fā)表于 11-20 13:42

    C加密算法實現(xiàn)

    電子發(fā)燒友網(wǎng)站提供《C加密算法實現(xiàn).pdf》資料免費下載
    發(fā)表于 09-20 11:10 ?1次下載
    C加密<b class='flag-5'>算法</b>的<b class='flag-5'>實現(xiàn)</b>

    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)絡(luò)的基本原理及Python編程實現(xiàn)

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

    FPGA能實現(xiàn)什么樣的算法

    FPGA功能如此強大,請問用FPGA能實現(xiàn)或者比較適合實現(xiàn)什么樣的算法
    發(fā)表于 05-26 20:18

    UM0560手冊上說明發(fā)送數(shù)據(jù)時的checksum XOR (N,[N+1 data bytes])是什么意思?

    想用STM8S自帶的bootloader 通過CAN升級軟件,有誰知道UM0560手冊上說明發(fā)送數(shù)據(jù)時的checksum XOR (N,[N+1 data bytes])是什么意思?如果發(fā)送128個數(shù)據(jù)這個checksum=XOR(127^128),還是最后2個數(shù)據(jù)異或?
    發(fā)表于 04-07 07:40

    CAPL腳本使用介紹

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

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

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

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

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

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

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

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

    RK3568驅(qū)動指南|驅(qū)動基礎(chǔ)進階篇-進階8 內(nèi)核運行ko文件總結(jié)
    的頭像 發(fā)表于 01-31 14:58 ?1145次閱讀
    RK3568驅(qū)動指南|驅(qū)動基礎(chǔ)<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 ?1523次閱讀
    在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 ?498次閱讀
    虹科技術(shù)|保障數(shù)據(jù)傳輸穩(wěn)定性:BabyLIN產(chǎn)品的CRC<b class='flag-5'>算法</b><b class='flag-5'>實現(xiàn)</b>
    主站蜘蛛池模板: 亚洲一级特黄| 亚洲国产欧美日本大妈| 校花在公车上被内射好舒| 亚洲狠狠97婷婷综合久久久久| 在线观看免费亚洲| 成人天堂婷婷青青视频在线观看| 国产人妻人伦精品98| 老司机福利视频一区在线播放| 日韩成人黄色| 亚洲永久免费视频| 沟沟人体一区二区| 久久欧洲视频| 亚欧成人毛片一区二区三区四区| 5g天天影院天天看天天爽| 国产精品久久久久久免费字体| 精品亚洲大全| 偷窥 亚洲 色 国产 日韩| 最好看中文字幕国语| 国产久爱青草视频在线观看| 欧美含羞草免费观看全部完| 亚洲欧洲日本天天堂在线观看| 成人bt下载| 蜜臀色欲AV无人A片一区| 亚洲 欧美无码原创区| 播色屋97超碰在人人| 美女脱光app| 在线视频一区二区三区在线播放| 国产精品久久久久久久人热| 牛牛在线视频| 67194线在线精品观看| 久久精品天天爽夜夜爽| 小草影院免费| 国产 交换 丝雨 巅峰| 欧美高清视频www夜色资源网| 姉调无修版ova国语版| 久久精品成人免费看| 夜夜草导航| 金发欧美一区在线观看| 亚洲一区在线观看无码欧美| 韩国和日本免费不卡在线| 亚洲无码小格式|