【紫光同创国产FPGA教程】——(PGL22G第二章)键控流水灯实验例程

本原创教程由深圳市小眼睛科技有限公司创作,版权归本公司所有,如需转载,需授权并注明出处(www.meyesemi.com)

适用于板卡型号:

紫光同创PGL22G开发平台(盘古EU 22K)

一:盘古EU 22K开发板简介

盘古EU 22K开发板共有11个翠绿LED灯,其中1个是电源指示灯(POWER);2个是FPGA的运行状态指示灯:INIT和DONE;有8个用户LED灯(LED1~8),FPGA输出高电平时对应的LED灯亮灯(详情请查看"MES22GP开发板硬件使用手册")。

二:实验目的

由 USER_KEY1 按键输入,切换 USER_LED1~ USER_LED8 的输出效果。

三:实验原理

实现框架如下:

(1)顶层实现按键切换 LED 的流水灯状态;

(2)需要设计一个输入控制模块及一个输出控制模块; 这个实验带大家将多个模块整合成为一个工程,涉及到的知识点有子模块设计、模块例化; 子模块的设计主要是依据功能定位,确定输入输出,再做具体的设计;

模块例化方式如下:

按键控制模块功能

接收按键输入信号。统计按键按下次数,由于流水灯模式是 3 种,计数统计范围是 0~2循环,将计数结果传递给 LED 控制模块;

根据需求输入信号有:时钟,按键;输出信号有:流水灯控制信号;

内部功能处理:

<1>内部需要对按键信号做消抖处理;

<2>按键触发计数器(计数值输出)改变继而调整流水灯的状态;

按键消抖模块

前后抖动时间约为 5~10ms,取按键抖动区间开始标识,持续 10-20ms 后标识归零,在抖 动区间内输出保持,非消抖区间,按键状态输出。

LED 控制模块功能

3 种流水灯模式有按键传递过来的计数控制切换,每一个 LED 的显示状态完整后进入下一 模式初始化。根据需求可得到如下信息:

输入信号:时钟,流水灯模式控制信号; 出信号:8bit 位宽的 LED 控制信号;

功能处理注意事项:流水灯状态切换点,不同状态的切换时如何初始化;

四:实验源码设计

顶层文件源码

按键控制模块

按键消抖模块

Verilog 中的 generate 语句常用于编写可配置的、可综合的 RTL 的设计结构。它可用于 创建模块的多个实例化,或者有条件的实例化代码块。

我们常用 generate 语句做三件事情。一个是用来构造循环结构,用来多次实例化某个模 块。一个是构造条件 generate 结构,用来在多个块之间最多选择一个代码块,条件 generate 结构包含 if--generate 结构和 case--generate 形式。还有一个是用来断言。

在 Verilog 中,generate 在建模(elaboration)阶段实施,出现预处理之后,正式模拟 仿真之前。因此。generate 结构中的所有表达式都必须是常量表达式,并在建模(elaboration) 时确定。例如,generate 结构可能受参数值的影响,但不受动态变量的影响。

Verilog 中的 generate 块创建了新的作用域和新的层次结构,就像实例化模块一样。因 此在尝试对 generate 块中的信号进行引用时,很容易因此混乱,因此请记住这一点。

L E D 控 制 模 块

五:实验现象

每按下一次 KEY1,LED 灯状态切换一次,总共三种 LED 模式供循环切换;

LED 模式一:从高位到低位的 LED 流水灯;

LED 模式二:隔一亮一交替点亮;

LED 模式三:从高位到低位暗灯流水;

相关推荐
LabVIEW开发12 小时前
LabVIEW与FPGA超声探伤
fpga开发·labview·labview功能
cycf13 小时前
FPGA设计中的数据存储
fpga开发
FPGA之旅2 天前
FPGA从零到一实现FOC(一)之PWM模块设计
fpga开发·dubbo
XMAIPC_Robot2 天前
基于ARM+FPGA的光栅尺精密位移加速度测试解决方案
arm开发·人工智能·fpga开发·自动化·边缘计算
cycf2 天前
状态机的设计
fpga开发
szxinmai主板定制专家2 天前
【精密测量】基于ARM+FPGA的多路光栅信号采集方案
服务器·arm开发·人工智能·嵌入式硬件·fpga开发
千宇宙航2 天前
闲庭信步使用SV搭建图像测试平台:第三十二课——系列结篇语
fpga开发
千宇宙航2 天前
闲庭信步使用SV搭建图像测试平台:第三十一课——基于神经网络的手写数字识别
图像处理·人工智能·深度学习·神经网络·计算机视觉·fpga开发
小眼睛FPGA3 天前
【RK3568+PG2L50H开发板实验例程】FPGA部分/紫光同创 IP core 的使用及添加
科技·嵌入式硬件·ai·fpga开发·gpu算力
forgeda3 天前
如何将FPGA设计验证效率提升1000倍以上(2)
fpga开发·前沿技术·在线调试·硬件断点·时钟断点·事件断点