嵌入式存储标准:EMMC编程详解
需积分: 29 32 浏览量
更新于2024-08-05
1
收藏 1.58MB PDF 举报
"13_imx6ull_pro之_EMMC编程.pdf"
本文档详细介绍了i.MX6ULL处理器与EMMC(Embedded MultiMediaCard)的编程相关知识,旨在帮助开发者理解如何在基于i.MX6ULL芯片的系统中正确地与EMMC设备进行交互。
1. EMMC介绍
- EMMC是一种嵌入式存储标准,主要用于移动设备如手机、相机和平板电脑。它的设计目标是简化存储器设计,减少电路板空间占用。
- EMMC集成了NAND Flash、控制器以及MMC标准接口,形成一个单一的芯片解决方案。
2. EMMC硬件连接
- CPU通过CLK、CMD、DATA[0-7]和RST信号线与EMMC设备相连。
- 接口信号包括不同模式的数据速率、IO电压、总线位宽、时钟速率和最大数据传输速率,如:
- SDR模式:支持3/1.8/1.2V电压,1、4、8bit总线宽度,最高26MHz时钟,26MHz数据传输速率。
- 高速SDR模式:同上,但时钟可达52MHz,数据传输速率提升至52MHz。
- DDR模式:支持3/1.8/12V电压,4、8bit总线,52MHz时钟,104MHz数据传输速率。
- HS200模式:1.8/12V电压,4、8bit总线,200MHz时钟,200MHz数据传输速率。
- HS400模式:DDR,1.8/12V电压,8bit总线,200MHz时钟,400MHz数据传输速率。
- CLK线提供时钟信号,CMD线用于命令与应答双向传输,RST线用于设备复位,DATA线则进行数据传输,并可以按需配置位宽。
3. 操作模式
- SDR模式下,数据采样发生在时钟上升沿;DDR模式下,数据在时钟的上升和下降沿都被采样。
- 用户上电或复位时,仅DATA0可用于数据传输,根据需求可配置4位或8位数据总线,配置后相应的内部上拉会激活。
4. EMMC编程要点
- 在i.MX6ULL平台中,编程涉及初始化、命令发送、数据读写及错误处理等步骤。
- 初始化过程包括设置时钟频率、配置总线宽度、选择工作模式等。
- 命令发送通常包括读/写命令、擦除命令等,每条命令都有对应的响应码。
- 数据读写涉及DMA(直接内存访问)的使用,以提高传输效率。
- 错误处理是关键,包括CRC校验错误、超时错误、命令执行失败等,需要适当地捕获并处理这些异常情况。
5. 开发参考
- 资料光盘包含的JESD84-B50-1eMMCStandard.pdf提供了官方的EMMC标准详细信息,是开发过程中重要的参考资料。
- https://linux.codingbelief.com/zh/storage/flash_memory/emmc/ 提供了更具体的Linux环境下的EMMC编程实践指导。
总结,理解和掌握i.MX6ULL与EMMC的交互涉及对硬件连接、操作模式、命令结构和错误处理机制的深入理解。正确编程能够确保存储设备的稳定、高效运行,为移动设备提供可靠的存储功能。
264 浏览量
159 浏览量
168 浏览量
169 浏览量
2024-07-11 上传
1203 浏览量
1053 浏览量
338 浏览量
韦东山
- 粉丝: 2w+
- 资源: 23
最新资源
- SAP BC400 课程中文自学笔记
- 北京邮电大学模拟电子技术课件
- Multi 9系列C65系列小型断路器产品目录
- TASCAM MD350快速使用手册.doc
- PLSQL教程.doc
- WAP Push SP接口协议
- Linux Socket Programming by Example [Que 2000 No-Bookmark].pdf
- oracle sql优化100条
- LPC_CAN接受滤波器AFMR设置.pdf
- ARM7数据手册.pdf
- Informix 常见问题处理
- ARM常见疑难问题答疑
- 480中文使用说明书
- 计算机二级 c++(45套试题)
- Spring 开发指南
- Direct3D9初级教程