版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、合肥工業(yè)大學宣城校區(qū) 微電子科學與工程 Verilog數(shù)字系統(tǒng)設計 Verilog數(shù)字系統(tǒng)設計 代碼90例Contents1、二選一多路選擇器.12、多路器模塊的編寫測試平臺.13、三位加法器.24、比較器.25、實例調用三態(tài)門選擇器.26、同步置位/清零的計數(shù)器.37、異步清零.38、case語句實現(xiàn)3-8譯碼器的部分代碼.39、for語句來實現(xiàn)8位數(shù)據(jù)中低4位左移到高4位.410、for語句計算出13路脈沖信號為高電平的個數(shù).411、生成語句對兩個N位的總線用門級原語進行按位異或.512、用條件生成語句實現(xiàn)參數(shù)化乘法器.513、使用case生成語句實現(xiàn)N位加法器.614、四選一多路器.71
2、5、四位計數(shù)器.716、使用任務控制交通燈.817、CPU總線控制的任務.918、自動任務示例.919、用函數(shù)實現(xiàn)乘累加器.1020、計算32位地址值的偶校驗位.1121、左/右移位寄存器.1222、用函數(shù)的遞歸調用定義階乘計算.1223、常量函數(shù).1324、帶符號函數(shù).1325、顯示任務.1426、文件寫入操作的例子.1427、讀取文件的示例1.1528、讀取文件的示例2.1529、使用$random生成隨機數(shù).1630、宏定義語句define.1631、帶有宏定義的8位加法器.1732、用include語句設計的16位加法器.1733、結構化描述方式對四選一多路選擇器.1834、結構化描述
3、方式實現(xiàn)一位全加器.1835、結構化描述方式實例化四個一位全加器實現(xiàn)四位串行進位全加器.1836、用戶定義原語.1937、四選一的多路選擇器的自定義原語設計.2038、用戶定義原語的方式設計電平敏感鎖存器.2039、用戶定義原語的方式設計D觸發(fā)器(時鐘下降沿觸發(fā)).2040、采用實例化前面用定義原語設計的四選一多路選擇器(MUX)的方法實現(xiàn)十六 選一的多路選擇器.2141、數(shù)據(jù)流建模描述方式:一位全加器.2242、行為建模方式設計一位加法器.2243、混合設計方式設計一位全加器.2244、數(shù)據(jù)流描述方式對四選一多路選擇器建模.2345、行為建模方式設計四選一多路選擇器.2346、用RTL級建模
4、方式設計此電路.2447、四位全加器.2448、組合邏輯電路.2449、單向三態(tài)端口.2550、單向總線緩沖器.2551、雙向三態(tài)端口.2552、雙向總線緩沖器.2653、2選1多路選擇器.2654、多路比較器.2755、帶使能端的38譯碼器.2856、4位二進制到格雷碼的轉換器.2957、時序邏輯電路.3058、JK觸發(fā)器.3159、D觸發(fā)器.3260、帶異步復位端D觸發(fā)器.3261、帶異步置位端D觸發(fā)器.3262、帶有異步置位和復位的D觸發(fā)器.3363、帶有同步復位的D觸發(fā)器.3364、帶同步置位端的上升沿觸發(fā)器.3365、帶異步復位端和輸出使能端的上升沿觸發(fā)器.3466、鎖存器:電平觸發(fā)
5、的存儲器單元,基本SR鎖存器.3467、透明鎖存器.3568、基本N位同步計數(shù)器.3569、帶有異步復位、同步計數(shù)使能和可預置的十進制計數(shù)器.3570、格雷碼計數(shù)器.3671、四位移位寄存器.3772、8位串入串出移位寄存器.3773、利用移位寄存器產(chǎn)生順序脈沖.3874、可輸出輸入信號的2分頻信號、4分頻信號和8分頻信號的分頻器.3875、分頻系數(shù)為12的分頻器.3976、分頻系數(shù)為6,占空比為1:5的偶數(shù)分頻器.3977、3分頻占空比為1:1的奇數(shù)分頻器.4078、分頻系數(shù)為5、占空比為1:1的奇數(shù)分頻器.4179、分頻系數(shù)為7、占空比為1:6的奇數(shù)分頻器.4280、帶使能端和復位端的時鐘
6、同步8位寄存器組邏輯.4281、自觸發(fā)always塊.4282、1001序列信號檢測器.4383、米利型有限狀態(tài)機.4784、自動售飲料機的設計.4985、并行數(shù)據(jù)流轉換為一種特殊串行數(shù)據(jù)流模塊的設計.5386、設計對數(shù)字采集芯片AD0809的控制接口電路的Verilog代碼.5787、面積優(yōu)化設計乘法選擇器.6188、串行化描述一個乘法累加器,其位寬位16位 對8個16位數(shù)據(jù)進行乘法和加法運算.6389、流水線設計流水線計數(shù)使用實例:8位加法器.6490、流水線設計設計一個為8位全加器 (一個是直接實現(xiàn),一個采用4級流水線實現(xiàn)).65合肥工業(yè)大學宣城校區(qū) 微電子科學與工程 Verilog數(shù)字
7、系統(tǒng)設計1、二選一多路選擇器行為描述:module muxtwo(out,a,b,sl);input a,b,sl;output out;reg out;always(a or b or sl) if(!sl) out = a; else out = b;endmodule邏輯描述:module muxtwo(out,a,b,sl);input a,b,sl;output out;不用寫寄存器 wire nsl,sela,selb;assign nsl = sl;assign sela = a&nsl;assign selb = b&sl;assign out = sela|s
8、elb;endmodule門級描述:module muxtwo(out,a,b,sl); input a,b,sl;output out;不用寫寄存器 not u1(nsl,sl); and u2(sela,a,nsl); and u3(selb,b,sl); or u4(out,sela,selb); endmodule2、多路器模塊的編寫測試平臺include “muxtwo.v” module t; reg ain,bin,select; reg clock; wire outw; initial begin ain=0; bin=0; select=0; clock=0; end al
9、ways #50 clock =clock; always(posedge clock) begin#1 ain = $random%2;#3 bin = $random%2; end muxtwo m(.out(outw),.a(ain),.b(bin),.sl(select);endmodule3、 三位加法器module adder ( count,sum,a,b,cin ); input 2:0 a,b; input cin; output count; output 2:0 sum; assign count,sum=a+b+cin;endmodule4、比較器:module com
10、pare ( equal,a,b ); output equal; /聲明輸出信號equal input 1:0 a,b; /聲明輸入信號a,b assign equal=(a=b)?1:0;/如果兩個輸入信號相等,輸出為1。否則為0endmodule5、實例調用三態(tài)門選擇器module mytri(out,in,enable); output out; input in, enable; assign out = enable? in : 'bz;endmodulemodule trist1(sout,sin,ena); output sout; input sin, ena; my
11、tri tri_inst(.out(sout), .in(sin),.enable(ena);endmodulemodule trist2(sout,sin,ena); output out; input in, enable; mytri tri_inst(sout,sin,ena);endmodule6、同步置位/清零的計數(shù)器module sync(out,d,load,clr,clk) input d,load,clk,clr; input7:0 d; output7:0out; reg7:0 out; always ( posedge clk ) /clk上升沿觸發(fā) begin if
12、( !clr ) out <= 8h00; /同步清0,低電平有效 else if ( load ) out <= d; /同步置數(shù),高電平有效 else out <= out+1 /計數(shù) endendmodule7、異步清零module async(d,clk,clr,q); input d,clk,clr; output q: reg q; always ( posedge clk or posedge clr) /異步清0 begin if ( clr ) q <= 1b0; else q <= d; endendmodule8、case語句實現(xiàn)3-8譯碼器
13、的部分代碼wire2:0 sel;reg7:0 res;always (sel or res) begin case (sel) 3b000 : res=8b00000001; 3b001 : res=8b00000010; 3b010 : res=8b00000100; 3b011 : res=8b00001000; 3b100 : res=8b00010000; 3b101 : res=8b00100000; 3b110 : res=8b01000000; default : res=8b10000000; endcase end9、for語句來實現(xiàn)8位數(shù)據(jù)中低4位左移到高4位intege
14、r i;reg 7:0 datain; always (posedge clk) begin for(i=4;i<=7;i=i+1) begin dataini <= datain i-4; end end10、for語句計算出13路脈沖信號為高電平的個數(shù) input clk,rst; input 12:0 datain; /輸入13路數(shù)據(jù) output 15:0 num; /13路數(shù)據(jù)電平為高的路數(shù) reg 3:0 i; reg 15:0 num; always (posedge clk) begin
15、160; if ( !rst ) begin num <= 0; end else begin for ( i = 0; i < 13; i = i + 1) /用for循環(huán)進行
16、計算 if ( datain i ) num <= num +1; end end11、生成語句對兩個N位的總線用門級原語進行按位異或/本模塊生成兩條N位總線變量的按位異或 module gen_xor(out,i0,i1); parameter N = 32; /參數(shù)聲明語句,
17、參數(shù)可以重新定義; /默認的總線位寬為32位 output N-1:0 out; inputN-1:0 i0,i1; /聲明一個臨時循環(huán)變量 /該變量只用于生成塊的循環(huán)計算 /Verilog仿真時該變量在設計中并不存在 genvar j;/用一個單循環(huán)生成按位異或的異或門(xor) generate for( j = 0 ; j < N ; j = j+1) begin :xor_loop xor g1(out j ,i0 j , i1 j ); end endgenerate/用一個單循環(huán)生成用always塊來描述的異或門(xor) /reg N-1 : 0 out; generate
18、 for( j = 0 ; j < N ; j = j+1) begin :xor_loop always(i0j,i1j ) outj= i0ji1j ; end endgenerate endmodule12、用條件生成語句實現(xiàn)參數(shù)化乘法器/本模塊實現(xiàn)一個參數(shù)化乘法器 module multiplier(product,a0,a1); parameter a0_width = 8; /參數(shù)聲明,該參數(shù)可以重新定義 parameter a1_width = 8; /本地參數(shù)聲明 /本地參數(shù)不能用參數(shù)重新定義(defparam)修改 /也不能在實例引用時通過傳遞參數(shù)語句,即#(參數(shù)1,參
19、數(shù)2,)的方法修改 localparam product_width = a0_width+a1_width; /端口聲明語句 output product_width -1 :0 product; input a0_width -1: 0 a0; input a1_width -1: 0 a1; /有條件地調用(實例引用)不同類型的乘法器 /根據(jù)參數(shù)a0_width和a1_width的值,在調用時引用相對應的乘法器實例 generate if( (a0_width < 8) | (a1_width < 8) ) cal_multiplier # (a0_width,a1_widt
20、h) m0(product,a0,a1); else tree_multiplier # (a0_width,a1_width) m0(product,a0,a1); endgenerate endmodule13、使用case生成語句實現(xiàn)N位加法器/本模塊生成N位的加法器 module addr(co,sum,a0,a1,ci); /參數(shù)聲明,本參數(shù)可以重新定義 parameter N= 4; /缺省的.急線位寬為4 /端口聲明 output N-1:0 sum; output co; input N-1:0 a0,a1; input ci; /根據(jù)總線的位寬,調用(實例引用)相應的加法器
21、/參數(shù)N在調用(實例引用)時可以重新定義。調用(實例引用) /不同位寬的加法器是根據(jù)不同的N來決定的 generate case(N) /當N=1或2時分別選用位寬為1位或2位的加法器 1 : addr_1bit addr1(co,sum,a0,a1,ci); /1位的加法器 2 : addr_2bit addr2(co,sum,a0,a1,ci); /2位的加法器 / 默認的情況下選用位寬為N位的超前進位加法器 default : addr_cla #(N) addr3(co,sum,a0,a1,ci); endgenerate/生成塊的結束endmodule14、四選一多路器/四選一多路器
22、,其端口列表完全根據(jù)輸人/輸出圖編寫 module mux4_to_1(out,i0,i1,i2,i3,s1,s0); /根據(jù)輸入/輸出圖的端口聲明 output out; input i0, i1, i2, i3; input s1, s0; /輸出端口被聲明為寄存器類型變量reg out; /若輸人信號改變,則重新計算輸出信號out /造成輸出信號out重新計算的所有輸人信號 /必須寫入always(.)的電平敏感列表 always(s1,s0,i0,i1,i2,i3) begin case(s1,s0) 2'b00 : out = i0; 2'b01 : out = i1
23、; 2'b10 : out = i2; 2'b11 : out = i3; default : out = bx; endendmodule15、四位計數(shù)器/四位二進制計數(shù)器module counter(Q,clock,clear);/輸入/輸出端口 output 3:0 Q; inputclock,clear;/輸出變量Q被定義為寄存器類型 reg 3:0 Q; always(posedge clear or negedge clock) begin if(clear) Q<=4'd0;/為了能生成諸如觸發(fā)器一類的時序邏輯, /建議使用非阻塞賦值 else Q&
24、lt;=Q+1; /Q是一個四位的寄存器, endendmodule16、使用任務控制交通燈module traffic_lights; reg clock, red, amber, green; parameter on = 1, off = 0, red_tics = 350, amber_tics = 30, green_tics = 200; /交通燈初始化 initial red = off; initial amber = off; initial green = off;/交通燈控制時序 always begin red=on;/開紅燈 light(red,red_tics);/
25、調用等待任務 green=on;/開綠燈 light(green,green_tics);/等待 amber=on;/開黃燈 light(amber,amber_tics);/等待 end/定義交通燈開啟時間的任務 task light; /注意此行不需要端口名列表 output color;/ task的輸出參量 input31:0 tics;/ task的輸入?yún)⒘?begin repeat ( tics ) ( posedge clock ); /等待tics個時鐘的上升沿 color = off;/關燈 end endtask/產(chǎn)生時鐘脈沖的always塊always begin #10
26、0 clock = 0; #100 clock = 1; endendmodule17、CPU總線控制的任務timescale 1ns/10psmodule bus_ctrl_tb; reg 7: 0 data; reg data_valid; reg data_rd; cpu u1(data_valid, data,data_rd); initial begin / /任務調用 cpu_driver (8'b0000_0000); cpu_driver (8'b1010_1010); cpu_driver (8'b0101_0101); end/定義任務task cp
27、u_driver; input 7:0 data_in; begin #30 data_valid = 1; wait (data_rd = 1); #20 data = data_in; wait (data_rd = 0); #20 data = 8'hzz; #30 data_valid = 0; end endtask /任務結束endmodule18、自動任務示例module auto_task; reg 4:0 cd_add, ef_add; reg 4:0 c, d , e, f; reg clk1,clk2; parameter delay=1; initial beg
28、in clk1=0; clk2=0; c=3; d=5; e=7; f=4; #20 c=2; d=4; e=8; f=10; #20 $stop; endinitial forever #4 clk1=clk1;initial forever #5 clk2=clk2;task automatic adder; / 任務定義 output 4: 0 ab_adder; input 4: 0 a, b; begin #delay ab_adder = a + b; endendtaskalways (posedge clk1) adder(ef_add,e,f);always (posedge clk2) adder(cd_add, c, d);endmodule19、用函數(shù)實現(xiàn)乘累加器module mac(out,a,b,clk,clr); /? output15:0 out; input7:0 a,b; input clk,clr; reg15:0 out; wire15:0 sum; /定義函數(shù)mult;function15:0 mult; input7:0 a,b; reg15:0 result; integer i; begin result = a0 ? b:0; fo
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 校園各項消防安全管理工作計劃三篇
- 【可行性報告】2025年防毒面具項目可行性研究分析報告
- 照明工業(yè)刻錄機行業(yè)行業(yè)發(fā)展趨勢及投資戰(zhàn)略研究分析報告
- 音樂一年級下冊教學計劃
- 開學典禮演講稿范文15篇
- 志愿者2022工作計劃安排三篇
- 語文教研組工作計劃
- 中航重機驗資報告
- 工作保證書集合15篇
- 申請辭職報告模板集錦7篇
- 2023北京市第一次高中學業(yè)水平合格性考試數(shù)學試卷真題(含答案詳解)
- 九年級語文上學期教學工作總結
- 偉大的《紅樓夢》智慧樹知到答案章節(jié)測試2023年
- 有限空間作業(yè)審批表格模板
- 春節(jié)人員流失預控方案
- 2019年日照市專業(yè)人員繼續(xù)教育答案(更新全)
- TWSJD 002-2019 醫(yī)用清洗劑衛(wèi)生要求
- 杭州地鐵一號線工程某盾構區(qū)間實施施工組織設計
- XX集團公司“揭榜掛帥”實施辦法
- 闌尾炎的CT診斷課件
- 現(xiàn)代漢語常用詞匯表(兩字)
評論
0/150
提交評論