老古开发网首页
导航:老古开发网首页文章索引文章分类嵌入式系统→[利用SPD实现嵌入式系统中内存自动识别和配置]
| -文章搜索 - 最新文章 - |

利用SPD实现嵌入式系统中内存自动识别和配置

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

       1 SPD规范及数据格式      

       内存的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。 

 





参考文献:
1 intel PC SDRAM Serial Presence Detect (SPD) Specification
2 24C02 datasheet
3 MPC8240 Integrated Processor User,s Manual


欢迎进入老古论坛进行讨论
[嵌入式系统] 相关文章:
TPMS外置编码存储器式轮胎定位技术的电路实现(图)
简介:
TPMS技术及轮胎定位原理 汽车轮胎压力监测系统(TPMS)主要用于在汽车行驶时,适时地对轮胎气压进行自动监测,对轮胎漏气造成低胎压和高温高胎压爆胎进行预警,确保行车安全。 TPMS中的轮胎定位是指系统接受轮胎发射模块发出的信号,并识别、判定出是哪个轮胎的过程。 轮胎重新定位问题的提出 汽车因为前后左右车轮负荷不均、前轮负责转向和前后轴悬挂角度不同等原因,通常各轮胎磨损程度和位置也不同。为了延长轮胎的使用寿命,达到四个轮胎同步均匀磨损的效果,这就需要定期进行轮胎换位。 在轮胎换位的过程中,相应的发射检测模块也会换位。这就导致了原先存储在接收显示模块MCU中的I......

Microchip与CCID共同举办其首届中国嵌入式技术高峰论坛
国际嵌入式技术巡展已经来到中国
用智能马桶实现体温测量与亚健康预测
嵌入式操作系统UC/OSII的内核实现
嵌入式系统开发选择Linux
嵌入式Linux的GDB远程调试的实现
单片机的快速启动技术
Linux内核解读入门
Tensilica处理器内核新增六家合作伙伴
 
下一个:[嵌入式系统]基于单片机仿真器的设计
简介:
1 概 述   SST89C54/58(简称89C54/58)是美国SST公司推出的多用途51系列单片机,片内集成了20 kB/36 kB的SuperFlashE''PROM程序存储器,分为BLOCK0(16kB/32kB)和BLOCKl(4kB)两块。其中,BLOCKl可以映射(Mapping)到64kB存储空间的最高端或最低端,而且,对于程序计数器来说可以是不可见的。由于其存储结构上独特的优点,使得89C54/58非常适合于用做单片机仿真器。 &......
 

上一个:[嵌入式系统]一种单片机测控通用系统

老古开发网版权所有 2006年9月 asp.Net V2.0 设计:老古
页面缓存:否 执行时间:16毫秒