FPGA电子时钟设计

1.设计目标

- 实现24小时制数字时钟的基本计时功能(时:分:秒)

- 通过8位数码管显示时间,格式为 HH.MM.SS

- 支持按键调整时间(秒、分、时分别可调)

- 拓展:本设计实现闹钟功能,可设置闹钟时间并在指定时间触发蜂鸣器报警

2.开发流程

2.1开发环境

| 目标器件 | EP4CE10F17C8 (Altera Cyclone IV) |

| 开发工具 | Quartus II 13.0 |

| 系统时钟 | 50MHz晶振 |

| 编程语言 | Verilog HDL |

2.2架构设计

为了提供一种最简单直观的显示,开发板上提供了一个7段8位共阳极数码管电路,为了减少对FPGA引脚资源的占用,开发板上的数码管采用串行移位寄存器芯片将串行数据转化为16位并行数据后进行驱动。Cyclone IV E通过3根数据线,连接到两片级联的串行移位器芯片74HC595上,再由74HC595将每次16位串行的数据转化为16位并行的数据,分别用以驱动7段8位数码管的段选和位选。

top顶层模块,负责各子模块的连接与信号分配 (top.v) 

Project_Segled2 数字时钟核心模块,包含计时、显示、按键处理、闹钟等功能( Project_Segled2.v)

HC595_Driver|74HC595移位寄存器驱动,实现串行数据输出(HC595_Driver.v )

2.3顶层IO

