Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/littlefs-project/littlefs.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/lfs.h
diff options
context:
space:
mode:
authorBill Gesner <bill.gesner@renesas.com>2020-09-18 02:41:20 +0300
committerBill Gesner <bill.gesner@renesas.com>2020-09-18 02:41:20 +0300
commit10ac6b9cf074ec165b2bf07bd412e386461ae395 (patch)
tree023022a48ee5d4ab9f3bc0010fc2827999fb5889 /lfs.h
parent4c9146ea539f72749d6cc3ea076372a81b12cb11 (diff)
add thread safe wrappers
Diffstat (limited to 'lfs.h')
-rw-r--r--lfs.h183
1 files changed, 148 insertions, 35 deletions
diff --git a/lfs.h b/lfs.h
index 35bbbab..92f0490 100644
--- a/lfs.h
+++ b/lfs.h
@@ -9,6 +9,7 @@
#include <stdint.h>
#include <stdbool.h>
+#include "lfs_util.h"
#ifdef __cplusplus
extern "C"
@@ -53,7 +54,7 @@ typedef uint32_t lfs_block_t;
// Maximum size of a file in bytes, may be redefined to limit to support other
// drivers. Limited on disk to <= 4294967296. However, above 2147483647 the
-// functions lfs_file_seek, lfs_file_size, and lfs_file_tell will return
+// functions _lfs_file_seek, _lfs_file_size, and _lfs_file_tell will return
// incorrect values due to using signed integers. Stored in superblock and
// must be respected by other littlefs drivers.
#ifndef LFS_FILE_MAX
@@ -84,6 +85,9 @@ enum lfs_error {
LFS_ERR_NOMEM = -12, // No more memory available
LFS_ERR_NOATTR = -61, // No data/attr available
LFS_ERR_NAMETOOLONG = -36, // File name too long
+#if LFS_THREAD_SAFE
+ LFS_ERR_LOCK = -23, // Failed to aquire lock
+#endif
};
// File types
@@ -174,6 +178,16 @@ struct lfs_config {
// are propogated to the user.
int (*sync)(const struct lfs_config *c);
+ #if LFS_THREAD_SAFE
+ // Lock the underlying block device. Negative error codes
+ // are propogated to the user.
+ int (*lock)(const struct lfs_config *c);
+
+ // Unlock the underlying block device. Negative error codes
+ // are propogated to the user.
+ int (*unlock)(const struct lfs_config *c);
+ #endif
+
// Minimum size of a block read. All read operations will be a
// multiple of this value.
lfs_size_t read_size;
@@ -406,7 +420,7 @@ typedef struct lfs {
// be zeroed for defaults and backwards compatibility.
//
// Returns a negative error code on failure.
-int lfs_format(lfs_t *lfs, const struct lfs_config *config);
+int _lfs_format(lfs_t *lfs, const struct lfs_config *config);
// Mounts a littlefs
//
@@ -416,13 +430,13 @@ int lfs_format(lfs_t *lfs, const struct lfs_config *config);
// be zeroed for defaults and backwards compatibility.
//
// Returns a negative error code on failure.
-int lfs_mount(lfs_t *lfs, const struct lfs_config *config);
+int _lfs_mount(lfs_t *lfs, const struct lfs_config *config);
// Unmounts a littlefs
//
// Does nothing besides releasing any allocated resources.
// Returns a negative error code on failure.
-int lfs_unmount(lfs_t *lfs);
+int _lfs_unmount(lfs_t *lfs);
/// General operations ///
@@ -430,7 +444,7 @@ int lfs_unmount(lfs_t *lfs);
//
// If removing a directory, the directory must be empty.
// Returns a negative error code on failure.
-int lfs_remove(lfs_t *lfs, const char *path);
+int _lfs_remove(lfs_t *lfs, const char *path);
// Rename or move a file or directory
//
@@ -438,13 +452,13 @@ int lfs_remove(lfs_t *lfs, const char *path);
// If the destination is a directory, the directory must be empty.
//
// Returns a negative error code on failure.
-int lfs_rename(lfs_t *lfs, const char *oldpath, const char *newpath);
+int _lfs_rename(lfs_t *lfs, const char *oldpath, const char *newpath);
// Find info about a file or directory
//
// Fills out the info structure, based on the specified file or directory.
// Returns a negative error code on failure.
-int lfs_stat(lfs_t *lfs, const char *path, struct lfs_info *info);
+int _lfs_stat(lfs_t *lfs, const char *path, struct lfs_info *info);
// Get a custom attribute
//
@@ -458,7 +472,7 @@ int lfs_stat(lfs_t *lfs, const char *path, struct lfs_info *info);
// Note, the returned size is the size of the attribute on disk, irrespective
// of the size of the buffer. This can be used to dynamically allocate a buffer
// or check for existance.
-lfs_ssize_t lfs_getattr(lfs_t *lfs, const char *path,
+lfs_ssize_t _lfs_getattr(lfs_t *lfs, const char *path,
uint8_t type, void *buffer, lfs_size_t size);
// Set custom attributes
@@ -468,7 +482,7 @@ lfs_ssize_t lfs_getattr(lfs_t *lfs, const char *path,
// implicitly created.
//
// Returns a negative error code on failure.
-int lfs_setattr(lfs_t *lfs, const char *path,
+int _lfs_setattr(lfs_t *lfs, const char *path,
uint8_t type, const void *buffer, lfs_size_t size);
// Removes a custom attribute
@@ -476,7 +490,7 @@ int lfs_setattr(lfs_t *lfs, const char *path,
// If an attribute is not found, nothing happens.
//
// Returns a negative error code on failure.
-int lfs_removeattr(lfs_t *lfs, const char *path, uint8_t type);
+int _lfs_removeattr(lfs_t *lfs, const char *path, uint8_t type);
/// File operations ///
@@ -487,7 +501,7 @@ int lfs_removeattr(lfs_t *lfs, const char *path, uint8_t type);
// are values from the enum lfs_open_flags that are bitwise-ored together.
//
// Returns a negative error code on failure.
-int lfs_file_open(lfs_t *lfs, lfs_file_t *file,
+int _lfs_file_open(lfs_t *lfs, lfs_file_t *file,
const char *path, int flags);
// Open a file with extra configuration
@@ -500,7 +514,7 @@ int lfs_file_open(lfs_t *lfs, lfs_file_t *file,
// config struct must be zeroed for defaults and backwards compatibility.
//
// Returns a negative error code on failure.
-int lfs_file_opencfg(lfs_t *lfs, lfs_file_t *file,
+int _lfs_file_opencfg(lfs_t *lfs, lfs_file_t *file,
const char *path, int flags,
const struct lfs_file_config *config);
@@ -510,19 +524,19 @@ int lfs_file_opencfg(lfs_t *lfs, lfs_file_t *file,
// sync had been called and releases any allocated resources.
//
// Returns a negative error code on failure.
-int lfs_file_close(lfs_t *lfs, lfs_file_t *file);
+int _lfs_file_close(lfs_t *lfs, lfs_file_t *file);
// Synchronize a file on storage
//
// Any pending writes are written out to storage.
// Returns a negative error code on failure.
-int lfs_file_sync(lfs_t *lfs, lfs_file_t *file);
+int _lfs_file_sync(lfs_t *lfs, lfs_file_t *file);
// Read data from file
//
// Takes a buffer and size indicating where to store the read data.
// Returns the number of bytes read, or a negative error code on failure.
-lfs_ssize_t lfs_file_read(lfs_t *lfs, lfs_file_t *file,
+lfs_ssize_t _lfs_file_read(lfs_t *lfs, lfs_file_t *file,
void *buffer, lfs_size_t size);
// Write data to file
@@ -531,38 +545,38 @@ lfs_ssize_t lfs_file_read(lfs_t *lfs, lfs_file_t *file,
// actually be updated on the storage until either sync or close is called.
//
// Returns the number of bytes written, or a negative error code on failure.
-lfs_ssize_t lfs_file_write(lfs_t *lfs, lfs_file_t *file,
+lfs_ssize_t _lfs_file_write(lfs_t *lfs, lfs_file_t *file,
const void *buffer, lfs_size_t size);
// Change the position of the file
//
// The change in position is determined by the offset and whence flag.
// Returns the new position of the file, or a negative error code on failure.
-lfs_soff_t lfs_file_seek(lfs_t *lfs, lfs_file_t *file,
+lfs_soff_t _lfs_file_seek(lfs_t *lfs, lfs_file_t *file,
lfs_soff_t off, int whence);
// Truncates the size of the file to the specified size
//
// Returns a negative error code on failure.
-int lfs_file_truncate(lfs_t *lfs, lfs_file_t *file, lfs_off_t size);
+int _lfs_file_truncate(lfs_t *lfs, lfs_file_t *file, lfs_off_t size);
// Return the position of the file
//
-// Equivalent to lfs_file_seek(lfs, file, 0, LFS_SEEK_CUR)
+// Equivalent to _lfs_file_seek(lfs, file, 0, LFS_SEEK_CUR)
// Returns the position of the file, or a negative error code on failure.
-lfs_soff_t lfs_file_tell(lfs_t *lfs, lfs_file_t *file);
+lfs_soff_t _lfs_file_tell(lfs_t *lfs, lfs_file_t *file);
// Change the position of the file to the beginning of the file
//
-// Equivalent to lfs_file_seek(lfs, file, 0, LFS_SEEK_SET)
+// Equivalent to _lfs_file_seek(lfs, file, 0, LFS_SEEK_SET)
// Returns a negative error code on failure.
-int lfs_file_rewind(lfs_t *lfs, lfs_file_t *file);
+int _lfs_file_rewind(lfs_t *lfs, lfs_file_t *file);
// Return the size of the file
//
-// Similar to lfs_file_seek(lfs, file, 0, LFS_SEEK_END)
+// Similar to _lfs_file_seek(lfs, file, 0, LFS_SEEK_END)
// Returns the size of the file, or a negative error code on failure.
-lfs_soff_t lfs_file_size(lfs_t *lfs, lfs_file_t *file);
+lfs_soff_t _lfs_file_size(lfs_t *lfs, lfs_file_t *file);
/// Directory operations ///
@@ -570,26 +584,26 @@ lfs_soff_t lfs_file_size(lfs_t *lfs, lfs_file_t *file);
// Create a directory
//
// Returns a negative error code on failure.
-int lfs_mkdir(lfs_t *lfs, const char *path);
+int _lfs_mkdir(lfs_t *lfs, const char *path);
// Open a directory
//
// Once open a directory can be used with read to iterate over files.
// Returns a negative error code on failure.
-int lfs_dir_open(lfs_t *lfs, lfs_dir_t *dir, const char *path);
+int _lfs_dir_open(lfs_t *lfs, lfs_dir_t *dir, const char *path);
// Close a directory
//
// Releases any allocated resources.
// Returns a negative error code on failure.
-int lfs_dir_close(lfs_t *lfs, lfs_dir_t *dir);
+int _lfs_dir_close(lfs_t *lfs, lfs_dir_t *dir);
// Read an entry in the directory
//
// Fills out the info structure, based on the specified file or directory.
// Returns a positive value on success, 0 at the end of directory,
// or a negative error code on failure.
-int lfs_dir_read(lfs_t *lfs, lfs_dir_t *dir, struct lfs_info *info);
+int _lfs_dir_read(lfs_t *lfs, lfs_dir_t *dir, struct lfs_info *info);
// Change the position of the directory
//
@@ -597,7 +611,7 @@ int lfs_dir_read(lfs_t *lfs, lfs_dir_t *dir, struct lfs_info *info);
// an absolute offset in the directory seek.
//
// Returns a negative error code on failure.
-int lfs_dir_seek(lfs_t *lfs, lfs_dir_t *dir, lfs_off_t off);
+int _lfs_dir_seek(lfs_t *lfs, lfs_dir_t *dir, lfs_off_t off);
// Return the position of the directory
//
@@ -605,12 +619,12 @@ int lfs_dir_seek(lfs_t *lfs, lfs_dir_t *dir, lfs_off_t off);
// sense, but does indicate the current position in the directory iteration.
//
// Returns the position of the directory, or a negative error code on failure.
-lfs_soff_t lfs_dir_tell(lfs_t *lfs, lfs_dir_t *dir);
+lfs_soff_t _lfs_dir_tell(lfs_t *lfs, lfs_dir_t *dir);
// Change the position of the directory to the beginning of the directory
//
// Returns a negative error code on failure.
-int lfs_dir_rewind(lfs_t *lfs, lfs_dir_t *dir);
+int _lfs_dir_rewind(lfs_t *lfs, lfs_dir_t *dir);
/// Filesystem-level filesystem operations
@@ -621,7 +635,7 @@ int lfs_dir_rewind(lfs_t *lfs, lfs_dir_t *dir);
// size may be larger than the filesystem actually is.
//
// Returns the number of allocated blocks, or a negative error code on failure.
-lfs_ssize_t lfs_fs_size(lfs_t *lfs);
+lfs_ssize_t _lfs_fs_size(lfs_t *lfs);
// Traverse through all blocks in use by the filesystem
//
@@ -630,12 +644,12 @@ lfs_ssize_t lfs_fs_size(lfs_t *lfs);
// blocks are in use or how much of the storage is available.
//
// Returns a negative error code on failure.
-int lfs_fs_traverse(lfs_t *lfs, int (*cb)(void*, lfs_block_t), void *data);
+int _lfs_fs_traverse(lfs_t *lfs, int (*cb)(void*, lfs_block_t), void *data);
#ifdef LFS_MIGRATE
// Attempts to migrate a previous version of littlefs
//
-// Behaves similarly to the lfs_format function. Attempts to mount
+// Behaves similarly to the _lfs_format function. Attempts to mount
// the previous version of littlefs and update the filesystem so it can be
// mounted with the current version of littlefs.
//
@@ -644,7 +658,106 @@ int lfs_fs_traverse(lfs_t *lfs, int (*cb)(void*, lfs_block_t), void *data);
// be zeroed for defaults and backwards compatibility.
//
// Returns a negative error code on failure.
-int lfs_migrate(lfs_t *lfs, const struct lfs_config *cfg);
+int _lfs_migrate(lfs_t *lfs, const struct lfs_config *cfg);
+#endif
+
+#if LFS_THREAD_SAFE
+
+int _ts_lfs_format(lfs_t *lfs, const struct lfs_config *config);
+int _ts_lfs_mount(lfs_t *lfs, const struct lfs_config *config);
+int _ts_lfs_unmount(lfs_t *lfs);
+int _ts_lfs_remove(lfs_t *lfs, const char *path);
+int _ts_lfs_rename(lfs_t *lfs, const char *oldpath, const char *newpath);
+int _ts_lfs_stat(lfs_t *lfs, const char *path, struct lfs_info *info);
+lfs_ssize_t _ts_lfs_getattr(lfs_t *lfs, const char *path, uint8_t type, void *buffer, lfs_size_t size);
+int _ts_lfs_setattr(lfs_t *lfs, const char *path, uint8_t type, const void *buffer, lfs_size_t size);
+int _ts_lfs_removeattr(lfs_t *lfs, const char *path, uint8_t type);
+int _ts_lfs_file_open(lfs_t *lfs, lfs_file_t *file, const char *path, int flags);
+int _ts_lfs_file_opencfg(lfs_t *lfs, lfs_file_t *file, const char *path, int flags, const struct lfs_file_config *config);
+int _ts_lfs_file_close(lfs_t *lfs, lfs_file_t *file);
+int _ts_lfs_file_sync(lfs_t *lfs, lfs_file_t *file);
+lfs_ssize_t _ts_lfs_file_read(lfs_t *lfs, lfs_file_t *file, void *buffer, lfs_size_t size);
+lfs_ssize_t _ts_lfs_file_write(lfs_t *lfs, lfs_file_t *file, const void *buffer, lfs_size_t size);
+lfs_soff_t _ts_lfs_file_seek(lfs_t *lfs, lfs_file_t *file, lfs_soff_t off, int whence);
+int _ts_lfs_file_truncate(lfs_t *lfs, lfs_file_t *file, lfs_off_t size);
+lfs_soff_t _ts_lfs_file_tell(lfs_t *lfs, lfs_file_t *file);
+int _ts_lfs_file_rewind(lfs_t *lfs, lfs_file_t *file);
+lfs_soff_t _ts_lfs_file_size(lfs_t *lfs, lfs_file_t *file);
+int _ts_lfs_mkdir(lfs_t *lfs, const char *path);
+int _ts_lfs_dir_open(lfs_t *lfs, lfs_dir_t *dir, const char *path);
+int _ts_lfs_dir_close(lfs_t *lfs, lfs_dir_t *dir);
+int _ts_lfs_dir_read(lfs_t *lfs, lfs_dir_t *dir, struct lfs_info *info);
+int _ts_lfs_dir_seek(lfs_t *lfs, lfs_dir_t *dir, lfs_off_t off);
+lfs_soff_t _ts_lfs_dir_tell(lfs_t *lfs, lfs_dir_t *dir);
+int _ts_lfs_dir_rewind(lfs_t *lfs, lfs_dir_t *dir);
+lfs_ssize_t _ts_lfs_fs_size(lfs_t *lfs);
+int _ts_lfs_fs_traverse(lfs_t *lfs, int (*cb)(void*, lfs_block_t), void *data);
+int _ts_lfs_migrate(lfs_t *lfs, const struct lfs_config *cfg);
+
+#define lfs_format _ts_lfs_format
+#define lfs_mount _ts_lfs_mount
+#define lfs_unmount _ts_lfs_unmount
+#define lfs_remove _ts_lfs_remove
+#define lfs_rename _ts_lfs_rename
+#define lfs_stat _ts_lfs_stat
+#define lfs_getattr _ts_lfs_getattr
+#define lfs_setattr _ts_lfs_setattr
+#define lfs_removeattr _ts_lfs_removeattr
+#define lfs_file_open _ts_lfs_file_open
+#define lfs_file_opencfg _ts_lfs_file_opencfg
+#define lfs_file_close _ts_lfs_file_close
+#define lfs_file_sync _ts_lfs_file_sync
+#define lfs_file_read _ts_lfs_file_read
+#define lfs_file_write _ts_lfs_file_write
+#define lfs_file_seek _ts_lfs_file_seek
+#define lfs_file_truncate _ts_lfs_file_truncate
+#define lfs_file_tell _ts_lfs_file_tell
+#define lfs_file_rewind _ts_lfs_file_rewind
+#define lfs_file_size _ts_lfs_file_size
+#define lfs_mkdir _ts_lfs_mkdir
+#define lfs_dir_open _ts_lfs_dir_open
+#define lfs_dir_close _ts_lfs_dir_close
+#define lfs_dir_read _ts_lfs_dir_read
+#define lfs_dir_seek _ts_lfs_dir_seek
+#define lfs_dir_tell _ts_lfs_dir_tell
+#define lfs_dir_rewind _ts_lfs_dir_rewind
+#define lfs_fs_size _ts_lfs_fs_size
+#define lfs_fs_traverse _ts_lfs_fs_traverse
+#define lfs_migrate _ts_lfs_migrate
+
+#else
+
+#define lfs_format _lfs_format
+#define lfs_mount _lfs_mount
+#define lfs_unmount _lfs_unmount
+#define lfs_remove _lfs_remove
+#define lfs_rename _lfs_rename
+#define lfs_stat _lfs_stat
+#define lfs_getattr _lfs_getattr
+#define lfs_setattr _lfs_setattr
+#define lfs_removeattr _lfs_removeattr
+#define lfs_file_open _lfs_file_open
+#define lfs_file_opencfg _lfs_file_opencfg
+#define lfs_file_close _lfs_file_close
+#define lfs_file_sync _lfs_file_sync
+#define lfs_file_read _lfs_file_read
+#define lfs_file_write _lfs_file_write
+#define lfs_file_seek _lfs_file_seek
+#define lfs_file_truncate _lfs_file_truncate
+#define lfs_file_tell _lfs_file_tell
+#define lfs_file_rewind _lfs_file_rewind
+#define lfs_file_size _lfs_file_size
+#define lfs_mkdir _lfs_mkdir
+#define lfs_dir_open _lfs_dir_open
+#define lfs_dir_close _lfs_dir_close
+#define lfs_dir_read _lfs_dir_read
+#define lfs_dir_seek _lfs_dir_seek
+#define lfs_dir_tell _lfs_dir_tell
+#define lfs_dir_rewind _lfs_dir_rewind
+#define lfs_fs_size _lfs_fs_size
+#define lfs_fs_traverse _lfs_fs_traverse
+#define lfs_migrate _lfs_migrate
+
#endif