









| Verilog              | BCD Counter Example                                                                                                                                                                                                                                                     |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ir<br>ou<br>re<br>re | ule BCDCount (CLK, clear, load, a0, a1);<br>nput CLK, reset, in;<br>utput a0, a1;<br>eg a0, a1;<br>eg [1:0] state; // state variables<br>eg [1:0] next_state;                                                                                                           |
|                      | lways @(posedge CLK) begin<br>state = next_state;<br>nd                                                                                                                                                                                                                 |
|                      | <pre>lways @(state or clear or load) begin<br/>case (state)<br/>2'b00: next_state = 2'b01;<br/>2'b01: next_state = 2'b10;<br/>2'b10: next_state = 2'b11;<br/>2'b11: next_state = 2'b00;<br/>endcase<br/>if (clear) next_state = 2'b00;<br/> // handle load<br/>nd</pre> |
| as                   | <pre>ssign a0 = state[0];<br/>ssign a0 = state[1];<br/>module<br/>CSE 370 - Spring 1999 - Verilog for Sequential Systems - 6</pre>                                                                                                                                      |





