CRC校驗算應該絕大部分理工類同學都學習過,但真正搞明白的沒幾個,之前給大家分享過《幾種常見的校驗算法》,今天結合STM32來分享其中CRC相關的內容。
1、關于CRC校驗
CRC:Cyclic Redundancy Check,即循環(huán)冗余校驗碼。
CRC是數(shù)據(jù)通信領域中最常用的一種查錯校驗碼,其特征是信息字段和校驗字段的長度可以任意選定。
循環(huán)冗余檢查(CRC)是一種數(shù)據(jù)傳輸檢錯功能,對數(shù)據(jù)進行多項式計算,并將得到的結果附在幀的后面,接收設備也執(zhí)行類似的算法,以保證數(shù)據(jù)傳輸?shù)恼_性和完整性。
---來自百度百科
學電子、計算機相關專業(yè)的同學都應該學習過CRC的基礎原理。其原理說難不難,可以說就是一個公式。同時,說簡單也不簡單,這個公式里面包含的內容不簡單。

拿STM32參考手冊中CRC計算單元來說,使用CRC-32(以太網(wǎng))多項式:0x4C11DB7─ X32 + X26 + X23 + X22 + X16 + X12 + X11 + X10 + X8 + X7 + X4 + X2 + X +1
關于CRC基礎原理的內容比較多,百度、谷歌一下可以看到很多關于CRC原理的內容,我這里就不再過多講述。
參考維基百科循環(huán)冗余校驗
2、STM32中CRC計算單元
相信初學STM32的朋友都知道STM32中有個CRC計算單元,如果有不知道的去面壁思過(參考手冊中目錄一看就能看見CRC章節(jié))。
但很多朋友都僅限知道有CRC計算單元這個東西,基本都沒怎么進一步了解過。
STM32全系列產品都具有 CRC 外設(注意,是全系列都有), 對 CRC 的計算提供硬件支持,為應用程序節(jié)省了代碼空間。
STM32的CRC(循環(huán)冗余校驗)計算單元使用一個固定的多項式發(fā)生器從一個 32 位的數(shù)據(jù)字中產生 CRC 碼。
在眾多的應用中,基于 CRC 的技術還常用來驗證數(shù)據(jù)傳輸或存儲的完整性。
根據(jù) EN/IEC60335-1 標準的規(guī)定,這些技術提供了驗證 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) 內完成
8 位通用寄存器 (可用于臨時存儲)
---來自STM32參考手冊
輸入/輸出數(shù)據(jù)的反轉
STM32默認不對輸入數(shù)據(jù)和輸出數(shù)據(jù)進行位反轉。
1.對輸入數(shù)據(jù)的位反轉操作可以設置為按字節(jié)/半字 /字為單元進行操作。例如輸入數(shù)據(jù)為0x1A2B3C4D,
每個字節(jié)內逐位反轉,結果是 0x58D43CB2
每半字內逐位反轉,結果是 0xD458B23C
每個字長內逐位反轉,結果是 0xB23CD458
2.對輸出數(shù)據(jù)的位反轉
例如輸出數(shù)據(jù)為 0x11223344,反轉后為 0x22CC4488
操作STM32的CRC比較簡單,只有三個比較簡單的寄存器,不管是使用寄存器,還是庫函數(shù),對于大部分人來說,沒有多大難度。
看下標準庫的部分函數(shù)源碼:

3、CRC應用
我記得讀書那個時候,想要把CRC搞明白好難啊,原因在于不知道學這個CRC到底有什么用途。
CRC用途其實非常廣泛,我們最常見的就是在一些通信上,比如:Modbus:

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

CRC其主要目的就是驗證數(shù)據(jù)的正確性。在CRC應用中,還有一個重要的作用:通過 CRC 校驗對 FLASH 的完整性進行檢查。
在對 FLASH 完整性檢查的應用中,需要事先計算出整個 FLASH 的 CRC 校驗值(不包括最后保存 CRC 值的字節(jié)),放在 FLASH 的末尾。在程序啟動或者運行的過程中重新用同樣的方法計算整個 FLASH 的 CRC 校驗值,然后與保存在 FLASH 末尾的 CRC 值進行比較。
這個對Flash添加CRC校驗主要目的:在遠程升級程序可有效檢查程序的完整性。
在IAR EWARM中有這么一個功能:Checksum。不知道大家使用過沒,也是可以對Flash添加CRC的功能??聪聢D:

簡單來說,這里的配置可以對Flash進行CRC計算,關于這里內容比較多,足以單獨寫一篇文章了,感興趣的讀者可以深入了解一下。
來源:strongerHuang
免責聲明:本文為轉載文章,轉載此文目的在于傳遞更多信息,版權歸原作者所有。本文所用視頻、圖片、文字如涉及作品版權問題,請聯(lián)系小編進行處理
審核編輯 黃宇
-
單片機
+關注
關注
6076文章
45495瀏覽量
670466 -
STM32
+關注
關注
2309文章
11162瀏覽量
373482 -
crc
+關注
關注
0文章
205瀏覽量
30848
發(fā)布評論請先 登錄
單片機Flash自檢和添加CRC常見方法
CRC算法在單片機通信系統(tǒng)中的實現(xiàn)
CRC-8 高效簡練的單片機實現(xiàn)方法
簡單實用的單片機CRC快速算法
C51實現(xiàn)單片機CRC快速算法
CRC差錯檢驗法在PC機與8031單片機串行通訊中的應用
單片機通信系統(tǒng)中CRC算法與硬件環(huán)境編程的實現(xiàn)
如何實現(xiàn)軟件CRC和所選單片機中使用的硬件CRC的詳細資料概述
如何使用51單片機實現(xiàn)CRC校驗算法
Qt CRC16校驗中,有時候電腦計算的CRC值和單片機中計算的值不一樣
用于單片機的CRC數(shù)據(jù)校驗方法
RA MCU中的CRC模塊和使用方法
單片機中CRC原理及應用
評論