引言 MMC、SD卡和SDHC卡都是基于Flash技術(shù)的新一代存儲器,具有體積小、容量大、數據傳輸快、移動(dòng)靈活等優(yōu)點(diǎn),是許多便攜式電子儀器理想的外部存儲介質(zhì).在數碼相機、MP3、手機與大容量存儲設備中被廣泛使用。MMC卡是基于NAND快閃記憶技術(shù)開(kāi)發(fā)的存儲卡:SD卡是在MMC卡的基礎上開(kāi)發(fā)研制的一款具有大容量、高性能、安全性好等特點(diǎn)的多功能存儲卡.存儲容量最高可達4G:SDHC是高容量SD存儲卡.SD2.0系統規范中規定SDHC卡的容量范圍為大于2GB小于等于32GB.速度最高可達25MB/秒。近年來(lái).雖然MMC卡技術(shù)已逐漸被SD卡所代替.但SD卡接口向下兼容MMC卡.因此MMC卡仍在很多應用場(chǎng)合使用。SD/MMC卡有SD和SPI兩種通信模式。前者可獲得比后者更高的通信速率。目前的SD/MMC接口多采用SPI通信模式。為了能獲得更快的卡訪(fǎng)問(wèn)速度.并且在同一個(gè)接口中支持對MMC、SD和SDHC三類(lèi)卡的訪(fǎng)問(wèn),筆者基于S3C2410控制器設計并實(shí)現了一個(gè)采用SD通信模式的通用的SD/MMC卡驅動(dòng)。下面具體描述該驅動(dòng)的實(shí)現過(guò)程。 1 S3C2410片內SD接口 S3C2410是三星公司的16/32位RISC控制器,它內部具有豐富的系統外圍設備控制器.包括一個(gè)SD接口(SDI)。該SDI兼容SD1.0、MMC2.1l、SDIO1.0規范:支持l位/4位數據總線(xiàn)模式以及塊,流讀寫(xiě)模式切換:SD時(shí)鐘最高達25MHz,MMC時(shí)鐘最高達10MHz。SDI內部寄存器眾多.主要分為三大類(lèi):通用控制類(lèi)寄存器,如:控制寄存器、波特率預分頻因子寄存器等:命令控制類(lèi)寄存器,如:命令參數寄存器、命令控制寄存器、命令狀態(tài)寄存器、4個(gè)命令響應寄存器;數據傳輸類(lèi)寄存器,如:數據控制寄存器、數據狀態(tài)寄存器、FIFO狀態(tài)寄存器、數據寄存器。主機通過(guò)這些寄存器完成卡命令的發(fā)送、接收卡回送的響應以及與卡進(jìn)行數據交換。 2 S3C2410 與 SD/MMC卡的SD模式接口電路 2.1 SD總線(xiàn)通信模式下卡引腳定義 雖然SD/MMC卡有兩種通信模式.但在具體通信過(guò)程中主機只能選擇其中一種通信模式。不同模式下各引腳的功能不完全相同。表1為SD模式下的卡引腳定義。 表1 SD模式下卡的引腳定義 ![]() MMC卡除了接口中沒(méi)有第8和第9腳外,其余與SD卡接口相同。 2.2 SD通信模式下的SD/MMC卡接口電路 S3C2410與SD/MMC卡座的接口電路如圖1所示。接口電路原理圖說(shuō)明如下: ![]() 圖1 SD/MMC卡SD模式接口電路原理圖 CD/DAT3(第1腳)通過(guò)10KΩ電阻上拉到3.3V,使SD/MMC卡上電后自動(dòng)進(jìn)入SD模式。本接口中該引腳用于卡上電后的模式選擇。 CLK(第5腳)為時(shí)鐘輸入信號,SDCMD(第2腳)為命令響應線(xiàn),DATO-DAT;涕7,8,9引腳加上CD/DAT3組成4位數據線(xiàn)。 CD(第10腳)為卡插入檢測信號。由于CD/DAT3引腳用于模式選擇,故在卡座中增加該引腳作為卡檢測信號。由于該引腳被上拉,當卡未插入卡座內時(shí),從INT0/GPF0引腳讀到的是高電平;當卡完全插入到卡座內時(shí),卡座內部觸點(diǎn)接地,則從INT0/GPF0讀到的是低電平。通常通過(guò)檢測該引腳的電平值來(lái)判斷卡的動(dòng)態(tài)拔插動(dòng)作。 WP(第12腳)為卡座中增加的卡寫(xiě)保護檢測信號.檢測原理與CD腳相同。應當注意,SD/MMC卡并不檢測該引腳,因此.卡寫(xiě)保護控制必須由主機實(shí)現。在設計SDfMMC卡座接12時(shí)。WP不是必需的。 為保證輸入的穩定性.除VCC、VSS1和VSS2、GND外的引腳均通過(guò)10Kfl上拉到3.3V。 3 S3C2410與SD/MMC的通信實(shí)現 在SD/MMC卡與主機的通信過(guò)程中.卡一直是從設備.由主機發(fā)送命令來(lái)控制它。當S3C2410(下稱(chēng)主機)以查詢(xún)方式獲取卡已插入卡座.或者當卡插人卡座后通過(guò)CD引腳發(fā)送中斷給主機后.主機首先應完成卡的初始化.之后才能對卡上的數據進(jìn)行讀寫(xiě)。 3.1 卡的初始化和識別 SD/MMC卡在上電后進(jìn)入空閑狀態(tài)(Idle State)。此時(shí).主機需要按照一定的處理流程完成卡的初始化。該過(guò)程主要的工作就是卡的識別(Card Identification),包括識別卡的類(lèi)型、讀取卡上的信息、為卡分配地址等?ǖ某跏蓟幚砹鞒桃(jiàn)圖2。 ![]() 圖2 卡初始化處理流程 在卡識別過(guò)程中.首先發(fā)送CMD8命令判斷卡是否支持V2.00及以上協(xié)議。關(guān)鍵語(yǔ)句如下(語(yǔ)句中的SD_HC_SEND_IF_COND為CMD8命令描述的簡(jiǎn)寫(xiě),其余同): SdmmcSendCmd(SD_HC_SEND_IF_COND,0x1aa); if((rSDIRSPO & Ox1aa) == 0x1aa ) {/* V2.00及以上協(xié)議卡 */ ...... } 此處CMD8命令參數中bit[7]一[0]為0/1交替的0blOl01010即0xaa.是推薦使用的檢測模式;bit[1l]-[8]則用于檢測卡能否在主機提供的電壓下運行,Ob0001表示2.7-3.6V電壓.其他取值目前不可用.若卡支持v2.00及以上協(xié)議.且能夠在指定的電壓下運行.則返回0xlaa。 V2.00及以上協(xié)議的卡有兩種類(lèi)型:標準SD卡和SDHC卡。由于本驅動(dòng)支持SDHC卡,在發(fā)送ACMD41命令時(shí),將其參數中的HCS域(第30位)置為1。判斷語(yǔ)句如下: SdmmcSendCmd(MMC_APP_CMD,SDmmcCardRca); SdmmcSendCmd(SD_APP_OP_COND,Ox40ff8000); if(rSD1RSPO==0xcOff8000){ SdmmcCardType=HC_SD_CARD; /* SDHC CARD */ ......; } else if(rSDIRSP0 == Ox80ff8000){ SdmmcCardType = SD_CARD;/*S D CARD */ } 由于A(yíng)CMD41命令為擴展命令.故需要在該命令前面發(fā)送MMC_APP_CMD(CMD55)命伽知卡后面緊跟的命令為擴展命令。 若卡不響應CMD8.則有可能是MMC卡或V2.00以下的SD卡。由于SD卡支持ACMD命令.而MMC卡不支持該命令。故當卡能正確響應時(shí).則可判斷為SD卡。判斷語(yǔ)句如下: SdmmcSendCmd(MMC_APP_CMD,SdmmcCardRca); SdmmcSendCmd(SD_APP_OP_COND,OxOOff8000); if(rSDIRSP0 == 0x80ff8000){ SdmmcCardType = SD_CARD; /* SD卡 */ ⋯⋯⋯: } 在識別完卡的類(lèi)型后.便可發(fā)送CMD2獲取卡標識等后續共同的初始化過(guò)程. 3.2 卡的讀操作 在初始化和識別完成后并被選中后,SD/MMC卡進(jìn)入傳輸模式.此時(shí)主機可使用讀命令來(lái)讀取卡上數據。每次讀操作通常以塊(一般為512字節)為單位。MMC卡還可以按字節流的方式讀取。若一次讀取的數據在一塊以?xún),可使用單塊讀命令:若超過(guò)一塊.則應使用多塊讀命令.此時(shí)還應在接收完預期數據后給卡發(fā)送停止傳輸命令(CMDl2)通知卡停止傳送數據。 讀命令的4字節參數為欲讀取數據的地址。MMC卡和SD卡的最大容量為4G,地址以字節為單位,通常與512對齊。SDHC卡的容量為2G-32G,字節地址不能尋址全部空間.此時(shí)以塊為單位。命令的參數為欲讀數據的起始塊號。 3.3 卡的寫(xiě)操作 寫(xiě)卡操作也有單塊寫(xiě)命令和多塊寫(xiě)命令.操作流程與讀操作類(lèi)似。SD/MMC卡接收完主機傳送過(guò)來(lái)的數據之后進(jìn)入編程狀態(tài)?▋炔繛閷(xiě)操作提供了一個(gè)緩存.該緩存使得卡在編程的同時(shí)可以接收下一塊數據。當該緩存滿(mǎn)時(shí).卡從DAT0線(xiàn)輸出低電平,表示正處于寫(xiě)的忙狀態(tài).否則從DAT0輸出高阻態(tài)。因此.在往卡發(fā)送數據前應檢查卡是否處于忙狀態(tài)。另外,為了提高某些卡的寫(xiě)速度.建議在多讀寫(xiě)命令之前發(fā)送預擦除命令.預擦除的塊數在該命令的參數中給出。 4 結束語(yǔ) 本文的創(chuàng )新點(diǎn)是以SD通信模式實(shí)現了一個(gè)通用的、能同時(shí)支持MMC卡、SD卡和SDHC卡的SD/MMC卡驅動(dòng)。目前它已被集成到基于FAT文件格式的嵌人式文件系統中.并被成功應用到MP3產(chǎn)品中。 項目經(jīng)濟效益為300萬(wàn)元左右。 作者:湯龍梅,張國安 來(lái)源:《微計算機信息》(嵌入式與SOC)2009年第6-2期 |