SD卡协议学习点滴(三)

转载 2012年03月28日 15:43:43

宽总线选择/取消选择

宽总线(4bit)模式可以通过ACMD6选择/取消选择,默认工作模式为1bit模式。

为了改变总线宽度,以下两个条件须满足:1. SD卡处于Transfer 状态 2.SD卡未被锁定

2Gbyte SD卡:

为使用2Gbyte的SD卡,Maximum Block Length(READ_BL_LEN=WRITE_BL_LEN)参数须设置为1024byte。但是,由CMD6设置的Block Length须为512byte,从而可与最大仅可使用512byte Block Length的SD卡相兼容

读数据

DAT线上没有数据传输时,由外部上拉电阻保持为高电平。传输数据块由一个起始比特(1或者4个比特的低电平),以及紧跟着的连续数据流组成。数据流包含有效载荷数据(以及错误校验比特,如果有使用到ECC)。数据流以数据结束标识符结束(1或者4比特的高电平)。数据传输和时钟信号是同步的。有效载荷数据后紧跟着1比特或者4比特的CRC校验码

读命令在出现BLOCK_LEN_ERROR 或者ADDRESS_ERROR的情况下可以被否决,这种情况下,不会发生数据传输过程

块读操作

块传输下,基本的数据传输单位是块,它最大为512byte,小一些的块传输也是可以的,如果它指向的内容其地址范围处于以512字节为边界的某块内(譬如 地址范围为200~300的传输是可以的,但是地址范围为500~600因为地址横跨了两个块,则不可行

由CMD16设置的Block Length参数最大可为512byte,而与READ_BL_LEN的大小无关

块数据的结尾都附加有CRC校验码,用以保证传输数据的完整性。CMD17(READ_SINGLE_BLOCK)发起单次的块传输,传输结束后,SD卡返回Transfer状态,CMD18(READ_MULTIPLE_BLOCK)开始多个连续块的数据传输。块传输会一直持续下去,除非收到一条STOP_TRANSMISSION命令(CMD12)。停止传输命令会有执行上的延迟,因为它是串行传输的,数据传输会在stop命令的停止位之后结束

If the host uses partial blocks whose accumulated length is not block aligned and block misalignment is
not allowed, the card shall detect a block misalignment at the beginning of the first misaligned block, set
the ADDRESS_ERROR error bit in the status register, abort transmission and wait in the Data State for
a stop command.
If the misaligned block is the first data block of the command (i.e. ADDRESS_ERROR was reported in
the actual response to the command), then no data is transferred and the card remains in the TRAN
state.


上面一段讲的是misalignment,理解不够,直接贴英文了

写数据

数据写传输类似读传输,块数据传输的话,在每块数据后面附加有CRC校验码

当出现BLOCK_LEN_ERROR 或者ADDRESS_ERROR时,写命令会被拒绝,并不会发生实际的数据传输

写数据块

写数据块命令(CMD24-27, 42, 56(w))会将一块或多块数据写入SD卡,支持块写入操作的SD卡要求由命令CMD16设定的块长度(Block Lenghth)为512byte,而不管WRITE_BL_LEN是1K还是2K

下表给出了部分写入禁止(WRITE_BL_PARTIAL=0)情况下SD卡的写入行为


如果WRITE_BL_PARTIAL=1,则更小块数据的写入--精度可以为1byte---是可以进行的。如果CRC校验失败,SD卡会在DAT线上给出相应的指示,已传输数据会被丢弃,并且这其后所传输的数据块(在多块写入模式下)也会被忽略

编程CSD寄存器并不需要先前设定好的块长度。传输数据同样附加有CRC校验,如果CSD的某部分存储在ROM里面,这个不可改变的部分同样会映射到数据缓存的相应部分(但是这部分数据不会写入),如果这个匹配条件不满足,SD卡会回报一个错误信息,并且此次写入无效

某些SD卡会需要比较长并且不可预期的写入时间。如果SD卡的缓存为满,则其在接收完块数据并完成CRC校验后,SD卡会开始数据的写入,并拉低DAT0。任何时刻,控制器可以通过命令SEND_STATUS(CMD13)主动查询SD卡的状态,SD卡对应的响应其标志位READY_FOR_DATA表明其是否可以接收新数据。

多块写操作之前的预擦除指令

使用预擦除命令(ACMD23)设定多个写入块的预擦除会让随后的多块写入更快完成。控制器一般会使用这个值(擦除多少块)来决定随后的多块数据写入的块数。如果控制器在写入多块数据之前使用stop名林终止数据传输,那么,余下的数据块里面的值是未知的,可能是旧的值,也可能是擦除后的空白值(全1)。如果控制器传输的数据块数多于预擦除指定的块数,,SD卡会以一次擦除一块的操作方式来擦除数据(当收到新数据的时候)。ACMD32所定义的擦除块数会在多块数据写入完成后复位为默认值(1)

建议在每次使用CMD25之前使用此命令。注意ACMD23必须在刚好要使用写入命令之前使用,否则,如果中间穿插了别的命令,可能或把ACMD23所设定的值自动清除

发送可写入块数

在使用流水线机制的系统里面,控制器可能在某些情况下不清楚哪个数据块是最后的可正确写入的块。如果在多块写入中间出现写入错误,SD卡会返回一个ACMD22命令,其间包含了可正确写入块的数值

擦除

同时擦除多块数据在提高数据传输速率方面是很有帮助的,标识这些写入块可以通过命令ERASE_WR_BLK_START(CMD32) ERASE_WR_BLK_END(CMD33)完成

控制器必须使用如下的命令序列来完成所需的操作:ERASE_WR_BLK_START ERASE_WR_BLK_END , ERASE

如果这三个命令的某一个没有按照此顺序来执行,SD卡会置位其ERASE_SEQ_ERROR位,并复位整个执行序列

If an out of sequence command (except SEND_STATUS) is received, the card shall set the
ERASE_RESET status bit in the status register, reset the erase sequence and execute the last
command. ---这段话啥子意思嘛...

如果擦除区域包含了写保护扇区,则这些区域不会被擦除,仅其余部分被擦除。WP_ERASE_SKIP标志位也会置1

在地址设定命令里面包含的地址以字节为单位,SD卡会自动忽略小于WRITE_BL_LEN大小的低位地址信号

如同块写入,在擦除过程中,SD卡也会拉低DAT0。

相关文章推荐

SD卡协议学习点滴(三)

转自:http://hi.baidu.com/narshben/blog/item/98f3e008a778b83fe8248849.html 宽总线选择/取消选择: 宽总线(4b...

SD卡协议学习点滴(二)

数据传输模式: 在SD卡识别模式结束之前,控制器使用的时钟频率均为Fod。在数据传输模式,控制器可能会使用Fpp频率。控制器发送一条SSEND_CSD(CMD9)命令来获取SD卡CSD寄存器(Car...

SD卡协议学习点滴(二)

转自:http://hi.baidu.com/narshben/blog/item/cfcb983e52e36c3271cf6cb2.html 数据传输模式: 在SD卡识别模式结束之前...

SD卡协议学习点滴(一)

首先SD卡有所谓操作模式(operation mode)的概念,每种操作模式又具体对应一种或多种状态,主机通过发送命令可以使SD卡在不同的状态间转换,SD卡则接受命令,并根据自己现在所处状态做出不同的...

sd卡---spi协议

SPI概述   SPI:高速同步串行口。3~4线接口,收发独立、可同步 进行.   SPI,是英语Serial Peripheral interface的缩写,顾名思义就是串行外围设备...

sd卡---spi协议

SPI概述   SPI:高速同步串行口。3~4线接口,收发独立、可同步 进行.   SPI,是英语Serial Peripheral interface的缩写,顾名思义就是串行外围设备...

sd卡2.0协议

  • 2017-02-10 17:47
  • 1.73MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)