HDLBits刷题记录——FSM Q2a

导言

这题是个实现仲裁电路的状态机。有了此题的状态转移图和文字描述,实现仲裁电路的难度下降了许多。

代码

module top_module (
    input clk,
    input resetn,    // active-low synchronous reset
    input [3:1] r,   // request
    output [3:1] g   // grant
); 
    
    parameter A=2'b00,B=2'b01,C=2'b10,D=2'b11;
    reg [1:0] state,next;
    
    always@(posedge clk) begin
        if(~resetn) begin
            state <= A;
        end
        else begin
            state <= next;
        end
    end
    
    always@* begin
        case(state)
            A: next = r[1] ? B:(r[2] ? C:(r[3] ? D:A));
            B: next = r[1] ? B:A;
            C: next = r[2] ? C:A;
            D: next = r[3] ? D:A;
        endcase
    end
    
    always@(posedge clk) begin
        if(~resetn) begin
            g <= 3'b000;
        end
        else begin
            case(next)
                A: g <= 3'b000;
                B: g <= 3'b001;
                C: g <= 3'b010;
                D: g <= 3'b100;
                default: g <= 3'b000;
            endcase
        end
    end

endmodule

小结

这应该是一个很基础的仲裁电路,其他仲裁结构可以根据自定义的优先级来重新定义状态转换。状态机实现仲裁的思想值得借鉴。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值