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

本文详细介绍了Verilog HDL中时序逻辑与组合逻辑的区别及正确使用方法。强调了时序逻辑应当使用非阻塞赋值(<=),而组合逻辑则应当采用阻塞赋值(=)。此外还讨论了assign语句的应用场景及其限制。

说明always语句内存在错误。可能原因为赋值语句有错误,或者程序块内信号有问题。

阻塞赋值和非阻塞赋值

非阻塞逻辑:<=
阻塞逻辑:=
详细介绍见这位博主
总结:
1、时序逻辑一定用非阻塞赋值”<=”,一旦看到敏感列表有 posedge 就用”<=”。
2、组合逻辑一定用”=” ,一旦敏感列表没有 posedge 就用”=”,一旦看到 assign 就用”=”。
3、时序逻辑和组合逻辑分成不同的模块,即一个 always 模块里面只能出现非阻塞赋值”<=”或者”=”。
4、assign语句必须使用阻塞赋值

程序块内信号的类型

在assign内,被赋值的只能是reg类型的。而input output都是默认为wire类型。需要更改output类型的定义,例如由
output [2:0] d1
改为
output reg [2:0] d1

INFO: [VRFC 10-2263] Analyzing Verilog file "E:/zuoye/vivado/112205/112205.srcs/sources_1/new/counter.v" into library xil_defaultlib INFO: [VRFC 10-311] analyzing module counter INFO: [VRFC 10-2263] Analyzing Verilog file "E:/zuoye/vivado/112205/112205.srcs/sources_1/new/seg_decoder.v" into library xil_defaultlib INFO: [VRFC 10-311] analyzing module seg_decoder ERROR: [VRFC 10-1280] procedural assignment to a non-register seg is not permitted, left-hand side should be reg/integer/time/genvar [E:/zuoye/vivado/112205/112205.srcs/sources_1/new/seg_decoder.v:7] ERROR: [VRFC 10-1280] procedural assignment to a non-register seg is not permitted, left-hand side should be reg/integer/time/genvar [E:/zuoye/vivado/112205/112205.srcs/sources_1/new/seg_decoder.v:8] ERROR: [VRFC 10-1280] procedural assignment to a non-register seg is not permitted, left-hand side should be reg/integer/time/genvar [E:/zuoye/vivado/112205/112205.srcs/sources_1/new/seg_decoder.v:9] ERROR: [VRFC 10-1280] procedural assignment to a non-register seg is not permitted, left-hand side should be reg/integer/time/genvar [E:/zuoye/vivado/112205/112205.srcs/sources_1/new/seg_decoder.v:10] ERROR: [VRFC 10-1280] procedural assignment to a non-register seg is not permitted, left-hand side should be reg/integer/time/genvar [E:/zuoye/vivado/112205/112205.srcs/sources_1/new/seg_decoder.v:11] ERROR: [VRFC 10-1280] procedural assignment to a non-register seg is not permitted, left-hand side should be reg/integer/time/genvar [E:/zuoye/vivado/112205/112205.srcs/sources_1/new/seg_decoder.v:12] ERROR: [VRFC 10-1280] procedural assignment to a non-register seg is not permitted, left-hand side should be reg/integer/time/genvar [E:/zuoye/vivado/112205/112205.srcs/sources_1/new/seg_decoder.v:13] ERROR: [VRFC 10-1280] procedural assignment to a non-register seg is not permitted, left-hand side should be reg/integer/time/genvar [E:/zuoye/vivado/112205/112205.srcs/sources_1/new/seg_decoder.v:14] ERROR: [VRFC 10-1280] procedural assignment to a non-register seg is not permitted, left-hand side should be reg/integer/time/genvar [E:/zuoye/vivado/112205/112205.srcs/sources_1/new/seg_decoder.v:15] ERROR: [VRFC 10-1280] procedural assignment to a non-register seg is not permitted, left-hand side should be reg/integer/time/genvar [E:/zuoye/vivado/112205/112205.srcs/sources_1/new/seg_decoder.v:16] ERROR: [VRFC 10-1280] procedural assignment to a non-register seg is not permitted, left-hand side should be reg/integer/time/genvar [E:/zuoye/vivado/112205/112205.srcs/sources_1/new/seg_decoder.v:17] ERROR: [VRFC 10-8530] module 'seg_decoder' is ignored due to previous errors [E:/zuoye/vivado/112205/112205.srcs/sources_1/new/seg_decoder.v:1]
11-22
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值