MMC/SD/SDIO介绍 - 创龙小识堂 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 2761|回复: 0

MMC/SD/SDIO介绍

[复制链接]

12

主题

169

帖子

731

积分

QQ游客

积分
731
发表于 2017-1-20 16:00:51 | 显示全部楼层 |阅读模式
1. 前言
熟悉Linux kernel的人都知道,kernel使用MMCsubsystem统一管理MMC、SD、SDIO等设备,为什么呢?到底什么是MMC?SD和SDIO又是什么?为什么可以用MMC统称呢?
在分析Linux kernelMMC subsystem之前,有必要先介绍一些概念,以便对MMC/SD/SDIO有一个大致的了解,这就是本文的目的。

2. 基本概念
MMC是MultiMediaCard的简称,从本质上看,它是一种用于固态非易失性存储的内存卡(memory card)规范[1],定义了诸如卡的形态、尺寸、容量、电气信号、和主机之间的通信协议等方方面面的内容。
从1997年MMC规范发布至今,基于不同的考量(物理尺寸、电压范围、管脚数量、最大容量、数据位宽、clock频率、安全特性、是否支持SPI mode、是否支持DDR mode、等等),进化出了MMC、SD、microSD、SDIO、eMMC等不同的规范(如下面图片1所示)。虽然乱花迷人,其本质终究还是一样的,丝毫未变,这就是Linux kernel将它们统称为MMC的原因。
1.png
图 1
关于该图片,这里强调几点:
MMCSDSDIO的技术本质是一样的(使用相同的总线规范,等等),都是从MMC规范演化而来:
1.MMC强调的是多媒体存储(MMMultiMedia);
2.SD强调的是安全和数据保护(SSecure);
3.SDIO是从SD演化出来的,强调的是接口(IOInput/Output),不再关注另一端的具体形态(可以是WIFI设备、Bluetooth设备、GPS等等)。

3. 规范简介

MMC分别从卡(CardConcept)、总线(Bus Concept)以及控制器(Host Controller)三个方面,定义MMC system的行为,如下面图片2所示:
2.png
图 2
不同岗位的工程师,可以根据自己的工作性质,重点理解某一部分的规范,下面从嵌入式软件工程师的视角,简单的介绍一下。
3.1 卡的规范

卡的规范主要规定卡的形状、物理尺寸、管脚,内部block组成、寄存器等等,以eMMC为例:
3.png
图 3
1)有关形状、尺寸的内容,这里不再介绍,感兴趣的同学可参考[1]
2)卡的内部由如下几个block组成:
Memory core,存储介质,一般是NAND flashNOR flash等;
Memory core interface,管理存储介质的接口,用于访问(读、写、擦出等操作)存储介质;
Card interfaceCMDCLKDATA),总线接口,外界访问卡内部存储介质的接口,和具体的管脚相连;
Card interface controller,将总线接口上的协议转换为Memorycore interface的形式,用于访问内部存储介质;
Power模块,提供reset、上电检测等功能;
寄存器(图片1中位于Card interface controller的左侧,那些小矩形),用于提供卡的信息、参数、访问控制等功能。
3)卡的管脚有VDDGNDRSTCLKCMDDATA等,VDDGND提供powerRST用于复位,CLKCMDDATAMMC总线协议(具体可参考3.2小节)的物理通道:
CLK有一条,提供同步时钟,可以在CLK的上升沿(或者下降沿,或者上升沿和下降沿)采集数据;
CMD有一条,用于传输双向的命令。
DATA用于传说双向的数据,根据MMC的类型,可以有一条(1-bit)、四条(4-bit)或者八条(8-bit)。
4)以eMMC为例,规范定义了OCR,CID, CSD, EXT_CSD, RCA 以及DSR 6组寄存器,具体含义后面再介绍。
3.2 总线规范
前面我们提到过,MMC的本质是提供一套可以访问固态非易失性存储介质的通信协议,从产业化的角度看,这些存储介质一般集成在一个独立的外部模块中(卡、WIFI模组等),通过物理总线和CPU连接。对任何有线的通信协议来说,总线规范都是非常重要的。关于MMC总线规范,简单总结如下:
1)物理信号有CLKCMDDATA三类。
2)电压范围为1.65V3.6V(参考上面图片2),根据工作电压的不同,MMC卡可以分为两类:
High Voltage MultiMediaCard,工作电压为2.7V~3.6V
Dual Voltage MultiMediaCard,工作电压有两种,1.70V~1.95V2.7V~3.6VCPU可以根据需要切换。
3)数据传输的位宽(称作data buswidth mode)是允许动态配置的,包括1-bit (默认)模式、4-bit模式和8-bit模式。
1:不使用的数据线,需要保持上拉状态,这就是图片2中的DATA中标出上拉的原因。另外,由于数据线宽度是动态可配的,这要求CPU可以动态的enable/disable数据线的那些上拉电阻。
4MMC规范定义了CLK的频率范围,包括0-20MHz0-26MHz0-52MHz等几种,结合数据线宽度,基本决定了MMC的访问速度。
5)总线规范定义了一种简单的、主从式的总线协议,MMC卡位从机(slave),CPU为主机(Host)。
6)协议规定了三种可以在总线上传输的信标(token):
CommandHost通过CMD线发送给Slave的,用于启动(或结束)一个操作(后面介绍);
ResponseSlave通过CMD线发送给Host,用于回应Host发送的Command
DataHostSlave之间通过数据线传说的数据。方向可以是HostSlave,也可以是SlaveHost。数据线的个数可以是14或者8。在每一个时钟周期,每根数据线上可以传输1bit或者2bits的数据。
7)一次数据传输过程,需要涉及所有的3个信标。一次数据传输的过程也称作Bus Operation,根据场景的不同,MMC协议规定了很多类型的Bus Operation(具体可参考相应的规范)。
3.3 控制器规范
Host控制器是MMC总线规范在Host端的实现,也是Linux驱动工程师比较关注的地方,后面将会结合Linux MMC framework的有关内容,再详细介绍。

4. 总结
本文对MMC/SD/SDIO等做了一个简单的介绍,有了这些基本概念之后,在Linux kernel中编写MMC驱动将不再是一个困难的事情(因为MMC是一个协议,所有有关协议的事情,都很简单,因为协议是固定的),我们只需要如下步骤即可完成:
1)结合MMC的规范,阅读HostMMC controllerspec,理解有关的功能和操作方法。
2)根据Linux MMCframework的框架,将MMC bus有关的操作方法通过MMC controller实现。
具体可参考后续MMC framework的分析文档。
本文档转载自:

http://www.wowotech.net/basic_tech/mmc_sd_sdio_intro.html



回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|嵌入式开发者社区 ( 粤ICP备15055271号

GMT+8, 2024-3-29 01:04 , Processed in 0.045817 second(s), 30 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

快速回复 返回顶部 返回列表