女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

阻塞賦值和非阻塞賦值的用法一篇文章就夠了

汽車玩家 ? 來(lái)源:FPGA技術(shù)聯(lián)盟 ? 作者:Jarvis ? 2020-01-30 17:41 ? 次閱讀

對(duì)于VerilogHDL語(yǔ)言中,經(jīng)常在always模塊中,面臨兩種賦值方式:阻塞賦值和非阻塞賦值。對(duì)于初學(xué)者,往往非常迷惑這兩種賦值方式的用法,本章節(jié)主要介紹這兩種文章的用法。其實(shí),有時(shí)候概念稍微不清楚,Bug就會(huì)找到我們,下面一文掃清阻塞賦值和非阻塞賦值所有的障礙。

基本概念

阻塞賦值(Blocking Assignment)

阻塞賦值的基本描述格式為:

[變量] = [邏輯表達(dá)式];

阻塞賦值在執(zhí)行的時(shí)候,右端表達(dá)式執(zhí)行并賦值到左邊變量,不會(huì)受任何情況打斷。所以在本次賦值結(jié)束之前他“阻塞”了當(dāng)前其他的賦值任務(wù),阻塞賦值的操作和C語(yǔ)言中的變量賦值非常相似。

非阻塞賦值(Nonblocking assignment)

非阻塞賦值的基本描述格式為:

[變量] 《= [邏輯表達(dá)式];

非阻塞賦值行為有些細(xì)微之處比較難以理解。我們最好從硬件角度來(lái)理解,always模塊可以被認(rèn)為是純硬件模塊,當(dāng)always模塊被激活時(shí),非阻塞賦值的右側(cè)表達(dá)式就開(kāi)始執(zhí)行;當(dāng)always模塊所有表達(dá)式執(zhí)行結(jié)束之后,所有執(zhí)行結(jié)果才賦值到左側(cè)變量當(dāng)中。之所以稱為“非阻塞”就是在本條賦值語(yǔ)句執(zhí)行的過(guò)程中,其他賦值語(yǔ)句也可以執(zhí)行。

金規(guī)

1. 在組合邏輯電路描述中采用阻塞賦值

阻塞賦值和非阻塞賦值雖然都可以用來(lái)描述同一電路,以1位比較器舉例來(lái)解釋這種差別。

阻塞賦值實(shí)現(xiàn)1bit比較器

module eq1_block

input wire i0, i1,

output reg eq

);

reg p0, p1;

always @(i0,i1) // i0 和i1 在敏感量列表當(dāng)中

// 語(yǔ)句描述的順序非常關(guān)鍵

begin

p0 = ~i0 & ~i1;

p1 = i0 & i1;

eq = p0 | p1;

end

endmodule

分析:程序中,敏感量列表中包含i0和i1,只要這兩個(gè)變量有一個(gè)發(fā)生改變,都會(huì)激活always語(yǔ)句,那么p0、p1和eq就會(huì)順序賦值,最終eq賦值就會(huì)被更新,所以這三條語(yǔ)句的描述順序非常關(guān)鍵,假如將最后一條語(yǔ)句提前:

always @(i0,i1)

begin

eq = p0 | p1;

p0 = ~i0 & ~i1;

p1 = i0 & i1;

end

在第一條描述中,由于p0和p1還沒(méi)有被賦予新值,所以p0和p1依然保持原來(lái)的賦值,這樣得到的最終結(jié)果顯然是錯(cuò)誤的。

非阻塞賦值實(shí)現(xiàn)1bit比較器

module eq1_non_block

input wire i0, i1,

output reg eq

);

reg p0, p1;

always @(i0,i1,p0,p1) // p0, p1依然在敏感量列表中

// 描述順序無(wú)關(guān)緊要

begin

p0 《= ~i0 & ~i1;

p1 《= i0 & i1;

eq 《= p0 | p1;

end

endmodule

分析:p0和p1包含在敏感量列表當(dāng)中,當(dāng)i0 或者 i1有所變化,always模塊被激活,p0和p1在第一個(gè)時(shí)鐘節(jié)拍結(jié)束時(shí)賦值,由于eq值為基于p0和p1原來(lái)保持值的賦值,所以eq不變,當(dāng)前賦值結(jié)束時(shí),always模塊重新被激活,由于p0和p1被改變(這就是p0和p1放在敏感量列表中的原因),eq變量在第二個(gè)時(shí)鐘節(jié)拍賦予了新值。從以上分析,即使將以上語(yǔ)句的順序發(fā)生改變,也不會(huì)影響最終結(jié)果,因?yàn)閑q的賦值以及always模塊的激活與這些語(yǔ)句的順序并沒(méi)關(guān)系。

總結(jié):雖然兩種描述方法都可以描述同一電路,但是兩個(gè)電路的結(jié)果是有區(qū)別的,采用非阻塞賦值法描述仿真的時(shí)候花的時(shí)間更長(zhǎng)一些,電路輸出結(jié)果在時(shí)序上也有微弱差別,鑒于此,我們有這么一條原則“在組合邏輯電路描述中采用阻塞賦值”。

