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

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

3天內不再提示

CRC校驗 、STM32中CRC計算單元、 CRC應用

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

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

1關于CRC校驗

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

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

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

---來自百度百科

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

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

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

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

參考維基百科循環(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全系列產品都具有 CRC 外設(注意,是全系列都有), 對 CRC 的計算提供硬件支持,為應用程序節(jié)省了代碼空間。

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

在眾多的應用中,基于 CRC 的技術還常用來驗證數據傳輸或存儲的完整性。

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

CRC 主要特性

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

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

單輸入/輸出 32 位數據寄存器

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

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

---來自STM32參考手冊

輸入/輸出數據的反轉

STM32默認不對輸入數據和輸出數據進行位反轉。

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

每個字節(jié)內逐位反轉,結果是 0x58D43CB2

每半字內逐位反轉,結果是 0xD458B23C

每個字長內逐位反轉,結果是 0xB23CD458

2.對輸出數據的位反轉

例如輸出數據為 0x11223344,反轉后為 0x22CC4488

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

看下標準庫的部分函數源碼:

3

CRC應用

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

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

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

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

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

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

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

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

    關注

    28

    文章

    810

    瀏覽量

    40119
  • STM32
    +關注

    關注

    2257

    文章

    10828

    瀏覽量

    352433
  • CRC校驗
    +關注

    關注

    0

    文章

    84

    瀏覽量

    15145
收藏 人收藏

    評論

    相關推薦

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

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

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

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

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

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

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

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

    RA MCUCRC模塊和使用方法

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

    fpga報告crc故障是什么意思

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

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

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

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

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

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

    電子發(fā)燒友網站提供《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配置生成對應代碼區(qū)域的CRC校驗

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

    奇偶校驗crc校驗的區(qū)別 CRC校驗和奇偶校驗之間有什么關系?

    奇偶校驗crc校驗的區(qū)別 CRC校驗和奇偶校驗之間有什么關系? 奇偶
    的頭像 發(fā)表于 10-17 16:28 ?3045次閱讀

    N32G45x硬件CRC計算Modbus的CRC16

    以前都是使用軟件CRC,浪費計算時間,有硬件CRC不用,真是可惜。本次使用硬件CRC對ModBus的CRC進行
    的頭像 發(fā)表于 10-16 15:01 ?899次閱讀
    N32G45x硬件<b class='flag-5'>CRC</b><b class='flag-5'>計算</b>Modbus的<b class='flag-5'>CRC</b>16

    單片機CRC原理及應用

    單片機CRC原理及應用
    的頭像 發(fā)表于 09-27 16:02 ?1624次閱讀
    單片機<b class='flag-5'>中</b><b class='flag-5'>CRC</b>原理及應用

    32位可編程循環(huán)冗余校驗(CRC)

    電子發(fā)燒友網站提供《32位可編程循環(huán)冗余校驗(CRC).pdf》資料免費下載
    發(fā)表于 09-25 11:22 ?0次下載
    32位可編程循環(huán)冗余<b class='flag-5'>校驗</b>(<b class='flag-5'>CRC</b>)