| module top ( | |
| input clk, | |
| output LED1, | |
| output LED2, | |
| output LED3, | |
| output LED4, | |
| output LED5 | |
| ); | |
| localparam BITS = 3; | |
| localparam LOG2DELAY = 22; | |
| reg [BITS+LOG2DELAY-1:0] counter = 0; | |
| reg [BITS-1:0] outcnt = 0; | |
| always @(posedge clk) begin | |
| counter <= counter + 1; | |
| outcnt <= counter >> LOG2DELAY; | |
| end | |
| assign {LED1, LED2, LED3, LED4, LED5} = outcnt ^ (outcnt >> 1); | |
| endmodule |