關於利用SPD實現嵌入式系統中記憶體的自動識別和配置的論文
關於利用SPD實現嵌入式系統中記憶體的自動識別和配置的論文
摘要:介紹了記憶體的SPD規範及其硬體介面型別和資料組織結構,實現了在嵌入式系統中對不同記憶體的識別與配置,提高了系統的穩定性,方便更換和檢測。具體例項詳細描述了嵌入式系統中記憶體的自動配置過程。
關鍵詞:SPD I2C 嵌入式系統 MPC824X
在嵌入式系統設計中經常用大容量的SDRAM,存放RTOS和資料。這時使用者可以有兩種選擇:一種是選用合適的記憶體晶片自己佈線,把整個SDRAM做到嵌入式系統的PCB板上,這種方法在小系統中經常採用;另一種就是選用現成的記憶體條(如膝上型電腦上常用的DIMM記憶體),現成的記憶體條不僅容量大,而且由於用量大,價格也相對便宜。另外現成的記憶體條還節省了PCB佈線空間,縮小嵌入式系統的記憶體體積,提高系統的穩定性,方便更換和檢測。筆記本記憶體的型號和種類很多,採購時也可能來自多個廠家。為了使各種記憶體條在嵌入式系統都能正常使用,就需要系統的BOOT程式能進行自動識別和配置,按照SPD(SDRAM Serial Presence Detect Specification)規範正確讀取記憶體引數,另外根據記憶體引數配置SDRAM控制器。圖1 資料傳輸時序 1 SPD規範及資料格式
記憶體的SPD規範是SDRAM控制器引數配置的主要依據,在SPD規範中定義了單面或雙面DRAM的詳細引數,如記憶體的大小、資料位、行列地址的寬度、邏輯Bank數和物理Bank等。這些資料存放在EEPROM晶片中,詳細描述了記憶體條的各種引數。
存放記憶體引數的是一個兩線制的序列EEPROM晶片,介面型別符合I2C協議。I2C協議是Philips公司制定的兩線制的序列資料傳輸標準,資料的讀寫透過一根時鐘線和一根資料線實現。資料傳輸有其嚴格的格式,一個數據幀由起始位、器件地址、應答位、資料地址、傳輸資料和結束位構成,可以允許多個器件分主從模式進行傳輸。其資料傳輸時序如圖1所示。主控制器讀寫資料的格式如圖2所示。
圖2 主控制讀寫資料的格式
記憶體的SPD一般要求EEPROM帶有2Kbit的儲存空間,用於存放記憶體的配置引數,而硬體電路介面是I2C介面。要讀取記憶體引數,主控制器必須能按照I2C協議進行通訊,進行資料的讀操作。另外還需知道EEPROM的資料存放格式及其含義。SPD規範中對存放的資料進行了詳細的說明和定義。以PC133-333為例詳細說明挑選配置時用到的引數,如表1所示。使用者只需把相應地址中的值讀出來,對照規範中的說明即可知道記憶體的詳細引數。
表1 PC133-333配置時用到的'引數
位元組地址定 義PC133引數值備 注0廠商使用的位元組數80h使用了128位元組1EEPROM儲存容量08h256位元組2記憶體型別04hSDRAM3行地址位數0ch12位行地址4列地址位數09h9位列地址5排數02h兩排6資料寬度(低位元組)40h64位寬度7資料寬度(高位元組)00h 8訊號電平01hLVTTL9SDRAM最高時鐘頻率75hTclk=7.5ns10SDRAM訪問時間54hTac=5.4nc11配置型別00h不支援校驗糾錯12刷行率/型別80h15.6μs/自重新整理13最小SDRAM顆粒資料寬度08h8位16支援地猝發傳輸長度8Fh1,2,4,817邏輯bank數04h4banks18CAS延遲06hCL=2,323
SDRAM時鐘(2的最大指數倍)A0hTclk=10ns24SDRAM訪問時間(2的最大指數倍)60hTac=6ns34輸入資料建立時間15h1.5ns35輸入資料保持時間08h0.8ns62SPD版本號12hRev.1.2其它不詳述(見SPD規範手冊)
2 卡的自動識別和配置過程
下面以Motorola公司的MPC824XCPU為例介紹記憶體的識別和配置過程。MPC824X是一款功能強大的嵌入式處理器,它由603E核107橋構成。107橋有很豐富的控制介面模組,如SDRAM控制器、EPIC、UART、I2C控制器等,很方便與外圍電路介面。嵌入式系統板中資料量很大,至少要用到256MB記憶體。為了方便各種廠家的記憶體型號進行混插使用,需要編寫記憶體自動識別和配置程式,把需要配置的資料從EEPROM讀出,然後根據SPD協議轉換成記憶體的配置引數。這個配置過程必須在系統上電後立即執行,為後面的RTOS執行做準備。記憶體初始化引數包括行列地址寬度、邏輯Bank數、物理Bank的大小。因為MPC824X內有I2C控制器,所以可以直接與SPD連線,透過軟體的初始化,配置好I2C控制器,程式流程如圖3。(收集整理)
相關程式碼及註釋:
/*配置分頻係數、模組使能*/
mpc107_i2c_start();
/*設定控制器為傳送模式*/
sysEUMBBARWrite(MPC107_I2CCR,MPC107_CCR_MEN
| MPC107_CCR_MSTA | MPC107_CCR_MTX );
/*送器件地址,置寫標誌*/
sysEUMBBARWrite(MPC107_I2CDR, 0xa0);
/*等待傳輸結束*/
i2c_wait();
/*送資料地址*/
sysEUMBBARWrite(MPC107_I2CDR, 0x0);
/*等待傳輸結束*/
i2c_wait();
/*再次傳送start位*/
sysEUMBBARWrite(MPC107_I2CCR, MPC107_CCR_MEN
|MPC107_CCR_MSTA|MPC107_CCR_MTX|MPC107_CCR_RSTA);
/*送器件地址,置讀標誌*/
sysEUMBBARWrite(MPC107_I2CDR, 0xa1);
/*等待傳輸結束*/
i2c_wait();
/*傳送應答位*/
sysEUMBBARWrite(MPC107_I2CCR,MPC107_CCR_MEN
|MPC107_CCR_MSTA | MPC107_CCR_TXAK);
/*做一次假讀操作*/
sysEUMBBARRead(MPC107_I2CDR);
/*傳送應答*/
sysEUMBBARWrite(MPC107_I2CCR,MPC107_CCR_MEN |
MPC107_CCR_TXAK);
/*讀資料*/
data = sysEUMBBARRead(MPC107_I2CDR);
/*配置MCCR暫存器*/
sys107RegWrite(MCCR_ADD,T_DATA);
其它暫存器按此順序配置。