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

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

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

門控時鐘實(shí)現(xiàn)低功耗的原理

FPGA之家 ? 來源:FPGA之家 ? 作者:FPGA之家 ? 2022-07-03 15:32 ? 次閱讀

門控時鐘的設(shè)計(jì)初衷是實(shí)現(xiàn)FPGA的低功耗設(shè)計(jì),本文從什么是門控時鐘、門控時鐘實(shí)現(xiàn)低功耗的原理、推薦的FPGA門控時鐘實(shí)現(xiàn)這三個角度來分析門控時鐘。

一、什么是門控時鐘

門控時鐘技術(shù)(gating clock) 是通過在時鐘路徑上增加邏輯門對時鐘進(jìn)行控制,使電路的部分邏輯在不需要工作時停止時鐘樹的翻轉(zhuǎn),而并不影響原本的邏輯狀態(tài)。在ASIC和FPGA設(shè)計(jì)中都存在門控時鐘的概念(前者應(yīng)用更廣)。

典型的門控時鐘邏輯如下圖所示:

ccc5e538-ef76-11ec-ba43-dac502259ad0.png

二、門控時鐘降低功耗的原理

1. FPGA功耗分類

靜態(tài)功耗:靜態(tài)功耗又叫泄漏功耗,它是指電路處于等待或不激活狀態(tài)時-泄漏電流所產(chǎn)生的功耗。通常由FPGA制造工藝的優(yōu)化而提升。同一代的FPGA產(chǎn)品中,也有專門的低功耗版本(譬如Intel開發(fā)的Cyclone10 GX與Cyclone 10 LP,后者為低功耗版本low power但前者性能更強(qiáng))??梢栽贔PGA選型時加以考慮。

動態(tài)功耗:是指電容充放電功耗和短路功耗,是由電路的翻轉(zhuǎn)造成的。FPGA中的動態(tài)功耗主要體現(xiàn)在元件的電平翻轉(zhuǎn)時對負(fù)載電容的充放電及時鐘的翻轉(zhuǎn)。

2. 為什么門控時鐘可以降低功耗

當(dāng)系統(tǒng)中某模塊電路完成既定任務(wù)后(譬如TDC中對BIN的標(biāo)定等初始化類任務(wù)),通過門控時鐘使能信號的控制,使得驅(qū)動該模塊的時鐘停止翻轉(zhuǎn),相應(yīng)的時序元件不再更新,那么其間的組合邏輯也恢復(fù)到靜態(tài)。此時該模塊的功耗相當(dāng)于靜態(tài)功耗,從而降低了整個系統(tǒng)的功耗。

三、不合理的門控時鐘設(shè)計(jì)

1.偽門控時鐘

如下圖所示,設(shè)計(jì)中有意識地使用使能信號,意圖維持寄存器的數(shù)據(jù)。但是僅對寄存器組的數(shù)據(jù)輸入端添加選擇器和使能信號,并不妨礙寄存器組時鐘輸入端的翻轉(zhuǎn),輸出維持不變只是因?yàn)榇嬖诜答伝芈吩诓粩嗟倪M(jìn)行使能判斷、輸出、使能判斷、輸出的循環(huán)。實(shí)則并沒有起到低功耗的作用。

ccd78e00-ef76-11ec-ba43-dac502259ad0.png

當(dāng)然某些情況下確實(shí)需要用到這種設(shè)計(jì),此處僅用來和門控時鐘做區(qū)分,避免混淆。

2.直接門控時鐘

將使能信號直接連接在AND門,結(jié)構(gòu)簡單。不足之處在于產(chǎn)生使能信號的組合邏輯的毛刺將完全地反應(yīng)到AND門,造成門控時鐘輸出質(zhì)量變差(clk_en將會有占空比不良和毛刺等情況)。

ccdfd1a0-ef76-11ec-ba43-dac502259ad0.png

四、推薦的門控時鐘設(shè)計(jì)

1.基于鎖存器的門控時鐘

