mirror of
https://github.com/eledio-devices/thirdparty-littlefs.git
synced 2025-11-01 00:38:29 +01:00
address review comments
This commit is contained in:
346
lfs.c
346
lfs.c
@@ -4912,375 +4912,539 @@ cleanup:
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if LFS_THREAD_SAFE
|
#if !LFS_THREADSAFE
|
||||||
|
|
||||||
int lfs_format_ts(lfs_t *lfs, const struct lfs_config *config)
|
int lfs_format (lfs_t * lfs, const struct lfs_config * config) {
|
||||||
{
|
return lfs_format_raw(lfs, config);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_mount (lfs_t * lfs, const struct lfs_config * config) {
|
||||||
|
return lfs_mount_raw(lfs, config);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_unmount (lfs_t * lfs) {
|
||||||
|
return lfs_unmount_raw(lfs);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_remove (lfs_t * lfs, const char * path) {
|
||||||
|
return lfs_remove_raw(lfs, path);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_rename (lfs_t * lfs, const char * oldpath, const char * newpath) {
|
||||||
|
return lfs_rename_raw(lfs, oldpath, newpath);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_stat (lfs_t * lfs, const char * path, struct lfs_info * info) {
|
||||||
|
return lfs_stat_raw(lfs, path, info);
|
||||||
|
}
|
||||||
|
|
||||||
|
lfs_ssize_t lfs_getattr (lfs_t * lfs, const char * path, uint8_t type, void * buffer, lfs_size_t size) {
|
||||||
|
return lfs_getattr_raw(lfs, path, type, buffer, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_setattr (lfs_t * lfs, const char * path, uint8_t type, const void * buffer, lfs_size_t size) {
|
||||||
|
return lfs_setattr_raw(lfs, path, type, buffer, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_removeattr (lfs_t * lfs, const char * path, uint8_t type) {
|
||||||
|
return lfs_removeattr_raw(lfs, path, type);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_file_open (lfs_t * lfs, lfs_file_t * file, const char * path, int flags) {
|
||||||
|
return lfs_file_open_raw(lfs, file, path, flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_file_opencfg (lfs_t * lfs,
|
||||||
|
lfs_file_t * file,
|
||||||
|
const char * path,
|
||||||
|
int flags,
|
||||||
|
const struct lfs_file_config * config) {
|
||||||
|
return lfs_file_opencfg_raw(lfs, file, path, flags, config);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_file_close (lfs_t * lfs, lfs_file_t * file) {
|
||||||
|
return lfs_file_close_raw(lfs, file);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_file_sync (lfs_t * lfs, lfs_file_t * file) {
|
||||||
|
return lfs_file_sync_raw(lfs, file);
|
||||||
|
}
|
||||||
|
|
||||||
|
lfs_ssize_t lfs_file_read (lfs_t * lfs, lfs_file_t * file, void * buffer, lfs_size_t size) {
|
||||||
|
return lfs_file_read_raw(lfs, file, buffer, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
lfs_ssize_t lfs_file_write (lfs_t * lfs, lfs_file_t * file, const void * buffer, lfs_size_t size) {
|
||||||
|
return lfs_file_write_raw(lfs, file, buffer, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
lfs_soff_t lfs_file_seek (lfs_t * lfs, lfs_file_t * file, lfs_soff_t off, int whence) {
|
||||||
|
return lfs_file_seek_raw(lfs, file, off, whence);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_file_truncate (lfs_t * lfs, lfs_file_t * file, lfs_off_t size) {
|
||||||
|
return lfs_file_truncate_raw(lfs, file, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
lfs_soff_t lfs_file_tell (lfs_t * lfs, lfs_file_t * file) {
|
||||||
|
return lfs_file_tell_raw(lfs, file);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_file_rewind (lfs_t * lfs, lfs_file_t * file) {
|
||||||
|
return lfs_file_rewind_raw(lfs, file);
|
||||||
|
}
|
||||||
|
|
||||||
|
lfs_soff_t lfs_file_size (lfs_t * lfs, lfs_file_t * file) {
|
||||||
|
return lfs_file_size_raw(lfs, file);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_mkdir (lfs_t * lfs, const char * path) {
|
||||||
|
return lfs_mkdir_raw(lfs, path);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_dir_open (lfs_t * lfs, lfs_dir_t * dir, const char * path) {
|
||||||
|
return lfs_dir_open_raw(lfs, dir, path);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_dir_close (lfs_t * lfs, lfs_dir_t * dir) {
|
||||||
|
return lfs_dir_close_raw(lfs, dir);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_dir_read (lfs_t * lfs, lfs_dir_t * dir, struct lfs_info * info) {
|
||||||
|
return lfs_dir_read_raw(lfs, dir, info);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_dir_seek (lfs_t * lfs, lfs_dir_t * dir, lfs_off_t off) {
|
||||||
|
return lfs_dir_seek_raw(lfs, dir, off);
|
||||||
|
}
|
||||||
|
|
||||||
|
lfs_soff_t lfs_dir_tell (lfs_t * lfs, lfs_dir_t * dir) {
|
||||||
|
return lfs_dir_tell_raw(lfs, dir);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_dir_rewind (lfs_t * lfs, lfs_dir_t * dir) {
|
||||||
|
return lfs_dir_rewind_raw(lfs, dir);
|
||||||
|
}
|
||||||
|
|
||||||
|
lfs_ssize_t lfs_fs_size (lfs_t * lfs) {
|
||||||
|
return lfs_fs_size_raw(lfs);
|
||||||
|
}
|
||||||
|
|
||||||
|
int lfs_fs_traverse (lfs_t * lfs, int (* cb)(void *, lfs_block_t), void * data) {
|
||||||
|
return lfs_fs_traverse_raw(lfs, cb, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef LFS_MIGRATE
|
||||||
|
|
||||||
|
int lfs_migrate (lfs_t * lfs, const struct lfs_config * cfg) {
|
||||||
|
return lfs_migrate_raw(lfs, cfg);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if LFS_THREADSAFE
|
||||||
|
|
||||||
|
int lfs_format (lfs_t * lfs, const struct lfs_config * config) {
|
||||||
int err = config->lock(config);
|
int err = config->lock(config);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_format_raw(lfs, config);
|
err = lfs_format_raw(lfs, config);
|
||||||
config->unlock(config);
|
config->unlock(config);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_mount_ts(lfs_t *lfs, const struct lfs_config *config)
|
|
||||||
{
|
int lfs_mount (lfs_t * lfs, const struct lfs_config * config) {
|
||||||
int err = config->lock(config);
|
int err = config->lock(config);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_mount_raw(lfs, config);
|
err = lfs_mount_raw(lfs, config);
|
||||||
config->unlock(config);
|
config->unlock(config);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_unmount_ts(lfs_t *lfs)
|
|
||||||
{
|
int lfs_unmount (lfs_t * lfs) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_unmount_raw(lfs);
|
err = lfs_unmount_raw(lfs);
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_remove_ts(lfs_t *lfs, const char *path)
|
|
||||||
{
|
int lfs_remove (lfs_t * lfs, const char * path) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_remove_raw(lfs, path);
|
err = lfs_remove_raw(lfs, path);
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_rename_ts(lfs_t *lfs, const char *oldpath, const char *newpath)
|
|
||||||
{
|
int lfs_rename (lfs_t * lfs, const char * oldpath, const char * newpath) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_rename_raw(lfs, oldpath, newpath);
|
err = lfs_rename_raw(lfs, oldpath, newpath);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_stat_ts(lfs_t *lfs, const char *path, struct lfs_info *info)
|
|
||||||
{
|
int lfs_stat (lfs_t * lfs, const char * path, struct lfs_info * info) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_stat_raw(lfs, path, info);
|
err = lfs_stat_raw(lfs, path, info);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
lfs_ssize_t lfs_getattr_ts(lfs_t *lfs, const char *path, uint8_t type, void *buffer, lfs_size_t size)
|
|
||||||
{
|
lfs_ssize_t lfs_getattr (lfs_t * lfs, const char * path, uint8_t type, void * buffer, lfs_size_t size) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_getattr_raw(lfs, path, type, buffer, size);
|
err = lfs_getattr_raw(lfs, path, type, buffer, size);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_setattr_ts(lfs_t *lfs, const char *path, uint8_t type, const void *buffer, lfs_size_t size)
|
|
||||||
{
|
int lfs_setattr (lfs_t * lfs, const char * path, uint8_t type, const void * buffer, lfs_size_t size) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_setattr_raw(lfs, path, type, buffer, size);
|
err = lfs_setattr_raw(lfs, path, type, buffer, size);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_removeattr_ts(lfs_t *lfs, const char *path, uint8_t type)
|
|
||||||
{
|
int lfs_removeattr (lfs_t * lfs, const char * path, uint8_t type) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_removeattr_raw(lfs, path, type);
|
err = lfs_removeattr_raw(lfs, path, type);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_file_open_ts(lfs_t *lfs, lfs_file_t *file, const char *path, int flags)
|
|
||||||
{
|
int lfs_file_open (lfs_t * lfs, lfs_file_t * file, const char * path, int flags) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_file_open_raw(lfs, file, path, flags);
|
err = lfs_file_open_raw(lfs, file, path, flags);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_file_opencfg_ts(lfs_t *lfs, lfs_file_t *file, const char *path, int flags, const struct lfs_file_config *config)
|
|
||||||
{
|
int lfs_file_opencfg (lfs_t * lfs,
|
||||||
|
lfs_file_t * file,
|
||||||
|
const char * path,
|
||||||
|
int flags,
|
||||||
|
const struct lfs_file_config * config) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_file_opencfg_raw(lfs, file, path, flags, config);
|
err = lfs_file_opencfg_raw(lfs, file, path, flags, config);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_file_close_ts(lfs_t *lfs, lfs_file_t *file)
|
|
||||||
{
|
int lfs_file_close (lfs_t * lfs, lfs_file_t * file) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_file_close_raw(lfs, file);
|
err = lfs_file_close_raw(lfs, file);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_file_sync_ts(lfs_t *lfs, lfs_file_t *file)
|
|
||||||
{
|
int lfs_file_sync (lfs_t * lfs, lfs_file_t * file) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_file_sync_raw(lfs, file);
|
err = lfs_file_sync_raw(lfs, file);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
lfs_ssize_t lfs_file_read_ts(lfs_t *lfs, lfs_file_t *file, void *buffer, lfs_size_t size)
|
|
||||||
{
|
lfs_ssize_t lfs_file_read (lfs_t * lfs, lfs_file_t * file, void * buffer, lfs_size_t size) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_file_read_raw(lfs, file, buffer, size);
|
err = lfs_file_read_raw(lfs, file, buffer, size);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
lfs_ssize_t lfs_file_write_ts(lfs_t *lfs, lfs_file_t *file, const void *buffer, lfs_size_t size)
|
|
||||||
{
|
lfs_ssize_t lfs_file_write (lfs_t * lfs, lfs_file_t * file, const void * buffer, lfs_size_t size) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_file_write_raw(lfs, file, buffer, size);
|
err = lfs_file_write_raw(lfs, file, buffer, size);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
lfs_soff_t lfs_file_seek_ts(lfs_t *lfs, lfs_file_t *file, lfs_soff_t off, int whence)
|
|
||||||
{
|
lfs_soff_t lfs_file_seek (lfs_t * lfs, lfs_file_t * file, lfs_soff_t off, int whence) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_file_seek_raw(lfs, file, off, whence);
|
err = lfs_file_seek_raw(lfs, file, off, whence);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_file_truncate_ts(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) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_file_truncate_raw(lfs, file, size);
|
err = lfs_file_truncate_raw(lfs, file, size);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
lfs_soff_t lfs_file_tell_ts(lfs_t *lfs, lfs_file_t *file)
|
|
||||||
{
|
lfs_soff_t lfs_file_tell (lfs_t * lfs, lfs_file_t * file) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_file_tell_raw(lfs, file);
|
err = lfs_file_tell_raw(lfs, file);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_file_rewind_ts(lfs_t *lfs, lfs_file_t *file)
|
|
||||||
{
|
int lfs_file_rewind (lfs_t * lfs, lfs_file_t * file) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_file_rewind_raw(lfs, file);
|
err = lfs_file_rewind_raw(lfs, file);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
lfs_soff_t lfs_file_size_ts(lfs_t *lfs, lfs_file_t *file)
|
|
||||||
{
|
lfs_soff_t lfs_file_size (lfs_t * lfs, lfs_file_t * file) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_file_size_raw(lfs, file);
|
err = lfs_file_size_raw(lfs, file);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_mkdir_ts(lfs_t *lfs, const char *path)
|
|
||||||
{
|
int lfs_mkdir (lfs_t * lfs, const char * path) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_mkdir_raw(lfs, path);
|
err = lfs_mkdir_raw(lfs, path);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_dir_open_ts(lfs_t *lfs, lfs_dir_t *dir, const char *path)
|
|
||||||
{
|
int lfs_dir_open (lfs_t * lfs, lfs_dir_t * dir, const char * path) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_dir_open_raw(lfs, dir, path);
|
err = lfs_dir_open_raw(lfs, dir, path);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_dir_close_ts(lfs_t *lfs, lfs_dir_t *dir)
|
|
||||||
{
|
int lfs_dir_close (lfs_t * lfs, lfs_dir_t * dir) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_dir_close_raw(lfs, dir);
|
err = lfs_dir_close_raw(lfs, dir);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_dir_read_ts(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) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_dir_read_raw(lfs, dir, info);
|
err = lfs_dir_read_raw(lfs, dir, info);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_dir_seek_ts(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) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_dir_seek_raw(lfs, dir, off);
|
err = lfs_dir_seek_raw(lfs, dir, off);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
lfs_soff_t lfs_dir_tell_ts(lfs_t *lfs, lfs_dir_t *dir)
|
|
||||||
{
|
lfs_soff_t lfs_dir_tell (lfs_t * lfs, lfs_dir_t * dir) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_dir_tell_raw(lfs, dir);
|
err = lfs_dir_tell_raw(lfs, dir);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_dir_rewind_ts(lfs_t *lfs, lfs_dir_t *dir)
|
|
||||||
{
|
int lfs_dir_rewind (lfs_t * lfs, lfs_dir_t * dir) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_dir_rewind_raw(lfs, dir);
|
err = lfs_dir_rewind_raw(lfs, dir);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
lfs_ssize_t lfs_fs_size_ts(lfs_t *lfs)
|
|
||||||
{
|
lfs_ssize_t lfs_fs_size (lfs_t * lfs) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_fs_size_raw(lfs);
|
err = lfs_fs_size_raw(lfs);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
int lfs_fs_traverse_ts(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) {
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_fs_traverse_raw(lfs, cb, data);
|
err = lfs_fs_traverse_raw(lfs, cb, data);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
@@ -5290,13 +5454,13 @@ int lfs_fs_traverse_ts(lfs_t *lfs, int (*cb)(void*, lfs_block_t), void *data)
|
|||||||
|
|
||||||
#ifdef LFS_MIGRATE
|
#ifdef LFS_MIGRATE
|
||||||
|
|
||||||
int lfs_migrate_ts(lfs_t *lfs, const struct lfs_config *cfg)
|
int lfs_migrate (lfs_t * lfs, const struct lfs_config * cfg) {
|
||||||
{
|
|
||||||
int err = lfs->cfg->lock(lfs->cfg);
|
int err = lfs->cfg->lock(lfs->cfg);
|
||||||
if(err)
|
if (err)
|
||||||
{
|
{
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = lfs_migrate_raw(lfs, cfg);
|
err = lfs_migrate_raw(lfs, cfg);
|
||||||
|
|
||||||
lfs->cfg->unlock(lfs->cfg);
|
lfs->cfg->unlock(lfs->cfg);
|
||||||
|
|||||||
206
lfs.h
206
lfs.h
@@ -16,7 +16,6 @@ extern "C"
|
|||||||
{
|
{
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/// Version info ///
|
/// Version info ///
|
||||||
|
|
||||||
// Software library version
|
// Software library version
|
||||||
@@ -54,7 +53,7 @@ typedef uint32_t lfs_block_t;
|
|||||||
|
|
||||||
// Maximum size of a file in bytes, may be redefined to limit to support other
|
// 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
|
// drivers. Limited on disk to <= 4294967296. However, above 2147483647 the
|
||||||
// functions lfs_file_seek_raw, lfs_file_size_raw, and lfs_file_tell_raw 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
|
// incorrect values due to using signed integers. Stored in superblock and
|
||||||
// must be respected by other littlefs drivers.
|
// must be respected by other littlefs drivers.
|
||||||
#ifndef LFS_FILE_MAX
|
#ifndef LFS_FILE_MAX
|
||||||
@@ -175,7 +174,7 @@ struct lfs_config {
|
|||||||
// are propogated to the user.
|
// are propogated to the user.
|
||||||
int (*sync)(const struct lfs_config *c);
|
int (*sync)(const struct lfs_config *c);
|
||||||
|
|
||||||
#if LFS_THREAD_SAFE
|
#if LFS_THREADSAFE
|
||||||
// Lock the underlying block device. Negative error codes
|
// Lock the underlying block device. Negative error codes
|
||||||
// are propogated to the user.
|
// are propogated to the user.
|
||||||
int (*lock)(const struct lfs_config *c);
|
int (*lock)(const struct lfs_config *c);
|
||||||
@@ -183,7 +182,7 @@ struct lfs_config {
|
|||||||
// Unlock the underlying block device. Negative error codes
|
// Unlock the underlying block device. Negative error codes
|
||||||
// are propogated to the user.
|
// are propogated to the user.
|
||||||
int (*unlock)(const struct lfs_config *c);
|
int (*unlock)(const struct lfs_config *c);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Minimum size of a block read. All read operations will be a
|
// Minimum size of a block read. All read operations will be a
|
||||||
// multiple of this value.
|
// multiple of this value.
|
||||||
@@ -417,7 +416,7 @@ typedef struct lfs {
|
|||||||
// be zeroed for defaults and backwards compatibility.
|
// be zeroed for defaults and backwards compatibility.
|
||||||
//
|
//
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_format_raw(lfs_t *lfs, const struct lfs_config *config);
|
int lfs_format(lfs_t *lfs, const struct lfs_config *config);
|
||||||
|
|
||||||
// Mounts a littlefs
|
// Mounts a littlefs
|
||||||
//
|
//
|
||||||
@@ -427,13 +426,13 @@ int lfs_format_raw(lfs_t *lfs, const struct lfs_config *config);
|
|||||||
// be zeroed for defaults and backwards compatibility.
|
// be zeroed for defaults and backwards compatibility.
|
||||||
//
|
//
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_mount_raw(lfs_t *lfs, const struct lfs_config *config);
|
int lfs_mount(lfs_t *lfs, const struct lfs_config *config);
|
||||||
|
|
||||||
// Unmounts a littlefs
|
// Unmounts a littlefs
|
||||||
//
|
//
|
||||||
// Does nothing besides releasing any allocated resources.
|
// Does nothing besides releasing any allocated resources.
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_unmount_raw(lfs_t *lfs);
|
int lfs_unmount(lfs_t *lfs);
|
||||||
|
|
||||||
/// General operations ///
|
/// General operations ///
|
||||||
|
|
||||||
@@ -441,7 +440,7 @@ int lfs_unmount_raw(lfs_t *lfs);
|
|||||||
//
|
//
|
||||||
// If removing a directory, the directory must be empty.
|
// If removing a directory, the directory must be empty.
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_remove_raw(lfs_t *lfs, const char *path);
|
int lfs_remove(lfs_t *lfs, const char *path);
|
||||||
|
|
||||||
// Rename or move a file or directory
|
// Rename or move a file or directory
|
||||||
//
|
//
|
||||||
@@ -449,13 +448,13 @@ int lfs_remove_raw(lfs_t *lfs, const char *path);
|
|||||||
// If the destination is a directory, the directory must be empty.
|
// If the destination is a directory, the directory must be empty.
|
||||||
//
|
//
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_rename_raw(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
|
// Find info about a file or directory
|
||||||
//
|
//
|
||||||
// Fills out the info structure, based on the specified file or directory.
|
// Fills out the info structure, based on the specified file or directory.
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_stat_raw(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
|
// Get a custom attribute
|
||||||
//
|
//
|
||||||
@@ -469,7 +468,7 @@ int lfs_stat_raw(lfs_t *lfs, const char *path, struct lfs_info *info);
|
|||||||
// Note, the returned size is the size of the attribute on disk, irrespective
|
// 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
|
// of the size of the buffer. This can be used to dynamically allocate a buffer
|
||||||
// or check for existance.
|
// or check for existance.
|
||||||
lfs_ssize_t lfs_getattr_raw(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);
|
uint8_t type, void *buffer, lfs_size_t size);
|
||||||
|
|
||||||
// Set custom attributes
|
// Set custom attributes
|
||||||
@@ -479,7 +478,7 @@ lfs_ssize_t lfs_getattr_raw(lfs_t *lfs, const char *path,
|
|||||||
// implicitly created.
|
// implicitly created.
|
||||||
//
|
//
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_setattr_raw(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);
|
uint8_t type, const void *buffer, lfs_size_t size);
|
||||||
|
|
||||||
// Removes a custom attribute
|
// Removes a custom attribute
|
||||||
@@ -487,7 +486,7 @@ int lfs_setattr_raw(lfs_t *lfs, const char *path,
|
|||||||
// If an attribute is not found, nothing happens.
|
// If an attribute is not found, nothing happens.
|
||||||
//
|
//
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_removeattr_raw(lfs_t *lfs, const char *path, uint8_t type);
|
int lfs_removeattr(lfs_t *lfs, const char *path, uint8_t type);
|
||||||
|
|
||||||
|
|
||||||
/// File operations ///
|
/// File operations ///
|
||||||
@@ -498,7 +497,7 @@ int lfs_removeattr_raw(lfs_t *lfs, const char *path, uint8_t type);
|
|||||||
// are values from the enum lfs_open_flags that are bitwise-ored together.
|
// are values from the enum lfs_open_flags that are bitwise-ored together.
|
||||||
//
|
//
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_file_open_raw(lfs_t *lfs, lfs_file_t *file,
|
int lfs_file_open(lfs_t *lfs, lfs_file_t *file,
|
||||||
const char *path, int flags);
|
const char *path, int flags);
|
||||||
|
|
||||||
// Open a file with extra configuration
|
// Open a file with extra configuration
|
||||||
@@ -511,7 +510,7 @@ int lfs_file_open_raw(lfs_t *lfs, lfs_file_t *file,
|
|||||||
// config struct must be zeroed for defaults and backwards compatibility.
|
// config struct must be zeroed for defaults and backwards compatibility.
|
||||||
//
|
//
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_file_opencfg_raw(lfs_t *lfs, lfs_file_t *file,
|
int lfs_file_opencfg(lfs_t *lfs, lfs_file_t *file,
|
||||||
const char *path, int flags,
|
const char *path, int flags,
|
||||||
const struct lfs_file_config *config);
|
const struct lfs_file_config *config);
|
||||||
|
|
||||||
@@ -521,19 +520,19 @@ int lfs_file_opencfg_raw(lfs_t *lfs, lfs_file_t *file,
|
|||||||
// sync had been called and releases any allocated resources.
|
// sync had been called and releases any allocated resources.
|
||||||
//
|
//
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_file_close_raw(lfs_t *lfs, lfs_file_t *file);
|
int lfs_file_close(lfs_t *lfs, lfs_file_t *file);
|
||||||
|
|
||||||
// Synchronize a file on storage
|
// Synchronize a file on storage
|
||||||
//
|
//
|
||||||
// Any pending writes are written out to storage.
|
// Any pending writes are written out to storage.
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_file_sync_raw(lfs_t *lfs, lfs_file_t *file);
|
int lfs_file_sync(lfs_t *lfs, lfs_file_t *file);
|
||||||
|
|
||||||
// Read data from file
|
// Read data from file
|
||||||
//
|
//
|
||||||
// Takes a buffer and size indicating where to store the read data.
|
// 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.
|
// Returns the number of bytes read, or a negative error code on failure.
|
||||||
lfs_ssize_t lfs_file_read_raw(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);
|
void *buffer, lfs_size_t size);
|
||||||
|
|
||||||
// Write data to file
|
// Write data to file
|
||||||
@@ -542,38 +541,38 @@ lfs_ssize_t lfs_file_read_raw(lfs_t *lfs, lfs_file_t *file,
|
|||||||
// actually be updated on the storage until either sync or close is called.
|
// 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.
|
// Returns the number of bytes written, or a negative error code on failure.
|
||||||
lfs_ssize_t lfs_file_write_raw(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);
|
const void *buffer, lfs_size_t size);
|
||||||
|
|
||||||
// Change the position of the file
|
// Change the position of the file
|
||||||
//
|
//
|
||||||
// The change in position is determined by the offset and whence flag.
|
// 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.
|
// Returns the new position of the file, or a negative error code on failure.
|
||||||
lfs_soff_t lfs_file_seek_raw(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);
|
lfs_soff_t off, int whence);
|
||||||
|
|
||||||
// Truncates the size of the file to the specified size
|
// Truncates the size of the file to the specified size
|
||||||
//
|
//
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_file_truncate_raw(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
|
// Return the position of the file
|
||||||
//
|
//
|
||||||
// Equivalent to lfs_file_seek_raw(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.
|
// Returns the position of the file, or a negative error code on failure.
|
||||||
lfs_soff_t lfs_file_tell_raw(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
|
// Change the position of the file to the beginning of the file
|
||||||
//
|
//
|
||||||
// Equivalent to lfs_file_seek_raw(lfs, file, 0, LFS_SEEK_SET)
|
// Equivalent to lfs_file_seek(lfs, file, 0, LFS_SEEK_SET)
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_file_rewind_raw(lfs_t *lfs, lfs_file_t *file);
|
int lfs_file_rewind(lfs_t *lfs, lfs_file_t *file);
|
||||||
|
|
||||||
// Return the size of the file
|
// Return the size of the file
|
||||||
//
|
//
|
||||||
// Similar to lfs_file_seek_raw(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.
|
// Returns the size of the file, or a negative error code on failure.
|
||||||
lfs_soff_t lfs_file_size_raw(lfs_t *lfs, lfs_file_t *file);
|
lfs_soff_t lfs_file_size(lfs_t *lfs, lfs_file_t *file);
|
||||||
|
|
||||||
|
|
||||||
/// Directory operations ///
|
/// Directory operations ///
|
||||||
@@ -581,26 +580,26 @@ lfs_soff_t lfs_file_size_raw(lfs_t *lfs, lfs_file_t *file);
|
|||||||
// Create a directory
|
// Create a directory
|
||||||
//
|
//
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_mkdir_raw(lfs_t *lfs, const char *path);
|
int lfs_mkdir(lfs_t *lfs, const char *path);
|
||||||
|
|
||||||
// Open a directory
|
// Open a directory
|
||||||
//
|
//
|
||||||
// Once open a directory can be used with read to iterate over files.
|
// Once open a directory can be used with read to iterate over files.
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_dir_open_raw(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
|
// Close a directory
|
||||||
//
|
//
|
||||||
// Releases any allocated resources.
|
// Releases any allocated resources.
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_dir_close_raw(lfs_t *lfs, lfs_dir_t *dir);
|
int lfs_dir_close(lfs_t *lfs, lfs_dir_t *dir);
|
||||||
|
|
||||||
// Read an entry in the directory
|
// Read an entry in the directory
|
||||||
//
|
//
|
||||||
// Fills out the info structure, based on the specified file or 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,
|
// Returns a positive value on success, 0 at the end of directory,
|
||||||
// or a negative error code on failure.
|
// or a negative error code on failure.
|
||||||
int lfs_dir_read_raw(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
|
// Change the position of the directory
|
||||||
//
|
//
|
||||||
@@ -608,7 +607,7 @@ int lfs_dir_read_raw(lfs_t *lfs, lfs_dir_t *dir, struct lfs_info *info);
|
|||||||
// an absolute offset in the directory seek.
|
// an absolute offset in the directory seek.
|
||||||
//
|
//
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_dir_seek_raw(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
|
// Return the position of the directory
|
||||||
//
|
//
|
||||||
@@ -616,12 +615,12 @@ int lfs_dir_seek_raw(lfs_t *lfs, lfs_dir_t *dir, lfs_off_t off);
|
|||||||
// sense, but does indicate the current position in the directory iteration.
|
// sense, but does indicate the current position in the directory iteration.
|
||||||
//
|
//
|
||||||
// Returns the position of the directory, or a negative error code on failure.
|
// Returns the position of the directory, or a negative error code on failure.
|
||||||
lfs_soff_t lfs_dir_tell_raw(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
|
// Change the position of the directory to the beginning of the directory
|
||||||
//
|
//
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_dir_rewind_raw(lfs_t *lfs, lfs_dir_t *dir);
|
int lfs_dir_rewind(lfs_t *lfs, lfs_dir_t *dir);
|
||||||
|
|
||||||
|
|
||||||
/// Filesystem-level filesystem operations
|
/// Filesystem-level filesystem operations
|
||||||
@@ -632,7 +631,7 @@ int lfs_dir_rewind_raw(lfs_t *lfs, lfs_dir_t *dir);
|
|||||||
// size may be larger than the filesystem actually is.
|
// size may be larger than the filesystem actually is.
|
||||||
//
|
//
|
||||||
// Returns the number of allocated blocks, or a negative error code on failure.
|
// Returns the number of allocated blocks, or a negative error code on failure.
|
||||||
lfs_ssize_t lfs_fs_size_raw(lfs_t *lfs);
|
lfs_ssize_t lfs_fs_size(lfs_t *lfs);
|
||||||
|
|
||||||
// Traverse through all blocks in use by the filesystem
|
// Traverse through all blocks in use by the filesystem
|
||||||
//
|
//
|
||||||
@@ -641,12 +640,12 @@ lfs_ssize_t lfs_fs_size_raw(lfs_t *lfs);
|
|||||||
// blocks are in use or how much of the storage is available.
|
// blocks are in use or how much of the storage is available.
|
||||||
//
|
//
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
int lfs_fs_traverse_raw(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
|
#ifdef LFS_MIGRATE
|
||||||
// Attempts to migrate a previous version of littlefs
|
// Attempts to migrate a previous version of littlefs
|
||||||
//
|
//
|
||||||
// Behaves similarly to the lfs_format_raw 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
|
// the previous version of littlefs and update the filesystem so it can be
|
||||||
// mounted with the current version of littlefs.
|
// mounted with the current version of littlefs.
|
||||||
//
|
//
|
||||||
@@ -655,108 +654,39 @@ int lfs_fs_traverse_raw(lfs_t *lfs, int (*cb)(void*, lfs_block_t), void *data);
|
|||||||
// be zeroed for defaults and backwards compatibility.
|
// be zeroed for defaults and backwards compatibility.
|
||||||
//
|
//
|
||||||
// Returns a negative error code on failure.
|
// Returns a negative error code on failure.
|
||||||
|
int lfs_migrate(lfs_t *lfs, const struct lfs_config *cfg);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int lfs_format_raw(lfs_t *lfs, const struct lfs_config *config);
|
||||||
|
int lfs_mount_raw(lfs_t *lfs, const struct lfs_config *config);
|
||||||
|
int lfs_unmount_raw(lfs_t *lfs);
|
||||||
|
int lfs_remove_raw(lfs_t *lfs, const char *path);
|
||||||
|
int lfs_rename_raw(lfs_t *lfs, const char *oldpath, const char *newpath);
|
||||||
|
int lfs_stat_raw(lfs_t *lfs, const char *path, struct lfs_info *info);
|
||||||
|
lfs_ssize_t lfs_getattr_raw(lfs_t *lfs, const char *path, uint8_t type, void *buffer, lfs_size_t size);
|
||||||
|
int lfs_setattr_raw(lfs_t *lfs, const char *path, uint8_t type, const void *buffer, lfs_size_t size);
|
||||||
|
int lfs_removeattr_raw(lfs_t *lfs, const char *path, uint8_t type);
|
||||||
|
int lfs_file_open_raw(lfs_t *lfs, lfs_file_t *file, const char *path, int flags);
|
||||||
|
int lfs_file_opencfg_raw(lfs_t *lfs, lfs_file_t *file, const char *path, int flags, const struct lfs_file_config *config);
|
||||||
|
int lfs_file_close_raw(lfs_t *lfs, lfs_file_t *file);
|
||||||
|
int lfs_file_sync_raw(lfs_t *lfs, lfs_file_t *file);
|
||||||
|
lfs_ssize_t lfs_file_read_raw(lfs_t *lfs, lfs_file_t *file, void *buffer, lfs_size_t size);
|
||||||
|
lfs_ssize_t lfs_file_write_raw(lfs_t *lfs, lfs_file_t *file, const void *buffer, lfs_size_t size);
|
||||||
|
lfs_soff_t lfs_file_seek_raw(lfs_t *lfs, lfs_file_t *file, lfs_soff_t off, int whence);
|
||||||
|
int lfs_file_truncate_raw(lfs_t *lfs, lfs_file_t *file, lfs_off_t size);
|
||||||
|
lfs_soff_t lfs_file_tell_raw(lfs_t *lfs, lfs_file_t *file);
|
||||||
|
int lfs_file_rewind_raw(lfs_t *lfs, lfs_file_t *file);
|
||||||
|
lfs_soff_t lfs_file_size_raw(lfs_t *lfs, lfs_file_t *file);
|
||||||
|
int lfs_mkdir_raw(lfs_t *lfs, const char *path);
|
||||||
|
int lfs_dir_open_raw(lfs_t *lfs, lfs_dir_t *dir, const char *path);
|
||||||
|
int lfs_dir_close_raw(lfs_t *lfs, lfs_dir_t *dir);
|
||||||
|
int lfs_dir_read_raw(lfs_t *lfs, lfs_dir_t *dir, struct lfs_info *info);
|
||||||
|
int lfs_dir_seek_raw(lfs_t *lfs, lfs_dir_t *dir, lfs_off_t off);
|
||||||
|
lfs_soff_t lfs_dir_tell_raw(lfs_t *lfs, lfs_dir_t *dir);
|
||||||
|
int lfs_dir_rewind_raw(lfs_t *lfs, lfs_dir_t *dir);
|
||||||
|
lfs_ssize_t lfs_fs_size_raw(lfs_t *lfs);
|
||||||
|
int lfs_fs_traverse_raw(lfs_t *lfs, int (*cb)(void*, lfs_block_t), void *data);
|
||||||
int lfs_migrate_raw(lfs_t *lfs, const struct lfs_config *cfg);
|
int lfs_migrate_raw(lfs_t *lfs, const struct lfs_config *cfg);
|
||||||
#endif
|
|
||||||
|
|
||||||
#if LFS_THREAD_SAFE
|
|
||||||
|
|
||||||
int lfs_format_ts(lfs_t *lfs, const struct lfs_config *config);
|
|
||||||
int lfs_mount_ts(lfs_t *lfs, const struct lfs_config *config);
|
|
||||||
int lfs_unmount_ts(lfs_t *lfs);
|
|
||||||
int lfs_remove_ts(lfs_t *lfs, const char *path);
|
|
||||||
int lfs_rename_ts(lfs_t *lfs, const char *oldpath, const char *newpath);
|
|
||||||
int lfs_stat_ts(lfs_t *lfs, const char *path, struct lfs_info *info);
|
|
||||||
lfs_ssize_t lfs_getattr_ts(lfs_t *lfs, const char *path, uint8_t type, void *buffer, lfs_size_t size);
|
|
||||||
int lfs_setattr_ts(lfs_t *lfs, const char *path, uint8_t type, const void *buffer, lfs_size_t size);
|
|
||||||
int lfs_removeattr_ts(lfs_t *lfs, const char *path, uint8_t type);
|
|
||||||
int lfs_file_open_ts(lfs_t *lfs, lfs_file_t *file, const char *path, int flags);
|
|
||||||
int lfs_file_opencfg_ts(lfs_t *lfs, lfs_file_t *file, const char *path, int flags, const struct lfs_file_config *config);
|
|
||||||
int lfs_file_close_ts(lfs_t *lfs, lfs_file_t *file);
|
|
||||||
int lfs_file_sync_ts(lfs_t *lfs, lfs_file_t *file);
|
|
||||||
lfs_ssize_t lfs_file_read_ts(lfs_t *lfs, lfs_file_t *file, void *buffer, lfs_size_t size);
|
|
||||||
lfs_ssize_t lfs_file_write_ts(lfs_t *lfs, lfs_file_t *file, const void *buffer, lfs_size_t size);
|
|
||||||
lfs_soff_t lfs_file_seek_ts(lfs_t *lfs, lfs_file_t *file, lfs_soff_t off, int whence);
|
|
||||||
int lfs_file_truncate_ts(lfs_t *lfs, lfs_file_t *file, lfs_off_t size);
|
|
||||||
lfs_soff_t lfs_file_tell_ts(lfs_t *lfs, lfs_file_t *file);
|
|
||||||
int lfs_file_rewind_ts(lfs_t *lfs, lfs_file_t *file);
|
|
||||||
lfs_soff_t lfs_file_size_ts(lfs_t *lfs, lfs_file_t *file);
|
|
||||||
int lfs_mkdir_ts(lfs_t *lfs, const char *path);
|
|
||||||
int lfs_dir_open_ts(lfs_t *lfs, lfs_dir_t *dir, const char *path);
|
|
||||||
int lfs_dir_close_ts(lfs_t *lfs, lfs_dir_t *dir);
|
|
||||||
int lfs_dir_read_ts(lfs_t *lfs, lfs_dir_t *dir, struct lfs_info *info);
|
|
||||||
int lfs_dir_seek_ts(lfs_t *lfs, lfs_dir_t *dir, lfs_off_t off);
|
|
||||||
lfs_soff_t lfs_dir_tell_ts(lfs_t *lfs, lfs_dir_t *dir);
|
|
||||||
int lfs_dir_rewind_ts(lfs_t *lfs, lfs_dir_t *dir);
|
|
||||||
lfs_ssize_t lfs_fs_size_ts(lfs_t *lfs);
|
|
||||||
int lfs_fs_traverse_ts(lfs_t *lfs, int (*cb)(void*, lfs_block_t), void *data);
|
|
||||||
int lfs_migrate_ts(lfs_t *lfs, const struct lfs_config *cfg);
|
|
||||||
|
|
||||||
#define lfs_format lfs_format_ts
|
|
||||||
#define lfs_mount lfs_mount_ts
|
|
||||||
#define lfs_unmount lfs_unmount_ts
|
|
||||||
#define lfs_remove lfs_remove_ts
|
|
||||||
#define lfs_rename lfs_rename_ts
|
|
||||||
#define lfs_stat lfs_stat_ts
|
|
||||||
#define lfs_getattr lfs_getattr_ts
|
|
||||||
#define lfs_setattr lfs_setattr_ts
|
|
||||||
#define lfs_removeattr lfs_removeattr_ts
|
|
||||||
#define lfs_file_open lfs_file_open_ts
|
|
||||||
#define lfs_file_opencfg lfs_file_opencfg_ts
|
|
||||||
#define lfs_file_close lfs_file_close_ts
|
|
||||||
#define lfs_file_sync lfs_file_sync_ts
|
|
||||||
#define lfs_file_read lfs_file_read_ts
|
|
||||||
#define lfs_file_write lfs_file_write_ts
|
|
||||||
#define lfs_file_seek lfs_file_seek_ts
|
|
||||||
#define lfs_file_truncate lfs_file_truncate_ts
|
|
||||||
#define lfs_file_tell lfs_file_tell_ts
|
|
||||||
#define lfs_file_rewind lfs_file_rewind_ts
|
|
||||||
#define lfs_file_size lfs_file_size_ts
|
|
||||||
#define lfs_mkdir lfs_mkdir_ts
|
|
||||||
#define lfs_dir_open lfs_dir_open_ts
|
|
||||||
#define lfs_dir_close lfs_dir_close_ts
|
|
||||||
#define lfs_dir_read lfs_dir_read_ts
|
|
||||||
#define lfs_dir_seek lfs_dir_seek_ts
|
|
||||||
#define lfs_dir_tell lfs_dir_tell_ts
|
|
||||||
#define lfs_dir_rewind lfs_dir_rewind_ts
|
|
||||||
#define lfs_fs_size lfs_fs_size_ts
|
|
||||||
#define lfs_fs_traverse lfs_fs_traverse_ts
|
|
||||||
#define lfs_migrate lfs_migrate_ts
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
#define lfs_format lfs_format_raw
|
|
||||||
#define lfs_mount lfs_mount_raw
|
|
||||||
#define lfs_unmount lfs_unmount_raw
|
|
||||||
#define lfs_remove lfs_remove_raw
|
|
||||||
#define lfs_rename lfs_rename_raw
|
|
||||||
#define lfs_stat lfs_stat_raw
|
|
||||||
#define lfs_getattr lfs_getattr_raw
|
|
||||||
#define lfs_setattr lfs_setattr_raw
|
|
||||||
#define lfs_removeattr lfs_removeattr_raw
|
|
||||||
#define lfs_file_open lfs_file_open_raw
|
|
||||||
#define lfs_file_opencfg lfs_file_opencfg_raw
|
|
||||||
#define lfs_file_close lfs_file_close_raw
|
|
||||||
#define lfs_file_sync lfs_file_sync_raw
|
|
||||||
#define lfs_file_read lfs_file_read_raw
|
|
||||||
#define lfs_file_write lfs_file_write_raw
|
|
||||||
#define lfs_file_seek lfs_file_seek_raw
|
|
||||||
#define lfs_file_truncate lfs_file_truncate_raw
|
|
||||||
#define lfs_file_tell lfs_file_tell_raw
|
|
||||||
#define lfs_file_rewind lfs_file_rewind_raw
|
|
||||||
#define lfs_file_size lfs_file_size_raw
|
|
||||||
#define lfs_mkdir lfs_mkdir_raw
|
|
||||||
#define lfs_dir_open lfs_dir_open_raw
|
|
||||||
#define lfs_dir_close lfs_dir_close_raw
|
|
||||||
#define lfs_dir_read lfs_dir_read_raw
|
|
||||||
#define lfs_dir_seek lfs_dir_seek_raw
|
|
||||||
#define lfs_dir_tell lfs_dir_tell_raw
|
|
||||||
#define lfs_dir_rewind lfs_dir_rewind_raw
|
|
||||||
#define lfs_fs_size lfs_fs_size_raw
|
|
||||||
#define lfs_fs_traverse lfs_fs_traverse_raw
|
|
||||||
#define lfs_migrate lfs_migrate_raw
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
} /* extern "C" */
|
} /* extern "C" */
|
||||||
|
|||||||
@@ -44,8 +44,8 @@ extern "C"
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Enables thread-safe wrappers using the lock/unlock callbacks in lfs_config
|
// Enables thread-safe wrappers using the lock/unlock callbacks in lfs_config
|
||||||
#ifndef LFS_THREAD_SAFE
|
#ifndef LFS_THREADSAFE
|
||||||
#define LFS_THREAD_SAFE 0
|
#define LFS_THREADSAFE 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Macros, may be replaced by system specific wrappers. Arguments to these
|
// Macros, may be replaced by system specific wrappers. Arguments to these
|
||||||
|
|||||||
Reference in New Issue
Block a user