【Verilog】强基础,if else 语句,以及综合RTL

对比两种写法,以及其RTL

写法1

bash 复制代码
module zaza(
    input              clk	 ,
	input              rst   ,
	output  [7:0]      a     ,
	output reg [1:0]   b
    );
    
   always @(posedge clk or posedge rst)begin 
	  if(rst)begin
	   b<=2'd0;
	  end
	  else if(a>'d6)begin
	    b<=2'd1;
	  end
	  else if(a>'d200)begin
	     b<=2'd2;
	  end
	  else begin
	     b<=2'd0;
	  end
	end
    
endmodule
bash 复制代码
因此,如果几个条件不互斥,RTL是这样处理的,其实是有优先级的。
第一个if满足后,立马就出第一个条件满足后的结果。
其实是if 有优先级的。

写法2

bash 复制代码
module zaza(
    input              clk	 ,
	input              rst   ,
	output  [7:0]      a     ,
	output reg [1:0]   b
    );
    
   always @(posedge clk or posedge rst)begin
      if(rst)begin
	   b<=2'd0;
	  end
	  else begin
	   if(a>'d6)begin
	        b<=2'd1;
	   end
	   else begin
	       if(a>'d200)begin
	           b<=2'd2;
	       end
	       else begin
	           b<=2'd0;  
	       end
	   end
	  end  
   end

endmodule

综上

综上,两种写法,综合出的电路是一样的。

其他阅读推荐:

【数字图像处理与FPGA实现】00 绪,建立"算法思维"与"硬件思维"的桥梁

相关推荐
ALINX技术博客15 小时前
【黑金云课堂】FPGA技术教程Vitis开发:PS端UART与CAN通信
fpga开发·fpga
FPGA小迷弟1 天前
FPGA工程师常见面试问题,有参考答案,必学!!!
fpga开发·面试·职场和发展·verilog·fpga·modelsim
followless2 天前
linux server中搭建questasim 10.6c & ise14.7
linux·fpga开发
乌恩大侠2 天前
【AI-RAN】WNC O-RU 配置、英伟达 AI-RAN、
fpga开发·o-ru
小麦嵌入式3 天前
FPGA入门(一):手把手教你用 Vivado 创建工程并仿真
stm32·单片机·嵌入式硬件·mcu·fpga开发·硬件架构·硬件工程
m0_46644103詹湛4 天前
(一)FPGA :基础概念详解(Xilinx平台)
笔记·学习·fpga开发·verilog
xyx-3v4 天前
ZYNQ 简介
fpga开发
xyx-3v4 天前
Zynq-7000
fpga开发
xyx-3v5 天前
zynq7010和zynq7020的区别
fpga开发
xyx-3v5 天前
LUT(Look-Up Table,查找表)的定义与核心概念
fpga开发