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

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

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

CRC校驗(yàn)和STM32中CRC計(jì)算單元相關(guān)內(nèi)容

5RJg_mcuworld ? 來源:工程師曾玲 ? 2019-02-02 16:22 ? 次閱讀

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

1關(guān)于CRC校驗(yàn)

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

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

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

---來自百度百科

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

CRC校驗(yàn)和STM32中CRC計(jì)算單元相關(guān)內(nèi)容

拿STM32參考手冊(cè)中CRC計(jì)算單元來說,使用CRC-32(以太網(wǎng))多項(xià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)冗余校驗(yà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計(jì)算單元

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

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

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

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

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

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

CRC 主要特性

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

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

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

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

8 位通用寄存器 (可用于臨時(shí)存儲(chǔ))

---來自STM32參考手冊(cè)

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

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

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

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

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

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

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

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

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

看下標(biāo)準(zhǔn)庫的部分函數(shù)源碼:

CRC校驗(yàn)和STM32中CRC計(jì)算單元相關(guān)內(nèi)容

3

CRC應(yīng)用

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

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

CRC校驗(yàn)和STM32中CRC計(jì)算單元相關(guān)內(nèi)容

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

CRC校驗(yàn)和STM32中CRC計(jì)算單元相關(guān)內(nèi)容

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

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

這個(gè)對(duì)Flash添加CRC校驗(yàn)主要目的:在遠(yuǎn)程升級(jí)程序可有效檢查程序的完整性。

在IAR EWARM中有這么一個(gè)功能:Checksum。不知道大家使用過沒,也是可以對(duì)Flash添加CRC的功能??聪聢D:

CRC校驗(yàn)和STM32中CRC計(jì)算單元相關(guān)內(nèi)容

簡單說,這里的配置可以對(duì)Flash進(jìn)行CRC計(jì)算。關(guān)于這里內(nèi)容比較多,足以單獨(dú)寫一篇文章了??赡芎竺鏁?huì)單獨(dú)寫一篇相關(guān)文章。

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

    關(guān)注

    2270

    文章

    10901

    瀏覽量

    356224
  • crc
    crc
    +關(guān)注

    關(guān)注

    0

    文章

    199

    瀏覽量

    29470

原文標(biāo)題:STM32中,CRC相關(guān)內(nèi)容都理解透了嗎?

