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

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

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

CRC校驗 、STM32中CRC計算單元、 CRC應(yīng)用

黃工的嵌入式技術(shù)圈 ? 來源:黃工的嵌入式技術(shù)圈 ? 2020-03-04 13:54 ? 次閱讀

從這一段時間后臺反饋的問題可以看得出來,好些朋友對CRC沒有什么概念,今天就在這里講述一下關(guān)于CRC校驗、STM32中CRC計算單元相關(guān)內(nèi)容。

1關(guān)于CRC校驗

CRC:Cyclic Redundancy Check,即循環(huán)冗余校驗碼。

CRC是數(shù)據(jù)通信領(lǐng)域中最常用的一種查錯校驗碼,其特征是信息字段和校驗字段的長度可以任意選定。

循環(huán)冗余檢查(CRC)是一種數(shù)據(jù)傳輸檢錯功能,對數(shù)據(jù)進行多項式計算,并將得到的結(jié)果附在幀的后面,接收設(shè)備也執(zhí)行類似的算法,以保證數(shù)據(jù)傳輸?shù)恼_性和完整性。

---來自百度百科

學電子、計算機相關(guān)專業(yè)的同學都應(yīng)該學習過CRC的基礎(chǔ)原理。其原理說難不難,可以說就是一個公式。同時,說簡單也不簡單,這個公式里面包含的內(nèi)容不簡單。

拿STM32參考手冊中CRC計算單元來說,使用CRC-32(以太網(wǎng))多項式: 0x4C11DB7

─ X32 + X26 + X23 + X22 + X16 + X12 + X11 + X10 + X8 + X7 + X4 + X2 + X +1

關(guān)于CRC基礎(chǔ)原理的內(nèi)容比較多,百度、谷歌一下可以看到很多關(guān)于CRC原理的內(nèi)容,我這里就不再過多講述。

參考維基百科循環(huán)冗余校驗:

https://zh.wikipedia.org/wiki/%E5%BE%AA%E7%92%B0%E5%86%97%E9%A4%98%E6%A0%A1%E9%A9%97

2

STM32中CRC計算單元

相信初學STM32的朋友都知道STM32中有個CRC計算單元,如果有不知道的去面壁思過(參考手冊中目錄一看就能看見CRC章節(jié))。

但很多朋友都僅限知道有CRC計算單元這個東西,基本都沒怎么進一步了解過。

STM32全系列產(chǎn)品都具有 CRC 外設(shè)(注意,是全系列都有), 對 CRC 的計算提供硬件支持,為應(yīng)用程序節(jié)省了代碼空間。

STM32的CRC(循環(huán)冗余校驗)計算單元使用一個固定的多項式發(fā)生器從一個 32 位的數(shù)據(jù)字中產(chǎn)生 CRC 碼。

在眾多的應(yīng)用中,基于 CRC 的技術(shù)還常用來驗證數(shù)據(jù)傳輸或存儲的完整性。

根據(jù) EN/IEC60335-1 標準的規(guī)定,這些技術(shù)提供了驗證 Flash 完整性的方法。 CRC 計算單元有助于在運行期間計算軟件的簽名,并將該簽名與鏈接時生成并存儲在指定存儲單元的參考簽名加以比較。

CRC 主要特性

使用 CRC-32 (以太網(wǎng))多項式: 0x4C11DB7

— X32 + X26 + X23 + X22 + X16 + X12 + X11 + X10 +X8 + X7 + X5 + X4 + X2+ X +1

單輸入/輸出 32 位數(shù)據(jù)寄存器

CRC 計算在 4 個 AHB 時鐘周期 (HCLK) 內(nèi)完成

8 位通用寄存器 (可用于臨時存儲)

---來自STM32參考手冊

輸入/輸出數(shù)據(jù)的反轉(zhuǎn)

STM32默認不對輸入數(shù)據(jù)和輸出數(shù)據(jù)進行位反轉(zhuǎn)。

1.對輸入數(shù)據(jù)的位反轉(zhuǎn)操作可以設(shè)置為按字節(jié)/半字 /字為單元進行操作。例如輸入數(shù)據(jù)為 0x1A2B3C4D,

