博客
关于我
STM32笔记之 SDIO(SD Card操作)
阅读量:783 次
发布时间:2019-03-24

本文共 1198 字,大约阅读时间需要 3 分钟。

STM32 SDIO接口实现

一、SDIO接口

SDIO(SD Input(Output)接口),即SD的I/O接口,是解决嵌入式系统中模块间高速通信的重要方法。其传输速度可达到25Mbps。在实际应用中,SDIO常与MMC和SD密切结合,形成MMC/SD/SDIO的发展脉络。

从技术演化来看,MMC(MultiMediaCard)注重多媒体存储功能,SD(Secure Digital)则聚焦于数据安全保护,SDIO则强调I/O接口的扩展性,对接口类型和设备类型持无关性态(如支持WIFI、Bluetooth、GPS等)。此外,SDIO接口在STM32实现中主要包含两个部分:

  • SDIO适配器模块:负责实现MMC/SD/SDIO卡的相关功能,如时钟管理、命令传输、数据处理等。
  • AHB总线接口:为SDIO适配器模块提供操作权限,包括寄存器访问、中断和DMA请求。
  • 二、SD卡

    1. SD卡构架

    SD卡采用了 [错误:无法识别图片src] 针状结构,核心部件包括芯片接口_modules与读写保护区。其物理布局符合anki标准,支持多种操作模式。

    2. 接口定义

    SD卡定义了多个寄存器(错误:无法识别图片src)用于存储卡片信息与配置参数。这些寄存器包括:

    OCR寄存器
    存储卡片唯一标识信息。
    CID寄存器
    存储卡片生产商及产品信息。
    CSD寄存器
    存储卡片特殊数据结构。
    RCA寄存器
    存储卡片的物理地址。
    DSR寄存器
    配置总线参数。
    SCR寄存器
    存储特殊控制命令。

    3. SD卡操作流程图

    SD卡的数据读写过程通过命令和数据传输完成,具体流程图如下:

    [错误:无法识别图片src]

    4. SD卡寄存器详解

    SD卡寄存器主要用于存储设备特性信息:

  • OCR寄存器:通过命令访问,存储卡片生产商和产品标识。
  • CID寄存器:包含卡片ID、制造日期等信息。
  • CSD寄存器:存储卡片序列号、过滤器等特殊数据。
  • RCA寄存器:初始化时由卡片提供,用于寻址。
  • DSR寄存器:配置总线参数,对总线性能有重要影响。
  • SCR寄存器:存储特殊控制命令,供应用程序调用。
  • 三、代码实验操作

    基于STM32标准库,在[错误:无法识别路径中找到SD卡操作模块,需要实现以下接口:

  • SD_LowLevel_Init()函数:配置SDIO总线,包括时钟和命令线控制。
  • SD_LowLevel_DeInit()函数:复位SDIO模块,包括总线和相关信号控制。
  • SD_LowLevel_DMA_TxConfig()和SD_LowLevel_DMA_RxConfig()函数:配置DMA传输,实现高效数据传输。
  • 此外,SD卡检测逻辑可通过宏控制实现:

    [错误:无法识别图片src}

    实验验证

    通过ST官方提供的模板代码,编写测试程序验证各功能:

    [错误:无法识别图片src}

    [此处依次对应上述各部分,完整文章可跳转查看]

    转载地址:http://kgtkk.baihongyu.com/

    你可能感兴趣的文章
    mysql 字段区分大小写
    查看>>
    mysql 字段合并问题(group_concat)
    查看>>
    mysql 字段类型类型
    查看>>
    MySQL 字符串截取函数,字段截取,字符串截取
    查看>>
    MySQL 存储引擎
    查看>>
    mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
    查看>>
    MySQL 存储过程参数:in、out、inout
    查看>>
    mysql 存储过程每隔一段时间执行一次
    查看>>
    mysql 存在update不存在insert
    查看>>
    Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
    查看>>
    Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
    查看>>
    Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
    查看>>
    Mysql 学习总结(89)—— Mysql 库表容量统计
    查看>>
    mysql 实现主从复制/主从同步
    查看>>
    mysql 审核_审核MySQL数据库上的登录
    查看>>
    mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
    查看>>
    mysql 导入导出大文件
    查看>>
    mysql 将null转代为0
    查看>>
    mysql 常用
    查看>>
    MySQL 常用列类型
    查看>>