[Cluster-devel] Re: [PATCH] gfs2: cleanup file_operations mess
Steven Whitehouse
swhiteho at redhat.com
Wed Apr 8 09:50:29 UTC 2009
Hi,
Yes, that looks better! Its about to appear in the GFS2 git tree.
Thanks,
Steve.
On Tue, 2009-04-07 at 19:42 +0200, Christoph Hellwig wrote:
> Remove the weird pointer to file_operations mess and replace it with
> straight-forward defining of the lockinginstance names to the _nolock
> variants.
>
>
> Signed-off-by: Christoph Hellwig <hch at lst.de>
>
> Index: linux-2.6/fs/gfs2/inode.c
> ===================================================================
> --- linux-2.6.orig/fs/gfs2/inode.c 2009-04-06 14:17:05.667570170 +0200
> +++ linux-2.6/fs/gfs2/inode.c 2009-04-07 19:21:25.250572236 +0200
> @@ -137,15 +137,15 @@ void gfs2_set_iop(struct inode *inode)
> if (S_ISREG(mode)) {
> inode->i_op = &gfs2_file_iops;
> if (gfs2_localflocks(sdp))
> - inode->i_fop = gfs2_file_fops_nolock;
> + inode->i_fop = &gfs2_file_fops_nolock;
> else
> - inode->i_fop = gfs2_file_fops;
> + inode->i_fop = &gfs2_file_fops;
> } else if (S_ISDIR(mode)) {
> inode->i_op = &gfs2_dir_iops;
> if (gfs2_localflocks(sdp))
> - inode->i_fop = gfs2_dir_fops_nolock;
> + inode->i_fop = &gfs2_dir_fops_nolock;
> else
> - inode->i_fop = gfs2_dir_fops;
> + inode->i_fop = &gfs2_dir_fops;
> } else if (S_ISLNK(mode)) {
> inode->i_op = &gfs2_symlink_iops;
> } else {
> Index: linux-2.6/fs/gfs2/inode.h
> ===================================================================
> --- linux-2.6.orig/fs/gfs2/inode.h 2009-04-06 14:17:05.671570051 +0200
> +++ linux-2.6/fs/gfs2/inode.h 2009-04-07 19:21:08.357447364 +0200
> @@ -101,21 +101,23 @@ void gfs2_dinode_print(const struct gfs2
> extern const struct inode_operations gfs2_file_iops;
> extern const struct inode_operations gfs2_dir_iops;
> extern const struct inode_operations gfs2_symlink_iops;
> -extern const struct file_operations *gfs2_file_fops_nolock;
> -extern const struct file_operations *gfs2_dir_fops_nolock;
> +extern const struct file_operations gfs2_file_fops_nolock;
> +extern const struct file_operations gfs2_dir_fops_nolock;
>
> extern void gfs2_set_inode_flags(struct inode *inode);
>
> #ifdef CONFIG_GFS2_FS_LOCKING_DLM
> -extern const struct file_operations *gfs2_file_fops;
> -extern const struct file_operations *gfs2_dir_fops;
> +extern const struct file_operations gfs2_file_fops;
> +extern const struct file_operations gfs2_dir_fops;
> +
> static inline int gfs2_localflocks(const struct gfs2_sbd *sdp)
> {
> return sdp->sd_args.ar_localflocks;
> }
> #else /* Single node only */
> -#define gfs2_file_fops NULL
> -#define gfs2_dir_fops NULL
> +#define gfs2_file_fops gfs2_file_fops_nolock
> +#define gfs2_dir_fops gfs2_dir_fops_nolock
> +
> static inline int gfs2_localflocks(const struct gfs2_sbd *sdp)
> {
> return 1;
> Index: linux-2.6/fs/gfs2/ops_file.c
> ===================================================================
> --- linux-2.6.orig/fs/gfs2/ops_file.c 2009-04-06 14:17:05.716570192 +0200
> +++ linux-2.6/fs/gfs2/ops_file.c 2009-04-07 17:56:32.544445433 +0200
> @@ -705,7 +705,7 @@ static int gfs2_flock(struct file *file,
> }
> }
>
> -const struct file_operations *gfs2_file_fops = &(const struct file_operations){
> +const struct file_operations gfs2_file_fops = {
> .llseek = gfs2_llseek,
> .read = do_sync_read,
> .aio_read = generic_file_aio_read,
> @@ -723,7 +723,7 @@ const struct file_operations *gfs2_file_
> .setlease = gfs2_setlease,
> };
>
> -const struct file_operations *gfs2_dir_fops = &(const struct file_operations){
> +const struct file_operations gfs2_dir_fops = {
> .readdir = gfs2_readdir,
> .unlocked_ioctl = gfs2_ioctl,
> .open = gfs2_open,
> @@ -735,7 +735,7 @@ const struct file_operations *gfs2_dir_f
>
> #endif /* CONFIG_GFS2_FS_LOCKING_DLM */
>
> -const struct file_operations *gfs2_file_fops_nolock = &(const struct file_operations){
> +const struct file_operations gfs2_file_fops_nolock = {
> .llseek = gfs2_llseek,
> .read = do_sync_read,
> .aio_read = generic_file_aio_read,
> @@ -751,7 +751,7 @@ const struct file_operations *gfs2_file_
> .setlease = generic_setlease,
> };
>
> -const struct file_operations *gfs2_dir_fops_nolock = &(const struct file_operations){
> +const struct file_operations gfs2_dir_fops_nolock = {
> .readdir = gfs2_readdir,
> .unlocked_ioctl = gfs2_ioctl,
> .open = gfs2_open,
More information about the Cluster-devel
mailing list