【 Verilog HDL 】赋值冲突问题

最近在看《FPGA之道》,对此爱不释手,真是开卷有益!很想收藏一本,可惜买不到了。

进入正题,今天记录这篇笔记,应该是学习使用Verilog HDL描述硬件电路时都会遇到的问题,记录下来,供大家参考。


赋值冲突

赋值冲突,是写变量时常碰到的一类问题,其主要可分为两类,如下:

两个以上并行语句赋值冲突

这种赋值冲突就FPGA来说是致命的,因为它违背了变量操作中的“一写”的原则。关于“一写”的含义就是如果有多个并行语句需要操作一个变量时,有且只能有一个固定的并行语句可以对变量进行写操作。这篇博文:【 Verilog HDL 】正确的变量访问思路有详细介绍。

这种赋值冲突必须禁止!

两个以上串行语句的赋值冲突

这类冲突对编译器并不一定是致命的,但是由于违背了“一写”中“每次动作只能修改一次变量的值”,因此,当出现此类冲突时,FPGA设计的行为很可能与我们预期的不一致,从而造成问题。

下面我们针对纯净的组合逻辑并行语句和时序逻辑并行语句来进行赋值冲突讨论。

这类补充一点,如果在一个always中对同一变量同时应用阻塞赋值和非阻塞赋值,那么这类赋值冲突编译器是会报错的。

(1)组合并行语句内串行语句的赋值冲突

这类赋值冲突可分为三种:

第一种,无反馈的组合串行赋值冲突。这类冲突发生时,按照HDL串行语句的执行思路,可知写在最后面的一条语句才是有效的。如下࿱

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李锐博恩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值