版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、EDA技術(shù)與VHDL,第4章Quartus II 使用方法,4.1 QuartusII設(shè)計流程,1.創(chuàng)建工程準備工作,圖4-1 選擇編輯文件,KONXIN,4.1 QuartusII設(shè)計流程,1.創(chuàng)建工程準備工作,圖4-2 選擇編輯文件的語言類型,鍵入源程序并存盤,4.1 QuartusII設(shè)計流程,2. 創(chuàng)建工程,圖4-3 利用“New Preject Wizard”創(chuàng)建工程cnt10,4.1 QuartusII設(shè)計流程
2、,2.創(chuàng)建工程,圖4-4 將所有相關(guān)的文件都加入進此工程,4.1 QuartusII設(shè)計流程,2.創(chuàng)建工程,圖4-5 選擇目標(biāo)器件EP1C6Q240C8,4.1 QuartusII設(shè)計流程,3.編譯前設(shè)置,圖4-6 選擇配置器件的工作方式,4.1 QuartusII設(shè)計流程,3.編譯前設(shè)置,圖4-7 選擇配置器件和編程方式,圖4-8 全程編譯后出現(xiàn)報錯信息,4.全程編譯,4.1 QuartusII設(shè)計流程,圖4-9 選擇編輯矢
3、量波形文件,5.時序仿真,4.1 QuartusII設(shè)計流程,圖4-10 波形編輯器,5.時序仿真,4.1 QuartusII設(shè)計流程,圖4-11 設(shè)置仿真時間長度,5.時序仿真,4.1 QuartusII設(shè)計流程,圖4-12 .vwf激勵波形文件存盤,5.時序仿真,4.1 QuartusII設(shè)計流程,圖4-13 向波形編輯器拖入信號節(jié)點,4.1.2 創(chuàng)建工程,4.1 QuartusII設(shè)計流程,圖4-14 設(shè)置時鐘CL
4、K的周期,5.時序仿真,4.1 QuartusII設(shè)計流程,圖4-15 設(shè)置好的激勵波形圖,5.時序仿真,4.1 QuartusII設(shè)計流程,圖4-16 選擇總線數(shù)據(jù)格式,5.時序仿真,4.1 QuartusII設(shè)計流程,圖4-17 選擇仿真控制,5.時序仿真,4.1 QuartusII設(shè)計流程,圖4-18 仿真波形輸出,5.時序仿真,4.1 QuartusII設(shè)計流程,圖4-19 選擇全時域顯示,5.時序仿真,4.1 Qu
5、artusII設(shè)計流程,圖4-20 Assignment Editor編輯器,6.觀察RTL電路,7.引腳鎖定和下載,4.1 QuartusII設(shè)計流程,圖4-21 表格方式引腳鎖定對話框圖,7.引腳鎖定和下載,4.1 QuartusII設(shè)計流程,4-22 圖形方式引腳鎖定對話框,7.引腳鎖定和下載,4.1 QuartusII設(shè)計流程,圖4-23 選擇編程下載文件,8.編程下載,4.1 QuartusII設(shè)計流程,圖4-24加入
6、編程下載方式,8.編程下載,4.1 QuartusII設(shè)計流程,圖4-25 雙擊選中的編程方式名,8.編程下載,4.1 QuartusII設(shè)計流程,圖4-26 ByteBlaster II接口AS模式編程窗口,9.AS模式編程,4.1 QuartusII設(shè)計流程,圖4-27 選擇目標(biāo)器件EP1C6Q240,10.JTAG間接模式編程,4.1 QuartusII設(shè)計流程,圖4-28 選定SOF文件后,選擇文件壓縮,10.
7、JTAG間接模式編程,4.1 QuartusII設(shè)計流程,圖4-29 用JTAG模式對配置器件EPCS1進行間接編程,10.JTAG間接模式編程,4.2 嵌入式邏輯分析儀,圖4-30 SignalTap II編輯窗,1.打開SignalTap II編輯窗,4.2 嵌入式邏輯分析儀,圖4-31 SignalTap II編輯窗,2.調(diào)入待測信號,3.SignalTap II參數(shù)設(shè)置,4.2 嵌入式邏輯分析儀,圖4-32
8、下載cnt10.sof并準備啟動SignalTap II,4.文件存盤,5.編譯下載,6.啟動SignalTap II進行采樣與分析,4.2 嵌入式邏輯分析儀,圖4-33 SignalTap II數(shù)據(jù)窗設(shè)置后的信號波形,6.啟動SignalTap II進行采樣與分析,4.3 編輯SignalTapII的觸發(fā)信號,圖4-34 選擇高級觸發(fā)條件,4.3 編輯SignalTapII的觸發(fā)信號,圖4
9、-35 進入“觸發(fā)條件函數(shù)編輯”窗口,4.3 編輯SignalTapII的觸發(fā)信號,圖4-36 編輯觸發(fā)函數(shù),4.4 LPM_ROM宏模塊應(yīng)用,圖4-37 正弦信號發(fā)生器結(jié)構(gòu)框圖,4.4.1 工作原理,4.4 LPM_ROM宏模塊應(yīng)用,4.4.2 定制初始化數(shù)據(jù)文件,1.建立.mif格式文件,【例4-1】WIDTH = 8;DEPTH = 64;ADDRESS_RADIX = HEX;DATA_RADIX = HEX;
10、CONTENT BEGIN0 : FF;1 : FE;2 : FC;3 : F9;4 : F5;…(數(shù)據(jù)略去)3D : FC;3E : FE;3F : FF;END;,4.4 LPM_ROM宏模塊應(yīng)用,4.4.2 定制初始
11、化數(shù)據(jù)文件,1.建立.mif格式文件,【例4-2】#include #include "math.h"main(){int i;float s;for(i=0;i sin_rom.mif;,4.4 LPM_ROM宏模塊應(yīng)用,4.4.2 定制初始化數(shù)據(jù)文件,2.建立.hex格式文件,圖4-38 將波形數(shù)據(jù)填入mif文件表中,4.4 LPM_ROM宏模塊應(yīng)用,圖4-39 ASM格式建hex文件,4.4
12、LPM_ROM宏模塊應(yīng)用,4.4.2 定制初始化數(shù)據(jù)文件,2.建立.hex格式文件,圖4-40 sdata.hex文件的放置路徑,4.4 LPM_ROM宏模塊應(yīng)用,4.4.3 定制LPM_ROM元件,圖4-41 定制新的宏功能塊,4.4 LPM_ROM宏模塊應(yīng)用,4.4.3 定制LPM_ROM元件,圖4-42 LPM宏功能塊設(shè)定,4.4 LPM_ROM宏模塊應(yīng)用,4.4.3 定制LPM_ROM元件,圖4-43 選擇data
13、_rom模塊數(shù)據(jù)線和地址線寬,4.4 LPM_ROM宏模塊應(yīng)用,4.4.3 定制LPM_ROM元件,圖4-44 選擇地址鎖存信號inclock,4.4 LPM_ROM宏模塊應(yīng)用,4.4.3 定制LPM_ROM元件,圖4-45 調(diào)入ROM初始化數(shù)據(jù)文件并選擇在系統(tǒng)讀寫功能,4.4 LPM_ROM宏模塊應(yīng)用,4.4.3 定制LPM_ROM元件,圖4-46 LPM_ROM設(shè)計完成,4.4 LPM_ROM宏模塊應(yīng)用,【例4-3】
14、LIBRARY ieee;USE ieee.std_logic_1164.all;LIBRARY altera_mf;USE altera_mf.altera_mf_components.all; --使用宏功能庫中的所有元件ENTITY data_rom ISPORT (address: IN STD_LOGIC_VECTOR (5 DOWNTO 0); inclock: IN STD_LOGIC ;
15、q: OUT STD_LOGIC_VECTOR (7 DOWNTO 0) );END data_rom;ARCHITECTURE SYN OF data_rom ISSIGNAL sub_wire0: STD_LOGIC_VECTOR (7 DOWNTO 0);COMPONENT altsyncram --例化altsyncram元件,調(diào)用了LPM模塊altsyncramGENERIC (
16、 --參數(shù)傳遞語句intended_device_family : STRING; --類屬參量數(shù)據(jù)類型定義width_a: NATURAL; widthad_a: NATURAL;numwords_a: NATURAL; operation_mode: STRING;outdata_reg_a: STRING;a
17、ddress_aclr_a: STRING;outdata_aclr_a: STRING; width_byteena_a: NATURAL;init_file: STRING; lpm_hint: STRING;lpm_type: STRING);PORT (clock0: IN STD_LOGIC ; --altsyncram元件接口聲明addr
18、ess_a: IN STD_LOGIC_VECTOR (5 DOWNTO 0);q_a: OUT STD_LOGIC_VECTOR (7 DOWNTO 0) );END COMPONENT; (接下頁),4.4 LPM_ROM宏模塊應(yīng)用,BEGINq "Cyclone", --
19、參數(shù)傳遞映射width_a => 8, --數(shù)據(jù)線寬度8widthad_a => 6, --地址線寬度6numwords_a => 64, --數(shù)據(jù)數(shù)量64o
20、peration_mode => "ROM", --LPM模式ROMoutdata_reg_a => "UNREGISTERED", --輸出無鎖存address_aclr_a => "NONE",
21、 --無異步地址清0outdata_aclr_a => "NONE", --無輸出鎖存異步清0width_byteena_a => 1, -- byteena_a輸入口寬度1init_file => "./dataHEX/SDATA.hex", --ROM
22、初始化數(shù)據(jù)文件,此處已修改過lpm_hint => "ENABLE_RUNTIME_MOD=YES, INSTANCE_NAME=NONE", lpm_type => "altsyncram" ) --LPM類型PORT MAP ( clock0 => inclock, address_a => a
23、ddress,q_a => sub_wire0 );END SYN;,4.4 LPM_ROM宏模塊應(yīng)用,4.4.4 完成頂層設(shè)計,【例4-4】 正弦信號發(fā)生器頂層設(shè)計LIBRARY IEEE; --正弦信號發(fā)生器源文件USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;ENTITY SINGT IS PORT ( CLK : IN STD
24、_LOGIC; --信號源時鐘 DOUT : OUT STD_LOGIC_VECTOR (7 DOWNTO 0) );--8位波形數(shù)據(jù)輸出END;ARCHITECTURE DACC OF SINGT ISCOMPONENT data_rom --調(diào)用波形數(shù)據(jù)存儲器LPM_ROM文件:data_rom.vhd聲明 PORT(address : IN STD_LOG
25、IC_VECTOR (5 DOWNTO 0);--6位地址信號 inclock : IN STD_LOGIC ;--地址鎖存時鐘 q : OUT STD_LOGIC_VECTOR (7 DOWNTO 0));END COMPONENT; SIGNAL Q1 : STD_LOGIC_VECTOR (5 DOWNTO 0); --設(shè)定內(nèi)部節(jié)點作為地址計數(shù)器 BEGINPROCESS
26、(CLK ) --LPM_ROM地址發(fā)生器進程 BEGINIF CLK'EVENT AND CLK = '1' THEN Q1Q1, q => DOUT,inclock=>CLK);--例化END;,4.4 LPM_ROM宏模塊應(yīng)用,4.4.4 完成頂層設(shè)計,圖4-47 仿真波形輸出,4.4 LPM_ROM宏模塊應(yīng)用,
27、4.4.4 完成頂層設(shè)計,圖4-48 嵌入式邏輯分析儀獲得的波形,4.5 In-System Memory Content Editor應(yīng)用,圖4-49 In-System Memory Content Editor編輯窗,4.5 In-System Memory Content Editor應(yīng)用,圖4-50 與實驗系統(tǒng)上的FPGA通信正常情況下的編輯窗界面,4.5 In-System Memory Content Editor
28、應(yīng)用,圖4-51 從FPGA中的ROM讀取波形數(shù)據(jù),4.5 In-System Memory Content Editor應(yīng)用,圖4-52 編輯波形數(shù)據(jù),4.5 In-System Memory Content Editor應(yīng)用,圖4-53下載編輯數(shù)據(jù)后的SignalTap II采樣波形,4.6 LPM_RAM/FIFO的定制與應(yīng)用,圖4-54 編輯定制RAM,4.6.1 LPM_RAM定制,4.6 LPM_RAM/
29、FIFO的定制與應(yīng)用,圖4-55 LPM_RAM的仿真波形,4.6.1 LPM_RAM定制,4.6 LPM_RAM/FIFO的定制與應(yīng)用,圖4-56 FIFO編輯窗,4.6.2 FIFO定制,4.6 LPM_RAM/FIFO的定制與應(yīng)用,圖4-57 FIFO的仿真波形,4.6.2 FIFO定制,4.7 LPM嵌入式鎖相環(huán)調(diào)用,圖4-58 選擇參考時鐘為20MHz,1.建立嵌入式鎖相環(huán)元件,4.7 LPM嵌入式鎖相環(huán)調(diào)用,圖
30、4-59 選擇控制信號,1.建立嵌入式鎖相環(huán)元件,4.7 LPM嵌入式鎖相環(huán)調(diào)用,圖4-60 選擇e0的輸出頻率為210MHz,2.測試鎖相環(huán),4.7 LPM嵌入式鎖相環(huán)調(diào)用,圖4-61 PLL元件的仿真波形,2.測試鎖相環(huán),4.7 LPM嵌入式鎖相環(huán)調(diào)用,2.測試鎖相環(huán),. . .;ENTITY DDS_VHDL IS PORT ( CLK
31、K : IN STD_LOGIC; --此時鐘進入鎖相環(huán) FWORD : IN STD_LOGIC_VECTOR(7 DOWNTO 0);. . .;ARCHITECTURE one OF DDS_VHDL IS COMPONENT PLLU --調(diào)入PLL聲明 PORT (inclk0 : IN STD_LOGIC :=
32、39;0'; c0 : OUT STD_LOGIC); END COMPONENT; COMPONENT REG32B. . .;BEGIN . . .; u6 : SIN_ROM PORT MAP( address=>D32B(31 DOWNTO 22), q=>POUT, inclock=>CLK ); u7 : PLL20 PORT
33、 MAP( inclk0=> CLKK,c0=>CLK); --例化END;,4.8 IP核NCO使用方法,圖4-62 安裝NCO核,4.8 IP核NCO使用方法,圖4-63 確定安裝路徑,4.8 IP核NCO使用方法,圖4-64 開始Core的工程路徑,4.8 IP核NCO使用方法,圖4-65 確定工程路徑和工程名,4.8 IP核NCO使用方法,圖4-66 打開Core用戶庫設(shè)置窗,4.8 IP核NCO使用
34、方法,圖4-67 選中確定路徑上的NCO庫,4.8 IP核NCO使用方法,圖4-68 加入NCO庫,4.8 IP核NCO使用方法,圖4-69 已經(jīng)在工程中加入NCO庫,4.8 IP核NCO使用方法,圖4-70 打開Core設(shè)置管理窗,4.8 IP核NCO使用方法,圖4-71 開始進入Core參數(shù)設(shè)置窗Toolbench,4.8 IP核NCO使用方法,圖4-72 設(shè)置NCO參數(shù),4.8 IP核NCO使用方法,圖4-73設(shè)置NC
35、O參數(shù),4.8 IP核NCO使用方法,圖4-74 完成NCO參數(shù)設(shè)置并生成設(shè)計文件后的信息窗,4.8 IP核NCO使用方法,圖4-75 加入NCO的授權(quán)文件,4.9 原理圖設(shè)計方法,圖4-76 元件輸入對話框,1. 為本項工程設(shè)計建立文件夾,2. 輸入設(shè)計項目和存盤,4.9 原理圖設(shè)計方法,圖4-77 將所需元件全部調(diào)入原理圖編輯窗并連接好,3. 將設(shè)計項目設(shè)置成可調(diào)用的元件,4.9 原理圖設(shè)計方法,圖4-78 連接好的全加器原理
36、圖f_adder.bdf,4. 設(shè)計全加器頂層文件,4.9 原理圖設(shè)計方法,圖4-79 f_adder.bdf工程設(shè)置窗,5. 將設(shè)計項目設(shè)置成工程和時序仿真,4.9 原理圖設(shè)計方法,圖4-80 加入本工程所有文件,5. 將設(shè)計項目設(shè)置成工程和時序仿真,4.9 原理圖設(shè)計方法,圖4-81 全加器工程f_adder的仿真波形文件,5. 將設(shè)計項目設(shè)置成工程和時序仿真,4.10流水線乘法器的混合輸入設(shè)計,【例4-5】LIBRARY IEE
37、E;USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;ENTITY ADDER16B IS PORT ( CIN : IN STD_LOGIC; A,B : IN STD_LOGIC_VECTOR(15 DOWNTO 0); S : OUT STD_LOGIC_VECTOR(15 DOWNTO 0);
38、 COUT : OUT STD_LOGIC );END ADDER16B;ARCHITECTURE behav OF ADDER16B IS SIGNAL SINT : STD_LOGIC_VECTOR(16 DOWNTO 0);SIGNAL AA,BB : STD_LOGIC_VECTOR(16 DOWNTO 0);BEGINAA<='0'&A; BB&l
39、t;='0'& B; SINT <= AA + BB + CIN; S <= SINT(15 DOWNTO 0); COUT <= SINT(4);END behav;,4.10流水線乘法器的混合輸入設(shè)計,圖4-82 在原理圖編輯窗加入LPM元件,4.10流水線乘法器的混合輸入設(shè)計,圖4-83 將LPM乘法器設(shè)置為流水線工作方式,4.10流水線乘法器的混合輸入設(shè)計,圖4-84
40、乘法累加器電路,4.10流水線乘法器的混合輸入設(shè)計,圖4-85 muladd工程仿真波形,4.10流水線乘法器的混合輸入設(shè)計,圖4-86 對乘法器選擇不同設(shè)置后的編譯報告,習(xí) 題,4-1. 如果不使用MegaWizard Plug-In Manager工具,如何在自己的設(shè)計中調(diào)用LPM模塊?以計數(shù)器lpm_counter為例,寫出調(diào)用該模塊的程序,其中參數(shù)自定。4-2. LPM_ROM、LPM_RAM、LPM_FIFO
41、等模塊與FPGA中嵌入的EAB,ESB,M4K有怎樣的聯(lián)系關(guān)系? 4-3. 參考QuartusII的Help(Contents),詳細說明LPM元件altcam、altsyncram、lpm_fifo、lpm_shiftreg的使用方法,以及其中各參量的含義和設(shè)置方法。4-4. 如果要設(shè)計一8051單片機,如何為它配置含有匯編程序代碼的ROM(文件)?4-5. 將例4-4的頂層程序和例4-3的ROM程序合并成為一個程序,要求用例化
42、語句直接調(diào)用LPM模塊altsyncram。編譯驗證,使之功能與原設(shè)計相同。4-6. 根據(jù)例3-23設(shè)計8位左移移位寄存器,給出時序仿真波形。4-7. 歸納利用QuartusII進行VHDL文本輸入設(shè)計的流程:從文件輸入一直到SignalTap II測試。4-8. 如何為設(shè)計中的SignalTap II加入獨立采用時鐘?試給出完整的程序和對它的實測結(jié)果。,習(xí) 題,4-9. 參考Quartus II的Hel
43、p,詳細說明Assignments菜單中Settings對話框的功能。(1)說明其中的Timing Requirements & Qptions的功能、使用方法和檢測途徑。(2)說明其中的Compilation Process的功能和使用方法。(3)說明Analysis & Synthesis Setting的功能和使用方法,以及其中的Synthesis Netlist Optimization的功能和使用方法。
44、(4)說明Fitter Settings中的Design Assistant和Simulator功能,舉例說明它們的使用方法。4-10. 概述Assignments菜單中Assignment Editor的功能,舉例說明。4-11. 用74148和與非門實現(xiàn)8421BCD優(yōu)先編碼器,用3片74139組成一個5-24線譯碼器。4-12. 用74283加法器和邏輯門設(shè)計實現(xiàn)一位8421BCD碼加法器電路,輸入輸出均是BCD碼,CI為低
45、位的進位信號,CO為高位的進位信號,輸入為兩個1位十進制數(shù)A,輸出用S表示。4-13. 設(shè)計一個7人表決電路,參加表決者7人,同意為1,不同意為0,同意者過半則表決通過,綠指示燈亮;表決不通過則紅指示燈亮。4-14. 設(shè)計一個周期性產(chǎn)生二進制序列01001011001的序列發(fā)生器,用移位寄存器或用同步時序電路實現(xiàn),并用時序仿真器驗證其功能。,實 驗 與 設(shè) 計,4-1. 組合電路的設(shè)計實驗?zāi)康模菏煜uartusⅡ的VHDL文本設(shè)
46、計流程全過程,學(xué)習(xí)簡單組合電路的設(shè)計、多層次電路設(shè)計、仿真和硬件測試。 實驗內(nèi)容1:首先利用QuartusⅡ完成2選1多路選擇器(例3-3)的文本編輯輸入(mux21a.vhd)和仿真測試等步驟,給出圖3-3所示的仿真波形。最后在實驗系統(tǒng)上進行硬件測試,驗證本項設(shè)計的功能。 實驗內(nèi)容2:將此多路選擇器看成是一個元件mux21a,利用元件例化語句描述圖3-18,并將此文件放在同一目錄中。,實 驗 與 設(shè) 計,以下是部分參考程序:..
47、. COMPONENT MUX21A PORT ( a,b,s : IN STD_LOGIC; y : OUT STD_LOGIC); END COMPONENT ;... u1 : MUX21A PORT MAP(a=>a2,b=>a3,s=>s0,y=>tmp); u2 : MUX21A PORT MAP(a=&
48、gt;a1,b=>tmp,s=>s1,y=>outy); END ARCHITECTURE BHV ;按照本章給出的步驟對上例分別進行編譯、綜合、仿真。并對其仿真波形作出分析說明。,實 驗 與 設(shè) 計,實驗任務(wù)3:引腳鎖定以及硬件下載測試。建議選實驗電路模式5,用鍵1(PIO0)控制s0;用鍵2(PIO1)控制s1;a3、a2和a1分別接clock5、clock0和clock2;輸出信號outy仍接揚聲器spk
49、er。通過短路帽選擇clock0接256Hz信號,clock5接1024Hz,clock2接8Hz信號。最后進行編譯、下載和硬件測試實驗(通過選擇鍵1、鍵2,控制s0、s1,可使揚聲器輸出不同音調(diào))。 實驗報告:根據(jù)以上的實驗內(nèi)容寫出實驗報告,包括程序設(shè)計、軟件編譯、仿真分析、硬件測試和詳細實驗過程;給出程序分析報告、仿真波形圖及其分析報告。 附加內(nèi)容:根據(jù)本實驗以上提出的各項實驗內(nèi)容和實驗要求,設(shè)計1位全加器。首先用Q
50、uartusII完成以上給出的全加器的設(shè)計,包括仿真和硬件測試。實驗要求分別仿真測試底層硬件或門和半加器,最后完成頂層文件全加器的設(shè)計和測試,給出設(shè)計原程序,程序分析報告、仿真波形圖及其分析報告。 實驗習(xí)題:以1位二進制全加器為基本元件,用例化語句寫出8位并行二進制全加器的頂層文件,并討論此加法器的電路特性。,實 驗 與 設(shè) 計,實驗4-2. 時序電路的設(shè)計 實驗?zāi)康模菏煜uartusⅡ的VHDL文本設(shè)計過程
51、,學(xué)習(xí)簡單時序電路的設(shè)計、仿真和測試。 實驗任務(wù)1:設(shè)計觸發(fā)器(使用例3-6),給出程序設(shè)計、軟件編譯、仿真分析、硬件測試及詳細實驗過程。 實驗任務(wù)2:設(shè)計鎖存器(使用例3-14),同樣給出程序設(shè)計、軟件編譯、仿真分析、硬件測試及詳細實驗過程。 實驗任務(wù)3:只用一個1位二進制全加器為基本元件和一些輔助的時序電路,設(shè)計一個8位串行二進制全加器。提示:此加法器有并/串和串/并移位寄存器各一。 實驗報告:分析比
52、較實驗內(nèi)容1和2的仿真和實測結(jié)果,說明這兩種電路的異同點。,實 驗 與 設(shè) 計,實驗4-3. 含異步清0和同步時鐘使能的加法計數(shù)器的設(shè)計 實驗?zāi)康模簩W(xué)習(xí)計數(shù)器的設(shè)計、仿真和硬件測試,進一步熟悉VHDL設(shè)計技術(shù)。 實驗原理:實驗程序為例3-22,實驗原理參考3.5節(jié),設(shè)計流程參考本章。 實驗任務(wù)1:在QuartusⅡ上對例3-22進行編輯、編譯、綜合、適配、仿真。說明例中各語句的作用,詳細描述示例的功能特點,
53、給出其所有信號的時序仿真波形。 實驗任務(wù)2:引腳鎖定以及硬件下載測試。引腳鎖定后進行編譯、下載和硬件測試實驗。將實驗過程和實驗結(jié)果寫進實驗報告。 實驗任務(wù)3:使用SignalTap II對此計數(shù)器進行實時測試。 實驗任務(wù)4:從設(shè)計中去除SignalTapII,要求全程編譯后生成用于配置器件EPCS1編程的壓縮POF文件,并使用USB-Blaster,通過JTAG間接模式對實驗板上的EPCS1進行編程,最后進行驗證
54、。 實驗任務(wù)5:為此項設(shè)計加入一個可用于SignalTapII采樣的獨立的時鐘輸入端(采用時鐘選擇clock0=12MHz,計數(shù)器時鐘CLK分別選擇256Hz、16384Hz、6MHz),并進行實時測試。 實驗思考題:在例3-22中是否可以不定義信號CQI,而直接用輸出端口信號完成加法運算,即:CQ <= CQ + 1?為什么? 實驗報告:將實驗原理、設(shè)計過程、編譯仿真波形和分析結(jié)果、硬件測試實驗結(jié)果寫進
55、實驗報告。一些輔助的時序電路,設(shè)計一個8位串行二進制全加器,要求:,實 驗 與 設(shè) 計,實驗4-4. 用原理圖輸入法設(shè)計8位全加器 實驗?zāi)康模菏煜だ肣uartusⅡ的原理圖輸入方法設(shè)計簡單組合電路,掌握層次化設(shè)計的方法,并通過一個8位全加器的設(shè)計把握利用EDA軟件進行原理圖輸入方式的電子線路設(shè)計的詳細流程。 實驗原理:一個8位全加器可以由8個1位全加器構(gòu)成,加法器間的進位可以串行方式實現(xiàn),即將低位加法器的進位輸出c
56、out與相臨的高位加法器的最低進位輸入信號cin相接。而一個1位全加器可以按照4.9節(jié)介紹的方法來完成。 實驗任務(wù)1:完成半加器和全加器的設(shè)計,包括原理圖輸入、編譯、綜合、適配、仿真、實驗板上的硬件測試,并將此全加器電路設(shè)置成一個硬件符號入庫。鍵1、鍵2、鍵3(PIO0/1/2)分別接ain、bin、cin;發(fā)光管D2、D1(PIO9/8)分別接sum和cout。 實驗任務(wù)2:建立一個更高層次的原理圖設(shè)計,利用以上獲
57、得的1位全加器構(gòu)成8位全加器,并完成編譯、綜合、適配、仿真和硬件測試。建議選擇電路模式1;鍵2、鍵1輸入8位加數(shù);鍵4、鍵3輸入8位被加數(shù);數(shù)碼6/5顯示加和;D8顯示進位cout。 實驗報告:詳細敘述8位加法器的設(shè)計流程;給出各層次的原理圖及其對應(yīng)的仿真波形圖;給出加法器的時序分析情況;最后給出硬件測試流程和結(jié)果。,實 驗 與 設(shè) 計,實驗4-5. 正弦信號發(fā)生器設(shè)計 實驗?zāi)康模哼M一步熟悉QuartusII及其LPM
58、_ROM與FPGA硬件資源的使用方法。 實驗原理:參考本章4.4節(jié)相關(guān)內(nèi)容。 實驗內(nèi)容1:根據(jù)例4-4,在Quartus II上完成正弦信號發(fā)生器設(shè)計,包括仿真和資源利用情況了解(假設(shè)利用Cyclone器件)。最后在實驗系統(tǒng)上實測,包括SignalTap II測試、FPGA中ROM的在系統(tǒng)數(shù)據(jù)讀寫測試和利用示波器測試。最后完成EPCSx配置器件的編程 實驗內(nèi)容2:按照圖4-87所示,用原理圖方法設(shè)計正弦信號發(fā)生
59、器,要調(diào)用3個LPM模塊來構(gòu)成:1、PLL,輸入頻率20MHz,32MHz單頻率輸出;2、6位二進制計數(shù)器;3、LPM_ROM,加載的波形數(shù)據(jù)同上。注意,硬件實現(xiàn)時可以通過SignalTapII觀察波形,波形必須用高速DAC5651輸出。 實驗內(nèi)容3:修改例4-3的數(shù)據(jù)ROM文件,設(shè)其數(shù)據(jù)線寬度為8,地址線寬度也為8,初始化數(shù)據(jù)文件使用MIF格式,用C程序產(chǎn)生正弦信號數(shù)據(jù),最后完成以上相同的實驗。 實驗內(nèi)容4:設(shè)計一任意
60、波形信號發(fā)生器,可以使用LPM雙口RAM擔(dān)任波形數(shù)據(jù)存儲器,利用單片機產(chǎn)生所需要的波形數(shù)據(jù),然后輸向FPGA中的RAM(可以利用GW48系統(tǒng)上與FPGA接口的單片機完成此實驗,D/A可利用系統(tǒng)上配置的0832或5651高速器件)。 實驗報告:根據(jù)以上的實驗內(nèi)容寫出實驗報告,包括設(shè)計原理、程序設(shè)計、程序分析、仿真分析、硬件測試和詳細實驗過程。,實 驗 與 設(shè) 計,實驗4-5. 正弦信號發(fā)生器設(shè)計,圖4-87 調(diào)用了PLL元件信號發(fā)
61、生器原理,實 驗 與 設(shè) 計,實驗4-6. 七段數(shù)碼顯示譯碼器設(shè)計 實驗?zāi)康模簩W(xué)習(xí)7段數(shù)碼顯示譯碼器設(shè)計;學(xué)習(xí)VHDL的CASE語句應(yīng)用及多層次設(shè)計方法。 實驗原理:7段數(shù)碼是純組合電路,通常的小規(guī)模專用IC,如74或4000系列的器件只能作十進制BCD碼譯碼,然而數(shù)字系統(tǒng)中的數(shù)據(jù)處理和運算都是2進制的,所以輸出表達都是16進制的,為了滿足16進制數(shù)的譯碼顯示,最方便的方法就是利用譯碼程序在FPGA/CPLD中來實現(xiàn)
62、。例4-6作為7段譯碼器,輸出信號LED7S的7位分別接如圖8-49數(shù)碼管的7個段,高位在左,低位在右。例如當(dāng)LED7S輸出為“1101101”時,數(shù)碼管的7個段:g、f、e、d、c、b、a分別接1、1、0、1、1、0、1;接有高電平的段發(fā)亮,于是數(shù)碼管顯示“5”。注意,這里沒有考慮表示小數(shù)點的發(fā)光管,如果要考慮,需要增加段h,例3-29中的LED7S:OUT STD_LOGIC_VECTOR(6 DOWNTO 0)應(yīng)改為 ... (7
63、 DOWNTO 0) 。 實驗任務(wù)1:說明例4-6中各語句的含義,以及該例的整體功能。在QuartusII上對該例進行編輯、編譯、綜合、適配、仿真,給出其所有信號的時序仿真波形。提示:用輸入總線的方式給出輸入信號仿真數(shù)據(jù),仿真波形示例圖如圖4-88所示。,實 驗 與 設(shè) 計,實驗4-6. 七段數(shù)碼顯示譯碼器設(shè)計,圖4-88 7段譯碼器仿真波形,實 驗 與 設(shè) 計,實驗4-6. 七段數(shù)碼顯示譯碼器設(shè)計,【例4-6】 LIB
64、RARY IEEE ; USE IEEE.STD_LOGIC_1164.ALL ; ENTITY DECL7S IS PORT ( A : IN STD_LOGIC_VECTOR(3 DOWNTO 0); LED7S : OUT STD_LOGIC_VECTOR(6 DOWNTO 0) ) ; END ; ARCHITECTURE one OF DECL7S IS BEGIN PROCESS( A )
65、 BEGIN CASE A IS WHEN "0000" => LED7S LED7S LED7S LED7S LED7S LED7S LED7S LED7S LED7S LED7S LED7S LED7S LED7S LED7S LED7S LED7S NULL ; END CASE ; END PROCESS ;
66、 END ;,實 驗 與 設(shè) 計,實驗4-6. 七段數(shù)碼顯示譯碼器設(shè)計 實驗任務(wù)2:引腳鎖定及硬件測試。建議選GW48系統(tǒng)的實驗電路模式6,用數(shù)碼8顯示譯碼輸出(PIO46-PIO40),鍵8、鍵7、鍵6和鍵5四位控制輸入,硬件驗證譯碼器的工作性能。 實驗任務(wù)3:用第3章介紹的例化語句,按圖4-90的方式連接成頂層設(shè)計電路(用VHDL表述),圖中的CNT4B是一個4位二進制加法計數(shù)器,可以由例3-22修
67、改獲得;模塊DECL7S即為例4-6實體元件,重復(fù)以上實驗過程。對于引腳鎖定和實驗,建議選電路模式6,用數(shù)碼8顯示譯碼輸出,用鍵3作為時鐘輸入(每按2次鍵為1個時鐘脈沖),或直接接時鐘信號clock0。 實驗報告:根據(jù)以上的實驗內(nèi)容寫出實驗報告,包括程序設(shè)計、軟件編譯、仿真分析、硬件測試和實驗過程;設(shè)計程序、程序分析報告、仿真波形圖及其分析報告,實 驗 與 設(shè) 計,實驗4-6. 七段數(shù)碼顯示譯碼器設(shè)計,圖4-89共陰數(shù)碼管及其
68、電路,實 驗 與 設(shè) 計,實驗4-6. 七段數(shù)碼顯示譯碼器設(shè)計,圖4-90 計數(shù)器和譯碼器連接電路的頂層文件原理圖,實 驗 與 設(shè) 計,實驗4-7. 數(shù)控分頻器的設(shè)計 實驗?zāi)康模簩W(xué)習(xí)數(shù)控分頻器的設(shè)計、分析和測試方法。 實驗原理:數(shù)控分頻器的功能就是當(dāng)在輸入端給定不同輸入數(shù)據(jù)時,將對輸入的時鐘信號有不同的分頻比,數(shù)控分頻器就是用計數(shù)值可并行預(yù)置的加法計數(shù)器設(shè)計完成的,方法是將計數(shù)溢出位與預(yù)置數(shù)加載輸入信號相
69、接即可,詳細設(shè)計程序如例4-7所示。 實驗任務(wù)1:根據(jù)圖4-91的波形,分析例4-7中的各語句功能、設(shè)計原理及邏輯功能,詳述進程P_REG和P_DIV的作用,并畫出該程序的RTL電路圖。輸入不同的CLK頻率和預(yù)置值D,給出如圖4-91的時序波形。 實驗任務(wù)2:在實驗系統(tǒng)上硬件驗證例4-7功能??蛇x實驗電路模式1;鍵2/鍵1負責(zé)輸入8位預(yù)置數(shù)D(PIO7-PIO0);CLK由clock0輸入,頻率選65536Hz或更高(
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
評論
0/150
提交評論