机械行业资料网 - 分享快乐
网站首页行业新闻机械资料求购信息供应信息机械产品机械企业机械软件招商展会

 首页 ->  资料大全 ->  电子/电气机械 -> 正文

 
Google

利用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配置时用到的参数

字节地址0123456789101112131617182324343562其它
定  义PC133参数值备   注
厂商使用的字节数80h使用了128字节
EEPROM存储容量08h256字节
内存类型04hSDRAM
行地址位数0ch12位行地址
列地址位数09h9位列地址
排数02h两排
数据宽度(低字节)40h64位宽度
数据宽度(高字节)00h 
信号电平01hLVTTL
SDRAM最高时钟频率75hTclk=7.5ns
SDRAM访问时间54hTac=5.4nc
配置类型00h不支持校验纠错
刷行率/类型80h15.6μs/自刷新
最小SDRAM颗粒数据宽度08h8位
支持地猝发传输长度8Fh1,2,4,8
逻辑bank数04h4banks
CAS延迟06hCL=2,3
SDRAM时钟(2的最大指数倍)A0hTclk=10ns
SDRAM访问时间(2的最大指数倍)60hTac=6ns
输入数据建立时间15h1.5ns
输入数据保持时间08h0.8ns
SPD版本号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);

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



 

• 电容式与CCD联合检测条干均匀度仪分析
• 基于双通道12位DAC的高精度直流电压/电流源
• 简易锂电池保护IC测试电路的设计及特点
• 电力变压器固体绝缘故障的诊断方法
• 热敏电阻典型用途及所具特点
• 浅谈电解电容检测及选用
• 基于双通道12位DAC的高精度直流电压/电流源
• 电子元件的复合化和印制板埋置元件化发展
• 如何选用LCR电桥及如何认识电阻、电容、电感
• 基于CAN总线分布式控制系统智能节点的设计

模具 | 风机 | 减速机 | 液压与气动 | 泵真空设备
食品/饮料/烟草机械 | 电子/电气机械 | 通信设备
机械/五金零件 | 金属加工机械 | 锅炉与原动机
缝纫/服装机械 | 包装机械 | 制冷/空调/换热设备
冶金机械设备 | 电厂设备 | 工程机械 | 仪器仪表
纺织印染机械 | 化工机械 | 印刷机械 | 机电设备
农林畜牧机械 | 气体压缩分离设备 | 塑料橡胶机械
其它机械资料
 网站地图 - 广告服务 - 联系我们 - 友情连接 - - 站长邮箱:555jx@163.com QQ:57075944 © 55jx.com 蜀ICP备05026423号