<abbr id="kc8ii"><menu id="kc8ii"></menu></abbr>
  • <input id="kc8ii"><tbody id="kc8ii"></tbody></input><table id="kc8ii"><source id="kc8ii"></source></table><kbd id="kc8ii"></kbd>
    <center id="kc8ii"><table id="kc8ii"></table></center>
  • <input id="kc8ii"></input>
    <abbr id="kc8ii"></abbr>
  • <abbr id="kc8ii"></abbr>
  • <center id="kc8ii"><table id="kc8ii"></table></center>
    <abbr id="kc8ii"></abbr>
    你的位置:首頁 > 電路保護 > 正文

    FPGA設計異步復位同步釋放有講究

    發(fā)布時間:2017-01-23 責任編輯:susan

    【導讀】異步復位同步釋放,首先要說一下同步復位與異步復位的區(qū)別。同步復位是指復位信號在時鐘的上升沿或者下降沿才能起作用,而異步復位則是即時生效,與時鐘無關。異步復位的好處是速度快。再來談一下為什么FPGA設計中要用異步復位同步釋放。

    復位信號的釋放是有講究的:
     
    我們知道,DFF的D端和clk端之間時序關系是有約束的,這種約束我們通過setup time和hold time來 check。即D端的data跳變的時刻要與clk端的時鐘上升沿(或者下降沿)跳變要錯開,如果這兩個跳變撞到一起,我們無法保證DFF能夠sample到正確的data,這時候不滿足setup/hold time要求,就會發(fā)生亞穩(wěn)態(tài),我們sample到的data可能是不穩(wěn)定的中間態(tài)的值,并不是我們原本想要的data。
     
     
    與此類似,異步復位端與clk端之間也存在著類似的時序約束關系,為了準確穩(wěn)定地sample到異步復位端的reset信號,我們要求reset信號在clk上升沿(或者下降沿)跳變的前后一段時間內保持穩(wěn)定,不要跳變。clk跳變沿之前必須保持穩(wěn)定的最短時間叫做recovery time,clk跳變沿之后需要保持穩(wěn)定的最短時間叫做removal time。如果在此時間窗口內reset信號發(fā)生跳變,不確定reset到底有沒有釋放成功(類似setup+hold時間窗口內,data跳變,發(fā)生亞穩(wěn)態(tài),sample到的值是不穩(wěn)定的中間態(tài)值)。
     
    在IC設計過程中我們是會check recovery和removal time的,如果不滿足,我們會通過布局布線的調整(后端的調整)讓電路滿足這個條件(實質就是讓reset跳變沿和clk跳變沿錯開);但是對于FPGA設計而言,我們一般不采用異步釋放的方法,因為FPGA的布局布線可以調整的空間不大,相對于IC設計,F(xiàn)PGA后端的布局布線基本上是tool自己搞定,所以我們很難調整布局布線以滿足這個條件,所以我們一般就會直接用異步復位同步釋放的方法來讓reset跳變沿和clk跳變沿錯開。
     
    最后再說一下同步數(shù)字電路的setup/hold timing check的實質。
     
    同步數(shù)字電路的基本單元就是兩級DFF,中間是一堆組合邏輯,data就是在clk一拍一拍的控制下,逐漸向后面?zhèn)鬟f,當然,在傳遞的過程中,通過組合邏輯實現(xiàn)數(shù)據(jù)的處理與轉換;但是物理世界里面,組合邏輯一定是有毛刺的,比如說data通過一系列的處理之后準備通過DFF傳遞到下一個單元的時候,你怎么能保證第二級DFF采到的值是處理完畢穩(wěn)定可靠的data,而不是還處于中間態(tài)的data?!(舉個例子,假設我們這里的data是一個8bit的bus信號,處理之前是1111_0000,通過組合邏輯處理完之后我們期望變成1111_1111;我們知道后面4個bit由0變1是需要時間的,由于布局布線的緣故,這4bit不可能在同一個時刻齊刷刷的同時由0變1,肯定是有的bit先變1,有的bit后變1;也就是在由1111_0000變成1111_1111的過程中,可能會存在1111_1000/1111_1100/1111_1101/...等等這樣的中間態(tài)數(shù)據(jù),我們不能在data還處于中間態(tài)的時候就去sample它,否則得到的不是我們預期的值,會引起整個芯片的邏輯錯誤)。
     
    我們實際上是通過setup/hold time來保證的,即:如果電路中所有DFF的setup/hold time都能夠滿足,表示data到達D端的時間比clk跳變沿時刻超過了setup時間(反之,如果data在setup+hold時間窗口內還在變化,一定會有setup/hold timing vio),這樣,我們通過check 所有DFF的setup/hold timing來間接地保證所有DFF采到的值都是經過組合邏輯處理并且處理完畢之后穩(wěn)定可靠的值。(更確切的說,通過hold timing check來保證sample到的值是經過組合邏輯處理之后的值而不是上一筆的data,通過setup time來保證sample到的是經過組合邏輯處理完畢之后并且穩(wěn)定下來的值)。

    特別推薦
    技術文章更多>>
    技術白皮書下載更多>>
    熱門搜索
    ?

    關閉

    ?

    關閉

    成人无码视频97免费| 国产成人无码一区二区在线观看| 中文无码字慕在线观看| 亚洲av无码成人精品区| 人妻少妇偷人精品无码| 久久午夜无码鲁丝片秋霞 | 亚洲精品无码专区在线在线播放| 亚洲欧美日韩中文在线制服| 国产午夜精品无码| 亚洲av无码专区在线播放| 三上悠亚ssⅰn939无码播放| 最近中文字幕mv免费高清视频8| 中文在线天堂网WWW| 蜜臀AV无码国产精品色午夜麻豆 | 免费A级毛片无码A∨| 最新中文字幕AV无码不卡| 无码av中文一二三区| 婷婷综合久久中文字幕| 熟妇人妻不卡中文字幕| 亚洲中文字幕无码一去台湾| 久久精品?ⅴ无码中文字幕| 99无码人妻一区二区三区免费| 人妻夜夜添夜夜无码AV| 无码人妻久久一区二区三区免费| 亚洲精品无码久久久久sm| 亚洲精品无码成人AAA片| 中文字幕无码日韩专区免费| 久久久无码精品亚洲日韩蜜臀浪潮| 性无码专区一色吊丝中文字幕| 最近免费最新高清中文字幕韩国 | 中文字幕精品久久久久人妻| 精品久久久久中文字幕一区| 最近中文国语字幕在线播放视频 | 中文字幕视频在线免费观看| 无码人妻精品中文字幕免费东京热 | 国产丰满乱子伦无码专区 | 无码国产精品一区二区免费vr| 无码人妻精品一区二区三区99仓本 | 日韩中文在线视频| 视频二区中文字幕| 日本爆乳j罩杯无码视频|