在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
楼主: largedeer

CRC并行实现(Verilog)

[复制链接]
发表于 2013-8-19 17:08:22 | 显示全部楼层
XIE XIE
发表于 2013-11-29 15:55:18 | 显示全部楼层
看看~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
发表于 2014-2-12 10:45:07 | 显示全部楼层
我贴出来了 !

Below code is 16-bit CRC-CCITT implementation, with following features

    * Width = 16 bits
    * Truncated polynomial = 0x1021
    * Initial value = 0xFFFF
    * Input data is NOT reflected
    * Output CRC is NOT reflected
    * No XOR is performed on the output CRC

                   

               


  1 //-----------------------------------------------------
  2 // Design Name : parallel_crc_ccitt
  3 // File Name   : parallel_crc.v
  4 // Function    : CCITT Parallel CRC
  5 // Coder       : Deepak Kumar Tala
  6 //-----------------------------------------------------
  7 module parallel_crc_ccitt (
  8 clk     ,
  9 reset   ,
10 enable  ,
11 init    ,
12 data_in ,
13 crc_out
14 );
15 //-----------Input Ports---------------
16 input clk     ;
17 input reset   ;
18 input enable  ;
19 input init    ;
20 input [7:0] data_in ;
21 //-----------Output Ports---------------
22 output [15:0] crc_out;
23 //------------Internal Variables--------
24 reg [15:0]   crc_reg;
25 wire [15:0]  next_crc;
26 //-------------Code Start-----------------
27 assign crc_out = crc_reg;
28 // CRC Control logic
29 always @ (posedge clk)
30 if (reset) begin
31   crc_reg <= 16'hFFFF;
32 end else if (enable) begin
33   if (init) begin
34      crc_reg <= 16'hFFFF;
35   end else begin
36      crc_reg <= next_crc;
37   end
38 end
39 // Parallel CRC calculation
40 assign next_crc[0] = data_in[7] ^ data_in[0] ^ crc_reg[4] ^ crc_reg[11];
41 assign next_crc[1] = data_in[1] ^ crc_reg[5];
42 assign next_crc[2] = data_in[2] ^ crc_reg[6];
43 assign next_crc[3] = data_in[3] ^ crc_reg[7];
44 assign next_crc[4] = data_in[4] ^ crc_reg[8];
45 assign next_crc[5] = data_in[7] ^ data_in[5] ^ data_in[0] ^ crc_reg[4] ^ crc_reg[9] ^ crc_reg[11];
46 assign next_crc[6] = data_in[6] ^ data_in[1] ^ crc_reg[5] ^ crc_reg[10];
47 assign next_crc[7] = data_in[7] ^ data_in[2] ^ crc_reg[6] ^ crc_reg[11];
48 assign next_crc[8] = data_in[3] ^ crc_reg[0] ^ crc_reg[7];
49 assign next_crc[9] = data_in[4] ^ crc_reg[1] ^ crc_reg[8];
50 assign next_crc[10] = data_in[5] ^ crc_reg[2] ^ crc_reg[9];
51 assign next_crc[11] = data_in[6] ^ crc_reg[3] ^ crc_reg[10];
52
53 endmodule
发表于 2014-3-28 23:54:18 | 显示全部楼层
看看看看
发表于 2014-3-30 22:36:19 | 显示全部楼层
谢谢分享。
发表于 2014-5-14 11:57:30 | 显示全部楼层
xie xie    !!!!!!
发表于 2015-5-10 20:38:39 | 显示全部楼层
看看再说
发表于 2015-7-7 14:32:41 | 显示全部楼层
回复 1# largedeer


    thanks
发表于 2015-11-4 16:41:06 | 显示全部楼层
谢谢好人
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条


小黑屋| 手机版| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-12-23 16:17 , Processed in 0.019985 second(s), 7 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表