隨著電子技術的飛速發展, 存儲器的種類日益繁多,每一種存儲器都有其獨有的操作時序,為了提高存儲器芯片的測試效率,一種多功能存儲器芯片的測試系統應運而生。本文提出了一種多功能存儲器芯片的測試系統硬件設計與實現,對各種數據位寬的多種存儲器芯片(SRAM、MRAM、NOR FALSH、NAND FLASH、EEPROM等)進行了詳細的結口電路設計(如何掛載到NIOSII的總線上),最終解決了不同數據位寬的多種存儲器的同平臺測試解決方案,并詳細地設計了各結口的硬件實現方法。
引言
隨著電子技術的飛速發展,存儲器類芯片的品種越來越多,其操作方式完全不一樣,因此要測試其中一類存儲器類芯片就會有一種專用的存儲器芯片測試儀。本文設計的多種存儲器芯片測試系統是能夠對SRAM、Nand FLASH、Nor FLASH、MRAM、EEPROM等多種存儲器芯片進行功能測試,而且每一類又可兼容8位、16位、32位、40位等不同寬度的數據總線,如果針對每一種產品都單獨設計一個測試平臺,其測試操作的復雜程度是可想而知的。為達到簡化測試步驟、減小測試的復雜度、提高測試效率、降低測試成本,特設計一種多功能的存儲器類芯片測試系統,實現在同一平臺下完成所有上述存儲器芯片的方便快捷地測試。
設計原理
此設計方案根據上述各種存儲器獨自的讀寫時序訪問特性,通過FPGA的靈活編程特性,適當地調整NIOSII的外部總線時序,最終實現基于NIOSII的外部總線訪問各種存儲器讀寫時序的精確操作。如圖2-1。通過FPGA自定義一個可以掛載所有存儲器芯片的總線接口-ABUS,如表1。而且在同一個接口上能夠自動識別各種接入的被測試存儲器芯片,它們通過類別輸入信號(CLAS)來區分,每一種存儲器芯片對應一種獨特的操作時序。下面是幾種存儲器芯片的接口連接方式及信號描述。其它的存儲器芯片都可以用類似的接法掛載到ABUS總線上,最終完成測試。
?
40位NAND FLASH連接設計
如圖2-2所示,40位NAND FLASH與NIOSII 通過ABUS(FPGA)橋接,把外部總線的時序完全轉換成NAND FLASH的操作時序。40位NAND FLASH芯片品由五個獨立的8位NAND FLASH芯片拼接構成。5個8位器件的外部IO口拼接成40位的外部IO口,而各自的控制線(NCLE,NALE,NRE,NWE)連接在一起構成一組控制線(NCLE,NALE,NRE,NWE),片選相互獨立引出成NCS0-NCS9,忙信號獨立引出為R/B0-R/B9。
如表2,詳述了40位NAND FLASH與ABUS的連接關系。
?
40位SRAM與NIOSII連接
40位SRM模塊與NIOSII通過ABUS連接,實現正確的時序讀寫操作。測試時,一次只測試8位,分5次完成所有空間的測試。如圖2-4。表4是詳細的信號連接說明。
?
8位SRAM與NIOSII連接
8位SRM模塊與NIOSII通過ABUS(FPGA)連接,實現正確的時序讀寫操作。如圖2-5。表5是信號連接說明。
?
8位SRM模塊與NIOSII通過ABUS(FPGA)連接,實現正確的時序讀寫操作。如圖2-5。表5是信號連接說明。
?
硬件電路設計
在測試NAND FLASH時,測試時間長達十個小時不等。在此為提高測試效率,增加測試速度,本設計采用兩套完全一樣且獨立的硬件系統構成。可同時最多測試2片NAND FLASH器件。每一個硬件系統由一個微處理器(NIOSII)加一個大容量FPGA及一個存儲器測試擴展接口(即ABUS接口)三大模塊構成。如圖3-1。RS232通信接口實現測試系統與上位機的數據交換,完成人機交互操作。電源系統產生各種合適的電壓,滿足各芯片的電源供給。
處理器模塊電路
處理器模塊電路由FPGA內嵌的NIOSII軟核(CPU)、兩路RS232通信、一個FLASH芯和一個SRAM芯片組成。CPU是整個系統的核心管理者,向下負責各種存儲器芯片的讀寫測試,向上負責與上位機通信,實現人機交互。通信由其中一個RS232電路完成,另一個RS232電路用來實現系統調試和軟件固化。FLASH芯片用來存儲程序代碼及重要的數據。而SRAM芯片在CPU上電工作以后,通過CPU加載FLASH的程序,最終給CPU的程序代碼提供快速的運行環境。
基于FPGA的ABUS接口模塊
ABUS接口模塊由FPGA芯片、配置FLASH及數據存儲EEPROM芯片構成。ABUS要實現NIOSII的外部總線與多種存儲器模塊的接口對接,每一種特定的存儲器有一個特定的時序邏輯,而每一種時序邏輯可以通過FPGA的硬件代碼(IP核)來實現,具體的每一個存儲器模塊在測試時會給ABUS接口一個固定的類別信號CLAS,ABUS接口根據這個類別信號識別出各種SIP存儲器模塊,最終切換出正確的對應特定產品的時序邏輯,來完成NIOSII通過外部總線來對存儲器芯片的讀寫測試。而配置FLASH實現FPGA在上電時硬件程序的加載工作及掉電數據保護。EEPROM用來存儲一些重要的系統參數。
SIP存儲器測試擴展接口
存儲器測試擴展接口在硬件上由兩排雙排座構成。一共是120個管腳。ABUS接口與測試擴展接口相連接:40個管腳與雙向的數據或I/O線相連、8個管腳與8根信號輸入控制線相連、16個管腳與16根片選信號輸出線相連、5個管腳與5根類別輸入信號相連、16個管腳與16根狀態輸入信號線相連、27個管腳與27根地址線相連。其它的管腳可分配成電源和地線,以及信號指示等。
ABUS接口IP核的設計
每一種SIP存儲器對應于一個特定的ABUS接口IP核,以實現正確的時序讀寫操作。這個IP核有一個統一的接口約定,都是由兩個固定的接口構成,其中與NIOSII連接的是外部總線接口,其操作按照NIOSII的外部總線時序規范來實現,另一個接口就是上文提及的ABUS接口,在相應的CLAS信號有效的情況下,它負責把NIOSII的外部總線讀寫時序轉換成對應存儲器芯片的時序。IP核的工作就是完成這些讀寫操作的轉換。表5是各種SIP存儲器對應的類別信(CLAS)號輸入值,在設計接口轉接板時要按這個值設定,ABUS才會切換出正確的讀寫時序。
七位類別示別信號含義:T_XX_WW_CC,T為1表示高低測試測試,為0表示常溫下的功能測試。XX表示存儲器種類,WW表示總線寬度,CC表示容量種類。
?
?
8位SRAM/MRAM/NOR FLASH接口IP核設計
如圖4-1,SRAM、MRAM和NOR FLASH的接口操作基本一致,NIOSII的總線時序完全滿足。故在FPGA內部只要簡單地把相應的控制線和數據線相連就可以了,唯獨只要設計一個片選寄存器,用來區分存儲器芯片的16個片選。每一個片選可以訪問的空間為128MByte。片選寄存器的地址為(基址+0x0FFFFFFC),基地址設在NIOSII外部總線的最高地址位。
16位SRAM/MRAM/NOR FLASH接口IP核設計
如圖4-2,SRAM、MRAM和NOR FLASH的接口操作基本一致,NIOSII的總線時序完全滿足。故在FPGA內部只要簡單的把相應的控制線和數據線相連就可以了,唯獨只要設計一個片選寄存器,用來區分SIP的16個片選。每一個片選可以訪問的空間為128MByte。片選寄存器的地址為(基址+0x0FFFFFFC),基地址設在NIOSII 外部總線的最高地址位。
32位SRAM/MRAM/NOR FLASH接口IP核設計
如圖4-3,SRAM、MRAM和NOR FLASH的接口操作基本一致,NIOSII的總線時序完全滿足。故在FPGA內部只要簡單的把相應的控制線和數據線相連就可以了,唯獨只要設計一個片選寄存器,用來區分SIP的16個片選。每一個片選可以訪問的空間為128MByte。片選寄存器的地址為(基址+0x0FFFFFFC),基地睛設在NIOSII 外部總線的最高地址位。
40位SRAM/MRAM/NOR FLASH接口IP核設計
如圖4-4,40位的數據寬度有點特殊。在此我們把40位的數據分成5個8位的區域,用8位寬度的總線去分別訪問每一個區域。IP核中的位選寄存器就是用來完成切換8位數據總線到40位總線的5個區域的其中一個。片選寄存器的地址為(基址+0x0FFFFFFC),位選寄存器的地址為(基址+0x0FFFFFF8)。最大可以測試128M×40位×16片的存儲器SRAM/MRAM/NOR FLASH模塊。
8位NAND FLASH的ABUS接口IP設計
如圖4-5,通過寫片選寄存器來選中模塊的16個片選的其中一個。我們約定其地址為(基址+0x0FFFFFFC)。讀狀態寄存器返回的是16個NAND FLASH芯片的忙信號,其地址為(基址+0x0FFFFFF8)。向地址(基址+0x00)寫入數據就是對NAND FLASH數據寄存器的寫操作。向地址(基址+0x00)單元讀數據就是對NAND FLASH數據寄存器的讀操作。向地址(基址+0x01)寫入數據就是對NAND FLASH命令寄存器的寫操作。向地址(基址+0x02)寫入數據就是對NAND FLASH地址寄存器的寫操作。
16位NAND FLASH的ABUS接口IP設計
16位的NAND FLASH存儲器芯片可以有多種組合方式,可以用多個16位的NAND FLASH組合,也可以用多個8位的NAND FLASH組合。這里我們假設16位的SIP NAND FLASH產品是由多個16位的NAND FLASH組合而成,下面的IP核是根據它的結構來設計的。
如圖4-6,通過寫片選寄存器來選中模塊的16個片選的其中一個。我們約定其地址為(基址+0x0FFFFFFC)。讀狀態寄存器返回的是16個NAND FLASH芯片的忙信號,其地址為(基址+0x0FFFFFF8)。向地址(基址+0x00)寫入數據就是對NAND FLASH數據寄存器的寫操作。向地址(基址+0x00)單元讀數據就是對NAND FLASH數據寄存器的讀操作。向地址(基址+0x01)寫入數據就是對NAND FLASH命令寄存器的寫操作。向地址(基址+0x02)寫入數據就是對NAND FLASH地址寄存器的寫操作。
驗證與總結
將寫好的FPGA程序和調試的C代碼寫入FLASH后,掉電重配置FPGA,串口的輸出能正常識別所有設置好的存儲器芯片,并能夠進行準確地讀寫功能測試。達到了設計目的。
本文介紹了一種低成本、簡單、靈活的多種存儲器芯片測試系統的硬件設計,并采用FPGA、FLASH、SDRAM、RS232電路等實現。采用這種方案,用戶可根據市場需求,靈活的增加測試系統功能,實現更多的存儲器芯片測試。
評論
查看更多