SD卡及接口设计基础

2024-03-01 16:18
文章标签 基础 设计 接口 sd 卡及

本文主要是介绍SD卡及接口设计基础,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        要了解SD卡的设计规范,咱们必须从SD卡的分类讲起。一般有两种分类方式。一种是根据卡容量来分类。分为标准卡(SDSC)、高容量卡(SDHC)、扩展容量卡(SDXC)。SDSC不超过2GB,支持所有的SD协议。SDHC不超过32GB,但大于2GB,知识SD2.0协议。SDXC不超过2TB但大于32GB,支持SD3.0协议。另一种根据卡的速率来分类,如SDR104,即支持最大传输速率为104MB/S,时钟频率为208MHz,供电1.8V。SDR50、SDR25、SDR12类别以上,不再赘述。DDR50与SDR50相比其最大时钟频率为50MHz。high speed类型同SDR25,但供电为3.3V,default speed类型同SDR12,供电为3.3V。

        对于设计来讲,无非有两种情况,即按照客户需求,是否支持热插拔。

        我们都知道,SD卡信号是有VDD,CLK,DATA0~3,CMD,GND组成。但是支持热插拔的话需要增加中断检测pin即detect,接到卡座的硬开关上。

        对于识卡流程,支持热插拔的话,会先去检测DETECT上的电平,当卡插入时电平会被拉低。不支持热插拔卡可自动省去这一步骤,直接会给SD卡上电3.3V(某些平台或SD3.0上电前可能会有一个低电平持续时间,bring up时需要注意)如果检测不到卡系统会直接关闭供电。检测到后CPU会发送CMD信号给到SD,SD收到后会做ACK应答给到CPU,从而实现和CPU的通信建立。

        那我们设计的时候应该注意什么呢?重点来了。

        DATA0~3作为信号传输,需要尽可能保证干扰最小,因此最好预留0欧姆电阻串接以供调试。当然出现干扰问题时,也可以尝试调整驱动电流。SD卡单信号线小于100mm,DATA,CLK,CMD信号组间差值控制7mm以内,同时此类信号线需要做包地处理,减少其他信号干扰。SD2.0驱动电流200mA,输出电容1uF,SD3.0,S/DDR50:400mA,2.2uF。SDR104需要800mA的驱动电流,4.7uF输出电容滤波。因此要注重走线的过流能力。

        那对于SD卡设计需要验证其功能是否正常,也需要以下的考量。

        我们需要测试SD卡的接口协议,对照SPEC判断正确与否。同时也需要测试每个管脚的抗浪涌能力,以及静电测试。如果卡支持热插拔的话,还要测试热插拔功能是否正常,最好能量出具体波形测量。

        当然,SD卡出现故障时,我们需要通过专业能力迅速定位问题。

        首先我们得排查是不是单体问题,因此需要和其他机器作对比。同时测量出SD卡信号的对地阻抗,与正常卡作比较,最好再能用二极管档也做测试,看看是不是卡座虚焊等原因导致。再往后,用示波器测试识卡流程是否正常,若不正常可能是CPU存在问题,同时抓取log给软件分析。

这篇关于SD卡及接口设计基础的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/763055

相关文章

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

SpringBoot+Redis防止接口重复提交问题

《SpringBoot+Redis防止接口重复提交问题》:本文主要介绍SpringBoot+Redis防止接口重复提交问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录前言实现思路代码示例测试总结前言在项目的使用使用过程中,经常会出现某些操作在短时间内频繁提交。例

springboot下载接口限速功能实现

《springboot下载接口限速功能实现》通过Redis统计并发数动态调整每个用户带宽,核心逻辑为每秒读取并发送限定数据量,防止单用户占用过多资源,确保整体下载均衡且高效,本文给大家介绍spring... 目录 一、整体目标 二、涉及的主要类/方法✅ 三、核心流程图解(简化) 四、关键代码详解1️⃣ 设置

spring中的ImportSelector接口示例详解

《spring中的ImportSelector接口示例详解》Spring的ImportSelector接口用于动态选择配置类,实现条件化和模块化配置,关键方法selectImports根据注解信息返回... 目录一、核心作用二、关键方法三、扩展功能四、使用示例五、工作原理六、应用场景七、自定义实现Impor

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

MyBatis设计SQL返回布尔值(Boolean)的常见方法

《MyBatis设计SQL返回布尔值(Boolean)的常见方法》这篇文章主要为大家详细介绍了MyBatis设计SQL返回布尔值(Boolean)的几种常见方法,文中的示例代码讲解详细,感兴趣的小伙伴... 目录方案一:使用COUNT查询存在性(推荐)方案二:条件表达式直接返回布尔方案三:存在性检查(EXI

安装centos8设置基础软件仓库时出错的解决方案

《安装centos8设置基础软件仓库时出错的解决方案》:本文主要介绍安装centos8设置基础软件仓库时出错的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录安装Centos8设置基础软件仓库时出错版本 8版本 8.2.200android4版本 javas

Linux基础命令@grep、wc、管道符的使用详解

《Linux基础命令@grep、wc、管道符的使用详解》:本文主要介绍Linux基础命令@grep、wc、管道符的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录grep概念语法作用演示一演示二演示三,带选项 -nwc概念语法作用wc,不带选项-c,统计字节数-

Java中的Closeable接口及常见问题

《Java中的Closeable接口及常见问题》Closeable是Java中的一个标记接口,用于表示可以被关闭的对象,它定义了一个标准的方法来释放对象占用的系统资源,下面给大家介绍Java中的Clo... 目录1. Closeable接口概述2. 主要用途3. 实现类4. 使用方法5. 实现自定义Clos