emmc基础技术8:操作模式2-device identification mode
1.前言
eMMC总线操作包含:
- boot mode,
- device identification mode
- interrupt mode
- data transfer mode
本文主要描述device identification mode,本模式下所有的数据通信都只在cmd line上完成,主要完成:
- host reset device
- 检查操作电压范围和访问模式
- 识别设备
- 指定bus上的device RCA(relative device address)
2.device identification mode

图 device identification mode
2.1 概要说明
- 四种情况会进入idle state
. 完成boot操作;
. boot mode下cmd line保持电平时间少于74个时钟;
. power on后,如果不支持boot启动;
. 直接发送CMD0+0x00000000均将进入idle state,从此进入device identification mode的领地
- 进入idle state后
. 输出总线将保持高阻态
. device的RCA 地址会被初始化为0x0001
. 驱动能力设置为默认;
. host提供clock时钟,此时钟为identification clock rate(fod)
- CMD0+0x00000000
除了inactive state, CMD0+0x00000000在任何state下都是有效的,可以将device reset到idle state
注:为了向后兼容,除inactive state,任何状态下如果收到CMD0且参数不是0xffffffa或0xf0f0f0f0,device都将执行reset到idle state;
host在除了Inactive和Pre-boot状态之外使用CMD0+0xFFFFFFFA命令,设备会认为是重启命令且变为Idle状态。
- 访问模式
. SEND_OP_COND(CMD1)命令和OCR寄存器包含了两个位来指明memory所支持的访问模式。
. CMD1内的两个位表明了host是否有能力处理sector寻址,而OCR寄存器内的两个位表明了设备是否支持sector寻址。
OCR寄存器的两个位只有在CMD1命令的最后一个 response中有效(也就是设备进入Ready状态后才有效)
若是host没有指明是否有处理sector寻址的能力的话,大约2GB的memory会把状态切换为Inactive
从OCR寄存器的两个位中,host可以把设备从其他byte寻址的设备中区别开来
. host发送CMD1时,如果device处于busy状态(power up/reset过程中),device会发送固定内容给host, 0x00FF8080(容量小于2GB)或者是0x40FF8080(容量大于2GB), 且不会变化到Inactive state,此时host必须重复发送CMD1直到busy bit被清除
. 若设备在进入Ready state时,表明CMD1执行完毕,device应该给主机回应0x80FF8080(容量小于2G)或0xC0FF8080( 容量大于2G)来表明大小
- 工作电压
. host可能会改变设备的电压。若是host把设备的电压范围设置到一个新的范围,设备应该完全的关闭且以新的电压范围重新启动。 若是电压范围 1.95V-2.7V被使用,双电压设备可能会失败
. 初始化过程中不允许改变电压范围,如果确实需要改变电压范围,host必须要reset device(通过CMD0+0x000000000)然后重新执行初始化进程
. 如果要访问处于inactive state的device,必须执行硬件reset(掉电然后上电)
- inactive state
在data transfer mode下,除sleep state外,其它任何状态下发送CMD15可在需要的时候让device进入inactive state
2.2 设备识别过程

