方法一:官网库移植
1) 官网下载Fatfs库
FATFS官网

2) 将源文件添加到工程
该工程需要实现某存储器的读写等底层驱动,比如SD卡或者FLASH亦或者磁盘等存储介质

  ff.c           //FatFs module.ffconf.h       //Configuration file of FatFs module.ff.h           //Common include file for FatFs and application module.diskio.h       //Common include file for FatFs and disk I/O module.diskio.c       //An example of glue function to attach existing disk I/O module to FatFs.ffunicode.c    //Optional Unicode utility functions.ffsystem.c     //An example of optional O/S related functions.

3) 修改FATFS相关函数接口
主要包括diskio.c中的:
① disk_status()//获取设备状态

DSTATUS disk_status (BYTE pdrv       /* Physical drive nmuber to identify the drive */
)
{DSTATUS stat;switch (pdrv) {case DEV_SD :if(SD_GetCID(ciddata))    //调用SD卡的获取设备状态函数接口  stat = RES_ERROR;elsestat = RES_OK;return stat;}return STA_NOINIT;/* Drive not initialized */
}

② disk_initialize()//初始化

/*@pdrv Physical drive nmuber to identify the drive */
DSTATUS disk_initialize (BYTE pdrv)
{DSTATUS stat;switch (pdrv) {case DEV_SD :SD_Init();//初始化SD卡if(SD_GetCID(ciddata))  //重新获取一下SD卡的ID,看是否初始化成功  stat = RES_ERROR;elsestat = RES_OK;return stat;}return STA_NOINIT;/* Drive not initialized */
}

③ disk_read()//设备读

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 */
)
{DRESULT res;switch (pdrv) {case DEV_SD :res = SD_ReadDisk(buff, sector, count);if(res != 0) //读失败{SD_Init();//重新初始化SD卡res = SD_ReadDisk(buff, sector, count);//重新读}return res;}return RES_PARERR;
}

④ disk_write()//设备写

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 */
)
{DRESULT res;switch (pdrv) {case DEV_SD :res = SD_WriteDisk((BYTE *)buff, sector, count);if( res != 0) //写失败{SD_Iint();//重新初始化SD卡res = SD_WriteDisk((BYTE *)buff, sector, count);//重新写   }return res;}return RES_PARERR;
}

⑤ disk_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 == DEV_SD){switch (cmd) {case CTRL_SYNC:res = RES_OK; break;     case GET_SECTOR_SIZE:*(DWORD*)buff = 512; //每个扇区的大小为512字节res = RES_OK;break;  case GET_BLOCK_SIZE:*(WORD*)buff = 8;res = RES_OK;break;  case GET_SECTOR_COUNT:*(DWORD*)buff = SD_GetSectorCount();//调用获取SD卡扇区个数的函数接口res = RES_OK;break;default:res = RES_PARERR;break;}}if(res)return RES_PARERR;return res;
}

4) 修改ffconf.h中的宏定义来使能相应的函数接口

#define FF_FS_READONLY   0 /*This option switches read-only configuration. (0:Read/Write or 1:Read-only)*/
#define FF_USE_MKFS     1/* This option switches f_mkfs() function. (0:Disable or 1:Enable) */
//f_mkfs()  The f_mkfs function creates an FAT/exFAT volume on the logical drive.格式化,一般挂载失败可以尝试调用格式化一下磁盘在再重新挂载
#define FF_CODE_PAGE    936 /*支持文件名为中文格式*/
#define FF_USE_LFN      0
#define FF_MAX_LFN      255
/* The FF_USE_LFN switches the support for LFN (long file name).
/   0: Disable LFN. FF_MAX_LFN has no effect.
/   1: Enable LFN with static  working buffer on the BSS. Always NOT thread-safe.注意开启的话,会增大代码占用空间
/   2: Enable LFN with dynamic working buffer on the STACK. 一般使用OS时设置
*/
#define FF_VOLUMES      1 /* Number of volumes (logical drives) to be used. (1-10) */
#define FF_MIN_SS       512
#define FF_MAX_SS       512
/*
/ 配置所支持的扇区大小范围。 (512, 1024, 2048或4096),一般大容量存储介质都配置为512,像磁盘,MMC等,对于flash一般需要将最大值设置为4096
*/
#define FF_FS_NORTC     0 /*0 使能时间戳,1 关闭时间戳,需要我们自己实现get_fattime(),可以开启RTC获得具体的时间*/

具体的宏定义查看官网具体配置介绍说明
以上就完成了移植与修改
接下来就可以调用相应的API函数来实现文件的创建,读写等操作。

//设备挂载
FRESULT f_mount (FATFS*       fs,    /* [IN] Filesystem object */const TCHAR* path,  /* [IN] Logical drive number */BYTE         opt    /* [IN] Initialization option */
);
//设备卸载
FRESULT f_unmount (const TCHAR* path   /* [IN] Logical drive number */
);
//格式化设备
FRESULT f_mkfs (const TCHAR* path,   /* [IN] Logical drive number */const MKFS_PARM* opt,/* [IN] Format options */void* work,          /* [-]  Working buffer */UINT len             /* [IN] Size of working buffer */
);
// 打开或者创建一个文件
FRESULT f_open (FIL* fp,            /* Pointer to the blank file object */const TCHAR* path,    /* Pointer to the file name */BYTE mode         /* Access mode and file open mode flags */
)
//mode
#define FA_READ             0x01 // 指定对对象的读取权限。可以从文件中读取数据。
#define FA_WRITE            0x02 // 指定对对象的写访问权。数据可以写入文件。
#define FA_OPEN_EXISTING    0x00 // 打开文件。如果文件不存在,该函数将失败
#define FA_CREATE_NEW       0x04 // 创建一个新文件。如果文件存在,该函数将失败并显示 FR_EXIST 。
#define FA_CREATE_ALWAYS    0x08 // 创建一个新文件。如果文件存在,它将被截断并覆盖。
#define FA_OPEN_ALWAYS      0x10 // 如果文件存在,则打开该文件。如果不是,则创建一个新文件。
#define FA_OPEN_APPEND      0x30 // 存在则打开、不存在则创建,指针指向文件尾
//举例
f_open(fp,"att_log.txt",FA_WRITE|FA_OPEN_APPEND);
//格化式写入
/*-----------------------------------------------------------------------*/
/* Put a Formatted String to the File                                    */
/*-----------------------------------------------------------------------*/
int f_printf (FIL* fp,          /* Pointer to the file object */const TCHAR* fmt,   /* Pointer to the format string */...                   /* Optional arguments... */
)
//例如
f_printf(fp,"%d,%d\n",buff[0],buff[1]);
//关闭文件
FRESULT f_close (FIL *fp        /* Pointer to the file object to be closed */
)
//打开/创建文件、写完之后要关闭,否则最终的数据不会写到SD卡中
f_close(fp);
//写数据到文件里
FRESULT f_write (FIL* fp,           /* Pointer to the file object */const void* buff,   /* Pointer to the data to be written 要写进文件的数据buff*/UINT btw,            /* Number of bytes to write 要写的数据个数*/UINT* bw           /* Pointer to number of bytes written 写进文件的实际数据个数*/
)
//从文件里读
FRESULT f_read (FIL* fp,    /* Pointer to the file object */void* buff, /* Pointer to data buffer 要存放数据的buff*/UINT btr, /* Number of bytes to read 指定要读的数据长度*/UINT* br  /* Pointer to number of bytes read 实际读出的数据长度*/
)
/刷新(同步)文件
FRESULT f_sync (FIL* fp     /* Pointer to the file object */
)
//也就是不关闭文件可以继续写,但是可以保证前面写的数据保存到SD卡中,
//可以降低因断电等带来的数据丢失分析,f_close调用的也是f_sync.
//但是f_close关闭文件后要想继续写需要重新打开.

具体的解释与示例参考官网http://elm-chan.org/fsw/ff/00index_e.html
基本上每个函数都有官方用法的示例参考。

SD卡之FATFS库移植相关推荐

  1. STM32+雷龙SD NAND(贴片SD卡)完成FATFS文件系统移植与测试

    一.前言 在STM32项目开发中,经常会用到存储芯片存储数据. 比如:关机时保存机器运行过程中的状态数据,上电再从存储芯片里读取数据恢复:在存储芯片里也会存放很多资源文件.比如,开机音乐,界面上的菜单 ...

  2. 基于STM32采用CS创世 SD NAND(贴片SD卡)完成FATFS文件系统移植与测试

    一.前言 在STM32项目开发中,经常会用到存储芯片存储数据. 比如:关机时保存机器运行过程中的状态数据,上电再从存储芯片里读取数据恢复:在存储芯片里也会存放很多资源文件.比如,开机音乐,界面上的菜单 ...

  3. 基于STM32采用CS创世 SD NAND(贴片SD卡)完成FATFS文件系统移植与测试(中篇)

    3.2 SPI硬件时序方式 上面的3.1小节是采用SPI模拟时序驱动SD NAND,STM32本身集成有SPI硬件模块,可以直接利用STM32硬件SPI接口读写. 下面贴出底层的适配代码. 上面贴出的 ...

  4. STM32 通过USB接口读写挂载的SD卡(支持fatfs文件系统)

    通过USB接口读写挂载的SD卡 HAL库 标准库 本文以STM32F407为例分别用HAL库(STM32CubeMX)和标准库实现SD卡对fatfs支持,以及通过USB接口读写SD卡.首先看电路连接: ...

  5. STM32CubeMX配置SD卡+DMA+Fatfs文件系统

    STM32CubeMX配置SD卡+DMA+Fatfs文件系统 一.设备及软件 1.keil 2.STM32CubeMX 3.正点原子STM32F407探索者开发板 二.配置步骤 1.配置RCC外部晶振 ...

  6. cubemx 读卡器_STM32CubeMX基于SD卡的FATFS文件系统测试

    1.问题描述:使用STM32CubeMX配置SD基于SD卡的FATFS文件系统,并进行测试文件的读写. 2.测试准备: (1)测试环境: 软件平台:STM32CubeMX -4.22.0;KEIL5 ...

  7. STM32挂载SD卡基于Fatfs文件系统读取文件信息

    STM32挂载SD卡基于Fatfs文件系统读取文件信息

  8. 基于SD卡的FatFs文件系统(FatFs移植到STM32)

    平台:STM32ZET6(核心板)+ST-LINK/V2+SD卡+USB串口线 工程介绍:主要文件在USER组中,bsp_sdio_sdcard.c,bsp_sdio_sdcard.h和main.c, ...

  9. 模拟SPI进行TF卡操作+Fatfs文件系统移植

    FATFS版本:FATFS R0.13b SD卡容量:16G 概述 本文的重点是进行Fatfs文件系统的移植和初步的使用.TF卡的操作实际上是指令操作,即你想它发送固定的CMD指令,它接收到指令给你返 ...

最新文章

  1. JavaScript递归
  2. Kotlin极简教程:第7章 面向对象编程
  3. distance在函数 int_Arduino智能小车——超声波避障
  4. jQuery从入门到忘记
  5. SpringCloud Greenwich(六)集成dubbo与openfeign的feignTargeter报错,cannot access its superinterface Targeter
  6. Leecode 136. 只出现一次的数字
  7. ARM Linux 3.x的设备树
  8. python常用模块:pickle、shelve、json、xml、configparser
  9. 解决oracle客户端乱码问题,如何解决oracle客户端中文乱码问题?-Oracle
  10. jQuery的页面加载事件
  11. osi模型_OSI模型
  12. 【论文】PathQG: 基于事实的神经问题生成
  13. Vulnhub-HackInOS
  14. 学习日记16、easyui editor datagrid 动态绑定url
  15. 数控弯管机xyz转换ybc的算法_数控弯管机技术的更新和应用.pdf
  16. HPC高性能计算知识: HPDA新兴技术分析(附下载)
  17. 频繁发送socket命令返回:[WinError 10054] 远程主机强迫关闭了一个现有的连接
  18. 缠论-2011.4.11晚
  19. 杨浦区双创小巨人、科技小巨人申请条件及奖励政策
  20. OpenLDAP配置坎坷路

热门文章

  1. PANDAS: 新手教程 一
  2. HTTP 协议,通俗易懂
  3. OPenCV笔记-Mat转Base64(使用Qt进行转换)
  4. 时序数据库InfluxDB介绍
  5. 前端开发笔记3-开发小项目,kline遇到的知识点及问题
  6. coco数据集 解析下载
  7. 如何有趣的解释什么是微服务架构
  8. 聚焦!百度创作者首批数字藏品限量发售,开启奇妙新世界!
  9. Java使用HttpUrlConnection实现多线程断点下载
  10. 更改免提使其无操作加audio_policy_conf配置