大容量輔助存儲(chǔ)系統(tǒng)的設(shè)計(jì)
摘要:串行SPI通信協(xié)議是一種標(biāo)準(zhǔn)的通信協(xié)議。本文首先簡(jiǎn)要介紹了SPI總線模式,然后闡述了單片機(jī)在SPI協(xié)議下與SD卡硬件接口電路,以及軟件模擬的SPI總線數(shù)據(jù)傳輸,最后給出了具體實(shí)現(xiàn)SD卡的初始化、FAT32文件系統(tǒng)的管理和寫操作的軟件流程。
本文引用地址:http://m.butianyuan.cn/article/202451.htm0 引言
SD卡英文全稱為Secure DIGITAL Memory Card,其以FLASH Memory為存儲(chǔ)體,具備體積 小、容量大、功耗低、可擦寫以及非易失性等特點(diǎn),在需要長(zhǎng)時(shí)間地采集、記錄海量數(shù)據(jù)時(shí), 以SD卡作為存儲(chǔ)媒質(zhì)是一種很好的選擇。
1 系統(tǒng)硬件設(shè)計(jì)
1.1 SPI總線
SPI是一種串行總線接口,主要通過三根線進(jìn)行數(shù)據(jù)傳輸:同步時(shí)鐘線SCK,主/從機(jī)輸 出線MISO、主/從機(jī)輸入線MOSI,還有一條低電平有效的從機(jī)片選線CS。SPI系統(tǒng)的片選信號(hào) 以及同步時(shí)鐘脈沖由主機(jī)提供。SPI模式通過四條線就可以完成所有的數(shù)據(jù)交換,傳輸協(xié)議 簡(jiǎn)單,采用SPI模式對(duì)SD卡進(jìn)行讀寫操作可大大簡(jiǎn)化硬件電路的設(shè)計(jì)。 SPI消息由指令、回應(yīng)和數(shù)據(jù)塊組成,所有的操作均由主設(shè)備控制。
SPI接口有0、1、2 和 3共四種操作模式。SPI操作模式?jīng)Q定了設(shè)備接收和發(fā)送數(shù)據(jù)時(shí)的時(shí)鐘相位和極性,即決定了 時(shí)鐘信號(hào)的上升和下降沿與數(shù)據(jù)流動(dòng)方向之間的關(guān)系,如圖1所示。本設(shè)計(jì)采用模式3。
1.2 硬件電路設(shè)計(jì)
MCU采用的是ATMEL公司生產(chǎn)的低電壓、高性能CMOS8位單片機(jī)AT89S51,內(nèi)含4K字節(jié)的可 反復(fù)擦寫的ROM存儲(chǔ)器和128字節(jié)的RAM存儲(chǔ)器。由于SD卡的數(shù)據(jù)寫入是以塊為單位,每塊為 512字節(jié),所以在單片機(jī)最小系統(tǒng)上增加一片RAM。本系統(tǒng)中RAM選用存儲(chǔ)器芯片AT24C64,容 量為64K位。
對(duì)于不帶SPI串行總線接口的單片機(jī)來說,可以使用軟件來模擬SPI的操作,包括串行時(shí) 鐘、數(shù)據(jù)輸入和數(shù)據(jù)輸出。對(duì)于不同的串行接口外圍芯片,它們的時(shí)鐘時(shí)序是不同的。對(duì)于 在SCK的上升沿輸入(接收)數(shù)據(jù)和在下降沿輸出(發(fā)送)數(shù)據(jù)的器件,一般應(yīng)將其串行時(shí) 鐘輸出口P1.1的初始狀態(tài)設(shè)置為1,而在允許接口后再置P1.1為0。這樣,MCU在輸出1位SCK 時(shí)鐘的同時(shí),將使接口芯片串行左移,從而輸出1位數(shù)據(jù)至單片機(jī)的P1.3口(模擬MCU的MISO 線),此后再置P1.1為1,使單片機(jī)從P1.0(模擬MCU的MOSI線)輸出1位數(shù)據(jù)(先為高位)至 串行接口芯片。至此,模擬1位數(shù)據(jù)輸入輸出便宣告完成。此后再置P1.1為0,模擬下1位數(shù) 據(jù)的輸入輸出……,依此循環(huán)8次,即可完成1次通過SPI總線傳輸8位數(shù)據(jù)的操作。對(duì)于在SCK 的下降沿輸入數(shù)據(jù)和上升沿輸出數(shù)據(jù)的器件,則應(yīng)取串行時(shí)鐘輸出的初始狀態(tài)為0,即在接 口芯片允許時(shí),先置P1.1為1,以便外圍接口芯片輸出1位數(shù)據(jù)(MCU接收1位數(shù)據(jù)),之后再 置時(shí)鐘為0,使外圍接口芯片接收1位數(shù)據(jù)(MCU發(fā)送1位數(shù)據(jù)),從而完成1位數(shù)據(jù)的傳送。
評(píng)論