




版權(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 包頭職業(yè)技術(shù)學(xué)院《電影藝術(shù)解析視與聽》2023-2024學(xué)年第二學(xué)期期末試卷
- 武漢光谷職業(yè)學(xué)院《C#程序語言設(shè)計》2023-2024學(xué)年第二學(xué)期期末試卷
- 江西工程職業(yè)學(xué)院《鋼結(jié)構(gòu)課程設(shè)計》2023-2024學(xué)年第二學(xué)期期末試卷
- 滇西應(yīng)用技術(shù)大學(xué)《生物醫(yī)學(xué)光學(xué)》2023-2024學(xué)年第二學(xué)期期末試卷
- 廣西安全工程職業(yè)技術(shù)學(xué)院《建筑物抗震設(shè)計》2023-2024學(xué)年第二學(xué)期期末試卷
- 云南旅游職業(yè)學(xué)院《vc程序設(shè)計》2023-2024學(xué)年第二學(xué)期期末試卷
- 新生兒疾病篩查健康教育
- 江西理工大學(xué)《新聞節(jié)目播音主持》2023-2024學(xué)年第二學(xué)期期末試卷
- 吉林農(nóng)業(yè)科技學(xué)院《計算機組成原理與匯編語言程序設(shè)計》2023-2024學(xué)年第二學(xué)期期末試卷
- 廣東建設(shè)職業(yè)技術(shù)學(xué)院《網(wǎng)絡(luò)及其計算》2023-2024學(xué)年第二學(xué)期期末試卷
- 2.6.2數(shù)列求和公開課一等獎?wù)n件省賽課獲獎?wù)n件
- 公司道德和商業(yè)行為準(zhǔn)則
- 【年產(chǎn)1000噸富硒沙棘果汁工藝生產(chǎn)設(shè)計16000字(論文)】
- 2024年湖南高二學(xué)業(yè)水平合格性考試英語試卷試題(含答案詳解)
- 汽車維修合作協(xié)議書范本
- HG-T 4062-2023 波形擋邊輸送帶
- 中等職業(yè)學(xué)校信息技術(shù)課程標(biāo)準(zhǔn)(2020年版)(文本精排版)
- 提水試驗過程及數(shù)據(jù)處理
- (正式版)SHT 3046-2024 石油化工立式圓筒形鋼制焊接儲罐設(shè)計規(guī)范
- 呼吸系統(tǒng)(0001)課件
- 2023年第37屆中國化學(xué)奧林匹克競賽(江蘇賽區(qū))初賽真題(學(xué)生版+解析版)
評論
0/150
提交評論