【eMMC协议】6.2.4 - 6.3.4

6.2.4 - 6.3.4

  1. 配置分区:
  • 增强分区的起始地址,需要与写保护组对齐。

  • 配置分区参数时,需要设置ext_csd中的ERASE_GROUP_DEF位说明使用高容量擦除组的大小以及高容量写入保护组的大小。需要注意的是,先设置ERASE_GROUP_DEF位,接着使用CMD6命令发送分区参数到EMMC,否则会显示SWITCH_ERROR 。

两个概念:High Capacity Write Protect Group Sizes类似
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uDthTE9I-1689324563272)(C:\Users\bw002421\AppData\Roaming\Typora\typora-user-images\1685631788731.png)]

  • 设置好分区,并且分区保持稳定后,class5和class6的命令就可以在高容量擦除组合和高容量保护组上使用。

  • PARTITION_SETTING_COMPLETED --》bit0,保护分区信息,避免突然掉电影响。

  • 检查分区是否正确指令 ---- CMD13,任一参数出错都会报错(SWITCH_ERROR) , 因为这种情况下,device 无法确定配置分区和用户分区的具体大小 。

  • 由于分区信息,只能写入一次,当向device发出CMD6命令,对GPP分区和增强用户数据分区进行更改,则EMMC会在接收CMD6响应的状态寄存器中报错SWITCH_ERROR,不会执行任何内部操作。 但可以通过CMD8获取分区配置信息。

  1. 访问分区
  • 配置完分区后,在读写擦前,需要将ERASE_GROUP_DEF置1,因为该bit上电后将会被重置

  • 访问分区流程:

    • 在ext_csd的PARTITION_CONFIG字段设置PARTITION_ACCESS,才能访问其中一个分区。
    • 对确定要访问的分区发送访问命令 。
    • 访问完后恢复默认User Data Area分区的访问权限,或者对下一个分区进行访问。
  • 特殊的,CMD0或者硬件复位时, host 首先会获得对默认UDA分区的访问权限 。若意外掉电, 默认情况下host将恢复对UDA分区的访问 。

  1. boot操作模式

    1) 在该模式下,host 有两种方式访问到EMMC内存boot 分区存储的系统引导数据 。

    • 持续拉低CMD0
    • 在发送CMD1 命令之前,发送 参数为0xFFFFFFFA的CMD0命令

    2) 引导分区

    • 两个boot 分区,与用户分区分开。每个引导分区的最小容量为128KB,boot 分区的容量计算公式为: 最大boot 分区容量等于 128KB 乘以BOOT_SIZE_MULT,其中BOOT_SIZE_MULT定义为ex_csd寄存器第226位字节数 。
    • 设备的boot配置在ext_csd register byte [179]。主机能通过CMD6设置该值进行boot配置。除此之外,还能设置ext_csd register byte [179] 为0x111b配置 BOOT_PARTITION_ENABLE bit,来让设备从用户分区启动。

    3) boot操作

    • CMD持续拉低74个clock

    • 在提前使能ext_csd寄存器第162字节的前提下,接收参数为0xF0F0F0F0的CMD0命令

    • 进行硬件复位操作信号

    boot开始初始化, host读取ext_csd寄存器中的179字节中的bit[5:3],选择启动分区,然后读取启动需要的数据。 同时在boot 启动过程中能通过计算公式 (128KB × BOOT_SIZE_MULT (EXT_CSD byte [226])) 获得用于boot的分区中存储的数据大小。

    ​ boot启动时,host传输可以采用高速率模式, 可以通过设置ext_xsd寄存器的第177字节的[4:3]位来实现。 当ext_cd寄存器第177字段中的[4:3]被设置成’10’时,host 就可以选择双倍速率模式传输速率,同时ext_csd寄存器的第228字段的bit 1会通知host, 对应的EMMC 是否在boot 模式支持双倍传输速率。

    PS: 不支持HS200和HS400数据传输模式

    • 检测是否处于boot模式 ----- ext-csd 寄存器的第179字节的bit6置1 来选择接收EMMC的boot 识别过程(boot ack)。如果打开了boot ack,CMD拉低的情况下,host能够在50ms内收到“010”信号。

    • 如果CMD线拉高的情况下,host会终止boot 模式启动,如果host在数据传输中间拉高将cmd线拉高,则EMMC将会终止数据传输。

    • 在boot 操作启动执行期间,EMMC(slave)会准备好用于CMD1操作的数据,同时host 需要发送CMD1,进而启动正常的MMC初始化序列,当所有用于boot 启动的数据全部发送至host后,boot 操作就会停下来 。
      CMD1,进而启动正常的MMC初始化序列,当所有用于boot 启动的数据全部发送至host后,boot 操作就会停下来 。

    • 如果在发出CMD1之前,CMD信号在上电后保持低电平时间少于74个clock,或者在初始化boot之前,主设备发送除CMD0(参数为0xFFFFFFFA)以外的任何正常EMMC命令,则EMMC不会进行响应。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Blank_time

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值