SD Host功能列表

  • SD Host挂接在SoC中,与外部的SD card进行交互
  • 有控制寄存器和状态寄存器,SoC往往有CPU,通过CPU进行配置寄存器,有些SoC没有CPU,需要使用I2C或者SPI可以进行写寄存器
  • 内建DMA-数据需要从外部将数据读取到buffer中,然后再对于SD卡进行写操作;对于读操作,首先先将SD卡读取到控制器中buffer中,再从buffer中将数据存储到SoC中的存储单元中,数据搬移需要使用DMA
  • DMA也是挂接在AHB总线上的
  • 数据缓存的FiFo和内嵌DMA模块
  • SD卡的时钟频率比较低,所以需要分频电路
  • 读操作,硬件停时钟功能,当读数据的时候,fifo读满之后,不能继续读取sd card中的内容,在等待DMA搬移数据的过程中,可以停止时钟,DMA搬移完fifo中的数据后,可以打开时钟

架构

  • 先将外部需要的接口画出来:AHB总线和SD总线
  • SD Host是基于AHB总线的,并且有一些控制和状态寄存器,所以需要设置ahb_slave_if模块,处理AHB信号
  • ahb_slave_if中有控制寄存器,进行任务驱动,产生任务信息给到sd_ctrl模块
  • 设置一个sd_ctrl模块发起对于sd总线的请求
  • sd_ctrl与sd总线的交互除了有命令总线还有数据总线,都是双向的
  • ahb时钟比较快,sd时钟比较慢,所以需要有 一个时钟分频模块

  • 根据配置信息,产生命令,启动SD ctrl进行一些命令的发送
  • 需要有一个缓存存储数据(FiFo),对于读数据,sd_ctrl控制数据总线,读取数据从sd总线上读取出来存储到fifo中,fifo中的数据满了之后,通过DMA将数据存储到SoC中的存储单元中
  • DMA-搬运数据的时候是一个master,控制总线,发送数据
  • ahb_slave_if模块是slave



sd_ctrl模块

  • 对于sd card进行读写,当上电之后,sd card处于idle状态,需要通过命令发送跳转到data transfer state,才可以进行数据的读写,如果想要让sd card处于data transfer状态,需要配置很多命令才可以
  • sd协议的状态机比较复杂,有两种设计思路

    1.通过硬件实现所有的状态机,包括卡识别模式和数据传输模式

    每一步操作都需要很多的指令,首先需要在ahb_slave_if模块中通过软件配置所有的操作,需要定义整个过程的操作以及每个操作所需的指令是什么;比如:在standby模式下有时候需要设置CMD4,有时候需要配置CMD9,在standby的时候,是否需要配置这写命令需要软件配置,硬件实现全部的功能

    优点:集中式的配置,事先将所有的操作都配置好,发起启动信号之后,由硬件进行执行,和CPU交互频率较低,CPU负担较轻

    缺点:硬件实现非常复杂,后期更改软件灵活性差

    2.将硬件的执行力度降低,硬件操作的时候有两种:一种进行数据传输或者只进行命令传输,可以以一条指令的数据传输为粒度进行设计状态机,硬件只实现一条CMD的发送和response的接收,只实现一条CMD对应的data的发送和接收

    整个流程的控制权全部交给CPU,也就是软件,硬件只实现最小粒度的命令发送和接收,以及数据发送和接收

    优点:硬件实现代价小,软件的灵活性非常大

    缺点:CPU需要和SD Host进行大量的交互,CPU负担较重

  • cmd发送和response返回都是类似的

    CPU与SD Host通过中断进行交互,SD Host也会发送中断给到中断控制器,CPU收到中断之后,需要进入中断处理程序处理中断
  • CPU与IP通过中断通信,SD Host发送中断出来,给到中断控制器,每一条指令,中断控制器将中断上报给CPU,CPU进行响应中断,决策下一步做什么
  • IDLE的时候,CPU发送ACMD41,CPU会等待中断,card接收到ACMD41之后,会返回一个response给到host,host接收到reponse之后,会返回中断给到CPU,CPU收到中断之后,CPU会查询SD Host中的寄存器,如果读取的寄存器的值是busy的,CPU会再次发送ACMD41

CMD发送

  • CMD发送的时序是类似的,可以设置一个状态机,实现CMD的发送和response接收
  • 接收来自ahb_salve_if的配置
  • 再设置一个状态机,实现data的发送和接收



SD Host控制功能列表

SD Host控制器软硬件模块划分



  • 对于复杂的流程交给软件控制,硬件只进行一条命令及数据处理
  • AHB有两个接口,一个master接口,DMA主动发起请求;写操作,DMA从外部搬移数据发送出去,读操作,从FIFO中读取数据,将数据发送给AHB总线;一个从接口(AHB_slave_if)
  • 软件主要配置寄存器,然后等待中断
  • 硬件工程师写好程序,根据不同的操作执行不同的函数,配置不同的寄存器进行不同的操作
  • 硬件给出不同操作的状态位(更新状态寄存器中的值)或者产生中断信号

SD Host控制器模块功能描述

  • 通过异步fifo实现不同时钟域之间数据的传递
  • 分频参数通过ahb_slave_if中进行配置

SD Host模块功能简述

  • 卡识别模式和data transfer模式下时钟频率是不同的

SD Host架构设计文档