module top( input Clk, // 50MHz系统时钟 input Rst_n, // 复位信号(低电平有效) input KEY1, // 模式切换/长按进入闹钟设置 input KEY2, // 数值递增按键 output SH_CP, // 74HC595移位时钟 output ST_CP, // 74HC595锁存时钟 output DS, // 74HC595串行数据 output BEEP // 蜂鸣器输出 ); 

2.4数字时钟核心模块 (Project_Segled2.v)

2.4.1 按键消抖

采用计数器消抖方式,消抖时间约20ms:

parameter DB_CNT_MAX = 20'd100; // 消抖计数最大值 // 两级同步 + 计数消抖 always @(posedge CLK_50M or negedge RST_N) begin     if(!RST_N) begin         k1_sync0 <= 1'b1; k1_sync1 <= 1'b1;     end else begin         k1_sync0 <= FLAG1; k1_sync1 <= k1_sync0;     end end 

设计特点:

- 采用两级触发器同步,防止亚稳态

- 检测高→低电平翻转,产生单周期脉冲

- 支持长按检测(1秒),用于进入闹钟设置模式

2.4.2 计时

基于50MHz时钟进行分频,实现秒、分、时的计时:

// 关键参数 parameter SET_TIME_1S = 'd50_000_000;  // 1秒计数值 parameter SIXTY = 'd60;                 // 60进制 parameter TWENTYFORE = 'd24;            // 24进制 // 1秒定时器 always @ (posedge CLK_50M or negedge RST_N) begin     if(!RST_N)         cnt_1s <= 28'd0;     else if(set_mode != 2'd0)  // 调整模式下暂停         cnt_1s <= 28'd0;     else if(cnt_1s == SET_TIME_1S - 1)         cnt_1s <= 28'd0;     else         cnt_1s <= cnt_1s + 28'b1; end

计时进位逻辑:

- 秒:0-59循环,满60进位

- 分:0-59循环,满60进位

- 时:0-23循环,满24复位

2.4.3 时间调整模式状态机

通过按键切换四种工作模式:

| 模式值 | 模式名称 | 功能描述 |

| 0 | 正常模式 | 时钟正常走时 |

| 1 | 调秒模式 | 秒位闪烁,可调整秒 |

| 2 | 调分模式 | 分位闪烁,可调整分 |

| 3 | 调时模式 | 时位闪烁,可调整时 |

always @(posedge CLK_50M or negedge RST_N) begin     if(!RST_N)         set_mode <= 2'd0;     else if(mode_pulse && !alarm_set_mode && !alarm_triggered)         set_mode <= set_mode + 2'd1;  // 0→1→2→3→0 循环 end

2.4.4 闹钟功能

闹钟设置流程:

- 长按KEY1(1秒)进入闹钟设置模式

- 短按KEY1切换时/分设置位置

- 按KEY2递增当前设置值

- 再次长按KEY1退出设置并使能闹钟

// 闹钟触发检测 always @(posedge CLK_50M or negedge RST_N) begin     if(!RST_N)         alarm_triggered <= 1'b0;     else if(alarm_triggered && (mode_pulse || inc_pulse))         alarm_triggered <= 1'b0;  // 任意按键取消     else if(alarm_enabled && !alarm_set_mode &&             cnt_h == alarm_h && cnt_m == alarm_m && cnt_s == 6'd0)         alarm_triggered <= 1'b1;  // 时间匹配,触发闹钟 end

报时特性:

- 闪烁6次(300ms周期)

- 蜂鸣器间歇发声

2.4.5 数码管显示

采用动态扫描方式驱动8位数码管:

// 显示格式: HH-MM-SS // 位置分配: 7-6-5-4-3-2-1-0 //          时十位-时个位-横线-分十位-分个位-横线-秒十位-秒个位 // 1ms扫描周期 parameter SET_TIME_1MS = 16'd50_000; // 段码查找表(共阴极数码管) parameter SEG_CODE_0 = 8'b1100_0000,           SEG_CODE_1 = 8'b1111_1001,           ...           SEG_CODE_9 = 8'b1001_0000,           SEG_CODE_DASH = 8'b1011_1111;  // 横线"-"

二进制转BCD算法(Double Dabble):

// 将6位二进制数转换为2位BCD for(i = 5; i >= 0; i = i - 1) begin     if (s_ones >= 4'd5) s_ones = s_ones + 4'd3;     if (s_tens >= 4'd5) s_tens = s_tens + 4'd3;     s_tens = {2'b00, s_tens[2:0], s_ones[3]};     s_ones = {2'b00, s_ones[2:0], cnt_s[i]}; end 

2.4.6 蜂鸣器控制

生成约2kHz方波驱动蜂鸣器:

parameter BEEP_FREQ_CNT = 16'd12500;  // 50MHz/12500/2 = 2kHz always @(posedge CLK_50M or negedge RST_N) begin     if(!RST_N)         beep_cnt <= 16'd0;     else if(beep_cnt >= BEEP_FREQ_CNT - 1) begin         beep_cnt <= 16'd0;         beep_tone <= ~beep_tone;     end else         beep_cnt <= beep_cnt + 16'd1; end

2.5 74HC595驱动模块 (HC595_Driver.v)

2.5.1 74HC595芯片简介

74HC595是一款8位串入并出移位寄存器,具有以下特点:

- 串行数据输入,8位并行数据输出

- 具有输出锁存功能

- 可级联扩展

2.5.2 引脚功能

| 引脚 | 名称 | 功能 |

|------|------|------|

| DS | 数据输入 | 串行数据输入端 |

| SH_CP | 移位时钟 | 上升沿移入数据 |

| ST_CP | 锁存时钟 | 上升沿锁存数据到输出 |

2.5.3 驱动时序设计

parameter DATA_WIDTH = 16;  // 16位数据(8位段码 + 8位位选) parameter CNT_MAX = 4;      // 分频系数 // 移位时钟生成 always@(posedge Clk or negedge Rst_n)     if(!Rst_n)         divider_cnt <= 16'd0;     else if(divider_cnt == CNT_MAX)         divider_cnt <= 16'd0;     else         divider_cnt <= divider_cnt + 1'b1; assign sck_pluse = (divider_cnt == CNT_MAX);

2.5.4 时序状态机

case(SHCP_EDGE_CNT)     5'd0: begin SH_CP <= 1'b0; ST_CP <= 1'b1; DS <= r_data[15]; end     5'd1: begin SH_CP <= 1'b1; ST_CP <= 1'b0; end     5'd2: begin SH_CP <= 1'b0; DS <= r_data[14]; end     5'd3: begin SH_CP <= 1'b1; end     // ... 依次移出16位数据     5'd30: begin SH_CP <= 1'b0; DS <= r_data[0]; end     5'd31: begin SH_CP <= 1'b1; end endcase

3 系统功能说明

3.1 操作说明

| 操作 | 按键 | 功能说明 |

|------|------|----------|

| 模式切换 | 短按KEY1 | 正常→调秒→调分→调时→正常 循环 |

| 数值调整 | 按KEY2 | 在调整模式下,递增当前选中位 |

| 进入闹钟设置 | 长按KEY1(1秒) | 进入闹钟时间设置模式 |

| 切换闹钟设置位 | 短按KEY1 | 在闹钟设置模式下切换时/分 |

| 设置闹钟值 | 按KEY2 | 递增闹钟时间 |

| 退出闹钟设置 | 长按KEY1(1秒) | 保存并使能闹钟 |

| 取消闹钟 | 按任意键 | 闹钟响时按任意键停止 |

3.2 状态指示

| 状态 | 显示效果 |

|------|----------|

| 正常计时 | 全部数字稳定显示 |

| 调秒模式 | 秒位闪烁(250ms周期) |

| 调分模式 | 分位闪烁(250ms周期) |

| 调时模式 | 时位闪烁(250ms周期) |

| 闹钟设置 | 被调整位闪烁,秒显示00 |

| 整点报时 | 全部闪烁6次(300ms周期),蜂鸣器间歇响 |

| 闹钟触发 | 全部快速闪烁(125ms周期),蜂鸣器持续响 |

4附录

完整代码如下

https://github.com/acousma-az/FPGA_digital_clock

  

Read more

万字讲解内网横向渗透vulnstack(七):红日靶场7实战全流程-CS上线全部Web1/Web2/PC1/PC2/DC

万字讲解内网横向渗透vulnstack(七):红日靶场7实战全流程-CS上线全部Web1/Web2/PC1/PC2/DC

目录 一、渗透环境 1、网络拓扑 2、角色表 3、网络搭建 (1)网络适配器配置 ①修改Web1的网卡配置 ②修改Web2的网卡配置 ③修改PC1的网卡配置 (2)配置网段 ①编辑虚拟网络编辑器 ② vmnet2网卡 ③ vmnet14网卡 二、信息搜集 1、探测存活主机 2、探测端口 三、Redis渗透 1、生成ssh私钥 2、查看生成公钥文件 3、写入Redis服务器 (1) 直接连接未授权Redis (2)写入SSH公钥获取服务器权限 4、ssh连接 5、查看Web1的Nginx配置 四、Laravel渗透(Web2) 1、发现Laravel 2、下载PoC 3、执行PoC上传木马

毕业设计源码:Python音乐推荐系统 Django+Echarts+协同过滤算法+前端三剑客 课程设计 毕业设计(建议收藏)✅

毕业设计源码:Python音乐推荐系统 Django+Echarts+协同过滤算法+前端三剑客 课程设计 毕业设计(建议收藏)✅

博主介绍:✌全网粉丝10W+,前互联网大厂软件研发、集结硕博英豪成立工作室。专注于计算机相关专业项目实战6年之久,选择我们就是选择放心、选择安心毕业✌ > 🍅想要获取完整文章或者源码,或者代做,拉到文章底部即可与我联系了。🍅 点击查看作者主页,了解更多项目! 🍅感兴趣的可以先收藏起来,点赞、关注不迷路,大家在毕设选题,项目以及论文编写等相关问题都可以给我留言咨询,希望帮助同学们顺利毕业 。🍅 1、毕业设计:2026年计算机专业毕业设计选题汇总(建议收藏)✅ 2、大数据毕业设计:2026年选题大全 深度学习 python语言 JAVA语言 hadoop和spark(建议收藏)✅ 1、项目介绍 技术栈 以Python为开发语言,基于Django框架搭建系统整体架构,集成基于用户的协同过滤推荐算法实现核心推荐功能,运用Echarts完成数据可视化展示,前端通过HTML、CSS、JavaScript构建交互页面,采用MySQL或PostgreSQL数据库存储各类业务数据。 功能模块 * 可视化界面 * 首页 * 音乐播放与信息展示 * 音乐详情页 * 音乐推

SpringBoot+Vue 校园网上店铺设计与实现平台完整项目源码+SQL脚本+接口文档【Java Web毕设】

SpringBoot+Vue 校园网上店铺设计与实现平台完整项目源码+SQL脚本+接口文档【Java Web毕设】

系统架构设计### 摘要 随着互联网技术的快速发展,校园内的商业活动逐渐向线上迁移,学生和教职工对便捷的购物体验需求日益增长。传统的线下店铺受限于时间和空间,难以满足校园用户的多样化需求,因此构建一个高效、便捷的校园网上店铺平台成为迫切需求。该平台旨在整合校园内的商品资源,提供在线浏览、下单、支付及配送等功能,优化校园商业生态。通过线上交易模式,减少中间环节,降低运营成本,同时为学生创业提供技术支持。关键词:校园电商、在线交易、商品管理、Java Web、毕设设计。 本平台采用前后端分离架构,后端基于SpringBoot框架实现RESTful API接口,提供高效的数据处理和业务逻辑支持;前端使用Vue.js框架构建用户界面,确保交互流畅性和响应速度。数据库采用MySQL存储商品、订单和用户信息,并通过SQL脚本实现数据表的初始化。系统功能模块包括用户注册登录、商品分类展示、购物车管理、订单支付及后台管理,支持多角色权限控制。技术栈整合了JWT身份认证、Redis缓存优化及Swagger接口文档生成,确保系统安全性和可维护性。关键词:SpringBoot、Vue.js、MySQL、

【芯片解读】TI AFE5816:16通道超声波模拟前端 (AFE) 深度详解

【芯片解读】TI AFE5816:16通道超声波模拟前端 (AFE) 深度详解

【芯片解读】TI AFE5816:16通道超声波模拟前端 (AFE) 深度详解 简介 在医疗超声成像、无若检测(NDT)以及声纳应用中,模拟前端(AFE)的性能直接决定了成像的质量。Texas Instruments (TI) 的 AFE5816 是一款高度集成的 16 通道模拟前端解决方案,专为需要高性能、低功耗和小尺寸的便携式及高端超声波系统设计。 国产类似产品为海思的AC9810-32,该产品与TI的AFE5832功能相似,为32通道AFE,海思后续还有64通道的产品推出。 1. 核心特性概览 (Key Features) AFE5816 是一个多芯片模块(MCM),集成了两个晶圆:VCA(压控放大器)和 ADC_CONV(模数转换)。其主要特性如下: * 高集成度:单芯片集成 16 个通道,每个通道包含衰减器、LNA、LPF、