mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-06 02:24:14 +08:00
f057f6cdf6
This is the big patch that I've been working on for some time now. There are many reasons for wanting to make this change such as: o Reducing overhead by eliminating duplicated fields between structures o Simplifcation of the code (reduces the code size by a fair bit) o The locking interface is now the DLM interface itself as proposed some time ago. o Fewer lookups of glocks when processing replies from the DLM o Fewer memory allocations/deallocations for each glock o Scope to do further optimisations in the future (but this patch is more than big enough for now!) Please note that (a) this patch relates to the lock_dlm module and not the DLM itself, that is still a separate module; and (b) that we retain the ability to build GFS2 as a standalone single node filesystem with out requiring the DLM. This patch needs a lot of testing, hence my keeping it I restarted my -git tree after the last merge window. That way, this has the maximum exposure before its merged. This is (modulo a few minor bug fixes) the same patch that I've been posting on and off the the last three months and its passed a number of different tests so far. Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
38 lines
1.4 KiB
Plaintext
38 lines
1.4 KiB
Plaintext
config GFS2_FS
|
|
tristate "GFS2 file system support"
|
|
depends on EXPERIMENTAL && (64BIT || LBD)
|
|
select DLM if GFS2_FS_LOCKING_DLM
|
|
select CONFIGFS_FS if GFS2_FS_LOCKING_DLM
|
|
select SYSFS if GFS2_FS_LOCKING_DLM
|
|
select IP_SCTP if DLM_SCTP
|
|
select FS_POSIX_ACL
|
|
select CRC32
|
|
help
|
|
A cluster filesystem.
|
|
|
|
Allows a cluster of computers to simultaneously use a block device
|
|
that is shared between them (with FC, iSCSI, NBD, etc...). GFS reads
|
|
and writes to the block device like a local filesystem, but also uses
|
|
a lock module to allow the computers coordinate their I/O so
|
|
filesystem consistency is maintained. One of the nifty features of
|
|
GFS is perfect consistency -- changes made to the filesystem on one
|
|
machine show up immediately on all other machines in the cluster.
|
|
|
|
To use the GFS2 filesystem in a cluster, you will need to enable
|
|
the locking module below. Documentation and utilities for GFS2 can
|
|
be found here: http://sources.redhat.com/cluster
|
|
|
|
The "nolock" lock module is now built in to GFS2 by default. If
|
|
you want to use the DLM, be sure to enable HOTPLUG and IPv4/6
|
|
networking.
|
|
|
|
config GFS2_FS_LOCKING_DLM
|
|
bool "GFS2 DLM locking"
|
|
depends on (GFS2_FS!=n) && NET && INET && (IPV6 || IPV6=n) && HOTPLUG
|
|
help
|
|
Multiple node locking module for GFS2
|
|
|
|
Most users of GFS2 will require this. It provides the locking
|
|
interface between GFS2 and the DLM, which is required to use GFS2
|
|
in a cluster environment.
|