二、9【FPGA】时序逻辑电路——寄存器

本文档记录了使用FPGA通过D触发器实现按键控制LED灯亮灭的实践过程,包括同步和异步时序电路的设计、仿真及上板验证。在同步电路中,LED灯在按键未按时保持亮态,按键按下时熄灭;而在异步电路中,增加了复位信号的处理。通过逻辑仿真验证了设计,并提供了详细的代码和波形图。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

学习说明此文档为本人的学习笔记,注重实践,关于理论部分会给出相应的学习链接。

学习视频:是根据野火FPGA视频教程——第十一讲
https://www.bilibili.com/video/BV1nQ4y1Z7zN?p=3

学习资料:《数字电子技术基础》清华大学出版社

理论学习

相关数字电路基础理论学习请参考本人的另一个笔记,可以让你深刻理解相关知识。

《数字电子技术基础》6.3 时序逻辑电路——寄存器和计数器功能介绍_追逐者-桥的博客-优快云博客寄存器和移位寄存器、计数器功能介绍https://blog.youkuaiyun.com/ARM_qiao/article/details/124415549

实战演练

一、设计规划

1.1 实验(项目)目标

使用D触发器来控制LED灯,当按键未按下时led灯处于点亮状态;当按键被按下时led灯熄灭。

1.2 硬件资源:

二、程序设计

2.1 模块框图及波形图  

输入输出信号描述
信号位宽类型功能描述
sys_clk1bitinput工作时钟信号,频率50MHz
sys_ret_n1bitinput复位信号,低电平有效
key_in1bitinput按键输入信号
led_out1bitoutput输出控制LED灯

2.2 代码编写

同步时序电路:

`timescale 1ns / 1ps
//////////////////////////////////////////////////////////////////////////////////
// Company: 追逐者——桥的小作坊
// Engineer: 
// 
// Create Date: 2022/04/25 09:23:40
// Design Name: D触发器实现按键控制LED
// Module Name: counter4
// Project Name: 
// Target Devices: 
// Tool Versions: Vivado 2018_3
// Description: 
// 
// Dependencies: 
// 
// Revision:
// Revision 0.01 - File Created
// Additional Comments:视频学习代码
// 
//////////////////////////////////////////////////////////////////////////////////

module flip_flop(
    input wire sys_clk, sys_ret_n, key_in,
    output reg led_out
    );
    
    always@(posedge sys_clk)
        if(sys_ret_n == 1'b0)
            led_out <= 1'b0;
        else
            led_out <= key_in;    
endmodule

RTL视图 

异步时序逻辑电路

module flip_flop(
    input wire sys_clk, sys_ret_n, key_in,
    output reg led_out
    );
    
    always@(posedge sys_clk or negedge sys_ret_n)    //添加条件
        if(sys_ret_n == 1'b0)
            led_out <= 1'b0;
        else
            led_out <= key_in;    
endmodule

三、逻辑仿真

3.1 仿真文件的编写

`timescale 1ns / 1ns
//////////////////////////////////////////////////////////////////////////////////
// Company: 追逐者——桥的小作坊
// Engineer: 
// 
// Create Date: 2022/04/25 09:23:40
// Design Name: D触发器实现按键控制LED
// Module Name: counter4
// Project Name: 
// Target Devices: 
// Tool Versions: Vivado 2018_3
// Description: 
// 
// Dependencies: 
// 
// Revision:
// Revision 0.01 - File Created
// Additional Comments:视频学习代码
// 
//////////////////////////////////////////////////////////////////////////////////
module tb_flip_flop();
    reg sys_clk, sys_ret_n, key_in;
    wire led_out;
    initial begin
        sys_clk = 1'b1;
        sys_ret_n <= 1'b0;
        key_in <= 1'b0;
        #20
        sys_ret_n <= 1'b1;
        
        #210
        sys_ret_n <= 1'b0;
        
        #40
        sys_ret_n <= 1'b1;
    end
    always #10 sys_clk = ~sys_clk;  //模拟时钟,没10ns电平翻转一次,周期20ns,频率50MHz
    always #20 key_in <= {$random} % 2;
    initial begin
        $timeformat(-9, 0, "ns", 6);
        $monitor("@time %t:key_in=%b, led_out=%b", $time, key_in, led_out);
    end
    flip_flop ff_inst(sys_clk, sys_ret_n, key_in, led_out);
endmodule

3.2 仿真波形图对比

从仿真图与波形图对比发现,输出未正常同步时序电路控制。 

四、上板验证

请参考之前按键控制LED灯的实战:

二、3【FPGA】如何点亮LED灯_追逐者-桥的博客-优快云博客FPGA开发 按键控制LED灯的亮灭Xilinx Artix7https://blog.youkuaiyun.com/ARM_qiao/article/details/123969251

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

追逐者-桥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值