1.前言

本文主要介绍eMMC 总线协议相关的内容,主要包括:

(1)command token format

(2)response token format

(3)data packet format

(4)CRC token

(5)bus speed mode

2. command token format

图 cmd token format
  • 总长度48bits;
  • 固定以0开始,以1结束;
  • transmiter bit表示数据的传输方向,1代表从host to device;
  • 通过CRC7保护,device 端在接收到CMD时同样会计算一个CRC值,如果与host发送的CRC不一致,则被认为是传输错误;
详情请参考 eMMC基础技术3:eMMC command

3. response token format

图 response token format
  • 有5种格式,使用哪种格式依赖于CMD,长度为48bits或136bits;
  • start bit 总是0,在没有数据传输的情况下,CMD 信号保持高电平,当 eMMC Device 将 Start Bit 发送到总线上时,Host 可以很方便检测到该信号,并开始接收 Response
  • transmitter bit代表传输方向,0表示device to host;
  • Content 为 Response 的具体内容,不同的 Command 会有不同的 Content
  • CRC7 是包含 Start Bit、Transmission Bit 和 Content 内容的 CRC 校验值
  • End Bit 为结束标志位,固定为"1"。

4. data packet format

(1) 1bit sdr传输

     图 1bit bus sdr传输
start bit + data + crc + end bit
 
1bit sdr只使用了DATA0数据线,对于1个block(block length=512BYTE)来讲,需要花费block length * 8 cycles
 
(2)4bit sdr传输
       图 4bit bus sdr传输
对于1个block(block length=512BYTE)来讲,需要花费block length  * 8 / 4 = block length *2 cycles
(3)8bit sdr传输
 
         图 8bit bus sdr传输
对于1个block(block length=512BYTE)来讲,对于1个block(block length=512BYTE)来讲,需要花费block length * 8 / 8 = block length cycles
 
(4)4bit bus ddr传输
图 4bit bus ddr传输
ddr传输时,上升沿和下降沿都会传输数据,对于1个block(block length=512BYTE)来讲,需要花费block lenght * 8 / 4 / 2 = block length cycles
 
(5)8bit bus ddr传输
 
 
图 8bit bus ddr传输
 
ddr传输时,上升沿和下降沿都会传输数据,对于1个block(block length=512BYTE)来讲,需要花费block lenght * 8 / 8 / 2 = block length / 2 cycles
 
在 DDR 模式下,Data Line 在时钟的上升沿和下降沿都会传输数据,其中上升沿传输数据的奇数字节 (Byte 1,3,5 ...),下降沿则传输数据的偶数字节(Byte 2,4,6 ...)。
此外,在 DDR 模式下,1 个 Data Line 上有两个相互交织的 CRC16,上升沿的 CRC 比特组成 odd CRC16,下降沿的 CRC 比特组成 even CRC16。
odd CRC16 用于校验该 Data Line 上所有上升沿比特组成的数据,even CRC16 则用于校验该 Data Line 上所有下降沿比特组成的数据
(6)8bit ddr for hs400 
 
图 8bit ddr for hs400
hs400 高电平或低电平用于传输数据,对于1个block(block length=512BYTE)来讲,需要花费block lenght * 8 / 8 / 2 = block length / 2 cycles

5. CRC status token

在写数据传输中,eMMC Device 接收到 Host 发送的一个 Data Block 后,会进行 CRC 校验

  • 如果校验失败,device则会在对应的 Data Line 上向host发送一个 Negative CRC status token (101)
  • 如果校验成功,device则会在对应的 Data Line 上向host发送一个 Positive CRC status token (010)

注:读数据时,Host 接收到 eMMC Device 发送的 Data Block 后,也会进行 CRC 校验,但是不管校验成功或者失败,都不会向 eMMC Device 发送 CRC Status Token

详细格式如下图所示:

图 DR52 Positive CRC status token

图 DDR52 Negative CRC status token

6. 参考文档

[1]http://www.wowotech.net/basic_tech/emmc_bus_protocol.html

[2]http://www.jedec.org/sites/default/files/docs/JESD84-B51.pdf

