|
|
bee754 |
commit 3e500a8f116b0515d1507fe0ab4bf617664a6cdc
|
|
|
bee754 |
Author: Eric Sandeen <sandeen@redhat.com>
|
|
|
bee754 |
Date: Fri Jul 4 23:07:36 2014 -0400
|
|
|
bee754 |
|
|
|
bee754 |
e2fsprogs: add mount options to ext4.5
|
|
|
bee754 |
|
|
|
bee754 |
This is a straight cut and paste from the util-linux
|
|
|
bee754 |
mount manpage to ext4.5 (with commented-out lines
|
|
|
bee754 |
removed).
|
|
|
bee754 |
|
|
|
bee754 |
It's pretty much impossible for util-linux to keep up
|
|
|
bee754 |
with every filesystem out there, and Karel has more than
|
|
|
bee754 |
once expressed a wish that mount options move into fs-specific
|
|
|
bee754 |
manpages.
|
|
|
bee754 |
|
|
|
bee754 |
So, here we go.
|
|
|
bee754 |
|
|
|
bee754 |
Signed-off-by: Eric Sandeen <sandeen@redhat.com>
|
|
|
bee754 |
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
|
|
|
bee754 |
|
|
|
bee754 |
diff --git a/misc/ext4.5.in b/misc/ext4.5.in
|
|
|
bee754 |
index 134c19f..9112b3d 100644
|
|
|
bee754 |
--- a/misc/ext4.5.in
|
|
|
bee754 |
+++ b/misc/ext4.5.in
|
|
|
bee754 |
@@ -251,10 +251,368 @@ and it also speeds up the time required for
|
|
|
bee754 |
.BR mke2fs (8)
|
|
|
bee754 |
to create the file system.
|
|
|
bee754 |
.RE
|
|
|
bee754 |
+.SH MOUNT OPTIONS
|
|
|
bee754 |
+This section describes mount options which are specific to ext2, ext3,
|
|
|
bee754 |
+and ext4. Other generic mount options may be used as well; see
|
|
|
bee754 |
+.BR mount (8)
|
|
|
bee754 |
+for details.
|
|
|
bee754 |
+.SH "Mount options for ext2"
|
|
|
bee754 |
+The `ext2' filesystem is the standard Linux filesystem.
|
|
|
bee754 |
+Since Linux 2.5.46, for most mount options the default
|
|
|
bee754 |
+is determined by the filesystem superblock. Set them with
|
|
|
bee754 |
+.BR tune2fs (8).
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR acl | noacl
|
|
|
bee754 |
+Support POSIX Access Control Lists (or not).
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR bsddf | minixdf
|
|
|
bee754 |
+Set the behavior for the
|
|
|
bee754 |
+.I statfs
|
|
|
bee754 |
+system call. The
|
|
|
bee754 |
+.B minixdf
|
|
|
bee754 |
+behavior is to return in the
|
|
|
bee754 |
+.I f_blocks
|
|
|
bee754 |
+field the total number of blocks of the filesystem, while the
|
|
|
bee754 |
+.B bsddf
|
|
|
bee754 |
+behavior (which is the default) is to subtract the overhead blocks
|
|
|
bee754 |
+used by the ext2 filesystem and not available for file storage. Thus
|
|
|
bee754 |
+.sp 1
|
|
|
bee754 |
+% mount /k \-o minixdf; df /k; umount /k
|
|
|
bee754 |
+.TS
|
|
|
bee754 |
+tab(#);
|
|
|
bee754 |
+l2 l2 r2 l2 l2 l
|
|
|
bee754 |
+l c r c c l.
|
|
|
bee754 |
+Filesystem#1024-blocks#Used#Available#Capacity#Mounted on
|
|
|
bee754 |
+/dev/sda6#2630655#86954#2412169#3%#/k
|
|
|
bee754 |
+.TE
|
|
|
bee754 |
+.sp 1
|
|
|
bee754 |
+% mount /k \-o bsddf; df /k; umount /k
|
|
|
bee754 |
+.TS
|
|
|
bee754 |
+tab(#);
|
|
|
bee754 |
+l2 l2 r2 l2 l2 l
|
|
|
bee754 |
+l c r c c l.
|
|
|
bee754 |
+Filesystem#1024-blocks#Used#Available#Capacity#Mounted on
|
|
|
bee754 |
+/dev/sda6#2543714#13#2412169#0%#/k
|
|
|
bee754 |
+.TE
|
|
|
bee754 |
+.sp 1
|
|
|
bee754 |
+(Note that this example shows that one can add command line options
|
|
|
bee754 |
+to the options given in
|
|
|
bee754 |
+.IR /etc/fstab .)
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR check=none " or " nocheck
|
|
|
bee754 |
+No checking is done at mount time. This is the default. This is fast.
|
|
|
bee754 |
+It is wise to invoke
|
|
|
bee754 |
+.BR e2fsck (8)
|
|
|
bee754 |
+every now and then, e.g.\& at boot time. The non-default behavior is unsupported
|
|
|
bee754 |
+(check=normal and check=strict options have been removed). Note that these mount options
|
|
|
bee754 |
+don't have to be supported if ext4 kernel driver is used for ext2 and ext3 filesystems.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B debug
|
|
|
bee754 |
+Print debugging info upon each (re)mount.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR errors= { continue | remount-ro | panic }
|
|
|
bee754 |
+Define the behavior when an error is encountered.
|
|
|
bee754 |
+(Either ignore errors and just mark the filesystem erroneous and continue,
|
|
|
bee754 |
+or remount the filesystem read-only, or panic and halt the system.)
|
|
|
bee754 |
+The default is set in the filesystem superblock, and can be
|
|
|
bee754 |
+changed using
|
|
|
bee754 |
+.BR tune2fs (8).
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR grpid | bsdgroups " and " nogrpid | sysvgroups
|
|
|
bee754 |
+These options define what group id a newly created file gets.
|
|
|
bee754 |
+When
|
|
|
bee754 |
+.B grpid
|
|
|
bee754 |
+is set, it takes the group id of the directory in which it is created;
|
|
|
bee754 |
+otherwise (the default) it takes the fsgid of the current process, unless
|
|
|
bee754 |
+the directory has the setgid bit set, in which case it takes the gid
|
|
|
bee754 |
+from the parent directory, and also gets the setgid bit set
|
|
|
bee754 |
+if it is a directory itself.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR grpquota | noquota | quota | usrquota
|
|
|
bee754 |
+The usrquota (same as quota) mount option enables user quota support on the
|
|
|
bee754 |
+filesystem. grpquota enables group quotas support. You need the quota utilities
|
|
|
bee754 |
+to actually enable and manage the quota system.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B nouid32
|
|
|
bee754 |
+Disables 32-bit UIDs and GIDs. This is for interoperability with older
|
|
|
bee754 |
+kernels which only store and expect 16-bit values.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR oldalloc " or " orlov
|
|
|
bee754 |
+Use old allocator or Orlov allocator for new inodes. Orlov is default.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+\fBresgid=\fP\,\fIn\fP and \fBresuid=\fP\,\fIn\fP
|
|
|
bee754 |
+The ext2 filesystem reserves a certain percentage of the available
|
|
|
bee754 |
+space (by default 5%, see
|
|
|
bee754 |
+.BR mke2fs (8)
|
|
|
bee754 |
+and
|
|
|
bee754 |
+.BR tune2fs (8)).
|
|
|
bee754 |
+These options determine who can use the reserved blocks.
|
|
|
bee754 |
+(Roughly: whoever has the specified uid, or belongs to the specified group.)
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BI sb= n
|
|
|
bee754 |
+Instead of block 1, use block
|
|
|
bee754 |
+.I n
|
|
|
bee754 |
+as superblock. This could be useful when the filesystem has been damaged.
|
|
|
bee754 |
+(Earlier, copies of the superblock would be made every 8192 blocks: in
|
|
|
bee754 |
+block 1, 8193, 16385, \&...\& (and one got thousands of copies on
|
|
|
bee754 |
+a big filesystem). Since version 1.08,
|
|
|
bee754 |
+.B mke2fs
|
|
|
bee754 |
+has a \-s (sparse superblock) option to reduce the number of backup
|
|
|
bee754 |
+superblocks, and since version 1.15 this is the default. Note
|
|
|
bee754 |
+that this may mean that ext2 filesystems created by a recent
|
|
|
bee754 |
+.B mke2fs
|
|
|
bee754 |
+cannot be mounted r/w under Linux 2.0.*.)
|
|
|
bee754 |
+The block number here uses 1\ k units. Thus, if you want to use logical
|
|
|
bee754 |
+block 32768 on a filesystem with 4\ k blocks, use "sb=131072".
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR user_xattr | nouser_xattr
|
|
|
bee754 |
+Support "user." extended attributes (or not).
|
|
|
bee754 |
+
|
|
|
bee754 |
+
|
|
|
bee754 |
+.SH "Mount options for ext3"
|
|
|
bee754 |
+The ext3 filesystem is a version of the ext2 filesystem which has been
|
|
|
bee754 |
+enhanced with journaling. It supports the same options as ext2 as
|
|
|
bee754 |
+well as the following additions:
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B journal=update
|
|
|
bee754 |
+Update the ext3 filesystem's journal to the current format.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B journal=inum
|
|
|
bee754 |
+When a journal already exists, this option is ignored. Otherwise, it
|
|
|
bee754 |
+specifies the number of the inode which will represent the ext3 filesystem's
|
|
|
bee754 |
+journal file; ext3 will create a new journal, overwriting the old contents
|
|
|
bee754 |
+of the file whose inode number is
|
|
|
bee754 |
+.IR inum .
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR journal_dev=devnum / journal_path=path
|
|
|
bee754 |
+When the external journal device's major/minor numbers
|
|
|
bee754 |
+have changed, these options allow the user to specify
|
|
|
bee754 |
+the new journal location. The journal device is
|
|
|
bee754 |
+identified either through its new major/minor numbers encoded
|
|
|
bee754 |
+in devnum, or via a path to the device.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR norecovery / noload
|
|
|
bee754 |
+Don't load the journal on mounting. Note that
|
|
|
bee754 |
+if the filesystem was not unmounted cleanly,
|
|
|
bee754 |
+skipping the journal replay will lead to the
|
|
|
bee754 |
+filesystem containing inconsistencies that can
|
|
|
bee754 |
+lead to any number of problems.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR data= { journal | ordered | writeback }
|
|
|
bee754 |
+Specifies the journaling mode for file data. Metadata is always journaled.
|
|
|
bee754 |
+To use modes other than
|
|
|
bee754 |
+.B ordered
|
|
|
bee754 |
+on the root filesystem, pass the mode to the kernel as boot parameter, e.g.\&
|
|
|
bee754 |
+.IR rootflags=data=journal .
|
|
|
bee754 |
+.RS
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B journal
|
|
|
bee754 |
+All data is committed into the journal prior to being written into the
|
|
|
bee754 |
+main filesystem.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B ordered
|
|
|
bee754 |
+This is the default mode. All data is forced directly out to the main file
|
|
|
bee754 |
+system prior to its metadata being committed to the journal.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B writeback
|
|
|
bee754 |
+Data ordering is not preserved \(en data may be written into the main
|
|
|
bee754 |
+filesystem after its metadata has been committed to the journal.
|
|
|
bee754 |
+This is rumoured to be the highest-throughput option. It guarantees
|
|
|
bee754 |
+internal filesystem integrity, however it can allow old data to appear
|
|
|
bee754 |
+in files after a crash and journal recovery.
|
|
|
bee754 |
+.RE
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B data_err=ignore
|
|
|
bee754 |
+Just print an error message if an error occurs in a file data buffer in
|
|
|
bee754 |
+ordered mode.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B data_err=abort
|
|
|
bee754 |
+Abort the journal if an error occurs in a file data buffer in ordered mode.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR barrier=0 " / " barrier=1 "
|
|
|
bee754 |
+This disables / enables the use of write barriers in the jbd code. barrier=0
|
|
|
bee754 |
+disables, barrier=1 enables (default). This also requires an IO stack which can
|
|
|
bee754 |
+support barriers, and if jbd gets an error on a barrier write, it will disable
|
|
|
bee754 |
+barriers again with a warning. Write barriers enforce proper on-disk ordering
|
|
|
bee754 |
+of journal commits, making volatile disk write caches safe to use, at some
|
|
|
bee754 |
+performance penalty. If your disks are battery-backed in one way or another,
|
|
|
bee754 |
+disabling barriers may safely improve performance.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BI commit= nrsec
|
|
|
bee754 |
+Sync all data and metadata every
|
|
|
bee754 |
+.I nrsec
|
|
|
bee754 |
+seconds. The default value is 5 seconds. Zero means default.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B user_xattr
|
|
|
bee754 |
+Enable Extended User Attributes. See the
|
|
|
bee754 |
+.BR attr (5)
|
|
|
bee754 |
+manual page.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B acl
|
|
|
bee754 |
+Enable POSIX Access Control Lists. See the
|
|
|
bee754 |
+.BR acl (5)
|
|
|
bee754 |
+manual page.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR usrjquota=aquota.user | grpjquota=aquota.group | jqfmt=vfsv0
|
|
|
bee754 |
+Apart from the old quota system (as in ext2, jqfmt=vfsold aka version 1 quota)
|
|
|
bee754 |
+ext3 also supports journaled quotas (version 2 quota). jqfmt=vfsv0
|
|
|
bee754 |
+enables journaled quotas. For journaled quotas the mount options
|
|
|
bee754 |
+usrjquota=aquota.user and grpjquota=aquota.group are required to tell the
|
|
|
bee754 |
+quota system which quota database files to use. Journaled quotas have the
|
|
|
bee754 |
+advantage that even after a crash no quota check is required.
|
|
|
bee754 |
+
|
|
|
bee754 |
+.SH "Mount options for ext4"
|
|
|
bee754 |
+The ext4 filesystem is an advanced level of the ext3 filesystem which
|
|
|
bee754 |
+incorporates scalability and reliability enhancements for supporting large
|
|
|
bee754 |
+filesystem.
|
|
|
bee754 |
+
|
|
|
bee754 |
+The options
|
|
|
bee754 |
+.B journal_dev, norecovery, noload, data, commit, orlov, oldalloc, [no]user_xattr
|
|
|
bee754 |
+.B [no]acl, bsddf, minixdf, debug, errors, data_err, grpid, bsdgroups, nogrpid
|
|
|
bee754 |
+.B sysvgroups, resgid, resuid, sb, quota, noquota, grpquota, usrquota
|
|
|
bee754 |
+.B usrjquota, grpjquota and jqfmt
|
|
|
bee754 |
+are backwardly compatible with ext3 or ext2.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B journal_checksum
|
|
|
bee754 |
+Enable checksumming of the journal transactions. This will allow the recovery
|
|
|
bee754 |
+code in e2fsck and the kernel to detect corruption in the kernel. It is a
|
|
|
bee754 |
+compatible change and will be ignored by older kernels.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B journal_async_commit
|
|
|
bee754 |
+Commit block can be written to disk without waiting for descriptor blocks. If
|
|
|
bee754 |
+enabled older kernels cannot mount the device.
|
|
|
bee754 |
+This will enable 'journal_checksum' internally.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR barrier=0 " / " barrier=1 " / " barrier " / " nobarrier
|
|
|
bee754 |
+These mount options have the same effect as in ext3. The mount options
|
|
|
bee754 |
+"barrier" and "nobarrier" are added for consistency with other ext4 mount
|
|
|
bee754 |
+options.
|
|
|
bee754 |
+
|
|
|
bee754 |
+The ext4 filesystem enables write barriers by default.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BI inode_readahead_blks= n
|
|
|
bee754 |
+This tuning parameter controls the maximum number of inode table blocks that
|
|
|
bee754 |
+ext4's inode table readahead algorithm will pre-read into the buffer cache.
|
|
|
bee754 |
+The value must be a power of 2. The default value is 32 blocks.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BI stripe= n
|
|
|
bee754 |
+Number of filesystem blocks that mballoc will try to use for allocation size
|
|
|
bee754 |
+and alignment. For RAID5/6 systems this should be the number of data disks *
|
|
|
bee754 |
+RAID chunk size in filesystem blocks.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B delalloc
|
|
|
bee754 |
+Deferring block allocation until write-out time.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B nodelalloc
|
|
|
bee754 |
+Disable delayed allocation. Blocks are allocated when data is copied from user
|
|
|
bee754 |
+to page cache.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BI max_batch_time= usec
|
|
|
bee754 |
+Maximum amount of time ext4 should wait for additional filesystem operations to
|
|
|
bee754 |
+be batch together with a synchronous write operation. Since a synchronous
|
|
|
bee754 |
+write operation is going to force a commit and then a wait for the I/O
|
|
|
bee754 |
+complete, it doesn't cost much, and can be a huge throughput win, we wait for a
|
|
|
bee754 |
+small amount of time to see if any other transactions can piggyback on the
|
|
|
bee754 |
+synchronous write. The algorithm used is designed to automatically tune for
|
|
|
bee754 |
+the speed of the disk, by measuring the amount of time (on average) that it
|
|
|
bee754 |
+takes to finish committing a transaction. Call this time the "commit time".
|
|
|
bee754 |
+If the time that the transaction has been running is less than the commit time,
|
|
|
bee754 |
+ext4 will try sleeping for the commit time to see if other operations will join
|
|
|
bee754 |
+the transaction. The commit time is capped by the max_batch_time, which
|
|
|
bee754 |
+defaults to 15000\ \[mc]s (15\ ms). This optimization can be turned off entirely by
|
|
|
bee754 |
+setting max_batch_time to 0.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BI min_batch_time= usec
|
|
|
bee754 |
+This parameter sets the commit time (as described above) to be at least
|
|
|
bee754 |
+min_batch_time. It defaults to zero microseconds. Increasing this parameter
|
|
|
bee754 |
+may improve the throughput of multi-threaded, synchronous workloads on very
|
|
|
bee754 |
+fast disks, at the cost of increasing latency.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BI journal_ioprio= prio
|
|
|
bee754 |
+The I/O priority (from 0 to 7, where 0 is the highest priority) which should be
|
|
|
bee754 |
+used for I/O operations submitted by kjournald2 during a commit operation.
|
|
|
bee754 |
+This defaults to 3, which is a slightly higher priority than the default I/O
|
|
|
bee754 |
+priority.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B abort
|
|
|
bee754 |
+Simulate the effects of calling ext4_abort() for
|
|
|
bee754 |
+debugging purposes. This is normally used while
|
|
|
bee754 |
+remounting a filesystem which is already mounted.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR auto_da_alloc | noauto_da_alloc
|
|
|
bee754 |
+Many broken applications don't use fsync() when
|
|
|
bee754 |
+replacing existing files via patterns such as
|
|
|
bee754 |
+
|
|
|
bee754 |
+fd = open("foo.new")/write(fd,...)/close(fd)/ rename("foo.new", "foo")
|
|
|
bee754 |
+
|
|
|
bee754 |
+or worse yet
|
|
|
bee754 |
+
|
|
|
bee754 |
+fd = open("foo", O_TRUNC)/write(fd,...)/close(fd).
|
|
|
bee754 |
+
|
|
|
bee754 |
+If auto_da_alloc is enabled, ext4 will detect the replace-via-rename and
|
|
|
bee754 |
+replace-via-truncate patterns and force that any delayed allocation blocks are
|
|
|
bee754 |
+allocated such that at the next journal commit, in the default data=ordered
|
|
|
bee754 |
+mode, the data blocks of the new file are forced to disk before the rename()
|
|
|
bee754 |
+operation is committed. This provides roughly the same level of guarantees as
|
|
|
bee754 |
+ext3, and avoids the "zero-length" problem that can happen when a system
|
|
|
bee754 |
+crashes before the delayed allocation blocks are forced to disk.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B noinit_itable
|
|
|
bee754 |
+Do not initialize any uninitialized inode table blocks in the background. This
|
|
|
bee754 |
+feature may be used by installation CD's so that the install process can
|
|
|
bee754 |
+complete as quickly as possible; the inode table initialization process would
|
|
|
bee754 |
+then be deferred until the next time the filesystem is mounted.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B init_itable=n
|
|
|
bee754 |
+The lazy itable init code will wait n times the number of milliseconds it took
|
|
|
bee754 |
+to zero out the previous block group's inode table. This minimizes the impact on
|
|
|
bee754 |
+system performance while the filesystem's inode table is being initialized.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR discard / nodiscard
|
|
|
bee754 |
+Controls whether ext4 should issue discard/TRIM commands to the underlying
|
|
|
bee754 |
+block device when blocks are freed. This is useful for SSD devices and
|
|
|
bee754 |
+sparse/thinly-provisioned LUNs, but it is off by default until sufficient
|
|
|
bee754 |
+testing has been done.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B nouid32
|
|
|
bee754 |
+Disables 32-bit UIDs and GIDs. This is for
|
|
|
bee754 |
+interoperability with older kernels which only
|
|
|
bee754 |
+store and expect 16-bit values.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR block_validity / noblock_validity
|
|
|
bee754 |
+This options allows to enables/disables the in-kernel facility for tracking
|
|
|
bee754 |
+filesystem metadata blocks within internal data structures. This allows multi-\c
|
|
|
bee754 |
+block allocator and other routines to quickly locate extents which might
|
|
|
bee754 |
+overlap with filesystem metadata blocks. This option is intended for debugging
|
|
|
bee754 |
+purposes and since it negatively affects the performance, it is off by default.
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.BR dioread_lock / dioread_nolock
|
|
|
bee754 |
+Controls whether or not ext4 should use the DIO read locking. If the
|
|
|
bee754 |
+dioread_nolock option is specified ext4 will allocate uninitialized extent
|
|
|
bee754 |
+before buffer write and convert the extent to initialized after IO completes.
|
|
|
bee754 |
+This approach allows ext4 code to avoid using inode mutex, which improves
|
|
|
bee754 |
+scalability on high speed storages. However this does not work with data
|
|
|
bee754 |
+journaling and dioread_nolock option will be ignored with kernel warning.
|
|
|
bee754 |
+Note that dioread_nolock code path is only used for extent-based files.
|
|
|
bee754 |
+Because of the restrictions this options comprises it is off by default
|
|
|
bee754 |
+(e.g.\& dioread_lock).
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B max_dir_size_kb=n
|
|
|
bee754 |
+This limits the size of the directories so that any attempt to expand them
|
|
|
bee754 |
+beyond the specified limit in kilobytes will cause an ENOSPC error. This is
|
|
|
bee754 |
+useful in memory-constrained environments, where a very large directory can
|
|
|
bee754 |
+cause severe performance problems or even provoke the Out Of Memory killer. (For
|
|
|
bee754 |
+example, if there is only 512\ MB memory available, a 176\ MB directory may
|
|
|
bee754 |
+seriously cramp the system's style.)
|
|
|
bee754 |
+.TP
|
|
|
bee754 |
+.B i_version
|
|
|
bee754 |
+Enable 64-bit inode version support. This option is off by default.
|
|
|
bee754 |
+
|
|
|
bee754 |
.SH SEE ALSO
|
|
|
bee754 |
.BR mke2fs (8),
|
|
|
bee754 |
.BR mke2fs.conf (5),
|
|
|
bee754 |
.BR e2fsck (8),
|
|
|
bee754 |
.BR dumpe2fs (8),
|
|
|
bee754 |
.BR tune2fs (8),
|
|
|
bee754 |
-.BR debugfs (8)
|
|
|
bee754 |
+.BR debugfs (8),
|
|
|
bee754 |
+.BR mount (8)
|