鎖存器是電平敏感的元件,此圖中當(dāng)CLK信號為低電平時,鎖存器透明,EN端數(shù)據(jù)直接傳輸至AND門的一端(ENL),AND門另一端連接CLK。

cceea9b4-ef76-11ec-ba43-dac502259ad0.png

當(dāng)產(chǎn)生使能信號的組合邏輯不復(fù)雜時,產(chǎn)生使能信號的時間小于半個時鐘周期。在CLK高電平時,鎖存器的引入有效地過濾了前段組合邏輯競爭冒險產(chǎn)生的毛刺;在時鐘低電平時,前段組合邏輯的毛刺將受到AND門控制將無法輸出。較好地實(shí)現(xiàn)了門控時鐘的要求。

ccfe36ea-ef76-11ec-ba43-dac502259ad0.png

當(dāng)產(chǎn)生使能信號的組合邏輯復(fù)雜時,產(chǎn)生使能信號的時間大于半個時鐘周期。考慮鎖存器的延時,那么對于首個ENCLK周期而言,占空比將被削減;當(dāng)EN信號拉低時,則有可能產(chǎn)生毛刺。均不利于后續(xù)寄存器組的時序過程。

cd07b300-ef76-11ec-ba43-dac502259ad0.png

這種情況難以通過在鎖存器前端加同步寄存器避免,因?yàn)榇藭r的使能信號是不滿足寄存器的建立時間的,大概率會產(chǎn)生亞穩(wěn)態(tài)現(xiàn)象。因此產(chǎn)生門控使能信號的組合邏輯應(yīng)當(dāng)盡可能簡化,保證在半個時鐘周期之內(nèi)得到穩(wěn)定電平。

保險起見,一方面,保證使能信號半周期確定;另一方面,在鎖存器之前加一級上升沿觸發(fā)的寄存器,過濾輸入鎖存器的信號。

2.基于寄存器的門控時鐘

上面介紹的基于鎖存器的門控時鐘實(shí)際上更適合在ASIC中實(shí)現(xiàn),一方面FPGA中沒有專門的鎖存器資源,需要利用其中的組合邏輯資源外加寄存器來等效地實(shí)現(xiàn),不經(jīng)濟(jì);另一方面,鎖存器本身的特性沒法進(jìn)行靜態(tài)時序分析,出問題了不易排查。

真正適合在FPGA中實(shí)現(xiàn)的是基于寄存器的門控時鐘,如下圖所示。

cd1ae2c2-ef76-11ec-ba43-dac502259ad0.png

前段使用加法器產(chǎn)生計(jì)數(shù)值,通過比較器產(chǎn)生使能信號,送入使能寄存器。值得注意的是,前端產(chǎn)生使能邏輯時序元件是上升沿觸發(fā),而使能寄存器是下降沿觸發(fā)。如此一來,同樣需要滿足產(chǎn)生使能信號的組合邏輯簡單這一前提要求(半周期內(nèi)達(dá)到en寄存器的建立時間)。好處在于,AND門時時刻刻都只有一個輸入在變,不容易產(chǎn)生毛刺。時序圖如下:

cd27eb48-ef76-11ec-ba43-dac502259ad0.png

為了便于理解,此處給出若使能寄存器也是上升沿觸發(fā)的時序圖:

cd340392-ef76-11ec-ba43-dac502259ad0.png

可見,AND門變化時兩個個輸入在變,容易產(chǎn)生毛刺。

五、討論

只有當(dāng)FPGA工程需要大量降低功耗時才有必要引入門控時鐘,若必須引入門控時鐘,則推薦使用基于寄存器的門控時鐘設(shè)計(jì)。

在時鐘樹的枝干處使用門控,而不是在枝丫處使用門控。

使用門控時,應(yīng)該注意時鐘的質(zhì)量(使用專用時鐘網(wǎng)絡(luò)),畢竟好的時鐘才能產(chǎn)生好的使能信號和門控時鐘信號。同時,產(chǎn)生使能信號的邏輯不能太復(fù)雜,確保可以滿足使能寄存器的建立時間和保持時間。

