2017-05-12 17:46:09 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2017 HAW-Hamburg
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @defgroup sys_fatfs FatFs integration
|
|
|
|
* @ingroup sys_fs
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief FatFs integration for vfs
|
|
|
|
*
|
|
|
|
* @author Michel Rottleuthner <michel.rottleuthner@haw-hamburg.de>
|
|
|
|
*/
|
|
|
|
|
2017-07-05 14:54:42 +02:00
|
|
|
#ifndef FS_FATFS_H
|
|
|
|
#define FS_FATFS_H
|
2017-05-12 17:46:09 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2020-11-10 17:59:03 +01:00
|
|
|
#include "fatfs/source/ff.h"
|
2017-05-12 17:46:09 +02:00
|
|
|
#include "vfs.h"
|
|
|
|
|
|
|
|
#ifndef FATFS_YEAR_OFFSET
|
2017-07-05 14:54:42 +02:00
|
|
|
/** The year in FatFs timestamps is relative to this offset */
|
2017-05-12 17:46:09 +02:00
|
|
|
#define FATFS_YEAR_OFFSET (1980)
|
|
|
|
#endif
|
|
|
|
|
2017-07-05 14:54:42 +02:00
|
|
|
/** The epoch offset is used to convert between FatFs and time_t timestamps */
|
2017-05-12 17:46:09 +02:00
|
|
|
#define EPOCH_YEAR_OFFSET (1970)
|
|
|
|
|
2017-07-05 14:54:42 +02:00
|
|
|
/** size needed for volume strings like "n:/" where n is the volume id */
|
2018-02-21 09:49:43 +01:00
|
|
|
#define FATFS_MAX_VOL_STR_LEN (6)
|
2017-07-05 14:54:42 +02:00
|
|
|
|
|
|
|
/** 0:mount on first file access, 1 mount in f_mount() call */
|
|
|
|
#define FATFS_MOUNT_OPT (1)
|
|
|
|
|
2020-07-02 19:11:05 +02:00
|
|
|
/** FAT filesystem type that a file system should be formatted in by vfs_format() */
|
|
|
|
#ifndef CONFIG_FATFS_FORMAT_TYPE
|
|
|
|
#if FF_FS_EXFAT
|
|
|
|
#define CONFIG_FATFS_FORMAT_TYPE FM_EXFAT
|
|
|
|
#else
|
|
|
|
#define CONFIG_FATFS_FORMAT_TYPE FM_ANY
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Statically allocate work buffer for format operation
|
|
|
|
*
|
|
|
|
* This will statically allocate 512 bytes as the work buffer for
|
|
|
|
* the format operation.
|
|
|
|
*
|
|
|
|
* If this is set to 0, dynamic allocation (malloc) will be used
|
|
|
|
* instead and format will fail if not enough memory is available.
|
|
|
|
*/
|
|
|
|
#ifndef CONFIG_FATFS_FORMAT_ALLOC_STATIC
|
|
|
|
#define CONFIG_FATFS_FORMAT_ALLOC_STATIC 0
|
|
|
|
#endif
|
|
|
|
|
2018-02-22 08:04:09 +01:00
|
|
|
/**
|
|
|
|
* @brief Size of path buffer for absolute paths
|
|
|
|
*
|
|
|
|
* Most FatFs file operations need an absolute path. This defines the size of
|
|
|
|
* the needed buffer to circumvent stack allocation within vfs-wrappers
|
|
|
|
*/
|
2017-07-05 14:54:42 +02:00
|
|
|
#define FATFS_MAX_ABS_PATH_SIZE (FATFS_MAX_VOL_STR_LEN + VFS_NAME_MAX + 1)
|
2017-05-12 17:46:09 +02:00
|
|
|
|
|
|
|
/**
|
2018-02-22 08:04:09 +01:00
|
|
|
* @brief FatFs instance descriptor
|
2017-05-12 17:46:09 +02:00
|
|
|
*/
|
|
|
|
typedef struct fatfs_desc {
|
|
|
|
FATFS fat_fs; /**< FatFs work area needed for each volume */
|
2021-12-04 16:28:54 +01:00
|
|
|
mtd_dev_t *dev; /**< MTD device to use */
|
2017-05-12 17:46:09 +02:00
|
|
|
uint8_t vol_idx; /**< low level device that is used by FatFs */
|
2017-07-05 14:54:42 +02:00
|
|
|
|
|
|
|
/** most FatFs file operations need an absolute path. This buffer provides
|
|
|
|
static memory to circumvent stack allocation within vfs-wrappers */
|
|
|
|
char abs_path_str_buff[FATFS_MAX_ABS_PATH_SIZE];
|
2017-05-12 17:46:09 +02:00
|
|
|
} fatfs_desc_t;
|
|
|
|
|
|
|
|
/**
|
2018-02-22 08:04:09 +01:00
|
|
|
* @brief FatFs file instance descriptor
|
2017-05-12 17:46:09 +02:00
|
|
|
*/
|
|
|
|
typedef struct fatfs_file_desc {
|
2017-07-05 14:54:42 +02:00
|
|
|
FIL file; /**< FatFs work area for a single file */
|
|
|
|
char fname[VFS_NAME_MAX + 1]; /**< name of the file (e.g. f_stat uses
|
|
|
|
filename instead of FIL) */
|
2017-05-12 17:46:09 +02:00
|
|
|
} fatfs_file_desc_t;
|
|
|
|
|
2017-07-05 14:54:42 +02:00
|
|
|
/** The FatFs vfs driver, a pointer to a fatfs_desc_t must be
|
|
|
|
provided as vfs_mountp::private_data */
|
2017-05-12 17:46:09 +02:00
|
|
|
extern const vfs_file_system_t fatfs_file_system;
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-07-05 14:54:42 +02:00
|
|
|
#endif /* FS_FATFS_H */
|
2017-05-12 17:46:09 +02:00
|
|
|
|
|
|
|
/** @} */
|