1 前言
閃存(又稱FLASH,閃速存儲器)是一種新興的半導體存儲器,是一種不揮發性存儲器NVM(Non-Volatile Memory)。它采用類似于EPROM的單管疊柵結構的存儲單元,是新一代用電信號擦除的可編程ROM;既吸收了EPROM結構簡單、編程可靠的優點,又具有EEPROM用隧道效應擦除的快捷特性,集成度可做得很高,因而在便攜式數據存儲和各種圖像采集記錄系統中得到了廣泛的應用。其主要特點有:非易失性,可靠性高;功耗小;壽命長,可以在在線工作的情況下進行寫入、讀出和擦除操作,標準擦寫次數可達10萬次;密度大、成本低,具有很高的容量密度,價格也在不斷降低;具有抗震動、抗沖擊、溫度適應范圍寬等。正是由于閃存具有上述諸多優點,近年得到了快速而迅猛的發展。
全球閃速存儲器的主要供應商有AMD、Atmel、Fujistu、Hitachi、Hyundai、Intel、Micron、Mitsubishi、Samsung、SST、Sharp、Toshiba。由于各自技術架構的不同,分為幾大陣營,因此閃速存儲也按其采用技術的不同而分為幾大類:
*NOR技術——代表公司Intel,特點為擦除和寫入慢、隨機讀快;
*NAND技術——代表公司Samsung、Toshiba,特點為隨機讀寫慢、以頁為單位連續讀寫快;
*AND技術——代表公司Hitachi,特點為低功耗,價格高。
*由EEPROM派生的閃速存儲器。特點:介于NOR與EEPROM之間。
存儲器的發展具有容量更大、體積更小、功耗更低、價格更低的趨勢,這在閃速存儲器行業表現得淋漓盡致。隨著半導體制造工藝的發展,主流閃速存儲器廠家采用90nm,甚至73nm的制造工藝。
借助于先進工藝的優勢,閃速存儲器的容量可以更大:NOR技術已經出現512Mb的器件,NAND和AND技術已經有32Gb的器件。
芯片的封裝尺寸更小:從最初DIP封裝,到PSOP、SSOP、TSOP封裝,再到BGA封裝,閃速存儲器已經變得非常纖細小巧。
工作電壓更低:從最初12V的編程電壓,一步步下降到5V、3.3V、2.7V、1.8V單電壓供電;符合國際上低功耗的潮流,更促進了便攜式產品的發展。
位成本大幅度下降:采用NOR技術的Intel公司的28F128J3價格為25美元,NAND技術和AND技術的閃速存儲器已經突破10MB/2美元的價位,性價比極高。
本文中討論的是采用NAND技術的TH58NVG1S3A。
2 TH58NVG1S3A芯片
TH58NVG1S3A是Toshiba公司生產的一款閃存芯片。它的單片容量是2Gbits,采用的是NAND技術,它可以在200μs內完成一頁2112個字節的編程操作,還可以在2ms內完成128K字節的擦除操作,同時數據區內的數據能以20MBps的速度讀出。
TH58NVG1S3A大容量閃存芯片的I/O口既可以作為地址的輸入端,也可以作為數據的輸入/輸出端,同時還可以作為指令的輸入端。芯片上的寫控制器能自動控制所有編程和擦除操作,包括提供必要的重復脈沖、內部確認和數據空間等。
2.1 TH58NVG1S3A芯片的性能參數
TH58NVG1S3A的主要特點如下:
?采用3.3V電源;
?芯片內部的存儲單元陣列為(256+8192K)×8bits,數據寄存器和緩沖存儲器均為(2K+64)×8bits;
?具有指令/地址/數據復用的I/O口;
?由于采用可靠的CMOS移動門技術,使得芯片最大可實現100000次編程/擦除操作,該技術可以保證數據保存10年而不丟失。
2.2 TH58NVG1S3A芯片的主要引腳說明
TH58NVG1S3A有48個引腳,具體功能如下:
I/O0~I/O7:數據輸入輸出口,I/O口常用于指令和地址的輸入以及數據的輸入/輸出,其中數據在讀的過程中輸入。當芯片沒有被選中或不能輸出時,I/O口處于高阻態。
CLE:指令鎖存端,用于激活指令到指令寄存器的路徑,并在WE上升沿且CLE為高電平時將指令鎖存。
ALE:地址鎖存端用于激活地址到內部地址寄存器的路徑,并在WE上升沿且ALE為高電平時,地址鎖存。
CE:片選端用于控制設備的選擇。當設備忙時CE為高電平而被忽略,此時設備不能回到備用狀態。
RE:讀使能端,用于控制數據的連續輸出,并將數據送到I/O總線。只有在RE的下降沿時,輸出數據才有效,同時它還可以對內部數據地址進行累加。
WE:寫使能控制端,用于控制I/O口的指令寫入,同時,通過該端口可以在WE脈沖的上升沿將指令、地址和數據進行鎖存。
WP:寫保護端,通過WP端可在電源變換中進行寫保護。當WP為低電平時,其內部高電平發生器將復位。
RY/BY_N:就緒/忙輸出,RY/BY_N的輸出能夠顯示設備的操作狀態。RY/BY_N處于低電平時,表示有編程、擦除或隨機讀操作正在進行。操作完成后,RY/BY_N會自動返回高電平。由于該端是漏極開路輸出,所以即使當芯片沒有被選中或輸出被禁止時,它也不會處于高阻態。
3 利用CPLD對TH58NVG1S3A控制的實現
本項目采用的CPLD是LATTICE公司的高密度在系統可編程邏輯器件ISPLSI1032E,這款CPLD有84腳和100腳兩種封裝形式,有64個I/O口供用戶使用,內部集成6000門,有192個寄存器。能夠滿足設計需要。
3.1 硬件連接
圖1所示為ISPLSI1032E控制TH58NVG1S3A芯片的主要信號連接情況。圖中ADDR、DATA、CMD是系統與外部的接口信號,提供給用戶使用;CLK是輸入到CPLD的時鐘信號(頻率為20Mhz);另外ISPLSI1032E提供6根控制線和8根數據線以實現對TH58NVG1S3A的邏輯控制和數據交換,這些對用戶是不透明的。ADDR是提供給閃存的29位的地址輸入線,可實現對閃存的512M×8bits單元尋址;CMD為3位輸入線表示對閃存的操作狀態(讀、寫、擦除等);DATA 為雙向8位數據線;RY/BY_N是TH58NVG1S3A的反饋信號,示意操作過程是否結束;其他信號是TH58NVG1S3A的控制信號。
3.2 軟件設計
本文使用VHDL語言對CPLD進行編程。VHDL語言具有很強的電路描述和建模能力,能從多個層次對數字系統進行建模和描述,使用VHDL語言對CPLD進行編程,可以將硬件工作軟件化,從而大大簡化了硬件設計任務,提高了設計效率和可靠性,在語言方面具有很好的易讀性;同時VHDL語言描述的系統是以并行方式工作的,大大提高了系統的運算速度;用VHDL語言進行電子系統設計的最大優點是使我們專致于功能的實現,而不需要對不影響功能的因素花費過多時間和精力,縮短了產品的開發時間。VHDL是一種標準語言,不是針對某廠家的器件,而是針對所有可編程邏輯器件,因而具有普遍性,成為最常用的硬件描述語言。程序流程如圖2 所示。其中用CMD=001表示讀閃存,CMD=010表示對閃存進行寫操作,CMD=100表示對閃存進行塊擦除。
TH58NVG1S3A的讀是按頁執行的。讀操作首先把00H命令寫到指令寄存器作為讀地址輸入指令,一旦該指令被鎖存,就不能在下頁中寫入讀操作了,然后輸入5個周期的地址數據到地址寄存器中進行地址譯碼,最后把30H寫到指令寄存器作為讀開始指令,但是并不是馬上就能從閃存讀出數據,直到將選定頁中的2112字節數據存入數據寄存器后才能從閃存輸出數據,系統可以通過分析RY/BY_N腳的輸出來判斷數據轉移是否完成。選定頁中的2112字節數據能夠在25μs內被存入數據寄存器中,而存入數據寄存器的數據可以很快地被讀出,數據通過周期為50ns 的RE脈沖被連續輸出至I/O。
TH58NVG1S3A的寫操作也是按頁進行的。首先輸入連續數據輸入指令80H,再輸入5個周期的地址數據到地址寄存器中進行地址譯碼,之后在50ns的WE周期上升沿將要寫入的2112字節數據寫入數據寄存器中,最后輸入自動編程指令10H開始編程。可以通過查詢RY/BY_N腳的輸出來判斷編程是否完成。編程完成后通過輸入讀狀態寄存器70H來確定編程操作是否成功。雖然閃存的寫操作是以頁為單位的,但是TH58NVG1S3A可以將一頁空間(2112字節)分成8個部分(0-511,512-1023,1024-1535,1536-2047,2048-2063,2064-2079,2080-2095,2096-2111)分別操作,只是在進行寫操作的時候,把要進行寫操作的部分寫入需要的數據,其他7個不需要進行寫操作的部分必須寫“1”。
TH58NVG1S3A的擦除操作是以塊為單位進行的。塊地址裝載將從一個塊擦除指令60H開始,之后是三個周期的塊地址輸入,然后輸入擦除指令D0H開始擦除,通過查詢R/B來判斷擦除操作是否完成。TH58NVG1S3A內的狀態寄存器可以確認編程和擦除操作是否成功完成。在寫入指令(70H)到指令寄存器后,讀循環會把狀態寄存器的內容在RE的下降沿輸出到I/O。而在新的指令到達前,指令寄存器將保持讀狀態。
本文編程的讀操作仿真波形如圖3,寫和擦除與讀操作方式類似,不再贅述。
4 結束語
本文的創新點是成功使用CPLD控制TOSHIBA公司新推出的2Gbits NAND FLASH芯片 TH58NVG1S3A,完成了軟硬件設計,使本系統相對于傳統的存儲方式來說更適用于非常惡劣的環境,有非常高的可靠性,能夠承受強烈的震動,具有較低的功耗,靈活性高,控制方便,已經成功應用于某航天項目中,并產生了很好的效果。
責任編輯:gt
評論
查看更多