[Cluster-devel] [GFS2 PATCH] gfs2: Automatically set GFS2_DIF_SYSTEM flag on system files

Bob Peterson rpeterso at redhat.com
Tue Nov 10 21:13:26 UTC 2015


----- Original Message -----
> When new files and directories are created inside a parent directory
> we automatically inherit the GFS2_DIF_SYSTEM flag (if set) and assign
> it to the new file/dirs.
> 
> All new system files/dirs created in the metafs by, say gfs2_jadd,
> will have this flag set because they will have parent directories in
> the metafs whose GFS2_DIF_SYSTEM flag has already been set (most likely
> by a previous mkfs.gfs2)
> 
> Resolves: rhbz#1272086
> Signed-off-by: Abhi Das <adas at redhat.com>
> ---
>  fs/gfs2/file.c  | 4 ++--
>  fs/gfs2/inode.c | 5 +++++
>  2 files changed, 7 insertions(+), 2 deletions(-)
> 
> diff --git a/fs/gfs2/file.c b/fs/gfs2/file.c
> index 71cd138..63fe948 100644
> --- a/fs/gfs2/file.c
> +++ b/fs/gfs2/file.c
> @@ -298,9 +298,9 @@ static int gfs2_set_flags(struct file *filp, u32 __user
> *ptr)
>  		gfsflags &= ~GFS2_DIF_TOPDIR;
>  		if (gfsflags & GFS2_DIF_INHERIT_JDATA)
>  			gfsflags ^= (GFS2_DIF_JDATA | GFS2_DIF_INHERIT_JDATA);
> -		return do_gfs2_set_flags(filp, gfsflags, ~0);
> +		return do_gfs2_set_flags(filp, gfsflags, ~GFS2_DIF_SYSTEM);
>  	}
> -	return do_gfs2_set_flags(filp, gfsflags, ~GFS2_DIF_JDATA);
> +	return do_gfs2_set_flags(filp, gfsflags, ~(GFS2_DIF_SYSTEM |
> GFS2_DIF_JDATA));
>  }
>  
>  static long gfs2_ioctl(struct file *filp, unsigned int cmd, unsigned long
>  arg)
> diff --git a/fs/gfs2/inode.c b/fs/gfs2/inode.c
> index 063fdfc..2c05bc3 100644
> --- a/fs/gfs2/inode.c
> +++ b/fs/gfs2/inode.c
> @@ -685,6 +685,11 @@ static int gfs2_create_inode(struct inode *dir, struct
> dentry *dentry,
>  		ip->i_entries = 2;
>  		break;
>  	}
> +
> +	/* Force SYSTEM flag on all files and subdirs of a SYSTEM directory */
> +	if (dip->i_diskflags & GFS2_DIF_SYSTEM)
> +		ip->i_diskflags |= GFS2_DIF_SYSTEM;
> +
>  	gfs2_set_inode_flags(inode);
>  
>  	if ((GFS2_I(d_inode(sdp->sd_root_dir)) == dip) ||
> --
> 2.4.3
> 
> 
Hi,

Thanks. This is now applied to the for-next branch of the linux-gfs2 tree:
https://git.kernel.org/cgit/linux/kernel/git/gfs2/linux-gfs2.git/commit/fs/gfs2?h=for-next&id=acc546fd6108cb17f87f985e4235b68756d7b01f

Regards,

Bob Peterson
Red Hat File Systems




More information about the Cluster-devel mailing list