2. 時(shí)序邏輯描述,采用非阻塞賦值方式賦值

就單獨(dú)一個(gè)寄存器來(lái)說(shuō),阻塞賦值和非阻塞賦值都可以描述存儲(chǔ)單元,如DFF可以描述為

always@(posedge clk)

q 《= d;

也可以描述為

always@(posedge clk)

q = d;

但是當(dāng)設(shè)計(jì)中存在多個(gè)寄存器描述單元的時(shí)候,就會(huì)有細(xì)微的查別,假設(shè)有兩個(gè)寄存器在每個(gè)時(shí)鐘的上升沿進(jìn)行數(shù)據(jù)交換,采用阻塞賦值描述如下:

always@(posedge clk)

a = b;

always@(posedge clk)

b = a;

在時(shí)鐘的上升沿,兩個(gè)always語(yǔ)句同時(shí)被激活并且并行執(zhí)行,一個(gè)時(shí)鐘節(jié)拍后兩條語(yǔ)句執(zhí)行結(jié)束,按照verilog語(yǔ)法標(biāo)準(zhǔn),兩個(gè)always語(yǔ)句執(zhí)行結(jié)果時(shí)間順序上誰(shuí)都有可能在前面,這樣一來(lái),如果第一個(gè)always語(yǔ)句執(zhí)行在前面,由于阻塞賦值,所以變量a立即得到b的賦值,那么當(dāng)?shù)诙€(gè)always塊執(zhí)行之后,變量b得到a的賦值,由于剛才第一個(gè)always執(zhí)行的時(shí)候b值賦予了a,所以現(xiàn)在b的值會(huì)維持不變,還是原來(lái)的值。

同樣的道理,如果第二個(gè)always模塊先執(zhí)行了,那么a就會(huì)保持自身值不變,從Verilog語(yǔ)法角度來(lái)看,兩種結(jié)果都是有效的。但是從數(shù)字電路的角度來(lái)說(shuō),明顯引起了競(jìng)爭(zhēng)。

下面我們將阻塞賦值修改為非阻塞賦值,以上代碼修改為:

always@(posedge clk)

a 《= b;

always@(posedge clk)

b 《= a;

采用非阻塞賦值,由于原始信號(hào)在賦值語(yǔ)句中使用,所以a和b都會(huì)得到正確的值,而與順序沒(méi)有關(guān)系。所以在時(shí)序邏輯描述中,阻塞賦值往往會(huì)引起條件競(jìng)爭(zhēng),所以要采用非阻塞賦值方式賦值。

總結(jié)一下

① 在組合邏輯電路描述中采用阻塞賦值

② 時(shí)序邏輯描述,采用非阻塞賦值方式賦值

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 阻塞賦值
    +關(guān)注

    關(guān)注

    0

    文章

    10

    瀏覽量

    9229
  • VerilogHDL
    +關(guān)注

    關(guān)注

    2

    文章

    39

    瀏覽量

    19339
