FPGA之FIFO和RAM模块创建及封装

菜菜昨天在用quatus做FIFO模块和RAM模块时疯狂报错,加上完全不记得自己以前如何写的,问了很多同学才有了一点点印象,最后成功编译,且下载后现象也正确,那我们就赶紧先写下来吧,不然下次又忘了/(ㄒoㄒ)/~~


都是用lpm库来实现的

FIFO模块

先介绍一下FIFO
设计要求:
设计1个同步FIFO,8bits*256words
其最终图为:
FPGA之FIFO和RAM模块创建及封装

  1. 创建项目(new project)----->命名为fifo_test
  2. 创建模块(选择文件模式)
    FPGA之FIFO和RAM模块创建及封装
  3. 点击空白两下,出现如下界面,点击红色方框
    FPGA之FIFO和RAM模块创建及封装
    FPGA之FIFO和RAM模块创建及封装
  4. 选择模块
    FPGA之FIFO和RAM模块创建及封装
    首先在左边找到我们的FIFO,并选择(点击即可),再在右边路径中添加我们模块的名称
    注意:不要和我们的工程名称相同
  5. 继续调整我们的模块
    FPGA之FIFO和RAM模块创建及封装
    我们可以看到左边那个模块已经和我们期望的一致了,但是很多细节我们还是需要考虑一下的,比如右边的8和256代表输入位数及深度,可是我们下载到板子上输入一共只有8位拨码开关,故我们可以调整一下输入输出只有4位,然后256代表可以有256个字,由8位控制,我们也可以调整为一些小的方便控制

直接单击下一步
FPGA之FIFO和RAM模块创建及封装
可选择勾选该同步清零,再点击下一步即可

FPGA之FIFO和RAM模块创建及封装
直接下一步
FPGA之FIFO和RAM模块创建及封装
FPGA之FIFO和RAM模块创建及封装

勾选vhd文件,这样才会之后拥有,点击finish即可
FPGA之FIFO和RAM模块创建及封装
FPGA之FIFO和RAM模块创建及封装
点击OK,将其保存,注意文件名为工程文件名(也可任意),后缀为bdf

  1. 编译之前,先将输入输出调整好
    FPGA之FIFO和RAM模块创建及封装
    编译没有错误之后将封装模块

  2. File ----> Create/Update ------> Ceate Symbol File for current file
    即可得到bsf文件

若是别的模块需要调用该模块,只需要将该文件夹里的bsf,bdf,vhd全部复制到我们的顶层文件夹即可,这样别的模块在封装的时候,可看到并且直接调用
FPGA之FIFO和RAM模块创建及封装

FIFO模块的构建就完成啦

RAM模块

RAM模块与FIFO模块构建相似,主要是
FPGA之FIFO和RAM模块创建及封装
我们要根据要求选择单端口或者其它的
同样也是选择位数和深度,一直next即可,直到finish
FPGA之FIFO和RAM模块创建及封装
FPGA之FIFO和RAM模块创建及封装

那我们的笔记就做完啦!

上一篇:python – 在linux中通过命名管道发送数据块


下一篇:CAN笔记(14) STM32-M4 寄存器