有关SD卡接口及其内部寄存器请看这里!SD卡简单介绍

CSDN真的 ctrl+z 慎用!不知道那些工程师是怎么想的!垃圾 ~


SD总线传输

SD 总线通信是基于命令和数据传输的。通讯由一个起始位 (“0”),由一个停止位 (“1”) 终止。SD 通信一般是主机发送一个命令 (Command),从设备在接收到命令后作出响应 (Response),如有需要会有数据 (Data) 传输参与。

无响应和无数据模式

来自STM32F10xxx中文参考手册

块读取操作

来自STM32F10xxx中文参考手册

块写操作

SD 数据是以块 (Black) 形式传输的,SDHC卡数据块长度一般为512字节,数据可以从主机到卡,也可以是从卡到主机。数据块需要CRC位来保证数据传输成功。CRC位由SD卡系统硬件生成。

来自STM32F10xxx中文参考手册

SD 数据传输支持单块和多块读写,它们分别对应不同的操作命令,多块写入还需要使用命令来停止整个写入操作。数据写入前需要检测 SD 卡忙状态,因为 SD 卡在接收到数据后编程到存储区过程需要一定操作时间。SD 卡忙状态通过把 D0 线拉低表示。

连续读操作

来自STM32F10xxx中文参考手册

连续写操作

来自STM32F10xxx中文参考手册

SD卡数据包

使用 4 数据线传输时,每次传输 4bit 数据,每根数据线都必须有起始位、终止位以及 CRC 位, CRC 位每根数据线都要分别检查,并把检查结果汇总然后在数据传输完后通过 D0 线反馈给主 机。

SD卡有两种数据包格式。

  • 常规数据(8位宽度):常规数据(8位宽度)首先以LSB(最低有效字节)顺序发送,最后以MSB(最高有效字节)顺序发送。但在单个字节中,它首先是MSB(最高有效位),最后是LSB(最低有效位)。
  • 宽数据(SD内存寄存器):宽数据从MSB位移位。

常规数据格式

来自[野火]《STM32库开发实战指南》

DAT3 数据线发较高位,DAT0 数据线发较低位。先发低字节再发高字节,每个字节先发高位再发低位。每根线发送一个字节的其中两位。

宽位数据包格式

对 SD 卡而言宽位数据包发送方式是针对 SD 卡 SSR(SD 状态) 寄存器内容发送的,SSR 寄存器总共有 512bit,在主机发出 ACMD13 命令后 SD 卡 将 SSR 寄存器内容通过 DAT 线发送给主机。

来自[野火]《STM32库开发实战指南》

命令格式

命令编码格式

来自[野火]《STM32库开发实战指南》

命令组成:

  • 起始位和终止位:命令的主体包含在起始位与终止位之间,它们都只包含一个数据位,起始位为 0,终止位为 1。
  • 传输标志:用于区分传输方向,该位为 1 时表示命令,方向为主机传输到 SD 卡,该位为 0 时表示响应,方向为 SD 卡传输到主机。
  • 命令号:它固定占用 6bit,所以总共有 64 个命令 (代号:CMD0~CMD63),每个命令都有特定的用途,部分命令不适用于 SD 卡操作,只是专门用于 MMC 卡或者 SD I/O 卡。
  • 地址/参数:每个命令有 32bit 地址信息/参数用于命令附加内容,例如,广播命令没有地址信息,这 32bit 用于指定参数,而寻址命令这 32bit 用于指定目标 SD 卡的地址。
  • CRC7 校验:长度为 7bit 的校验位用于验证命令传输内容正确性,如果发生外部干扰导致传输数据个别位状态改变将导致校准失败,也意味着命令传输失败,SD 卡不执行命令。

命令类型

SD 命令有 4 种类型:

  • 无响应广播命令 (bc),发送到所有卡,不返回任务响应;
  • 带响应广播命令 (bcr),发送到所有卡,同时接收来自所有卡响应;
  • 寻址命令 (ac),发送到选定卡,DAT 线无数据传输;
  • 寻址数据传输命令 (adtc),发送到选定卡,DAT 线有数据传输。

响应编码格式

在 CMD 中,最高有效位(MSB)首先传输,最低有效位(LSB)最后传输。