每個字節(jié)內(nèi)逐位反轉(zhuǎn),結(jié)果是 0x58D43CB2

每半字內(nèi)逐位反轉(zhuǎn),結(jié)果是 0xD458B23C

每個字長內(nèi)逐位反轉(zhuǎn),結(jié)果是 0xB23CD458

2.對輸出數(shù)據(jù)的位反轉(zhuǎn)

例如輸出數(shù)據(jù)為 0x11223344,反轉(zhuǎn)后為 0x22CC4488

操作STM32的CRC比較簡單,只有三個比較簡單的寄存器,不管是使用寄存器,還是庫函數(shù),對于大部分人來說,沒有多大難度。

看下標準庫的部分函數(shù)源碼:

3

CRC應(yīng)用

我記得讀書那個時候,想要把CRC搞明白好難啊,原因在于不知道學這個CRC到底有什么用途。

CRC用途其實非常廣泛,我們最常見的就是在一些通信上,比如:Modbus:

再比如之前講述的MAVLink通信協(xié)議:

CRC其主要目的就是驗證數(shù)據(jù)的正確性。在CRC應(yīng)用中,還有一個重要的作用:通過 CRC 校驗對 FLASH 的完整性進行檢查。

在對 FLASH 完整性檢查的應(yīng)用中,需要事先計算出整個 FLASH 的 CRC 校驗值(不包括最后保存 CRC 值的字節(jié)),放在 FLASH 的末尾。在程序啟動或者運行的過程中重新用同樣的方法計算整個 FLASH 的 CRC 校驗值,然后與保存在 FLASH 末尾的 CRC 值進行比較。

這個對Flash添加CRC校驗主要目的:在遠程升級程序可有效檢查程序的完整性。

在IAR EWARM中有這么一個功能:Checksum。不知道大家使用過沒,也是可以對Flash添加CRC的功能。看下圖:

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

    關(guān)注

    28

    文章

    824

    瀏覽量

    40192
  • STM32
    +關(guān)注

    關(guān)注

    2263

    文章

    10848

    瀏覽量

    353818
  • CRC校驗
    +關(guān)注

    關(guān)注

    0

    文章

    84

    瀏覽量

    15166
