基於STM32F429,Cubemx的SDHC卡的基本Fatfs文件移植

 

 

本博文要求各位初步瞭解Fatfs文件系統html

友情提示Fatfs官網:http://elm-chan.org/fsw/ff/00index_e.htmlgit

1.開發軟件

  keil5,Cube5.21函數

2.實驗目的

  往SDHC卡上移植Fatfs文件學習

SDHC:測試

  SDHC是"Secure Digital High Capacity「的縮寫,即「高容量SD存儲卡」。2006年5月SD協會發布了SD 2.0的系統規範,並在其中規定SDHC是符合該規範、SDHC存儲卡容量爲「4GB-32GB」。spa

  SDHC最大的特色就是高容量(4GB-32GB)。另外,SD協會規定SDHC必須採用FAT32 文件系統,這是由於以前在SD卡中使用的FAT16文件系統所支持的最大容量爲2GB,並不能知足SDHC的要求。
  做爲SD卡的繼任者,SDHC主要特徵在於文件格式從之前的FAT十二、FAT16提高到了FAT32,並且最高支持32GB。同時傳輸速度被從新定義爲Class二、Class四、Class6等級別,高速的SD卡能夠支持高分辨視頻錄製的實時存儲。
  SDHC卡的外形尺寸與SD卡同樣,著做權保護機能等也和之前相同,可是因爲文件系統被變動,之前只支持FAT12/16格式的SD設備存在不兼容現象,而支持FAT32(SDHC)的機器,仍能夠讀取現存的FAT12/16格式的SD卡。
FATFS:
  FatFs是一個通用的文件系統(FAT/exFAT)模塊,用於在小型嵌入式系統中實現FAT文件系統。 FatFs 組件的編寫遵循ANSI C(C89),徹底分離於磁盤 I/O 層,所以不依賴於硬件平臺。它能夠嵌入到便宜的微控制器中,如 8051, PIC, AVR, ARM, Z80, RX等等,不須要作任何修改。
由於FatFs模塊徹底與磁盤I/O層分開,所以須要下面的函數來實現底層物理磁盤的讀寫與獲取當前時間。底層磁盤I/O模塊並非FatFs的一部分,而且必須由用戶提供。

3.Cube配置

(1)在Cube上點開芯片功能的SDIO,由於我用的是4GB的SDHC卡,因此用SD 4 bits,用默認配置便可與SD卡通訊

 

 

 紅框內爲SDIO協議引用的引腳

PC8 ------> SDIO_D0
PC9 ------> SDIO_D1
PC10 ------> SDIO_D2
PC11 ------> SDIO_D3
PC12 ------> SDIO_CK
PD2 ------> SDIO_CMD 調試

 

 

 

(2)再點開下面的FATFS,即向工程裏添加fatfs移植文件,而後再勾選SD Card,底層的disiko接口默認添加SD卡讀寫程序

(3)配置時鐘完成後,就可生成工程

 

4.工程講解

(1)下面的文件是Cube幫你移植的Fatfs文件,但不用修改裏面的程序code

(2)下面的兩個C文件,一個是SD的diskio接口層,Cube已往裏面調用了HAL庫的SD卡讀寫函數,能夠不修改,另外一個是上層的fatfs文件功能函數,可根據須要添加函數,也能夠不用修改。orm

 (3)雖然Cube使用了MX_SDIO_SD_Init();進行了SD卡的初始化,但還要用下面的初始化進行初始化才能使用SD卡,它們在stm32f4xx_hal_sd.c裏視頻

  HAL_SD_Init(&hsd);
  HAL_SD_InitCard(&hsd);

 

 5.程序測試

 (1)使用FATFS_GetAttachedDriversNbr()判斷SD卡是否掛載上驅動

i=FATFS_GetAttachedDriversNbr();
printf("已掛載的驅動:%d",i);

 

 

(2)調用ff.c的文件功能函數,若是返回FR_OK(0)則成功

