哈哈哈哈哈操欧洲电影,久草网在线,亚洲久久熟女熟妇视频,麻豆精品色,久久福利在线视频,日韩中文字幕的,淫乱毛视频一区,亚洲成人一二三,中文人妻日韩精品电影

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

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

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

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

汽車玩家 ? 來源:FPGA技術(shù)聯(lián)盟 ? 作者:Jarvis ? 2020-01-30 17:41 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

基本概念

阻塞賦值(Blocking Assignment)

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

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

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

非阻塞賦值(Nonblocking assignment)

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

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

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

金規(guī)

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

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

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

module eq1_block

input wire i0, i1,

output reg eq

);

reg p0, p1;

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

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

begin

p0 = ~i0 & ~i1;

p1 = i0 & i1;

eq = p0 | p1;

end

endmodule

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

always @(i0,i1)

begin

eq = p0 | p1;

p0 = ~i0 & ~i1;

p1 = i0 & i1;

end

在第一條描述中,由于p0和p1還沒有被賦予新值,所以p0和p1依然保持原來的賦值,這樣得到的最終結(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依然在敏感量列表中

// 描述順序無關(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原來保持值的賦值,所以eq不變,當(dāng)前賦值結(jié)束時(shí),always模塊重新被激活,由于p0和p1被改變(這就是p0和p1放在敏感量列表中的原因),eq變量在第二個(gè)時(shí)鐘節(jié)拍賦予了新值。從以上分析,即使將以上語句的順序發(fā)生改變,也不會(huì)影響最終結(jié)果,因?yàn)閑q的賦值以及always模塊的激活與這些語句的順序并沒關(guān)系。

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

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

就單獨(dú)一個(gè)寄存器來說,阻塞賦值和非阻塞賦值都可以描述存儲(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語句同時(shí)被激活并且并行執(zhí)行,一個(gè)時(shí)鐘節(jié)拍后兩條語句執(zhí)行結(jié)束,按照verilog語法標(biāo)準(zhǔn),兩個(gè)always語句執(zhí)行結(jié)果時(shí)間順序上誰都有可能在前面,這樣一來,如果第一個(gè)always語句執(zhí)行在前面,由于阻塞賦值,所以變量a立即得到b的賦值,那么當(dāng)?shù)诙€(gè)always塊執(zhí)行之后,變量b得到a的賦值,由于剛才第一個(gè)always執(zhí)行的時(shí)候b值賦予了a,所以現(xiàn)在b的值會(huì)維持不變,還是原來的值。

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

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

always@(posedge clk)

a 《= b;

always@(posedge clk)

b 《= a;

采用非阻塞賦值,由于原始信號(hào)在賦值語句中使用,所以a和b都會(huì)得到正確的值,而與順序沒有關(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ī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 阻塞賦值
    +關(guān)注

    關(guān)注

    0

    文章

    10

    瀏覽量

    9343
  • VerilogHDL
    +關(guān)注

    關(guān)注

    2

    文章

    39

    瀏覽量

    19941
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    電信接收機(jī) IF/RF 前端 SAW 濾波方案:70–300MHz 選擇性提升 + 阻塞防護(hù) + 匹配驗(yàn)證全流程(FSF-5050 系列)

    電信接收機(jī) IF/RF 前端易受強(qiáng)帶外干擾引發(fā)壓縮、互調(diào)與阻塞,DSP 難補(bǔ)救。本方案以 SAW 濾波器為“門禁”,覆蓋 70–300MHz IF 規(guī)劃,給出放置位置、IL/阻帶/群時(shí)延取舍、匹配與 PCB 要點(diǎn),并提供 VNA+阻塞測(cè)試驗(yàn)證流程,適配 FSF 5×5mm
    的頭像 發(fā)表于 01-29 14:00 ?1211次閱讀
    電信接收機(jī) IF/RF 前端 SAW 濾波方案:70–300MHz 選擇性提升 + <b class='flag-5'>阻塞</b>防護(hù) + 匹配驗(yàn)證全流程(FSF-5050 系列)

    C語言重點(diǎn)—指針

    和原理(必須清楚掌握)2.1 直接'='賦值int a = 5;printf("a = %d",a); 結(jié)果: a = 5 這
    發(fā)表于 01-22 08:23

    解析SN65LVDS125A和SN65LVDT125A:4x4阻塞交叉點(diǎn)開關(guān)的卓越性能

    和SN65LVDT125A作為4x4阻塞交叉點(diǎn)開關(guān),憑借其出色的性能和廣泛的應(yīng)用場(chǎng)景,成為了眾多工程師的首選。今天,我們就來深入了解下這兩款器件。 文件下載: sn65lvdt125a.pdf
    的頭像 發(fā)表于 12-29 17:40 ?717次閱讀

    探索SN65LVDS125A和SN65LVDT125A:4x4阻塞交叉點(diǎn)開關(guān)的卓越性能

    和SN65LVDT125A這兩款由德州儀器(TI)推出的4x4阻塞交叉點(diǎn)開關(guān),憑借其出色的性能,在眾多應(yīng)用場(chǎng)景中展現(xiàn)出強(qiáng)大的競(jìng)爭(zhēng)力。今天,我們就起來深入了解這兩款器件的特點(diǎn)、應(yīng)用及相關(guān)技術(shù)細(xì)節(jié)。 文件下載
    的頭像 發(fā)表于 12-29 17:40 ?841次閱讀

    深入解析SN65LVDS250與SN65LVDT250:高性能4x4 LVDS交叉點(diǎn)開關(guān)

    ,咱們就來詳細(xì)剖析德州儀器(Texas Instruments)推出的SN65LVDS250與SN65LVDT250這兩款4x4阻塞交叉點(diǎn)開關(guān),看看它們究竟有哪些獨(dú)特的性能和優(yōu)勢(shì)。 文件下載
    的頭像 發(fā)表于 12-29 17:10 ?666次閱讀

    深入剖析SN65LVCP204:4×4千兆交叉點(diǎn)開關(guān)的卓越性能與應(yīng)用

    ×4阻塞交叉點(diǎn)開關(guān),它在高速網(wǎng)絡(luò)、電信等領(lǐng)域有著廣泛的應(yīng)用。 文件下載: sn65lvcp204.pdf 、產(chǎn)品概述 SN65LVCP204是款專為高速數(shù)據(jù)傳輸設(shè)計(jì)的4×4
    的頭像 發(fā)表于 12-25 10:45 ?657次閱讀

    具有阻塞總線恢復(fù)功能的 TCA4307 熱插拔 I2C 總線和 SMBus 緩沖器介紹

    具有阻塞總線恢復(fù)功能的 TCA4307 熱插拔 I2C 總線和 SMBus 緩沖器介紹 在電子設(shè)計(jì)領(lǐng)域,熱插拔 I2C 總線緩沖器是實(shí)現(xiàn)系統(tǒng)靈活擴(kuò)展和維護(hù)的重要組件。今天,我們就來深入了解
    的頭像 發(fā)表于 12-17 15:40 ?501次閱讀

    飛凌嵌入式ElfBoard-文件I/O的深入學(xué)習(xí)之阻塞I/O與阻塞I/O

    可能會(huì)使程序阻塞等待,直到有數(shù)據(jù)可讀時(shí)才會(huì)被喚醒返回。 普通文件的讀寫操作是不會(huì)阻塞的,不管讀寫多少個(gè)字節(jié)數(shù)據(jù),read或 write定會(huì)在有限的時(shí)間內(nèi)返回,所以普通文件定是以
    發(fā)表于 12-01 13:07

    Siumulink模型測(cè)試典型問題分享——模型層級(jí)設(shè)計(jì)不合理

    典型測(cè)試問題分享-模型層級(jí)設(shè)計(jì)不合理 問題描述: ?重點(diǎn)功能與重點(diǎn)功能混合,導(dǎo)致測(cè)試層級(jí)選擇困難。 ?模型未體現(xiàn)層級(jí)劃分,結(jié)構(gòu)平鋪導(dǎo)致層級(jí)圈復(fù)雜度異常。 ?部分計(jì)算/判斷/賦值等結(jié)構(gòu)位于測(cè)試層級(jí)之外,存在未覆蓋風(fēng)險(xiǎn)。
    的頭像 發(fā)表于 09-20 12:31 ?3066次閱讀
    Siumulink模型測(cè)試典型問題分享——模型層級(jí)設(shè)計(jì)不合理

    CH32V307 串口發(fā)送阻塞的原因?怎么解決?

    */ modbus_set_rx_mode(master); modbus發(fā)送,不知為何阻塞在rt_device_write,初始化 find open 正常
    發(fā)表于 09-18 06:06

    集成DMR858M:ESP32自定義數(shù)字對(duì)講機(jī)實(shí)踐指南

    成功集成DMR858M模塊的核心在于遵循幾個(gè)關(guān)鍵的工程實(shí)踐:設(shè)計(jì)個(gè)能夠應(yīng)對(duì)高瞬態(tài)電流的穩(wěn)健電源系統(tǒng);通過系統(tǒng)化的測(cè)試方法確定并實(shí)現(xiàn)正確的串行通信校驗(yàn)和算法;以及采用結(jié)構(gòu)化、阻塞的固件架構(gòu)來確保系統(tǒng)的實(shí)時(shí)響應(yīng)能力。
    的頭像 發(fā)表于 09-03 11:04 ?1240次閱讀
    集成DMR858M:ESP32自定義數(shù)字對(duì)講機(jī)實(shí)踐指南

    【HZ-RK3568開發(fā)板免費(fèi)體驗(yàn)】基于 Select Poll的TCP發(fā)服務(wù)器

    ,般分為網(wǎng)絡(luò)IO(本質(zhì)就是socket讀寫)和磁盤IO。 IO模型大致可以分為:同步阻塞、同步阻塞、異步、信號(hào)驅(qū)動(dòng)。 可細(xì)分為5種I/O模型: 1)
    發(fā)表于 08-19 22:01

    matlab appdesigner 表格組件賦值問題,求助

    如上圖所示,我在用matlab2021Ra APP模塊進(jìn)行編程的時(shí)候,想在表格中調(diào)入自己編寫的結(jié)構(gòu)數(shù)組,我從網(wǎng)上AI了個(gè)程序語句,看著沒問題,但是就是給表格賦值不了,還請(qǐng)各位大神幫忙看下這個(gè)是怎么回事,我是初學(xué)者,請(qǐng)各位幫
    發(fā)表于 07-12 11:45

    CH32V307串口發(fā)送阻塞的原因?如何解決?

    */ modbus_set_rx_mode(master); modbus發(fā)送,不知為何阻塞在rt_device_write,初始化 find open 正常
    發(fā)表于 06-11 08:05

    harmony OS NEXT-Navagation基本用法

    # Navagation基本用法 > Navigation組件是路由導(dǎo)航的根視圖容器,般作為Page頁面的根容器使用,其內(nèi)部默認(rèn)包含了標(biāo)題欄,內(nèi)容欄和公工具欄,其中內(nèi)容區(qū)默認(rèn)首頁顯示導(dǎo)航內(nèi)容
    的頭像 發(fā)表于 04-27 17:39 ?1058次閱讀
    千阳县| 敦化市| 双牌县| 衡南县| 孟州市| 穆棱市| 怀安县| 砚山县| 邵阳市| 呼伦贝尔市| 开江县| 莒南县| 芮城县| 易门县| 新干县| 曲阳县| 平果县| 梅河口市| 女性| 仁寿县| 扶余县| 渭南市| 全椒县| 石嘴山市| 饶平县| 正定县| 苍梧县| 唐海县| 台山市| 固原市| 昆山市| 新津县| 藁城市| 芜湖县| 南充市| 板桥市| 石楼县| 唐河县| 思茅市| 岳普湖县| 桦甸市|