最近在看《FPGA之道》,对此爱不释手,真是开卷有益!很想收藏一本,可惜买不到了。
进入正题,今天记录这篇笔记,应该是学习使用Verilog HDL描述硬件电路时都会遇到的问题,记录下来,供大家参考。
赋值冲突
赋值冲突,是写变量时常碰到的一类问题,其主要可分为两类,如下:
两个以上并行语句赋值冲突
这种赋值冲突就FPGA来说是致命的,因为它违背了变量操作中的“一写”的原则。关于“一写”的含义就是如果有多个并行语句需要操作一个变量时,有且只能有一个固定的并行语句可以对变量进行写操作。这篇博文:【 Verilog HDL 】正确的变量访问思路有详细介绍。
这种赋值冲突必须禁止!
两个以上串行语句的赋值冲突
这类冲突对编译器并不一定是致命的,但是由于违背了“一写”中“每次动作只能修改一次变量的值”,因此,当出现此类冲突时,FPGA设计的行为很可能与我们预期的不一致,从而造成问题。
下面我们针对纯净的组合逻辑并行语句和时序逻辑并行语句来进行赋值冲突讨论。
这类补充一点,如果在一个always中对同一变量同时应用阻塞赋值和非阻塞赋值,那么这类赋值冲突编译器是会报错的。
(1)组合并行语句内串行语句的赋值冲突
这类赋值冲突可分为三种:
第一种,无反馈的组合串行赋值冲突。这类冲突发生时,按照HDL串行语句的执行思路,可知写在最后面的一条语句才是有效的。如下