组合逻辑LUT和时序逻辑REG

LUT(Look-Up-Table):查找表。 
LUT本质上就是一个RAM。它把数据事先写入RAM后, 
每当输入一个信号就等于输入一个地址进行查表,找出地址对应的内容,然后输出。


LATCH :就是锁存器。由电平触发,非同步控制。在使能信号有效时latch相当于通路,在使能信号无效时latch保持输出状态。

 

LUT和LATCH 他们的共同点是:均属于组合逻辑(和时钟没有半点关系)。

不同点是:LUT是FPGA最小单元的组成结构,而LATCH不是。


说道LATCH就不得不提到FF,FF(Flip Flop):触发器。

那么DFF就是,众所周知的D类触发器。它是边沿触发的,归为时序逻辑。

他和reg又有着什么关系呢?reg就是由DFF组成的。一个8位的寄存器,就是用了8个同步的D触发器。


一般一个FPGA最小单元就会包含多个LUT和多个REG,且REG的个数多于LUT。(这个以后再具体分析)


关系都找出来了,我们来做些实验,看看下列代码都能综合出什么东西:

实验1:


module testlatch
(
	input a,
	input b,
	output reg q
);

	always @(a or b)
		if(a == 1'b1)
			q = b;
	
endmodule


组合逻辑LUT和时序逻辑REG_第1张图片

实验2:


module testlatch
(
	input a,
	input b,
	output reg q
);

	always @(a or b)
		if(a == 1'b1)
			q = b;
		else 
			q = a;
	
endmodule


组合逻辑LUT和时序逻辑REG_第2张图片

实验3:

module testlatch
(
	input CLK,
	input a,
	input b,
	output reg q
);

	always @(posedge CLK)
		if(a == 1'b1)
			q = b;

endmodule




组合逻辑LUT和时序逻辑REG_第3张图片


总结:
1、always (*)或者 assign 综合出的就是LUT构建的东西,可认为就是LUT。
2、在always (*)的情况下,如果if 或者cace 不完整的话,会综合出latch,导致不稳定。

3、在always (posedge CLK)的情况下,综合出的是reg,即使if,或者case不完整,也不会综合出latch。

4、不要用latch作为模块名,会报错,这个名字已经被Quartus占用了。


大家可能会说,并没有看到LUT,我们知道LUT就是查找表,去technology Map Viewer,去看看: 

组合逻辑LUT和时序逻辑REG_第4张图片

就知道RTL那些  “梯形的选择器” ,其实就是由LUT构成的!!


梯形选择器,类似于:

组合逻辑LUT和时序逻辑REG_第5张图片    组合逻辑LUT和时序逻辑REG_第6张图片     组合逻辑LUT和时序逻辑REG_第7张图片



一句话点题:

            万能查表法再加上寄存器就保证了快速运算逻辑,这就是FPGA!



技术讨论欢迎加群~~电子技术协会   362584474

你可能感兴趣的:(fpga)