FPGA学习-基于 DE2-115 板的 Verilog 分秒计数器设计与按键功能实现

一、核心功能设计

按键暂停/继续:通过KEY1控制计时状态

按键消抖处理:20ms消抖周期消除机械抖动

硬件资源分配:符合DE2-115开发板引脚规范

二、核心模块实现详解

1. 顶层模块(counter)

bash 复制代码
module counter(
    input  CLOCK_50,     // 50MHz时钟(PIN_Y2)
    input  KEY0,         // 复位按键(低有效,PIN_M23)
    input  KEY1,         // 暂停按键(低有效,PIN_M21)
    output [6:0] hex0,   // 秒个位(PIN_AF10~AG16)
    output [6:0] hex1,   // 秒十位
    output [6:0] hex2,   // 分个位
    output [6:0] hex3    // 分十位

2. 时钟分频模块(clock_divider)

bash 复制代码
module clock_divider #(
    parameter DIVIDER = 24_999_999 // 50MHz→1Hz
)(
    input  clk,
    input  reset,
    output reg clk_out
);
reg [31:0] counter;  // 32位计数器

always @(posedge clk or posedge reset) begin
    if (reset) begin
        counter <= 0;
        clk_out <= 0;
    end else if (counter == DIVIDER) begin
        counter <= 0;
        clk_out <= ~clk_out;  // 输出翻转
    end else
        counter <= counter + 1;
end
endmodule

参数计算
T c y c l e = D I V I D E R + 1 f c l k = 25 , 000 , 000 50 , 000 , 000 = 0.5 s T_{cycle} = \frac{DIVIDER+1}{f_{clk}} = \frac{25,000,000}{50,000,000} = 0.5s Tcycle=fclkDIVIDER+1=50,000,00025,000,000=0.5s
f o u t = 1 2 × 0.5 s = 1 H z f_{out} = \frac{1}{2 \times 0.5s} = 1Hz fout=2×0.5s1=1Hz


3. 优化版按键消抖模块(key_debounce)

bash 复制代码
module key_debounce #(
    parameter DEBOUNCE_MS = 20,    // 消抖时间
    parameter CLK_FREQ = 50_000_000 
)(
    input  clk,
    input  key_n,         // 低有效
    output reg key_pulse  // 输出脉冲
);

4. 七段译码器(seg7_decoder)

bash 复制代码
module seg7_decoder(
    input [3:0] num,
    output reg [6:0] seg
);
always @(*) begin
    case(num)
        4'd0: seg = 7'b1000000; // 共阳极编码
        // ...其他数字编码
        default: seg = 7'b1111111; // 全灭
    endcase
end
endmodule

显示优化

  • 十进制拆分逻辑:
verilog 复制代码
seg0(.num(seconds%10),  // 个位
seg1(.num(seconds/10)   // 十位
  • 错误状态自动灭灯

三、关键电路设计

1. 复位信号展宽电路

verilog 复制代码
reg [5:0] reset_hold = 0;  // 6位展宽寄存器
always @(posedge CLOCK_50) begin
    if (reset_pulse) 
        reset_hold <= 6'b111111;  // 64周期展宽
    else if (reset_hold > 0)
        reset_hold <= reset_hold - 1;
end

时序特性

  • 展宽时间: t = 64 50 M H z = 1.28 μ s t = \frac{64}{50MHz} = 1.28\mu s t=50MHz64=1.28μs
  • 确保计数器稳定复位

2. 状态控制FSM

verilog 复制代码
always @(posedge CLOCK_50) begin
    if (reset_extended)          // 复位优先
        running <= 1'b1;
    else if (pause_pulse)        // 暂停切换
        running <= ~running;
end

四、工程文件结构

复制代码
/fpga_counter
├── quartus/
│   ├── counter.qpf       
│   └── DE2_115.qsf       
├── modelsim/
│   ├── tb_counter.v     
│   └── wave.do          
└── src/
    ├── counter.v         
    └── seg7_decoder.v    

五.实验结果

fpga3

六.总结

本次实验在 DE2 - 115 板子上使用 Verilog 完成分秒计数器设计。通过代码实现精准计数,同时加入按键暂停与消抖功能。经多次测试,计数器运行稳定,按键操作能有效控制,为后续数字电路设计积累了实践经验。

相关推荐
坏孩子的诺亚方舟14 天前
FPGA系统架构设计实践15_高云Arora V系列时钟体系
fpga开发·系统架构
FPGA小徐14 天前
入门 CNN 结构全解析|从流程图理论到 FPGA Verilog 硬件实现(含习题带讲解)
fpga开发
FPGA小徐14 天前
FPGA 数字信号处理:并行 FIR 与串行滤波器设计原理、对比与完整 Verilog 实现
fpga开发
Saniffer_SH15 天前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境
人工智能·驱动开发·测试工具·缓存·fpga开发·计算机外设·压力测试
zlinear数据采集卡15 天前
双核架构深度解析:ARM+FPGA如何让数据采集卡实现500Ksps高性能?
arm开发·fpga开发·架构
9527华安15 天前
FPGA实现GTH Transceivers Wizard传输2路视频,基于aurora 8b10b编解码架构,提供4套工程源码和技术支持
fpga开发·gth·aurora 8b10b·transceivers
FPGA小徐16 天前
FPGA 数字信号处理(二):并行 FIR 滤波器的 Verilog 全流程设计与实现
fpga开发
国科安芯16 天前
基于AS32S601ZIT2型抗辐照MCU的商业航天卫星姿态确定与控制系统研究
单片机·嵌入式硬件·安全·fpga开发·架构·risc-v
ALINX技术博客16 天前
【黑金云课堂】FPGA技术教程FPGA基础:I2C 总线通信技术
fpga开发·i2c
Hello-FPGA16 天前
Xilinx KU040 FPGA Camera Link 图像采集
c++·fpga开发