色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

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

設(shè)計(jì)Verilog時(shí)為什么要避免Latch的產(chǎn)生呢?

冬至子 ? 來(lái)源:數(shù)字IC與好好生活的兩居室 ? 作者:除夕之夜啊 ? 2023-06-02 11:32 ? 次閱讀

Latch 的含義

◆鎖存器(Latch),是電平觸發(fā)的存儲(chǔ)單元,數(shù)據(jù)存儲(chǔ)的動(dòng)作取決于輸入時(shí)鐘(或者使能)信號(hào)的電平值。僅當(dāng)鎖存器處于使能狀態(tài)時(shí),輸出才會(huì)隨著數(shù)據(jù)輸入發(fā)生變化。

當(dāng)電平信號(hào)無(wú)效時(shí),輸出信號(hào)隨輸入信號(hào)變化,就像通過(guò)了緩沖器;當(dāng)電平有效時(shí),輸出信號(hào)被鎖存。激勵(lì)信號(hào)的任何變化,都將直接引起鎖存器輸出狀態(tài)的改變,很有可能會(huì)因?yàn)樗矐B(tài)特性不穩(wěn)定而產(chǎn)生振蕩現(xiàn)象。

鎖存器示意圖如下:

圖片

◆觸發(fā)器(flip-flop),是邊沿敏感的存儲(chǔ)單元,數(shù)據(jù)存儲(chǔ)的動(dòng)作(狀態(tài)轉(zhuǎn)換)由某一信號(hào)的上升沿或者下降沿進(jìn)行同步的(限制存儲(chǔ)單元狀態(tài)轉(zhuǎn)換在一個(gè)很短的時(shí)間內(nèi))。

觸發(fā)器示意圖如下:

圖片

寄存器(register),在 Verilog 中用來(lái)暫時(shí)存放參與運(yùn)算的數(shù)據(jù)和運(yùn)算結(jié)果的變量。一個(gè)變量聲明為寄存器時(shí),它既可以被綜合成觸發(fā)器,也可能被綜合成 Latch,甚至是 wire 型變量。

但是大多數(shù)情況下我們希望它被綜合成觸發(fā)器,但是有時(shí)候由于代碼書寫問題,它會(huì)被綜合成不期望的 Latch 結(jié)構(gòu)。

◆Latch 的主要危害有:1)輸入狀態(tài)可能多次變化,容易產(chǎn)生毛刺,增加了下一級(jí)電路的不確定性;2)在大部分 FPGA 的資源中,可能需要比觸發(fā)器更多的資源去實(shí)現(xiàn) Latch 結(jié)構(gòu);3)鎖存器的出現(xiàn)使得靜態(tài)時(shí)序分析變得更加復(fù)雜。

Latch 多用于門控時(shí)鐘(clock gating)的控制,設(shè)計(jì)時(shí)一般應(yīng)當(dāng)避免 Latch 的產(chǎn)生。

if 結(jié)構(gòu)不完整

◆組合邏輯中,不完整的 if - else 結(jié)構(gòu),會(huì)產(chǎn)生 Latch。

例如下面的模型,if 語(yǔ)句中缺少 else 結(jié)構(gòu),系統(tǒng)默認(rèn) else 的分支下寄存器 q 的值保持不變,即具有存儲(chǔ)數(shù)據(jù)的功能,所以寄存器 q 會(huì)被綜合成 Latch 結(jié)構(gòu)。

module module1_Latch1(
    input       data, 
    input       en ,
    output reg  q) ;

    always @(*) begin
        if (en) q = data ;
    end


endmodule

◆避免此類 Latch 的方法主要有 2 種,一種是補(bǔ)全 if-else 結(jié)構(gòu),或者對(duì)信號(hào)賦初值。

例如,上面模型中的 always 語(yǔ)句,可以改為以下兩種形式:

// 補(bǔ)全條件分支結(jié)構(gòu)   
    always @(*) begin
        if (en)  q = data ;
        else     q = 1'b0 ;
    end
//賦初值
    always @(*) begin
        q = 1'b0 ;
        if (en) q = data ; //如果en有效,改寫q的值,否則q會(huì)保持為0
    end

◆但是在時(shí)序邏輯中,不完整的 if - else 結(jié)構(gòu),不會(huì)產(chǎn)生 Latch,例如下面模型。

這是因?yàn)椋琿 寄存器具有存儲(chǔ)功能,且其值在時(shí)鐘的邊沿下才會(huì)改變,這正是觸發(fā)器的特性。

module module1_ff(
    input       clk ,
    input       data, 
    input       en ,
    output reg  q) ;

    always @(posedge clk) begin
        if (en) q <= data ;
    end


