mirror of
				https://github.com/eledio-devices/thirdparty-littlefs.git
				synced 2025-10-31 00:32:38 +01:00 
			
		
		
		
	Merge pull request #237 from Ar2rL/reverse_finalize_close
Protect (LFS_ASSERT) file operations against using not opened or closed files.
This commit is contained in:
		
							
								
								
									
										31
									
								
								lfs.c
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								lfs.c
									
									
									
									
									
								
							| @@ -2237,6 +2237,9 @@ static int lfs_ctz_traverse(lfs_t *lfs, | |||||||
| 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 char *path, int flags, | ||||||
|         const struct lfs_file_config *cfg) { |         const struct lfs_file_config *cfg) { | ||||||
|  |     // do not allow open for already opened file | ||||||
|  |     LFS_ASSERT(0 == (file->flags & LFS_F_OPENED)); | ||||||
|  |  | ||||||
|     // deorphan if we haven't yet, needed at most once after poweron |     // deorphan if we haven't yet, needed at most once after poweron | ||||||
|     if ((flags & 3) != LFS_O_RDONLY) { |     if ((flags & 3) != LFS_O_RDONLY) { | ||||||
|         int err = lfs_fs_forceconsistency(lfs); |         int err = lfs_fs_forceconsistency(lfs); | ||||||
| @@ -2248,7 +2251,7 @@ int lfs_file_opencfg(lfs_t *lfs, lfs_file_t *file, | |||||||
|     // setup simple file details |     // setup simple file details | ||||||
|     int err; |     int err; | ||||||
|     file->cfg = cfg; |     file->cfg = cfg; | ||||||
|     file->flags = flags; |     file->flags = flags | LFS_F_OPENED; | ||||||
|     file->pos = 0; |     file->pos = 0; | ||||||
|     file->cache.buffer = NULL; |     file->cache.buffer = NULL; | ||||||
|  |  | ||||||
| @@ -2386,6 +2389,8 @@ int lfs_file_open(lfs_t *lfs, lfs_file_t *file, | |||||||
| } | } | ||||||
|  |  | ||||||
| int lfs_file_close(lfs_t *lfs, lfs_file_t *file) { | int lfs_file_close(lfs_t *lfs, lfs_file_t *file) { | ||||||
|  |     LFS_ASSERT(file->flags & LFS_F_OPENED); | ||||||
|  |  | ||||||
|     int err = lfs_file_sync(lfs, file); |     int err = lfs_file_sync(lfs, file); | ||||||
|  |  | ||||||
|     // remove from list of mdirs |     // remove from list of mdirs | ||||||
| @@ -2401,10 +2406,14 @@ int lfs_file_close(lfs_t *lfs, lfs_file_t *file) { | |||||||
|         lfs_free(file->cache.buffer); |         lfs_free(file->cache.buffer); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     file->flags &= ~LFS_F_OPENED; | ||||||
|  |  | ||||||
|     return err; |     return err; | ||||||
| } | } | ||||||
|  |  | ||||||
| static int lfs_file_relocate(lfs_t *lfs, lfs_file_t *file) { | static int lfs_file_relocate(lfs_t *lfs, lfs_file_t *file) { | ||||||
|  |     LFS_ASSERT(file->flags & LFS_F_OPENED); | ||||||
|  |  | ||||||
|     while (true) { |     while (true) { | ||||||
|         // just relocate what exists into new block |         // just relocate what exists into new block | ||||||
|         lfs_block_t nblock; |         lfs_block_t nblock; | ||||||
| @@ -2475,6 +2484,8 @@ relocate: | |||||||
| } | } | ||||||
|  |  | ||||||
| static int lfs_file_flush(lfs_t *lfs, lfs_file_t *file) { | static int lfs_file_flush(lfs_t *lfs, lfs_file_t *file) { | ||||||
|  |     LFS_ASSERT(file->flags & LFS_F_OPENED); | ||||||
|  |  | ||||||
|     if (file->flags & LFS_F_READING) { |     if (file->flags & LFS_F_READING) { | ||||||
|         if (!(file->flags & LFS_F_INLINE)) { |         if (!(file->flags & LFS_F_INLINE)) { | ||||||
|             lfs_cache_drop(lfs, &file->cache); |             lfs_cache_drop(lfs, &file->cache); | ||||||
| @@ -2490,7 +2501,7 @@ static int lfs_file_flush(lfs_t *lfs, lfs_file_t *file) { | |||||||
|             lfs_file_t orig = { |             lfs_file_t orig = { | ||||||
|                 .ctz.head = file->ctz.head, |                 .ctz.head = file->ctz.head, | ||||||
|                 .ctz.size = file->ctz.size, |                 .ctz.size = file->ctz.size, | ||||||
|                 .flags = LFS_O_RDONLY, |                 .flags = LFS_O_RDONLY | LFS_F_OPENED, | ||||||
|                 .pos = file->pos, |                 .pos = file->pos, | ||||||
|                 .cache = lfs->rcache, |                 .cache = lfs->rcache, | ||||||
|             }; |             }; | ||||||
| @@ -2553,6 +2564,8 @@ relocate: | |||||||
| } | } | ||||||
|  |  | ||||||
| int lfs_file_sync(lfs_t *lfs, lfs_file_t *file) { | int lfs_file_sync(lfs_t *lfs, lfs_file_t *file) { | ||||||
|  |     LFS_ASSERT(file->flags & LFS_F_OPENED); | ||||||
|  |  | ||||||
|     while (true) { |     while (true) { | ||||||
|         int err = lfs_file_flush(lfs, file); |         int err = lfs_file_flush(lfs, file); | ||||||
|         if (err) { |         if (err) { | ||||||
| @@ -2617,6 +2630,8 @@ lfs_ssize_t lfs_file_read(lfs_t *lfs, lfs_file_t *file, | |||||||
|     uint8_t *data = buffer; |     uint8_t *data = buffer; | ||||||
|     lfs_size_t nsize = size; |     lfs_size_t nsize = size; | ||||||
|  |  | ||||||
|  |     LFS_ASSERT(file->flags & LFS_F_OPENED); | ||||||
|  |  | ||||||
|     if ((file->flags & 3) == LFS_O_WRONLY) { |     if ((file->flags & 3) == LFS_O_WRONLY) { | ||||||
|         return LFS_ERR_BADF; |         return LFS_ERR_BADF; | ||||||
|     } |     } | ||||||
| @@ -2690,6 +2705,8 @@ lfs_ssize_t lfs_file_write(lfs_t *lfs, lfs_file_t *file, | |||||||
|     const uint8_t *data = buffer; |     const uint8_t *data = buffer; | ||||||
|     lfs_size_t nsize = size; |     lfs_size_t nsize = size; | ||||||
|  |  | ||||||
|  |     LFS_ASSERT(file->flags & LFS_F_OPENED); | ||||||
|  |  | ||||||
|     if ((file->flags & 3) == LFS_O_RDONLY) { |     if ((file->flags & 3) == LFS_O_RDONLY) { | ||||||
|         return LFS_ERR_BADF; |         return LFS_ERR_BADF; | ||||||
|     } |     } | ||||||
| @@ -2810,6 +2827,8 @@ relocate: | |||||||
|  |  | ||||||
| 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) { |         lfs_soff_t off, int whence) { | ||||||
|  |     LFS_ASSERT(file->flags & LFS_F_OPENED); | ||||||
|  |  | ||||||
|     // write out everything beforehand, may be noop if rdonly |     // write out everything beforehand, may be noop if rdonly | ||||||
|     int err = lfs_file_flush(lfs, file); |     int err = lfs_file_flush(lfs, file); | ||||||
|     if (err) { |     if (err) { | ||||||
| @@ -2837,6 +2856,8 @@ lfs_soff_t lfs_file_seek(lfs_t *lfs, lfs_file_t *file, | |||||||
| } | } | ||||||
|  |  | ||||||
| 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) { | ||||||
|  |     LFS_ASSERT(file->flags & LFS_F_OPENED); | ||||||
|  |  | ||||||
|     if ((file->flags & 3) == LFS_O_RDONLY) { |     if ((file->flags & 3) == LFS_O_RDONLY) { | ||||||
|         return LFS_ERR_BADF; |         return LFS_ERR_BADF; | ||||||
|     } |     } | ||||||
| @@ -2895,6 +2916,7 @@ int lfs_file_truncate(lfs_t *lfs, lfs_file_t *file, lfs_off_t size) { | |||||||
|  |  | ||||||
| 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) { | ||||||
|     (void)lfs; |     (void)lfs; | ||||||
|  |     LFS_ASSERT(file->flags & LFS_F_OPENED); | ||||||
|     return file->pos; |     return file->pos; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -2909,6 +2931,7 @@ int lfs_file_rewind(lfs_t *lfs, lfs_file_t *file) { | |||||||
|  |  | ||||||
| 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) { | ||||||
|     (void)lfs; |     (void)lfs; | ||||||
|  |     LFS_ASSERT(file->flags & LFS_F_OPENED); | ||||||
|     if (file->flags & LFS_F_WRITING) { |     if (file->flags & LFS_F_WRITING) { | ||||||
|         return lfs_max(file->pos, file->ctz.size); |         return lfs_max(file->pos, file->ctz.size); | ||||||
|     } else { |     } else { | ||||||
| @@ -3313,7 +3336,7 @@ int lfs_format(lfs_t *lfs, const struct lfs_config *cfg) { | |||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         lfs_superblock_tole32(&superblock); |         lfs_superblock_tole32(&superblock); | ||||||
|         err = lfs_dir_commit(lfs, &root, LFS_MKATTRS(  |         err = lfs_dir_commit(lfs, &root, LFS_MKATTRS( | ||||||
|                 {LFS_MKTAG(LFS_TYPE_CREATE, 0, 0), NULL}, |                 {LFS_MKTAG(LFS_TYPE_CREATE, 0, 0), NULL}, | ||||||
|                 {LFS_MKTAG(LFS_TYPE_SUPERBLOCK, 0, 8), "littlefs"}, |                 {LFS_MKTAG(LFS_TYPE_SUPERBLOCK, 0, 8), "littlefs"}, | ||||||
|                 {LFS_MKTAG(LFS_TYPE_INLINESTRUCT, 0, sizeof(superblock)), |                 {LFS_MKTAG(LFS_TYPE_INLINESTRUCT, 0, sizeof(superblock)), | ||||||
| @@ -4300,7 +4323,7 @@ int lfs_migrate(lfs_t *lfs, const struct lfs_config *cfg) { | |||||||
|  |  | ||||||
|                     entry1.d.type &= ~0x80; |                     entry1.d.type &= ~0x80; | ||||||
|                 } |                 } | ||||||
|                  |  | ||||||
|                 // also fetch name |                 // also fetch name | ||||||
|                 char name[LFS_NAME_MAX+1]; |                 char name[LFS_NAME_MAX+1]; | ||||||
|                 memset(name, 0, sizeof(name)); |                 memset(name, 0, sizeof(name)); | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								lfs.h
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								lfs.h
									
									
									
									
									
								
							| @@ -136,6 +136,7 @@ enum lfs_open_flags { | |||||||
|     LFS_F_READING = 0x040000, // File has been read since last flush |     LFS_F_READING = 0x040000, // File has been read since last flush | ||||||
|     LFS_F_ERRED   = 0x080000, // An error occured during write |     LFS_F_ERRED   = 0x080000, // An error occured during write | ||||||
|     LFS_F_INLINE  = 0x100000, // Currently inlined in directory entry |     LFS_F_INLINE  = 0x100000, // Currently inlined in directory entry | ||||||
|  |     LFS_F_OPENED  = 0x200000, // File has been opened | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // File seek flags | // File seek flags | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user