首页 > 其他分享 >基于EP4CE6F17C8的FPGA开发流程(以半加器为例)

基于EP4CE6F17C8的FPGA开发流程(以半加器为例)

时间:2024-03-05 20:46:24浏览次数:30  
标签:以半加器 FPGA 为例 对话框 值为 如下 点击 按钮 所示

一、电路模块

1、 芯片

FPGA芯片型号为EP4CE6F17C8,属于ALTERA公司Cyclone IV系统的产品。此型号为BGA封装,共有256个引脚。芯片实物图如下所示。

其主要参数如下表所示。

2、 LED

开发板板载了4个用户LED发光二极管。4 个用户LED部分的原理图如下图所示,当 FPGA的引脚输出为逻辑 0时,LED会熄灭。输出为逻辑1时,LED被点亮。

其实物图如下所示。

LED的引脚分配见下表。

3、 按键

开发板板载了4个独立按键,其中有3个用户按键(KEY1~KEY3),1个功能按键(RESET)。按键按下为低电平(0),释放为高电平(1),4个按键的原理图如下图所示。

其实物图如下所示。

按键的引脚分配见下表。

 

二、实验代码

本例实现一位数的半加器,输入使用两个按键key1和key2,输出使用两个发光管led1和led2。代码使用Verilog编写,如下。

module h_adder_1bit(key1,key2,led1,led2);
    input key1,key2;
    output led1,led2;
    assign led2 = key2 ^ key1;
    assign led1 = key2 & key1;
endmodule

三、实验步骤

1、新建工程

启动Quartus,点击File->New Project Wizard,通过向导来建立工程,如下图如示。

接着出现如下图所示的界面,提醒你建立工程需要的步骤,点击Next继续。

之后出现如下图所示的对话框,让你确定工程所在的文件夹及工程名称,根据自己的情况输入。需要注意的是,工程名称与顶层设计实体的名称是一致的,输入时会连动。另外,工程文件不要放在桌面或某个盘的根目录下,要放置到一个具体的文件夹中,如本例放在了D盘的EDA_FPGA目录下。输入完成后点击Next进入下一步。

接下来会问你建立工程的类型,默认工程为空,如下图所示,点击Next继续。

接着出现如下图所示的对话框,让你向建立的工程添加文件。由于目前还没有文件,所以直接点击Next进入下一步。

之后出现器件选择的对话框,如下图所示。在该对话框中,需要确定你使用的FPGA芯片型号。可通过条件筛选来缩小选择范围,先点击Family右边的下拉列表框,选择Cyclone IV E系统,再点击Pin count右边的下拉列表框,选择256脚,再点击Core speed grade右边的下拉列表框,选择8,最后就可在最下边的器件列表中找到EP4CE6F17C8的型号,点击选中它,然后点击Next按钮进入下一步。

接下来出现如下图所示的对话框,让你选择工具设置,这里不需要配置,直接点击Next进入下一步。

最后出现如下图所示的新建工程的简要概况,可阅览一下,然后点击Finish按钮结束。

建立好的工程界面如下图所示。

2、编写代码

在上面建好的工程中,点击File->New,新建一个项目,如下图所示。

在打开的对话框中,点击选中Verilog HDL File一项,如下图所示,然后点击OK确定。

接下来在新建的空白文档中输入前面半加器的Verilog代码,完成后点击保存,这里需要特别注意,保存文件的名称要与描述模块的名称一致,后缀为.v,如下图所示。

3、设置为顶层实体

在新建立的工程中,默认顶层实体为工程名称,这里需要修改一下。点击Hierarchy下拉列表框,选择Files,如下图所示。

然后选中刚才添加进来的文件h_adder_1bit,点击右键,选择Set as Top-Level Entity一项,把该文件设置为顶层实体,如下图所示。

最后再确认一下,点击刚才的下拉列表框回到Hierarchy下,可以看到顶层实体已经变成了刚才新建的文件,如下图所示。

4、设置管脚

在上面新建好的工程中,并没有把芯片的引脚与代码中的端口进行映射。在前面给出的电路图中,已经实现了芯片管脚与外围器件的连接。而这里要做的是,把芯片具体的管脚与代码中所描述的端口联系起来,因为在Verilog中只描述端口,并没有指定具体的芯片引脚,而管脚设置就是进行这个映射,它是通过开发环境Quartus的支持来实现的。在设置之前,由于Quartus还不知道代码中描述的有哪些端口,所以需要先对工程进行一下综合,点击工具条上的综合按钮,如下图所示。

综合完成之后,如果没有报错,会出现如下图所示的界面。注意综合需要一定的时间,一定要等到右下方显示的进度为100%时,才表明综合结束。如果其间有报错,则根据提示进行修改。

确保综合成功后,点击Assignments->Pin Planner,如下图所示,打开管脚配置的对话框。

