SD Host控制器微架构设计
微架构设计思路

- ahb_slave_if中的寄存器可以在datasheet中进行描述
- sd_clk - 时钟产生模块的接口描述
- sd_data_fsm和sd_cmd_fsm - 状态机描述
- 发送时序需要遵守,并且在发送的时候需要产生CRC
- 接受时序需要遵守,并且要接收CRC,进行比较
- FiFo中有存储体存储数据,FiFo_ctrl模块进行fifo的控制
- DMA - AHB_master的设计
sd_clk设计
设计需求
- 具有分频电路,根据ahb_slave_if中寄存器的配置对hclk进行分频
- 硬件停止时钟
- 软件开关时钟
- 需要考虑在DFT模式下,时钟如何?
- 时钟分频,使用计数器进行时钟周期,实现分频;如果分频配置为0,表示使用原始时钟hclk进行输入
- 软硬件开关时钟,就是在使能信号的条件下,选择时钟的输入
- test mode下同样是在test_en的条件下,选择hclk,保证扫描链的时钟频率是一样的

sd_if模块功能

- ahb总线信号处理,进行地址和数据对齐
- 其中有一些寄存器,对寄存器及其中的地址域段进行读写操作
- 有两个时钟域,ahb时钟域和sd时钟域,进行时钟域的同步
sd_clk模块

- 允许软硬件干预时钟

- in_clk_divider - 分频大小,软件写寄存器配置的
- in_sd_clk_enable - 软件使能clk
- hw_stop_clk - 硬件使能(硬件在读的时候,进行数据搬移的时候,可以关闭时钟)
- out_sd_clk_dft - 输出clk
sd_clk模块:时钟输出描述

- 分频大小通过寄存器配置,如果分频寄存器为0,就输出原时钟
- sd_io - 是更通用的协议,可以连接Wifi设备或者GPS设备
sd_cmd_fsm

- 硬件检测sd card是否是busy
- 将一条命令(比如48bit)作为一个状态

- idle状态通过cpu trigger信号进入到wait send状态,此时通过硬件检查sd card是否处于busy状态,就是data总线的data[0]是否为1,转到wait resp状态,当cmd=0的时候,转到receive resp状态
sd_cmd_fsm模块:状态机控制图

- in_command_ready = 1表示cpu让硬件去发送cmd
- in_sd_dat[0] - 拉高之后,进位send状态

- wait response时间超过预设的值Ncr,给出timeout信号,进入state stop状态

- in_soft_reset - 软件复位,高电平有效
- in_response - 表示当前命令有没有resp
- in_longresponse - 回复长命令信号,R2类型的resp
- in_cmmmand_ready - 软件置位,硬件清0,启动状态机
- has_send_bit - 表示当前发送了多少位(48bit,6bit)
- in_sd_dat - 这里给了3bit,实际上只要0bit就可以了
- has_receive_bit - 表示当前已经接收的多少位(136bit,8bit)
- end_command - 命令结束信号
- end_command_and_response - 命令结束并且完成回复接收
- response_timeout - 响应超时信号,给到状态寄存器
sd_cmd_send_shift_register模块

- in_current_state - 处于特特定的状态才能发送数据
- has_send_bit - 用于判断当前的命令发送的是crc还是argument
- out_cmd_dir - 控制输出的方向,输入还是输出
- out_sd_cmd - 并行数据转换为串行数据,利用移位寄存器,每次输出最高位然后左移一位,

- 0-25MHz - 数据是在下降沿进行驱动的
- 50Hz - 数据驱动沿是上升沿
sd_cmd_recieve_shift_register模块

- in_serial_cmd - 接收sd card发送的cmd
- in_longrespone - 接收136bit resp

sd_data_fsm

