深入分析verilog阻塞和非阻塞賦值_第1頁(yè)
深入分析verilog阻塞和非阻塞賦值_第2頁(yè)
深入分析verilog阻塞和非阻塞賦值_第3頁(yè)
全文預(yù)覽已結(jié)束

下載本文檔

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

文檔簡(jiǎn)介

深入分析verilog阻塞和非阻塞賦值學(xué)verilog一個(gè)月了,在開(kāi)發(fā)板上面寫了很多代碼,但是始終對(duì)一些問(wèn)題理解的不夠透徹,這里我們來(lái)寫幾個(gè)例子仿真出阻塞和非阻塞的區(qū)別,我們先上代碼moduleLED

(

CLK,RSTn,

scan,

flag,

c,

,one,two,three,four);

inputCLK;

inputRSTn;

inputscan;

outputflag,c;

output[3:0]one,two,three,four;/***********************************************************/

regF1,F2;

rega,b;

reg[3:0]one,two,three,four;

/********************信號(hào)傳遞之間的非阻塞賦值***************************************/

always@(posedgeCLKornegedgeRSTn)

//

if(!RSTn)

begin

F1<=1'b1;

F2<=1'b1;

end

else

begin

F1<=scan;

F2<=F1;

end

/*******************信號(hào)傳遞之間的阻塞賦值****************************************/

always@(posedgeCLKornegedgeRSTn)

//

if(!RSTn)

begin

a=1'b1;

b=1'b1;

end

else

begin

a=scan;

b=a;

end

/******************數(shù)據(jù)加

非阻塞賦值

先判斷后計(jì)數(shù)*****************************************/

always@(posedgeCLKornegedgeRSTn)

//one<=

if(!RSTn)

begin

one<=0;

end

else

begin

if(one==14)

one<=0;

else

one<=one+1;

end/***************數(shù)據(jù)加

非阻塞賦值

先計(jì)數(shù)后判斷********************************************/

always@(posedgeCLKornegedgeRSTn)

//

two<=

if(!RSTn)

begin

two<=0;

end

else

begin

two<=two+1;

if(two==14)

two<=0;

end

/**************數(shù)據(jù)加

阻塞賦值

先判斷后計(jì)數(shù)*********************************************/

always@(posedgeCLKornegedgeRSTn)

//three=

if(!RSTn)

begin

three=0;

end

else

begin

if(three==14)

three=0;

else

three=three+1;

end/*************數(shù)據(jù)加

阻塞賦值

先計(jì)數(shù)后判斷**********************************************/

always@(posedgeCLKornegedgeRSTn)

//four=

if(!RSTn)

begin

four=0;

end

else

begin

four=four+1;

if(four==14)

four=0;

end

/****************信號(hào)之間傳遞***********************/

assignflag=F2&!F1;assignc

=b

&!a;/***************************************/

endmodule

2、我使用modesim仿真,下面為我的

testbench

`timescale1ps/1psmoduleLED_vlg_tst();//constants

//generalpurposeregistersregeachvec;//testvectorinputregistersregCLK;regRSTn;regscan;//wires

wirec;wireflag;wire[3:0]

four;wire[3:0]

one;wire[3:0]

three;wire[3:0]

two;//assignstatements(ifany)

LEDi1(//portmap-connectionbetweenmasterportsandsignals/registers

.CLK(CLK),

.RSTn(RSTn),

.c(c),

.flag(flag),

.four(four),

.one(one),

.scan(scan),

.three(three),

.two(two));/*initial

begin

//codethatexecutesonlyonce

//insertcodehere-->begin

//-->end

$display("Runningtestbench");

end

always

//optionalsensitivitylist

//@(event1orevent2or....eventn)

begin

//codeexecutesforeveryeventonsensitivitylist

//insertcodehere-->begin

@eachvec;

//-->end

end

endmodule*/initialbeginCLK=0;forever#10CLK=~CLK;

endinitialbeginscan=0;forever#100scan=~scan;

endinitialbeginRSTn=0;#1000RSTn=

1;#1000;#1000;#1000;#1000;#1000;#1000;#1000;#1000;$stop;endendmodule

主要就是初始化一個(gè)CLK和scan的信號(hào),然后就是初始化一下復(fù)位,最后就是設(shè)置仿真時(shí)間,這樣modesim就不會(huì)一直處于仿真狀態(tài),消耗資源,也可以方便仿真。

其中quartus

與modesim

互相調(diào)用調(diào)試,可以關(guān)注我的博客,這里我就不具體講解了!

3、modesim波形圖

大家注意到紅線框內(nèi)的數(shù)據(jù)變化,就能很清楚的理解阻塞與非阻塞了!

微觀分析阻塞與非阻塞1、上代碼,具體觀察,a,b,c與F1,F(xiàn)2,flage的變化

moduleLED

(

CLK,RSTn,

scan,

flag,

a,b,c,F1,F2,);

inputCLK;

inputRSTn;

inputscan;

outputflag,a,b,c;

outputF1,F2;/***********************************************************/

regF1,F2;

rega,b;

/***********************************************************/

always@(posedgeCLKornegedgeRSTn)

//

if(!RSTn)

begin

F1<=1'b1;

F2<=1'b1;

end

else

begin

F1<=scan;

F2<=F1;

end

/***********************************************************/

always@(posedgeCLKornegedgeRSTn)

//

if(!RSTn)

begin

a=1'b1;

b=1'b1;

end

else

b

溫馨提示

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

最新文檔

評(píng)論

0/150

提交評(píng)論