文章出處:【微信號(hào):mcuworld,微信公眾號(hào):嵌入式資訊精選】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    如何利用循環(huán)冗余校驗(yàn)CRC計(jì)算單元進(jìn)行傳輸數(shù)據(jù)的校驗(yàn)

    循環(huán)冗余校驗(yàn)CRC計(jì)算單元是什么?如何利用循環(huán)冗余校驗(yàn)CRC
    發(fā)表于 12-15 06:04

    CRC應(yīng)用指南

    CRC應(yīng)用指南主要介紹如何使用硬件CRC 外設(shè)及CRC 原理相關(guān)內(nèi)容
    發(fā)表于 10-25 07:03

    40位以內(nèi)任意長度的CRC計(jì)算校驗(yàn)的實(shí)現(xiàn)

    論述了40位以內(nèi)任意長度的CRC計(jì)算校驗(yàn)在TMS320C5000系列DSP的實(shí)現(xiàn)方法。運(yùn)用該方法能實(shí)現(xiàn)任意信息長度的40位以內(nèi)任意CRC
    發(fā)表于 05-05 20:31 ?1900次閱讀
    40位以內(nèi)任意長度的<b class='flag-5'>CRC</b><b class='flag-5'>計(jì)算</b>及<b class='flag-5'>校驗(yàn)</b>的實(shí)現(xiàn)

    crc校驗(yàn)基本原理

    內(nèi)容介紹了crc校驗(yàn)基本原理,CRC幾個(gè)基本概念,CRC碼的生成步驟.CRC即循環(huán)冗余
    發(fā)表于 12-21 16:55 ?4714次閱讀

    crc校驗(yàn)原理_怎樣修復(fù)crc校驗(yàn)錯(cuò)誤

    crc校驗(yàn)原理 利用CRC進(jìn)行檢錯(cuò)的過程可簡單描述為:在發(fā)送端根據(jù)要傳送的k位二進(jìn)制碼序列,以一定的規(guī)則產(chǎn)生一個(gè)校驗(yàn)用的r位監(jiān)督碼(CRC
    發(fā)表于 09-05 09:26 ?3.5w次閱讀
    <b class='flag-5'>crc</b><b class='flag-5'>校驗(yàn)</b>原理_怎樣修復(fù)<b class='flag-5'>crc</b><b class='flag-5'>校驗(yàn)</b>錯(cuò)誤

    STM32L4循環(huán)冗余校驗(yàn)模塊(CRC)介紹

    STM32L4循環(huán)冗余校驗(yàn)模塊(CRC)介紹 有興趣的可以參考下
    發(fā)表于 12-25 10:38 ?27次下載

    crc校驗(yàn)錯(cuò)誤_crc校驗(yàn)錯(cuò)誤怎么解決

    CRC即循環(huán)冗余校驗(yàn)碼(Cyclic Redundancy Check[1] ):是數(shù)據(jù)通信領(lǐng)域中最常用的一種查錯(cuò)校驗(yàn)碼,其特征是信息字段和校驗(yàn)字段的長度可以任意選定。循環(huán)冗余檢查(
    發(fā)表于 12-05 15:34 ?4.8w次閱讀
    <b class='flag-5'>crc</b><b class='flag-5'>校驗(yàn)</b>錯(cuò)誤_<b class='flag-5'>crc</b><b class='flag-5'>校驗(yàn)</b>錯(cuò)誤怎么解決

    CRC計(jì)算工具CRC校驗(yàn)計(jì)算器應(yīng)用程序免費(fèi)下載

    本文檔的主要內(nèi)容詳細(xì)介紹的是CRC計(jì)算工具CRC校驗(yàn)計(jì)算器應(yīng)用程序免費(fèi)下載。
    發(fā)表于 07-01 08:00 ?135次下載
    <b class='flag-5'>CRC</b><b class='flag-5'>計(jì)算</b>工具<b class='flag-5'>CRC</b><b class='flag-5'>校驗(yàn)</b>碼<b class='flag-5'>計(jì)算</b>器應(yīng)用程序免費(fèi)下載

    CRC校驗(yàn)STM32CRC計(jì)算單元、 CRC應(yīng)用

    CRC校驗(yàn)、STM32CRC計(jì)算單元、
    的頭像 發(fā)表于 03-04 13:54 ?6120次閱讀

    CRC校驗(yàn)碼并行計(jì)算的FPGA實(shí)現(xiàn)

    用軟件實(shí)現(xiàn) CRC 校驗(yàn)計(jì)算很難滿足高速數(shù)據(jù)通信的要求 ,基于硬件的實(shí)現(xiàn)方法 ,有串行經(jīng)典算法 LFSR 電路 以及由軟件算法推導(dǎo)出來的其它各種并行
    發(fā)表于 03-28 09:34 ?30次下載
    <b class='flag-5'>CRC</b><b class='flag-5'>校驗(yàn)</b>碼并行<b class='flag-5'>計(jì)算</b>的FPGA實(shí)現(xiàn)

    關(guān)于STM32F4xx的硬件CRC32校驗(yàn)

    采用硬件CRC32校驗(yàn),于是成功入坑。STM32硬件CRC32校驗(yàn)的結(jié)果跟預(yù)期的值并不一致,參考了大神的方法,
    發(fā)表于 12-03 15:51 ?19次下載
    關(guān)于<b class='flag-5'>STM32</b>F4xx的硬件<b class='flag-5'>CRC</b>32<b class='flag-5'>校驗(yàn)</b>

    CRC校驗(yàn)原理及實(shí)現(xiàn)

    作者:王超首發(fā):電子電路開發(fā)學(xué)習(xí)目錄前言CRC算法簡介CRC計(jì)算CRC校驗(yàn)CRC
    發(fā)表于 01-26 17:37 ?30次下載
    <b class='flag-5'>CRC</b><b class='flag-5'>校驗(yàn)</b>原理及實(shí)現(xiàn)

    CRC校驗(yàn)計(jì)算過程

    據(jù)說剛過去的高考數(shù)學(xué)很難,小編當(dāng)年上學(xué)時(shí)挺喜歡數(shù)學(xué)的,最近特意復(fù)習(xí)了一下CRC校驗(yàn)計(jì)算過程。
    的頭像 發(fā)表于 07-15 11:06 ?1.2w次閱讀

    CRC循環(huán)冗余校驗(yàn)簡介

    CRC 是Cyclic Redundancy Check的縮寫,循環(huán)冗余校驗(yàn),用于校驗(yàn)數(shù)據(jù)傳輸?shù)耐暾?。一般情況下在數(shù)據(jù)發(fā)送前計(jì)算CRC
    的頭像 發(fā)表于 04-24 13:04 ?7070次閱讀
    <b class='flag-5'>CRC</b>循環(huán)冗余<b class='flag-5'>校驗(yàn)</b>簡介

    工控常用LRC XOR累加和CRC校驗(yàn)工具校驗(yàn)碼自動(dòng)生成軟件多計(jì)算方式

    CRC校驗(yàn)工具 校驗(yàn)碼自動(dòng)生成軟件支持十幾種CRC計(jì)算方式,包括MODBUS協(xié)議的CRC-16
    的頭像 發(fā)表于 11-25 14:27 ?3487次閱讀
    工控常用LRC XOR累加和<b class='flag-5'>CRC</b><b class='flag-5'>校驗(yàn)</b>工具<b class='flag-5'>校驗(yàn)</b>碼自動(dòng)生成軟件多<b class='flag-5'>計(jì)算</b>方式