usbf_crc16.v

来自「USB2.0 chip的一部分verilog源码。opencore上下的」· Verilog 代码 · 共 44 行

V
44
字号
//                            `include "usbf_defines.v"/////////////////////////////////////////////////////////////////////// CRC16/////////////////////////////////////////////////////////////////////module usbf_crc16(crc_in, din, crc_out);input	[15:0]	crc_in;input	[7:0]	din;output	[15:0]	crc_out;assign crc_out[0] =	din[7] ^ din[6] ^ din[5] ^ din[4] ^ din[3] ^			din[2] ^ din[1] ^ din[0] ^ crc_in[8] ^ crc_in[9] ^			crc_in[10] ^ crc_in[11] ^ crc_in[12] ^ crc_in[13] ^			crc_in[14] ^ crc_in[15];assign crc_out[1] =	din[7] ^ din[6] ^ din[5] ^ din[4] ^ din[3] ^ din[2] ^			din[1] ^ crc_in[9] ^ crc_in[10] ^ crc_in[11] ^			crc_in[12] ^ crc_in[13] ^ crc_in[14] ^ crc_in[15];assign crc_out[2] =	din[1] ^ din[0] ^ crc_in[8] ^ crc_in[9];assign crc_out[3] =	din[2] ^ din[1] ^ crc_in[9] ^ crc_in[10];assign crc_out[4] =	din[3] ^ din[2] ^ crc_in[10] ^ crc_in[11];assign crc_out[5] =	din[4] ^ din[3] ^ crc_in[11] ^ crc_in[12];assign crc_out[6] =	din[5] ^ din[4] ^ crc_in[12] ^ crc_in[13];assign crc_out[7] =	din[6] ^ din[5] ^ crc_in[13] ^ crc_in[14];assign crc_out[8] =	din[7] ^ din[6] ^ crc_in[0] ^ crc_in[14] ^ crc_in[15];assign crc_out[9] =	din[7] ^ crc_in[1] ^ crc_in[15];assign crc_out[10] =	crc_in[2];assign crc_out[11] =	crc_in[3];assign crc_out[12] =	crc_in[4];assign crc_out[13] =	crc_in[5];assign crc_out[14] =	crc_in[6];assign crc_out[15] =	din[7] ^ din[6] ^ din[5] ^ din[4] ^ din[3] ^ din[2] ^			din[1] ^ din[0] ^ crc_in[7] ^ crc_in[8] ^ crc_in[9] ^			crc_in[10] ^ crc_in[11] ^ crc_in[12] ^ crc_in[13] ^			crc_in[14] ^ crc_in[15];endmodule

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?