1.簡介
FatFs 是用于小型嵌入式系統(tǒng)的通用 FAT/exFAT 文件系統(tǒng)模塊。FatFs 模塊是按照 ANSI C (C89) 編寫的,與磁盤 I/O 層完全分離。因此它獨(dú)立于平臺。它可以集成到資源有限的小型微控制器中,例如 8051、PIC、AVR、ARM、Z80、RX 等。
特性
DOS/Windows 兼容 FAT/exFAT 文件系統(tǒng)。
平臺獨(dú)立。易于移植。
程序代碼和工作區(qū)的占用空間非常小。
支持的各種配置選項(xiàng):
支持多卷(物理驅(qū)動(dòng)器或分區(qū));
多個(gè) ANSI/OEM 代碼頁包括 DBCS;
支持長文件名, ANSI/OEM 或 Unicode;
支持 RTOS;
支持多種扇區(qū)大小;
只讀、最小化的 API 和 I/O 緩沖區(qū)等。
FATFS應(yīng)用范圍
支持 FAT12、 FAT16 和 FAT32;
可打開的文件:無限制,依賴于有效的存儲(chǔ)器;
支持最多 10 個(gè)卷;
文件大小:與 FAT 類型有關(guān)(upto 4G-1 bytes);
卷大小:與 FAT 類型有關(guān)(upto 2T bytes on 512 bytes/sector);
簇大小:與 FAT 類型有關(guān)(upto 64K bytes on 512 bytes/sector);
扇區(qū)大小:與 FAT 類型有關(guān)(upto 4K bytes)
2.軟件硬件平臺
3.FAT源碼下載
下載地址:FATFS下載
4.FATFS文件系統(tǒng)移植
移植FATFS文件系統(tǒng)只需要提供硬件讀寫扇區(qū)函數(shù)即可。
??1.FATFS源碼文件
2.打開工程,將FATFS源碼文件添加到工程中,添加頭文件路徑。
5.修改硬件接口文件diskio.c
??1.添加SD卡驅(qū)動(dòng)頭文件和驅(qū)動(dòng)設(shè)備卷標(biāo)號設(shè)置。
2.獲取設(shè)置狀態(tài)
3.初始化設(shè)備
DSTATUS disk_initialize (
BYTE pdrv /* Physical drive nmuber to identify the drive */
)
{
DSTATUS stat;
switch (pdrv) {
case DEV_SD :
stat=SD_Init();//SD卡初始化
return stat;
}
return STA_NOINIT;
}
4.讀扇區(qū)函數(shù)
DRESULT disk_read (
BYTE pdrv, /* Physical drive nmuber to identify the drive */
BYTE *buff, /* Data buffer to store read data */
LBA_t sector, /* Start sector in LBA */
UINT count /* Number of sectors to read */
)
{
int result;
switch (pdrv) {
case DEV_SD :
result=SD_ReadDisk(buff,sector,count);//讀扇區(qū)
if(result==0)return RES_OK;
}
return RES_PARERR;
}
5.寫扇區(qū)函數(shù)
DRESULT disk_write (
BYTE pdrv, /* Physical drive nmuber to identify the drive */
const BYTE *buff, /* Data to be written */
LBA_t sector, /* Start sector in LBA */
UINT count /* Number of sectors to write */
)
{
int result;
switch (pdrv) {
case DEV_SD :
result=SD_WriteDisk((u8 *)buff,sector,count);//寫扇區(qū)
if(result==0)return RES_OK;
}
return RES_PARERR;
}
6.其他函數(shù)
DRESULT disk_ioctl (
BYTE pdrv, /* Physical drive nmuber (0..) */
BYTE cmd, /* Control code */
void *buff /* Buffer to send/receive control data */
)
{
switch (pdrv) {
case DEV_SD :
switch(cmd)
{
case GET_SECTOR_COUNT://獲取扇區(qū)數(shù)量
*(DWORD *)buff=SDCardInfo.CardCapacity/512;
break;
case GET_SECTOR_SIZE://獲取扇區(qū)大小
*(DWORD *)buff=512;
break;
case GET_BLOCK_SIZE://塊大小
*(DWORD *)buff=SDCardInfo.CardBlockSize;
break;
}
return RES_OK;
}
return RES_PARERR;
}
7.時(shí)間函數(shù),為文件訪問提供時(shí)間。
6.裁剪FATFS文件系統(tǒng),修改ffconf.h
1.打開格式化功能
2.編碼格式選擇
3.打開長文件名支持。使用中文編碼需要長文件名支持。
選擇3時(shí)需要提供動(dòng)態(tài)分配空間接口函數(shù),在ffsystem.c中
修改堆空間大小,在startup_stm32f103_hd.s中
4.獲取時(shí)間支持
7.主函數(shù)
??編寫測試函數(shù),讀寫文件。
#include "ff.h" /* Obtains integer types */
FATFS fs;
u8 buff_tx[512]="SD卡扇區(qū)讀寫測試,文件系統(tǒng)讀寫測試sdfghj23456790\r\n";
u8 buff_rx[512];
void Fatfs_WriteData(const TCHAR *file_name,u8 *buff,u32 len);
void Fatfs_ReadData(const TCHAR *file_name,u8 *buff,u32 len);
int main()
{
u8 stat=0;
Beep_Init();
Led_Init();
Key_Init();
Usartx_Init(USART1,115200,72);
TIMx_Init(TIM2,72,20*1000);
RTC_Init();
stat=f_mount(&fs,"0:",1);//SD卡掛載
printf("stat=%d\r\n",stat);
if(stat==0) printf("磁盤掛載成功\r\n");
Fatfs_WriteData("0:/FAT文件系統(tǒng).doc",buff_tx,strlen((char *)buff_tx));
Fatfs_ReadData("0:/FAT文件系統(tǒng).doc",buff_rx,strlen((char *)buff_tx));
printf("rx:%s\r\n",buff_rx);
while(1)
{
}
?寫數(shù)據(jù)函數(shù)
/**************FATFS寫數(shù)據(jù)****************/
void Fatfs_WriteData(const TCHAR *file_name,u8 *buff,u32 len)
{
/*1.打開文件*/
FIL fp;
FRESULT res;
UINT bw;
res=f_open(&fp,file_name,FA_WRITE|FA_CREATE_ALWAYS);//寫+創(chuàng)建
if(res!=FR_OK)
{
printf("文件打開或創(chuàng)建失敗:ERR%d\r\n",res);
return ;
}
printf("文件創(chuàng)建或打開成功\r\n");
res=f_write(&fp,buff,len,&bw);
if(res==FR_OK)
{
printf("數(shù)據(jù)寫入成功 %d Byte\r\n",bw);
}
else printf("寫入失敗ERR:%d\r\n",res);
f_close(&fp);//關(guān)閉文件
}
讀數(shù)據(jù)函數(shù)
/****************FATFS讀數(shù)據(jù)*************/
void Fatfs_ReadData(const TCHAR *file_name,u8 *buff,u32 len)
{
/*1.打開文件*/
FIL fp;
FRESULT res;
UINT br;
res=f_open(&fp,file_name,FA_READ);//讀
if(res!=FR_OK)
{
printf("文件打開失敗:ERR%d\r\n",res);
return ;
}
printf("文件打開成功\r\n");
res=f_read(&fp,buff,len,&br);
if(res!=FR_OK)
{
printf("讀取數(shù)據(jù)失敗ERR:%d \r\n",res);
}
else
{
printf("讀取數(shù)據(jù)成功 %d byte\r\n",br);
}
f_close(&fp);//關(guān)閉文件
}
8.運(yùn)行效果
9.相關(guān)接口函數(shù)
1.f_open函數(shù)
函數(shù)原型:FRESULT f_open (FIL* fp, const TCHAR* path, BYTE mode); 返回值:成功返回FR_OK,失敗其它值。 |
2.f_read函數(shù)
函數(shù)原型:FRESULT f_read (FIL* fp, void* buff, UINT btr, UINT* br); 函數(shù)功能:讀文件 形參:fp 文件指針 ?buff 讀取數(shù)據(jù)緩沖區(qū) ?btr 讀取的字節(jié)數(shù) ?br 指向返回的已經(jīng)讀取的字節(jié)數(shù) UINT 變量的指針,不管此函數(shù)掉調(diào)用后返回的結(jié)果如何,這個(gè)值始終有效。如果返回值等于btr,則函數(shù)返回值為FR_OK。 返回值:成功返回FR_OK,失敗返回其它值 |
3.f_write函數(shù)
函數(shù)原型:FRESULT f_write (FIL* fp, const void* buff, UINT btw, UINT* bw); 函數(shù)功能:寫文件 形參:fp 文件指針 ?buff 要寫的數(shù)據(jù)內(nèi)容 ?btw?寫入是字節(jié)數(shù) ?br 指向接收寫入字節(jié)數(shù)的UINT變量的指針。無論函數(shù)返回代碼如何,該值在函數(shù)調(diào)用后始終有效。如果返回值等于btw,則函數(shù)返回值為FR_OK。 返回值:成功返回FR_OK,失敗返回其它值 |
4.f_close函數(shù)
函數(shù)原型:FRESULT f_close (FIL* fp); 函數(shù)功能:關(guān)閉文件 形參:fp ?文件指針 返回值:成功返回FR_OK,失敗返回其它值 |
-
STM32
+關(guān)注
關(guān)注
2258文章
10828瀏覽量
352499 -
SD卡
+關(guān)注
關(guān)注
2文章
553瀏覽量
63520 -
FATFS
+關(guān)注
關(guān)注
0文章
43瀏覽量
18211 -
FatFS文件系統(tǒng)
+關(guān)注
關(guān)注
0文章
12瀏覽量
7498
發(fā)布評論請先 登錄
相關(guān)推薦
評論