0

萌新提问大佬:请问case语句太多有简便得编写方法吗?

比如

always @(posedge clk or negedge rst_n)
begin
    if(!rst_n)
    begin
        case(a)
            8'd0: begin
                data[0] <= data_in;
            end
            8'd1: begin
                data[1] <= data_in;
            end
            ...
            ...
            8'd255: begin
                data[255] <= data_in;
            end
        endcase
    end
    else
    begin
        case(ctl)
            8'd0: begin
                data[0] <= ~data_in;
            end
            8'd1: begin
                data[1] <= ~data_in;
            end
            ...
            ...
            8'd255: begin
                data[255] <= `data_in;
            end
        endcase
    end
end

能够不写256个case语句吗?规模大到2000难道也要手写?

编辑 重设标签(回车键确认) 标为违禁 关闭 合并 删除
匿名用户

匿名

想向站长提问,微信扫码立刻加入! shawn的FPGA圈.png
0

直接拿脚本生成吧,兄弟,所以我说学FPGA,最好你会一门脚本语言,老一点的就是Tcl咯,新一点的python吧。当然你也可以搞个ROM,然后自己做一个类似于CPU的译码取指。

编辑 标为违禁 删除 链接 更多选项...
shawn 头像
登录/注册后进行回答

提问工具

1 follower

统计

已提问: 2020-09-14 19:53:20 +0800

已查看: 40 次

最后更新: Sep 16