《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > 利用SPD實現嵌入式系統中內存的自動識別和配置

利用SPD實現嵌入式系統中內存的自動識別和配置

2008-09-22
作者:趙 靜 陳家勝

??? 摘? 要: 介紹了內存的SPD規范及其硬件接口類型和數據組織結構,實現了在嵌入式系統" title="嵌入式系統">嵌入式系統中對不同內存的識別與配置,提高了系統的穩定性,方便更換和檢測。具體實例詳細描述了嵌入式系統中內存的自動配置過程。?

??? 關鍵詞: SPD? I2C? 嵌入式系統? MPC824X

?

??? 在嵌入式系統設計中經常用大容量的SDRAM,存放RTOS和數據。這時用戶可以有兩種選擇:一種是選用合適的內存芯片自己布線,把整個SDRAM做到嵌入式系統的PCB板上,這種方法在小系統中經常采用;另一種就是選用現成的內存條" title="內存條">內存條(如筆記本電腦上常用的DIMM內存),現成的內存條不僅容量大,而且由于用量大,價格也相對便宜。另外現成的內存條還節省了PCB布線空間,縮小嵌入式系統的內存體積,提高系統的穩定性,方便更換和檢測。筆記本內存的型號和種類很多,采購時也可能來自多個廠家。為了使各種內存條在嵌入式系統都能正常使用,就需要系統的BOOT程序能進行自動識別" title="自動識別">自動識別和配置,按照SPD(SDRAM Serial Presence Detect Specification)規范正確讀取內存參數,另外根據內存參數配置SDRAM控制器。?

1 SPD規范及數據格式?

??? 內存的SPD規范是SDRAM控制器參數配置的主要依據,在SPD規范中定義了單面或雙面DRAM的詳細參數,如內存的大小、數據位、行列地址的寬度、邏輯Bank數和物理Bank等。這些數據存放在EEPROM芯片中,詳細描述了內存條的各種參數。?

??? 存放內存參數的是一個兩線制" title="兩線制">兩線制的串行EEPROM芯片,接口類型符合I2C協議。I2C協議是Philips公司制定的兩線制的串行數據傳輸標準,數據的讀寫通過一根時鐘線和一根數據線實現。數據傳輸有其嚴格的格式,一個數據幀由起始位、器件地址、應答位、數據地址、傳輸數據和結束位構成,可以允許多個器件分主從模式進行傳輸。其數據傳輸時序如圖1所示。主控制器" title="主控制器">主控制器讀寫數據的格式如圖2所示。?

?

?

?

??? 內存的SPD一般要求EEPROM帶有2Kbit的存儲空間,用于存放內存的配置參數,而硬件電路接口是I2C接口。要讀取內存參數,主控制器必須能按照I2C協議進行通信,進行數據的讀操作。另外還需知道EEPROM的數據存放格式及其含義。SPD規范中對存放的數據進行了詳細的說明和定義。以PC133-333為例詳細說明挑選配置時用到的參數,如表1所示。用戶只需把相應地址中的值讀出來,對照規范中的說明即可知道內存的詳細參數。?

?

?

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[i] = sysEUMBBARRead( MPC107_I2CDR);?

?

??? /*配置MCCR寄存器*/?

??? sys107RegWrite(MCCR_ADD,T_DATA);?

??? 其它寄存器按此順序配置。?

參考文獻?

1 intel PC SDRAM Serial Presence Detect (SPD) Specification?

2 24C02 datasheet?

3 MPC8240 Integrated Processor User's Manual

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
主站蜘蛛池模板: 久久亚洲精品专区蓝色区| 亚洲欧洲国产经精品香蕉网| 蜜桃成熟时无删减手机在线观看 | 夜夜爽夜夜叫夜夜高潮漏水 | chinese激烈高潮HD| 成人人观看的免费毛片| 久久99国产综合精品| 日韩一级欧美一级在线观看| 亚洲av无码专区国产乱码不卡| 欧美精品亚洲精品日韩| 亚洲色图综合网| 男女下面的一进一出视频| 北条麻妃在线一区二区| 老子影院午夜伦手机在线看| 国产人成免费视频| 麻豆亚洲av熟女国产一区二| 国产成人综合久久综合| 浮力影院亚洲国产第一页| 国产黄a三级三级看三级| 99精品一区二区免费视频| 天天躁日日躁狠狠躁综合| xxxxx日韩| 好男人社区神马www| 一本大道香焦在线视频| 成人免费一级片| 不卡一卡二卡三亚洲| 成人欧美一区二区三区在线| 中文有码在线观看| 无码少妇一区二区浪潮AV| 久久久久久久久蜜桃| 日本一区二区三区欧美在线观看| 久久乐国产精品亚洲综合| 日本狂喷奶水在线播放212| 久久成人午夜电影mp4| 日韩不卡手机视频在线观看| 久久精品国产亚洲av高清漫画| 日韩精品欧美一区二区三区| 久久综合九色欧美综合狠狠| 日韩国产欧美在线观看一区二区| 久久精品无码专区免费东京热| 日韩精品极品视频在线观看免费 |