SD Host控制器微架构设计的更多相关文章
- 手机服务器微架构设计与实现 之 http server
手机服务器微架构设计与实现 之 http server ·应用 ·传输协议和应用层协议概念 TCP UDP TCP和UDP选择 三次握手(客户端与服务器端建立连接)/四次挥手(断开连接)过程图 · ...
- 【CPU微架构设计】分布式多端口(4写2读)寄存器堆设计
寄存器堆(Register File)是微处理的关键部件之一.寄存器堆往往具有多个读写端口,其中写端口往往与多个处理单元相对应.传统的方法是使用集中式寄存器堆,即一个集中式寄存器堆匹配N个处理单元.随 ...
- 【CPU微架构设计】利用Verilog设计基于饱和计数器和BTB的分支预测器
在基于流水线(pipeline)的微处理器中,分支预测单元(Branch Predictor Unit)是一个重要的功能部件,它负责收集和分析分支/跳转指令的执行结果,当处理后续分支/跳转指令时,BP ...
- Atitit.架构设计趋势 设计模式 ---微服务架构 soa
Atitit.架构设计趋势 设计模式 ---微服务架构 soa 什么是微服务架构?1 .微服务与SOA的关系 :微服务架架构师面向服务架构(SOA)的一种特定实现1 微服务与康威定律2 微服务的一些 ...
- 互联网保险O2O平台微服务架构设计(转)
非常感谢http://www.cnblogs.com/skyblog/p/5044486.html 关于架构,笔者认为并不是越复杂越好,而是相反,简单就是硬道理也提现在这里.这也是微服务能够流行的原因 ...
- (转)互联网保险O2O平台微服务架构设计
关于架构,笔者认为并不是越复杂越好,而是相反,简单就是硬道理也提现在这里.这也是微服务能够流行的原因,看看市场上曾经出现的服务架构:EJB.SCA.Dubbo等等,都比微服务先进,都比微服务功 ...
- 微服务架构:基于微服务和Docker容器技术的PaaS云平台架构设计(微服务架构实施原理)
版权声明:本文为博主原创文章,转载请注明出处,欢迎交流学习! 基于微服务架构和Docker容器技术的PaaS云平台建设目标是给我们的开发人员提供一套服务快速开发.部署.运维管理.持续开发持续集成的流程 ...
- (转)微服务架构 互联网保险O2O平台微服务架构设计
http://www.cnblogs.com/Leo_wl/p/5049722.html 微服务架构 互联网保险O2O平台微服务架构设计 关于架构,笔者认为并不是越复杂越好,而是相反,简单就是硬道理也 ...
- Java生鲜电商平台-生鲜系统中微服务架构设计与分析实战
Java生鲜电商平台-生鲜系统中微服务架构设计与分析实战 说明: Java生鲜系统中微服务的拆分应该如何架构设计与分析呢?以下是我的实战中的设计与经验分析. 目录 1. 微服务简介2. 当前现状3. ...
- Java生鲜电商平台-秒杀系统微服务架构设计与源码解析实战
Java生鲜电商平台-秒杀系统微服务架构设计与源码解析实战 Java生鲜电商平台- 什么是秒杀 通俗一点讲就是网络商家为促销等目的组织的网上限时抢购活动 比如说京东秒杀,就是一种定时定量秒杀,在规定 ...
随机推荐
- Halo新年灯笼-halonewyaer
title: Halo新年灯笼 date: 2021-12-29 15:49:34.665 updated: 2022-03-10 16:00:53.189 url: https://www.yby6 ...
- OpenGL纹理转换谜团:纹理写入FRAMEBUFFER后的镜像现象
在OpenGL中,最近将一个 GL_TEXTURE_2D 纹理写入到 GL_FRAMEBUFFER ,然后从GL_FRAMEBUFFER读取为GL_TEXTURE_2D纹理后,发现GL_TEXTURE ...
- libGDX游戏开发之Box2D(十四)
libGDX游戏开发之Box2D(十四) libGDX系列,游戏开发有unity3D巴拉巴拉的,为啥还用java开发?因为我是Java程序员emm-国内用libgdx比较少,多数情况需要去官网和goo ...
- electron入门之打包exe分发(五)
electron入门到入土,前面配置阿里镜像加速.为了防止我们打包下载龟速,所以需要给electron配置阿里镜像加速.参考配置阿里云镜像https://blog.csdn.net/weixin_44 ...
- 带你了解VXLAN网络中报文的转发机制
摘要:本节以集中式VXLAN网络(手工方式建立VXLAN隧道)为例,分别介绍相同子网内.不同子网间是如何进行通信的.在了解转发机制的前提下,我们先来看下VXLAN网关有哪些种类. VXLAN二层网关与 ...
- 实战案例丨分布式系统中如何用python实现Paxos
摘要:提到分布式算法,就不得不提 Paxos 算法,在过去几十年里,它基本上是分布式共识的代 名词,因为当前最常用的一批共识算法都是基于它改进的.比如,Fast Paxos 算法. Cheap Pax ...
- 下一代 SCA:流水线成分分析
软件成分分析(SCA)是检测开源库等依赖项中漏洞的重要工具.随着现代应用程序的组成从以自定义代码为主的转变为高达70-90%的开源,管理来自第三方的依赖项的漏洞比以往任何时候的重要性都高出许多.然而现 ...
- 火山引擎ByteHouse:4000字总结,Serverless在OLAP领域应用的五点思考
更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 作为云计算的下一个迭代,Serverless可以使开发者更专注于构建产品中的应用,而无需考虑底层堆栈问题.伴随着近 ...
- 挖掘优质短视频超百万条,火山引擎DataLeap助力电商平台生态治理
更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 在人们的日常生活中,网购已经成为人们生活中不可或缺的购物形式. 根据<中国社交电商行业发展白皮书( ...
- 中国人的 Java 生态,Solon v2.5.3 发布
Solon 是什么? 国产的 Java 应用开发框架.从零开始构建,有自己的标准规范与开放生态(历时五年,具备全球第二级别的生态规模).与其他框架相比,解决了两个重要的痛点:启动慢,费内存. 关键记事 ...