diff options
author | Wendy Cheng <wcheng@redhat.com> | 2007-11-29 17:56:51 -0500 |
---|---|---|
committer | Steven Whitehouse <swhiteho@redhat.com> | 2008-01-25 03:08:15 -0500 |
commit | c97bfe4351771675963e02f34d31e206fd2d7150 (patch) | |
tree | 9ee4de86cacc54f3e49135a4ce39cf7a236efb31 /fs/gfs2/inode.c | |
parent | bcd405599faa16cf32a3d3f1ce6a1e12cb37fede (diff) |
[GFS2] Remove lock methods for lock_nolock protocol
GFS2 supports two modes of locking - lock_nolock for single node filesystem
and lock_dlm for cluster mode locking. The gfs2 lock methods are removed from
file operation table for lock_nolock protocol. This would allow VFS to handle
posix lock and flock logics just like other in-tree filesystems without
duplication.
Signed-off-by: S. Wendy Cheng <wcheng@redhat.com>
Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
Diffstat (limited to 'fs/gfs2/inode.c')
-rw-r--r-- | fs/gfs2/inode.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/fs/gfs2/inode.c b/fs/gfs2/inode.c index 92959d093adf..53bca9978fb5 100644 --- a/fs/gfs2/inode.c +++ b/fs/gfs2/inode.c | |||
@@ -131,14 +131,21 @@ static struct inode *gfs2_iget_skip(struct super_block *sb, | |||
131 | 131 | ||
132 | void gfs2_set_iop(struct inode *inode) | 132 | void gfs2_set_iop(struct inode *inode) |
133 | { | 133 | { |
134 | struct gfs2_sbd *sdp = GFS2_SB(inode); | ||
134 | umode_t mode = inode->i_mode; | 135 | umode_t mode = inode->i_mode; |
135 | 136 | ||
136 | if (S_ISREG(mode)) { | 137 | if (S_ISREG(mode)) { |
137 | inode->i_op = &gfs2_file_iops; | 138 | inode->i_op = &gfs2_file_iops; |
138 | inode->i_fop = &gfs2_file_fops; | 139 | if (sdp->sd_args.ar_localflocks) |
140 | inode->i_fop = &gfs2_file_fops_nolock; | ||
141 | else | ||
142 | inode->i_fop = &gfs2_file_fops; | ||
139 | } else if (S_ISDIR(mode)) { | 143 | } else if (S_ISDIR(mode)) { |
140 | inode->i_op = &gfs2_dir_iops; | 144 | inode->i_op = &gfs2_dir_iops; |
141 | inode->i_fop = &gfs2_dir_fops; | 145 | if (sdp->sd_args.ar_localflocks) |
146 | inode->i_fop = &gfs2_dir_fops_nolock; | ||
147 | else | ||
148 | inode->i_fop = &gfs2_dir_fops; | ||
142 | } else if (S_ISLNK(mode)) { | 149 | } else if (S_ISLNK(mode)) { |
143 | inode->i_op = &gfs2_symlink_iops; | 150 | inode->i_op = &gfs2_symlink_iops; |
144 | } else { | 151 | } else { |