单片机读写SD卡电路设计和程序.docVIP

  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卡电路设计和程序

单片机读写SD卡电路设计和程序   摘要:本文设计了单片机读写SD卡电路,从硬件设计到软件实现的过程。本文以ARM 7为例,描述了设计工作原理,并给出连接图和程序。    关键字:SD卡单片机   Abstract: the paper presents the design of the single chip computer literacy SD card circuit, from hardware to software implementation process of design. Based on the ARM and for example, describes the design principle, and gives connection diagram and procedures.   Key word: SD card microcontroller          中图分类号:TN108.7文献标识码:A文章编号:    引言    近年来,使用半导体存储器作存储媒体是影音器材一个新的发展热点和潮流。目前已出现了各种各样的存储卡,如多媒体存储卡(MMC)、安全数字(SD)存储卡、记忆棒(MS)等。    SD卡就是Secure Digital Card--安全数码卡,是由日本松下公司,东芝公司和美国SANDISK公司1999年8月共同开发研制的,具有大容量,高性能,尤其是安全等多种特点的多功能存储卡。随后并成立一家名为SD-3C的公司负责将相关技术规格授权厂商制造。并于2000年1月正式成立SD Association,向全世界推广SD内存标准规格,并进行制定SD卡相关应用产品规格及检测规范。    1 系统设计方案    1.1系统硬件组成       图1系统组成    本设计硬件电路采用的整体结构如图1所示。RS232―HOST(单片机)―SD卡。其中单片机采用流行的ARM 7 PLC2132,串行接口RS232为标准3线制。    由稳定电压器供给5V电压,单片机通过SPI总线:时钟、输入、输出、片选4个I/O接口控制SD卡的读写操作。由于SD卡的供电电压为3.3V,所以我采用了LM317对SD卡提供3.3V的电压。SD的输入输出电压电平是3.3V的,而单片机的4个I/O接是5V的TTL电平,所以我采用了74LVX4245电平转换驱动芯片,对SD卡的数据传输进行驱动。    2 系统程序设计    2.1 SD卡模态选择    SD卡在工作时有两种总线模式:SD总线模式和SPI总线模式。两种模式下从管脚定义到数据传输协议都是不同的,比较如下:    1)、SD总线模式的优点是可以采用4条数据线并行传输数据,数据传输速率高。缺点是传输协议较为复杂,只有少数高档的单片机才提供此接口,若用软件的方法来模拟SD总线,则是很繁琐的,而且这样将大大降低SD卡的数据传输速率。    2)、SPI总线模式缺点是只有一条数据传输线,所以数据传输速率较低;优点是绝大多数中高档单片机都提供SPI总线,即使不提供,也很容易用软件的方法来模拟SPI总线,而且SD卡的SPI总线模式传输协议简单,易于实现。本设计采用SPI总线模式进行数据传输的。    2.2 上电模式    当加电之后,SD卡热插入,SD卡进入等待状态.在这时候SD卡不理睬所有的总线数据,直到收到ACMD41(ACMD指令类型将总是以CMD55之前)。ACMD41是一个用来操作电压范围和获得卡特别同步指令。除卡的操作电压范围之外, ACMD41回应包含忙碌的指令,指出卡仍然正在处理它的加电的程序而且还没准备好确认。这一位告知主机卡还没准备好。主机必须等候(继续等待)直到这一位被清除的。在SD卡的加电程序上,最大时间将不超过1秒。    2.3 读数据    在数据传输中,SPI模态中支持单区段和多区段操作(SD卡的CMD17或CMD18指令)。在接到有效的阅读命令时,SD卡回应以一个被SET_BLOCK_LENGTH(CMD16)指令定义一个数据.如图2 所示。       图2区段读操作    最大的区段长度是READ_BL_LEN(CSD参数)所定义的512个字节。区段长度可能是在 1到READ_BL_LEN之间任何数值。    开始地址可能是卡有效范围的地址中任何的字节。但一定是包含在同一扇区里。假使数据接收错误,卡将停止传输任何的数据。这时一个特别的错误数据将会被送到主机。    2.4 写数据    在写数据时,首先进入SPI模态, SD卡支持单一区段或者多区段写操作。在接到有效的写命令(CMD24或CMD25)后,卡会回应而且将等候一个数据区段从主机送出。CRC后

文档评论(0)

bokegood + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档