校招基础——锁存器和触发器

基本概念

1、名词解释

锁存器(latch)是电平触发的存储单元,数据存储的动作取决于输入时钟(或者使能)信号的电平值,尽当锁存器处于使能状态时,输出才会随着数据输入发生变化。

触发器(flipflop)是边沿敏感的存储单元,数据存储的动作由某一信号的上升或者下降沿行同步的。(钟控D触发器其实就是D锁存器,边沿D触发器才是真正的D触发器)

寄存器(register)是用来暂时存放参与运算的数据和运算结果。在实际的数字系统中,通常把能够用来存储一组二进制代码的同步时序逻辑电路称为寄存器。

 

2、锁存器和触发器的区别

锁存器同其所有的输入信号相关,是电平触发,当输入信号变化时锁存器就变化,没有时钟端,属于异步电路设计,时序分析困难且浪费大量芯片资源。

触发器受时钟控制的边沿触发,只有在时钟触发时才采样当前的输入产生输出,当然因为锁存器和触发器二者都是时序逻辑,所以输出不但同当前的输入相关,还同上一时间的输出相关。

 

3、触发器、锁存器、寄存器的区别?

由于触发器内有记忆功能,因此利用触发器可以方便地构成寄存器。由于一个触发器能够存储一位二进制码,所以把n个触发器的时钟端口连接起来就能构成一个存储n位二进制码的寄存器。从寄存数据的角度来讲,寄存器和锁存器的功能是相同的;它们的区别在于寄存器是同步时钟控制,而锁存器是电位信号控制。

 

4、锁存器有哪些缺点?

锁存器在不锁存数据时,输出端的信号随输入信号变化,就像信号通过一个缓存器一样;一旦锁存信号起锁存作用,则数据被锁住,输入信号不起作用。因此锁存器也称为透明锁存器,指的是不锁存时输出对输入是透明的。此外锁存器还有以下一些缺点:

1)对毛刺敏感,不能异步复位,所以上电后处于不确定的状态。

2)锁存器会使静态时序分析变得非常复杂。

3)在 FPGA 中,基本的单元时由查找表和触发器组成的,若生成锁存器反而需要更 多的资源。

 

5、触发器有哪些类型?

根据逻辑功能不同:RS触发器、D触发器、JK触发器、T触发器和T'触发器等。

根据触发方式不同:电平触发器、边沿触发器和主从触发器等。

根据电路结构不同:基本RS触发器,同步触发器、维持阻塞触发器、主从触发器和边沿触发器等。

 

D锁存器和D触发器专题

 

1D锁存器

所谓的 D 锁存器,就是能够将输入的单路数据D存入到锁存器中的电路,D锁存器的电路图如下图所示

 

D锁存器的特性表如下所示Qn指触发前的状态,Qn+1指触发后的状态。

 

CLk0时,Qn+1=Qn,即保持之前的状态;

CLK1时,Qn+1=D,即状态由D来决定;

现在来看一下波形,在以后的设计中的Q实际上是Qn+1,不要搞错了!这里要多说一点,很多书介绍D锁存器时喜欢将C写成CLK,实际上大多时候这个地方不是CLK

 

D 锁存器的波形图图中我们可以看出,D 是锁存器的输入信号,C 是锁存器的控制信号,Q 是锁存器的输出信号,当控制信号 C 为高电平时,输出信号 Q 将跟随输入信号 D 的变化而变化,大家看虚线内,Q 的波形等于 D 的波形。当控制信号 C 从高电平变为低电平时,输入信号 D 的状态将会决定锁存器将要锁存的状态。大家可以看到,C 由高变低的那两条虚线内,所对应的输入信号 D 为低电平,那么输出信号 Q 也将会锁存低电平。最后面的那两条虚线也同理,D 为高电平,Q 锁存高电平。

 

2、锁存器坏处 

上面已经说了锁存器的缺点,但只是文字,可能比较难懂。归根结底都是书上喜欢在介绍D锁存器时就写上CLk的字眼。我们再回顾一下锁存器和触发器概念,锁存器是电平触发,触发器是边沿触发,所以很多人看到CLK就不会分析了,殊不知,这里的CLK是看电平高低判别的,不是看边沿的,看边沿就属于D触发器了,数电书上区别如下所示:

 

              D锁存器

 

              D触发器

我们再来看看代码层面,他们的区别:

 

现在再来看一下经典题型:

 

可以看出,只要一般来说组合逻辑里elsecase不全、未写defaultelse后保持,这些情况大多会生成latch

 

3、D触发器

D触发器的分析和D锁存器几乎一致,唯一区别是触发方式是边沿触发。

 

