【紫光同创盘古PGX-Nano教程】——(盘古PGX-Nano开发板/PG2L50H_MBG324第三章)键控流水灯实验例程 - FPGA开发者技术社区 - 电子技术william hill官网 - 广受欢迎的专业电子william hill官网 - 威廉希尔官方网站
分享 收藏 返回

Mill 关注 私信
[文章]

【紫光同创盘古PGX-Nano教程】——(盘古PGX-Nano开发板/PG2L50H_MBG324第三章)键控流水灯实验例程

适用于板卡型号:
紫光同创PG2L50H_MBG324开发平台(盘古PGX-Nano)

一:盘古盘古PGX-Nano开发板简介
PGX-Nano 是一套以紫光同创 FPGA 为核心的开发板,选用紫光同创 logos2 系列 28nm 工艺的 FPGA(PG2L50H_MBG324)。集成下载器芯片,极大的便利 了用户的使用。 板卡搭载一颗容量为 2MB 的 SRAM 用于数据缓存,DAC 芯片用于产生模 拟信号进行测试验证,esp32 模组进行 WIFI、蓝牙透传;预留了丰富的扩展 IO 用于用户验证、测试外接模块威廉希尔官方网站 功能,一组串口进行串行通信;同时为用户提 供基础的硬件威廉希尔官方网站 资源,例如 led 灯、按键、拨码开关等。



二:实验目的

由PB0(即开发板S0位置)按键输入,切换LED0~LED7的输出效果。





三:实验原理
实现框架如下:


(1)顶层实现按键切换LED的流水灯状态;
(2)需要设计一个输入控制模块及一个输出控制模块;
这个实验带大家将多个模块整合成为一个工程,涉及到的知识点有子模块设计、模块例化;子模块的设计主要是依据功能定位,确定输入输出,再做具体的设计;
模块例化方式如下:


按键控制模块功能

接收按键输入信号。统计按键按下次数,由于流水灯模式是3种,计数统计范围是0~2循环,将计数结果传递给LED控制模块;
根据需求输入信号有:时钟,按键;输出信号有:流水灯控制信号;
内部功能处理:
<1>内部需要对按键信号做消抖处理;
<2>按键触发计数器(计数值输出)改变继而调整流水灯的状态;


按键消抖模块


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

LED控制模块功能

3种流水灯模式有按键传递过来的计数控制切换,每一个LED的显示状态完整后进入下一模式初始化。根据需求可得到如下信息:
输入信号:时钟,流水灯模式控制信号;出信号:8bit位宽的LED控制信号;
功能处理注意事项:流水灯状态切换点,不同状态的切换时如何初始化;




四:实验源码设计
顶层文件源码

按键控制模块



按键消抖模块



LED控制模块






五:实验现象
每按下一次KEY1,LED灯状态切换一次,总共三种LED模式供循环切换;
LED模式一:从高位到低位的LED流水灯;
LED模式二:隔一亮一交替点亮;
LED模式三:从高位到低位暗灯流水;


相关配套资料可联系:小眼睛半导体
抖yin搜索:小眼睛FPGA

更多回帖

×
发帖