【黑金云课堂】FPGA技术教程FPGA基础:流水灯实验

本篇流水灯实验 ,选自 ALINX 黑金云课堂 FPGA 免费直播课 。该课程由 ALINX 资深工程师团队倾力打造,从 0 到 1 系统化教学,帮助每位工程师跨过 FPGA 开发门槛。


流水灯实验

实验目的

  • 熟悉FPGA完整开发流程

  • 理解时序逻辑工作方式

  • 掌握寄存器、时钟、复位作用

  • 为后续实验(按键消抖、PWM、PLL、串口、VGA等)打基础

  • 培养工程习惯:先仿真、后上板、再在线调试

实验原理

  • 本质:循环移位寄存器

  • 工作机制:

    1. 状态保存:LED状态由寄存器保存(每bit对应一个LED)

    2. 时钟驱动:时钟信号驱动寄存器内容变化

    3. 状态转移:按照代码逻辑进行按位赋值

    4. 循环移位示例:0001 → 0010 → 0100 → 1000 → 0001

时钟与分频原理

  • 系统时钟典型频率:50MHz 或 100MHz

  • 人眼可识别频率:约 1~5Hz

  • 问题:直接用系统时钟驱动LED,变化太快,人眼看到"常亮"

  • 解决方案:使用计数器对时钟分频,得到低频节拍信号

  • 分频计算示例:200MHz 系统时钟 → 目标 4Hz → 分频系数 = 200M / 4 = 25,000,000

程序设计思路

  • 模块化设计:封装独立Verilog模块,清晰接口

  • 内部结构:

  1. 分频计数器(如24位计数器)

  2. LED状态寄存器(4位)

  3. 同步时序逻辑:所有状态变化在时钟上升沿触发,避免异步问题

Verilog核心代码(要点)

  • 计数器逻辑:计数到预设值(如10M)产生节拍脉冲

  • 状态更新:按照代码逻辑进行按位赋值

  • 复位逻辑:异步或同步复位,初始化计数器与LED状态

仿真验证

  • 目的:提前发现逻辑错误、时序问题,降低调试成本

  • Testbench设计要点:

  1. 生成周期性时钟(如20ns周期 = 50MHz)

  2. 施加复位信号(如100ns)

  3. 观察LED输出变化

  • 验证要点:

    1. 复位时LED初始化为 0001(或 0000,视设计)

    2. LED按固定周期依次变化

    3. 状态变化发生在时钟上升沿

    4. 计数器达到阈值时更新LED

ILA在线调试

  • **为什么需要:**仿真环境理想,硬件存在时序延迟、噪声等;FPGA内部信号无法直接测量

  • ILA(Integrated Logic Analyzer):

    嵌入FPGA内部的逻辑分析仪,通过JTAG采集信号

  • 调试步骤:

    1. 在Vivado/Quartus中添加ILA核,选择待观察信号(led_regcnt等)

    2. 生成包含ILA的bit文件,下载到FPGA

    3. 连接Hardware Manager,设置触发条件,抓取波形

    4. 验证硬件行为

    5. 固化到Flash(生成mcs/bin文件)

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