【黑金云课堂】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文件)

相关推荐
FPGA小迷弟13 小时前
FPGA工程师常见面试问题,有参考答案,必学!!!
fpga开发·面试·职场和发展·verilog·fpga·modelsim
followless20 小时前
linux server中搭建questasim 10.6c & ise14.7
linux·fpga开发
乌恩大侠21 小时前
【AI-RAN】WNC O-RU 配置、英伟达 AI-RAN、
fpga开发·o-ru
小麦嵌入式2 天前
FPGA入门(一):手把手教你用 Vivado 创建工程并仿真
stm32·单片机·嵌入式硬件·mcu·fpga开发·硬件架构·硬件工程
m0_46644103詹湛3 天前
(一)FPGA :基础概念详解(Xilinx平台)
笔记·学习·fpga开发·verilog
xyx-3v4 天前
ZYNQ 简介
fpga开发
xyx-3v4 天前
Zynq-7000
fpga开发
xyx-3v4 天前
zynq7010和zynq7020的区别
fpga开发
xyx-3v4 天前
LUT(Look-Up Table,查找表)的定义与核心概念
fpga开发
明德扬4 天前
K7+AD9144 多模式实测|8 种 JESD204B 配置全覆盖验证
fpga开发