2016-07-11 09:54:03 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2016 OTA keys S.A.
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2017-04-13 11:58:22 +02:00
|
|
|
* @defgroup sys_spiffs SPIFFS integration
|
2017-07-06 09:43:08 +02:00
|
|
|
* @ingroup pkg_spiffs
|
|
|
|
* @brief RIOT integration of SPIFFS
|
|
|
|
*
|
|
|
|
* The RIOT integration of SPIFFS follows the SPIFFS wiki:
|
|
|
|
* https://github.com/pellepl/spiffs/wiki/Integrate-spiffs#integrating-spiffs
|
|
|
|
*
|
2017-07-10 15:58:50 +02:00
|
|
|
* The RIOT integration uses by default the @p SPIFFS_HAL_CALLBACK_EXTRA option
|
|
|
|
* and needs a @p mtd device, passed as spiffs_desc_t::dev.
|
|
|
|
*
|
|
|
|
* If one disable @p SPIFFS_HAL_CALLBACK_EXTRA, the mtd device is passed through
|
|
|
|
* the @p SPIFFS_MTD_DEV macro as a @p mtd_dev_t pointer.
|
|
|
|
*
|
|
|
|
* Note that only one filesystem can be used if @p SPIFFS_HAL_CALLBACK_EXTRA is
|
|
|
|
* disabled.
|
|
|
|
*
|
|
|
|
* @p SPIFFS_SINGLETON is disabled by default, the memory layout is retrieved from
|
|
|
|
* the @p mtd device used. If @p SPIFFS_SINGLETON is enabled, the proper SPIFFS
|
|
|
|
* variables must be set (see spiffs_config.h from SPIFFS).
|
|
|
|
*
|
|
|
|
* The default integration enable @p SPIFFS_CACHE and uses the macro
|
|
|
|
* @p SPIFFS_FS_CACHE_SIZE as cache size.
|
|
|
|
*
|
|
|
|
* @p SPIFFS_LOCK and @p SPIFFS_UNLOCK are also defined in the RIOT custom
|
|
|
|
* spiffs_config.h to use @p spiffs_lock() and @p spiffs_unlock()
|
|
|
|
*
|
2016-07-11 09:54:03 +02:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief SPIFFS integration with vfs
|
|
|
|
*
|
|
|
|
* @author Vincent Dupont <vincent@otakeys.com>
|
|
|
|
*/
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#ifndef FS_SPIFFS_FS_H
|
|
|
|
#define FS_SPIFFS_FS_H
|
2016-07-11 09:54:03 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "spiffs.h"
|
|
|
|
#include "spiffs_config.h"
|
|
|
|
#include "vfs.h"
|
|
|
|
#include "mtd.h"
|
|
|
|
#include "mutex.h"
|
|
|
|
|
|
|
|
/** Size of the buffer needed for directory */
|
|
|
|
#define SPIFFS_DIR_SIZE (12)
|
|
|
|
|
|
|
|
#if (VFS_DIR_BUFFER_SIZE < SPIFFS_DIR_SIZE)
|
|
|
|
#error "VFS_DIR_BUFFER_SIZE too small"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name SPIFFS config constants
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#ifndef SPIFFS_FS_CACHE_SIZE
|
2017-07-06 09:43:08 +02:00
|
|
|
#if SPIFFS_CACHE || defined(DOXYGEN)
|
|
|
|
/**
|
|
|
|
* @brief the size of the cache buffer
|
|
|
|
*
|
|
|
|
* Ignored if cache is disabled in build config. One cache page will be slightly
|
|
|
|
* larger than the logical page size. The more ram, the more cache pages,
|
|
|
|
* the quicker the system.
|
|
|
|
*/
|
2016-07-11 09:54:03 +02:00
|
|
|
#define SPIFFS_FS_CACHE_SIZE (512)
|
|
|
|
#else
|
|
|
|
#define SPIFFS_FS_CACHE_SIZE (0)
|
|
|
|
#endif /* SPIFFS_CACHE */
|
|
|
|
#endif /* SPIFFS_FS_CACHE_SIZE */
|
|
|
|
#ifndef SPIFFS_FS_WORK_SIZE
|
2017-07-06 09:43:08 +02:00
|
|
|
/**
|
|
|
|
* @brief The size of the work buffer
|
|
|
|
*
|
|
|
|
* A ram memory buffer being double the size of the logical page size
|
|
|
|
* This buffer is used extensively by the spiffs stack.
|
|
|
|
* If logical page size is 256, this buffer must be 512 bytes.
|
|
|
|
*/
|
2016-07-11 09:54:03 +02:00
|
|
|
#define SPIFFS_FS_WORK_SIZE (512)
|
|
|
|
#endif
|
|
|
|
#ifndef SPIFFS_FS_FD_SPACE_SIZE
|
2017-07-06 09:43:08 +02:00
|
|
|
/**
|
|
|
|
* @brief the size of the file descriptor buffer
|
|
|
|
*
|
|
|
|
* A file descriptor normally is around 32 bytes depending on the build config -
|
|
|
|
* the bigger the buffer, the more file descriptors are available.
|
|
|
|
*/
|
|
|
|
#define SPIFFS_FS_FD_SPACE_SIZE (4 * 32)
|
2016-07-11 09:54:03 +02:00
|
|
|
#endif
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This contains everything needed to run an instance of SPIFFS
|
|
|
|
*/
|
|
|
|
typedef struct spiffs_desc {
|
|
|
|
spiffs fs; /**< The SPIFFS struct */
|
|
|
|
uint8_t work[SPIFFS_FS_WORK_SIZE]; /**< SPIFFS work buffer */
|
|
|
|
uint8_t fd_space[SPIFFS_FS_FD_SPACE_SIZE]; /**< SPIFFS file descriptor cache */
|
|
|
|
#if (SPIFFS_CACHE == 1) || defined(DOXYGEN)
|
|
|
|
uint8_t cache[SPIFFS_FS_CACHE_SIZE]; /**< SPIFFS cache */
|
|
|
|
#endif
|
|
|
|
spiffs_config config; /**< SPIFFS config, filled at mount time depending
|
|
|
|
* on the underlying mtdi_dev_t @p dev */
|
|
|
|
mutex_t lock; /**< A lock for SPIFFS internal use */
|
|
|
|
#if (SPIFFS_HAL_CALLBACK_EXTRA == 1) || defined(DOXYGEN)
|
|
|
|
mtd_dev_t *dev; /**< The underlying mtd device, must be set by user */
|
|
|
|
#endif
|
2017-10-24 15:10:06 +02:00
|
|
|
#if (SPIFFS_SINGLETON == 0) || defined(DOXYGEN)
|
|
|
|
uint32_t base_addr; /**< Base address of partition */
|
|
|
|
uint32_t block_count; /**< Number of blocks in current partition,
|
|
|
|
* if 0, the mtd number of sector is used */
|
|
|
|
#endif
|
2016-07-11 09:54:03 +02:00
|
|
|
} spiffs_desc_t;
|
|
|
|
|
|
|
|
/** The SPIFFS vfs driver, a pointer to a spiffs_desc_t must be provided as vfs_mountp::private_data */
|
|
|
|
extern const vfs_file_system_t spiffs_file_system;
|
|
|
|
|
2017-07-10 15:58:50 +02:00
|
|
|
/**
|
|
|
|
* @brief SPIFFS lock function
|
|
|
|
*
|
|
|
|
* This function must be used by @p SPIFFS_LOCK to lock the file system using
|
|
|
|
* the spiffs_desc_t::lock.
|
|
|
|
*
|
|
|
|
* @param fs spiffs descriptor
|
|
|
|
*/
|
|
|
|
void spiffs_lock(struct spiffs_t *fs);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief SPIFFS unlock function
|
|
|
|
*
|
|
|
|
* This function must be used by @p SPIFFS_UNLOCK to lock the file system using
|
|
|
|
* the spiffs_desc_t::lock.
|
|
|
|
*
|
|
|
|
* @param fs spiffs descriptor
|
|
|
|
*/
|
|
|
|
void spiffs_unlock(struct spiffs_t *fs);
|
|
|
|
|
2016-07-11 09:54:03 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#endif /* FS_SPIFFS_FS_H */
|
2016-07-11 09:54:03 +02:00
|
|
|
|
|
|
|
/** @} */
|