FPGA-ROM IP核的使用(2)

前言

接着昨天的进行一个小的实验验证ROM IP核。

实验效果

读取上一期生成的IP核中的数据,并将其显示在数码管上。

具体流程

ROM IP核存放数据0~255,之后每隔0.2s,从0的地址开始读数据,并显示在数码管上;接着先后使用两个按键信号读取指定地址数据,完成后,从当前地址开始继续0.2s间隔往后读取数据。

步骤

调用模块

ROM IP核模块

数码管显示模块

按键消抖模块

ROM控制模块

其中按键消抖模块和数码管显示模块为已有模块,可直接调用。

ROM IP核模块的调用过程

调用昨天完成的单端口ROM,将文件夹中生成的inst.v文件内容复制到顶层模块后,连接各个信号即可:

ROM控制模块调用

为什么要添加ROM控制模块?ROM的读操作在上升沿触发,但实际调用ROM时候并没有读使能,需要控制生成读地址。控制框图如下:时钟为系统时钟,复位信号低电平有效,有两个消抖后的按键信号,输入信号就是这几个,通过它们来产生读取的地址并读取数据。

ROM控制模块控制时序分析如下图所示:

系统时钟clk:50Mhz,一个时钟也就是20ns,设计效果是0.2s,设计一个计数器实现0.2s变化一次的效果。

计数器cnt_200ms:0.2s,一个时钟上升沿变化一次,最大计数值也就是200_000_000ns/20ns-1=9_999_999。即CNTMAX=9_999_999。计数器每次计数到最大值,地址+1。按键在某个地址按下时,也让计数器为0。

key1与key2:按键信号,拉高一个时钟。

addr1与addr2:读地址的标志信号,按下一次后,拉高,再按下一次后,拉低。红色线所示

图中含义是:按下按键1后,读取地址2的数据,按下按键2后,读取地址4的数据。可以看到这里延了一拍。绿色线所示。

每次只读取一个地址信号,因此每次只能有一个地址标志信号为高电平。

接下来就是参考上面的波形图编写ROM控制模块的代码了:

编辑器:Notepad++

顶层模块设计

顶层模块就是各个子功能模块的实例化和各类信号的连接,感觉也是最难得一部分,最需要全局思维的一部分。下面是顶层模块输入输出框图,其中

clk:系统时钟

rst_n:复位信号

key[1:0]:按键信号

stcp:输出数据存储器时钟

shcp:移位寄存器时钟输入

ds:串行数据输入

oe:输出使能信号

  • 编写顶层模块代码

仿真与上板验证

这里就不贴具体代码了,结果符合预期,上板验证(随机连续拍了几张图,还不知道怎么传视频)

小结

感觉还是有些懵懂,还需要多花时间琢磨一下。

相关推荐
江山如画,佳人北望3 小时前
stm32-c8t6实现语音识别(LD3320)
stm32·单片机·嵌入式硬件
baowxz4 小时前
航芯MCU使用IAR+Jlink调试
单片机·嵌入式硬件
wangxinwei20004 小时前
stm32_LAN8720驱动
stm32·单片机·嵌入式硬件
大叔带刺4 小时前
AUTOSAR实战教程--DoIP_01_配置项解释
单片机·嵌入式硬件
小胖同学~4 小时前
Linux--vsFTP配置篇
stm32·单片机·嵌入式硬件
Neil今天也要学习7 小时前
永磁同步电机参数辨识算法--IPMSM拓展卡尔曼滤波全参数辨识
单片机·嵌入式硬件·算法
知识噬元兽11 小时前
【工具使用】STM32CubeMX-FreeRTOS操作系统-信号标志、互斥锁、信号量篇
stm32·单片机·嵌入式硬件
GateWorld11 小时前
《从零掌握MIPI CSI-2: 协议精解与FPGA摄像头开发实战》-- CSI-2 协议详细解析LLP (二)
fpga开发·mipi csi2
Flag- L12 小时前
STM32标准库-TIM定时器
stm32·单片机·嵌入式硬件
2301_7756023812 小时前
STM32什么是寄存器
stm32·单片机·嵌入式硬件