• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# SPDX-License-Identifier: GPL-2.0-only
2#
3# File system configuration
4#
5
6menu "File systems"
7
8# Use unaligned word dcache accesses
9config DCACHE_WORD_ACCESS
10       bool
11
12config VALIDATE_FS_PARSER
13	bool "Validate filesystem parameter description"
14	help
15	  Enable this to perform validation of the parameter description for a
16	  filesystem when it is registered.
17
18if BLOCK
19
20config FS_IOMAP
21	bool
22
23source "fs/ext2/Kconfig"
24source "fs/ext4/Kconfig"
25source "fs/jbd2/Kconfig"
26
27config FS_MBCACHE
28# Meta block cache for Extended Attributes (ext2/ext3/ext4)
29	tristate
30	default y if EXT2_FS=y && EXT2_FS_XATTR
31	default y if EXT4_FS=y
32	default m if EXT2_FS_XATTR || EXT4_FS
33
34source "fs/reiserfs/Kconfig"
35source "fs/jfs/Kconfig"
36
37source "fs/xfs/Kconfig"
38source "fs/gfs2/Kconfig"
39source "fs/ocfs2/Kconfig"
40source "fs/btrfs/Kconfig"
41source "fs/nilfs2/Kconfig"
42source "fs/f2fs/Kconfig"
43source "fs/zonefs/Kconfig"
44
45config FS_DAX
46	bool "File system based Direct Access (DAX) support"
47	depends on MMU
48	depends on !(ARM || MIPS || SPARC)
49	select DEV_PAGEMAP_OPS if (ZONE_DEVICE && !FS_DAX_LIMITED)
50	select FS_IOMAP
51	select DAX
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.
57
58	  For a DAX device to support file system access it needs to have
59	  struct pages.  For the nfit based NVDIMMs this can be enabled
60	  using the ndctl utility:
61
62		# ndctl create-namespace --force --reconfig=namespace0.0 \
63			--mode=fsdax --map=mem
64
65	  See the 'create-namespace' man page for details on the overhead of
66	  --map=mem:
67	  https://docs.pmem.io/ndctl-user-guide/ndctl-man-pages/ndctl-create-namespace
68
69          For ndctl to work CONFIG_DEV_DAX needs to be enabled as well. For most
70	  file systems DAX support needs to be manually enabled globally or
71	  per-inode using a mount option as well.  See the file documentation in
72	  Documentation/filesystems/dax.rst for details.
73
74	  If you do not have a block device that is capable of using this,
75	  or if unsure, say N.  Saying Y will increase the size of the kernel
76	  by about 5kB.
77
78config FS_DAX_PMD
79	bool
80	default FS_DAX
81	depends on FS_DAX
82	depends on ZONE_DEVICE
83	depends on TRANSPARENT_HUGEPAGE
84
85# Selected by DAX drivers that do not expect filesystem DAX to support
86# get_user_pages() of DAX mappings. I.e. "limited" indicates no support
87# for fork() of processes with MAP_SHARED mappings or support for
88# direct-I/O to a DAX mapping.
89config FS_DAX_LIMITED
90	bool
91
92endif # BLOCK
93
94# Posix ACL utility routines
95#
96# Note: Posix ACLs can be implemented without these helpers.  Never use
97# this symbol for ifdefs in core code.
98#
99config FS_POSIX_ACL
100	def_bool n
101
102config EXPORTFS
103	tristate
104
105config EXPORTFS_BLOCK_OPS
106	bool "Enable filesystem export operations for block IO"
107	help
108	  This option enables the export operations for a filesystem to support
109	  external block IO.
110
111config FILE_LOCKING
112	bool "Enable POSIX file locking API" if EXPERT
113	default y
114	help
115	  This option enables standard file locking support, required
116          for filesystems like NFS and for the flock() system
117          call. Disabling this option saves about 11k.
118
119source "fs/crypto/Kconfig"
120
121source "fs/verity/Kconfig"
122
123source "fs/notify/Kconfig"
124
125source "fs/quota/Kconfig"
126
127source "fs/autofs/Kconfig"
128source "fs/fuse/Kconfig"
129source "fs/overlayfs/Kconfig"
130source "fs/incfs/Kconfig"
131
132menu "Caches"
133
134source "fs/netfs/Kconfig"
135source "fs/fscache/Kconfig"
136source "fs/cachefiles/Kconfig"
137
138endmenu
139
140if BLOCK
141menu "CD-ROM/DVD Filesystems"
142
143source "fs/isofs/Kconfig"
144source "fs/udf/Kconfig"
145
146endmenu
147endif # BLOCK
148
149if BLOCK
150menu "DOS/FAT/EXFAT/NT Filesystems"
151
152source "fs/fat/Kconfig"
153source "fs/exfat/Kconfig"
154source "fs/ntfs/Kconfig"
155source "fs/ntfs3/Kconfig"
156
157endmenu
158endif # BLOCK
159
160menu "Pseudo filesystems"
161
162source "fs/proc/Kconfig"
163source "fs/kernfs/Kconfig"
164source "fs/sysfs/Kconfig"
165
166config TMPFS
167	bool "Tmpfs virtual memory file system support (former shm fs)"
168	depends on SHMEM
169	help
170	  Tmpfs is a file system which keeps all files in virtual memory.
171
172	  Everything in tmpfs is temporary in the sense that no files will be
173	  created on your hard drive. The files live in memory and swap
174	  space. If you unmount a tmpfs instance, everything stored therein is
175	  lost.
176
177	  See <file:Documentation/filesystems/tmpfs.rst> for details.
178
179config TMPFS_POSIX_ACL
180	bool "Tmpfs POSIX Access Control Lists"
181	depends on TMPFS
182	select TMPFS_XATTR
183	select FS_POSIX_ACL
184	help
185	  POSIX Access Control Lists (ACLs) support additional access rights
186	  for users and groups beyond the standard owner/group/world scheme,
187	  and this option selects support for ACLs specifically for tmpfs
188	  filesystems.
189
190	  If you've selected TMPFS, it's possible that you'll also need
191	  this option as there are a number of Linux distros that require
192	  POSIX ACL support under /dev for certain features to work properly.
193	  For example, some distros need this feature for ALSA-related /dev
194	  files for sound to work properly.  In short, if you're not sure,
195	  say Y.
196
197config TMPFS_XATTR
198	bool "Tmpfs extended attributes"
199	depends on TMPFS
200	default n
201	help
202	  Extended attributes are name:value pairs associated with inodes by
203	  the kernel or by users (see the attr(5) manual page for details).
204
205	  Currently this enables support for the trusted.* and
206	  security.* namespaces.
207
208	  You need this for POSIX ACL support on tmpfs.
209
210	  If unsure, say N.
211
212config TMPFS_INODE64
213	bool "Use 64-bit ino_t by default in tmpfs"
214	depends on TMPFS && 64BIT
215	default n
216	help
217	  tmpfs has historically used only inode numbers as wide as an unsigned
218	  int. In some cases this can cause wraparound, potentially resulting
219	  in multiple files with the same inode number on a single device. This
220	  option makes tmpfs use the full width of ino_t by default, without
221	  needing to specify the inode64 option when mounting.
222
223	  But if a long-lived tmpfs is to be accessed by 32-bit applications so
224	  ancient that opening a file larger than 2GiB fails with EINVAL, then
225	  the INODE64 config option and inode64 mount option risk operations
226	  failing with EOVERFLOW once 33-bit inode numbers are reached.
227
228	  To override this configured default, use the inode32 or inode64
229	  option when mounting.
230
231	  If unsure, say N.
232
233config ARCH_SUPPORTS_HUGETLBFS
234	def_bool n
235
236config HUGETLBFS
237	bool "HugeTLB file system support"
238	depends on X86 || IA64 || SPARC64 || ARCH_SUPPORTS_HUGETLBFS || BROKEN
239	help
240	  hugetlbfs is a filesystem backing for HugeTLB pages, based on
241	  ramfs. For architectures that support it, say Y here and read
242	  <file:Documentation/admin-guide/mm/hugetlbpage.rst> for details.
243
244	  If unsure, say N.
245
246config HUGETLB_PAGE
247	def_bool HUGETLBFS
248
249config HUGETLB_PAGE_FREE_VMEMMAP
250	def_bool HUGETLB_PAGE
251	depends on X86_64
252	depends on SPARSEMEM_VMEMMAP
253
254config HUGETLB_PAGE_FREE_VMEMMAP_DEFAULT_ON
255	bool "Default freeing vmemmap pages of HugeTLB to on"
256	default n
257	depends on HUGETLB_PAGE_FREE_VMEMMAP
258	help
259	  When using HUGETLB_PAGE_FREE_VMEMMAP, the freeing unused vmemmap
260	  pages associated with each HugeTLB page is default off. Say Y here
261	  to enable freeing vmemmap pages of HugeTLB by default. It can then
262	  be disabled on the command line via hugetlb_free_vmemmap=off.
263
264config MEMFD_CREATE
265	def_bool TMPFS || HUGETLBFS
266
267config ARCH_HAS_GIGANTIC_PAGE
268	bool
269
270source "fs/configfs/Kconfig"
271source "fs/efivarfs/Kconfig"
272
273endmenu
274
275menuconfig MISC_FILESYSTEMS
276	bool "Miscellaneous filesystems"
277	default y
278	help
279	  Say Y here to get to see options for various miscellaneous
280	  filesystems, such as filesystems that came from other
281	  operating systems.
282
283	  This option alone does not add any kernel code.
284
285	  If you say N, all options in this submenu will be skipped and
286	  disabled; if unsure, say Y here.
287
288if MISC_FILESYSTEMS
289
290source "fs/orangefs/Kconfig"
291source "fs/adfs/Kconfig"
292source "fs/affs/Kconfig"
293source "fs/ecryptfs/Kconfig"
294source "fs/hfs/Kconfig"
295source "fs/hfsplus/Kconfig"
296source "fs/befs/Kconfig"
297source "fs/bfs/Kconfig"
298source "fs/efs/Kconfig"
299source "fs/jffs2/Kconfig"
300# UBIFS File system configuration
301source "fs/ubifs/Kconfig"
302source "fs/cramfs/Kconfig"
303source "fs/squashfs/Kconfig"
304source "fs/freevxfs/Kconfig"
305source "fs/minix/Kconfig"
306source "fs/omfs/Kconfig"
307source "fs/hpfs/Kconfig"
308source "fs/qnx4/Kconfig"
309source "fs/qnx6/Kconfig"
310source "fs/romfs/Kconfig"
311source "fs/pstore/Kconfig"
312source "fs/sysv/Kconfig"
313source "fs/ufs/Kconfig"
314source "fs/erofs/Kconfig"
315source "fs/vboxsf/Kconfig"
316
317endif # MISC_FILESYSTEMS
318
319menuconfig NETWORK_FILESYSTEMS
320	bool "Network File Systems"
321	default y
322	depends on NET
323	help
324	  Say Y here to get to see options for network filesystems and
325	  filesystem-related networking code, such as NFS daemon and
326	  RPCSEC security modules.
327
328	  This option alone does not add any kernel code.
329
330	  If you say N, all options in this submenu will be skipped and
331	  disabled; if unsure, say Y here.
332
333if NETWORK_FILESYSTEMS
334
335source "fs/nfs/Kconfig"
336source "fs/nfsd/Kconfig"
337
338config GRACE_PERIOD
339	tristate
340
341config LOCKD
342	tristate
343	depends on FILE_LOCKING
344	select GRACE_PERIOD
345
346config LOCKD_V4
347	bool
348	depends on NFSD_V3 || NFS_V3
349	depends on FILE_LOCKING
350	default y
351
352config NFS_ACL_SUPPORT
353	tristate
354	select FS_POSIX_ACL
355
356config NFS_COMMON
357	bool
358	depends on NFSD || NFS_FS || LOCKD
359	default y
360
361config NFS_V4_2_SSC_HELPER
362	bool
363	default y if NFS_V4_2
364
365source "net/sunrpc/Kconfig"
366source "fs/ceph/Kconfig"
367
368source "fs/cifs/Kconfig"
369source "fs/ksmbd/Kconfig"
370
371config SMBFS_COMMON
372	tristate
373	default y if CIFS=y || SMB_SERVER=y
374	default m if CIFS=m || SMB_SERVER=m
375
376source "fs/coda/Kconfig"
377source "fs/afs/Kconfig"
378source "fs/9p/Kconfig"
379
380endif # NETWORK_FILESYSTEMS
381
382source "fs/nls/Kconfig"
383source "fs/dlm/Kconfig"
384source "fs/unicode/Kconfig"
385
386config IO_WQ
387	bool
388
389endmenu
390