SDIO接口

来自:http://blog.youkuaiyun.com/luixing67/article/details/5658722

SDIO卡是在SD内存卡接口的基础上发展起来的接口,SDIO接口兼容以前的SD内存卡,并且可以连接SDIO接口的设备,目前根据SDIO协议的SPEC,SDIO接口支持的设备总类有蓝牙,网卡,电视卡等。

       SDIO协议是由SD卡的协议演化升级而来的,很多地方保留了SD卡的读写协议,同时SDIO协议又在SD卡协议之上添加了CMD52和CMD53命令。由于这个,SDIO和SD卡规范间的一个重要区别是增加了低速标准,低速卡的目标应用是以最小的硬件开始来支持低速I/O能力。低速卡支持类似调制解调器,条形码扫描仪和GPS接收器等应用。高速卡支持网卡,电视卡还有“组合”卡等,组合卡指的是存储器+SDIO。
       SDIO和SD卡的SPEC间的又一个重要区别是增加了低速标准。SDIO卡只需要SPI和1位SD传输模式。低速卡的目标应用是以最小的硬件开支来支持低速I/O能力,低速卡支持类似MODEM,条形扫描仪和GPS接收器等应用。对组合卡来说,全速和4BIT操作对卡内存储器和SDIO部分都是强制要求的。
       在非组合卡的SDIO设备里,其最高速度要只有达到25M,而组合卡的最高速度同SD卡的最高速度一样,要高于25M。
SDIO总线
       SDIO总线和USB总线类似,SDIO总线也有两端,其中一端是主机(HOST)端,另一端是设备端(DEVICE),采用HOST- DEVICE这样的设计是为了简化DEVICE的设计,所有的通信都是由HOST端发出命令开始的。在DEVICE端只要能解溪HOST的命令,就可以同HOST进行通信了。
       SDIO的HOST可以连接多个DEVICE,如下图所示:
       这个是同SD的总线一样的,其中有如下的几种信号
1.       CLK信号:HOST给DEVICE的时钟信号.
2.       CMD信号:双向的信号,用于传送命令和反应。
3.       DAT0-DAT3 信号:四条用于传送的数据线。
4.       VDD信号:电源信号。
5.       VSS1,VSS2:电源地信号。
在SDIO总线定义中,DAT1信号线复用为中断线。在SDIO的1BIT模式下DAT0用来传输数据,DAT1用作中断线。在SDIO的4BIT模式下DAT0-DAT3用来传输数据,其中DAT1复用作中断线。
SDIO命令:
       SDIO总线上都是HOST端发起请求,然后DEVICE端回应请求。其中请求和回应中会数据信息。
1.       Command:用于开始传输的命令,是由HOST端发往DEVICE端的。其中命令是通过CMD信号线传送的。
2.       Response:回应是DEVICE返回的HOST的命令,作为Command的回应。也是通过
CMD线传送的。
3.       Data:数据是双向的传送的。可以设置为1线模式,也可以设置为4线模式。数据是通过DAT0-DAT3信号线传输的。
  SDIO的每次操作都是由HOST在CMD线上发起一个CMD,对于有的CMD,DEVICE需要返回Response,有的则不需要。
       对于读命令,首先HOST会向DEVICE发送命令,紧接着DEVICE会返回一个握手信号,此时,当HOST收到回应的握手信号后,会将数据放在4位的数据线上,在传送数据的同时会跟随着CRC校验码。当整个读传送完毕后,HOST会再次发送一个命令,通知DEVICE操作完毕,DEVICE同时会返回一个响应。
       对于写命令,首先HOST会向DEVICE发送命令,紧接着DEVICE会返回一个握手信号,此时,当HOST收到回应的握手信号后,会将数据放在4位的数据线上,在传送数据的同时会跟随着CRC校验码。当整个写传送完毕后,HOST会再次发送一个命令,通知DEVICE操作完毕,DEVICE同时会返回一个响应。
SDIO的寄存器:
      SDIO卡的设备驱动80%的任务就是操作SDIO卡上的有关寄存器。SDIO卡最多允许有7个功能(function),这个同其功能号是对应的(0~7),每个功能都对应一个128K字节大小的寄存器,这个见下面的图。功能号之所以取值范围是1~7,而没有包含0,是因为功能0并不代表真正的功能,而代表CIA寄存器,即Common I/O Area,这个纪录着SDIO卡的一些基本信息和特性,并且可以改写这些寄存器。其中地址0x1000~0x17fff是SDIO卡的CIS区域,就是基本信息区域,Common Information Structure。初始化的时候读取并配对SDIO设备。
       这些寄存器的详细分区已经其对应的功能,在开发过程中都是需要仔细研读的,这些都在协议的SPEC中都有详细说明,这里就不在罗索了。
基于ARM含SD控制器的SD卡的SDIO模式驱动解析
SD卡由日本松下、东芝及美国SanDisk公司于1999年8月共同开发研制。
SD卡的结构能保证数字文件传送的安全性,也很容易重新格式化,因此越来越多的被应用的嵌入式系统中。SD卡的使用非常方便,常见的有两种工作模式:SPI和SDIO。SPI是串行的工作模式,速度相对较低,但是使用方便,只要MCU含有SPI接口均可使用。SDIO模式,可以最多4线传输,因此速度比较快,由于SD卡的普及,越来越多的MCU内部集成了SDIO控制器,简化了我们的工作。本文以三星s3c2410为例介绍。
2.    SD卡的协议
SD卡的控制指令非常强大,支持SPI,SDIO模式,兼容MMC等。而且不同的
指令有不同的响应(3种),这在我们使用指令是要注意的。

### SDIO 接口概述 SDIO (Secure Digital Input Output) 是一种用于连接各种外围设备的标准接口,尤其适用于移动和便携式设备。该接口不仅支持传统的存储功能,还允许其他类型的输入输出操作,如Wi-Fi模块、蓝牙模块等[^1]。 ### 工作模式 SDIO 支持三种主要的工作模式: - **SPI Mode**:这是必需的支持模式,在这种模式下,SDIO 设备可以像普通的 SPI 设备一样工作。 - **1-Bit Mode**:此模式提供单数据线的数据传输路径。 - **4-Bit Mode**:相比1-Bit Mode,这种方式能够显著提高数据吞吐量,因为它利用了四个并行的数据线路来加速数据交换过程。 ### 数据传输机制 为了实现高效的双向通信,SDIO采用了特定的信号线配置,主要包括命令线(CMD),时钟线(CLK),以及一条或多条数据线(DAT0-DAT3)[^2]。这些物理层面上的设计使得SDIO能够在保持较低功耗的同时达到较高的传输速率。 ### 初始化顺序 值得注意的是,在初始化过程中存在一定的优先级安排:“先探测SDIO,再处理SD,最后才是MMC”。这样的设计有助于确保系统的稳定性和兼容性[^3]。 ### 应用场景与发展前景 随着技术的进步,SDIO正逐渐成为嵌入式系统中最重要的一种接口形式,并有望在未来替代现有的基于GPIO控制下的SPI接口方案。此外,由于其出色的性能表现,SDIO也被广泛应用到各类消费电子产品当中,比如智能手机和平板电脑中的扩展卡槽就是典型例子。 ```c // C语言代码示例展示如何检测是否存在有效的SDIO设备 int sdio_probe_device(void){ int result; // 尝试访问SDIO设备 result = check_sdio_presence(); if(result == SUCCESS){ printf("Found valid SDIO device\n"); }else{ printf("No SDIO device detected or error occurred.\n"); } return result; } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值