HCS12X单片机的SD卡FAT文件系统读写设计

相关专题: 芯片

摘要:基于HCSl2X单片机SPI模块读取Micro SD卡与SD卡,并解析SD卡上FAT文件系统以实现文件的读取与写入。测试证明,系统对FAT文件系统的读取稳定,误差小,速度较快。使用HCSl2X类单片机对SD卡进行读取,在汽车智能设计和单片机调试方面有较高的应用价值。

关键词:HCSl2X单片机;SPI模块;SD卡;Micro SD卡;FAT文件系统

随着信息技术的飞速发展,高容量存储芯片日益向大容量小体积发展,其中以SD卡、Micro SD卡为突出代表。SD卡由日本松下、东芝及美国SanDisk公司于1999年8月共同开发研制。大小犹如一张邮票的SD卡,重量只有2 g,却拥有高记忆容量、快速数据传输率、极大的移动灵

活性以及很好的安全性。通过单片机处理SD卡信息,可以将信息化嵌入式产业向更小体积发展。考虑到稳定性与读取速度,研究中采用了Fr-eescale公司的16位单片机MC9S12XSl28MAA。为了进一步满足嵌入式研究的实时调试与应用需要,把SD卡的读取以及FATl6文件系统的读取写入移植到此单片机中,使开发应用有更好的扩展性。本文首次把FATl6文件系统的读取移植到HCSl2X单片机上,并通过HCSl2X单片机的SPI模块进行SD卡的读写,取得了良好的效果。

1 研究平台和设计思想

1.1 平台介绍

①MCS9S12XSl28MAA:Freescale公司16位单片机HCSl2X家族中的一员,相比于其他HCSl2X单片机,去除了XGATE协处理器,大大降低了成本。此单片机内嵌了许多资源,包括128KB Flash、4 KB EEPROM、16 KBROM以及多种通信接口。

②Micro SD卡:采用SD架构设计而成,尺寸几乎只有一片指甲盖大小,由摩托罗拉公司与SanDisk公司共同研发,是一种超小型卡(11 mm×15 mm×1 ram),约为SD卡的1/4。它支持3种传输模式,SPI模式(独立序列输入和序列输出),1位SD模式(独立指令和数据通道,独有的传输格式),以及4位SD模式(使用额外的引脚以及某些重新设置的引脚,支持4位宽的并行传输)。

③CodeWarrior:Freescale公司开发的编程环境。本文使用的CodeWarrior Special 5.0 For S12(X)是专门针对HCSl2X单片机开发的,可以进行程序的编辑、编译、链接和在线调试等多项功能,支持在C语言中嵌入汇编语言。

④移植条件:对于本文中的SD卡读取与写入,用户的单片机推荐使用HCSl2X系列,也可使用HCSl2系列,但总线超频会不稳定,从而影响SD卡读写速率以及稳定性。

1.2 设计思想

图1显示了本文中所使用的SD卡FAT文件系统通过MC9S12XSl28MAA进行解析的软硬件结构体系。编译链接软件使用CodeWarrior 5.O,硬件采用MC9S12XSl28MAA单片机与Kingston公司的Micro SD卡。代码由4部分组成:用户应用部分(由用户编写控制,本文使用MC9S12XS128MAA SCI串口模块进行信息调试),FAT文件系统读取解析部分,硬件控制部分(通过单片机SPI模块与SD卡连接),以及单片机CPU的初始化部分。其中,SPI模块与SD卡连接的硬件控制部分,以及FAT文件系统的读取解析部分是本文的重点。

其中,Sd_SPI.h是关于SD卡读取写入部分的一些宏定义、常量和函数的声明;Sd_SPI.c包括了通过SPI模块读写SD卡的代码;Fat.h是关于Fat文件系统解析的全局变量、宏定义以及函数声明;Fat.c包括了Fat文件系统解析的代码;SimpleFat.c是简易读取Fat文件系统信息的代码;SimpleFat.h是其全局变量以及函数的声明。

2 硬件设计

SD卡有2种操作模式:SD卡模式、SPI模式。SD卡模式允许通过4线高速总线传输,但由于大部分单片机无此接口模块,故选择SPI模式。HCSl2X系列单片机内部都带有此同步串行外部设备接口(Serial Peripheral Interface,SPI)。单片机可以通过SPI系统组成一个通信速率比SCI高的同步网络,故使用SPI模式可以把外设减少到最低。SPI模式相对于SD卡模式的缺点是损失了传输速度;但是目前的微处理器的处理速度越来越高,利用SPI模式大都能满足工程需要。

HCSl2X单片机的全双工8位SPI模块有4个引脚,分别为主入从出引脚MISO、主入从出引脚MOSI、串行时钟引脚SCK以及从机片选引脚SS。当CS信号线为低电平时,主机开始所有的总线传输。数据从单片机的MOSI引脚同步输入Micro SD卡的DA引脚,Micro SD卡返回数据由DO线同步输入单片机的MISO引脚,数据在CLK信号的上升沿同步输入和输出。

3 软件设计

3.1 HCSl2X总线时钟超频

MC9S12XSl28MAA默认总线时钟默认同外接晶振相关,但可以通过配置PLL锁相环实现单片机总线超频,从而加快SD卡读取速率。实验中可通过下列代码将单片机总线频率超频到80MHz:

作者:时 尧 天津大学 来源:电子设计工程


微信扫描分享本文到朋友圈
扫码关注5G通信官方公众号,免费领取以下5G精品资料

本周热点本月热点

 

  最热通信招聘

  最新招聘信息

最新技术文章

最新论坛贴子