靜態隨機存取記憶體(static random-access memory, SRAM,中國大陸譯靜態隨機存儲器[1],又稱靜態RAM[2],台灣譯靜態隨機存取記憶體),是隨機存取記憶體的一種。所謂「靜態」,是指這種記憶體只要保持通電,儲存的資料就可以恆常保持[3]。相對之下,動態隨機存取記憶體(DRAM)裏面所儲存的資料就需要週期性地更新。然而,當電力供應停止時,SRAM儲存的資料還是會消失(被稱為揮發性記憶體),這與在斷電後還能儲存資料的ROM或快閃記憶體是不同的。
此條目翻譯質素不佳。 |
設計
SRAM由儲存矩陣、地址譯碼器和讀/寫控制電路組成,容量的擴充有兩個方面:位數的擴充用晶片的並聯,字數的擴充可用外加譯碼器控制晶片的片選輸入端[4]。SRAM中的每一bit儲存在由4個場效電晶體(M1, M2, M3, M4)構成兩個交叉耦合的反相器中。另外兩個場效電晶體(M5, M6)是儲存基本單元到用於讀寫的位元線(Bit Line)的控制開關。
反相器是一種電路元件,其輸出是輸入的邏輯非。如圖所示的CMOS靜態反相器,由兩個互補的金氧半導體場效電晶體(MOSFET)組成,源極連接在高電位的是P溝道場效電晶體,源極連接在低電位的是N溝道場效電晶體。輸入電路接在兩個場效電晶體的柵極上,輸出電路從兩個場效電晶體的連接處接出。當輸入低電位,則P溝道場效電晶體導通,N溝道場效電晶體關閉,輸出高電位。當輸入高電位,則N溝道場效電晶體導通,P溝道場效電晶體關閉,輸出低電位。這就實現了「反相」輸出。
一個SRAM基本單元有0 和 1兩個電位穩定狀態。SRAM基本單元由兩個CMOS反相器組成。兩個反相器的輸入、輸出交叉連接,即第一個反相器的輸出連接第二個反相器的輸入,第二個反相器的輸出連接第一個反相器的輸入。這就能實現兩個反相器的輸出狀態的鎖定、儲存,即儲存了1個位元的狀態。
除了6電晶體的SRAM,其他SRAM還有8電晶體、10電晶體甚至每個位元使用更多的電晶體的實作。[5][6][7]這可用於實現多埠(port)的讀寫存取,如顯示記憶體或者暫存器檔案的多口SRAM電路的實現。
一般說來,每個基本單元用的電晶體數量越少,其佔用面積就越小。由於矽晶片(silicon wafer)的生產成本是相對固定的,因此SRAM基本單元的面積越小,在矽晶片上就可以製造更多的位元儲存,每位元儲存的成本就越低。
主記憶體基本單元使用少於6個電晶體是可能的—如3電晶體[8][9]甚至單電晶體,但單電晶體儲存單元是DRAM,不是SRAM。
存取SRAM時,字元線(Word Line)加高電位,使得每個基本單元的兩個控制開關用的電晶體M5與M6導通,把基本單元與位元線(Bit Line)連通。位元線用於讀取或寫入基本單元的儲存的狀態。雖然不是必須兩條反相的位元線,但是這種反相的位元線有助於改善雜訊容許值.
與動態記憶體(DRAM)相比,SRAM的頻寬有很大改進—由於兩條位元線是反相,這種差分訊號使得SRAM的抗雜訊干擾能力很強。而DRAM的位元線連接到儲存電容,受困於電荷共用(charge sharing)使得其位元線訊號上下波動。另一項差別使得SRAM更快是其位址線各位元是同時工作選擇出目標儲存單元的字元線,而DRAM往往為了降低成本,是先送出低半段的位址線的各位元,然後再送出高半段的位址線的各bit,這降低了DRAM封裝的位址引腳的數量。
有m條位址線與n條資料線的SRAM,其儲存容量是2m個字元(word),2m×nbit.每個字元的長度至少是64bit。
SRAM操作
SRAM的基本單元有3種狀態:電路處於閒置(standby) 、讀取(reading)與寫入(writing)。SRAM的讀取或寫入模式必須分別具有可讀(readability)與寫入穩定(write stability)。
- 閒置
如果字元線沒有被選為高電位,那麼作為控制用的M5與M6兩個電晶體處於斷路,把基本單元與位元線隔離。由M1 – M4組成的兩個反相器繼續保持其狀態,只要保持與高、低電位的連接。
- 讀取
假定儲存的內容為1,即在Q處的電位為高。讀取周期開始時,兩條位元線初始值為邏輯1,隨後字元線WL提高電位,使得兩個存取控制電晶體M5與M6通路。第二步是儲存在Q的值與位元線BL的初始值相同,所以BL保持邏輯1,而Q與BL的初始值不同,使得BL經由M1與M5放電而變成邏輯0(即Q的高電位使得電晶體M1通路)。在位元線BL一側,電晶體M4與M6通路,把位元線連接到VDD所代表的邏輯1(M4作為P溝道場效電晶體,由於柵極加了Q的低電位而M4通路)。如果儲存的內容為0,相反的電路狀態將會使BL為1而BL為0。只需要BL與BL有一個很小的電位差,讀取的放大電路將會辨識出哪條位元線是1哪條是0。敏感度越高,讀取速度越快。
- 寫入
寫入周期開始時,把要寫入的狀態載入到位元線。如果要寫入0,則設置BL為1且BL為0。隨後字元線WL載入為高電位,位元線的狀態被載入SRAM的基本單元。這是透過位元線輸入驅動能力設計的比基本單元相對較弱的電晶體更為強壯,使得位元線狀態可以覆蓋基本單元交叉耦合的反相器的以前的狀態。
存取時間為70ns的RAM在地址設置完成且有效之後,會在70ns之內將資料輸出。資料將繼續保持有效約5-10ns。起、落時間將影響有效時間槽(timeslot)約5ns。如果先讀入低半段地址,將會多耗費30ns[10]。
應用與使用
SRAM是比DRAM更為昂貴,但更為快速、非常低功耗(特別是在空閒狀態)。因此SRAM首選用於頻寬要求高,或者功耗要求低,或者二者兼而有之。SRAM比起DRAM更為容易控制,也更是隨機存取。由於複雜的內部結構,SRAM比DRAM的佔用面積更大,因而不適合用於更高儲存密度低成本的應用,如PC主記憶體。
SRAM功耗取決於它的存取頻率。如果用高頻率存取SRAM,其功耗比得上DRAM。有的SRAM在全頻寬時功耗達到幾個瓦特量級。另一方面,SRAM如果用於溫和的時鐘頻率的微處理器,其功耗將非常小,在空閒狀態時功耗可以忽略不計—幾個微瓦特級別。
SRAM用於:
工業與科學用的很多子系統,汽車電子等等都用到了SRAM。現代裝置中很多都嵌入了幾千位元組的SRAM。實際上幾乎所有實現了電子使用者介面的現代裝置都可能用上了SRAM,如玩具。數碼相機、手機、音響合成器等往往用了幾百萬位元組的SRAM。 即時訊號處理電路往往使用雙埠(dual-ported)的SRAM。
SRAM用於PC、工作站、路由器以及外接設備:內部的CPU高速緩衝記憶體,外部的突發模式使用的SRAM快取,硬碟緩衝區,路由器緩衝區,等等。LCD顯示器或者印表機也通常用SRAM來快取資料。SRAM做的小型緩衝區也常見於CDROM與CDRW的驅動器中,通常為256 KiB或者更多,用來緩衝音軌資料。線纜數據機及類似的連接於電腦的裝置也使用了SRAM。
搭建自己的處理器的業餘愛好者[11]更願意選用SRAM,這是由於其易用性的工作介面。沒有DRAM所需的更新周期;位址匯流排與資料匯流排直接存取而不是像DRAM那樣地址、資料訊號共用資料線,通過多路復用器存取。SRAM通常只需3個控制訊號:Chip Enable (CE), Write Enable (WE)與Output Enable(OE)。對於同步SRAM,還需要時鐘訊號(Clock,CLK)。
SRAM的類型
非揮發性SRAM(Non-volatile SRAM,nvSRAM)具有SRAM的標準功能,但在失去電源供電時可以保住其資料。非揮發性SRAM用於網絡、航天、醫療等需要關鍵場合[12]—保住資料是關鍵的而且不可能用上電池。
非同步SRAM(Asynchronous SRAM)的容量從4 Kb到64 Mb。SRAM的快速存取使得非同步SRAM適用於小型的cache很小的嵌入式處理器的主主記憶體,這種處理器廣泛用於工業電子裝置、測量裝置、硬碟、網絡裝置等等。
- 零匯流排翻轉(Zero bus turnaround,ZBT)—SRAM匯流排從寫到讀以及從讀到寫所需要的時鐘周期是0
- 同步突發SRAM(synchronous-burst SRAM,syncBurst SRAM)—
- DDR SRAM—同步、單口讀/寫,雙資料率I/O
- QDR SRAM(Quad Data Rate (QDR) SRAM)—同步,分開的讀/寫口,同時讀寫4個字(word)。
參見
參考文獻
Wikiwand in your browser!
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.