www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式教程
[導(dǎo)讀]利用SPD實(shí)現(xiàn)嵌入式系統(tǒng)中內(nèi)存的自動(dòng)識(shí)別和配置

摘要:介紹了內(nèi)存的SPD規(guī)范及其硬件接口類型和數(shù)據(jù)組織結(jié)構(gòu),實(shí)現(xiàn)了在嵌入式系統(tǒng)中對(duì)不同內(nèi)存的識(shí)別與配置,提高了系統(tǒng)的穩(wěn)定性,方便更換和檢測(cè)。具體實(shí)例詳細(xì)描述了嵌入式系統(tǒng)中內(nèi)存的自動(dòng)配置過(guò)程。

關(guān)鍵詞:SPDI2C嵌入式系統(tǒng)MPC824X

在嵌入式系統(tǒng)設(shè)計(jì)中經(jīng)常用大容量的SDRAM,存放RTOS和數(shù)據(jù)。這時(shí)用戶可以有兩種選擇:一種是選用合適的內(nèi)存芯片自己布線,把整個(gè)SDRAM做到嵌入式系統(tǒng)的PCB板上,這種方法在小系統(tǒng)中經(jīng)常采用;另一種就是選用現(xiàn)成的內(nèi)存條(如筆記本電腦上常用的DIMM內(nèi)存),現(xiàn)成的內(nèi)存條不僅容量大,而且由于用量大,價(jià)格也相對(duì)便宜。另外現(xiàn)成的內(nèi)存條還節(jié)省了PCB布線空間,縮小嵌入式系統(tǒng)的內(nèi)存體積,提高系統(tǒng)的穩(wěn)定性,方便更換和檢測(cè)。筆記本內(nèi)存的型號(hào)和種類很多,采購(gòu)時(shí)也可能來(lái)自多個(gè)廠家。為了使各種內(nèi)存條在嵌入式系統(tǒng)都能正常使用,就需要系統(tǒng)的BOOT程序能進(jìn)行自動(dòng)識(shí)別和配置,按照SPD(SDRAMSerialPresenceDetectSpecification)規(guī)范正確讀取內(nèi)存參數(shù),另外根據(jù)內(nèi)存參數(shù)配置SDRAM控制器。

1SPD規(guī)范及數(shù)據(jù)格式

內(nèi)存的SPD規(guī)范是SDRAM控制器參數(shù)配置的主要依據(jù),在SPD規(guī)范中定義了單面或雙面DRAM的詳細(xì)參數(shù),如內(nèi)存的大小、數(shù)據(jù)位、行列地址的寬度、邏輯Bank數(shù)和物理Bank等。這些數(shù)據(jù)存放在EEPROM芯片中,詳細(xì)描述了內(nèi)存條的各種參數(shù)。存放內(nèi)存參數(shù)的是一個(gè)兩線制的串行EEPROM芯片,接口類型符合I2C協(xié)議。I2C協(xié)議是Philips公司制定的兩線制的串行數(shù)據(jù)傳輸標(biāo)準(zhǔn),數(shù)據(jù)的讀寫(xiě)通過(guò)一根時(shí)鐘線和一根數(shù)據(jù)線實(shí)現(xiàn)。數(shù)據(jù)傳輸有其嚴(yán)格的格式,一個(gè)數(shù)據(jù)幀由起始位、器件地址、應(yīng)答位、數(shù)據(jù)地址、傳輸數(shù)據(jù)和結(jié)束位構(gòu)成,可以允許多個(gè)器件分主從模式進(jìn)行傳輸。其數(shù)據(jù)傳輸時(shí)序如圖1所示。主控制器讀寫(xiě)數(shù)據(jù)的格式如圖2所示。

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

2卡的自動(dòng)識(shí)別和配置過(guò)程

