报错信息[Synth 8-2576]

开放1 回答 169 浏览

报错信息[Synth 8-2576] procedural assignment to a non-register data is not permitted。

分享:
  • 二牛学FPGA

    原因:信号没有被声明,多出在输出信号下。

    措施:信号在 always 语句块中,被赋值的信号应该添加类型 reg。

    ————————————

    vivado 报错之procedural assignment to a non-register result is not permitted

    这个错误通常是由于尝试在非寄存器类型的对象上进行过程赋值所引起的。在 Verilog 中,当使用 always 块时,其中的赋值操作应该只用于寄存器类型的变量,比如 reg 类型。非寄存器类型的信号(比如 wire)不能在 always 块内进行赋值。

    出现这个错误的原因可能是在非寄存器类型的信号上尝试进行赋值操作。在您的代码中,如果 output_data 是一个 wire 类型的信号,而您尝试在 always 块内给它赋值,这将导致这个错误。

    解决这个问题的方法是将 output_data 声明为 reg 类型,而不是 wire 类型。修改代码如下:

    module Data_Selector(
        input [3:0] data0,  // 输入数据0
        input [3:0] data1,  // 输入数据1
        input sel,           // 选择信号
        output reg [3:0] output_data  // 输出数据(改为 reg 类型)
    );
    
    always @(*) begin
        // 使用条件运算符根据选择信号sel选择数据
        output_data = (sel == 1'b0) ? data0 : data1;
    end
    
    endmodule

    通过将 output_data 的声明从 wire 改为 reg 类型,您可以在 always 块内对其进行赋值,从而避免这个错误。

登录后可在本页底部提交回答

提问者

爱提问的小白白查看主页

描述场景与已尝试方案,更容易获得有效解答

浏览「技术分享」

相关问题

同分类问答

提问建议

  • 标题写清核心疑问,避免「求助」「请问」等空泛用语
  • 正文补充环境、版本、报错信息或截图
  • 先搜索本站是否已有相近问题,减少重复提问
  • 若与课程相关,请标明课时或章节便于讲师定位

技术问答

问完之后的闭环

  • 关联课程精学高频问题往往对应章节,建议回到课程补基础。
  • 产出与互助解决过程可写成笔记,帮助后续同学。

探索全站