收藏 人收藏

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    在testbench中如何使用阻塞賦值阻塞賦值

    本文詳細(xì)闡述了在個(gè)testbench中,應(yīng)該如何使用阻塞賦值阻塞賦值。首先說(shuō)結(jié)論,建議在t
    的頭像 發(fā)表于 04-15 09:34 ?529次閱讀
    在testbench中如何使用<b class='flag-5'>阻塞</b><b class='flag-5'>賦值</b>和<b class='flag-5'>非</b><b class='flag-5'>阻塞</b><b class='flag-5'>賦值</b>

    “串口阻塞”你真的會(huì)用嗎?

    很久才會(huì)發(fā)出來(lái),下子出來(lái)很多數(shù)據(jù)”。經(jīng)過(guò)幫客戶檢查應(yīng)用程序源碼,發(fā)現(xiàn)應(yīng)用程序在串口阻塞方面沒(méi)有做正確的處理,修改后解決。阻塞打開(kāi)串口open("/dev/tty
    的頭像 發(fā)表于 02-13 11:42 ?638次閱讀
    “串口<b class='flag-5'>阻塞</b>”你真的會(huì)用嗎?

    數(shù)組名之間可以直接賦值

    數(shù)組之間的賦值能不能直接使用等于號(hào)?比如這樣的代碼。 int main(){ int a[5] = {1, 2, 3, 4, 5}; int b[5] = {0}; b = a
    的頭像 發(fā)表于 11-26 11:23 ?496次閱讀

    TPA3004功放,開(kāi)機(jī)保護(hù),聲音阻塞,為什么?

    TPA3004功放,開(kāi)機(jī)保護(hù),聲音阻塞。過(guò)段時(shí)間,芯片發(fā)熱后正常。詢求問(wèn)題解決方法
    發(fā)表于 11-08 08:30

    socket編程中的阻塞阻塞

    在網(wǎng)絡(luò)編程中, socket 是個(gè)非常重要的概念,它提供了個(gè)抽象層,使得開(kāi)發(fā)者可以不必關(guān)心底層的網(wǎng)絡(luò)通信細(xì)節(jié)。 socket 編程中的阻塞
    的頭像 發(fā)表于 11-01 16:13 ?629次閱讀

    Verilog HDL的基礎(chǔ)知識(shí)

    本文繼續(xù)介紹Verilog HDL基礎(chǔ)知識(shí),重點(diǎn)介紹賦值語(yǔ)句、阻塞阻塞、循環(huán)語(yǔ)句、同步與異步、函數(shù)與任務(wù)語(yǔ)法知識(shí)。
    的頭像 發(fā)表于 10-24 15:00 ?1038次閱讀
    Verilog HDL的基礎(chǔ)知識(shí)

    SystemView上下文統(tǒng)計(jì)窗口識(shí)別阻塞原因

    SystemView工具可以記錄嵌入式系統(tǒng)的運(yùn)行時(shí)行為,實(shí)現(xiàn)可視化的深入分析。在新發(fā)布的v3.54版本中,增加了項(xiàng)新功能:上下文統(tǒng)計(jì)窗口,提供了對(duì)任務(wù)運(yùn)行時(shí)統(tǒng)計(jì)信息的深入分析,使用戶能夠徹底檢查每個(gè)任務(wù),幫助開(kāi)發(fā)人員識(shí)別阻塞原因。
    的頭像 發(fā)表于 08-20 11:31 ?633次閱讀

    socket阻塞阻塞的區(qū)別是什么

    在計(jì)算機(jī)編程中,socket 是種通信端點(diǎn),用于在網(wǎng)絡(luò)中進(jìn)行數(shù)據(jù)傳輸。Socket 可以是阻塞的或阻塞的,這兩種模式在處理數(shù)據(jù)傳輸時(shí)有不同的行為。
    的頭像 發(fā)表于 08-16 11:13 ?1124次閱讀

    求助,關(guān)于CyU3PUsbHostEpWaitForCompletion函數(shù)中的阻塞問(wèn)題求解

    主線程)調(diào)用該函數(shù)時(shí),CyU3PUsbHostEpWaitForCompletion 函數(shù)經(jīng)常阻塞,雖然指定了超時(shí)值,但從未返回。 我想應(yīng)該在主程序線程中調(diào)用該函數(shù),以避免出現(xiàn)阻塞問(wèn)題。 如何正確使用該功能而不造成
    發(fā)表于 07-23 07:57

    如何在espconn_gethostbyname上創(chuàng)建阻塞線程?

    在 espconn_gethostbyname 上創(chuàng)建阻塞線程
    發(fā)表于 07-10 07:45

    是否可以使用Aurix中的CCU6模塊,以阻塞方式在檢測(cè)到GPIO下降沿時(shí)觸發(fā)中斷?

    我想知道,是否可以使用 Aurix 中的 CCU6 模塊,以阻塞方式在檢測(cè)到 GPIO 下降沿時(shí)觸發(fā)中斷? TC397 的示例代碼僅將其用于 PWM 生成和時(shí)鐘定時(shí),但我很好奇如何將其用于 GPIO 邊沿檢測(cè)。
    發(fā)表于 07-04 07:00

    請(qǐng)問(wèn)怎們?cè)O(shè)置socket套接字的rec函數(shù)的阻塞時(shí)間?

    請(qǐng)問(wèn)怎們?cè)O(shè)置socket套接字的rec函數(shù)的阻塞時(shí)間?
    發(fā)表于 06-24 06:14

    FPGA學(xué)習(xí)筆記---基本語(yǔ)法

    :task...endtask 11、循環(huán)語(yǔ)句:for 12、賦值符號(hào):=和<=(阻塞阻塞賦值) 硬件設(shè)計(jì)的精髓,力求用最簡(jiǎn)單的語(yǔ)
    發(fā)表于 06-23 14:58

    請(qǐng)問(wèn)使用lwip創(chuàng)建socket,該如何做到阻塞的接收發(fā)送數(shù)據(jù)?

    請(qǐng)問(wèn)使用lwip創(chuàng)建socket,該如何做到阻塞的接收發(fā)送數(shù)據(jù)?
    發(fā)表于 06-19 06:02

    如何讓write行為具有阻塞特性?

    spp_vfs_write 與 PC 端 socket 溝通:esp32 write, PC read.若 PC 端不執(zhí)行 read 行為,esp32 持續(xù) spp_vfs_write ,數(shù)據(jù)會(huì)發(fā)送到 PC 端嗎?還是在 esp32 設(shè)備端 ?謝謝。另如何讓 write 行為具有阻塞特性?謝謝。
    發(fā)表于 06-11 07:23