要了解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的通信建立。
那我们设计的时候应该注意什么呢?重点来了。