4、D发器电路图

(1)电路结构1

 

 

(2)电路结构2

 

 

可以看出第一种和第二种是一样的效果,以后遇到题目就不要再懵逼了!

 

5

 

6、边沿触发器D输入端对于毛刺不敏感,只需要满足 setup/hold,不需要专门加滤波器?

对。

 

7D 触发器哪些端口毛刺对它没有影响(A

AD 触发端

B、时钟端

C、置位端

D、清 0

 

8、用门电路(D触发器)实现边沿检测?

 

 

9、用波形表示D触发器的功能?

  

 

10、用JK触发器和必须的门电路,实现D触发器的功能?

 

 

11D触发器带同步高置数和异步高复位端的2分频的电路,画出逻辑电路Verilog描述。

 

  

 

12画出4分频电路

 

解析:两个二分频电路相连,就是4分频

 

13、分析一下电路功能

 

4D触发器构成一个16分频的电路

A为低电平时,5D触发器全部复位,Y输出低电平A为高电平时,左边4个触发器开始分频计数,计数到第4个触发器输出高电平时,Y输出高电平。

(个人觉得功能是检测输入A高电平脉冲宽度)

  

 

14、移位寄存器

  

 

15、画出Q0Q1Q2的波形,并描述电路功能。

 

分析:Q0的输入是什么?题目没有给初值,因此我们就取寄存器初值0,那么Q0 = Q0’& Q1’=1,这个值传给Q1,维持1个节拍后传到Q2,Q2拉高。Q2拉高的这个时钟沿,Q0=1,Q0’=0,因此Q0的输入变为0了,Q0就拉低。后面Q1和Q2的波形和Q0类似。在Q2拉高的那个沿,Q0=Q0’& Q1’=1,Q0又拉高了,后面循环反复。最后电路功能可以描述为:占空比为1:2的三分频电路。

 

16、线性反馈移位寄存器(LSFR 

 

 

17、一个线性反馈移位寄存器(LSFR)的特征多项式为Fx=x4+x+1,初始态全为1,以下哪些描述是正确的?(BCD

A. 输出的m-序列为11100101

B. LFSR包含四个寄存器

C. 寄存器的状态不会出现全零

D. LFSR能够产生的不重复序列最长为15

下图是多项式对应的电路图:

 

输入初始为:1111

4个寄存器序列依次为:

1111 -> 0111 -> 1011 -> 0101 -> 1010 ->

1101 -> 0110 -> 0011 -> 1001 -> 0100->

0010 -> 0001 ->1000 -> 1100 -> 1110 ->1111

OUT 序列依次为:111101011001000

 

18画出clock gating cell的原理图

  

 

19下图中的触发器的初态均为0,试画出对应ABXY的波形。

 

AB互相缠绕,这就有点难分析了。分析X时,B看成时钟,分析YA看成时钟,带D触发器真值表即可。用状态方程会不会快一些?

 

20、

 

 

21verilog设计一个接口转换电路,接口timing如下图所示,假设clka频率为clkb频率的一半(不同源。注意图中clock关系仅为示意),且两次有效时间(wra_n有效)的间隔时间足够长。

 

module interface_change
(
   input         clka ,
   input         wra_n,
   input         da ,
   input         clkb,
   output  [7:0] db ,
   output        wrb
);
reg [7:0] data = 0 ;

always@(posedge clka) begin
        if(!wra_n)begin
                data<= {data[6:0],da} ;
        end
end

reg wra_n_reg1 ,wra_n_reg2 ;

always@(posedge clkb ) begin
        wra_n_reg1<= wra_n ;
        wra_n_reg2<= wra_n_reg1 ;
end

wire wra_n_check ;

assign wra_n_check = wra_n_reg1&&(!wra_n_reg2) ;
assign wrb = wra_n_check;
assign db = (wra_n_check == 1'b1) ? data :0 ;

endmodule

 

22、编写代码,完成带异步清 0,同步置 1(低电平有效)的 D 触发器

 

 

23、于时序逻辑编码,下列描述正确的是(C

  A、设计中所有寄存器必须带复位;

  B、设计中不能使用latch

  C、一个功能模块通常只使用一个时钟沿;

  D、异步复位信号可以插入组合逻辑,不影响功能;

 

24、下面关于时序部件描述错误的为(D 

A、触发器的setup+hold通常大于0

B、锁存器在时钟为窄脉中的驱动下可以作为触发器使用

C、逻辑路径插入触发器可以提高电路运行速度

D、触发器的setup不能为负数

 

posted @ 2020-09-10 10:01  咸鱼IC  阅读(4522)  评论(0编辑  收藏  举报