verilog - 在verilog中自动增加案例状态
问题描述
我想编写一个可合成的状态机,以有序的顺序读/写叉骨命令。
目前我定义了一些verilog宏:
`define WB_READ(READ_ADDR) \
begin \
wb_addr_o <= UART_DIV;\
wb_stb_o <= 1'b1; wb_cyc_o <= 1'b1; wb_we_o <= 1'b0; end
`define WB_WRITE(WR_ADDR, WVALUE) \
begin \
wb_addr_o <= WR_ADDR;\
wb_wdat_o <= WVALUE;\
wb_stb_o <= 1'b1; wb_cyc_o <= 1'b1; wb_we_o <= 1'b1; end\
`define WB_NOPE \
begin\
wb_stb_o <= 1'b0; wb_cyc_o <= 1'b0; wb_we_o <= 1'b0; end
并在我的 FSM 过程中使用:
always @(posedge clk or posedge rst)
if(rst) begin
count <= 8'h00;
wb_addr_o <= 8'h00;
wb_wdat_o <= 8'h00;
wb_stb_o <= 1'b0;
wb_cyc_o <= 1'b0;
wb_we_o <= 1'b0;
end
else begin
case(count)
{7'h01, 1'b1}: `WB_READ(UARD_DIV)
{7'h02, 1'b1}: `WB_READ(UARD_DIV)
{7'h03, 1'b1}: `WB_WRITE(UART_LCR, 8'h60)
{7'h04, 1'b1}: `WB_WRITE(UART_DIV, 8'h01)
{7'h05, 1'b1}: `WB_WRITE(UART_THR, 8'h55)
default: `WB_NOPE
endcase
if (count < {7'h06, 1'b1})
count <= count + 1;
end
每次计数为偶数,WB_NOPE 状态为“已执行”,每次为奇数时,执行给定的命令。
这在模拟中有效,但如果我想在状态机中间添加一个命令,我必须重新缩进所有 {7'hxx, 1'b1} 状态。并在最后增加 if(count < ...) 。
有人知道如何改进(使用宏?)以避免它吗?
解决方案
您可以在 case 语句中只使用一个整数值,并为每一步递增它。这是你的代码的一个稍微精简的版本,它可以做你想做的事情(或者至少足够接近你可以修复它:-))
module testcase (input logic clk,input logic rst);
enum logic [1:0] { READ,WRITE,NOP } op;
logic [7:0] count;
`define WB_READ begin op <= READ; end
`define WB_WRITE begin op <= WRITE; end
`define WB_NOPE begin op <= NOP; end
logic [6:0] fsm_step_number;
always @(posedge clk or posedge rst)
if(rst) begin
count <= 8'h00;
op <= NOP;
end
else begin
fsm_step_number=1;
case(count)
{(fsm_step_number++), 1'b1}: `WB_READ
{(fsm_step_number++), 1'b1}: `WB_READ
{(fsm_step_number++), 1'b1}: `WB_WRITE
{(fsm_step_number++), 1'b1}: `WB_WRITE
{(fsm_step_number++), 1'b1}: `WB_WRITE
default: `WB_NOPE
endcase
if (count < {(fsm_step_number), 1'b1})
count <= count + 1;
end
assert
endmodule
推荐阅读
- sql - Postgres ROLLUP中如何区分真正的NULL和正式的NULL?
- sql - 将日期从表转换为 MS Access 查询中的列
- python - 如何自动创建对象(例如在循环中)
- python - 增加元组数组中的值
- javascript - Tensorflowjs - KNN 分类器 - 无
- android - 如何在其他 android 应用程序中运行 android 应用程序?
- python - 如何调试 QProcess 脚本以查找行错误来自?
- github - 是否有 API 可以在 Github Teams 中为组织添加席位?
- python - 美丽的汤文字返回空白
- python - 追加到文件中的行尾