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

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

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

復(fù)位消抖電路具體長(zhǎng)什么樣子呢?

冬至子 ? 來(lái)源:芯時(shí)代青年 ? 作者:尼德蘭的喵 ? 2023-12-04 14:53 ? 次閱讀

復(fù)位信號(hào)在使用前一般需要進(jìn)行消抖處理,也稱(chēng)為復(fù)位濾毛刺。復(fù)位的抖動(dòng)可能會(huì)導(dǎo)致芯片產(chǎn)生多次復(fù)位動(dòng)作,給系統(tǒng)帶來(lái)不確定性和誤差。消抖的目的是為了確保復(fù)位信號(hào)的穩(wěn)定性和可靠性,從而保證系統(tǒng)能夠正常工作。

通過(guò)消抖,可以消除復(fù)位信號(hào)的抖動(dòng)干擾,保證復(fù)位信號(hào)的可靠性和穩(wěn)定性,避免系統(tǒng)故障和數(shù)據(jù)丟失等問(wèn)題。

舉個(gè)例子,如果要消除30ns以下的復(fù)位抖動(dòng),那么30ns以下的復(fù)位信號(hào)rst_n拉低操作就會(huì)被消抖電路消除,不會(huì)對(duì)電路產(chǎn)生任何的影響,只有30ns以上的復(fù)位拉低操作才能作用于內(nèi)部電路。

所以復(fù)位消抖電路具體長(zhǎng)什么樣子呢?目前我了解的有三種方式,不過(guò)因?yàn)闆](méi)有實(shí)際參與過(guò)CRG模塊的設(shè)計(jì)與流片,所以以下內(nèi)容只做參考。我們假定濾毛刺時(shí)鐘為100M,需要濾除的復(fù)位抖動(dòng)為30ns以下的信號(hào)。

第一種方式通過(guò)濾毛刺時(shí)鐘+D觸發(fā)器來(lái)完成 ,如要濾過(guò)30ns的抖動(dòng)電路圖如下:

圖片

