| module fsm ( clock, reset, req_0, req_1, gnt_0, gnt_1 ); | |
| input clock,reset,req_0,req_1; | |
| output gnt_0,gnt_1; | |
| wire clock,reset,req_0,req_1; | |
| reg gnt_0,gnt_1; | |
| parameter SIZE = 3; | |
| parameter IDLE = 3'b001; | |
| parameter GNT0 = 3'b010; | |
| parameter GNT1 = 3'b100; | |
| parameter GNT2 = 3'b101; | |
| reg [SIZE-1:0] state; | |
| reg [SIZE-1:0] next_state; | |
| always @ (posedge clock) | |
| begin : FSM | |
| if (reset == 1'b1) begin | |
| state <= #1 IDLE; | |
| gnt_0 <= 0; | |
| gnt_1 <= 0; | |
| end | |
| else | |
| case(state) | |
| IDLE : if (req_0 == 1'b1) begin | |
| state <= #1 GNT0; | |
| gnt_0 <= 1; | |
| end else if (req_1 == 1'b1) begin | |
| gnt_1 <= 1; | |
| state <= #1 GNT0; | |
| end else begin | |
| state <= #1 IDLE; | |
| end | |
| GNT0 : if (req_0 == 1'b1) begin | |
| state <= #1 GNT0; | |
| end else begin | |
| gnt_0 <= 0; | |
| state <= #1 IDLE; | |
| end | |
| GNT1 : if (req_1 == 1'b1) begin | |
| state <= #1 GNT2; | |
| gnt_1 <= req_0; | |
| end | |
| GNT2 : if (req_0 == 1'b1) begin | |
| state <= #1 GNT1; | |
| gnt_1 <= req_1; | |
| end | |
| default : state <= #1 IDLE; | |
| endcase | |
| end | |
| endmodule |