响应由 SD 卡向主机发出,部分命令要求 SD 卡作出响应,这些响应多用于反馈 SD 卡的状态。 SDIO 总共有 7 个响应类型 (代号:R1~R7),其中 SD 卡没有 R4、R5 类型响应。特定的命令对应 有特定的响应类型,比如当主机发送 CMD3 命令时,可以得到响应 R6。与命令一样,SD 卡的 响应也是通过 CMD 线连续传输的。根据响应内容大小可以分为短响应和长响应。短响应是 48bit 长度,只有 R2 类型是长响应,其长度为 136bit。

除了 R3 类型之外,其他响应都使用 CRC7 校验来校验,对于 R2 类型是使用 CID 和 CSD 寄存器 内部 CRC7。


SD总线

SD 卡支持 SDIO 模式和 SPI 模式。

SDIO模式

SD卡模式针脚定义
针脚 名称 类型 描述
1 CD DAT 3 I/O/PP 卡监测数据位3
2 CMD PP 命令、回复
3 VSS S
4 VCC S 供电电压
5 CLK I 时钟
6 VSS2 S
7 DAT 0 I/O/PP 数据位 0
8 DAT 1 I/O/PP 数据位 1
9 DAT 2 I/O/PP 数据位 2

注:S:电源供电,I:输入 O:输出 I/O:双向 PP:I/O 使用推挽驱动

SD 总线允许强大的 1 线到 4 线数据信号设置。当默认的上电后,SD 卡使用 DAT0。 初始化之后,主机可以改变线宽(即改为 2 根线,3 根线,4 根线。)。

CLK 时钟线,由 SDIO 主机产生。
CMD 命令控制线,SDIO 主机通过该线发送命令控制 SD 卡,如果命令要求 SD 卡提供应 答 (响应),SD 卡也是通过该线传输应答信息。
D0-3 数据线,传输读写数据;SD 卡可将 D0 拉低表示忙状态。

SPI模式

如果接到复位命令(CMD0)时,CS 信号有效(低电平),SPI 模式启用。

SIP 模式允许较为简单的 SPI 通道接口,相比于 SDIO 模式传送速度降低。

SPI模式需要两根数据线,一根片选。SPI 兼容模式使得 MMC 主机系统通过很小的改动就可使用SD卡。SPI 模式使用字节传输。

注意:SPI 模式时,这些信号需要在主机端用 10~100K 欧的电阻上拉


SD卡的操作模式及其切换

SD 卡系统 (包括主机和 SD 卡) 定义了两种操作模式:卡识别模式和数据传输模式。在系统复位 后,主机处于卡识别模式,寻找总线上可用的 SDIO 设备;同时,SD 卡也处于卡识别模式,直 到被主机识别到,即当 SD 卡接收到 SEND_RCA(CMD3) 命令后,SD 卡就会进入数据传输模式, 而主机在总线上所有卡被识别后也进入数据传输模式。在每个操作模式下,SD 卡都有几种状态, 参考表 SD 卡状态与操作模式 ,通过命令控制实现卡状态的切换。

SD卡的几种状态

操作模式 SD卡状态
无效模式(Inactive) 无效状态(Inactive State)
卡识别模式(Card identification mode)

空闲状态(Idle State)

准备状态(Ready State)

识别状态(Identification State)

数据传输模式(Data transfer mode)

待机状态(Stand-by State)

传输状态(Transfer State)

发送数据状态(Sending-data State)

接收数据状态(Receive-data State)

编程状态(Programming State)

断开连接状态(Disconnect State)

SD卡状态转换

重新上电时为Idle状态

  • CMD0上电重置到Idle状态(防止一些机型关机不掉电,如某些FPGA平台)
  • ACMD41获取SD卡支持的电压信息(还需要通过主机控制器设置电压)
  • CMD2获取卡商信息
  • CMD3请求SD卡发布相对地址
  • CMD9获取CSD寄存器,即卡的电气特性数据(需要使用SD卡相对地址)
  • CMD7通过相对地址选择对应的SD卡,该卡进入数据传输Transfer State状态
  • 各种CMD进行block读写

SD存储卡状态图

来自[野火]《STM32库开发实战指南》

主机上电后,所有卡处于空闲状态,包括当前处于无效状态的卡。主机也可以发送 GO_IDLE_STATE(CMD0) 让所有卡软复位从而进入空闲状态,但当前处于无效状态的卡并不会复位。

