mirror of
				https://github.com/eledio-devices/thirdparty-littlefs.git
				synced 2025-10-31 08:42:40 +01:00 
			
		
		
		
	The primary data structure backing the little fs was planned to be a little ctz based skip-list for O(logn) lookup and O(1) append. Was initially planning to start with a simple linked list of index blocks, but was having trouble implementing the free-list on top of the structure. Went ahead and adopted the skip-list structure since it may have actually been easier.
		
			
				
	
	
		
			46 lines
		
	
	
		
			927 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			927 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Configuration and type definitions
 | |
|  *
 | |
|  * Copyright (c) 2017 Christopher Haster
 | |
|  * Distributed under the MIT license
 | |
|  */
 | |
| #ifndef LFS_CONFIG_H
 | |
| #define LFS_CONFIG_H
 | |
| 
 | |
| #include <stdint.h>
 | |
| 
 | |
| // Type definitions
 | |
| typedef uint64_t lfs_lword_t;
 | |
| typedef uint32_t lfs_word_t;
 | |
| typedef uint16_t lfs_hword_t;
 | |
| 
 | |
| typedef lfs_word_t lfs_size_t;
 | |
| typedef lfs_word_t lfs_off_t;
 | |
| typedef int lfs_error_t;
 | |
| 
 | |
| typedef lfs_lword_t lfs_lsize_t;
 | |
| typedef lfs_word_t  lfs_ino_t;
 | |
| typedef lfs_hword_t lfs_ioff_t;
 | |
| 
 | |
| // Maximum length of file name
 | |
| #define LFS_NAME_MAX 255
 | |
| 
 | |
| // Builtin functions
 | |
| static inline lfs_word_t lfs_max(lfs_word_t a, lfs_word_t b) {
 | |
|     return (a > b) ? a : b;
 | |
| }
 | |
| 
 | |
| static inline lfs_word_t lfs_min(lfs_word_t a, lfs_word_t b) {
 | |
|     return (a < b) ? a : b;
 | |
| }
 | |
| 
 | |
| static inline lfs_word_t lfs_ctz(lfs_word_t a) {
 | |
|     return __builtin_ctz(a);
 | |
| }
 | |
| 
 | |
| static inline lfs_word_t lfs_npw2(lfs_word_t a) {
 | |
|     return 32 - __builtin_clz(a-1);
 | |
| }
 | |
| 
 | |
| #endif
 |