endmodule

◆在組合邏輯中,當(dāng)條件語(yǔ)句中有很多條賦值語(yǔ)句時(shí),每個(gè)分支條件下賦值語(yǔ)句的不完整也是會(huì)產(chǎn)生 Latch。

其實(shí)對(duì)每個(gè)信號(hào)的邏輯拆分來(lái)看,這也相當(dāng)于是 if-else 結(jié)構(gòu)不完整,相關(guān)寄存器信號(hào)缺少在其他條件下的賦值行為。例如:

module module1_Latch11(
    input       data1, 
    input       data2, 
    input       en ,
    output reg  q1 ,
    output reg  q2) ;

    always @(*) begin
        if (en)   q1 = data1 ;
        else      q2 = data2 ;
    end


endmodule

這種情況也可以通過(guò)補(bǔ)充完整賦值語(yǔ)句或賦初值來(lái)避免 Latch。例如:

always @(*) begin
        //q1 = 0; q2 = 0 ; //或在這里對(duì) q1/q2 賦初值
        if (en)  begin
            q1 = data1 ;
            q2 = 1'b0 ;
        end
        else begin
            q1 = 1'b0 ;
            q2 = data2 ;
        end
    end

case 結(jié)構(gòu)不完整

case 語(yǔ)句產(chǎn)生 Latch 的原理幾乎和 if 語(yǔ)句一致。在組合邏輯中,當(dāng) case 選項(xiàng)列表不全且沒有加 default 關(guān)鍵字,或有多個(gè)賦值語(yǔ)句不完整時(shí),也會(huì)產(chǎn)生 Latch。例如:

module module1_Latch2(
    input       data1, 
    input       data2, 
    input [1:0] sel ,
    output reg  q ) ;

    always @(*) begin
        case(sel)
            2'b00:  q = data1 ;
            2'b01:  q = data2 ;  //缺少 default 選項(xiàng)
        endcase
    end


endmodule

消除此種 Latch 的方法也是 2 種,將 case 選項(xiàng)列表補(bǔ)充完整,或?qū)π盘?hào)賦初值。

補(bǔ)充完整 case 選項(xiàng)列表時(shí),可以羅列所有的選項(xiàng)結(jié)果,也可以用 default 關(guān)鍵字來(lái)代替其他選項(xiàng)結(jié)果。

例如,上述 always 語(yǔ)句有以下 2 種修改方式。

always @(*) begin
        case(sel)
            2'b00:    q = data1 ;
            2'b01:    q = data2 ;
            default:  q = 1'b0 ;
        endcase
    end
always @(*) begin
        case(sel)
            2'b00:  q = data1 ;
            2'b01:  q = data2 ;
            2'b10, 2'b11 : 
                    q = 1'b0 ;
        endcase
    end

原信號(hào)賦值或判斷

在組合邏輯中,如果一個(gè)信號(hào)的賦值源頭有其信號(hào)本身,或者判斷條件中有其信號(hào)本身的邏輯,則也會(huì)產(chǎn)生 Latch。因?yàn)榇藭r(shí)信號(hào)也需要具有存儲(chǔ)功能,但是沒有時(shí)鐘驅(qū)動(dòng)。此類問題在 if 語(yǔ)句、case 語(yǔ)句、問號(hào)表達(dá)式中都可能出現(xiàn),例如:

//signal itself as a part of condition
    reg a, b ;
    always @(*) begin
        if (a & b)  a = 1'b1 ;   //a - > Latch
        else a = 1'b0 ;
    end
//signal itself are the assigment source
    reg        c;
    wire [1:0] sel ;
    always @(*) begin
        case(sel)
            2'b00:    c = c ;    //c - > Latch
            2'b01:    c = 1'b1 ;
            default:  c = 1'b0 ;
        endcase
    end
//signal itself as a part of condition in “? expression”
    wire      d, sel2;
    assign    d =  (sel2 && d) ? 1'b0 : 1'b1 ;  //d - > Latch

避免此類 Latch 的方法,就只有一種,即在組合邏輯中避免這種寫法,信號(hào)不要給信號(hào)自己賦值,且不要用賦值信號(hào)本身參與判斷條件邏輯。

例如,如果不要求立刻輸出,可以將信號(hào)進(jìn)行一個(gè)時(shí)鐘周期的延時(shí)再進(jìn)行相關(guān)邏輯的組合。上述第一個(gè)產(chǎn)生 Latch 的代碼可以描述為:

