欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

標(biāo)題: Verilog語(yǔ)法學(xué)習(xí)(一) [打印本頁(yè)]

作者: wangyin    時(shí)間: 2014-7-30 14:39
標(biāo)題: Verilog語(yǔ)法學(xué)習(xí)(一)
Verilog并不難,只要有一點(diǎn)的C語(yǔ)言基礎(chǔ),你就可以開(kāi)始學(xué)習(xí)它,進(jìn)而不斷深入的學(xué)習(xí)FPGA。和C語(yǔ)言以main函數(shù)一樣,Verilog以模塊為主體,看下面一個(gè)小小的例子:module my_first(
sys_clk,
rst_n,
data_ina,
data_inb,
data_out
);
// 端口說(shuō)明
input sys_clk;
input rst_n;
input [7:0] data_ina;
input      [7:0] data_inb
output [8:0] data_out;
// 功能操作
assign data_out = data_ina + data_inb;

endmodule




整個(gè)模塊就是以 module   模塊名 和 endmodule組成,這樣就算編寫了一個(gè)簡(jiǎn)單的模塊了。它主要包括:



作者: wangyin    時(shí)間: 2014-7-30 14:40
Verilog的數(shù)據(jù)類型常用的是:reg和wire型。當(dāng)我們對(duì)端口申明了時(shí),此時(shí)默認(rèn)的類型是wire型。
reg型是寄存器類型,也就是再用鎖存器和觸發(fā)器時(shí)必須聲明為此類型才合法,否則就不合法,這也是我們經(jīng)常對(duì)一個(gè)輸出定義時(shí)大多需要定義為reg的原因。當(dāng)然,當(dāng)我們的輸出由組合邏輯獲得時(shí),就不需聲明了,因?yàn)槟J(rèn)就是wire型而不用再申明了。wire類型就是連線類型,一般作為輸出級(jí)表達(dá)式右側(cè)的參數(shù)適用。例
module  test(
sys_clk,
rst_n,
data_in,
data_outa,
data_outb
);
input    data_in;
output  data_outa;
output  reg  data_outb;

assign data_outa = data_in;

always @(posedge sys_clk)
begin
if(rst_n == 1'b0)
data_outb <= 1'b0;
else
data_outb <= data_outa;
end
endmodule

這個(gè)例子中的data_outa是默認(rèn)的wire類型,它是對(duì)的,因?yàn)閍ssign   data_outa = data_in;是組合邏輯語(yǔ)句,不需要用寄存器保存其值;而data_outa是時(shí)序邏輯,需要寄存器保存現(xiàn)在的值,只有當(dāng)觸發(fā)條件到來(lái)時(shí)才更新寄存器中的值,所以定義為reg型,同時(shí)它的值可有wire類型的data_outa來(lái)決定,也就是一個(gè)組合邏輯的輸出作為時(shí)序的輸入,這是合法的。下次將從硬件描述語(yǔ)言的角度來(lái)看看 if和case語(yǔ)句的理解和運(yùn)用。
作者: wangyin    時(shí)間: 2014-7-30 14:40
本帖最后由 wangyin 于 2014-7-30 14:42 編輯

順序執(zhí)行語(yǔ)句:if(條件語(yǔ)句)  執(zhí)行的語(yǔ)句;即在程序執(zhí)行過(guò)程中是順序執(zhí)行的,按上下順序依次執(zhí)行。當(dāng)執(zhí)行的語(yǔ)句是一句語(yǔ)句,則不需加 begin   end,否則就要加begin     end,這里的begin end相當(dāng)于C語(yǔ)言里面的{ },同時(shí)注意:一般一個(gè)if需與一個(gè)else配對(duì),如果沒(méi)有的話則綜合的時(shí)候會(huì)生成一個(gè)隱性的鎖存器,當(dāng)有多個(gè)條件需要判斷時(shí)則用if(條件語(yǔ)句)  執(zhí)行的語(yǔ)句;else if(條件語(yǔ)句)  執(zhí)行的語(yǔ)句;.....else(條件語(yǔ)句)  執(zhí)行的語(yǔ)句道理同上面一樣,但if分支一般最多不超過(guò)3個(gè),如果太多的話則采用case語(yǔ)句實(shí)現(xiàn)。
并行執(zhí)行語(yǔ)句:case(條件語(yǔ)句)  滿足的條件:執(zhí)行的語(yǔ)句......; endcase 即在程序執(zhí)行過(guò)程中是并行執(zhí)行的,滿足條件的語(yǔ)句同時(shí)執(zhí)行。begin end的用法同上面的一樣,也需注意:當(dāng)有缺項(xiàng)沒(méi)有作為條件使用時(shí),同樣需要加default項(xiàng),否則也會(huì)生成隱性的鎖存器,case語(yǔ)句主要用在狀態(tài)機(jī)的編寫中。看下面的2個(gè)例子:
用if語(yǔ)句實(shí)現(xiàn)的一個(gè)選擇器:
module  mux(
a,
b,
sel,
out
);

input a;
input b;
input sel;
output out;
reg out;

always (sel)
begin
if(sel)
out <= a; // sel=1時(shí),out=a
else
out <= b; // sel=0時(shí),out=b
end
endmodule
用case語(yǔ)句實(shí)現(xiàn)的一個(gè)3-8譯碼器:
module yima(
data_in,
data_out,
);
input [2:0] data_in;
output [7:0] data_out;
reg [7:0] data_out;


always @(data_in)
begin
case(data_in)
3'd0: data_out <= 8'b0000_0001;
3'd1: data_out <= 8'b0000_0010;
3'd2: data_out <= 8'b0000_0100;
3'd3: data_out <= 8'b0000_1000;
3'd4: data_out <= 8'b0001_0000;
3'd5: data_out <= 8'b0010_0000;
3'd6: data_out <= 8'b0100_0000;
3'd7: data_out <= 8'b1000_0000;
endcase
end



endmodule





歡迎光臨 (http://m.raoushi.com/bbs/) Powered by Discuz! X3.1