2020-02-13 13:33:45 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2017 OTA keys S.A.
|
|
|
|
* Copyright (C) 2020 Inria
|
|
|
|
*
|
|
|
|
* 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_littlefs2 littlefs v2 integration
|
|
|
|
* @ingroup pkg_littlefs2
|
|
|
|
* @brief RIOT integration of littlefs version 2.x.y
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief littlefs v2 integration with vfs
|
|
|
|
*
|
|
|
|
* @author Vincent Dupont <vincent@otakeys.com>
|
|
|
|
* @author Koen Zandberg <koen@bergzand.net>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef FS_LITTLEFS2_FS_H
|
|
|
|
#define FS_LITTLEFS2_FS_H
|
|
|
|
|
2022-08-18 18:36:05 +02:00
|
|
|
#include <stdalign.h>
|
2020-02-13 13:33:45 +01:00
|
|
|
|
|
|
|
#include "vfs.h"
|
|
|
|
#include "lfs.h"
|
|
|
|
#include "mtd.h"
|
|
|
|
#include "mutex.h"
|
|
|
|
|
2022-08-18 18:36:05 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2020-02-13 13:33:45 +01:00
|
|
|
/**
|
|
|
|
* @name littlefs configuration
|
|
|
|
* @ingroup config
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#ifndef CONFIG_LITTLEFS2_LOOKAHEAD_SIZE
|
|
|
|
/** Default lookahead size */
|
|
|
|
#define CONFIG_LITTLEFS2_LOOKAHEAD_SIZE (16)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CONFIG_LITTLEFS2_FILE_BUFFER_SIZE
|
|
|
|
/** File buffer size, if 0, dynamic allocation is used.
|
|
|
|
* If set, only one file can be used at a time, must be program size (mtd page
|
|
|
|
* size is used internally as program size) */
|
|
|
|
#define CONFIG_LITTLEFS2_FILE_BUFFER_SIZE (0)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CONFIG_LITTLEFS2_READ_BUFFER_SIZE
|
|
|
|
/** Read buffer size, if 0, dynamic allocation is used.
|
|
|
|
* If set, it must be read size (mtd page size is used internally as read
|
|
|
|
* size) */
|
|
|
|
#define CONFIG_LITTLEFS2_READ_BUFFER_SIZE (0)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CONFIG_LITTLEFS2_PROG_BUFFER_SIZE
|
|
|
|
/** Prog buffer size, if 0, dynamic allocation is used.
|
|
|
|
* If set, it must be program size */
|
|
|
|
#define CONFIG_LITTLEFS2_PROG_BUFFER_SIZE (0)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CONFIG_LITTLEFS2_CACHE_PAGES
|
|
|
|
/** Sets the number of pages used as cache. Has to be at least 1.
|
|
|
|
*/
|
|
|
|
#define CONFIG_LITTLEFS2_CACHE_PAGES (1)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CONFIG_LITTLEFS2_BLOCK_CYCLES
|
|
|
|
/** Sets the maximum number of erase cycles before blocks are evicted as a part
|
|
|
|
* of wear leveling. -1 disables wear-leveling. */
|
|
|
|
#define CONFIG_LITTLEFS2_BLOCK_CYCLES (512)
|
|
|
|
#endif
|
2022-05-28 11:30:01 +02:00
|
|
|
|
|
|
|
#ifndef CONFIG_LITTLEFS2_MIN_BLOCK_SIZE_EXP
|
|
|
|
/**
|
|
|
|
* The exponent of the minimum acceptable block size in bytes (2^n).
|
|
|
|
* The desired block size is not guaranteed to be applicable but will be respected. */
|
|
|
|
#define CONFIG_LITTLEFS2_MIN_BLOCK_SIZE_EXP (-1)
|
|
|
|
#endif
|
2020-02-13 13:33:45 +01:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief littlefs descriptor for vfs integration
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
lfs_t fs; /**< littlefs descriptor */
|
|
|
|
struct lfs_config config; /**< littlefs config */
|
|
|
|
mtd_dev_t *dev; /**< mtd device to use */
|
|
|
|
mutex_t lock; /**< mutex */
|
|
|
|
/** first block number to use,
|
|
|
|
* total number of block is defined in @p config.
|
|
|
|
* if set to 0, the total number of sectors from the mtd is used */
|
|
|
|
uint32_t base_addr;
|
|
|
|
#if CONFIG_LITTLEFS2_FILE_BUFFER_SIZE || DOXYGEN
|
|
|
|
/** file buffer to use internally if CONFIG_LITTLEFS2_FILE_BUFFER_SIZE
|
|
|
|
* is set */
|
2022-08-18 18:36:05 +02:00
|
|
|
alignas(uint32_t) uint8_t file_buf[CONFIG_LITTLEFS2_FILE_BUFFER_SIZE];
|
2020-02-13 13:33:45 +01:00
|
|
|
#endif
|
|
|
|
#if CONFIG_LITTLEFS2_READ_BUFFER_SIZE || DOXYGEN
|
|
|
|
/** read buffer to use internally if CONFIG_LITTLEFS2_READ_BUFFER_SIZE
|
|
|
|
* is set */
|
2022-08-18 18:36:05 +02:00
|
|
|
alignas(uint32_t) uint8_t read_buf[CONFIG_LITTLEFS2_READ_BUFFER_SIZE];
|
2020-02-13 13:33:45 +01:00
|
|
|
#endif
|
|
|
|
#if CONFIG_LITTLEFS2_PROG_BUFFER_SIZE || DOXYGEN
|
|
|
|
/** prog buffer to use internally if CONFIG_LITTLEFS2_PROG_BUFFER_SIZE
|
|
|
|
* is set */
|
2022-08-18 18:36:05 +02:00
|
|
|
alignas(uint32_t) uint8_t prog_buf[CONFIG_LITTLEFS2_PROG_BUFFER_SIZE];
|
2020-02-13 13:33:45 +01:00
|
|
|
#endif
|
|
|
|
/** lookahead buffer to use internally */
|
2022-08-18 18:36:05 +02:00
|
|
|
alignas(uint32_t) uint8_t lookahead_buf[CONFIG_LITTLEFS2_LOOKAHEAD_SIZE];
|
|
|
|
uint16_t sectors_per_block; /**< number of sectors per block */
|
2020-06-30 16:09:40 +02:00
|
|
|
} littlefs2_desc_t;
|
2020-02-13 13:33:45 +01:00
|
|
|
|
|
|
|
/** The littlefs vfs driver */
|
|
|
|
extern const vfs_file_system_t littlefs2_file_system;
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* FS_LITTLEFS2_FS_H */
|
|
|
|
/** @} */
|