在打开的对话框中,先对端口key1进行映射,点击key1一行对应的location一格,输入m15然后回车,它会自动填充完整(PIN_M15),如下图所示。

参照前面的电路图,把与key及led相连接的4个端口都进行映射绑定,完成后如下图所示。

全部完成后,不需要保存,直接关闭对话框即可。接下来还需要对管脚的一些属性进行配置,点击Assignments->Device,如下图所示,打开器件对话框。

在打开的对话框中,点击Device and Pin Option按钮,如下图所示。

在打开的对话框中,先点击左边的Unused Pins,然后在右边点击下拉列表框,选择As input tri-stated,即把未使用的管脚全部设置为三态输入模式,如下图所示。

之后点击左边的Dual-Purpose Pins,然后把右边所有的下拉列表框,都选择为Use as regular I/O项(注:每个下拉列表框需要用鼠标点击三次才能选择),即把管脚都设置为标准I/O口,如下图所示。

最后点击左边的Voltage,然后把右边Default I/O standard下拉列表框,选择为3.3-V LVTTL项,即把电源选择为3.3V,如下图所示,完成后连续点击ok按钮回到主界面。

5、编译工程

以上设置全部完成后,就可以编译工程了。点击工具条上的编译按钮,如下图所示,对整个工程进行编译。

工程编译需要一定的时间,等待右下边的进度条显示100%后,编译才成功,此时会显示工程所用逻辑门的个数,以及使用的管脚数量等信息,如下图所示。

6、下载运行

编译成功后,就可以把结果下载到开发板上进行验证。先给开发板上电,然后点击工具条上的编程按钮,如下图所示。

接着会出现如下图所示的对话框。先确认下载器已经找到(USB-Blaster[USB-0]),再确认下载模式为JTAG方式,然后在下载文件一行中确认已勾选了Program/Configure一项,最后点击左边的Start按钮进行下载。

下载成功后,会在进度条显示100%,如下图所示。注意,这里的下载只是下到FPGA芯片的内存中,掉电就消失了。

7、结果验证

按照前面的电路,按键key没有按下时为1,按下时为0,输出为1时发光管led点亮,为0时熄灭。观察开发板,当key都没按下时(值都为1),led1亮(值为1),led2灭(值为0),如下图所示。证明,当进行1+1时,进位(led1)值为1,输出(led2)值为0。

当key1被按下时(值为0),led1灭(值为0),led2亮(值为1),如下图所示。证明,当进行0+1时,进位(led1)值为0,输出(led2)值为1。

当key2被按下时(值为0),led1灭(值为0),led2亮(值为1),如下图所示。证明,当进行1+0时,进位(led1)值为0,输出(led2)值为1。

当key都被按下时(值都为0),led1灭(值为0),led2灭(值为0),如下图所示。证明,当进行0+0时,进位(led1)值为0,输出(led2)值为0。

8、固化到FLASH中

按照前面的方法下载程序,在开发板掉电后,程序也就消失了。为了让程序在开发板上电后就能执行,就需要把程序固化到外部的FLASHROM器件中,当开发板上电时,会自动读取并运行。在Quartus中,工程程序编译后生成的文件以.sof结尾,它不能直接装入到FLASH中,需要转换一下格式。在Quartus中点击File->Convert Programming File,如下图所示,打开程序转换对话框。

在打开的对话框中,先要选择好程序文件的类型及外部FLASH器件,点击Programming file type右边的下拉列表框,选择JTAG Indirect Configuration File(.jic)一项,点击Configuration device右边的下拉列表框,选择EPCS16一项,如下图所示。

接着点击下方的Flash Loader选中,然后再点击右边的Add Device按钮,如下图所示。

在打开的对话框中,左边勾选Cyclone IV E,右边勾选EP4CE6,如下图所示。完成后点击OK确定,关闭对话框。

接下来点击下方的SOF Data选中,然后点击右边的Add File按钮,如下图所示。

在打开的对话框中,定位到工程目录下,选择前面编译生成的文件Exam_1.sof(与工程同名),如下图所示。选中后点击Open按钮关闭对话框。

确认所选器件及转换文件都正确后,点击下方的Generate按钮,如下图所示。

转换成功后,会弹出下图的提示框,点击OK关闭。

此时,在.sof所在目录下会生成一个同名的、以.jic为后缀的文件,该文件就可以写入到FLASH器件中了。再次点击工具条上的编程按钮(参见前面6),在打开的对话框中,先把前面的.sof文件删除(选中,点击Delete按钮),然后再导入.jic文件(点击Add File按钮,选中.jic文件并打开),检查一下打开的文件是否正确,并勾选Program/Configure,最后点击Start按钮把配置程序写入FLASH器件,如下图所示。

等待进度条为100%后同,表示写入成功。此时可把开发板断电,然后再上电,就可以看到程序已经在运行了。可再次执行第7步,验证结果是否正确。

