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

Andrew Price anprice at redhat.com
Thu Nov 5 18:19:48 UTC 2015


Hi Abhi,

On 30/10/15 19:57, Abhi Das wrote:
> 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));

Are these two changes still required? The function only seems to get 
called in the SETFLAGS ioctl path.

Cheers,
Andy

>   }
>
>   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) ||
>




More information about the Cluster-devel mailing list