【正点原子探索者STM32F407开发板例程连载+教学】第44章 FATFS文件系统实验
第四十四章 ?FATFS實驗? [mw_shl_code=c,true]1.硬件平臺:正點原子探索者STM32F407開發板?2.軟件平臺:MDK5.1 3.固件庫版本:V1.4.0 [/mw_shl_code] ?? ????上一章,我們學習了SD卡的使用,不過僅僅是簡單的實現讀扇區而已,真正要好好應用SD卡,必須使用文件系統管理,本章,我們將使用FATFS來管理SD卡,實現SD卡文件的讀寫等基本功能。本章分為如下幾個部分: 44.1 FATFS簡介 44.2?硬件設計 44.3?軟件設計 44.4?下載驗證 ? 44.1 FATFS簡介????FATFS是一個完全免費開源的FAT?文件系統模塊,專門為小型的嵌入式系統而設計。它完全用標準C?語言編寫,所以具有良好的硬件平**立性,可以移植到8051、PIC、AVR、SH、Z80、H8、ARM?等系列單片機上而只需做簡單的修改。它支持FATl2、FATl6?和FAT32,支持多個存儲媒介;有獨立的緩沖區,可以對多個文件進行讀/寫,并特別對8?位單片機和16?位單片機做了優化。 FATFS的特點有: l??Windows兼容的FAT文件系統(支持FAT12/FAT16/FAT32) l? 與平臺無關,移植簡單 l? 代碼量少、效率高 l? 多種配置選項 ?? 支持多卷(物理驅動器或分區,最多10個卷) ?? 多個ANSI/OEM代碼頁包括DBCS ?? 支持長文件名、ANSI/OEM或Unicode ?? 支持RTOS ?? 支持多種扇區大小 ?? 只讀、最小化的API和I/O緩沖區等 FATFS的這些特點,加上免費、開源的原則,使得FATFS應用非常廣泛。FATFS模塊的層次結構如圖44.1.1所示: ? ? 圖44.1.1 FATFS層次結構圖 最頂層是應用層,使用者無需理會FATFS的內部結構和復雜的FAT?協議,只需要調用FATFS模塊提供給用戶的一系列應用接口函數,如f_open,f_read,f_write?和f_close等,就可以像在PC?上讀/寫文件那樣簡單。 中間層FATFS模塊,實現了FAT?文件讀/寫協議。FATFS模塊提供的是ff.c和ff.h。除非有必要,使用者一般不用修改,使用時將頭文件直接包含進去即可。 需要我們編寫移植代碼的是FATFS模塊提供的底層接口,它包括存儲媒介讀/寫接口(disk I/O)和供給文件創建修改時間的實時時鐘。 FATFS的源碼,大家可以在:http://elm-chan.org/fsw/ff/00index_e.html?這個網站下載到,目前最新版本為R0.10b。本章我們就使用最新版本的FATFS作為介紹,下載最新版本的FATFS軟件包,解壓后可以得到兩個文件夾:doc和src。doc里面主要是對FATFS的介紹,而src里面才是我們需要的源碼。 其中,與平臺無關的是: ffconf.h???????????????? FATFS模塊配置文件 ff.h?????????????????????? FATFS和應用模塊公用的包含文件 ff.c?????????????????????? FATFS模塊 diskio.h???????????????? FATFS和disk I/O模塊公用的包含文件 interger.h???????????????數據類型定義 option???????????????????可選的外部功能(比如支持中文等) 與平臺相關的代碼(需要用戶提供)是: diskio.c???????????????? FATFS和disk I/O模塊接口層文件 FATFS模塊在移植的時候,我們一般只需要修改2個文件,即ffconf.h和diskio.c。FATFS模塊的所有配置項都是存放在ffconf.h里面,我們可以通過配置里面的一些選項,來滿足自己的需求。接下來我們介紹幾個重要的配置選項。 1)_FS_TINY。這個選項在R0.07版本中開始出現,之前的版本都是以獨立的C文件出現(FATFS和Tiny FATFS),有了這個選項之后,兩者整合在一起了,使用起來更方便。我們使用FATFS,所以把這個選項定義為0即可。 2)_FS_READONLY。這個用來配置是不是只讀,本章我們需要讀寫都用,所以這里設置為0即可。 3)_USE_STRFUNC。這個用來設置是否支持字符串類操作,比如f_putc,f_puts等,本章我們需要用到,故設置這里為1。 4)_USE_MKFS。這個用來定時是否使能格式化,本章需要用到,所以設置這里為1。 5)_USE_FASTSEEK。這個用來使能快速定位,我們設置為1,使能快速定位。 6)_USE_LABEL。這個用來設置是否支持磁盤盤符(磁盤名字)讀取與設置。我們設置為1,使能,就可以通過相關函數讀取或者設置磁盤的名字了。 7)_CODE_PAGE。這個用于設置語言類型,包括很多選項(見FATFS官網說明),我們這里設置為936,即簡體中文(GBK碼,需要c936.c文件支持,該文件在option文件夾)。 8)_USE_LFN。該選項用于設置是否支持長文件名(還需要_CODE_PAGE支持),取值范圍為0~3。0,表示不支持長文件名,1~3是支持長文件名,但是存儲地方不一樣,我們選擇使用3,通過ff_memalloc函數來動態分配長文件名的存儲區域。 9)_VOLUMES。用于設置FATFS支持的邏輯設備數目,我們設置為2,即支持2個設備。 10)_MAX_SS。扇區緩沖的最大值,一般設置為512。 其他配置項,我們這里就不一一介紹了,FATFS的說明文檔里面有很詳細的介紹,大家自己閱讀即可。下面我們來講講FATFS的移植,FATFS的移植主要分為3步: ①?????數據類型:在integer.h?里面去定義好數據的類型。這里需要了解你用的編譯器的數 據類型,并根據編譯器定義好數據類型。 ②?????配置:通過ffconf.h配置FATFS的相關功能,以滿足你的需要。 ③?????函數編寫:打開diskio.c,進行底層驅動編寫,一般需要編寫6?個接口函數,如 圖44.1.2?所示: ? 圖44.1.2 diskio?需要實現的函數 ???????通過以上三步,我們即可完成對FATFS的移植。 ???????第一步,我們使用的是MDK5.11a編譯器,器數據類型和integer.h里面定義的一致,所以此步,我們不需要做任何改動。 ???????第二步,關于ffconf.h里面的相關配置,我們在前面已經有介紹(之前介紹的10個配置),我們將對應配置修改為我們介紹時候的值即可,其他的配置用默認配置。 第三步,因為FATFS模塊完全與磁盤I/O?層分開,因此需要下面的函數來實現底層物理磁盤的讀寫與獲取當前時間。底層磁盤I/O?模塊并不是FATFS的一部分,并且必須由用戶提供。這些函數一般有6個,在diskio.c里面。 首先是disk_initialize函數,該函數介紹如圖44.1.3所示: ?圖44.1.3?disk_initialize函數介紹 ? ???????第二個函數是disk_status函數,該函數介紹如圖44.1.4所示: ? 圖44.1.4?disk_status函數介紹 ???????第三個函數是disk_read函數,該函數介紹如圖44.1.5所示: ? 圖44.1.5?disk_read函數介紹 ???????第四個函數是disk_write函數,該函數介紹如圖44.1.6所示: ? 圖44.1.6?disk_write函數介紹 ???????第五個函數是disk_ioctl函數,該函數介紹如圖44.1.7所示: ? 圖44.1.7?disk_ioctl函數介紹 ???????最后一個函數是get_fattime函數,該函數介紹如圖44.1.8所示: ? 圖44.1.8?get_fattime函數介紹 ???????以上六個函數,我們將在軟件設計部分一一實現。通過以上3個步驟,我們就完成了對FATFS的移植,就可以在我們的代碼里面使用FATFS了。 ?????? FATFS提供了很多API函數,這些函數FATFS的自帶介紹文件里面都有詳細的介紹(包括參考代碼),我們這里就不多說了。這里需要注意的是,在使用FATFS的時候,必須先通過f_mount函數注冊一個工作區,才能開始后續API的使用,關于FATFS的介紹,我們就介紹到這里。大家可以通過FATFS自帶的介紹文件進一步了解和熟悉FATFS的使用。 44.2?硬件設計?本章實驗功能簡介:開機的時候先初始化SD卡,初始化成功之后,注冊兩個工作區(一個給SD卡用,一個給SPI FLASH用),然后獲取SD卡的容量和剩余空間,并顯示在LCD模塊上,最后等待USMART輸入指令進行各項測試。本實驗通過DS0指示程序運行狀態。 本實驗用到的硬件資源有: 1)??指示燈DS0? 2)??串口 3)??TFTLCD模塊 4)??SD卡 5)??SPI FLASH ????? 這些,我們在之前都已經介紹過,如有不清楚,請參考之前內容。 44.3?軟件設計打開本章實驗目錄可以看到,我們在工程目錄下新建了一個FATFS的文件夾,然后將FATFS R0.10b程序包解壓到該文件夾下。同時,我們在FATFS文件夾里面新建了一個exfuns的文件夾,用于存放我們針對FATFS做的一些擴展代碼。設計完如圖44.3.1所示: ? 圖44.3.1 FATFS文件夾子目錄 然后打開我們實驗工程可以看到,我們新建了FATFS分組,將必要的源文件添加到了FATFS分組之下。打開diskio.c,代碼如下: #define SD_CARD 0? //SD卡,卷標為0 #define EX_FLASH 1?? //外部flash,卷標為1 #define FLASH_SECTOR_SIZE 512??????????????? ? //對于W25Q128 //前12M字節給fatfs用,12M字節后,用于存放字庫,字庫占用3.09M.???剩余部分, //給客戶自己用???? ?????????????????? ???? u16? FLASH_SECTOR_COUNT=2048*12;?????? //W25Q1218,前12M字節給FATFS占用 #define FLASH_BLOCK_SIZE?? ????? 8???? ??? //每個BLOCK有8個扇區 //初始化磁盤 DSTATUS disk_initialize ( ?????? BYTE pdrv????????????????????????? /* Physical drive nmuber (0..) */ ) { ?????? u8 res=0; ??? ?????? switch(pdrv) ?????? { ????????????? case SD_CARD://SD卡 ???????????????????? res=SD_Init();//SD卡初始化 ? ????????????????? break; ????????????? case EX_FLASH://外部flash ???????????????????? W25QXX_Init(); ???????????????????? FLASH_SECTOR_COUNT=2048*12;//W25Q1218,前12M字節給FATFS占用 ??????????????????? break; ????????????? default: ???????????????????? res=1; ?????? }??????????? ?????? if(res)return? STA_NOINIT; ?????? else return 0; //初始化成功 }? ? //獲得磁盤狀態 DSTATUS disk_status ( ?????? BYTE pdrv??????????? /* Physical drive nmuber (0..) */ ) { ?????? return 0; } ?? //讀扇區 //drv:磁盤編號0~9 //*buff:數據接收緩沖首地址 //sector:扇區地址 //count:需要讀取的扇區數 DRESULT disk_read ( ?????? BYTE pdrv,?????????? /* Physical drive nmuber (0..) */ ?????? BYTE *buff,???????? /* Data buffer to store read data */ ?????? DWORD sector,???? /* Sector address (LBA) */ ?????? UINT count?????????? /* Number of sectors to read (1..128) */ ) { ?????? u8 res=0; ??? if (!count)return RES_PARERR;//count不能等于0,否則返回參數錯誤????????????? ???? ? ?????? switch(pdrv) ?????? { ????????????? case SD_CARD://SD卡 ???????????????????? res=SD_ReadDisk(buff,sector,count);?? ???????????????????? break; ????????????? case EX_FLASH://外部flash ???????????????????? for(;count>0;count--) ???????????????????? { ??? ? W25QXX_Read(buff,sector*FLASH_SECTOR_SIZE,FLASH_SECTOR_SI ZE); ??????????????????????????? sector++; ??????????????????????????? buff+=FLASH_SECTOR_SIZE; ???????????????????? } ???????????????????? res=0; ???????????????????? break; ????????????? default: ???????????????????? res=1; ?????? } ?? //處理返回值,將SPI_SD_driver.c的返回值轉成ff.c的返回值 ??? if(res==0x00)return RES_OK;????? ??? else return RES_ERROR;????? ?? } //寫扇區 //drv:磁盤編號0~9 //*buff:發送數據首地址 //sector:扇區地址 //count:需要寫入的扇區數 #if _USE_WRITE DRESULT disk_write ( ?????? BYTE pdrv,????????????????? /* Physical drive nmuber (0..) */ ?????? const BYTE *buff, /* Data to be written */ ?????? DWORD sector,??????????? /* Sector address (LBA) */ ?????? UINT count????????????????? /* Number of sectors to write (1..128) */ ) { ?????? u8 res=0;? ??? if (!count)return RES_PARERR;//count不能等于0,否則返回參數錯誤????????????? ???? ? ?????? switch(pdrv) ?????? { ????????????? case SD_CARD://SD卡 ???????????????????? res=SD_WriteDisk((u8*)buff,sector,count); ???????????????????? break; ????????????? case EX_FLASH://外部flash ???????????????????? for(;count>0;count--) ???????????????????? {??????????????????????????????????????????????????????????????????? ??? ??????????????????????????? W25QXX_Write((u8*)buff,sector*FLASH_SECTOR_SIZE,FLASH_SECT OR_SIZE); ??????????????????????????? sector++; ??????????????????????????? buff+=FLASH_SECTOR_SIZE; ???????????????????? } ???????????????????? res=0; ???????????????????? break; ????????????? default: ???????????????????? res=1; ?????? } ??? //處理返回值,將SPI_SD_driver.c的返回值轉成ff.c的返回值 ??? if(res == 0x00)return RES_OK;??? ??? else return RES_ERROR;????? } #endif //其他表參數的獲得 ?//drv:磁盤編號0~9 ?//ctrl:控制代碼 ?//*buff:發送/接收緩沖區指針 #if _USE_IOCTL DRESULT disk_ioctl ( ?????? BYTE pdrv,?????????? /* Physical drive nmuber (0..) */ ?????? BYTE cmd,?????????? /* Control code */ ?????? void *buff???????????? /* Buffer to send/receive control data */ ) { ?????? DRESULT res;????????????????????????????????????????? ? ????????????????? ????? ?????? if(pdrv==SD_CARD)//SD卡 ?????? { ?????? ??? switch(cmd) ?????? ??? { ????????????? ??? case CTRL_SYNC: ??????????????????????????? res = RES_OK; ????????????? ??????? break;???? ????????????? ??? case GET_SECTOR_SIZE: ??????????????????????????? *(DWORD*)buff = 512; ????????????? ??????? res = RES_OK; ????????????? ??????? break;???? ????????????? ??? case GET_BLOCK_SIZE: ??????????????????????????? *(WORD*)buff = SDCardInfo.CardBlockSize; ????????????? ??????? res = RES_OK; ????????????? ??????? break;???? ????????????? ??? case GET_SECTOR_COUNT: ????????????? ??????? *(DWORD*)buff = SDCardInfo.CardCapacity/512; ????????????? ??????? res = RES_OK; ????????????? ??????? break; ????????????? ??? default: ????????????? ??????? res = RES_PARERR; ????????????? ??????? break; ?????? ??? } ?????? }else if(pdrv==EX_FLASH) //外部FLASH? ?????? { ?????? ??? switch(cmd) ?????? ??? { ????????????? ??? case CTRL_SYNC: ??????????????????????????? res = RES_OK; ????????????? ??????? break;???? ????????????? ??? case GET_SECTOR_SIZE: ????????????? ??????? *(WORD*)buff = FLASH_SECTOR_SIZE; ????????????? ??????? res = RES_OK; ????????????? ??????? break;???? ????????????? ??? case GET_BLOCK_SIZE: ????????????? ??????? *(WORD*)buff = FLASH_BLOCK_SIZE; ????????????? ??????? res = RES_OK; ????????????? ??????? break;???? ????????????? ??? case GET_SECTOR_COUNT: ????????????? ??????? *(DWORD*)buff = FLASH_SECTOR_COUNT; ????????????? ??????? res = RES_OK; ????????????? ??????? break; ????????????? ??? default: ????????????? ??????? res = RES_PARERR; ????????????? ??????? break; ?????? ??? } ?????? }else res=RES_ERROR;//其他的不支持 ??? return res; } #endif //獲得時間 //User defined function to give a current time to fatfs module????? */ //31-25: Year(0-127 org.1980), 24-21: Month(1-12), 20-16: Day(1-31) */?????????????????????????????????????????????????????????????????????????????????????????????????????????????????? ??????????????????????????????????????????????????????????????????????????????????????????????????????????????????????? //15-11: Hour(0-23), 10-5: Minute(0-59), 4-0: Second(0-29 *2) */??????????????????????????????????????????????????????????????????????? ???????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????? DWORD get_fattime (void) {????????????????????????? ?????? return 0; }?????????????????? //動態分配內存 void *ff_memalloc (UINT size)????????????????? { ?????? return (void*)mymalloc(SRAMIN,size); } //釋放內存 void ff_memfree (void* mf)???????? { ?????? myfree(SRAMIN,mf); }???? ??????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????? 該函數實現了我們44.1節提到的6個函數,同時因為在ffconf.h里面設置對長文件名的支持為方法3,所以必須實現ff_memalloc和ff_memfree這兩個函數。本章,我們用FATFS管理了2個磁盤:SD卡和SPI FLASH。SD卡比較好說,但是SPI FLASH,因為其扇區是4K字節大小,我們為了方便設計,強制將其扇區定義為512字節,這樣帶來的好處就是設計使用相對簡單,壞處就是擦除次數大增,所以不要隨便往SPI FLASH里面寫數據,非必要最好別寫,如果頻繁寫的話,很容易將SPI FLASH寫壞。 打開ffconf.h可以看到,我們根據前面講解修改了相關配置,此部分就不貼代碼了,請大家參考本例程源碼。另外,cc936.c主要提供UNICODE到GBK以及GBK到UNICODE的碼表轉換,里面就是兩個大數組,并提供一個ff_convert的轉換函數,供UNICODE和GBK碼互換,這個在中文長文件名支持的時候,必須用到! 前面提到,我們在FATFS文件夾下還新建了一個exfuns的文件夾,該文件夾用于保存一些FATFS一些針對FATFS的擴展代碼,本章,我們編寫了4個文件,分別是:exfuns.c、exfuns.h、fattester.c和fattester.h。其中exfuns.c主要定義了一些全局變量,方便FATFS的使用,同時實現了磁盤容量獲取等函數。而fattester.c文件則主要是為了測試FATFS用,因為FATFS的很多函數無法直接通過USMART調用,所以我們在fattester.c里面對這些函數進行了一次再封裝,使得可以通過USMART調用。這幾個文件的代碼,我們就不貼出來了,請大家參考本例程源碼, 最后,我們打開main.c,?main函數如下: int main(void) {??????????? ????? u32 total,free; ?????? u8 t=0; u8 res=0;?????????? ?????? NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//設置系統中斷優先級分組2 ?????? delay_init(168); ?//初始化延時函數 ?????? uart_init(115200);???????? //初始化串口波特率為115200 ?????? LED_Init();??????????????????????????????? //初始化LED ?????? usmart_dev.init(84);???????????? //初始化USMART ????? LCD_Init();??????????????????????????????? //LCD初始化? ????? KEY_Init();??????????????????????????????? //按鍵初始化 ?????? W25QXX_Init();???????????????????????? //初始化W25Q128 ?????? my_mem_init(SRAMIN);??????????? //初始化內部內存池 ?????? my_mem_init(SRAMCCM);???????? //初始化CCM內存池 ????? POINT_COLOR=RED;//設置字體為紅色 ?????? LCD_ShowString(30,50,200,16,16,"Explorer STM32F4");?????? ?????? LCD_ShowString(30,70,200,16,16,"FATFS TEST");? ?????? LCD_ShowString(30,90,200,16,16,"ATOM@ALIENTEK"); ?????? LCD_ShowString(30,110,200,16,16,"2014/5/15");?? ?????? LCD_ShowString(30,130,200,16,16,"Use USMART for test");? ?? ????? while(SD_Init())//檢測不到SD卡 ?????? { ????????????? LCD_ShowString(30,150,200,16,16,"SD Card Error!"); delay_ms(500);? ????????????? LCD_ShowString(30,150,200,16,16,"Please Check! "); delay_ms(500); ????????????? LED0=!LED0;//DS0閃爍 ?????? } ????? exfuns_init();???????????????????????????????????? //為fatfs相關變量申請內存????????????????????? ? ??? f_mount(fs[0],"0:",1); ?????????????????????? //掛載SD卡 ????? res=f_mount(fs[1],"1:",1); ???????????????? //掛載FLASH.????? ?????? if(res==0X0D)//FLASH磁盤,FAT文件系統錯誤,重新格式化FLASH ?????? { ????????????? LCD_ShowString(30,150,200,16,16,"Flash Disk Formatting...");????? //格式化FLASH ????????????? res=f_mkfs("1:",1,4096);//格式化FLASH,1,盤符;1,不需要引導區,8個扇區為1個簇 ????????????? if(res==0) ????????????? { ???????????????????? f_setlabel((const TCHAR *)"1:ALIENTEK");//設置磁盤的名字為:ALIENTEK ???????????????????? LCD_ShowString(30,150,200,16,16,"Flash Disk Format Finish");//格式化完成 ????????????? }else LCD_ShowString(30,150,200,16,16,"Flash Disk Format Error ");//格式化失敗 ????????????? delay_ms(1000); ?????? }???????????????????????????????????????????????????????????????????????????????????????? ??? ?????? LCD_Fill(30,150,240,150+16,WHITE);????? //清除顯示?????????????????? ? ?????? while(exf_getfree("0",&total,&free))????????? //得到SD卡的總容量和剩余容量 ?????? { ????????????? LCD_ShowString(30,150,200,16,16,"SD Card Fatfs Error!"); delay_ms(200); ????????????? LCD_Fill(30,150,240,150+16,WHITE); delay_ms(200);??? //清除顯示 ????????????? LED0=!LED0;//DS0閃爍 ?????? }???????????????????????????????????????????????????????????????????????????????????????? ? ????????????????? ???? ????? POINT_COLOR=BLUE;//設置字體為藍色??? ?????? LCD_ShowString(30,150,200,16,16,"FATFS OK!");? ?????? LCD_ShowString(30,170,200,16,16,"SD Total Size:???? MB");????? ?????? LCD_ShowString(30,190,200,16,16,"SD? Free Size:???? MB"); ? ???? ????? LCD_ShowNum(30+8*14,170,total>>10,5,16);???????? //顯示SD卡總容量?MB ????? LCD_ShowNum(30+8*14,190,free>>10,5,16);????????? //顯示SD卡剩余容量?MB????????? ??? ?????? while(1) ?????? { ????????????? t++; ????????????? delay_ms(200);???????????? ?????????????????? ??? ????????????? LED0=!LED0; ?????? } } 在main函數里面,我們為SD卡和FLASH都注冊了工作區(掛載),在初始化SD卡并顯示其容量信息后,進入死循環,等待USMART測試。 最后,我們在usmart_config.c里面的usmart_nametab數組添加如下內容: ?????? (void*)mf_mount,"u8 mf_mount(u8* path,u8 mt)", ?????? (void*)mf_open,"u8 mf_open(u8*path,u8 mode)", ?????? (void*)mf_close,"u8 mf_close(void)", ?????? (void*)mf_read,"u8 mf_read(u16 len)", ?????? (void*)mf_write,"u8 mf_write(u8*dat,u16 len)", ?????? (void*)mf_opendir,"u8 mf_opendir(u8* path)", ?????? (void*)mf_closedir,"u8 mf_closedir(void)", ?????? (void*)mf_readdir,"u8 mf_readdir(void)", ?????? (void*)mf_scan_files,"u8 mf_scan_files(u8 * path)", ?????? (void*)mf_showfree,"u32 mf_showfree(u8 *drv)", ?????? (void*)mf_lseek,"u8 mf_lseek(u32 offset)", ?????? (void*)mf_tell,"u32 mf_tell(void)", ?????? (void*)mf_size,"u32 mf_size(void)", ?????? (void*)mf_mkdir,"u8 mf_mkdir(u8*pname)", ?????? (void*)mf_fmkfs,"u8 mf_fmkfs(u8* path,u8 mode,u16 au)", ?????? (void*)mf_unlink,"u8 mf_unlink(u8 *pname)", ?????? (void*)mf_rename,"u8 mf_rename(u8 *oldname,u8* newname)", ?????? (void*)mf_getlabel,"void mf_getlabel(u8 *path)", ?????? (void*)mf_setlabel,"void mf_setlabel(u8 *path)", ?????? (void*)mf_gets,"void mf_gets(u16 size)", ?????? (void*)mf_putc,"u8 mf_putc(u8 c)", ?????? (void*)mf_puts,"u8 mf_puts(u8*c)", 這些函數均是在fattester.c里面實現,通過調用這些函數,即可實現對FATFS對應API函數的測試。 至此,軟件設計部分就結束了。 44.4?下載驗證在代碼編譯成功之后,我們通過下載代碼到ALIENTEK探索者STM32F4開發板上,可以看到LCD顯示如圖44.4.1所示的內容(假定SD卡已經插上了): ? 圖44.4.1?程序運行效果圖 打開串口調試助手,我們就可以串口調用前面添加的各種FATFS測試函數了,比如我們輸入mf_scan_files("0:"),即可掃描SD卡根目錄的所有文件,如圖44.4.2所示: ? 圖44.4.2?掃描SD卡根目錄所有文件 ?????? ?其他函數的測試,用類似的辦法即可實現。注意這里0代表SD卡,1代表SPI FLASH。另外,提醒大家,mf_unlink函數,在刪除文件夾的時候,必須保證文件夾是空的,才可以正常刪除,否則不能刪除。 實驗詳細手冊和源碼下載地址:http://www.openedv.com/posts/list/41586.htm? ? 正點原子探索者STM32F407開發板購買地址:http://item.taobao.com/item.htm?id=41855882779 ?? ? |
?
實驗39 FATFS實驗.zip
?
第四十四章 FATFS實驗-STM32F4開發指南-正點原子探索者STM32開發板.pDF
?
http://www.openedv.com/forum.php?mod=viewthread&tid=43377
?
總結
以上是生活随笔為你收集整理的【正点原子探索者STM32F407开发板例程连载+教学】第44章 FATFS文件系统实验的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Microsoft Windows XP
- 下一篇: 湖北 政府项目 软件 测试,湖北电子政务