当前位置:首页 > 嵌入式 > 嵌入式教程
[导读]利用SPD实现嵌入式系统中内存的自动识别和配置

摘要:介绍了内存的SPD规范及其硬件接口类型和数据组织结构,实现了在嵌入式系统中对不同内存的识别与配置,提高了系统的稳定性,方便更换和检测。具体实例详细描述了嵌入式系统中内存的自动配置过程。

关键词:SPDI2C嵌入式系统MPC824X

在嵌入式系统设计中经常用大容量的SDRAM,存放RTOS和数据。这时用户可以有两种选择:一种是选用合适的内存芯片自己布线,把整个SDRAM做到嵌入式系统的PCB板上,这种方法在小系统中经常采用;另一种就是选用现成的内存条(如笔记本电脑上常用的DIMM内存),现成的内存条不仅容量大,而且由于用量大,价格也相对便宜。另外现成的内存条还节省了PCB布线空间,缩小嵌入式系统的内存体积,提高系统的稳定性,方便更换和检测。笔记本内存的型号和种类很多,采购时也可能来自多个厂家。为了使各种内存条在嵌入式系统都能正常使用,就需要系统的BOOT程序能进行自动识别和配置,按照SPD(SDRAMSerialPresenceDetectSpecification)规范正确读取内存参数,另外根据内存参数配置SDRAM控制器。

1SPD规范及数据格式

内存的SPD规范是SDRAM控制器参数配置的主要依据,在SPD规范中定义了单面或双面DRAM的详细参数,如内存的大小、数据位、行列地址的宽度、逻辑Bank数和物理Bank等。这些数据存放在EEPROM芯片中,详细描述了内存条的各种参数。存放内存参数的是一个两线制的串行EEPROM芯片,接口类型符合I2C协议。I2C协议是Philips公司制定的两线制的串行数据传输标准,数据的读写通过一根时钟线和一根数据线实现。数据传输有其严格的格式,一个数据帧由起始位、器件地址、应答位、数据地址、传输数据和结束位构成,可以允许多个器件分主从模式进行传输。其数据传输时序如图1所示。主控制器读写数据的格式如图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);

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

参考文献

1intelPCSDRAMSerialPresenceDetect(SPD)Specification

224C02datasheet

3MPC8240IntegratedProcessorUser,sManual

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

根据IDC预测,中国在人工智能领域的投资预计到2027年将达到381亿美元,占全球总投资的近9%。作为全球人工智能的重要参与者,中国正加速在汽车、通信、医疗、金融等多个行业应用和发展生成式AI技术,全面迈入“AI 2.0...

关键字: AI 内存 DDR5

在工业物联网设备部署中,Modbus通信故障是导致系统停机的首要原因之一。据统计,超过60%的现场问题源于通信配置错误或数据解析异常。本文从嵌入式系统开发视角,系统阐述Modbus通信调试的方法论,结合实际案例解析如何高...

关键字: 嵌入式系统 Modbus通信

在嵌入式系统开发中,看门狗(Watchdog Timer, WDT)是保障系统可靠性的核心组件,其初始化时机的选择直接影响系统抗干扰能力和稳定性。本文从硬件架构、软件流程、安全规范三个维度,系统分析看门狗初始化的最佳实践...

关键字: 单片机 看门狗 嵌入式系统

8月17日消息,近日,超频爱好者“saltycroissant”成功将海盗船(CORSAIR)DDR5内存超频至12886MT/s,创造了新的世界纪录。

关键字: 内存 DDR5

在高性能服务架构设计中,缓存是不可或缺的环节。在实际项目中,我们通常会将一些热点数据存储在Redis或Memcached等缓存中间件中,只有在缓存访问未命中时才查询数据库。

关键字: 缓存 内存

在PoE(以太网供电)网络中,PSE(供电设备)与PD(受电设备)的协作质量直接决定着系统的稳定性与能效。从电源预算的精准分配到动态负载的实时响应,从电磁兼容的精细设计到热管理的量化控制,每个环节的协同优化都至关重要。本...

关键字: PSE PD

人工智能(AI)和机器学习(ML)是使系统能够从数据中学习、进行推理并随着时间的推移提高性能的关键技术。这些技术通常用于大型数据中心和功能强大的GPU,但在微控制器(MCU)等资源受限的器件上部署这些技术的需求也在不断增...

关键字: 嵌入式系统 人工智能 机器学习

7月25日消息,由于供应短缺,最近一段时间DDR4内存频繁出现涨价、缺货等现象。

关键字: DDR4 内存

Zephyr开源项目由Linux基金会维护,是一个针对资源受限的嵌入式设备优化的小型、可缩放、多体系结构实时操作系统(RTOS)。近年来,Zephyr RTOS在嵌入式开发中的采用度逐步增加,支持的开发板和传感器不断增加...

关键字: 嵌入式系统 软件开发 实时操作系统 Zephyr项目
关闭