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

相关推荐
化屾为海6 小时前
FPGA制造与测试全流程
fpga开发·制造
Aaron15887 小时前
RFSOC+VU13P+RK3588的核心优势与应用场景分析
嵌入式硬件·算法·matlab·fpga开发·信息与通信·信号处理·基带工程
Aaron15889 小时前
8通道测向系统演示科研套件
人工智能·算法·fpga开发·硬件工程·信息与通信·信号处理·基带工程
数字芯片实验室13 小时前
当FPGA开始支持“自然语言编程“,芯片定制的门槛要变了
fpga开发
Kong_199415 小时前
芯片开发学习笔记·二十四——PCIe(PCI Express)
fpga开发·芯片开发
化屾为海16 小时前
FPGA CP测试
fpga开发
何如呢16 小时前
ROM查表法实现UW
fpga开发
碎碎思17 小时前
FPGA图像处理平台搭建:MIPI + VDMA + Ethernet全流程
图像处理·人工智能·fpga开发
希言自然也1 天前
赛灵思KU系列FPGA的EFUSE/BBRAM加密操作
fpga开发