主机在开始与卡通信前,需要先确定双方在互相支持的电压范围内。SD 卡有一个电压支持范围,主机当前电压必须在该范围可能才能与卡正常通信。SEND_IF_COND(CMD8) 命令就是用于验证卡接口操作条件的 (主要是电压支持)。卡会根据命令的参数来检测操作条件匹配性,如果卡支持主机电压就产生响应,否则不响应。而主机则根据响应内容确定卡的电压匹配性。CMD8 是 SD 卡标准 V2.0 版本才有的新命令,所以如果主机有接收到响应,可以判断卡为 V2.0 或更高版本SD卡。

SD_SEND_OP_COND(ACMD41) 命令可以识别或拒绝不匹配它的电压范围的卡。ACMD41 命令的 VDD 电压参数用于设置主机支持电压范围,卡响应会返回卡支持的电压范围。对于对 CMD8 有响应的卡,把 ACMD41 命令的 HCS 位设置为 1,可以测试卡的容量类型,如果卡响应的 CCS 位为 1 说明为高容量 SD 卡,否则为标准卡。卡在响应 ACMD41 之后进入准备状态,不响应ACMD41 的卡为不可用卡,进入无效状态。ACMD41 是应用特定命令,发送该命令之前必须先发 CMD55。

ALL_SEND_CID(CMD2) 用来控制所有卡返回它们的卡识别号 (CID),处于准备状态的卡在发送CID 之后就进入识别状态。之后主机就发送 SEND_RELATIVE_ADDR(CMD3) 命令,让卡自己推荐一个相对地址 (RCA) 并响应命令。这个 RCA 是 16bit 地址,而 CID 是 128bit 地址,使用 RCA简化通信。卡在接收到 CMD3 并发出响应后就进入数据传输模式,并处于待机状态,主机在获取所有卡 RCA 之后也进入数据传输模式。

卡初始化流程

要实现 SDIO 驱动 SD 卡,最重要的步骤就是 SD 卡的初始化,只要 SD 卡初始化完成了,那么剩下的(读写操作)就简单了。

卡片初始化和识别流程

从图中,我们看到,不管什么卡(这里我们将卡分为 4 类:SD2.0 高容量卡(SDHC,最大 32G),SD2.0 标准容量卡(SDSC,最大 2G),SD1.x 卡和 MMC 卡),首先我们要执行的是卡上电,上电后发送 CMD0对卡进行软复位,之后发送 CMD8 命令,用于区分 SD 卡 2.0,只有 2.0 及以后的卡才支持 CMD8 命令,MMC 卡和 V1.x 的卡,是 不支持该命令的。

不同种类的卡初始化过程是不一样的,通过流程差异我们可以判断不同类型的卡。

SDIO:CMD0之后执行CMD5,CMD5只有SDIO类型才会有响应。

MMC:ACMD 41换为CMD1,ACMD类命令只有SD或SDIO卡才有响应。所以要先检测是否是SDIO,再检测是否是SD,最后检测是否是MMC(core层代码中也是这个顺序),否则会出现误判。

数据传输模式

只有 SD 卡系统处于数据传输模式下才可以进行数据读写操作。数据传输模式下可以将主机 SD 时钟频率设置为 FPP,默认最高为 25MHz,频率切换可以通过 CMD4 命令来实现。

SD存储卡状态图

来自[野火]《STM32库开发实战指南》

CMD7 用来选定和取消指定的卡,卡在待机状态下还不能进行数据通信,因为总线上可能有多个卡都是出于待机状态,必须选择一个 RCA 地址目标卡使其进入传输状态才可以进行数据通信。同时通过 CMD7 命令也可以让已经被选择的目标卡返回到待机状态。

数据传输模式下的数据通信都是主机和目标卡之间通过寻址命令点对点进行的。卡处于传输状态下可以使用表 SD 部分命令描述 中面向块的读写以及擦除命令对卡进行数据读写、擦除。CMD12 可以中断正在进行的数据通信,让卡返回到传输状态。CMD0 和 CMD15 会中止任何数据编程操作,返回卡识别模式,这可能导致卡数据被损坏。


最后,因为是计划到用STM32开发,所以大部分都为V2版本的协议内容。