與或門控輸出的時鐘信號,需要在timeanalyzer中設(shè)置為base clock。否則將會引入人為的時鐘偏斜。如下,將會以沒有使能寄存器的門控路徑作為最短分析路徑,以有寄存器的路徑作為最長路徑分析。

cd40e1de-ef76-11ec-ba43-dac502259ad0.png

In certain cases, converting the gated clocks to clock enables may help reduce glitch and clock skew, and eventually produce a more accurate timing analysis. You can set the Quartus II software to automatically convert gated clocks to clock enables by turning on the Auto Gated Clock Conversion (在綜合的設(shè)置里面)option. The conversion applies to two types of gated clocking schemes: single-gated clock and cascaded-gated clock

類似地,產(chǎn)生門控時鐘信號最好只有一個兩輸入AND門(OR門)。附加邏輯越多,產(chǎn)生毛刺可能性越大。

原文標(biāo)題:四、推薦的門控時鐘設(shè)計(jì)

文章出處:【微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

    關(guān)注

    1624

    文章

    21538

    瀏覽量

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

    關(guān)注

    31

    文章

    5268

    瀏覽量

    119646
  • 門控時鐘
    +關(guān)注

    關(guān)注

    0

    文章

    27

    瀏覽量

    8924

原文標(biāo)題:四、推薦的門控時鐘設(shè)計(jì)

