2018-02-15 12:31:32 -06:00
|
|
|
`ifndef LFSR_V
|
|
|
|
`define LFSR_V
|
2017-11-14 19:12:52 -05:00
|
|
|
|
2018-02-13 19:04:52 -06:00
|
|
|
module LFSR(clk,reset,enable,lfsr);
|
|
|
|
|
|
|
|
parameter NBITS = 8;
|
|
|
|
parameter TAPS = 8'b11101;
|
|
|
|
parameter INVERT = 0;
|
|
|
|
|
|
|
|
input clk, reset;
|
|
|
|
input enable;
|
|
|
|
output reg [NBITS-1:0] lfsr;
|
|
|
|
|
|
|
|
wire feedback = lfsr[NBITS-1] ^ INVERT;
|
|
|
|
|
|
|
|
always @(posedge clk)
|
|
|
|
begin
|
|
|
|
if (reset) // initialize to 1
|
|
|
|
lfsr <= {lfsr[NBITS-2:1], 1'b0, 1'b1};
|
|
|
|
else if (enable)
|
|
|
|
lfsr <= {lfsr[NBITS-2:0], 1'b0} ^ (feedback ? TAPS : 0);
|
|
|
|
end
|
|
|
|
|
2018-02-15 12:31:32 -06:00
|
|
|
endmodule
|
2017-11-14 19:12:52 -05:00
|
|
|
|
2018-02-15 12:31:32 -06:00
|
|
|
`endif
|