找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 3648|回復(fù): 1
打印 上一主題 下一主題
收起左側(cè)

很簡(jiǎn)練的8位CRC校驗(yàn)程序,剛接觸CRC校驗(yàn)的可以研究一下

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
如題,和移位寄存器原理差不多,只能校驗(yàn)8位,功能比較單一。

vhdl源程序如下:
  1. module crc8(                    /*x^8+x^5+x^4+1*/
  2.     input            rst,     /*async reset,active low*/
  3.     input            clk,     /*clock input*/
  4.     input     [7:0]  data_in, /*parallel data input pins */
  5.     output reg[7:0] crc
  6. );

  7. integer i;
  8. reg feedback;
  9. reg [7:0] crc_tmp;
  10. /*
  11. *  sequential process
  12. */
  13. always @(posedge clk or negedge rst)
  14. begin
  15.     if(!rst)
  16.         crc <= 8'b0;          /*觸發(fā)器中的初始值 */
  17.     else
  18.         crc <= crc_tmp;
  19. end

  20. /*
  21. *   combination process
  22. */
  23. always@( data_in)
  24. begin
  25.     crc_tmp = data_in;
  26.     for(i=7; i>=0; i=i-1)
  27.     begin
  28.         feedback    = crc_tmp[7];
  29.         crc_tmp[7]  = crc_tmp[6];
  30.         crc_tmp[6]  = crc_tmp[5];
  31.         crc_tmp[5]  = crc_tmp[4] ^ feedback;
  32.         crc_tmp[4]  = crc_tmp[3] ^ feedback;
  33.         crc_tmp[3]  = crc_tmp[2];
  34.         crc_tmp[2]  = crc_tmp[1];
  35.         crc_tmp[1]  = crc_tmp[0];
  36.         crc_tmp[0]  = feedback;
  37.      end
  38. end

  39. endmodule
復(fù)制代碼

所有資料51hei提供下載:
crc8.rar (2.27 MB, 下載次數(shù): 15)


評(píng)分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評(píng)分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:314046 發(fā)表于 2018-4-22 21:22 | 只看該作者
謝謝分享。
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表