1、概述
锁存器和触发器有时组合在一起,因为它们都可以在其输出上存储一位(1或0)。与锁存器相比,触发器是需要时钟信号(Clk)的同步电路。D 触发器仅在时钟从0 到 1(上升沿)或 1 到 0(下降沿)时存储来自 D 输入的新值。我们在FGPA开发中对D触发器进行设计,不同考虑其内部结构,只要根据需求实现当时钟信号上升沿或者下降沿到来时,输出的值等于输入D的值就行。
2、测试文件的编写
因为D触发器设计非常简单,这里就不多做介绍,直接上代码,新建一个d_ff.v文件(这里建立的.v文件必须和模块名一致,否则会报错):
//异步复位的D触发器
module d_ff(
input clk,
input rst_n,
input d ,
output reg q
);
always@(posedge clk or negedge rst_n) begin
if(!rst_n)
q<=1'b0;
else
q<=d;
end
endmodule
这里开始用到了时序电路,所以在后面的仿真中我们需要注意时序电路慢一拍输出的特性。
3、测试文件的编写
新建一个d_ff_tb.v文件,如下:
//定义时间尺度
`timescale 1ns/1ns
module d_ff_tb;
reg clk;
reg rst_n;
reg d;
wire q;
d_ff dff(