D觸發(fā)器的數(shù)量關(guān)系是如何得到的呢?先假設(shè)我只有一個(gè)延時(shí)D觸發(fā)器,那么復(fù)位信號(hào)必須維持L電平在一個(gè)clk時(shí)鐘周期以上或門(mén)才能在時(shí)鐘沿處打出一個(gè)L信號(hào)出來(lái)(即時(shí)鐘上升沿時(shí)rst_n || rst_n_ff1 == 1'b0),如下面的波形圖所示:

圖片

同樣的,如果有兩個(gè)延時(shí)D觸發(fā)器,那么復(fù)位信號(hào)必須維持L電平在兩個(gè)clk時(shí)鐘周期以上,或門(mén)才能在時(shí)鐘沿處打出一個(gè)L信號(hào)出來(lái):

圖片

如果有三個(gè)延時(shí)D觸發(fā)器,那么復(fù)位信號(hào)必須維持L電平在三個(gè)clk時(shí)鐘周期以上,或門(mén)才能在時(shí)鐘沿處打出一個(gè)L信號(hào)出來(lái):

圖片

因此,在或們前放置了N個(gè)延時(shí)D觸發(fā)器,就可以濾除N*T(T為消抖時(shí)鐘的周期)時(shí)長(zhǎng)以下的復(fù)位毛刺信號(hào)。這種方式存在一個(gè)巨大隱患,消抖時(shí)鐘信號(hào)是不受復(fù)位控制的,一旦消抖時(shí)鐘信號(hào)出了什么問(wèn)題,復(fù)位信號(hào)將永遠(yuǎn)無(wú)法從消抖電路傳遞出去。

第二種方式通過(guò)累加器來(lái)完成, 簡(jiǎn)單來(lái)說(shuō)就是數(shù)一下rst_n連續(xù)出現(xiàn)了多少拍,假如需要通過(guò)100M消抖時(shí)鐘來(lái)濾除100ns以下的復(fù)位抖動(dòng),那么rst_n要連續(xù)出現(xiàn)10拍低電平才達(dá)到100ns的復(fù)位標(biāo)準(zhǔn)。將rst_n打兩拍rst_n_ff1/rst_n_ff2消除亞穩(wěn)態(tài),當(dāng)rst_n_ff2持續(xù)達(dá)到10拍對(duì)外輸出復(fù)位信號(hào),對(duì)應(yīng)的波形示意如下:

圖片

簡(jiǎn)單的代碼示意如下:

reg rst_n_ff1, rst_n_ff2;
reg [3:0]vcnt_100m;

always @(posedge clk_100m) begin
    rst_n_ff1 <= rst_n;
    rst_n_ff2 <= rst_n_ff1;
end

wire vcnt_100m_clr = (rst_n_ff1 != rst_n_ff2);

always@(posedge clk_100m) begin
   if(vcnt_100m_clr)
       vcnt_100m <= 4'h0;
   else if(!rst_n_ff2)
       vcnt_100m <= vcnt_100m + 1'b1;
end

always@(posedge clk_100m) begin
    rst_100m_n <= (!rst_n_ff2 & vcnt_100m >=4'd9) ? 1'b0 : 1'b1;
end

這個(gè)消抖方案呢同樣存在上面的問(wèn)題,消抖時(shí)鐘信號(hào)是不受復(fù)位控制的,所以在芯片內(nèi)的模塊級(jí)別可能會(huì)被采用,但是在外部復(fù)位消抖時(shí)是一般不會(huì)使用的。

第三種方式是通過(guò)延時(shí)器件來(lái)實(shí)現(xiàn) ,要濾去100ns以下毛刺,那么就引入100ns延時(shí)器件,組成如下電路:

圖片

對(duì)應(yīng)的波形也很簡(jiǎn)單:

圖片

通過(guò)波形可以看出,如果復(fù)位時(shí)長(zhǎng)不夠100ns,prst_n根本不會(huì)被觸發(fā)。這個(gè)電路的隱患在于如何保證延時(shí)器件在不同溫度等外部環(huán)境干擾下的延時(shí)準(zhǔn)確性。

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(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)投訴
  • D觸發(fā)器
    +關(guān)注

    關(guān)注

    3

    文章

    164

    瀏覽量

    47827
  • 延時(shí)器
    +關(guān)注

    關(guān)注

    1

    文章

    36

    瀏覽量

    15074
  • CLK
    CLK
    +關(guān)注

    關(guān)注

    0

    文章

    127

    瀏覽量

    17103
  • 累加器
    +關(guān)注

    關(guān)注

    0

    文章

    50

    瀏覽量

    9436
  • 消抖電路
    +關(guān)注

    關(guān)注

    0

    文章

    6

    瀏覽量

    8578
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    單片機(jī)的按鍵與幾種按鍵電路

    按鍵電路 一、 硬件 : 按鍵防電路控制電路 所示利用RC 積分
    的頭像 發(fā)表于 12-17 07:45 ?10.6w次閱讀
    單片機(jī)的按鍵<b class='flag-5'>消</b><b class='flag-5'>抖</b>與幾種按鍵<b class='flag-5'>電路</b>

    異步復(fù)位同步撤離是什么意思?如何做到異步復(fù)位同步撤離?

    復(fù)位之后的下一件事,[異步復(fù)位]()同步撤離。這句話什么意思?
    的頭像 發(fā)表于 12-04 13:57 ?4559次閱讀
    異步<b class='flag-5'>復(fù)位</b>同步撤離是什么意思?如何做到異步<b class='flag-5'>復(fù)位</b>同步撤離<b class='flag-5'>呢</b>?

    按鍵

    請(qǐng)問(wèn)大家的按鍵是用什么方法解決的,如普通的按鍵如何。按鍵和數(shù)碼管接的端口是相同的,如何解決按鍵
    發(fā)表于 09-26 22:17

    技術(shù)分享:明德?lián)P按鍵的原理和基于fpga的設(shè)計(jì)

    本帖最后由 明德?lián)P吳老師 于 2017-8-2 11:45 編輯 按鍵1功能概述按鍵開(kāi)關(guān)是各種電子設(shè)備不可或缺的人機(jī)接口,如電腦的鍵盤(pán)等。實(shí)際應(yīng)用中,按鍵開(kāi)關(guān)通常為機(jī)械式彈性開(kāi)關(guān)。當(dāng)機(jī)械點(diǎn)
    發(fā)表于 08-02 10:38

    電路的傳輸特性會(huì)變成什么樣子?

    記得是從剛剛學(xué)模電的時(shí)候開(kāi)始,每次看到一個(gè)運(yùn)放電路,就會(huì)想,如果把這個(gè)電路的同相輸入端和反向輸入端換一下,那么電路的傳輸特性會(huì)變成什么樣子
    發(fā)表于 02-26 08:39

    請(qǐng)問(wèn)怎樣去設(shè)計(jì)一種按鍵電路

    按鍵電路結(jié)構(gòu)與電路模型按鍵電路數(shù)學(xué)模型按鍵
    發(fā)表于 04-29 06:13

    軟件電路中存在的不足是什么?

    什么是電路?軟件電路中存在的不足是什么?按鍵
    發(fā)表于 05-06 07:50

    51單片機(jī)_獨(dú)立按鍵延時(shí)

    51單片機(jī)_獨(dú)立按鍵延時(shí)_獨(dú)立按鍵定時(shí)器_矩陣鍵盤(pán)定時(shí)器1.獨(dú)立按鍵_延時(shí)
    發(fā)表于 07-16 13:56

    MCU按鍵問(wèn)題

    按鍵問(wèn)題機(jī)械按鍵是必須的,1、延時(shí)//按鍵處理函數(shù)//返回按鍵值//mode:0,不
    發(fā)表于 11-04 06:37

    有什么方法去實(shí)現(xiàn)按鍵的

    怎樣用軟件即程序來(lái)實(shí)現(xiàn)按鍵的?有什么方法去實(shí)現(xiàn)按鍵的?
    發(fā)表于 12-15 07:25

    MCU對(duì)按鍵長(zhǎng)按的檢測(cè)是否要

    MCU對(duì)按鍵長(zhǎng)按的檢測(cè),是否要
    發(fā)表于 10-13 08:14

    按鍵都有哪些處理方式?

    按鍵都有哪些處理方式除了硬件電路用軟件怎么實(shí)現(xiàn)
    發(fā)表于 11-01 07:06

    基于FPGA的按鍵電路設(shè)計(jì)

    采用了VHDL語(yǔ)言編程的設(shè)計(jì)方法,通過(guò)FPGA來(lái)實(shí)現(xiàn)按鍵的硬件電路。論述了基于計(jì)數(shù)器、RS觸發(fā)器和狀態(tài)機(jī)3種方法來(lái)實(shí)現(xiàn)按鍵
    發(fā)表于 12-05 14:13 ?224次下載

    VHDL—按鍵

    達(dá)到去抖動(dòng)的目的。本例中用狀態(tài)機(jī)實(shí)現(xiàn)了電路:端口描述:clk 輸入檢測(cè)時(shí)鐘;reset 復(fù)位信號(hào);din 原始按鍵信號(hào)輸入; dout 去抖動(dòng)輸出信號(hào)。
    發(fā)表于 11-11 17:17 ?2次下載

    鍵盤(pán)電路VHDL程序

    鍵盤(pán)電路VHDL程序,感興趣的小伙伴們可以瞧一瞧。
    發(fā)表于 11-11 15:51 ?1次下載