基于Quartus II的FPGA/CPLD设计实例精解
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人

2.3 基于Quartus Ⅱ的设计实例

加法器电路是数字电路中运算器的重要单元,分为半加器和全加器两种。全加器的实现可以根据其真值表直接用VHDL语言编程实现。

实现全加器的操作步骤如下:

(1)选择【开始】→【程序】→【Altera】→【Quartus Ⅱ】命令,或者双击桌面上的Quartus Ⅱ图标运行Quartus Ⅱ软件,出现如图2-9所示的界面。如果是第一次打开Quartus Ⅱ软件,可能还会有其他的提示信息,用户可以根据自己的实际情况进行设计后进入如图2-9所示的界面。

图2-9 Quartus Ⅱ软件的默认启动界面

(2)选择软件中的菜单命令【File】→【New Project Wizard】,新建一个工程,如图2-10所示。

图2-10 新建工程向导介绍页

(3)单击图2-10中的【Next】按钮,进入工作目录,工程名的设定对话框如图2-11所示。第一个输入框为工程目录输入框,用户可以输入路径来设置工程的目录;设定好后,所有的生成文件将放入这个工作目录。第二个输入框为工程名称输入框,第三个输入框为顶层实体名称输入框。用户可以设定EXP1,一般情况下工程名称与实体名称相同。用户也可以根据自己的实际情况来设定。

图2-11 制定工程及工作目录

(4)单击【Next】按钮,进入下一个设定对话框,按默认选项直接单击【Next】按钮,进入器件选择对话框,如图2-12和图2-13所示。在图2-13中,用户可以根据自己的硬件资源进行相应的选择;在选择具体器件的时候,首先要指定正确的器件家族(Family)。在【Family】一栏的下拉列表中选取正确的器件系列。这里我们选择FLEK10K系列芯片EPF10K10LC84-4。

图2-12 器件选择对话框(一)

图2-13 器件选择对话框(二)

在图2-13中,单击【Next】按钮,完成器件的选取,进入EDA Tool设置界面,如图2-14所示。

图2-14 EDA Tool设置界面

(5)按默认选项,单击【Next】按钮,出现新建工程以前所有的设置信息,如图2-15所示,单击【Finish】按钮,完成新建工程的建立,如图2-16所示。

图2-15 新建工程信息汇总

图2-16 新建立的工程界面

(6)选择【File】→【New】命令,新建一个VHDL文件,如图2-17所示。

图2-17 新建一个VHDL文件

(7)选择【VHDL File】文件类型,单击【OK】按钮,将VHDL程序写入后,如图2-18所示,并选择【File】→【Save】命令,无须做任何更改,单击【OK】按钮即可,如图2-19所示。

图2-18 VHDL程序写入

图2-19 存储新建的VHDL文件

(8)分析与综合。

① 设计输入完毕后,为了检查程序中是否存在语法错误,可运行菜单命令【Processing】→【Analyze current file】,进行语法错误检查。若无语法错误,系统分析后弹出如图2-20所示的信息对话框。

图2-20 语法分析成功对话框

② 选择主菜单命令【Processing】→【Start】→【Start Analysis & Synthesis】,运行分析与综合流程。执行该命令后,系统整合当前设计的所有设计文件,形成网表文件,并建立该设计的数据库;若设计无误,则系统弹出如图2-21所示的对话框提示分析与综合成功执行。

图2-21 分析与综合成功提示对话框

通过分析与综合的过程后,即可通过RTL电路观察器查看当前设计系统综合后生成的逻辑图。选择【Tools】→【Netlist Viewer】→【RTL Viewer】命令,系统运行电路观察器,查看当前设计生成的逻辑电路,如图2-22所示。

图2-22 RTL电路观察器

(9)代码书写结束后,选择【Processing】→【Start Compilation】命令,对编写的代码进行编译,直到编译通过,编译通过对话框如图2-23所示。

图2-23 编译通过对话框

(10)时序仿真。为了验证设计的逻辑功能和内部时序的正确性,需要对设计进行时序仿真。通过建立波形矢量文件进行仿真,仿真结果如图2-24所示。

图2-24 仿真结果

(11)引脚分配。选择【Assignment】→【Assignment Editor】命令,进入【Assignment Editor】(资源分配编辑器),分配引脚端口,如图2-25所示。

图2-25 引脚分配

(12)编译无误后,将实验系统的下载线与计算机并口连接好,打开电源。选择【Tools】→【Programmer】命令,进入程序下载界面,该界面对应文件名为adder.cdf。使用USB电缆时的界面如图2-26所示。使用ByteBlaster下载线下载时的界面如图2-27所示。然后单击【Start】按钮,将adder.sof文件下载到FPGA芯片中(注:初次使用USB电缆下载时,需要安装USB-Blaster驱动)。

图2-26 硬件安装后的编程下载界面

图2-27 编程下载界面

在完成硬件安装的编程下载界面中,在【Mode】一栏中选择【JTAG】,在工作区的下载文件列表选项中,选中【Program/Configure】复选框,单击左侧工具栏的启动下载按钮,启动下载。下载完毕后,可根据设计与外围资源的链接情况,进行测试操作。

(13)观察实验结果是否与程序设计相吻合。

参考程序如下所示:

            ---------------------------------库说明-------------------------------
            library ieee;                                    --IEEE标准库
            use ieee.std_logic_1164.all;
            entity adder is                                   --adder是实体名
            port(
            INA,INB:IN std_logic;                            --输入信号
            CI:std_logic;                                   --输入进位信号
            SO:OUT std_logic;                                --和输出
            CO:OUT std_logic);                              --进位信号输出
            end adder;
            -------------------------------结构体说明-----------------------------
            architecture rtl of adder is
            COMPONENT half_adder      --元件定义语句,定义半加器电路模块
            PORT(IN0,IN1:IN std_logic;
            SUM:OUT std_logic;
            CARRY_OUT:OUT std_logic);
            end COMPONENT ;
            SIGNAL SUM1,CO1,CO2:std_logic;
            BEGIN
            adder1:half_adder PORT MAP(INA,INB,SUM1,CO1);
            adder2:half_adder PORT MAP(SUM1,CI,SO,CO2);
            CO<=CO1 OR CO2;
            END rtl;
            --半加器模块
            library ieee;                                       --IEEE标准库
            use ieee.std_logic_1164.all;
            entity half_adder is
            port(
            IN0,IN1:IN std_logic;
            SUM:OUT std_logic;
            CARRY_OUT:OUT std_logic);
            end half_adder;
            -------------------------------结构体说明-----------------------------
            architecture rtl of half_adder is
            BEGIN
            PROCESS(IN0,IN1)
            BEGIN
            SUM<=IN0 XOR IN1;
            CARRY_OUT<=IN0 AND IN1;
            END PROCESS;
            END rtl;