/* USER CODE BEGIN Application */
 void SD_Fatfs_Test(void)
 {
    printf("文件掛載\n" );
    retSD=f_mount(&SDFatFS, "0:/",0);  
    if(retSD==FR_OK)
    {
         printf("MOUNT OK\n");
         printf("FAILED0: %d\n",retSD);
    }
    else
        printf("FAILED2: %d\n",retSD);
    printf("文件打開\n" );
    retSD=f_open(&SDFile, "0:hellow.txt", FA_CREATE_ALWAYS | FA_WRITE | FA_READ );  
    if(retSD==FR_OK)
    {
         printf("OPEN OK\n");
    }
    else
        printf("FAILED3: %d\n",retSD);
    
    
    
     printf("文件關閉\n" );
     retSD=f_close(&SDFile);
        
    if(retSD==FR_OK)
    {
         printf("closk OK\n");
    }
    else
        printf("FAILED5: %d\n",retSD);
     
    
 }    

 

(3)HAL_SD_ReadBlocks()和HAL_SD_WriteBlocks()能夠往SD卡讀寫數據

(4)用如下的HAKL庫函數可讀取SD卡的信息,有興趣能夠去弄

HAL_SD_CardStateTypeDef HAL_SD_GetCardState(SD_HandleTypeDef *hsd);
HAL_StatusTypeDef HAL_SD_GetCardCID(SD_HandleTypeDef *hsd, HAL_SD_CardCIDTypeDef *pCID);
HAL_StatusTypeDef HAL_SD_GetCardCSD(SD_HandleTypeDef *hsd, HAL_SD_CardCSDTypeDef *pCSD);
HAL_StatusTypeDef HAL_SD_GetCardStatus(SD_HandleTypeDef *hsd, HAL_SD_CardStatusTypeDef *pStatus);
HAL_StatusTypeDef HAL_SD_GetCardInfo(SD_HandleTypeDef *hsd, HAL_SD_CardInfoTypeDef *pCardInfo);

 

6.Fatfs使用小經驗

(1)使用FATFS,FIL等類型的變量時,可能要先申請內存空間,才能使用。具體是怎樣請先學習STM32的內存管理。

(2)使用f_mount,f_close等文件功能函數出錯時,請看其返回函數爲什麼值,更容易調試。

 
typedef enum {
    FR_OK = 0,                /* (0) Succeeded */
    FR_DISK_ERR,            /* (1) A hard error occurred in the low level disk I/O layer */
    FR_INT_ERR,                /* (2) Assertion failed */
    FR_NOT_READY,            /* (3) The physical drive cannot work */
    FR_NO_FILE,                /* (4) Could not find the file */
    FR_NO_PATH,                /* (5) Could not find the path */
    FR_INVALID_NAME,        /* (6) The path name format is invalid */
    FR_DENIED,                /* (7) Access denied due to prohibited access or directory full */
    FR_EXIST,                /* (8) Access denied due to prohibited access */
    FR_INVALID_OBJECT,        /* (9) The file/directory object is invalid */
    FR_WRITE_PROTECTED,        /* (10) The physical drive is write protected */
    FR_INVALID_DRIVE,        /* (11) The logical drive number is invalid */
    FR_NOT_ENABLED,            /* (12) The volume has no work area */
    FR_NO_FILESYSTEM,        /* (13) There is no valid FAT volume */
    FR_MKFS_ABORTED,        /* (14) The f_mkfs() aborted due to any problem */
    FR_TIMEOUT,                /* (15) Could not get a grant to access the volume within defined period */
    FR_LOCKED,                /* (16) The operation is rejected according to the file sharing policy */
    FR_NOT_ENOUGH_CORE,        /* (17) LFN working buffer could not be allocated */
    FR_TOO_MANY_OPEN_FILES,    /* (18) Number of open files > _FS_LOCK */
    FR_INVALID_PARAMETER    /* (19) Given parameter is invalid */
} FRESULT;

 

(3)要先加載文件卷,才能用文件功能函數。

(4)程序出錯通常是底層接口函數沒寫好。

 

  粗糙之做,有不合之處請多多指教。

相關文章
相關標籤/搜索