]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/blob - fs/Kconfig
Merge branch 'overlayfs-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mszer...
[mirror_ubuntu-jammy-kernel.git] / fs / Kconfig
1 #
2 # File system configuration
3 #
4
5 menu "File systems"
6
7 # Use unaligned word dcache accesses
8 config DCACHE_WORD_ACCESS
9 bool
10
11 if BLOCK
12
13 config FS_IOMAP
14 bool
15
16 source "fs/ext2/Kconfig"
17 source "fs/ext4/Kconfig"
18 source "fs/jbd2/Kconfig"
19
20 config FS_MBCACHE
21 # Meta block cache for Extended Attributes (ext2/ext3/ext4)
22 tristate
23 default y if EXT2_FS=y && EXT2_FS_XATTR
24 default y if EXT4_FS=y
25 default m if EXT2_FS_XATTR || EXT4_FS
26
27 source "fs/reiserfs/Kconfig"
28 source "fs/jfs/Kconfig"
29
30 source "fs/xfs/Kconfig"
31 source "fs/gfs2/Kconfig"
32 source "fs/ocfs2/Kconfig"
33 source "fs/btrfs/Kconfig"
34 source "fs/nilfs2/Kconfig"
35 source "fs/f2fs/Kconfig"
36
37 config FS_DAX
38 bool "Direct Access (DAX) support"
39 depends on MMU
40 depends on !(ARM || MIPS || SPARC)
41 select FS_IOMAP
42 select DAX
43 help
44 Direct Access (DAX) can be used on memory-backed block devices.
45 If the block device supports DAX and the filesystem supports DAX,
46 then you can avoid using the pagecache to buffer I/Os. Turning
47 on this option will compile in support for DAX; you will need to
48 mount the filesystem using the -o dax option.
49
50 If you do not have a block device that is capable of using this,
51 or if unsure, say N. Saying Y will increase the size of the kernel
52 by about 5kB.
53
54 config FS_DAX_PMD
55 bool
56 default FS_DAX
57 depends on FS_DAX
58 depends on ZONE_DEVICE
59 depends on TRANSPARENT_HUGEPAGE
60
61 endif # BLOCK
62
63 # Posix ACL utility routines
64 #
65 # Note: Posix ACLs can be implemented without these helpers. Never use
66 # this symbol for ifdefs in core code.
67 #
68 config FS_POSIX_ACL
69 def_bool n
70
71 config EXPORTFS
72 tristate
73
74 config EXPORTFS_BLOCK_OPS
75 bool "Enable filesystem export operations for block IO"
76 help
77 This option enables the export operations for a filesystem to support
78 external block IO.
79
80 config FILE_LOCKING
81 bool "Enable POSIX file locking API" if EXPERT
82 default y
83 help
84 This option enables standard file locking support, required
85 for filesystems like NFS and for the flock() system
86 call. Disabling this option saves about 11k.
87
88 config MANDATORY_FILE_LOCKING
89 bool "Enable Mandatory file locking"
90 depends on FILE_LOCKING
91 default y
92 help
93 This option enables files appropriately marked files on appropriely
94 mounted filesystems to support mandatory locking.
95
96 To the best of my knowledge this is dead code that no one cares about.
97
98 source "fs/crypto/Kconfig"
99
100 source "fs/notify/Kconfig"
101
102 source "fs/quota/Kconfig"
103
104 source "fs/autofs4/Kconfig"
105 source "fs/fuse/Kconfig"
106 source "fs/overlayfs/Kconfig"
107
108 menu "Caches"
109
110 source "fs/fscache/Kconfig"
111 source "fs/cachefiles/Kconfig"
112
113 endmenu
114
115 if BLOCK
116 menu "CD-ROM/DVD Filesystems"
117
118 source "fs/isofs/Kconfig"
119 source "fs/udf/Kconfig"
120
121 endmenu
122 endif # BLOCK
123
124 if BLOCK
125 menu "DOS/FAT/NT Filesystems"
126
127 source "fs/fat/Kconfig"
128 source "fs/ntfs/Kconfig"
129
130 endmenu
131 endif # BLOCK
132
133 menu "Pseudo filesystems"
134
135 source "fs/proc/Kconfig"
136 source "fs/kernfs/Kconfig"
137 source "fs/sysfs/Kconfig"
138
139 config TMPFS
140 bool "Tmpfs virtual memory file system support (former shm fs)"
141 depends on SHMEM
142 help
143 Tmpfs is a file system which keeps all files in virtual memory.
144
145 Everything in tmpfs is temporary in the sense that no files will be
146 created on your hard drive. The files live in memory and swap
147 space. If you unmount a tmpfs instance, everything stored therein is
148 lost.
149
150 See <file:Documentation/filesystems/tmpfs.txt> for details.
151
152 config TMPFS_POSIX_ACL
153 bool "Tmpfs POSIX Access Control Lists"
154 depends on TMPFS
155 select TMPFS_XATTR
156 select FS_POSIX_ACL
157 help
158 POSIX Access Control Lists (ACLs) support additional access rights
159 for users and groups beyond the standard owner/group/world scheme,
160 and this option selects support for ACLs specifically for tmpfs
161 filesystems.
162
163 If you've selected TMPFS, it's possible that you'll also need
164 this option as there are a number of Linux distros that require
165 POSIX ACL support under /dev for certain features to work properly.
166 For example, some distros need this feature for ALSA-related /dev
167 files for sound to work properly. In short, if you're not sure,
168 say Y.
169
170 config TMPFS_XATTR
171 bool "Tmpfs extended attributes"
172 depends on TMPFS
173 default n
174 help
175 Extended attributes are name:value pairs associated with inodes by
176 the kernel or by users (see the attr(5) manual page for details).
177
178 Currently this enables support for the trusted.* and
179 security.* namespaces.
180
181 You need this for POSIX ACL support on tmpfs.
182
183 If unsure, say N.
184
185 config HUGETLBFS
186 bool "HugeTLB file system support"
187 depends on X86 || IA64 || SPARC64 || (S390 && 64BIT) || \
188 SYS_SUPPORTS_HUGETLBFS || BROKEN
189 help
190 hugetlbfs is a filesystem backing for HugeTLB pages, based on
191 ramfs. For architectures that support it, say Y here and read
192 <file:Documentation/vm/hugetlbpage.txt> for details.
193
194 If unsure, say N.
195
196 config HUGETLB_PAGE
197 def_bool HUGETLBFS
198
199 config ARCH_HAS_GIGANTIC_PAGE
200 bool
201
202 source "fs/configfs/Kconfig"
203 source "fs/efivarfs/Kconfig"
204
205 endmenu
206
207 menuconfig MISC_FILESYSTEMS
208 bool "Miscellaneous filesystems"
209 default y
210 ---help---
211 Say Y here to get to see options for various miscellaneous
212 filesystems, such as filesystems that came from other
213 operating systems.
214
215 This option alone does not add any kernel code.
216
217 If you say N, all options in this submenu will be skipped and
218 disabled; if unsure, say Y here.
219
220 if MISC_FILESYSTEMS
221
222 source "fs/orangefs/Kconfig"
223 source "fs/adfs/Kconfig"
224 source "fs/affs/Kconfig"
225 source "fs/ecryptfs/Kconfig"
226 source "fs/hfs/Kconfig"
227 source "fs/hfsplus/Kconfig"
228 source "fs/befs/Kconfig"
229 source "fs/bfs/Kconfig"
230 source "fs/efs/Kconfig"
231 source "fs/jffs2/Kconfig"
232 # UBIFS File system configuration
233 source "fs/ubifs/Kconfig"
234 source "fs/cramfs/Kconfig"
235 source "fs/squashfs/Kconfig"
236 source "fs/freevxfs/Kconfig"
237 source "fs/minix/Kconfig"
238 source "fs/omfs/Kconfig"
239 source "fs/hpfs/Kconfig"
240 source "fs/qnx4/Kconfig"
241 source "fs/qnx6/Kconfig"
242 source "fs/romfs/Kconfig"
243 source "fs/pstore/Kconfig"
244 source "fs/sysv/Kconfig"
245 source "fs/ufs/Kconfig"
246 source "fs/exofs/Kconfig"
247
248 endif # MISC_FILESYSTEMS
249
250 source "fs/exofs/Kconfig.ore"
251
252 menuconfig NETWORK_FILESYSTEMS
253 bool "Network File Systems"
254 default y
255 depends on NET
256 ---help---
257 Say Y here to get to see options for network filesystems and
258 filesystem-related networking code, such as NFS daemon and
259 RPCSEC security modules.
260
261 This option alone does not add any kernel code.
262
263 If you say N, all options in this submenu will be skipped and
264 disabled; if unsure, say Y here.
265
266 if NETWORK_FILESYSTEMS
267
268 source "fs/nfs/Kconfig"
269 source "fs/nfsd/Kconfig"
270
271 config GRACE_PERIOD
272 tristate
273
274 config LOCKD
275 tristate
276 depends on FILE_LOCKING
277 select GRACE_PERIOD
278
279 config LOCKD_V4
280 bool
281 depends on NFSD_V3 || NFS_V3
282 depends on FILE_LOCKING
283 default y
284
285 config NFS_ACL_SUPPORT
286 tristate
287 select FS_POSIX_ACL
288
289 config NFS_COMMON
290 bool
291 depends on NFSD || NFS_FS || LOCKD
292 default y
293
294 source "net/sunrpc/Kconfig"
295 source "fs/ceph/Kconfig"
296 source "fs/cifs/Kconfig"
297 source "fs/coda/Kconfig"
298 source "fs/afs/Kconfig"
299 source "fs/9p/Kconfig"
300
301 endif # NETWORK_FILESYSTEMS
302
303 source "fs/nls/Kconfig"
304 source "fs/dlm/Kconfig"
305
306 endmenu