文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    射頻識別芯片設(shè)計(jì)中時鐘功耗的優(yōu)化與實(shí)現(xiàn)

    TypeC協(xié)議的UHF RFID標(biāo)簽基帶處理器的的優(yōu)化和實(shí)現(xiàn)。##降低功耗主要方法##RTL階段手工加時鐘門控##綜合階段工具插于集成門控
    發(fā)表于 03-24 14:36 ?4231次閱讀

    XOR自門控時鐘門控的不同之處

    時鐘XOR自門控(Self Gating)基本思路和時鐘門控類似,都是當(dāng)寄存器中的數(shù)據(jù)保持不變時,通過關(guān)閉某些寄存器的時鐘信號來降低設(shè)計(jì)的動
    的頭像 發(fā)表于 01-02 11:34 ?1345次閱讀
    XOR自<b class='flag-5'>門控</b>與<b class='flag-5'>時鐘</b><b class='flag-5'>門控</b>的不同之處

    行為邏輯層次低功耗設(shè)計(jì)

    層次設(shè)計(jì)摘要:由于集成電路的集成度增大導(dǎo)致功耗成倍增長,但是在整個電路的設(shè)計(jì)中還是有很多辦法來降低整個系統(tǒng)功耗。本文主要從嵌入式處理器的行為邏輯層次上來闡述如何降低功耗,包括采用超標(biāo)量結(jié)構(gòu),采用
    發(fā)表于 05-16 20:00

    基于門控時鐘低功耗時序電路設(shè)計(jì)

    可根據(jù)分頻因子(范圍為8至38)進(jìn)行編程,按提供給計(jì)數(shù)器組合邏輯的輸入所配置的提供一系列輸出頻率?! 〖词勾擞?jì)數(shù)器中配備了額外的硬件來實(shí)現(xiàn)可編程性,但是該電路的功耗通過一個邏輯提供的有效門控
    發(fā)表于 09-30 16:00

    什么是時鐘門控?如何去實(shí)線時鐘門控的設(shè)計(jì)呢

    什么是時鐘門控?有幾個因素會影響電路的功耗。邏輯門具有靜態(tài)或泄漏功率,只要對其施加電壓,該功率大致恒定,并且它們具有由切換電線產(chǎn)生的動態(tài)或開關(guān)功率。Flip-flop觸發(fā)器非常耗電,大約占總功率
    發(fā)表于 12-19 17:09

    基于門控時鐘的CMOS電路低功耗設(shè)計(jì)

    闡述了如何運(yùn)用門控時鐘來進(jìn)行CMOS電路的低功耗設(shè)計(jì)。分析了門控時鐘實(shí)現(xiàn)方式,如何借助EDA工
    發(fā)表于 11-19 11:49 ?22次下載

    基于門控時鐘低功耗電路設(shè)計(jì)方案

    在眾多低功耗技術(shù)中,門控時鐘對翻轉(zhuǎn)功耗和內(nèi)部功耗的抑制作用最強(qiáng)。本文主要講述門控
    發(fā)表于 02-21 09:31 ?3421次閱讀
    基于<b class='flag-5'>門控</b><b class='flag-5'>時鐘</b>的<b class='flag-5'>低功耗</b>電路設(shè)計(jì)方案

    應(yīng)用于片上系統(tǒng)中低功耗IP核設(shè)計(jì)的自適應(yīng)門控時鐘技術(shù)

    摘要:門控時鐘技術(shù)一直以來是降低芯片動態(tài)功耗的有效方法,文章結(jié)合片上系統(tǒng)(SOC)的結(jié)構(gòu)特性和設(shè)計(jì)特點(diǎn),分析已有的各種門控時鐘技術(shù)的優(yōu)缺點(diǎn),
    發(fā)表于 02-23 13:53 ?36次下載

    低功耗時鐘門控算術(shù)邏輯單元在不同F(xiàn)PGA中的時鐘能量分析

    低功耗時鐘門控算術(shù)邏輯單元在不同F(xiàn)PGA中的時鐘能量分析
    發(fā)表于 11-19 14:50 ?0次下載

    通常有兩種不同的時鐘門控實(shí)現(xiàn)技術(shù)

    constrained,mobile端不能夠充更多的電就只能盡可能地降低功耗了(無法開源只能節(jié)流呀),也因?yàn)?b class='flag-5'>時鐘門控是降低芯片動態(tài)功耗最簡單,最常用的方法之一。
    的頭像 發(fā)表于 06-13 16:48 ?2554次閱讀

    什么是門控時鐘 門控時鐘低功耗的原理

    門控時鐘的設(shè)計(jì)初衷是實(shí)現(xiàn)FPGA的低功耗設(shè)計(jì),本文從什么是門控時鐘、
    的頭像 發(fā)表于 09-23 16:44 ?1.3w次閱讀
    什么是<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>的原理

    什么是門控時鐘?如何生成門控時鐘?

    由于門控時鐘邏輯具有一定的開銷,因此數(shù)據(jù)寬度過小不適合做clockgating。一般情況下,數(shù)據(jù)寬度大于8比特時建議采用門控時鐘。
    發(fā)表于 12-05 12:28 ?2970次閱讀

    FPGA原型驗(yàn)證系統(tǒng)的時鐘門控

    門控時鐘是一種在系統(tǒng)不需要動作時,關(guān)閉特定塊的時鐘的方法,目前很多低功耗SoC設(shè)計(jì)都將其用作節(jié)省動態(tài)功率的有效技術(shù)。
    的頭像 發(fā)表于 04-20 09:15 ?1138次閱讀

    門控時鐘低功耗在Placement階段有什么技巧?

    門控時鐘技術(shù)可以用來降低電路的動態(tài)功耗,且在一定程度上能減小電路的面積。
    的頭像 發(fā)表于 06-29 16:45 ?1155次閱讀
    <b class='flag-5'>門控</b><b class='flag-5'>時鐘</b><b class='flag-5'>低功耗</b>在Placement階段有什么技巧?

    FSMs低功耗設(shè)計(jì)

    低功耗設(shè)計(jì)是當(dāng)下的需要!這篇文章:低功耗設(shè)計(jì)方法論的必要性讓我們深入了解了現(xiàn)代設(shè)計(jì)的意圖和對功耗感知的需求。在低功耗方法標(biāo)簽下的時鐘
    的頭像 發(fā)表于 10-17 10:41 ?610次閱讀
    FSMs<b class='flag-5'>低功耗</b>設(shè)計(jì)