| //----------------------------------------------------- |
| // This is FSM demo program using always block |
| // Design Name : fsm_using_always |
| // File Name : fsm_using_always.v |
| //----------------------------------------------------- |
| module fsm_using_always ( |
| clock , // clock |
| reset , // Active high, syn reset |
| req_0 , // Request 0 |
| req_1 , // Request 1 |
| gnt_0 , // Grant 0 |
| gnt_1 |
| ); |
| //-------------Input Ports----------------------------- |
| input clock,reset,req_0,req_1; |
| //-------------Output Ports---------------------------- |
| output gnt_0,gnt_1; |
| //-------------Input ports Data Type------------------- |
| wire clock,reset,req_0,req_1; |
| //-------------Output Ports Data Type------------------ |
| reg gnt_0,gnt_1; |
| //-------------Internal Constants-------------------------- |
| parameter SIZE = 3 ; |
| parameter IDLE = 3'b001,GNT0 = 3'b010,GNT1 = 3'b100 ; |
| //-------------Internal Variables--------------------------- |
| reg [SIZE-1:0] state ;// Seq part of the FSM |
| reg [SIZE-1:0] next_state ;// combo part of FSM |
| //----------Code startes Here------------------------ |
| always @ (state or req_0 or req_1) |
| begin : FSM_COMBO |
| next_state = 3'b000; |
| case(state) |
| IDLE : if (req_0 == 1'b1) begin |
| next_state = GNT0; |
| end else if (req_1 == 1'b1) begin |
| next_state= GNT1; |
| end else begin |
| next_state = IDLE; |
| end |
| GNT0 : if (req_0 == 1'b1) begin |
| next_state = GNT0; |
| end else begin |
| next_state = IDLE; |
| end |
| GNT1 : if (req_1 == 1'b1) begin |
| next_state = GNT1; |
| end else begin |
| next_state = IDLE; |
| end |
| default : next_state = IDLE; |
| endcase |
| end |
| //----------Seq Logic----------------------------- |
| always @ (posedge clock) |
| begin : FSM_SEQ |
| if (reset == 1'b1) begin |
| state <= #1 IDLE; |
| end else begin |
| state <= #1 next_state; |
| end |
| end |
| //----------Output Logic----------------------------- |
| always @ (posedge clock) |
| begin : OUTPUT_LOGIC |
| if (reset == 1'b1) begin |
| gnt_0 <= #1 1'b0; |
| gnt_1 <= #1 1'b0; |
| end |
| else begin |
| case(state) |
| IDLE : begin |
| gnt_0 <= #1 1'b0; |
| gnt_1 <= #1 1'b0; |
| end |
| GNT0 : begin |
| gnt_0 <= #1 1'b1; |
| gnt_1 <= #1 1'b0; |
| end |
| GNT1 : begin |
| gnt_0 <= #1 1'b0; |
| gnt_1 <= #1 1'b1; |
| end |
| default : begin |
| gnt_0 <= #1 1'b0; |
| gnt_1 <= #1 1'b0; |
| end |
| endcase |
| end |
| end // End Of Block OUTPUT_LOGIC |
| |
| endmodule // End of Module arbiter |