STM32F4X SDIO(二) SDIO协议

上一节简单介绍了SD卡的分类,本节将会介绍SD卡的通信协议,也就是SDIO协议。

STM32F4X SDIO(二)SDIO协议

  • SD 卡管脚和寄存器
    • SD卡管脚分布
    • SD卡通信协议
    • SD卡寄存器
    • SD卡内部结构
  • SDIO总线
    • SDIO总线拓扑
    • SDIO总线协议
      • SDIO协议的基本结构
      • SDIO协议数据传输
      • SDIO协议命令与响应的结构
        • 命令结构
        • 响应结构
          • 短响应
          • 长响应
      • SDIO数据包格式
        • 常规数据包格式(8bit 宽)
          • 1线模式
          • 4线模式
        • 宽位数据包格式
          • 1线模式
          • 4线模式

SD 卡管脚和寄存器

SD卡管脚分布

我们以标准SD卡为例,先介绍一下SD卡的管脚。我们翻开SD卡的背面就能看到SD卡的管脚分布。在这里插入图片描述
在这里插入图片描述

SD卡通信协议

SD卡的通信协议有两种,分别是SDIO协议和SPI协议,本节主要讲的是SDIO协议。

管脚SDIO协议SPI协议
名称类型描述名称类型描述
1CD/DAT3输入输出(推挽模式)检测/数据线3CS输入片选(低电平有效)
2CMD输入输出(推挽模式)命令/响应DI输入数据输入
3VSS1输入接电源地VSS输入接电源地
4VDD输入电源VDD输入电源
5CLK输入时钟SCLK输入时钟
6VSS2输入接电源地VSS2输入接电源地
7DAT0输入输出(推挽模式)数据线0DO输出(推挽模式)数据输出
8DAT1输入输出(推挽模式)数据线1保留xx
9DAT2输入输出(推挽模式)数据线2保留xx

SD卡寄存器

每个SD卡内部都有8个寄存器,寄存器的介绍如下

名字位数描述
CID 128位卡识别号;用来识别的卡的个体号码
RCA16位相对地址;卡的本地系统地址,初始化时,动态地由卡建议,主机核准,SPI 模式不使用
DSR16位驱动级寄存器;配置卡的输出驱动
SCR64位SD 配置寄存器;SD 卡的特殊能力信息
CSD128卡的具体数据;卡的操作条件信息
OCR32位操作条件寄存器
SSR512SD 状态;卡专有特征的信息
CSR32卡状态;卡状态信息
有关以上寄存器的详细信息在后面的章节会介绍

SD卡内部结构

下图为SD卡的内部结构,其结构主要可以分成以下5部分
在这里插入图片描述

  • 外部接口(1):外部接口是用户实际能看到的结构,在SD卡的背面,其作用是将内部的管脚引出来,与设备进行连接。
  • 寄存器(2):SD卡内部的寄存器组,SD卡的信息,地址、初始化操作都需要通过读写SD卡的寄存器完成。
  • SD卡接口控制器(3):SD卡内部的控制器,主要是处理用户的发下来命令、数据以及给用户返回SD卡的一些状态,可以理解成一个封装在SD卡内部的MCU。
  • 存储器接口(4):SD卡内部的存储器接口芯片,作用是管理SD卡的存储阵列。
  • 存储阵列:SD卡的数据存储都放在存储阵列中,SDHC的SD卡每个存储阵列大小为512字节。

SDIO总线

SDIO总线拓扑

在这里插入图片描述
一个SDIO控制器上运行连接多个SD卡设备,此时SDIO控制器相当于是主机,SD卡相当于是从机。在SD卡初始化的过程中,SD卡会给主机返回一个地址(RCA),这个地址就是代表该SD卡的在系统中的唯一编号,可以理解成I2C协议中的从设备地址。

SDIO总线协议

SDIO协议的基本结构

