www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式硬件
[導(dǎo)讀]CRC基本原理在串行數(shù)據(jù)流的最有效的檢錯(cuò)方案是CRC(Cyclic Redundancy check)循環(huán)冗余檢驗(yàn),CRC循環(huán)冗余校驗(yàn)最根本的原理就是將原始數(shù)據(jù)除以某個(gè)固定的數(shù),然后所得的余數(shù)就

CRC基本原理

在串行數(shù)據(jù)流的最有效的檢錯(cuò)方案是CRC(Cyclic Redundancy check)循環(huán)冗余檢驗(yàn),CRC循環(huán)冗余校驗(yàn)最根本的原理就是將原始數(shù)據(jù)除以某個(gè)固定的數(shù),然后所得的余數(shù)就是CRC校驗(yàn)碼,根據(jù)校驗(yàn)碼位數(shù)的不同常用的CRC循環(huán)冗余校驗(yàn)算法有:CRC8、CRC12、CCITT CRC16、ANSI CRC16、CRC32。這次我只實(shí)現(xiàn)了CRC8的算法,至于CRC16或CRC32下次再研究。

對(duì)于CRC的基本原理我們可以根據(jù)具體的硬件電路圖來(lái)理解,通常CRC循環(huán)冗余校驗(yàn)可以表示為帶有反饋的移位寄存器,移位寄存器的階數(shù)就是CRC字節(jié)的位數(shù)。另一種表示方法是將CRC表示為 X的多項(xiàng)式,X的冪次數(shù)就是CRC字節(jié)相應(yīng)的位數(shù),系數(shù)為“1”表示相對(duì)應(yīng)階數(shù)的寄存器有反饋,系數(shù)為“0”表示無(wú)反饋。

 

計(jì)算之前先將移位寄存器全部清零,然后將數(shù)據(jù)一位一位地串行方式輸入移位寄存器,當(dāng)所要計(jì)算的有用數(shù)據(jù)最后一位輸入后,此時(shí)移位寄存器中的值就是所輸入這段有用數(shù)據(jù)的CRC8校驗(yàn)值。

我們可以通過(guò)CRC8的兩個(gè)重要性質(zhì)來(lái)驗(yàn)證我們事先CRC8算法的正確性,這兩個(gè)性質(zhì)在接下來(lái)的仿真過(guò)程中要用到:

1)當(dāng)CRC8的移位寄存器的初始值為八位的數(shù)據(jù)A時(shí),如果將相同的8位數(shù)據(jù)A依次輸入給移位寄存器,寄存器將清零。也可以說(shuō)成是A除以A余數(shù)為0。

2)當(dāng)CRC8的移位寄存器的初始值為八位的數(shù)據(jù) 時(shí),如果我們將 的反碼 依次輸入給移位寄存器,移位寄存器的結(jié)果將是35H,也就是十進(jìn)制的53。利用該特性可以對(duì)CRC8算法進(jìn)行驗(yàn)證。

算法實(shí)現(xiàn)

以上所介紹的這種串行移位寄存器的方式主要是幫助我們掌握CRC校驗(yàn)的基本原理,當(dāng)然實(shí)現(xiàn)上也可以用Verilog語(yǔ)言實(shí)現(xiàn)這種硬件電路,可想而知這種方式計(jì)算起來(lái)是相當(dāng)慢的,要1個(gè)clk計(jì)算1bit。常用的CRC8算法是查找表算法。

該算法是以一次輸入8位數(shù)據(jù)din為單位的,也就是說(shuō)一個(gè)時(shí)鐘內(nèi)并行輸入一個(gè)字節(jié)數(shù)據(jù),下一個(gè)時(shí)鐘即可算出CRC8校驗(yàn)字節(jié)。利用Verilog語(yǔ)言先定義一個(gè)CRC8字節(jié)的寄存器,在CRC8寄存器內(nèi)容的基礎(chǔ)上,利用新輸入的8位數(shù)據(jù)計(jì)算新的CRC8字節(jié)來(lái)更新CRC8寄存器。如果CRC8寄存器初始值為0,那么輸入8位數(shù)據(jù)后計(jì)算得到的CRC8就有256種可能。因此,定義了一個(gè)查找表reg [7:0] CRC8_table[255:0]并初始化為如下所示:

 

下面說(shuō)下實(shí)現(xiàn)該算法的過(guò)程:輸入的8位數(shù)據(jù)din即作為查找表CRC8_table的索引i = din,然后執(zhí)行CRC8 《= CRC8_table語(yǔ)句就得到了該字節(jié)的CRC8校驗(yàn)碼,然而以上過(guò)程的前提是CRC8寄存器初始化為0,若CRC8寄存器不為0,那么查找表的索引i 的計(jì)算應(yīng)為當(dāng)前CRC8與輸入數(shù)據(jù)的異或,即 i = CRC8^din,然后執(zhí)行語(yǔ)句CRC8 《= CRC8_table就得到了新的CRC8校驗(yàn)碼。依次循環(huán)處理每個(gè)字節(jié)。。。。。。