9、清除FLASH中的固件

有时候希望把写入FLASH中的内容清除掉,可在编译对话框中,勾选Erase一项,并保证前面的Program/Configure同时勾选,然后点击Start按钮,当进度条到100%时,就把外部FLASH器件中的内容清空了。一般为了保险,在下载FLASH之前,都会先进行清空操作。

标签:以半加器,FPGA,为例,对话框,值为,如下,点击,按钮,所示
From: https://www.cnblogs.com/fxzq/p/18054154

相关文章

  • 高云FPGA直驱HDMI显示器
    HDMI显示实现的方案同LVDS一样,只是HDMI采用自带的DVITXIP实现并行RGB转TMDS协议,点亮HDMI接口的显示器,需要注意的是HDMI的并行时钟和串行时钟除以5实现的,此部分可以阅读代码和官方的DVITXIP文档,文档有详细介绍。硬件设计上需要注意HDMITX的应用,框起来的部......
  • FPGA数码管知识点整理
    知识点:  数码管控制分为位选和段选,通过位控制哪一个数码管亮,通过段选控制数码管中某一段亮。  我硬件买的上面的是共阳极的,也就是段选位给低电平就能亮。  下面是段选的位控制要显示的数据。比如数字0只要让G位灭掉就行,通过给段选8'h1100_0000 (共阳极),将g和点灭掉就是0......
  • 初识JavaScript逆向——以网易云音乐和招标网站为例
    前言:需要掌握一定的JavaScript基础,能看懂基础的JavaScript代码。我们平常在浏览网站的时候会看到许多加密的参数,如果需要知道它的原始数据,就需要知道整个加密过程,所以本篇文章就来介绍一下本人在初学逆向的时候一些笔记。想要获取加密过程大概来说有以下两个方法:(1)通过浏览器的i......
  • 基于FPGA的9/7整数小波变换和逆变换verilog实现,包含testbench
    1.算法运行效果图预览 将测试结果导入到matlab显示   2.算法运行软件版本vivado2019.2,matlab2022a 3.算法理论概述      小波变换是一种在信号处理中广泛应用的数学工具,它能够提供信号在不同尺度和位置上的信息。在图像处理、数据压缩、噪声消除等领域,小......
  • NVME FPGA IP测试记录
    这里涉及商业IP的部分文字资料,如有侵权,请联系删除。当前只说明基础测试,更多测试待后续更新。NVMEHOSTIPIP特性范例截图ZCU106测试使用ZCU106HPC0接口+FMCDriveNVME接口子卡,NVME使用三星980测试日志EnteringMainStartinginitialization...Expecting1dr......
  • (笔记)FPGA设计性能优化策略漫谈(一)--时序优化
    1   速度优化 1.1 关键路径重组FPGA逻辑设计中时序路径上的组合逻辑都会给路径增加延时,从而影响设计性能的往往只有几条关键的路径而已,所以可以通过减少关键路径上的组合逻辑单元数来减小该路径上的延时,从而达到优化的目的。关键路径重组技术多用于关键路径由多个路......
  • 基于FPGA的ECG信号滤波与心率计算verilog实现,包含testbench
    1.算法运行效果图预览 其RTL结构如下:  2.算法运行软件版本vivado2019.2  3.算法理论概述        心电图(ECG)是医学领域中常用的一种无创检测技术,用于记录和分析心脏的电活动。由于ECG信号微弱且易受到噪声干扰,因此在采集和处理过程中需要进行滤波以提取......
  • 以解析csv数据为例,讨论string、char[]、stream 不同类型来源是否能进行高性能读取解析
    篇幅较长,所以首先列举结果,也就是我们的目的核心目的为探索特定场景对不同类型数据进行统一抽象,并达到足够高性能,也就是一份代码实现,对不同类型数据依然高性能以下为结果,也就是我们的目的:对1w行csv数据的string进行RFC4180csv标准进行解析,string类型csv应该比StringRea......
  • 从面向对象的角度看集合类,以List<String> list = new ArrayList<>()为例
    心血来潮琢磨了这么一个问题:Listlist=newArrayList<>();这句代码挺常用的,但是如果要从面向对象的角度去讲讲这句代码背后的逻辑,该怎么讲?好像真不容易一口气说完整,于是便有了本文的梳理。从关系图我们可以知道,ArrayList继承自一个抽象类AbstractCollection,它们都实现了Lis......
  • 基于FPGA的图像双边滤波实现,包括tb测试文件和MATLAB辅助验证
    1.算法运行效果图预览  将FPGA数据导入到matlab对比测试: 2.算法运行软件版本vivado2019.2 matlab2022a 3.算法理论概述         双边滤波是一种非线性滤波方法,它能够在平滑图像的同时保持边缘的锐度。这一特性使得双边滤波在图像处理领域具有广泛的应......