SDIO总线协议是基于命令和数据流,在开始传输数据之前会有一个起始位,通常为0,结束时有一个停止位,通常为1.

  • 命令(Command):命令是主机发送给SD卡,通过CMD信号线进行传输,其作用向SD卡发起一个操作。
  • 响应((Response):响应是SD卡给主机,也是通过CMD线进行传输,作为收到命令后的操作,有些命令可以没有响应。
  • 数据((Data):数据的传输是双向的,通过数据线进行传输。

在这里插入图片描述

  • 没有响应的命令(1):对于没有响应的命令来说,主机只需要往CMD信号线上传输命令即可,不需要等待接收SD卡的响应。
  • 有响应的命令(2):对于有响应的命令,主机在CMD线上传输完命令之后,需要等待接收SD卡返回的响应,也是在CMD线上接收响应。

SDIO协议数据传输

SD卡的数据传输都是以为单位进行传输,SDHC容量的SD卡,每个块大小为512字节。
在这里插入图片描述
数据块的后面需要一个CRC来保证数据的准确性,CRC由SD卡或者SDIO硬件自动产生,在数据写入时需要检查busy信号,因为数据写入到SD卡的存储阵列需要时间。多块数据的写入还需要主机给从机发送停止命令让SD卡停止接收数据,SD卡的读操作类似。

SDIO协议命令与响应的结构

命令结构

在这里插入图片描述

  • 每一个命令的开始都要发送一个起始位,起始位的电平为低电平。
  • 每一个命令会都会接一个传输位,通常为1,代表主机发送命令。
  • CMD命令带参数传输,其参数位数为32位
  • 每个CMD都会一个7位的CRC校验码,保证命令的传输没有错误。
  • 结束时发送一个结束位,结束位电平为高电平。
  • 命令的总长度为48位。

命令格式:起始位(1bit)+传输位(1bit)+参数(32bit)+CRC(7bit)+停止位(1bit)

响应结构

SD卡的响应分为两种,分别是短响应(48bit)和长响应(136bit)
在这里插入图片描述

短响应
  • 每一个短响应发送一个起始位,起始位的电平为低电平。
  • 每一个短响应都会接一个传输位,通常为0,代表响应。
  • 接着是45位的响应数据,CRC(7bit)包含在响应数据里面
  • 结束时发送一个结束位,结束位电平为高电平。
  • 短响应的总长度为48位。
    短响应格式:起始位(1bit)+传输位(1bit)+响应数据(45bit)+停止位(1bit)
长响应
  • 每一个长响应发送一个起始位,起始位的电平为低电平。
  • 每一个长响应都会接一个传输位,通常为0,代表响应。
  • 接着是133位的响应数据,CRC(7bit)包含在响应数据里面
  • 结束时发送一个结束位,结束位电平为高电平。
  • 长响应的总长度为136位。
    短响应格式:起始位(1bit)+传输位(1bit)+响应数据(133bit)+停止位(1bit)

SDIO数据包格式

SDIO协议的数据包有两种格式,分别是常规数据包格式(8bit 宽)宽位数据包格式

常规数据包格式(8bit 宽)

常规数据包格式又可以分为两种,分别是1线4线模式

1线模式

在这里插入图片描述

  • 在数据发送前,需要发送一个起始位,低电平有效
  • 将数据按照8bit的格式一个一个在DATA0数据线上发送出去
  • 当所有数据传输完成后,需要发送一个CRC校验码,保证数据准确
  • 最后发送一个停止位,高电平有效
4线模式

在这里插入图片描述

  • 在数据发送前,需要发送一个起始位,低电平有效
  • 当发送一个字节时,需要将字节的高4位先发送,最后再发送字节的低4位。字节的发送按照DATA3:bit7 bit3,DATA2:bit6 bit2,DATA1:bit5 bit1,DATA0:bit4 bit0的格式进行发送
  • 当所有数据传输完成后,每根数据线上需要发送一个CRC校验码,保证数据准确
  • 最后发送一个停止位,高电平有效。
宽位数据包格式

宽位数据包格式也可以分为两种,分别是1线4线模式。其特点跟常规数据包模式类似。

1线模式

在这里插入图片描述

  • 在数据发送前,需要发送一个起始位,低电平有效
  • 将数据按照高位在前,低位在后的格式在DATA0数据线上发送出去
  • 当所有数据传输完成后,需要发送一个CRC校验码,保证数据准确
  • 最后发送一个停止位,高电平有效
4线模式

在这里插入图片描述

  • 在数据发送前,需要发送一个起始位,低电平有效
  • 按照高4位在前,低4位在后的格式依次在数据线上发送
  • 当所有数据传输完成后,每根数据线上需要发送一个CRC校验码,保证数据准确
  • 最后发送一个停止位,高电平有效。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/121858.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java将list转为逗号隔开字符串,将逗号连接的字符串转成字符数组,​将逗号分隔的字符串转换为List​(Java逗号分隔-字符串与数组相互转换)

一、通过testList.stream().collect(Collectors.joining(",")) &#xff0c;通过流转换&#xff0c;将list转为逗号隔开字符串 List<String> testList new ArrayList<>(); testList.add("test1"); testList.add("test2"); testList…

ArcGIS笔记12_ArcGIS搜索工具没法用?ArcGIS运行很慢很卡?

本文目录 前言Step 1 ArcGIS搜索工具没法用Step 2 ArcGIS运行很慢很卡 前言 这是笔者最近遇到的两个小问题&#xff0c;新换了台式机&#xff0c;安装上ArcGIS后发现搜索工具没法用&#xff0c;而且感觉还不如原来笔记本运行的流畅&#xff0c;加载图层很慢&#xff0c;编辑要…

web - 前段三剑客

目录 前言 一. HTML 常用标签演示 图片标签 ​编辑 表格标签(重点) ​编辑 表单标签 (重点) 布局标签 其余标签 二. CSS 2.1 . css的三种引入方式 2.2 . 三大选择器 2.3 . css样式 - 浮动 2.4 . css样式 - 定位 1.static 2.absolute(绝对位置) 3.relavite(相…

【PythonRS】Pyrsgis库安装+基础函数使用教程

pyrsgis库是一个用于处理地理信息系统(GIS)数据的Python库。它提供了一组功能强大的工具&#xff0c;可以帮助开发人员使用Python语言创建、处理、分析和可视化GIS数据。通过使用pyrsgis库&#xff0c;开发人员可以更轻松地理解和利用地理信息。 pyrsgis库包含了许多常见的GIS操…

自学SLAM(5)《第三讲:李群和李代数》作业

前言 小编研究生的研究方向是视觉SLAM&#xff0c;目前在自学&#xff0c;本篇文章为初学高翔老师课的第三次作业。 文章目录 前言1.群的性质2.验证向量叉乘的李代数性质3.推导 SE(3) 的指数映射4.伴随5.轨迹的描绘6.* 轨迹的误差(附加题) 1.群的性质 课上我们讲解了什么是群。…

UML中类之间的六种主要关系

UML中类之间的六种主要关系: 继承&#xff08;泛化&#xff09;&#xff08;Inheritance、Generalization&#xff09;, 实现&#xff08;Realization&#xff09;&#xff0c;关联&#xff08;Association)&#xff0c;聚合&#xff08;Aggregation&#xff09;&#xff0c;组…

Linux--进程替换

1.什么是进程替换 在fork函数之后&#xff0c;父子进程各自执行代码的一部分&#xff0c;但是如果子进程想要执行一份全新的程序呢&#xff1f; 通过进程替换来完成&#xff0c;进程替换就是父子进程代码发生写时拷贝&#xff0c;子进程执行自己的功能。 程序替换就是通过特定的…

python 笔记:h5py 读取HDF5文件

1 HDF5文件 HDF5 是 Hierarchical Data Format version 5 的缩写&#xff0c;是一种用于存储和管理大量数据的文件格式一个h5py文件可以看作是 “dataset” 和 “group” 二合一的容器 dataset : 数据集&#xff0c;像 numpy 数组一样工作group : 包含了其它 dataset 和 其它 …

GZ035 5G组网与运维赛题第4套

2023年全国职业院校技能大赛 GZ035 5G组网与运维赛项&#xff08;高职组&#xff09; 赛题第4套 一、竞赛须知 1.竞赛内容分布 竞赛模块1--5G公共网络规划部署与开通&#xff08;35分&#xff09; 子任务1&#xff1a;5G公共网络部署与调试&#xff08;15分&#xff09; 子…

C语言_断言assert详解

一、assert定义 assert() 的用法像是一种"契约式编程"&#xff0c;在我的理解中&#xff0c;其表达的意思就是&#xff0c;程序在我的假设条件下&#xff0c;能够正常良好的运作&#xff0c;其实就相当于一个 if 语句&#xff1a; if(假设成立) {程序正常运行&…

(免费领源码) Asp.Net#SQL Server校园在线投票系统10557-计算机毕业设计项目选题推荐

摘 要 随着互联网大趋势的到来&#xff0c;社会的方方面面&#xff0c;各行各业都在考虑利用互联网作为媒介将自己的信息更及时有效地推广出去&#xff0c;而其中最好的方式就是建立网络管理系统&#xff0c;并对其进行信息管理。由于现在网络的发达&#xff0c;校园投票通过网…

java - IDEA IDE - 设置字符串断点

文章目录 java - IDEA IDE - 设置字符串断点概述笔记END java - IDEA IDE - 设置字符串断点 概述 IDE环境为IDEA2022.3 在看一段序列化的代码, 想找出报错抛异常那个点, 理解一下代码实现. 因为序列化代码实现在第三方jar包中, 改不了(只读的). 根本数不清第几次才会开始报…

OpenCV学习(五)——图像基本操作(访问图像像素值、图像属性、感兴趣区域ROI和图像边框)

图像基本操作 5. 图像基本操作5.1 访问像素值并修改5.2 访问图像属性5.2 图像感兴趣区域ROI5.3 拆分和合并图像通道5.4 为图像设置边框&#xff08;填充&#xff09; 5. 图像基本操作 访问像素值并修改访问图像属性设置感兴趣区域&#xff08;ROI&#xff09;分割和合并图像 …

如何在vscode中添加less插件

Less &#xff08;Leaner Style Sheets 的缩写&#xff09; 是一门向后兼容的 CSS 扩展语言。它对CSS 语言增加了少许方便的扩展&#xff0c;通过less可以编写更少的代码实现更强大的样式。但less不是css&#xff0c;浏览器不能直接识别&#xff0c;即浏览器无法执行less代码&a…

2023年正版win10/win11系统安装教学(纯净版)

第一步&#xff1a;准备一个8G容量以上的U盘。 注意&#xff0c;在制作系统盘时会格式化U盘&#xff0c;所以最好准备个空U盘&#xff0c;防止资料丢失。 第二步&#xff1a;制作系统盘。 安装win10 进入windows官网 官网win10下载地址&#xff1a;https://www.microsoft.c…

安卓开发实例:随机数

点击按钮生成一个1-100之间的随机数 activity_random_number.xml <?xml version"1.0" encoding"utf-8"?> <androidx.constraintlayout.widget.ConstraintLayoutxmlns:android"http://schemas.android.com/apk/res/android"xmlns:a…

记一次vue3实现TRSP大华相机拉流的经历

一、背景 业务场景&#xff0c;大华IP相机安装在A城市某建筑场所&#xff0c;工控机是内网通过4G流量卡上网&#xff0c;工控机通过相机采集数据后做故障识别并上传故障信息到地面服务器&#xff0c;地面服务器在B城市。 现需要在地面服务器提供的WEB界面上实现IP相机实时拉流…

linux套接字选项API

获取套接字的选项值(getsockopt) 【头文件】 #include <sys/types.h> #include <sys/socket.h> 【函数原型】 int getsockopt(int sockfd, int level, int optname,void *optval, socklen_t *optlen); 【函数功能】 用于获取一个套接字的选项 【参数含义】 […

【前端】NodeJS核心知识点整理

1.Node.js入门案例 1.1.什么是Node.js JS是脚本语言&#xff0c;脚本语言都需要一个解析器才能运行。对于写在HTML页面里的JS&#xff0c;浏览器充当了解析器的角色。而对于需要独立运行的JS&#xff0c;NodeJS就是一个解析器。 每一种解析器都是一个运行环境&#xff0c;不但…

数据特征工程 | 主成分分析(Python)

特征抽取(feature extraction)和特征选择(feature selection)不一样,特征抽取是从原特征集中推导出有用的信息构成新的特征集。特征选择是从原特征集中选择一部分子集作为训练特征。 特征抽取将数据集从一个特征空间投影到了一个更低维度的特征空间。 主成分分析(princ…