下面以Motorola公司的MPC824XCPU為例介紹內(nèi)存的識(shí)別和配置過(guò)程。MPC824X是一款功能強(qiáng)大的嵌入式處理器,它由603E核107橋構(gòu)成。107橋有很豐富的控制接口模塊,如SDRAM控制器、EPIC、UART、I2C控制器等,很方便與外圍電路接口。嵌入式系統(tǒng)板中數(shù)據(jù)量很大,至少要用到256MB內(nèi)存。為了方便各種廠家的內(nèi)存型號(hào)進(jìn)行混插使用,需要編寫(xiě)內(nèi)存自動(dòng)識(shí)別和配置程序,把需要配置的數(shù)據(jù)從EEPROM讀出,然后根據(jù)SPD協(xié)議轉(zhuǎn)換成內(nèi)存的配置參數(shù)。這個(gè)配置過(guò)程必須在系統(tǒng)上電后立即運(yùn)行,為后面的RTOS運(yùn)行做準(zhǔn)備。內(nèi)存初始化參數(shù)包括行列地址寬度、邏輯Bank數(shù)、物理Bank的大小。因?yàn)镸PC824X內(nèi)有I2C控制器,所以可以直接與SPD連接,通過(guò)軟件的初始化,配置好I2C控制器,程序流程如圖3。

相關(guān)代碼及注釋:

/*配置分頻系數(shù)、模塊使能*/

mpc107_i2c_start();

/*設(shè)置控制器為發(fā)送模式*/

sysEUMBBARWrite(MPC107_I2CCR,MPC107_CCR_MEN

|MPC107_CCR_MSTA|MPC107_CCR_MTX);

/*送器件地址,置寫(xiě)標(biāo)志*/

sysEUMBBARWrite(MPC107_I2CDR,0xa0);

/*等待傳輸結(jié)束*/

i2c_wait();

/*送數(shù)據(jù)地址*/

sysEUMBBARWrite(MPC107_I2CDR,0x0);

/*等待傳輸結(jié)束*/

i2c_wait();

/*再次發(fā)送start位*/

sysEUMBBARWrite(MPC107_I2CCR,MPC107_CCR_MEN

|MPC107_CCR_MSTA|MPC107_CCR_MTX|MPC107_CCR_RSTA);

/*送器件地址,置讀標(biāo)志*/

sysEUMBBARWrite(MPC107_I2CDR,0xa1);

/*等待傳輸結(jié)束*/

i2c_wait();

/*發(fā)送應(yīng)答位*/

sysEUMBBARWrite(MPC107_I2CCR,MPC107_CCR_MEN

|MPC107_CCR_MSTA|MPC107_CCR_TXAK);

/*做一次假讀操作*/

sysEUMBBARRead(MPC107_I2CDR);

/*發(fā)送應(yīng)答*/

sysEUMBBARWrite(MPC107_I2CCR,MPC107_CCR_MEN|

MPC107_CCR_TXAK);

/*讀數(shù)據(jù)*/

data[i]=sysEUMBBARRead(MPC107_I2CDR);

/*配置MCCR寄存器*/

sys107RegWrite(MCCR_ADD,T_DATA);

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

參考文獻(xiàn)

1intelPCSDRAMSerialPresenceDetect(SPD)Specification

224C02datasheet

3MPC8240IntegratedProcessorUser,sManual

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

根據(jù)IDC預(yù)測(cè),中國(guó)在人工智能領(lǐng)域的投資預(yù)計(jì)到2027年將達(dá)到381億美元,占全球總投資的近9%。作為全球人工智能的重要參與者,中國(guó)正加速在汽車、通信、醫(yī)療、金融等多個(gè)行業(yè)應(yīng)用和發(fā)展生成式AI技術(shù),全面邁入“AI 2.0...

關(guān)鍵字: AI 內(nèi)存 DDR5

