本文以Altera公司生产的Cyclone IV系列的EP4CE15F17C8为主芯片的CRD500开发板作为项目的硬件实现平台,并以Quarter 18.1和ModelSim为开发工具和仿真工具。
目录
(3)选择目标芯片,选择CRD500开发板FPGA芯片EP4CE15F17C8。
[(1)方法一:基于Quartus 自身工具模块的仿真](#(1)方法一:基于Quartus 自身工具模块的仿真)
一、3-8译码器工作原理
3个输入信号进行译码,得到8个输出状态,输入与输出的关系如下表所示,表中1表示高电平,0表示低电平。
data:image/s3,"s3://crabby-images/0ca7f/0ca7f915bc0eacdb1503f2b345c05fd18ce4406d" alt=""
二、设计步骤
1、创建工程文件夹和编辑设计文件
(1)新建文件夹decoder_38
路径:D:\Verilog\txhFPGA\decoder_38
注:文件夹名不能包含中文
(2)输入源程序
选择菜单"File" --> "New"
data:image/s3,"s3://crabby-images/04ec1/04ec191717dd8cb2799f776664ba441f448f003d" alt=""
选择"Verilog HDL File"
data:image/s3,"s3://crabby-images/04a4b/04a4b511919cf334f73a4a5be2fed6dabd3f024e" alt=""
输入程序:
javascript
//3_8译码器程序,key1,key2,key3为译码器的输入,out为译码器的输出
module decoder_38(out, key_in);
output[7:0] out; // 说明信号out的流向
input[2:0] key_in; // 说明信号key_in的流向
reg[7:0] out; // 申明信号类型
always @(key_in) // 定义always块
begin
case(key_in)
3'd0: out=8'b11111110; //key_in = 000, out[0]为低电平
3'd1: out=8'b11111101;
3'd2: out=8'b11111011;
3'd3: out=8'b11110111;
3'd4: out=8'b11101111;
3'd5: out=8'b11011111;
3'd6: out=8'b10111111;
3'd7: out=8'b01111111;
endcase
end
endmodule
(3)文件存盘
快捷键"CTRL+S"保存文件,找到要保存的文件夹D:\Verilog\txhFPGA\decoder_38
文件名应与实体名保持一致,故文件名命名为decoder_38.v。保存后弹出对话框,点击"Yes"。
data:image/s3,"s3://crabby-images/ba686/ba6865240ce2c12241687c197dcc158c3e540832" alt=""
data:image/s3,"s3://crabby-images/bdc81/bdc81159fa89621f85ea967544043d6e90484693" alt=""
2、创建工程
(1)工程名、实体名
data:image/s3,"s3://crabby-images/c7923/c7923207c8c4e9bee6687357f3956976fe33de1a" alt=""
data:image/s3,"s3://crabby-images/8e18f/8e18fd14106513fd723506e14acf5ceb85f345e7" alt=""
(2)将设计文件加入工程,单击下图的"···"按钮。
data:image/s3,"s3://crabby-images/64523/645230c704b4ad9e33ca71cd993d8e2235505bc8" alt=""
data:image/s3,"s3://crabby-images/349b1/349b1e17d59c30ac867118ed933bfa53492624b4" alt=""
(3)选择目标芯片,选择CRD500开发板FPGA芯片EP4CE15F17C8。
data:image/s3,"s3://crabby-images/a458e/a458e353682f70b72ca7fac59895f3b7c1f19ad0" alt=""
(4)选择综合器和仿真器类型
若选"None",表示选择Quartus II 自带的综合器与仿真器。
对于简单设计项目,激励信号有规律,可选自带的仿真工具产生波形激励文件,作为信号源进行仿真。而对于复杂项目,激励信号无规律或很复杂,此时须选择第三方仿真软件(ModelSim_Altera)
data:image/s3,"s3://crabby-images/a8cbd/a8cbd82d9d42eb6d60272f43df69e6b121ed7a19" alt=""
(5)结束设置
显示本工程项目的层次结构和各层次的实体名
data:image/s3,"s3://crabby-images/36396/36396d75f88df9afffc3b0eb84e2bd1a8f14bdbf" alt=""
建立工程后,可使用"Project"菜单中的"Add/Remove Files in Project···"选项页在工程中设计、添加或删除其他文件。
或者:
3、编译工程
(1)编译前的设置
选择目标器件
data:image/s3,"s3://crabby-images/a4215/a42157197d18ad28010d6f15298dacd49aeeaf97" alt=""
data:image/s3,"s3://crabby-images/fcffe/fcffe7a73bb53364763a261e2f7419cece95ced8" alt=""
选择配置器件的编程配置方式
data:image/s3,"s3://crabby-images/aca05/aca05e2d334d433b6b5c6f57c5ccc7c85580eb87" alt=""
"Active Serial"这种方式指对专用配置器件(如项目中使用EPCS16)进行配置用的编程方式,而PC对此FPGA的直接配置方式都是JTAC方式。在"Configuration device"项目中选择配置芯片为"EPCS16"。
data:image/s3,"s3://crabby-images/f0a91/f0a91bb73f680076bbdd1af00b6b700e18e92e05" alt=""
选择编译后的输出文件格式(可选)。
data:image/s3,"s3://crabby-images/200fe/200fe13a2a843bb6bbf998382cda2f6e72e859c8" alt=""
选择目标器件闲置引脚的状态(可选)
data:image/s3,"s3://crabby-images/20d57/20d57e6e240f2e881aa444ce24db0bbcabf3700f" alt=""
(2)编译
data:image/s3,"s3://crabby-images/3d1c0/3d1c0d765fb8b79aa62360f1b5373443423bac34" alt=""
或者
data:image/s3,"s3://crabby-images/dac24/dac242d966a169d8958b0039fad9bbb446f96f12" alt=""
若编译成功,则:
data:image/s3,"s3://crabby-images/4d06b/4d06b565fd90b567d8d0494f66b3446066619f01" alt=""
4、仿真测试
(1)方法一:基于Quartus 自身工具模块的仿真
第一步:建立激励文件
data:image/s3,"s3://crabby-images/efd0a/efd0a33e9ff73a8d94f546839883aef9cc8e9020" alt=""
data:image/s3,"s3://crabby-images/67036/670360224e17552a7b51c64e8882a162af2b1252" alt=""
data:image/s3,"s3://crabby-images/85dab/85dabcbbcde57ffb249972161a377dd07123ebdb" alt=""
第二步:设置仿真时间区域
data:image/s3,"s3://crabby-images/63deb/63debaaf7808c3c9e78783555d1ab98c9746f7a7" alt=""
data:image/s3,"s3://crabby-images/1a961/1a961b5fef0999407de1466bc5fa67ba884e0c65" alt=""
第三步:保存波形文件。使用"File"菜单中的"Save As"项,将decoder_38.vwf的波形文件存入工程文件夹D:\Verilog\txhFPGA\decoder_38中。
第四步:输入信号节点,将3-8译码器的端口信号选入波形编辑器中。
data:image/s3,"s3://crabby-images/a225c/a225c0f11037c7fefcd83f61a11340bb9ef13aea" alt=""
data:image/s3,"s3://crabby-images/5f225/5f2257f0eaf5bb9e3d0a5da954f73356cd6e86fb" alt=""
选择完毕后按"OK"。
data:image/s3,"s3://crabby-images/6a0d3/6a0d35591d7a63705870d5d7aaf0b82afcbf1173" alt=""
data:image/s3,"s3://crabby-images/c623f/c623f9634fad24ae29535fdc2e14bd04ad0bdab5" alt=""
data:image/s3,"s3://crabby-images/f31fc/f31fc7f13e97ae5a78e6d8d9c2dcc15895d61e0e" alt=""
第五步:编辑输入波形(输入激励信号)。
单击选中图中的key_in[0],使之变成蓝色,再单击时钟,在"Clock"对话框中设置周期为20us、占空比为50%的周期信号。
data:image/s3,"s3://crabby-images/4be12/4be1277aed614cb36cbadd2c8349f591a0a3bfda" alt=""
得到key_in[0]的波形
data:image/s3,"s3://crabby-images/e391a/e391a3807a943a37ada7eb83f234c6669b95acf5" alt=""
同理将key_in[1]设置为周期为40us、占空比为50%的周期信号;
在key_in[2]的波形编辑区,前30us设置为低电平,再设置30us为高电平,40us为低电平。
data:image/s3,"s3://crabby-images/cbb02/cbb024ef864c8229124ac21d77071462a731c173" alt=""
仿真测试:
data:image/s3,"s3://crabby-images/a6273/a6273c07b3ccb3371465f6442bf33e50b1bbefb3" alt=""
data:image/s3,"s3://crabby-images/60b38/60b38ab6d7a7c1a2aa8314ffa3db991bf4160570" alt=""
(2)基于modelsim_altera的仿真
第一步:编写激励文件
创建testbench激励文件模板。
data:image/s3,"s3://crabby-images/9ea17/9ea17337584ead15f6bf44d9393338694bf2b85d" alt=""
打开模板文件,修改保存,得到激励文件。选择"File"菜单中的"Open"项,打开D:\Verilog\txhFPGA\decoder_38\simulation\modelsim\decoder_38.vt文件(创建的模板默认存放位置,且文件名自动命名)
data:image/s3,"s3://crabby-images/f390c/f390c4a746fdb2b0126a1261911f7117a46c2246" alt=""
激励脚本内容:
javascript
`timescale 1 ps/ 1 ps
module decoder_38_vlg_tst();
//reg eachvec;
// test vector input registers
reg [2:0] key_in;
// wires
wire [7:0] out;
// assign statements (if any)
decoder_38 i1 (
// port map - connection between master ports and signals/registers
.key_in(key_in),
.out(out)
);
initial //key_in[2]
begin
key_in[2] = 1'b0;
key_in[2] = #29440000 1'b1;
key_in[2] = #30720000 1'b0;
end
initial //key_in[1]
begin
repeat(2)
begin
key_in[1] = 1'b0;
key_in[1] = #20000000 1'b1;
# 20000000;
end
key_in[1] = 1'b0;
end
initial //key_in[0]
begin
repeat(5)
begin
key_in[0] = 1'b0;
key_in[0] = #10000000 1'b1;
# 10000000;
end
end
endmodule
第二步:设置仿真环境参量
data:image/s3,"s3://crabby-images/64eef/64eefdc0aacc42e0a92a6c45449ce93c47d4cc61" alt=""
依据激励文件修改参量,将"Time scale"栏设置为"1ps"(与激励文件一致)
data:image/s3,"s3://crabby-images/083b6/083b686b437b581e7858ad23ff288a6f299cffcf" alt=""
找到并添加激励文件,填写激励文件名、激励文件中的module名、激励文件中的实例名"i1",选中"End simulation at"并填写数字100,单位为"us"(与激励文件一致)。
data:image/s3,"s3://crabby-images/f27ee/f27eeea2bbd7bc91eba70723281d5e8a536b2178" alt=""
ModelSim仿真
data:image/s3,"s3://crabby-images/32b7e/32b7e7781042db3a5f47e3eab6e671f92597d5e1" alt=""
启动仿真,观察仿真结果(单击后跳转ModelSim,将自动获得仿真结果)
data:image/s3,"s3://crabby-images/3230a/3230afe4d1b9fbd22f95c9570e5040ae0fe385ae" alt=""
若是第一次使用Modelsim-Altera,需建立Quartus Prime和Modelsim的链接。
设置仿真文件的格式与目录
5、引脚锁定与.sof文件下载
(1)引脚锁定
data:image/s3,"s3://crabby-images/01721/01721242bce8079b1588942ed279273667112d47" alt=""
data:image/s3,"s3://crabby-images/2bbad/2bbad5033bd8eea047b81c262c40dd6df3db4ba4" alt=""
引脚锁定后,必须再编译一次,将引脚信息编译进下载文件中。在编译后产生的文件中,.sof格式的文件可直接下载到FPGA中运行。
引脚的绑定依据:
(1)FPGA与CRD500开发板上5个按键的连接关系:
|----------|---------|----------|----------|----------|----------|
| 信号名称 | rst | key1 | key2 | key3 | key4 |
| FPGA引脚 | P14 | T10 | P11 | N11 | N12 |
| 功能 | 键按下------高电平;不按------低电平 |||||
(2)8个LED灯与FPGA连接关系:
|----------|------------|------------|------------|------------|------------|------------|------------|------------|
| 信号名称 | Led(0) | Led(1) | Led(2) | Led(3) | Led(4) | Led(5) | Led(6) | Led(7) |
| FPGA引脚 | R11 | T11 | R12 | T12 | R13 | T13 | R14 | T14 |
| 功能 | 1------亮;0------灭 ||||||||
(2)选择编程模式和配置
为将编译产生的.sof文件配置进FPGA中进行测试,首先将系统连接好,开发板上电,后在"Tool"菜单中选择"Programmer"。在"Mode"栏选择编程模式为"JTAG",单击选中出现的下载文件右侧的第一个小方框,打勾。若此文件未出现,则点击左侧的"Add File",选择配置文件decoder_38.sof。
data:image/s3,"s3://crabby-images/a9d83/a9d83b7e518ab06aad36f87cb84c736a23e07a6e" alt=""
data:image/s3,"s3://crabby-images/5a4b3/5a4b37273b6e49f55fcd394be55cd7e0182d4841" alt=""
单击"Hardware Setup"后,在弹出的对话框中选择硬件,然后单击"Close"按钮。
data:image/s3,"s3://crabby-images/19898/1989802e127db267713991811fee2a2dca62f720" alt=""
若未出现硬件,则参考:
再单击左侧的"Start"项。
data:image/s3,"s3://crabby-images/0d67d/0d67dfc41b5986ba4f718de9291765226916e135" alt=""
当右侧的"Process"栏显示为100%,则表示编程成功。
data:image/s3,"s3://crabby-images/91919/9191936858c952a6271783cdd3bba7fb0ca4c2db" alt=""
三、板载测试
板载测试就是由三个按键产生000~111共8组输入信号,通过指示灯的亮与灭判断3-8译码器输出的准确性。
data:image/s3,"s3://crabby-images/cb91f/cb91f12c1b71668a008208832860d0a1870be073" alt=""
当未按键时,key_in=000,此时译码器输出"11111110",即LED0=0(LED1灭,其余亮)
当按下key1时,key_in=001,此时LED2=0(LED1灭,其余亮)
......
当同时按下key1、 key2、 key3,key_in=111,此时译码器输出"01111111",即LED7灭,其余亮。
data:image/s3,"s3://crabby-images/0ca7f/0ca7f915bc0eacdb1503f2b345c05fd18ce4406d" alt=""
板载测试结果如上表结论一致,由此验证了3-8译码器输出的准确性,至此该项目完成!
data:image/s3,"s3://crabby-images/19835/198358dc4b047960e102b66d88d5f086f613c285" alt=""