| # SPDX-License-Identifier: GPL-2.0-only |
| # |
| # File system configuration |
| # |
| |
| menu "File systems" |
| |
| # Use unaligned word dcache accesses |
| config DCACHE_WORD_ACCESS |
| bool |
| |
| config VALIDATE_FS_PARSER |
| bool "Validate filesystem parameter description" |
| help |
| Enable this to perform validation of the parameter description for a |
| filesystem when it is registered. |
| |
| config FS_IOMAP |
| bool |
| |
| # Stackable filesystems |
| config FS_STACK |
| bool |
| |
| config BUFFER_HEAD |
| bool |
| |
| # old blockdev_direct_IO implementation. Use iomap for new code instead |
| config LEGACY_DIRECT_IO |
| depends on BUFFER_HEAD |
| bool |
| |
| if BLOCK |
| |
| source "fs/ext2/Kconfig" |
| source "fs/ext4/Kconfig" |
| source "fs/jbd2/Kconfig" |
| |
| config FS_MBCACHE |
| # Meta block cache for Extended Attributes (ext2/ext3/ext4) |
| tristate |
| default y if EXT2_FS=y && EXT2_FS_XATTR |
| default y if EXT4_FS=y |
| default m if EXT2_FS_XATTR || EXT4_FS |
| |
| source "fs/jfs/Kconfig" |
| |
| source "fs/xfs/Kconfig" |
| source "fs/gfs2/Kconfig" |
| source "fs/ocfs2/Kconfig" |
| source "fs/btrfs/Kconfig" |
| source "fs/nilfs2/Kconfig" |
| source "fs/f2fs/Kconfig" |
| source "fs/bcachefs/Kconfig" |
| source "fs/zonefs/Kconfig" |
| |
| endif # BLOCK |
| |
| config FS_DAX |
| bool "File system based Direct Access (DAX) support" |
| depends on MMU |
| depends on ZONE_DEVICE || FS_DAX_LIMITED |
| select FS_IOMAP |
| select DAX |
| help |
| Direct Access (DAX) can be used on memory-backed block devices. |
| If the block device supports DAX and the filesystem supports DAX, |
| then you can avoid using the pagecache to buffer I/Os. Turning |
| on this option will compile in support for DAX. |
| |
| For a DAX device to support file system access it needs to have |
| struct pages. For the nfit based NVDIMMs this can be enabled |
| using the ndctl utility: |
| |
| # ndctl create-namespace --force --reconfig=namespace0.0 \ |
| --mode=fsdax --map=mem |
| |
| See the 'create-namespace' man page for details on the overhead of |
| --map=mem: |
| https://docs.pmem.io/ndctl-user-guide/ndctl-man-pages/ndctl-create-namespace |
| |
| For ndctl to work CONFIG_DEV_DAX needs to be enabled as well. For most |
| file systems DAX support needs to be manually enabled globally or |
| per-inode using a mount option as well. See the file documentation in |
| Documentation/filesystems/dax.rst for details. |
| |
| If you do not have a block device that is capable of using this, |
| or if unsure, say N. Saying Y will increase the size of the kernel |
| by about 5kB. |
| |
| config FS_DAX_PMD |
| bool |
| default FS_DAX |
| depends on FS_DAX |
| depends on ZONE_DEVICE |
| depends on TRANSPARENT_HUGEPAGE |
| |
| # Selected by DAX drivers that do not expect filesystem DAX to support |
| # get_user_pages() of DAX mappings. I.e. "limited" indicates no support |
| # for fork() of processes with MAP_SHARED mappings or support for |
| # direct-I/O to a DAX mapping. |
| config FS_DAX_LIMITED |
| bool |
| |
| # Posix ACL utility routines |
| # |
| # Note: Posix ACLs can be implemented without these helpers. Never use |
| # this symbol for ifdefs in core code. |
| # |
| config FS_POSIX_ACL |
| def_bool n |
| |
| config EXPORTFS |
| tristate |
| |
| config EXPORTFS_BLOCK_OPS |
| bool "Enable filesystem export operations for block IO" |
| help |
| This option enables the export operations for a filesystem to support |
| external block IO. |
| |
| config FILE_LOCKING |
| bool "Enable POSIX file locking API" if EXPERT |
| default y |
| help |
| This option enables standard file locking support, required |
| for filesystems like NFS and for the flock() system |
| call. Disabling this option saves about 11k. |
| |
| source "fs/crypto/Kconfig" |
| |
| source "fs/verity/Kconfig" |
| |
| source "fs/notify/Kconfig" |
| |
| source "fs/quota/Kconfig" |
| |
| source "fs/autofs/Kconfig" |
| source "fs/fuse/Kconfig" |
| source "fs/overlayfs/Kconfig" |
| |
| menu "Caches" |
| |
| source "fs/netfs/Kconfig" |
| source "fs/cachefiles/Kconfig" |
| |
| endmenu |
| |
| if BLOCK |
| menu "CD-ROM/DVD Filesystems" |
| |
| source "fs/isofs/Kconfig" |
| source "fs/udf/Kconfig" |
| |
| endmenu |
| endif # BLOCK |
| |
| if BLOCK |
| menu "DOS/FAT/EXFAT/NT Filesystems" |
| |
| source "fs/fat/Kconfig" |
| source "fs/exfat/Kconfig" |
| source "fs/ntfs3/Kconfig" |
| |
| endmenu |
| endif # BLOCK |
| |
| menu "Pseudo filesystems" |
| |
| source "fs/proc/Kconfig" |
| source "fs/kernfs/Kconfig" |
| source "fs/sysfs/Kconfig" |
| |
| config TMPFS |
| bool "Tmpfs virtual memory file system support (former shm fs)" |
| depends on SHMEM |
| select MEMFD_CREATE |
| help |
| Tmpfs is a file system which keeps all files in virtual memory. |
| |
| Everything in tmpfs is temporary in the sense that no files will be |
| created on your hard drive. The files live in memory and swap |
| space. If you unmount a tmpfs instance, everything stored therein is |
| lost. |
| |
| See <file:Documentation/filesystems/tmpfs.rst> for details. |
| |
| config TMPFS_POSIX_ACL |
| bool "Tmpfs POSIX Access Control Lists" |
| depends on TMPFS |
| select TMPFS_XATTR |
| select FS_POSIX_ACL |
| help |
| POSIX Access Control Lists (ACLs) support additional access rights |
| for users and groups beyond the standard owner/group/world scheme, |
| and this option selects support for ACLs specifically for tmpfs |
| filesystems. |
| |
| If you've selected TMPFS, it's possible that you'll also need |
| this option as there are a number of Linux distros that require |
| POSIX ACL support under /dev for certain features to work properly. |
| For example, some distros need this feature for ALSA-related /dev |
| files for sound to work properly. In short, if you're not sure, |
| say Y. |
| |
| config TMPFS_XATTR |
| bool "Tmpfs extended attributes" |
| depends on TMPFS |
| default n |
| help |
| Extended attributes are name:value pairs associated with inodes by |
| the kernel or by users (see the attr(5) manual page for details). |
| |
| This enables support for the trusted.*, security.* and user.* |
| namespaces. |
| |
| You need this for POSIX ACL support on tmpfs. |
| |
| If unsure, say N. |
| |
| config TMPFS_INODE64 |
| bool "Use 64-bit ino_t by default in tmpfs" |
| depends on TMPFS && 64BIT |
| default n |
| help |
| tmpfs has historically used only inode numbers as wide as an unsigned |
| int. In some cases this can cause wraparound, potentially resulting |
| in multiple files with the same inode number on a single device. This |
| option makes tmpfs use the full width of ino_t by default, without |
| needing to specify the inode64 option when mounting. |
| |
| But if a long-lived tmpfs is to be accessed by 32-bit applications so |
| ancient that opening a file larger than 2GiB fails with EINVAL, then |
| the INODE64 config option and inode64 mount option risk operations |
| failing with EOVERFLOW once 33-bit inode numbers are reached. |
| |
| To override this configured default, use the inode32 or inode64 |
| option when mounting. |
| |
| If unsure, say N. |
| |
| config TMPFS_QUOTA |
| bool "Tmpfs quota support" |
| depends on TMPFS |
| select QUOTA |
| help |
| Quota support allows to set per user and group limits for tmpfs |
| usage. Say Y to enable quota support. Once enabled you can control |
| user and group quota enforcement with quota, usrquota and grpquota |
| mount options. |
| |
| If unsure, say N. |
| |
| config ARCH_SUPPORTS_HUGETLBFS |
| def_bool n |
| |
| menuconfig HUGETLBFS |
| bool "HugeTLB file system support" |
| depends on X86 || SPARC64 || ARCH_SUPPORTS_HUGETLBFS || BROKEN |
| depends on (SYSFS || SYSCTL) |
| select MEMFD_CREATE |
| select PADATA if SMP |
| help |
| hugetlbfs is a filesystem backing for HugeTLB pages, based on |
| ramfs. For architectures that support it, say Y here and read |
| <file:Documentation/admin-guide/mm/hugetlbpage.rst> for details. |
| |
| If unsure, say N. |
| |
| if HUGETLBFS |
| config HUGETLB_PAGE_OPTIMIZE_VMEMMAP_DEFAULT_ON |
| bool "HugeTLB Vmemmap Optimization (HVO) defaults to on" |
| default n |
| depends on HUGETLB_PAGE_OPTIMIZE_VMEMMAP |
| help |
| The HugeTLB Vmemmap Optimization (HVO) defaults to off. Say Y here to |
| enable HVO by default. It can be disabled via hugetlb_free_vmemmap=off |
| (boot command line) or hugetlb_optimize_vmemmap (sysctl). |
| endif # HUGETLBFS |
| |
| config HUGETLB_PAGE |
| def_bool HUGETLBFS |
| select XARRAY_MULTI |
| |
| config HUGETLB_PAGE_OPTIMIZE_VMEMMAP |
| def_bool HUGETLB_PAGE |
| depends on ARCH_WANT_OPTIMIZE_HUGETLB_VMEMMAP |
| depends on SPARSEMEM_VMEMMAP |
| |
| config HUGETLB_PMD_PAGE_TABLE_SHARING |
| def_bool HUGETLB_PAGE |
| depends on ARCH_WANT_HUGE_PMD_SHARE && SPLIT_PMD_PTLOCKS |
| |
| config ARCH_HAS_GIGANTIC_PAGE |
| bool |
| |
| source "fs/configfs/Kconfig" |
| source "fs/efivarfs/Kconfig" |
| |
| endmenu |
| |
| menuconfig MISC_FILESYSTEMS |
| bool "Miscellaneous filesystems" |
| default y |
| help |
| Say Y here to get to see options for various miscellaneous |
| filesystems, such as filesystems that came from other |
| operating systems. |
| |
| This option alone does not add any kernel code. |
| |
| If you say N, all options in this submenu will be skipped and |
| disabled; if unsure, say Y here. |
| |
| if MISC_FILESYSTEMS |
| |
| source "fs/orangefs/Kconfig" |
| source "fs/adfs/Kconfig" |
| source "fs/affs/Kconfig" |
| source "fs/ecryptfs/Kconfig" |
| source "fs/hfs/Kconfig" |
| source "fs/hfsplus/Kconfig" |
| source "fs/befs/Kconfig" |
| source "fs/bfs/Kconfig" |
| source "fs/efs/Kconfig" |
| source "fs/jffs2/Kconfig" |
| # UBIFS File system configuration |
| source "fs/ubifs/Kconfig" |
| source "fs/cramfs/Kconfig" |
| source "fs/squashfs/Kconfig" |
| source "fs/freevxfs/Kconfig" |
| source "fs/minix/Kconfig" |
| source "fs/omfs/Kconfig" |
| source "fs/hpfs/Kconfig" |
| source "fs/qnx4/Kconfig" |
| source "fs/qnx6/Kconfig" |
| source "fs/romfs/Kconfig" |
| source "fs/pstore/Kconfig" |
| source "fs/sysv/Kconfig" |
| source "fs/ufs/Kconfig" |
| source "fs/erofs/Kconfig" |
| source "fs/vboxsf/Kconfig" |
| |
| endif # MISC_FILESYSTEMS |
| |
| menuconfig NETWORK_FILESYSTEMS |
| bool "Network File Systems" |
| default y |
| depends on NET |
| help |
| Say Y here to get to see options for network filesystems and |
| filesystem-related networking code, such as NFS daemon and |
| RPCSEC security modules. |
| |
| This option alone does not add any kernel code. |
| |
| If you say N, all options in this submenu will be skipped and |
| disabled; if unsure, say Y here. |
| |
| if NETWORK_FILESYSTEMS |
| |
| source "fs/nfs/Kconfig" |
| source "fs/nfsd/Kconfig" |
| |
| config GRACE_PERIOD |
| tristate |
| |
| config LOCKD |
| tristate |
| depends on FILE_LOCKING |
| select GRACE_PERIOD |
| |
| config LOCKD_V4 |
| bool |
| depends on NFSD || NFS_V3 |
| depends on FILE_LOCKING |
| default y |
| |
| config NFS_ACL_SUPPORT |
| tristate |
| select FS_POSIX_ACL |
| |
| config NFS_COMMON |
| bool |
| depends on NFSD || NFS_FS || LOCKD |
| default y |
| |
| config NFS_COMMON_LOCALIO_SUPPORT |
| tristate |
| depends on NFS_LOCALIO |
| default y if NFSD=y || NFS_FS=y |
| default m if NFSD=m && NFS_FS=m |
| select SUNRPC |
| |
| config NFS_LOCALIO |
| bool "NFS client and server support for LOCALIO auxiliary protocol" |
| depends on NFSD && NFS_FS |
| select NFS_COMMON_LOCALIO_SUPPORT |
| default n |
| help |
| Some NFS servers support an auxiliary NFS LOCALIO protocol |
| that is not an official part of the NFS protocol. |
| |
| This option enables support for the LOCALIO protocol in the |
| kernel's NFS server and client. Enable this to permit local |
| NFS clients to bypass the network when issuing reads and |
| writes to the local NFS server. |
| |
| If unsure, say N. |
| |
| config NFS_V4_2_SSC_HELPER |
| bool |
| default y if NFS_V4_2 |
| |
| source "net/sunrpc/Kconfig" |
| source "fs/ceph/Kconfig" |
| |
| source "fs/smb/Kconfig" |
| source "fs/coda/Kconfig" |
| source "fs/afs/Kconfig" |
| source "fs/9p/Kconfig" |
| |
| endif # NETWORK_FILESYSTEMS |
| |
| source "fs/nls/Kconfig" |
| source "fs/dlm/Kconfig" |
| source "fs/unicode/Kconfig" |
| |
| config IO_WQ |
| bool |
| |
| endmenu |