]>
Commit | Line | Data |
---|---|---|
ec8f24b7 | 1 | # SPDX-License-Identifier: GPL-2.0-only |
1da177e4 LT |
2 | # |
3 | # File system configuration | |
4 | # | |
5 | ||
6 | menu "File systems" | |
7 | ||
bfcfaa77 LT |
8 | # Use unaligned word dcache accesses |
9 | config DCACHE_WORD_ACCESS | |
10 | bool | |
11 | ||
31d921c7 DH |
12 | config VALIDATE_FS_PARSER |
13 | bool "Validate filesystem parameter description" | |
31d921c7 DH |
14 | help |
15 | Enable this to perform validation of the parameter description for a | |
16 | filesystem when it is registered. | |
17 | ||
9361401e DH |
18 | if BLOCK |
19 | ||
ae259a9c CH |
20 | config FS_IOMAP |
21 | bool | |
22 | ||
6da0b38f | 23 | source "fs/ext2/Kconfig" |
6da0b38f | 24 | source "fs/ext4/Kconfig" |
6da0b38f | 25 | source "fs/jbd2/Kconfig" |
dab291af | 26 | |
1da177e4 | 27 | config FS_MBCACHE |
02ea2104 | 28 | # Meta block cache for Extended Attributes (ext2/ext3/ext4) |
1da177e4 | 29 | tristate |
2c512397 | 30 | default y if EXT2_FS=y && EXT2_FS_XATTR |
939da108 | 31 | default y if EXT4_FS=y |
c290ea01 | 32 | default m if EXT2_FS_XATTR || EXT4_FS |
1da177e4 | 33 | |
b16ecfe2 | 34 | source "fs/reiserfs/Kconfig" |
f5c77969 | 35 | source "fs/jfs/Kconfig" |
1da177e4 | 36 | |
69050eee TS |
37 | source "fs/xfs/Kconfig" |
38 | source "fs/gfs2/Kconfig" | |
39 | source "fs/ocfs2/Kconfig" | |
40 | source "fs/btrfs/Kconfig" | |
41f4db0f | 41 | source "fs/nilfs2/Kconfig" |
d7196c5a | 42 | source "fs/f2fs/Kconfig" |
8dcc1a9d | 43 | source "fs/zonefs/Kconfig" |
69050eee | 44 | |
6cd176a5 MW |
45 | config FS_DAX |
46 | bool "Direct Access (DAX) support" | |
47 | depends on MMU | |
d92576f1 | 48 | depends on !(ARM || MIPS || SPARC) |
e7638488 | 49 | select DEV_PAGEMAP_OPS if (ZONE_DEVICE && !FS_DAX_LIMITED) |
6affb9d7 | 50 | select FS_IOMAP |
ef510424 | 51 | select DAX |
6cd176a5 MW |
52 | help |
53 | Direct Access (DAX) can be used on memory-backed block devices. | |
54 | If the block device supports DAX and the filesystem supports DAX, | |
55 | then you can avoid using the pagecache to buffer I/Os. Turning | |
56 | on this option will compile in support for DAX; you will need to | |
57 | mount the filesystem using the -o dax option. | |
58 | ||
59 | If you do not have a block device that is capable of using this, | |
60 | or if unsure, say N. Saying Y will increase the size of the kernel | |
61 | by about 5kB. | |
62 | ||
ee82c9ed DW |
63 | config FS_DAX_PMD |
64 | bool | |
65 | default FS_DAX | |
66 | depends on FS_DAX | |
c046c321 DW |
67 | depends on ZONE_DEVICE |
68 | depends on TRANSPARENT_HUGEPAGE | |
ee82c9ed | 69 | |
569d0365 DW |
70 | # Selected by DAX drivers that do not expect filesystem DAX to support |
71 | # get_user_pages() of DAX mappings. I.e. "limited" indicates no support | |
72 | # for fork() of processes with MAP_SHARED mappings or support for | |
73 | # direct-I/O to a DAX mapping. | |
74 | config FS_DAX_LIMITED | |
75 | bool | |
76 | ||
69050eee TS |
77 | endif # BLOCK |
78 | ||
16ebe911 RD |
79 | # Posix ACL utility routines |
80 | # | |
81 | # Note: Posix ACLs can be implemented without these helpers. Never use | |
82 | # this symbol for ifdefs in core code. | |
83 | # | |
84 | config FS_POSIX_ACL | |
85 | def_bool n | |
86 | ||
4199ca77 | 87 | config EXPORTFS |
79fead47 | 88 | tristate |
4199ca77 | 89 | |
15d66ac2 BC |
90 | config EXPORTFS_BLOCK_OPS |
91 | bool "Enable filesystem export operations for block IO" | |
92 | help | |
93 | This option enables the export operations for a filesystem to support | |
94 | external block IO. | |
95 | ||
bfcd17a6 | 96 | config FILE_LOCKING |
6a108a14 | 97 | bool "Enable POSIX file locking API" if EXPERT |
bfcd17a6 TP |
98 | default y |
99 | help | |
100 | This option enables standard file locking support, required | |
101 | for filesystems like NFS and for the flock() system | |
102 | call. Disabling this option saves about 11k. | |
103 | ||
9e8925b6 JL |
104 | config MANDATORY_FILE_LOCKING |
105 | bool "Enable Mandatory file locking" | |
106 | depends on FILE_LOCKING | |
107 | default y | |
108 | help | |
109 | This option enables files appropriately marked files on appropriely | |
110 | mounted filesystems to support mandatory locking. | |
111 | ||
112 | To the best of my knowledge this is dead code that no one cares about. | |
113 | ||
0b81d077 JK |
114 | source "fs/crypto/Kconfig" |
115 | ||
671e67b4 EB |
116 | source "fs/verity/Kconfig" |
117 | ||
272eb014 | 118 | source "fs/notify/Kconfig" |
0eeca283 | 119 | |
884d179d | 120 | source "fs/quota/Kconfig" |
1da177e4 | 121 | |
2a3ae0a1 | 122 | source "fs/autofs/Kconfig" |
3ef7784e | 123 | source "fs/fuse/Kconfig" |
e9be9d5e | 124 | source "fs/overlayfs/Kconfig" |
04578f17 | 125 | |
06b3db1b DH |
126 | menu "Caches" |
127 | ||
128 | source "fs/fscache/Kconfig" | |
9ae326a6 | 129 | source "fs/cachefiles/Kconfig" |
06b3db1b DH |
130 | |
131 | endmenu | |
132 | ||
9361401e | 133 | if BLOCK |
1da177e4 LT |
134 | menu "CD-ROM/DVD Filesystems" |
135 | ||
ddfaccd9 AD |
136 | source "fs/isofs/Kconfig" |
137 | source "fs/udf/Kconfig" | |
1da177e4 LT |
138 | |
139 | endmenu | |
25fad945 | 140 | endif # BLOCK |
1da177e4 | 141 | |
9361401e | 142 | if BLOCK |
b9d1e2e6 | 143 | menu "DOS/FAT/EXFAT/NT Filesystems" |
1da177e4 | 144 | |
1c6ace01 | 145 | source "fs/fat/Kconfig" |
b9d1e2e6 | 146 | source "fs/exfat/Kconfig" |
9d73ac9e | 147 | source "fs/ntfs/Kconfig" |
1da177e4 LT |
148 | |
149 | endmenu | |
25fad945 | 150 | endif # BLOCK |
1da177e4 LT |
151 | |
152 | menu "Pseudo filesystems" | |
153 | ||
6eedf8d3 | 154 | source "fs/proc/Kconfig" |
ba341d55 | 155 | source "fs/kernfs/Kconfig" |
5f3a211a | 156 | source "fs/sysfs/Kconfig" |
1da177e4 | 157 | |
1da177e4 | 158 | config TMPFS |
f5fc870d | 159 | bool "Tmpfs virtual memory file system support (former shm fs)" |
3f96b79a | 160 | depends on SHMEM |
1da177e4 LT |
161 | help |
162 | Tmpfs is a file system which keeps all files in virtual memory. | |
163 | ||
164 | Everything in tmpfs is temporary in the sense that no files will be | |
165 | created on your hard drive. The files live in memory and swap | |
166 | space. If you unmount a tmpfs instance, everything stored therein is | |
167 | lost. | |
168 | ||
0c1bc6b8 | 169 | See <file:Documentation/filesystems/tmpfs.rst> for details. |
1da177e4 | 170 | |
4db70f73 EP |
171 | config TMPFS_POSIX_ACL |
172 | bool "Tmpfs POSIX Access Control Lists" | |
173 | depends on TMPFS | |
174 | select TMPFS_XATTR | |
feda821e | 175 | select FS_POSIX_ACL |
4db70f73 | 176 | help |
206506cc RD |
177 | POSIX Access Control Lists (ACLs) support additional access rights |
178 | for users and groups beyond the standard owner/group/world scheme, | |
179 | and this option selects support for ACLs specifically for tmpfs | |
180 | filesystems. | |
181 | ||
182 | If you've selected TMPFS, it's possible that you'll also need | |
183 | this option as there are a number of Linux distros that require | |
184 | POSIX ACL support under /dev for certain features to work properly. | |
185 | For example, some distros need this feature for ALSA-related /dev | |
186 | files for sound to work properly. In short, if you're not sure, | |
187 | say Y. | |
4db70f73 | 188 | |
b09e0fa4 EP |
189 | config TMPFS_XATTR |
190 | bool "Tmpfs extended attributes" | |
191 | depends on TMPFS | |
192 | default n | |
193 | help | |
194 | Extended attributes are name:value pairs associated with inodes by | |
91581e4c | 195 | the kernel or by users (see the attr(5) manual page for details). |
b09e0fa4 EP |
196 | |
197 | Currently this enables support for the trusted.* and | |
198 | security.* namespaces. | |
199 | ||
b09e0fa4 EP |
200 | You need this for POSIX ACL support on tmpfs. |
201 | ||
4db70f73 | 202 | If unsure, say N. |
39f0247d | 203 | |
ea3271f7 CD |
204 | config TMPFS_INODE64 |
205 | bool "Use 64-bit ino_t by default in tmpfs" | |
206 | depends on TMPFS && 64BIT | |
207 | default n | |
208 | help | |
209 | tmpfs has historically used only inode numbers as wide as an unsigned | |
210 | int. In some cases this can cause wraparound, potentially resulting | |
211 | in multiple files with the same inode number on a single device. This | |
212 | option makes tmpfs use the full width of ino_t by default, without | |
213 | needing to specify the inode64 option when mounting. | |
214 | ||
215 | But if a long-lived tmpfs is to be accessed by 32-bit applications so | |
216 | ancient that opening a file larger than 2GiB fails with EINVAL, then | |
217 | the INODE64 config option and inode64 mount option risk operations | |
218 | failing with EOVERFLOW once 33-bit inode numbers are reached. | |
219 | ||
220 | To override this configured default, use the inode32 or inode64 | |
221 | option when mounting. | |
222 | ||
223 | If unsure, say N. | |
224 | ||
1da177e4 LT |
225 | config HUGETLBFS |
226 | bool "HugeTLB file system support" | |
5a1eb5c4 | 227 | depends on X86 || IA64 || SPARC64 || (S390 && 64BIT) || \ |
ffb4a73d | 228 | SYS_SUPPORTS_HUGETLBFS || BROKEN |
dda27d1a AO |
229 | help |
230 | hugetlbfs is a filesystem backing for HugeTLB pages, based on | |
231 | ramfs. For architectures that support it, say Y here and read | |
1ad1335d | 232 | <file:Documentation/admin-guide/mm/hugetlbpage.rst> for details. |
dda27d1a AO |
233 | |
234 | If unsure, say N. | |
1da177e4 LT |
235 | |
236 | config HUGETLB_PAGE | |
237 | def_bool HUGETLBFS | |
238 | ||
5d752600 MK |
239 | config MEMFD_CREATE |
240 | def_bool TMPFS || HUGETLBFS | |
241 | ||
461a7184 YX |
242 | config ARCH_HAS_GIGANTIC_PAGE |
243 | bool | |
244 | ||
4591dabe | 245 | source "fs/configfs/Kconfig" |
62c204dd | 246 | source "fs/efivarfs/Kconfig" |
7063fbf2 | 247 | |
1da177e4 LT |
248 | endmenu |
249 | ||
67ec7d3a RD |
250 | menuconfig MISC_FILESYSTEMS |
251 | bool "Miscellaneous filesystems" | |
252 | default y | |
a7f7f624 | 253 | help |
67ec7d3a RD |
254 | Say Y here to get to see options for various miscellaneous |
255 | filesystems, such as filesystems that came from other | |
256 | operating systems. | |
257 | ||
258 | This option alone does not add any kernel code. | |
259 | ||
260 | If you say N, all options in this submenu will be skipped and | |
261 | disabled; if unsure, say Y here. | |
262 | ||
263 | if MISC_FILESYSTEMS | |
1da177e4 | 264 | |
07f01962 | 265 | source "fs/orangefs/Kconfig" |
bc2de2ae | 266 | source "fs/adfs/Kconfig" |
10951bf0 | 267 | source "fs/affs/Kconfig" |
295c896c | 268 | source "fs/ecryptfs/Kconfig" |
b08bac1f AD |
269 | source "fs/hfs/Kconfig" |
270 | source "fs/hfsplus/Kconfig" | |
0b09eb32 | 271 | source "fs/befs/Kconfig" |
0ff42384 | 272 | source "fs/bfs/Kconfig" |
571f0a0b | 273 | source "fs/efs/Kconfig" |
31db6e9e | 274 | source "fs/jffs2/Kconfig" |
0d7eff87 AB |
275 | # UBIFS File system configuration |
276 | source "fs/ubifs/Kconfig" | |
2a22783b | 277 | source "fs/cramfs/Kconfig" |
22635ec9 | 278 | source "fs/squashfs/Kconfig" |
22135169 | 279 | source "fs/freevxfs/Kconfig" |
8b1cd7d3 | 280 | source "fs/minix/Kconfig" |
da55e6f9 | 281 | source "fs/omfs/Kconfig" |
928ea192 | 282 | source "fs/hpfs/Kconfig" |
4c741583 | 283 | source "fs/qnx4/Kconfig" |
5d026c72 | 284 | source "fs/qnx6/Kconfig" |
41810246 | 285 | source "fs/romfs/Kconfig" |
ca01d6dd | 286 | source "fs/pstore/Kconfig" |
8af915ba | 287 | source "fs/sysv/Kconfig" |
a276a52f | 288 | source "fs/ufs/Kconfig" |
47e4937a | 289 | source "fs/erofs/Kconfig" |
0fd16957 | 290 | source "fs/vboxsf/Kconfig" |
0c4fb877 | 291 | |
67ec7d3a | 292 | endif # MISC_FILESYSTEMS |
1da177e4 | 293 | |
ea0985ad JE |
294 | menuconfig NETWORK_FILESYSTEMS |
295 | bool "Network File Systems" | |
296 | default y | |
1da177e4 | 297 | depends on NET |
a7f7f624 | 298 | help |
ea0985ad JE |
299 | Say Y here to get to see options for network filesystems and |
300 | filesystem-related networking code, such as NFS daemon and | |
301 | RPCSEC security modules. | |
6fb1bc10 | 302 | |
ea0985ad JE |
303 | This option alone does not add any kernel code. |
304 | ||
305 | If you say N, all options in this submenu will be skipped and | |
306 | disabled; if unsure, say Y here. | |
307 | ||
308 | if NETWORK_FILESYSTEMS | |
1da177e4 | 309 | |
97afe47a | 310 | source "fs/nfs/Kconfig" |
e2b329e2 | 311 | source "fs/nfsd/Kconfig" |
1da177e4 | 312 | |
f7790029 JL |
313 | config GRACE_PERIOD |
314 | tristate | |
315 | ||
1da177e4 LT |
316 | config LOCKD |
317 | tristate | |
dd4dc82d | 318 | depends on FILE_LOCKING |
f7790029 | 319 | select GRACE_PERIOD |
1da177e4 LT |
320 | |
321 | config LOCKD_V4 | |
322 | bool | |
323 | depends on NFSD_V3 || NFS_V3 | |
dd4dc82d | 324 | depends on FILE_LOCKING |
1da177e4 LT |
325 | default y |
326 | ||
a257cdd0 AG |
327 | config NFS_ACL_SUPPORT |
328 | tristate | |
329 | select FS_POSIX_ACL | |
330 | ||
331 | config NFS_COMMON | |
332 | bool | |
f7790029 | 333 | depends on NFSD || NFS_FS || LOCKD |
a257cdd0 AG |
334 | default y |
335 | ||
9098c24f | 336 | source "net/sunrpc/Kconfig" |
9030aaf9 | 337 | source "fs/ceph/Kconfig" |
bb26b963 | 338 | source "fs/cifs/Kconfig" |
33a1a6fe | 339 | source "fs/coda/Kconfig" |
b2480c7f | 340 | source "fs/afs/Kconfig" |
0fcb4408 | 341 | source "fs/9p/Kconfig" |
93fa58cb | 342 | |
ea0985ad | 343 | endif # NETWORK_FILESYSTEMS |
1da177e4 | 344 | |
1da177e4 | 345 | source "fs/nls/Kconfig" |
e7fd4179 | 346 | source "fs/dlm/Kconfig" |
955405d1 | 347 | source "fs/unicode/Kconfig" |
1da177e4 | 348 | |
771b53d0 JA |
349 | config IO_WQ |
350 | bool | |
351 | ||
1da177e4 | 352 | endmenu |