forked from Github_Repos/cvw
35 lines
821 B
Systemverilog
35 lines
821 B
Systemverilog
|
module sd_crc_7(BITVAL, Enable, CLK, RST, CRC);
|
||
|
input BITVAL;// Next input bit
|
||
|
input Enable;
|
||
|
input CLK; // Current bit valid (Clock)
|
||
|
input RST; // Init CRC value
|
||
|
output [6:0] CRC; // Current output CRC value
|
||
|
|
||
|
reg [6:0] CRC;
|
||
|
// We need output registers
|
||
|
wire inv;
|
||
|
|
||
|
assign inv = BITVAL ^ CRC[6]; // XOR required?
|
||
|
|
||
|
|
||
|
always @(posedge CLK or posedge RST) begin
|
||
|
if (RST) begin
|
||
|
CRC = 0;
|
||
|
|
||
|
end
|
||
|
else begin
|
||
|
if (Enable==1) begin
|
||
|
CRC[6] = CRC[5];
|
||
|
CRC[5] = CRC[4];
|
||
|
CRC[4] = CRC[3];
|
||
|
CRC[3] = CRC[2] ^ inv;
|
||
|
CRC[2] = CRC[1];
|
||
|
CRC[1] = CRC[0];
|
||
|
CRC[0] = inv;
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
endmodule
|
||
|
|