鎖存器
在實際的數字系統中,通常把能夠用來存儲一組二進制代碼的同步時序邏輯電路稱爲寄存器.由於觸發器內有記憶功能,因此利用觸發器可以方便地構成寄存器。由於一個觸發器能夠存儲一位二進制碼,所以把n個觸發器的時鐘端口連接起來就能構成一個存儲n位二進制碼的寄存器。鎖存器是電平觸發的存儲單元,數據存儲的動作取決於輸入時鐘(或者使能)信號的電平值,盡當鎖存器處於使能狀態時,輸出纔會隨着數據輸入發生變化。
觸發器
觸發器是邊沿敏感的存儲單元,數據存儲的動作有某一信號的上升或者下降沿進行同步的。在實際的數字系統中,通常把能夠用來存儲一組二進制代碼的同步時序邏輯電路稱爲寄存器.由於觸發器內有記憶功能,因此利用觸發器可以方便地構成寄存器。由於一個觸發器能夠存儲一位二進制碼,所以把n個觸發器的時鐘端口連接起來就能構成一個存儲n位二進制碼的寄存器。寄存器用來存放數據的一些小型存儲區域,用來暫時存放參與運算的數據和運算結果。其實寄存器就是一種常用的時序邏輯電路,但這種時序邏輯電路只包含存儲電路。寄存器的存儲電路是由鎖存器或觸發器構成的,因爲一個鎖存器或觸發器能存儲1位二進制數,所以由N個鎖存器或觸發器可以構成N位寄存器。 觸發器是在時鐘的沿進行數據的鎖存的,而鎖存器是用電平使能來鎖存數據的。所以觸發器的Q輸出端在每一個時鐘沿都會被更新,而鎖存器只能在使能電平有效器件纔會被更新。 有一些教科書裏的觸發器實際是鎖存器。在FPGA設計中建議如果不是必須那麼應該儘量使用觸發器而不是鎖存器。
觸發器與鎖存器的比較:
1、latch由電平觸發,非同步控制。在使能信號有效時latch相當於通路,在使能信號無效時latch保持輸出狀態。DFF由時鐘沿觸發,同步控制。
2、latch對輸入電平敏感,受佈線延遲影響較大,很難保證輸出沒有毛刺產生;DFF則不易產生毛刺。
3、如果使用門電路來搭建latch和DFF,則latch消耗的門資源比DFF要少,這是latch比DFF優越的地方。所以,在ASIC中使用 latch的集成度比DFF高,但在FPGA中正好相反,因爲FPGA中沒有標準的latch單元,但有DFF單元,一個LATCH需要多個LE才能實現。latch是電平觸發,相當於有一個使能端,且在激活之後(在使能電平的時候)相當於導線了,隨輸出而變化。在非使能狀態下是保持原來的信號,這就可以看出和flip-flop的差別,其實很多時候latch是不能代替ff的。
4、latch將靜態時序分析變得極爲複雜。
5、目前latch只在極高端電的路中使用,如intel 的P4等CPU。 FPGA中有latch單元,寄存器單元就可以配置成latch單元,在xilinx v2p的手冊將該單元成爲register/latch單元,附件是xilinx半個slice的結構圖。