图 设备识别过程
结合上图实例介绍device identification mode过程,环境说明如下:
. 有多个device
. 且向前兼容到规范4.0
. 开始执行devie identification过程时,host必须处在open-drain模式(CMD line为open-drian则允许在设备识别阶段多个设备并行操作)
. identification clock为fod
1.device被激活后(bus一般是进入idle state)后,host发送CMD1请求device发送它的有效的操作电压范围,如果不兼容的设备将进入inactive state,如果兼容设备将发送回应给host告知其电压操作条件
2.host发送CMD2,要求所有device回复它的CID,任何未识别设备(如处于ready state)一个一个发送CID给host
3.若是有些设备发送的CID和它们标示的CID不符合,则立即停止发送CID且必须等待下一个识别周期(保持在Ready状态), 因为CID是每个设备的唯一识别码,应只有一个设备成功的发送其全部的CID数字到host。此设备随即进入到Identification状态
4. 此后host发送CMD3(SET_RELATIVE_ADDR)命令来给此设备指定一个RCA(Relative Device Address),此RCA比CID码短且会在将来data transfer mode(一般clock rate会高于fod)中用于寻址设备
6.一旦device 收到RCA,device将进入stand by state, 且设备不会对未来的识别周期做出任何反应
7.device将open-drain调整为push-pull
8.host重复其识别过程,即,CMD2和CMD3命令,如果没有设备响应这个命令(通过识别超时),则认为所有device识别结束。
注:识别超时是发送CMD2之后超过Nid时钟周期之后没有device回应start位,则判定为识别超时。
3.参考文档
[1]http://www.jedec.org/sites/default/files/docs/JESD84-B51.pdf
emmc基础技术8:操作模式2-device identification mode的更多相关文章
- eMMC基础技术2:eMMC概述
0.前言 本文主要参考eMMC规范,从总体上对eMMC 进行简要介绍.主要包含如下的内容: (1)eMMC系统的总体架构 (2)eMMC的总线协议 (3)device controller (4)fl ...
- eMMC基础技术3:eMMC总线token
1.前言 本文主要介绍eMMC 总线协议相关的内容,主要包括: (1)command token format (2)response token format (3)data packet form ...
- emmc基础技术8:操作模式3-interrupt mode
1. 前言 eMMC总线操作包含: boot mode, device identification mode interrupt mode data transfer mode 本文主要描述inte ...
- eMMC基础技术8:操作模式1-boot mode
1.前言 eMMC总线操作包含: boot mode device identification mode interrupt mode data transfer mode 本文主要描述boot m ...
- emmc基础技术8:操作模式4-data transfer mode
1.前言 eMMC总线操作包含: boot mode, device identification mode interrupt mode data transfer mode 本文主要描述data ...
- eMMC基础技术4:eMMC command
1.前言 本文主要对eMMC的command进行详细介绍,主要包含如下内容: (1)command类型 (2)command格式 2.command类型 command类型 说明 bc 不带respo ...
- eMMC基础技术11:flash memory
[转]http://www.wowotech.net/basic_tech/367.html 0.前言 eMMC 是 Flash Memory 的一类,在详细介绍 eMMC 之前,先简单介绍一下 Fl ...
- eMMC基础技术9:分区管理
[转]http://www.wowotech.net/basic_tech/emmc_partitions.html 0.前言 eMMC 标准中,将内部的 Flash Memory 划分为 4 类区域 ...
- eMMC基础技术1:MMC简介
[转]http://www.wowotech.net/basic_tech/mmc_sd_sdio_intro.html 1. 前言 熟悉Linux kernel的人都知道,kernel使用MMC s ...
随机推荐
- 自学Linux Shell6.3-系统环境变量持久化
点击返回 自学Linux命令行与Shell脚本之路 6.3-系统环境变量持久化 在你登录Linux系统启动一个bash shell时,默认情况下bash在几个文件中查找命令,这几个文件成为启动文件:b ...
- [hgoi#2019/2/18]比较水
T1--调换纸牌(card) Alex有 n张纸牌,每张纸牌上都有一个值ai,Alex把这些纸牌排成一排,希望将纸牌按值从小到大的顺序排好.现在他把这个任务交给你,你只能进行一种操作:选中一张牌,然后 ...
- Raid卷详解
#RAID卷 独立磁盘冗余阵列RAID是一种把多块独立的硬盘(物理硬盘)按不同的方式组合起来形成一个硬盘组(逻辑硬盘),从而提供比单个硬盘更高的存储性能和提供数据备份技术.组成磁盘阵列的不同方式成为R ...
- 牛客网小白月赛5I区间(差分数组)
链接:https://www.nowcoder.com/acm/contest/135/I来源:牛客网 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 32768K,其他语言65536 ...
- Java需要强制捕获的异常
Java编译器要求我们强制捕获Excetion,但不包括RuntimeException 不强制要求捕获Error和RuntimeException是因为,这两种异常我们程序一般无能为力,而其他Exc ...
- HTML的前世今生
HTML的基础知识扫盲 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 三年前,我就听周围的一些工程师说,python就是一个脚本语言,没啥好学的,学JAVA吧,python能干的J ...
- 如何解决win7系统无法运行cmd命令提示符
如何解决win7系统无法运行cmd命令提示符 CMD命令可以帮助我们很快的执行所需要的程序命令,可以查询系统中很多的信息和解决系统很多的故障,对我们来说非常方便,但是最近有用户反馈自己win7电脑 ...
- ajax跨域原理和cors跨域资源共享
不需要设置前端太多,只需要在服务端是在请求头,使服务端的回复数据可以正常通过浏览器的限制,进入网站 首先说下简单请求和非简单请求: 简单请求:必须满足下列条件 1.请求方式:head,get,post ...
- vue基础篇---路由的实现
路由可以有两种实现方式,一种是标签形式的,一种是js实现. 标签: <router-link to='/city'> 北京 </router-link> 标签还有另外一种实现方 ...
- gitlab与pycharm结合
一切都在图中 点开pycharm里的菜单选项 设置git代码仓库的地址 修改了代码之后,如何推送到git服务器上 通过pycharm下载代码仓库 pycharm中如何设置分支 pycharm新建了分支 ...