Merge branch 'for-4.16/nfit' into libnvdimm-for-next
[linux-2.6-microblaze.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 # Selected by DAX drivers that do not expect filesystem DAX to support
62 # get_user_pages() of DAX mappings. I.e. "limited" indicates no support
63 # for fork() of processes with MAP_SHARED mappings or support for
64 # direct-I/O to a DAX mapping.
65 config FS_DAX_LIMITED
66         bool
67
68 endif # BLOCK
69
70 # Posix ACL utility routines
71 #
72 # Note: Posix ACLs can be implemented without these helpers.  Never use
73 # this symbol for ifdefs in core code.
74 #
75 config FS_POSIX_ACL
76         def_bool n
77
78 config EXPORTFS
79         tristate
80
81 config EXPORTFS_BLOCK_OPS
82         bool "Enable filesystem export operations for block IO"
83         help
84           This option enables the export operations for a filesystem to support
85           external block IO.
86
87 config FILE_LOCKING
88         bool "Enable POSIX file locking API" if EXPERT
89         default y
90         help
91           This option enables standard file locking support, required
92           for filesystems like NFS and for the flock() system
93           call. Disabling this option saves about 11k.
94
95 config MANDATORY_FILE_LOCKING
96         bool "Enable Mandatory file locking"
97         depends on FILE_LOCKING
98         default y
99         help
100           This option enables files appropriately marked files on appropriely
101           mounted filesystems to support mandatory locking.
102
103           To the best of my knowledge this is dead code that no one cares about.
104
105 source "fs/crypto/Kconfig"
106
107 source "fs/notify/Kconfig"
108
109 source "fs/quota/Kconfig"
110
111 source "fs/autofs4/Kconfig"
112 source "fs/fuse/Kconfig"
113 source "fs/overlayfs/Kconfig"
114
115 menu "Caches"
116
117 source "fs/fscache/Kconfig"
118 source "fs/cachefiles/Kconfig"
119
120 endmenu
121
122 if BLOCK
123 menu "CD-ROM/DVD Filesystems"
124
125 source "fs/isofs/Kconfig"
126 source "fs/udf/Kconfig"
127
128 endmenu
129 endif # BLOCK
130
131 if BLOCK
132 menu "DOS/FAT/NT Filesystems"
133
134 source "fs/fat/Kconfig"
135 source "fs/ntfs/Kconfig"
136
137 endmenu
138 endif # BLOCK
139
140 menu "Pseudo filesystems"
141
142 source "fs/proc/Kconfig"
143 source "fs/kernfs/Kconfig"
144 source "fs/sysfs/Kconfig"
145
146 config TMPFS
147         bool "Tmpfs virtual memory file system support (former shm fs)"
148         depends on SHMEM
149         help
150           Tmpfs is a file system which keeps all files in virtual memory.
151
152           Everything in tmpfs is temporary in the sense that no files will be
153           created on your hard drive. The files live in memory and swap
154           space. If you unmount a tmpfs instance, everything stored therein is
155           lost.
156
157           See <file:Documentation/filesystems/tmpfs.txt> for details.
158
159 config TMPFS_POSIX_ACL
160         bool "Tmpfs POSIX Access Control Lists"
161         depends on TMPFS
162         select TMPFS_XATTR
163         select FS_POSIX_ACL
164         help
165           POSIX Access Control Lists (ACLs) support additional access rights
166           for users and groups beyond the standard owner/group/world scheme,
167           and this option selects support for ACLs specifically for tmpfs
168           filesystems.
169
170           If you've selected TMPFS, it's possible that you'll also need
171           this option as there are a number of Linux distros that require
172           POSIX ACL support under /dev for certain features to work properly.
173           For example, some distros need this feature for ALSA-related /dev
174           files for sound to work properly.  In short, if you're not sure,
175           say Y.
176
177           To learn more about Access Control Lists, visit the POSIX ACLs for
178           Linux website <http://acl.bestbits.at/>.
179
180 config TMPFS_XATTR
181         bool "Tmpfs extended attributes"
182         depends on TMPFS
183         default n
184         help
185           Extended attributes are name:value pairs associated with inodes by
186           the kernel or by users (see the attr(5) manual page, or visit
187           <http://acl.bestbits.at/> for details).
188
189           Currently this enables support for the trusted.* and
190           security.* namespaces.
191
192           You need this for POSIX ACL support on tmpfs.
193
194           If unsure, say N.
195
196 config HUGETLBFS
197         bool "HugeTLB file system support"
198         depends on X86 || IA64 || SPARC64 || (S390 && 64BIT) || \
199                    SYS_SUPPORTS_HUGETLBFS || BROKEN
200         help
201           hugetlbfs is a filesystem backing for HugeTLB pages, based on
202           ramfs. For architectures that support it, say Y here and read
203           <file:Documentation/vm/hugetlbpage.txt> for details.
204
205           If unsure, say N.
206
207 config HUGETLB_PAGE
208         def_bool HUGETLBFS
209
210 config ARCH_HAS_GIGANTIC_PAGE
211         bool
212
213 source "fs/configfs/Kconfig"
214 source "fs/efivarfs/Kconfig"
215
216 endmenu
217
218 menuconfig MISC_FILESYSTEMS
219         bool "Miscellaneous filesystems"
220         default y
221         ---help---
222           Say Y here to get to see options for various miscellaneous
223           filesystems, such as filesystems that came from other
224           operating systems.
225
226           This option alone does not add any kernel code.
227
228           If you say N, all options in this submenu will be skipped and
229           disabled; if unsure, say Y here.
230
231 if MISC_FILESYSTEMS
232
233 source "fs/orangefs/Kconfig"
234 source "fs/adfs/Kconfig"
235 source "fs/affs/Kconfig"
236 source "fs/ecryptfs/Kconfig"
237 source "fs/hfs/Kconfig"
238 source "fs/hfsplus/Kconfig"
239 source "fs/befs/Kconfig"
240 source "fs/bfs/Kconfig"
241 source "fs/efs/Kconfig"
242 source "fs/jffs2/Kconfig"
243 # UBIFS File system configuration
244 source "fs/ubifs/Kconfig"
245 source "fs/cramfs/Kconfig"
246 source "fs/squashfs/Kconfig"
247 source "fs/freevxfs/Kconfig"
248 source "fs/minix/Kconfig"
249 source "fs/omfs/Kconfig"
250 source "fs/hpfs/Kconfig"
251 source "fs/qnx4/Kconfig"
252 source "fs/qnx6/Kconfig"
253 source "fs/romfs/Kconfig"
254 source "fs/pstore/Kconfig"
255 source "fs/sysv/Kconfig"
256 source "fs/ufs/Kconfig"
257 source "fs/exofs/Kconfig"
258
259 endif # MISC_FILESYSTEMS
260
261 source "fs/exofs/Kconfig.ore"
262
263 menuconfig NETWORK_FILESYSTEMS
264         bool "Network File Systems"
265         default y
266         depends on NET
267         ---help---
268           Say Y here to get to see options for network filesystems and
269           filesystem-related networking code, such as NFS daemon and
270           RPCSEC security modules.
271
272           This option alone does not add any kernel code.
273
274           If you say N, all options in this submenu will be skipped and
275           disabled; if unsure, say Y here.
276
277 if NETWORK_FILESYSTEMS
278
279 source "fs/nfs/Kconfig"
280 source "fs/nfsd/Kconfig"
281
282 config GRACE_PERIOD
283         tristate
284
285 config LOCKD
286         tristate
287         depends on FILE_LOCKING
288         select GRACE_PERIOD
289
290 config LOCKD_V4
291         bool
292         depends on NFSD_V3 || NFS_V3
293         depends on FILE_LOCKING
294         default y
295
296 config NFS_ACL_SUPPORT
297         tristate
298         select FS_POSIX_ACL
299
300 config NFS_COMMON
301         bool
302         depends on NFSD || NFS_FS || LOCKD
303         default y
304
305 source "net/sunrpc/Kconfig"
306 source "fs/ceph/Kconfig"
307 source "fs/cifs/Kconfig"
308 source "fs/ncpfs/Kconfig"
309 source "fs/coda/Kconfig"
310 source "fs/afs/Kconfig"
311 source "fs/9p/Kconfig"
312
313 endif # NETWORK_FILESYSTEMS
314
315 source "fs/nls/Kconfig"
316 source "fs/dlm/Kconfig"
317
318 endmenu