收藏 人收藏

    評論

    相關(guān)推薦

    TAS5805內(nèi)部的硬件CRC8對應(yīng)標準的哪種? CRC校驗的數(shù)據(jù)是offset和value值嗎?

    TAS5805 內(nèi)部的硬件 CRC8 對應(yīng)標準的哪種? CRC 校驗的數(shù)據(jù)是 offset 和 value 值嗎?用 PPC 加載文件計算出來的值和在線
    發(fā)表于 10-12 06:19

    如何計算BMHD的逆CRC值?

    我想知道如何計算 BMHD 的逆 CRC 值。 以Ifx_Ssw.h的示例為例 Ifx_Ssw_Bmhd結(jié)構(gòu)的頭文件和手冊。 /** BMHD 的結(jié)構(gòu)定義 * 根據(jù) BMI 和起
    發(fā)表于 05-31 06:43

    詳解TSMaster CAN 與 CANFD 的 CRC E2E 校驗方法

    面對切換工具鏈的用戶來說,在TSMaster上完成總線通訊CRC/E2E校驗處理不是特別熟悉,該文章可以協(xié)助客戶快速使用TSMaster完成CAN/CANFD總線通訊的CRC/E2
    的頭像 發(fā)表于 05-25 08:21 ?1575次閱讀
    詳解TSMaster CAN 與 CANFD 的 <b class='flag-5'>CRC</b> E2E <b class='flag-5'>校驗</b>方法

    使用C語言實現(xiàn)的CRC計算單元的例子

    使用C語言實現(xiàn)的CRC計算單元的例子
    的頭像 發(fā)表于 05-16 16:16 ?755次閱讀

    CRC(循環(huán)冗余校驗)應(yīng)用舉例

    CRC(循環(huán)冗余校驗)應(yīng)用舉例
    的頭像 發(fā)表于 05-16 16:12 ?889次閱讀

    這個CRC計算單元是如何基于固定的生成多項式(0x4C11DB7)來獲取給定數(shù)據(jù)緩沖區(qū)的CRC碼的?

    這個CRC計算單元是如何基于固定的生成多項式(0x4C11DB7)來獲取給定數(shù)據(jù)緩沖區(qū)的CRC碼的?
    的頭像 發(fā)表于 05-16 16:06 ?621次閱讀

    怎么使用hal accumulate函數(shù)完成crc分塊校驗與整體校驗crc值相等?

    怎么使用hal accumulate函數(shù)完成crc分塊校驗與整體校驗crc值相等
    發(fā)表于 03-27 07:46

    RA MCUCRC模塊和使用方法

    瑞薩RA單片機硬件CRC計算單元采用固定的多項式發(fā)生器來計算8位或者32位數(shù)據(jù)的CRC校驗值,對
    發(fā)表于 02-26 11:45 ?739次閱讀
    RA MCU<b class='flag-5'>中</b>的<b class='flag-5'>CRC</b>模塊和使用方法

    fpga報告crc故障是什么意思

    方法,通過對發(fā)送的數(shù)據(jù)進行計算并附加到數(shù)據(jù)末尾,接收方能夠使用相同的校驗算法來檢測傳輸的錯誤。CRC可以檢測多種不同類型的錯
    的頭像 發(fā)表于 01-04 11:06 ?1213次閱讀

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

    CRC校驗(循環(huán)冗余校驗)是數(shù)據(jù)通訊中最常采用的校驗方式。CAN協(xié)議,總線通信節(jié)點也常采用CRC
    的頭像 發(fā)表于 01-02 17:23 ?458次閱讀
    虹科技術(shù) | 保障數(shù)據(jù)傳輸穩(wěn)定性:BabyLIN產(chǎn)品的<b class='flag-5'>CRC</b>算法實現(xiàn)

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

    文章將以CRC8校驗為例,介紹在BabyLIN產(chǎn)品如何使用CRC校驗算法。 CRC
    的頭像 發(fā)表于 01-02 10:45 ?413次閱讀
    虹科技術(shù)|保障數(shù)據(jù)傳輸穩(wěn)定性:BabyLIN產(chǎn)品的<b class='flag-5'>CRC</b>算法實現(xiàn)

    簡述循環(huán)冗余碼crc校驗方法的工作原理

    循環(huán)冗余碼(CRC校驗是一種常用的錯誤檢測和糾正方法,廣泛應(yīng)用于通信和存儲設(shè)備,用于確定數(shù)據(jù)在傳輸或存儲過程是否出現(xiàn)錯誤。 CRC
    的頭像 發(fā)表于 12-20 11:27 ?1024次閱讀

    瑞薩RA MCUCRC模塊的使用方法

    CRC(Cyclic Redundancy Check),即循環(huán)冗余校驗碼。CRC是數(shù)據(jù)通信領(lǐng)域中最常用的一種查錯校驗碼,其特征是信息字段和校驗
    的頭像 發(fā)表于 12-07 10:23 ?1830次閱讀
    瑞薩RA MCU<b class='flag-5'>中</b><b class='flag-5'>CRC</b>模塊的使用方法

    CRC校驗原理及其軟件實現(xiàn)

    電子發(fā)燒友網(wǎng)站提供《CRC校驗原理及其軟件實現(xiàn).pdf》資料免費下載
    發(fā)表于 11-16 10:11 ?1次下載
    <b class='flag-5'>CRC</b><b class='flag-5'>校驗</b>原理及其軟件實現(xiàn)

    如何在IAR Embedded Workbench配置生成對應(yīng)代碼區(qū)域的CRC校驗

    在“使用IAR Embedded Workbench和MCU的CRC模塊來檢查代碼的完整性”一文,介紹了如何在IAR Embedded Workbench配置生成對應(yīng)代碼區(qū)域的CRC
    的頭像 發(fā)表于 10-27 11:49 ?1398次閱讀
    如何在IAR Embedded Workbench<b class='flag-5'>中</b>配置生成對應(yīng)代碼區(qū)域的<b class='flag-5'>CRC</b><b class='flag-5'>校驗</b>碼