超大規(guī)模集成電路第九次作業(yè)2016秋-段成華_第1頁
超大規(guī)模集成電路第九次作業(yè)2016秋-段成華_第2頁
超大規(guī)模集成電路第九次作業(yè)2016秋-段成華_第3頁
超大規(guī)模集成電路第九次作業(yè)2016秋-段成華_第4頁
超大規(guī)模集成電路第九次作業(yè)2016秋-段成華_第5頁
已閱讀5頁,還剩11頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

Assignment91.Designan8-bitupanddownsynchronouscounterinVHDLwiththefollowingfeatures:Thesameportsareusedforsignalstobeinputtedandoutputted.Theportsarebi-directionallybuffered(three-state).Thecounteriswithanasynchronousresetthatassignsaspecificinitialvalueforcounting.Thecounteriswithasynchronousdataloadcontrolinputforanewvalueofcountingandanenablecontrolinputforallowingtheupanddowncounting.Theloadcontrolinputhasapriorityovertheenablecontrolinput.Thisimpliesthatwhentheloadoperationisinprocessthecounteroperationisprohibited.Somedatatypes,suchasSTD_LOGIC,UNSIGNED,SIGNEDandINTEGER,maybeused.Synthesizethedesign.Createasetofreasonableinputwaveformsforyourdesignandcompletebothbehavioralandpost-place&routesimulationswithinternalsignalsand/orvariablesincludedinwaveformorlistwindows.Solution:代碼如下:libraryIEEE;useIEEE.STD_LOGIC_1164.ALL;useIEEE.STD_LOGIC_ARITH.ALL;useIEEE.STD_LOGIC_UNSIGNED.ALL;----Uncommentthefollowinglibrarydeclarationifinstantiating----anyXilinxprimitivesinthiscode.--libraryUNISIM;--useUNISIM.VComponents.all;entitycount_8_bidirisPort( clk:inSTD_LOGIC;rst:inSTD_LOGIC;load:inSTD_LOGIC;enable:inSTD_LOGIC;cnt:inoutSTD_LOGIC_VECTOR(7downto0));endcount_8_bidir;architectureBehavioralofcount_8_bidirissignalcnt_in:STD_LOGIC_VECTOR(7downto0);signalcnt_out:STD_LOGIC_VECTOR(7downto0);beginpro0:process(oe,cnt_out,cnt) beginif(load='1')then cnt<=(others=>'Z');cnt_in<=cnt; else cnt<=cnt_out; endif; endprocess; pro1:process(clk,rst) begin if(rst='1')then cnt_out<=(others=>'0'); elsifrising_edge(clk)then if(load='1')thencnt_out<=cnt_in; elsif(enable='1')then cnt_out<=cnt_out+1; elsecnt_out<=cnt_out-1; endif; endif; endprocess;endBehavioral;解釋代碼:這里有兩個進程,進程0時是用來控制三態(tài)門控制的雙向端口。當cnt作為輸入時(load='1'),把cnt賦給cnt_in(初值裝載),然后置cnt為高阻狀態(tài);否則,即cnt作為輸出時(load='0'),把cnt_out(計數(shù)器計數(shù)輸出值)賦給cnt。進程1的作用是:當復位信號rst='1',計數(shù)器輸出cnt_out為全0,否則在時鐘的上升沿檢測cnt端口是作為輸入還是作為輸出,當作為輸入時(load='1'),把cnt_in中的數(shù)取進來,然后當up_down='0'時,進行加法運算,否則做減法運算,同時可以和進程0配合當load='0',將數(shù)值從cnt_out輸出到cnt。TestBench代碼:LIBRARYieee;USEieee.std_logic_1164.ALL;USEieee.std_logic_unsigned.all;USEieee.numeric_std.ALL;ENTITYcount_8_bidir_tbISENDcount_8_bidir_tb;ARCHITECTUREbehaviorOFcount_8_bidir_tbIS--ComponentDeclarationfortheUnitUnderTest(UUT)COMPONENTcount_8_bidirPORT(oe:INstd_logic;clk:INstd_logic;rst:INstd_logic;load:INstd_logic;enable:INstd_logic;圖1圖2ForCPLDimplementation(fit)oftheFIFOs,howmanyMCs(macrocells)andPTs(productterms)areneeded?Whichparameteriscriticaltothemaximuminternalclockworkingfrequency?Trytofindoutthiscriticalparameteranditscorrespondingcircuitpath.設置芯片為CoolRunnerXPLA3CPLDS系XCR3512XL-7-PQ208,速度為-7,綜合后報告分析如下

圖3為CPLD綜合報告:從報告中可以知道一共使用了87個MCs,占總體的17%,使用了208個PTs,占總體的14%,選這個型號似乎有點大材小用啊,不過資源很足夠,滿足設計的需求。圖4為CPLD時間報告:由圖4可知,時鐘的最小周期為8.6ns,受clocktosetup影響最大,故關鍵路徑為tcyc。延時為8.6ns,時鐘的工作頻率為116.279MHz。圖3圖4ForFPGAimplementation(placeandroute)oftheFIFOs,howmanyLBs(logicblocks)?Whichparameteriscriticaltothemaximuminternalclockworkingfrequency?Trytofindoutthiscriticalparameteranditscorrespondingcircuitpath.設置芯片為更換芯片型號為Spartan3-xc3s200-5pq208,速度為-5,其綜合報告如下圖5為FPGA綜合報告:圖5圖6為Spartan3datasheet圖6圖7由上圖知,對于選擇的器件,其logiccell為4320,CLB有24X20=480個,每個CLB包含4個slice,而對于我們的程序,一共使用了66個slice,占總數(shù)的百分之三(總slice共計1920個),故使用的CLB數(shù)為66/4=16.5,即使用了17個。由圖7可知,時鐘的最小周期為5.078ns,受clocktosetup影響最大,時鐘的工作頻率為196.927MHz。Trytosynthesizeagainthedesignwithtimingconstraintsandcomparewithitsformercounterparts.Youwillcreatethetimingconstraintfilebyyourselfandaddittoyourproject.PleaserefertothefollowinggraphicinterfaceofISE:圖8為timingconstrain設置圖;圖9為沒有設置時序約束時的報告;圖10為設置CLK周期約束為5ns時的報告;圖11為設置CLK周期約束為4.5ns時的報告;圖12設置clk周期約束為4ns時的報告圖13設置clk周期約束為3.5ns時的報告圖8圖9圖10圖11圖12圖13FortheVHDLmodelgivenbelow(CodeListTwo),theremaybesomedesignerrorsinit.Somewarning(s)and/orerror(s)informationmaybeissuedwhensynthesizingit.Trytofindoutsuchdesignerrorsandcorrectthem.仿真后無錯誤,有兩個警告如下圖:圖14(1)程序中,輸入端口rd沒有使用到,其作用被oe所取代,因此可以將rd信號去掉,用oe來表示其功能,且不影響整個系統(tǒng)的設計。(2)程序中輸入信號端口en也未被使用,因為直接在fifo(wrptr)中取得了寫地址的值,因此信號en也應去掉。(3)語句dmuxout<=fifo(wrptr);應改為dmuxout<=fifo(rdptr);因為這時是讀寄存器里的值,應該由讀地址指針rdptr來指定應該讀取哪個寄存器的值。改進后加入激勵得到圖15的輸出波形。圖158X9FIFOBUFFERDESIGNEXAMPLES1#VHDLCODELIST:libraryIEEE;useIEEE.STD_LOGIC_1164.ALL;useIEEE.STD_LOGIC_ARITH.ALL;useIEEE.STD_LOGIC_UNSIGNED.ALL;entityfifo89isPort(clk:instd_logic;rst:instd_logic;rd:instd_logic;wr:instd_logic;rdinc:instd_logic;wrinc:instd_logic;rdptrclr:instd_logic;wrptrclr:instd_logic;data_in:instd_logic_vector(8downto0);data_out:outstd_logic_vector(8downto0));endfifo89;--clk:usedtosynchronizethebuffers;--rst:resetthebuffers--rd:whenvalid,theoutputbuffersareenabled;--wr:whenvalid,writeregisterwith9-bitwidthispermitted;--rdinc:readcounterenabled;--wrinc:writecounterenabled;--rdptrclr:resetreadcounter,pointingtothefirstregisterfor--readpurpose;--wrptrclr:resetwritecounter,pointingtothefirstregisterfor--writepurpose;--data_in:datainputswith9-bitwidthtotheFIFOs;--data_out:dataoutputswith9-bitwidthfromtheFIFOs.architectureBehavioraloffifo89is typefifo_arrayisarray(7downto0)ofstd_logic_vector(8downto0); signalfifo:fifo_array; signalwrptr,rdptr:std_logic_vector(2downto0); signalen:std_logic_vector(7downto0); signaldmuxout:std_logic_vector(8downto0);begin--fiforegister_array:reg_array:process(rst,clk) begin ifrst='1'then foriin7downto0loop fifo(i)<=(others=>'0');--aggregate endloop; elsif(clk'eventandclk='1')then ifwr='1'then foriin7downto0loop ifen(i)='1'then fifo(i)<=data_in; else fifo(i)<=fifo(i); endif; endloop; endif; endif; endprocess;--readpointerread_count:process(rst,clk) begin ifrst='1'then rdptr<=(others=>'0'); elsif(clk'eventandclk='1')then ifrdptrclr='1'then rdptr<=(others=>'0'); elsifrdinc='1'then rdptr<=rdptr+1; endif; endif; endprocess;--writepointerwrite_count:process(rst,clk) begin ifrst='1'then wrptr<=(others=>'0'); elsif(clk'eventandclk='1')then ifwrptrclr='1'then wrptr<=(others=>'0'); elsifwrinc='1'then wrptr<=wrptr+1; endif; endif; endprocess;--8:1outputdatamuxwithrdptrselect dmuxout<=fifo(0)when"000", fifo(1)when"001", fifo(2)when"010", fifo(3)when"011", fifo(4)when"100", fifo(5)when"101", fifo(6)when"110", fifo(7)whenothers;--FIFOregisterselectordecoderwithwrptrselect en<="00000001"when"000", "00000010"when"001", "00000100"when"010", "00001000"when"011", "00010000"when"100", "00100000"when"101", "01000000"when"110", "10000000"whenothers;--three-statecontrolofoutputsthree_state:process(rd,dmuxout) begin ifrd='1'then data_out<=dmuxout; else data_out<=(others=>'Z'); endif; endprocess;endBehavioral;2#VHDLCODELIST:libraryIEEE;useIEEE.STD_LOGIC_1164.ALL;useIEEE.STD_LOGIC_ARITH.ALL;useIEEE.STD_LOGIC_UNSIGNED.ALL;entityfifoxyisgeneric(wide:integer:=8);--widthis8+1Port(clk:instd_logic;rst:instd_logic; oe:instd_logic;rd:instd_logic;wr:instd_logic;rdinc:instd_logic;wrinc:instd_logic;rdptrclr:instd_logic;wrptrclr:instd_logic;data_in:instd_logic_vector(widedownto0);data_out:outstd_logic_vector(widedownto0));endfifoxy;architectureArchfifoxyoffifoxyis constantdeep:integer:=7;--depthis7+1 typefifo_arrayisarray(deepdownto0)ofstd_logic_vector(widedownto0); signalfifo:fifo_array; signalwrptr,rdptr:integerrange0todeep; signalen:std_logic_vector(deepdownto0); signaldmuxout:std_logic_vector(widedownto0

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論