SD卡简单介绍-数据传输、模式流程相关推荐

  1. 简单介绍asp模式与saas模式

    简单介绍asp模式与saas模式 一 名词解释: asp:Application Service Provider,应用服务提供商:它是指配置.租赁和管理应用解决方案,为企业.个人提供服务的专业化服务 ...

  2. Android SD卡简单的文件读写操作

    最近有这样的需求,把每次统计到的数据,以txt形式保存到手机SD卡或是手机内存中,遇到一些问题,记录下来. 首先如果要在程序中使用sdcard进行存储,我们必须要在AndroidManifset.xm ...

  3. 遗传算法的简单介绍以及模式定理的简单证明

    遗传算法   遗传算法(Genetic Algorithm,GA),最早是由美国的John holland在20世纪70年代提出.算法通过模拟达尔文生物进化论的自然选择以及遗传学机理的生物进化过程来搜 ...

  4. 简单介绍工厂模式和单例模式

    工厂模式: 介绍: 工厂模式主要是为创建对象提供过渡接口,以便将创建对象的具体过程(new 关键字和具体的构造器)隐藏起来.用一个工厂方法来替代,对外提供的只是一个工厂方法,达到提高灵活性的目的.  ...

  5. CA认证简单介绍和工作流程

    CA是证书的签发机构,它是PKI的核心.CA是负责签发证书.认证证书.管理已颁发证书的机关.它要制定政策和具体步骤来验证.识别用户身份,并对用户证书进行签名,以确保证书持有者的身份和公钥的拥有权..  ...

  6. CA认证简单介绍与工作流程

    转载自:https://blog.csdn.net/cnh294141800/article/details/25242765 CA工作原理 数字安全证书利用一对互相匹配的密钥进行加密.解密.每个用户 ...

  7. sd卡tf卡进入spi模式

    现在我们手机的内存卡多为Micro SD卡,又叫TF卡,所以Micro SD卡比SD卡常见.自己曾经也想写写SD卡的读取程序,但又不想特地再去买个SD卡,这时想起手机内存卡不是和SD卡很像吗?在网上查 ...

  8. SD卡 SPI模式操作(1)初始化SD卡

    原文(本人转载):帆登小站-SD卡 SPI模式操作(1)初始化SD卡 作者是初学者,水平有限,本文仅作为个人学习笔记使用,不能保证内容的正确性.部分资料来源于网络,参考了SD卡协议2.0手册等资料,如 ...

  9. SD nand 与 SD卡的SPI模式驱动

    文章目录 SD nand 与 SD卡的SPI模式驱动 1. 概述 2. SPI接口模式与SD接口模式区别 2.1 接口模式区别 2.2 硬件引脚 2.3 注意事项 3. SD接口协议 3.1 命令 3 ...

最新文章

  1. Java生鲜电商平台-监控模块的设计与架构
  2. python基本使用-python基本用法
  3. SAP 金额在表中的存储及货币转换因子
  4. pexpect oracle,expect免交互脚本编程
  5. 好用的ToolStripManager类
  6. C#中Socket通信编程的同步实现
  7. HALCON示例程序hull.hdev区域提取与凸度筛选
  8. winform教_电脑绝技教你22天学精Csharp之第十五天winform应用程序补充5
  9. linux头文件怎么编译,microsoft编译器怎么使用Linux头文件
  10. linux监控mysql性能,MySQL 性能监控4大指标——第二部分
  11. php中file对象实例,AJAX_File, FileReader 和 Ajax 文件上传实例分析(php),File FileReader 可以干什么? Ajax - phpStudy...
  12. 学报格式和论文格式一样吗_学报格式
  13. 阿里云消息服务(MNS)简单介绍
  14. 1型错误和2型错误_沈阳地铁1号线太原街站导向牌出现错误!
  15. 商家如何利用小程序积分营销工具为小程序引流?
  16. java反转函数_在JAVA中,下列哪个函数可用于字符串的反转?
  17. 从沟通的一般模型想到互联网,再想到数字媒体,最后想到信息世界
  18. [附源码]Java计算机毕业设计SSM大学生运动员健康管理系统
  19. 裁剪TIF图像,代码简单,易懂(Arcpy)
  20. oracle基础语句练习

热门文章

  1. 压缩图片几款简单实用的工具
  2. 微前端qiankun 子应用使用阿里字体图标不显示
  3. 最伤害眼睛的7大恶习
  4. 尘锋信息基于 Apache Paimon 的流批一体湖仓实践
  5. 推荐一个好用的微信、支付宝等Rust三方服务框架
  6. 获取DedeCMS当前文章页的本文地址URL地址方法
  7. 为UE4整理中文字库,本文为如何将文本去重
  8. 面试了一个34岁的程序员,只因这一个细节,被我一眼看穿是培训班出来的,没啥工作经验...
  9. 飞利浦css5530+g评测,5款入门级电动牙刷评测:飞利浦第三,第一颜值实力兼具...
  10. html 组织结构 图表,OrgChart-简单实用的组织结构图表jQuery插件