一种SD卡控制器的硬件实现.pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

一种SD卡控制器的硬件实现

左源,刘新宁,师超

东南大学国家专用集成电路系统工程技术研究中心,江苏南京(210096)

摘要:本文阐述了一种基于AMBA总线的SD卡控制器的工作原理,进行了模块划分,

并采用硬件描述语言实现了设计;利用SYNOPSYS公司的EDA工具对该控制器进行仿真、

综合;通过FPGA验证。

关键词:AMBA总线;SD总线;SD卡控制器;FPGA

1引言

随着消费类电子产品音视频等多媒体功能的不断增强,系统对于存储介质的安全、容

量、性能的需求不断提高。SD存储卡支持符合SDMI标准的版权保护机制,并且具有更快

的传输速度和更大的存储容量,同时SD存储卡还向上兼容MMC卡[2]。由于SD卡的这些优

点,越来越多的电子产品提供SD卡扩展接口。本文设计的SD卡控制器基于一款面向多媒

体应用的SoC芯片,该芯片采用AMBA总线架构。

本文通过对SD卡控制器工作原理的分析,确定控制器的总体结构并进行具体的模块

划分,最后使用硬件描述语言将设计实现并通过FPGA验证。

2SD卡控制器的工作原理

SD卡控制器通过SD总线对SD卡进行初始化以及读写等操作。SD总线包括时钟线

CLK,命令线CMD,数据线DAT3–DAT0等[2]。SD总线上的通信基于命令和数据的比特流,

命令和数据的第一位是起始位,最后一位是停止位。控制器通过发出命令发起操作,命令

通过命令线传给SD卡,SD卡发出响应作为对于命令的回应,响应也在命令线上传输。控

制器接收并分析响应以确定SD卡的状态,并根据SD卡的状态进行下一步的操作。

为了检测传输错误,命令和响应都带有7位CRC校验码。在发送命令时控制器需要计

算命令的CRC校验码并附在命令之后一起发送,SD卡在接收命令时重新计算命令的CRC

码并比较计算的CRC校验码和接收到的CRC校验码是否一致来确定传输的正确性,对于

响应也采取类似的处理。如果命令或响应在传输过程中有错误发生,SD卡控制器会向处

理器发出中断。

在写操作时,控制器发出单数据块写命令(CMD24)或者多数据块写命令(CMD25),

在收到SD卡的正确响应后,控制器开始根据SD总线协议发出写数据。在读操作时,控

制器发出单数据块读命令(CMD17)或者多数据块读命令(CMD18),控制器开始等待读

数据的起始位,然后根据SD总线协议接收SD卡发出的读数据。控制器要支持1位/4位

两种数据宽度,硬件电路按照SD总线协议将有效数据组织成1位/4位宽度并同步收发。

同样为了检测数据线上的传输错误,数据的收发也需要CRC校验,所不同的是,命令和响

应采用7位CRC校验而数据采用16位CRC校验,这是由于数据比特流要比命令和响应比

-1-

特流长得多。

控制器通过时钟线为SD卡提供时钟,命令和数据的传输都要与这个时钟同步。同时

这个时钟的频率必须可以配置,因为SD卡在初始化状态和正常工作状态需要不同频率的

时钟,而且不同SD卡正常工作的最大频率也不一样。

综上所述,SD卡控制器需要为SD卡提供频率可配置的时钟,控制器还要负责发出命

令接收响应以及发送/接收数据,为保证传输的正确性控制器还要对命令、响应、数据进行

CRC校验。

3模块划分及实现

根据以上对于SD卡控制器工作原理和总体设计的分析,将SD控制器分成图1所示

的7个子模块:SD时钟控制模块(CLKCONT)、命令收发控制器(CMDCONTROLLER)、

数据收发控制器(DATACONTROLLER)、中断控制器(INTC)、读数据缓冲器(READ

FIFO)、写数据缓冲器(WRITEFIFO)和AMBA总线接口模块(APBINTERFACE)。

图1SD控制器模块划分

3.1SD时钟

文档评论(0)

文档小天才 + 关注
实名认证
文档贡献者

就是文档小天才

1亿VIP精品文档

相关文档