eMMC基础技术3:eMMC总线token的更多相关文章

  1. eMMC基础技术2:eMMC概述

    0.前言 本文主要参考eMMC规范,从总体上对eMMC 进行简要介绍.主要包含如下的内容: (1)eMMC系统的总体架构 (2)eMMC的总线协议 (3)device controller (4)fl ...

  2. eMMC基础技术1:MMC简介

    [转]http://www.wowotech.net/basic_tech/mmc_sd_sdio_intro.html 1. 前言 熟悉Linux kernel的人都知道,kernel使用MMC s ...

  3. eMMC基础技术11:flash memory

    [转]http://www.wowotech.net/basic_tech/367.html 0.前言 eMMC 是 Flash Memory 的一类,在详细介绍 eMMC 之前,先简单介绍一下 Fl ...

  4. eMMC基础技术9:分区管理

    [转]http://www.wowotech.net/basic_tech/emmc_partitions.html 0.前言 eMMC 标准中,将内部的 Flash Memory 划分为 4 类区域 ...

  5. eMMC基础技术7:Bus Speed Modes

    1. 前言 eMMC有多种速率模式,主要根据如下几个方面进行划分: single rate or dual rate I/O电压 BUS宽度 支持的clock频率范围 最大的传输速率 2. 概览 图 ...

  6. emmc基础技术8:操作模式3-interrupt mode

    1. 前言 eMMC总线操作包含: boot mode, device identification mode interrupt mode data transfer mode 本文主要描述inte ...

  7. emmc基础技术8:操作模式2-device identification mode

    1.前言 eMMC总线操作包含: boot mode, device identification mode interrupt mode data transfer mode 本文主要描述devic ...

  8. eMMC基础技术6:eMMC data读写

    1. 前言 data可以经data线从host发往device,也可以从device发往host 数据线以是1线(DATA0),4线(DATA0~DATA3),8线(DATA0~DATA7) 对每条数 ...

  9. eMMC基础技术8:操作模式1-boot mode

    1.前言 eMMC总线操作包含: boot mode device identification mode interrupt mode data transfer mode 本文主要描述boot m ...

随机推荐

  1. Xshell5

    Xshell5 -------- Xshell5默认属性 备份样式 --------------------------

  2. hadoop 伪分布式搭建

    下载hadoop1.0.4版本,和jdk1.6版本或更高版本:1. 安装JDK,安装目录大家可以自定义,下面是我的安装目录: /usr/jdk1.6.0_22 配置环境变量: [root@hadoop ...

  3. 剑指Offer_编程题_8

    题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级.求该青蛙跳上一个n级的台阶总共有多少种跳法. class Solution { public: int jumpFloor(int number ...

  4. 访问内网(https,udp)

    安装teamview 客户端. 安装vpn驱动(这里的VPN应该是A主机与B客户端分别连接上了teamview的服务器,但是本身不是局域 网,所以不能直接访问A的局域网的其他主机) 主机端A,安装主机 ...

  5. linux优化之系统参数调优篇

    linux优化之系统参数调优篇 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.用户限制配置文件(首先需要编辑/etc/security/limits.conf文件) 大家可以 ...

  6. MyBatis-DynamicSQL 动态SQL

    MyBatis 的动态 SQL 使用 OGNL 表达式 http://commons.apache.org/proper/commons-ognl/language-guide.html 在 XML ...

  7. vue中v-show与v-if的区别

    v-show 手段:通过设置DOM元素的display样式属性控制显隐: 编译过程:v-show只是简单的基于css切换: 编译条件:v-show是在任何条件下(首次条件是否为真)都被编译,然后被缓存 ...

  8. 原生JavaScript运动功能系列(一):运动功能剖析与匀速运动实现

    在我们日常生活中运动就是必不可少的部分,走路.跑步.打篮球等.在网页交互设计上运动也是必不可少的部分,创建的网站交互设计运动模块有轮播图,下拉菜单,还有各种炫酷的游戏效果都跟运动密切相关.所以很重要, ...

  9. 学习总结:CSS(二)块级与行级元素特性、盒模型、层模型、BUG与BFC、浮动模型

    一.元素的块级与行级特性 在CSS属性display控制元素是否及如何显示的特性,常用的值有none.inline.block.inline-block,在CSS3中还有一些新的特性状态,在这里不做讨 ...

  10. Chrome刷新缓存

    Ctrl+Shift+Del  清除Google浏览器缓存的快捷键  Ctrl+Shift+R  重新加载当前网页而不使用缓存内容