SD-Host控制器设计架构的更多相关文章

  1. Kubernetes系列02—Kubernetes设计架构和设计理念

    本文收录在容器技术学习系列文章总目录 1.Kubernetes设计架构 Kubernetes集群包含有节点代理kubelet和Master组件(APIs, scheduler, etc),一切都基于分 ...

  2. Android App的设计架构:MVC,MVP,MVVM与架构经验谈

    相关:http://www.cnblogs.com/wytiger/p/5996876.html 和MVC框架模式一样,Model模型处理数据代码不变在Android的App开发中,很多人经常会头疼于 ...

  3. 13 JSP、MVC开发模式、EL表达式和JSPL标签+软件设计架构---学习笔记

    1.JSP (1)JSP概念:Java Server Pages 即java服务器端页面可以理解为:一个特殊的页面,其中既可以指定定义html标签,又可以定义java代码用于简化书写!!! (2)原理 ...

  4. (转)Kubernetes设计架构

    转:https://www.kubernetes.org.cn/kubernetes设计架构 Kubernetes集群包含有节点代理kubelet和Master组件(APIs, scheduler, ...

  5. Android App的设计架构:MVC,MVP,MVVM与架构AAAAA

    1. 架构设计的目的1.1 通过设计使程序模块化,做到模块内部的高聚合和模块之间的低耦合.1.2 这样做的好处是使得程序在开发的过程中,开发人员只需要专注于一点,提高程序开发的效率,并且更容易进行后续 ...

  6. MVC:开发模式&&三层架构:软件设计架构

    MVC:开发模式 jsp演变历史 早期只有servlet,只能使用response输出标签数据,非常麻烦 后来又jsp,简化了Servlet的开发,如果过度使用jsp,在jsp中即写大量的java代码 ...

  7. Goodle Clean设计架构

    Goodle Clean设计架构 23 * @param <P> the response type 24 */ 25 public abstract class UseCase<Q ...

  8. 基于FPGA的XPT2046触摸控制器设计

    基于FPGA的XPT2046触摸控制器设计 小梅哥编写,未经许可,文章内容和所涉及代码不得用于其他商业销售的板卡 本实例所涉及代码均可通过向 xiaomeige_fpga@foxmail.com  发 ...

  9. 基于FPGA的SPI FLASH控制器设计

    1.SPI FLASH的基本特征 本文实现用FPGA来设计SPI FLASH,FLASH型号为W25Q128BV.支持3种通信方式,SPI.Dual SPI和Quad SPI.FLASH的存储单元无法 ...

  10. 2014.04.28基于CPLD的LCOS场序彩色视频控制器设计

    基于CPLD的LCOS场序彩色视频控制器设计 作者:宋丹娜,代永平,刘艳艳,商广辉 发表刊物:液晶与显示,2009 学习时间:2014.04.28 文章讲述了-- (和上一篇论文有些相似之处) 1. ...

随机推荐

  1. 华企盾DSC客户端连不上服务器(客户端在回收站)

    解决方法:确保该计算机在CLIENT表recyclebin列中的值为False,最好把所有计算机都改成False,改好后重启DSC服务器,最后重新安装客户端. 或者将客户端从回收站移动到正常的工作组.

  2. 基于QT环境下,实现客户端红外采集人体向服务端通信。

    一.本次测试目的 基于QT环境下STM32人体红外检测,实现客户端红外采集到信息向服务端通信. 二.功能 (1).传入音乐,当服务端接收到信息时,打开音乐    (2).在服务端上面显示图片,当接收到 ...

  3. Layui treeTable 使用【数据不显示、子级不显示】

    //返回JSON数据类 public class LeaveMessageTreeTable { public LeaveMessageTreeTable() { this.children = ne ...

  4. vulnhub - tornado - wp

    coverY: 0 tornado 信息收集 目标开放了80,22端口. 访问80网页,是默认页面: 目录枚举 用dirsearch没有什么发现,换gobuster发现了一个bluesky目录.访问如 ...

  5. Vulntarget-b-wp

    Vulntarget-b 环境配置 centos7 用户 密码 root root vulntarget root 宝塔Linux面板http://192.168.0.104:8888/045b276 ...

  6. 《A Novel Table-to-Graph Generation Approach for Document-Level Joint Entity and Relation Extraction》阅读笔记

    代码   原文地址   文档级关系抽取(DocRE)的目的是从文档中提取实体之间的关系,这对于知识图谱构建等应用非常重要.然而,现有的方法通常需要预先识别出文档中的实体及其提及,这与实际应用场景不一致 ...

  7. 在centos7.9中 修改docker0 的网卡默认IP地址

    docker0网卡的默认IP地址为172.17.0.1/16 因此很可能会与企业网中的业务地址冲突,为了解决这个问题,必须修改docker0的网卡配置,操作如下 1.查看网卡docker0的默认地址  ...

  8. Linux 中查看文件系统的块大小

    有时可能需要查看 Unix 操作系统中有关于文件基本单元的块大小,以便对有的系统进行适当的优化(如 MySQL),本文将介绍几种在 Unix 上以及类 Unix 操作系统上可行的查看方式 检查文件系统 ...

  9. 使用WPF开发自定义用户控件,以及实现相关自定义事件的处理

    在前面随笔<使用Winform开发自定义用户控件,以及实现相关自定义事件的处理>中介绍了Winform用户自定义控件的处理,对于Winform自定义的用户控件来说,它的呈现方式主要就是基于 ...

  10. 文心一言 VS 讯飞星火 VS chatgpt (45)-- 算法导论6.1 3题

    三.证明:在最大堆的任一子树中,该子树所包含的最大元素在该子树的根结点上. 文心一言: 在最大堆中,根结点是整个堆中最大元素的孩子,因此它包含的最大元素是在该子树的根结点上. 我们可以通过递归的方式证 ...