在工業(yè)物聯(lián)網(wǎng)設(shè)備部署中,Modbus通信故障是導(dǎo)致系統(tǒng)停機(jī)的首要原因之一。據(jù)統(tǒng)計(jì),超過(guò)60%的現(xiàn)場(chǎng)問(wèn)題源于通信配置錯(cuò)誤或數(shù)據(jù)解析異常。本文從嵌入式系統(tǒng)開(kāi)發(fā)視角,系統(tǒng)闡述Modbus通信調(diào)試的方法論,結(jié)合實(shí)際案例解析如何高...

關(guān)鍵字: 嵌入式系統(tǒng) Modbus通信

在嵌入式系統(tǒng)開(kāi)發(fā)中,看門(mén)狗(Watchdog Timer, WDT)是保障系統(tǒng)可靠性的核心組件,其初始化時(shí)機(jī)的選擇直接影響系統(tǒng)抗干擾能力和穩(wěn)定性。本文從硬件架構(gòu)、軟件流程、安全規(guī)范三個(gè)維度,系統(tǒng)分析看門(mén)狗初始化的最佳實(shí)踐...

關(guān)鍵字: 單片機(jī) 看門(mén)狗 嵌入式系統(tǒng)

8月17日消息,近日,超頻愛(ài)好者“saltycroissant”成功將海盜船(CORSAIR)DDR5內(nèi)存超頻至12886MT/s,創(chuàng)造了新的世界紀(jì)錄。

關(guān)鍵字: 內(nèi)存 DDR5

在高性能服務(wù)架構(gòu)設(shè)計(jì)中,緩存是不可或缺的環(huán)節(jié)。在實(shí)際項(xiàng)目中,我們通常會(huì)將一些熱點(diǎn)數(shù)據(jù)存儲(chǔ)在Redis或Memcached等緩存中間件中,只有在緩存訪問(wèn)未命中時(shí)才查詢數(shù)據(jù)庫(kù)。

關(guān)鍵字: 緩存 內(nèi)存

在PoE(以太網(wǎng)供電)網(wǎng)絡(luò)中,PSE(供電設(shè)備)與PD(受電設(shè)備)的協(xié)作質(zhì)量直接決定著系統(tǒng)的穩(wěn)定性與能效。從電源預(yù)算的精準(zhǔn)分配到動(dòng)態(tài)負(fù)載的實(shí)時(shí)響應(yīng),從電磁兼容的精細(xì)設(shè)計(jì)到熱管理的量化控制,每個(gè)環(huán)節(jié)的協(xié)同優(yōu)化都至關(guān)重要。本...

關(guān)鍵字: PSE PD

人工智能(AI)和機(jī)器學(xué)習(xí)(ML)是使系統(tǒng)能夠從數(shù)據(jù)中學(xué)習(xí)、進(jìn)行推理并隨著時(shí)間的推移提高性能的關(guān)鍵技術(shù)。這些技術(shù)通常用于大型數(shù)據(jù)中心和功能強(qiáng)大的GPU,但在微控制器(MCU)等資源受限的器件上部署這些技術(shù)的需求也在不斷增...

關(guān)鍵字: 嵌入式系統(tǒng) 人工智能 機(jī)器學(xué)習(xí)

7月25日消息,由于供應(yīng)短缺,最近一段時(shí)間DDR4內(nèi)存頻繁出現(xiàn)漲價(jià)、缺貨等現(xiàn)象。

關(guān)鍵字: DDR4 內(nèi)存

Zephyr開(kāi)源項(xiàng)目由Linux基金會(huì)維護(hù),是一個(gè)針對(duì)資源受限的嵌入式設(shè)備優(yōu)化的小型、可縮放、多體系結(jié)構(gòu)實(shí)時(shí)操作系統(tǒng)(RTOS)。近年來(lái),Zephyr RTOS在嵌入式開(kāi)發(fā)中的采用度逐步增加,支持的開(kāi)發(fā)板和傳感器不斷增加...

關(guān)鍵字: 嵌入式系統(tǒng) 軟件開(kāi)發(fā) 實(shí)時(shí)操作系統(tǒng) Zephyr項(xiàng)目
關(guān)閉