Verilog設(shè)計求最大公約數(shù)系統(tǒng)_第1頁
Verilog設(shè)計求最大公約數(shù)系統(tǒng)_第2頁
Verilog設(shè)計求最大公約數(shù)系統(tǒng)_第3頁
Verilog設(shè)計求最大公約數(shù)系統(tǒng)_第4頁
Verilog設(shè)計求最大公約數(shù)系統(tǒng)_第5頁
已閱讀5頁,還剩7頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)

文檔簡介

PAGE1-武漢大學(xué)電工電子基礎(chǔ)課程教學(xué)基地實驗報告學(xué)院專業(yè)2010年6月18日課程名稱求最大公因數(shù)指導(dǎo)教師曹華偉姓名年級學(xué)號成績一:實驗?zāi)康?學(xué)會控制器模型的設(shè)計。2掌握FSM的設(shè)計方法。3繼續(xù)熟悉實驗箱的使用方法。二:實驗原理1、集成電路的劃分 數(shù)據(jù)單元包含有保存運算數(shù)據(jù)和運算結(jié)果的數(shù)據(jù)寄存器,還包括組合邏輯電路來完成數(shù)據(jù)運算。數(shù)據(jù)單元元產(chǎn)生輸出信號,數(shù)據(jù)運算狀態(tài)等信息。控制單元要從數(shù)據(jù)單元得到狀態(tài)信息,以決定繼續(xù)進行哪些數(shù)據(jù)運算,產(chǎn)生控制信號序列,以決定何時進行何種數(shù)據(jù)運算。求最大公因數(shù)模型完成對集成電路系統(tǒng)的劃分任務(wù),通過數(shù)據(jù)路徑和控制路徑實現(xiàn)求得最大公因數(shù)的可直接綜合系統(tǒng)。三:實驗步驟:定義模塊接口定義模塊接口如下圖:該模塊有4個輸入operand_A、operand_B,result_taken,input_available以及3個輸入idle,result_data和result_rdy。根據(jù)此接口定義可以進行數(shù)據(jù)路徑和控制路徑路徑的實現(xiàn)?;灸K實現(xiàn)(1)定義數(shù)據(jù)路徑數(shù)據(jù)單元包含有保存運算數(shù)據(jù)和運算結(jié)果的數(shù)據(jù)寄存器,還包括組合邏輯電路來完成數(shù)據(jù)運算。數(shù)據(jù)單元元產(chǎn)生輸出信號,數(shù)據(jù)運算狀態(tài)等信息??刂茊卧獜臄?shù)據(jù)單元得到狀態(tài)信息,以決定繼續(xù)進行哪些數(shù)據(jù)運算,產(chǎn)生控制信號序列,以決定何時進行何種數(shù)據(jù)運算。數(shù)據(jù)路徑是以一定的拓撲關(guān)系互連的若干功能部件。而數(shù)據(jù)路徑的設(shè)計流程如下圖:根據(jù)圖中所示的數(shù)據(jù)路徑可進行數(shù)據(jù)路徑的定義。實現(xiàn)代碼如下:modulegcdDatapath(inputclk,//Datasignalsinput[0:7]operand_bits_A,input[0:7]operand_bits_B,output[0:7]result_bits_data,//Controlsignals(ctrl->dpath)inputA_en,inputB_en,input[0:1]A_mux_sel,inputB_mux_sel,//Controlsignals(dpath->ctrl)outputB_zero,outputA_lt_B);(2)定義控制路徑行為綜合器總是用有限狀態(tài)機作為控制器,而且一般采用硬連線方式,也就是說用隨機組合邏輯電路計算下一狀態(tài),當(dāng)前狀態(tài)以一定方式編碼后由寄存器鎖存。硬連線方式有限狀態(tài)機不僅有完善的數(shù)學(xué)模型,更重要的是這種電路的綜合技術(shù)已有非常充分的研究,因此寄存器傳輸級綜合能夠得到很好的結(jié)果。在行為級描述中,各個狀態(tài)以隱含方式表達,由行為綜合根據(jù)源代碼進行狀態(tài)分配和編碼?,F(xiàn)在的行為綜合工具中,狀態(tài)的更新都采用同步方式,用單相沿觸發(fā)時鐘方案。得到控制器原理圖實現(xiàn)代碼如下:modulegcdControlUnit(inputclk,inputreset,//Datasignalsinputinput_available,//signaltobeginthe//'CALC'stateinputresult_taken,outputregresult_rdy,//signalappearswhen//itcomestothe'DONE'state//Controlsignals(ctrl->dpath)outputregA_en,outputregB_en,outputreg[0:1]A_mux_sel,outputregB_mux_sel,//Controlsignals(dpath->ctrl)inputB_zero,inputA_lt_B);在每一狀態(tài),控制器和數(shù)據(jù)路徑要完成如下任務(wù):(1)控制器進入新的狀態(tài),計算出控制信號和下一狀態(tài);(2)控制器把控制信號送往數(shù)據(jù)路徑;(3)數(shù)據(jù)路徑根據(jù)控制信號進行相應(yīng)操作;(4)數(shù)據(jù)路徑存儲運算結(jié)果,并把各種條件信號送人控制器。(3)定義控制轉(zhuǎn)變的狀態(tài)機本題中共有3個狀態(tài),等待狀態(tài)wait,用于等待新數(shù)據(jù)輸入。新數(shù)據(jù)輸入后進入下一個狀態(tài)calc,在此狀態(tài)完成判斷A、B的大小以及相減任務(wù),然后檢查B的值,若B=0,則進入下一個狀態(tài)done,等待用戶取走數(shù)據(jù),若不滿足B=0,則繼續(xù)判斷A、B大小,進行相減操作。(4)實驗完整代碼:modulemy_gcd(inputclk,//Datasignalsinput[0:7]operand_bits_A,input[0:7]operand_bits_B,output[0:7]result_bits_data,//Controlsignalsinputinput_available,inputreset,outputresult_rdy,inputresult_taken);wirea_en,b_en,b_mux_sel;wire[0:1]a_mux_sel;wireb_zero;wirea_lt_b;gcdDatapathdatapath(.clk(clk),.operand_bits_A(operand_bits_A),.operand_bits_B(operand_bits_B),.result_bits_data(result_bits_data),.A_en(a_en),.B_en(b_en),.A_mux_sel(a_mux_sel),.B_mux_sel(b_mux_sel),.B_zero(b_zero),.A_lt_B(a_lt_b));gcdControlUnitcontrol(.clk(clk),.reset(reset),.input_available(input_available),.result_taken(result_taken),.result_rdy(result_rdy),.A_en(a_en),.B_en(b_en),.A_mux_sel(a_mux_sel),.B_mux_sel(b_mux_sel),.B_zero(b_zero),.A_lt_B(a_lt_b));endmodulemodulegcdDatapath(inputclk,//Datasignalsinput[0:7]operand_bits_A,input[0:7]operand_bits_B,output[0:7]result_bits_data,//Controlsignals(ctrl->dpath)inputA_en,inputB_en,input[0:1]A_mux_sel,inputB_mux_sel,//Controlsignals(dpath->ctrl)outputB_zero,outputA_lt_B);//wireswillbeusedinthemiddleofthismodulewire[0:7]B;//outputofthedflipflopwire[0:7]A;wire[0:7]sub_out;//outputofthesubtractionwire[0:7]A_mux_out;//outputofthemuxn_1(n=3or2)wire[0:7]B_mux_out;//noregisterfor'A'or'B',usetheDflipflopinsteadmux3_1u1_mux3_1(.IN0(operand_bits_A),.IN1(B),.IN2(sub_out),.SEL(A_mux_sel),.OUT(A_mux_out));//DflipflopwithenableED_FFA_ff(.clk(clk),.en_p(A_en),.d_p(A_mux_out),.q_np(A));mux2_1u2_mux2_1(.IN0(operand_bits_B),.IN1(A),.SEL(B_mux_sel),.OUT(B_mux_out));ED_FFB_ff(.clk(clk),.en_p(B_en),.d_p(B_mux_out),.q_np(B));//whentherighthandhaschanged,the'assign'sentencewillwork.assignB_zero=(B==0);assignA_lt_B=(A<B);assignsub_out=A-B;//whenB==0result_bits_dataequalstoA.assignresult_bits_data=A;endmodulemodulegcdControlUnit(inputclk,inputreset,//Datasignalsinputinput_available,//signaltobeginthe'CALC'//stateinputresult_taken,outputregresult_rdy,//signalappearswhenit//comestothe'DONE'state//Controlsignals(ctrl->dpath)outputregA_en,outputregB_en,outputreg[0:1]A_mux_sel,outputregB_mux_sel,//Controlsignals(dpath->ctrl)inputB_zero,inputA_lt_B);//therearethreestatesaltogether.localparamWAIT=2'b00;//localparamsarescopedconstantslocalparamCALC=2'b01;localparamDONE=2'b10;reg[0:1]state_next;wire[0:1]state_current;//localparamA_MUX_SEL_IN=2'b00;localparamA_MUX_SEL_B=2'b01;localparamA_MUX_SEL_SUB=2'b10;localparamA_MUX_SEL_X=2'bxx;localparamB_MUX_SEL_IN=1'b0;localparamB_MUX_SEL_A=1'b1;localparamB_MUX_SEL_X=1'bx;//initialnizethecontrolunitvcRDFF_pfstate_pf(.clk(clk),.reset(reset),.d(state_next),.q(state_current));always@(*)begin//stoptheworkingofmuxandDflipflopA_mux_sel=A_MUX_SEL_X;A_en=1'b0;B_mux_sel=B_MUX_SEL_X;B_en=1'b0;result_rdy=1'b0;case(state_current) WAIT: begin A_mux_sel=A_MUX_SEL_IN; A_en=1'b1; B_mux_sel=B_MUX_SEL_IN; B_en=1'b1; end CALC: begin if(A_lt_B) begin A_mux_sel=A_MUX_SEL_B; A_en=1'b1; B_mux_sel=B_MUX_SEL_A; B_en=1'b1; end elseif(!B_zero) begin A_mux_sel=A_MUX_SEL_SUB; A_en=1'b1; end end DONE: begin result_rdy=1'b1; endendcaseend//Nextstatelogicalwaysbegin//Defaultistostayinthesamestatestate_next=state_current;case(state_current) WAIT: if(input_available==1) state_next=CALC; CALC: if(B_zero==1) state_next=DONE; DONE: if(result_taken==1) state_next=WAIT; endcaseendendmodule//thefollowingarethemodulesusedineitherthe'datapath'or'controlunit'module//3路選擇器modulemux3_1(IN0,IN1,IN2,SEL,OUT);input[0:7]IN0,IN1,IN2;input[0:1]SEL;output[0:7]OUT;reg[0:7]OUT;always@(*)begincase(SEL)2'b00:OUT=IN0;2'b01:OUT=IN1;2'b10:OUT=IN2;endcaseendendmodule//2路選擇器modulemux2_1(IN0,IN1,SEL,OUT);input[0:7]IN0,IN1;inputSEL;output[0:7]OUT;reg[0:7]OUT;always@(*)begincase(SE

溫馨提示

  • 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. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論