首先定義了個(gè)module

 

SCLK輸入時(shí)鐘,在上升沿對(duì)輸入數(shù)據(jù)din[7:0]采集,使能信號(hào)EN, 計(jì)算結(jié)果CRC8[7:0]

仿真結(jié)果:

1)輸入數(shù)據(jù)依次為:8‘h11 8‘h22 8‘h33 8‘h44 8‘h55 8‘h66 8‘h77 8‘h88 在最后一個(gè)字節(jié)的下一個(gè)時(shí)鐘上升沿得到校驗(yàn)結(jié)果為8’h7b

 

2)根據(jù)性質(zhì)一,如果我們繼續(xù)輸入8‘h7b,得到的結(jié)果將是8’h00

 

3)根據(jù)性質(zhì)二,8‘h7b的反碼是8’h84,如果在1)數(shù)據(jù)的基礎(chǔ)上繼續(xù)輸入8’h84,將得到8‘h35,在封裝IP核的過(guò)程中我們只需要上一步的.v文件,也就是CRC8_LookupTable.v文件。

 

1)打開(kāi)vivado, 點(diǎn)擊 manage IP 創(chuàng)建新IP,如下圖:

 


2)選擇IP核工程路徑:CRC8_LUT_IP這個(gè)文件夾是之前創(chuàng)建的,以后我們所有的創(chuàng)建的文件都在這個(gè)文件下,這個(gè)路徑很重要

 


3)點(diǎn)擊finish后,在TOOL下拉菜單選擇Create and Package IP

 


4)點(diǎn)擊next,選擇Create New AXI4 Peripheral,注意默認(rèn)的路徑是 CRC8_LUT_IP/managed_ip_project ,這個(gè)事錯(cuò)誤的,如果在這個(gè)路徑下的話,在接下來(lái)的過(guò)程中會(huì)遇到錯(cuò)誤,將路徑改為: CRC8_LUT_IP下

 

[!--empirenews.page--]

 


5)添加IP核的詳細(xì)信息:

 


6)更改AXI總線名字,添加4個(gè)32位的slv_reg寄存器,其實(shí)都是默認(rèn)的即可

 

7)選擇Generate Drivers,點(diǎn)擊next,然后finish

 

 

8)這樣我們就可以在IP Catalog下搜索CRC,就會(huì)找到自己生成的IP核“CRC8_LUT_ip_V1_0”, 然后右鍵選擇Edit in IP Packager,這樣就會(huì)打開(kāi)IP核編輯界面:

 

9)在flow navigator欄中選擇 add aoirce 添加之前自己編輯的CRC算法的.v文件,即CRC8_LookupTable.v

 

 

10)會(huì)發(fā)現(xiàn)在工程里一共3個(gè).v文件:

CRC8_LUT_ip_v1_0_S_AXI.v 和 CRC8_LUT_ip_v1_0.v 和剛剛添加的自己的CRC8_LookupTable.v文件,然后需要修改CRC8_LUT_ip_v1_0_s_AXI.v 文件,把我們的IP核掛載到AXI總線上,其實(shí)就是一個(gè)簡(jiǎn)單的例化過(guò)程。由于我所創(chuàng)建的IP核不需要和FPGA外部通信,不用分配引腳,只需和AXI總線通信,所以就不用在CRC8_LUT_ip_v1_0_S_AXI.v添加用戶input或者output,只需把slv_reg 0 1 2 3 分別連接到sclk、en、din和CRC8.

由于slv_reg3是一個(gè)寄存器型的,所以要定義一個(gè)wie型變量CRC8,再連接到slv_reg3,不然綜合會(huì)出錯(cuò)。

 


 


11)然后保存,綜合,如果報(bào)錯(cuò),繼續(xù)修改綜合,知道沒(méi)有報(bào)錯(cuò)。

 

12)綜合完成后,點(diǎn)擊Package IP-CRC8_LUT_ip標(biāo)簽頁(yè),點(diǎn)擊Categories ,選擇我們的IP核將會(huì)出現(xiàn)在IP catalog的哪個(gè)類別里面,如果選擇“basic elements” 就會(huì)在IP catalog的basic elements類別下找到,如圖

 

 

13)添加IP核支持的芯片型號(hào),也就是添加family,因?yàn)橐趍icroZed板子上跑,所以要把zynq系列添加進(jìn)來(lái)

14)最后封裝IP,如果我們能在Create archive of IP所示的路徑下找到這個(gè)壓縮文件,就說(shuō)明我們的IP制定成功了~

 

 

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過(guò)流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問(wèn)題卻十分常見(jiàn),不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問(wèn)題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問(wèn)題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來(lái)解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開(kāi)關(guān)電源具有效率高的特性,而且開(kāi)關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開(kāi)關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