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

相关推荐
風清掦7 小时前
【STM32学习笔记-14】WDG看门狗 - 14.2 WWDG窗口看门狗
笔记·stm32·单片机·嵌入式硬件·学习·fpga开发
尤老师FPGA10 小时前
HDMI数据的接收发送实验(十二)
fpga开发
坏孩子的诺亚方舟14 小时前
FPGA神经网络数学基础0
人工智能·神经网络·线性代数·fpga开发
熠速14 小时前
PolarBox高性能实时仿真系统
arm开发·fpga开发·嵌入式实时数据库·硬件在环半实物仿真
南檐巷上学15 小时前
基于Zynq-7020的带有正弦波发生器的8051软核设计
单片机·嵌入式硬件·fpga开发·fpga
思尔芯S2C15 小时前
FPGA原型验证中的内存模型应用:基于DDR5的Linux系统启动与测试
fpga开发·内存模型·ddr4·ddr5·memory model·hbm3·prototyping
hai3152475431 天前
RISC-V CVA6 AXI适配器+DMA桥蜂鸟E203处理器的总线接口单元(BIU)仲裁器
驱动开发·fpga开发·硬件架构·硬件工程·精益工程
高速上的乌龟1 天前
Lattice LFCPNX-100 HSB+Fpga开发详解:2.3 Hololink 顶层模块深度全解析
linux·fpga开发
ALINX技术博客1 天前
【FPGA 开发教程】基于 ALINX FPGA 开发板实现 USB3.2 高速通信(Z7-P+FL2010)
fpga开发·fpga·fmc子卡·usb3.2通信
Ricky05531 天前
搭载实时 FPGA 处理系统的航天器上用于海上监视的超分辨率YOLO目标检测技术(意大利2026年研究)
yolo·目标检测·fpga开发