reg   a, b ;
    reg   a_r ;

    always (@posedge clk)
        a_r  <= a ;

    always @(*) begin
        if (a_r & b)  a = 1'b1 ;   //there is no Latch
        else a = 1'b0 ;
    end

敏感信號(hào)列表不完整

如果組合邏輯中 always@() 塊內(nèi)敏感列表沒有列全,該觸發(fā)的時(shí)候沒有觸發(fā),那么相關(guān)寄存器還是會(huì)保存之前的輸出結(jié)果,因而會(huì)生成鎖存器。

這種情況,把敏感信號(hào)補(bǔ)全或者直接用 always@(*) 即可消除 Latch。

小結(jié)

總之,為避免 Latch 的產(chǎn)生,在組合邏輯中,需要注意以下幾點(diǎn):

1)if-else 或 case 語(yǔ)句,結(jié)構(gòu)一定要完整

2)不要將賦值信號(hào)放在賦值源頭,或條件判斷中

3)敏感信號(hào)列表建議多用 always@(*)

聲明:本文內(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)投訴
  • FPGA設(shè)計(jì)
    +關(guān)注

    關(guān)注

    9

    文章

    428

    瀏覽量

    26572
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5363

    瀏覽量

    120911
  • Verilog
    +關(guān)注

    關(guān)注

    28

    文章

    1351

    瀏覽量

    110240
  • 鎖存器
    +關(guān)注

    關(guān)注

    8

    文章

    907

    瀏覽量

    41589
  • 觸發(fā)器
    +關(guān)注

    關(guān)注

    14

    文章

    2002

    瀏覽量

    61284
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    CMOS的閂鎖效應(yīng):Latch up的原理分析

    電路無(wú)法正常工作,甚至燒毀電路。 Latch up是指CMOS晶片中,在電源VDD和地線GND(VSS)之間由于寄生的PNP和NPN雙極性BJT相互影響而產(chǎn)生的一低阻抗通路,它的存在會(huì)使VDD和GND之間產(chǎn)生大電流; 隨著IC制
    的頭像 發(fā)表于 12-23 16:06 ?5.7w次閱讀
    CMOS的閂鎖效應(yīng):<b class='flag-5'>Latch</b> up的原理分析

    芯片設(shè)計(jì)都不可避免的考慮要素—閂鎖效應(yīng)latch up

    閂鎖效應(yīng),latch up,是個(gè)非常重要的問題。現(xiàn)在的芯片設(shè)計(jì)都不可避免考慮它。我今天就簡(jiǎn)單地梳理一下LUP的一些問題。
    的頭像 發(fā)表于 12-01 17:11 ?3250次閱讀
    芯片設(shè)計(jì)都不可<b class='flag-5'>避免</b>的考慮要素—閂鎖效應(yīng)<b class='flag-5'>latch</b> up

    #硬聲創(chuàng)作季 【4.2】——D-LatchVerilog表述

    fpgaVerilog
    Mr_haohao
    發(fā)布于 :2022年09月08日 09:11:17

    [4.2.1]--4-2D-LatchVerilog表述

    Verilog
    李開鴻
    發(fā)布于 :2022年11月12日 14:49:30

    Latch UP

    的PNP和NPN雙極性BJT相互影響而產(chǎn)生的一低阻抗通路, 它的存在會(huì)使VDD和GND之間產(chǎn)生大電流隨著IC制造工藝的發(fā)展, 封裝密度和集成度越來(lái)越高,產(chǎn)生Latch up的可能性會(huì)越
    發(fā)表于 12-16 16:37

    GSM教你理解verilog HDL語(yǔ)言的一些概念

    表:Always過(guò)程中,所有被讀取的數(shù)據(jù),即等號(hào)右邊的變量都要應(yīng)放在敏感表中,不然,綜合時(shí)不能正確地映射到所用的門。12、IF:如果變量沒有在IF語(yǔ)句的每個(gè)分支中進(jìn)行賦值,將會(huì)產(chǎn)生latch。如果
    發(fā)表于 02-24 10:37

    Verilog綜合遇到的這樣的警告如何處理

    大家好:請(qǐng)教個(gè)問題 我是個(gè)初學(xué)者 對(duì)Verilog運(yùn)用不是很熟悉。我定義了一個(gè)輸出寄存器output reg[15:0] INT_PWM_BLOCK,當(dāng)條件滿足,把這個(gè)寄存器的第0位置0,否則為1
    發(fā)表于 03-05 15:29

    【鋯石科技】關(guān)于 Verilog HDL 語(yǔ)言的一些關(guān)鍵問題解惑【免費(fèi)下載】

    設(shè)計(jì)③ 如何給端口選擇正確的數(shù)據(jù)類型④ Verilog語(yǔ)言中latch產(chǎn)生⑤ 組合邏輯反饋環(huán)⑥ 阻塞賦值與非阻塞賦值的不同⑦ FPGA的靈魂?duì)顟B(tài)機(jī)⑧ 代碼風(fēng)格的重要性[hide][/hide]
    發(fā)表于 08-17 05:56

    寄生電路的效應(yīng):Latch-Up(鎖定)

    了解電路設(shè)計(jì)技巧之后,這種效應(yīng)已經(jīng)可以被控制了。CMOS電路之所以會(huì)產(chǎn)生Latch-Up效應(yīng),我們可以用圖2.29來(lái)表示。在圖中我們以剖面圖來(lái)看一個(gè)CMOS反相器如何發(fā)生此效應(yīng),而且它是用P型阱制造
    發(fā)表于 08-23 06:06

    請(qǐng)問Latch到底是什么

    (Address Latch Enable)。描述是這樣的,ALE是一個(gè)脈沖信號(hào),用來(lái)鎖住(Latch)AD0~AD7的地址。這里Latch又是動(dòng)詞。請(qǐng)問Latch到底是什么意思
    發(fā)表于 12-06 10:35

    Verilog基本功--flipflop和latch以及register的區(qū)別

    消耗的門資源比f(wàn)f少。但是你用的如果是 fpga,那么內(nèi)部一般帶DFF單元,反而用觸發(fā)器更好。3、latch與register的區(qū)別,為什么現(xiàn)在多用register.行為級(jí)描述中latch如何
    發(fā)表于 08-27 08:30

    怎么知道產(chǎn)生的PWM波形對(duì)不對(duì)

    前言在做嵌入式開發(fā)的過(guò)程中,不可避免的會(huì)用到PWM的功能,但是我們?cè)趺粗?b class='flag-5'>產(chǎn)生的PWM波形對(duì)不對(duì),這個(gè)時(shí)候可能就需要一臺(tái)示波器來(lái)測(cè)量一下了,但是這始終有點(diǎn)麻煩。于是我嘗試著使用STM32的定時(shí)器
    發(fā)表于 08-16 09:06

    為什么C語(yǔ)言避免使用Null指針

    為什么C語(yǔ)言避免使用Null指針?指針作為數(shù)組的應(yīng)用有哪些
    發(fā)表于 12-20 07:19

    verilog中if與case語(yǔ)句不完整產(chǎn)生鎖存器的原因分析

      在很多地方都能看到,verilog中if與case語(yǔ)句必須完整,即if加上else,case后加上default語(yǔ)句,以防止鎖存器的發(fā)生,下載內(nèi)容中就談到了其中原因。
    發(fā)表于 09-16 09:29 ?24次下載

    安全光幕避免在哪些環(huán)境下使用

    安全光幕避免在哪些環(huán)境下使用
    的頭像 發(fā)表于 06-28 14:38 ?456次閱讀
    安全光幕<b class='flag-5'>要</b><b class='flag-5'>避免</b>在哪些環(huán)境下使用
    主站蜘蛛池模板: 夜夜骑夜夜欢| 诱人的秘书BD在线观看| 琪琪午夜福利免费院| 男男h开荤粗肉h文1v1| 免费看大黄高清网站视频在线| 免费 高清 中文在线观看| 暖暖日本 在线 高清| 青青青国产依人精品视频| 色聚网久久综合| 午夜免费无码福利视频麻豆| 亚洲成人中文| 在线观看插女生免费版| 91麻豆精品| 扒开老师大腿猛进AAA片邪恶| 仓井空torrent| 国产欧美一区二区三区视频| 久久91精品国产91| 久久亚洲免费视频| 欧美亚洲日韩国码在线观看| 色综合久久久久久| 亚洲精品理论电影在线观看| 中文字幕在线观看亚洲视频| 芭乐视频免费资源在线观看| 国产免费久久精品国产传媒| 久久久精品久久久久三级| 欧美内射深插日本少妇| 视频一区二区中文字幕| 亚洲三级在线看| 99久久99久久久精品齐齐鬼色| 吃奶吸咪咪动态图| 好紧好湿太硬了我太爽了小说| 邻家美姨在线观看全集免费| 日本无码毛片久久久九色综合| 亚洲 欧美 国产 综合 在线| 在线观看中文字幕码2021不用下载| av影音先锋影院男人站| 国产精品私人玩物在线观看| 久久亚洲AV无码精品午色夜麻豆| 日本红怡院亚洲红怡院最新| 亚洲国产精品高清在线| 69日本人xxxx16—18|