【问题标题】:Generate inside always_comb block in SystemVerilog在 SystemVerilog 中的 always_comb 块内生成
【发布时间】:2021-07-26 09:02:56
【问题描述】:

我知道您不能在 SystemVerilog 中的 always_comb 块中包含 generate,但我想做类似于下面显示的操作,但我不知道该怎么做。

genvar i, j;
generate
for (i = 0; i < 4; i++) begin
    always_comb begin 
        unique case (STATE) 
            0: begin
               ...
               for(j = 0; j < 8; j++)
                   var[j*8+2*i+1:j*8+2*i] = 2'b11;
            end
            ...
        endcase

    end
end
endgenerate

现在它给了我以下编译错误:Unknown range in part select 任何帮助都将不胜感激。

【问题讨论】:

    标签: system-verilog


    【解决方案1】:
    1. var是verilog中的关键字,不能作为变量使用。
    2. genvar j 不能在 always 块内修改。
    3. partselect 在系统 verilog 中必须至少有一个恒定的宽度。
    4. 你错过了endgenerate

    所以,你需要

    1. var 重命名为其他名称
    2. j 声明为非genvar 变量,即int
    3. 您的宽度始终为2,因此您可以使用系统verilog +:-: 范围说明符
    4. 您在系统 verilog 中不再需要 generate..endgenerate 标记。

    这是一个例子:

    genvar i;
    //generate
      for (i = 0; i < 4; i++) begin: loop
        always_comb begin 
            unique case (STATE) 
                0: begin
                   //...
                  for(int j = 0; j < 8; j++)
                    v[j*8+2*i +: 2] = 2'b11;
                       //v[j*8+2*i+1:j*8+2*i] = 2'b11;
                end
                //...
            endcase
        end
      end
    //endgenerate
    

    【讨论】:

    • 你说得对,我忘记了 endgenerate,因为这只是我为发布问题而写的一个简短示例。通过使用:+ 我可以解决我的问题:)。非常感谢! (还有,不知道j不能修改)
    猜你喜欢
    • 2020-12-10
    • 1970-01-01
    • 2021-08-04
    • 2016-10-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-07-05
    • 1970-01-01
    相关资源
    最近更新 更多