1# Copyright (c) 2019 Bolt Innovation Management, LLC
2# Copyright (c) 2019 Peter Bigot Consulting, LLC
3# Copyright (c) 2020 Nordic Semiconductor ASA
4# SPDX-License-Identifier: Apache-2.0
5
6config FILE_SYSTEM_LITTLEFS
7	bool "LittleFS support"
8	depends on FILE_SYSTEM
9	depends on ZEPHYR_LITTLEFS_MODULE
10	help
11	  Enables LittleFS file system support.
12
13if FILE_SYSTEM_LITTLEFS
14
15menu "LittleFS Settings"
16	visible if FILE_SYSTEM_LITTLEFS
17
18config FS_LITTLEFS_NUM_FILES
19	int "Maximum number of opened files"
20	default 4
21	help
22	  This is a global maximum across all mounted littlefs filesystems.
23
24config FS_LITTLEFS_NUM_DIRS
25	int "Maximum number of opened directories"
26	default 4
27	help
28	  This is a global maximum across all mounted littlefs filesystems.
29
30config FS_LITTLEFS_READ_SIZE
31	int "Minimum size of a block read"
32	default 16
33	help
34	  All read operations will be a multiple of this value.
35
36config FS_LITTLEFS_PROG_SIZE
37	int "Minimum size of a block program"
38	default 16
39	help
40	  All program operations will be a multiple of this value.
41
42config FS_LITTLEFS_CACHE_SIZE
43	int "Size of block caches in bytes"
44	default 64
45	help
46	  Each cache buffers a portion of a block in RAM.  The littlefs
47	  needs a read cache, a program cache, and one additional cache
48	  per file. Larger caches can improve performance by storing
49	  more data and reducing the number of disk accesses. Must be a
50	  multiple of the read and program sizes of the underlying flash
51	  device, and a factor of the block size.
52
53config FS_LITTLEFS_LOOKAHEAD_SIZE
54	int "Size of lookahead buffer in bytes"
55	default 32
56	help
57	  A larger lookahead buffer increases the number of blocks found
58	  during an allocation pass. The lookahead buffer is stored as a
59	  compact bitmap, so each byte of RAM can track 8 blocks. Must
60	  be a multiple of 8.
61
62config FS_LITTLEFS_BLOCK_CYCLES
63	int "Number of erase cycles before moving data to another block"
64	default 512
65	help
66	  For dynamic wear leveling, the number of erase cycles before data
67	  is moved to another block.  Set to a non-positive value to
68	  disable leveling.
69
70endmenu
71
72config FS_LITTLEFS_FC_HEAP_SIZE
73	int "Enable flexible file cache sizes for littlefs"
74	default 0
75	help
76	  littlefs requires a per-file buffer to cache data.
77
78	  When applications customize littlefs configurations and support
79	  different cache sizes for different partitions this preallocation is
80	  inadequate as an application might require a small number of files
81	  using a large cache size and a larger number of files using a
82	  smaller cache size.  In that case application should provide a
83	  positive value for the heap size.  Be aware that there is a
84	  per-allocation overhead that affects how much usable space is
85	  present in the heap.
86
87	  If this option is set to a non-positive value the heap is sized to
88	  support up to FS_LITTLE_FS_NUM_FILES blocks of
89	  FS_LITTLEFS_CACHE_SIZE bytes.
90
91if FS_LITTLEFS_FC_HEAP_SIZE <= 0
92
93config FS_LITTLEFS_HEAP_PER_ALLOC_OVERHEAD_SIZE
94	int "Size of per-allocation overhead for littleFS heap in bytes"
95	default 32
96	help
97	  In case when total size of littleFS heap is automatically calculated
98	  we need to take into account overhead caused per block allocation.
99	  For the purpose of heap size calculation the size of each cache block
100	  will be increased by this value.
101	  NOTE: when your app fails to open pre-defined number of files, as set
102	  by FS_LITTLEFS_NUM_FILES, try to increase the value.
103
104endif # FS_LITTLEFS_FC_HEAP_SIZE <= 0
105
106config FS_LITTLEFS_FMP_DEV
107	bool "Support for littlefs on flash devices"
108	depends on FLASH_MAP
109	depends on FLASH_PAGE_LAYOUT || !FLASH_HAS_EXPLICIT_ERASE
110	default y
111	help
112	  Enable this option to provide support for littlefs on flash devices
113	  (using the flash_map API).
114
115config FS_LITTLEFS_BLK_DEV
116	bool "Support for littlefs on block devices"
117	help
118	  Enable this option to provide support for littlefs on the block
119	  devices (like for example SD card).
120
121config FS_LITTLEFS_DISK_VERSION
122	bool "Support for selecting littlefs disk version"
123	default y if $(dt_compat_any_has_prop,$(DT_COMPAT_ZEPHYR_FSTAB_LITTLEFS),disk-version)
124	help
125	  Enable this option to provide support for selecting littlefs disk version
126	  to maintain backward compatibility with existing littlefs
127	  with the same major disk version.
128
129endif # FILE_SYSTEM_LITTLEFS
130