|
|||
![]() |
您现在的位置: 中国EDA技术网 >> 文章中心 >> 嵌入式系统 >> 嵌入式操作系统 >> 文章正文 | 用户登录 新用户注册 |
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| 利用SPD实现嵌入式系统中内存的自动识别和配置 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| 作者:赵 静 陈… 文章来源:电子技术应用 点击数: 更新时间:2004-6-2 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
在嵌入式系统设计中经常用大容量的SDRAM,存放RTOS和数据。这时用户可以有两种选择:一种是选用合适的内存芯片自己布线,把整个SDRAM做到嵌入式系统的PCB板上,这种方法在小系统中经常采用;另一种就是选用现成的内存条(如笔记本电脑上常用的DIMM内存),现成的内存条不仅容量大,而且由于用量大,价格也相对便宜。另外现成的内存条还节省了PCB布线空间,缩小嵌入式系统的内存体积,提高系统的稳定性,方便更换和检测。笔记本内存的型号和种类很多,采购时也可能来自多个厂家。为了使各种内存条在嵌入式系统都能正常使用,就需要系统的BOOT程序能进行自动识别和配置,按照SPD(SDRAM Serial Presence Detect Specification)规范正确读取内存参数,另外根据内存参数配置SDRAM控制器。 内存的SPD规范是SDRAM控制器参数配置的主要依据,在SPD规范中定义了单面或双面DRAM的详细参数,如内存的大小、数据位、行列地址的宽度、逻辑Bank数和物理Bank等。这些数据存放在EEPROM芯片中,详细描述了内存条的各种参数。 存放内存参数的是一个两线制的串行EEPROM芯片,接口类型符合I2C协议。I2C协议是Philips公司制定的两线制的串行数据传输标准,数据的读写通过一根时钟线和一根数据线实现。数据传输有其严格的格式,一个数据帧由起始位、器件地址、应答位、数据地址、传输数据和结束位构成,可以允许多个器件分主从模式进行传输。其数据传输时序如图1所示。主控制器读写数据的格式如图2所示。
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); 其它寄存器按此顺序配置。 |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| 文章录入:方丈 责任编辑:方丈 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| 【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口】 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| 最新热点 | 最新推荐 | 相关文章 | ||
| 中国嵌入式系统专家委员会筹 用IXP网络处理器设计的数字家 开放源码:嵌入式系统开发面 小型燃料电池实现直接与笔记 适宜于嵌入式多媒体应用的Fl 基于S1C33L11的JPEG图像实时 网元管理系统中的嵌入式管理 SAF-TE技术在磁盘阵列背板中 TCP/IP协议栈在嵌入式芯片上 用I2C总线扩展I/O |
网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!) |
| | 欢迎投稿 | 网站简介 | 网站地图 | 广告服务 |联系我们 | 友情链接 | 版权申明 | | |
| 本站所载文章力求原创,部分文章来源网上,转载本站文章均注明出处,我们鼓励原创,欢迎投稿 假如我们发布的某些文章侵犯了您的权益,请联系我们,我们将在最短的时间内删除相关文章。 同时我们提供了一个电子爱好者自由交流的平台,欢迎大家参与讨论。点击进入 |
|