Re: [PATCH 12/15] xfs: move the di_flags2 field to struct xfs_inode

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Monday 22 June 2020 6:21:37 PM IST Chandan Babu R wrote:
> On Saturday 20 June 2020 12:40:59 PM IST Christoph Hellwig wrote:
> > In preparation of removing the historic icinode struct, move the flags2
> > field into the containing xfs_inode structure.
> >
> 
> The changes look good to me.
> 
> Reviewed-by: Chandan Babu R <chandanrlinux@xxxxxxxxx>

The commit "fs/xfs: Update xfs_ioctl_setattr_dax_invalidate()"
(e4f9ba20d3b8c2b86ec71f326882e1a3c4e47953) adds the function
xfs_ioctl_setattr_prepare_dax() which refers to xfs_icdinode->di_flags2. A
rebase should solve this issue.

> 
> > Signed-off-by: Christoph Hellwig <hch@xxxxxx>
> > ---
> >  fs/xfs/libxfs/xfs_inode_buf.c |  4 ++--
> >  fs/xfs/libxfs/xfs_inode_buf.h |  2 --
> >  fs/xfs/xfs_bmap_util.c        | 24 ++++++++++++------------
> >  fs/xfs/xfs_file.c             |  4 ++--
> >  fs/xfs/xfs_inode.c            | 22 ++++++++++------------
> >  fs/xfs/xfs_inode.h            |  3 ++-
> >  fs/xfs/xfs_inode_item.c       |  2 +-
> >  fs/xfs/xfs_ioctl.c            | 23 +++++++++++------------
> >  fs/xfs/xfs_iops.c             |  2 +-
> >  fs/xfs/xfs_itable.c           |  2 +-
> >  fs/xfs/xfs_reflink.c          |  8 ++++----
> >  11 files changed, 46 insertions(+), 50 deletions(-)
> > 
> > diff --git a/fs/xfs/libxfs/xfs_inode_buf.c b/fs/xfs/libxfs/xfs_inode_buf.c
> > index bb9c4775ecaa5c..79e470933abfa8 100644
> > --- a/fs/xfs/libxfs/xfs_inode_buf.c
> > +++ b/fs/xfs/libxfs/xfs_inode_buf.c
> > @@ -255,7 +255,7 @@ xfs_inode_from_disk(
> >  					   be64_to_cpu(from->di_changecount));
> >  		to->di_crtime.tv_sec = be32_to_cpu(from->di_crtime.t_sec);
> >  		to->di_crtime.tv_nsec = be32_to_cpu(from->di_crtime.t_nsec);
> > -		to->di_flags2 = be64_to_cpu(from->di_flags2);
> > +		ip->i_diflags2 = be64_to_cpu(from->di_flags2);
> >  		ip->i_cowextsize = be32_to_cpu(from->di_cowextsize);
> >  	}
> >  
> > @@ -321,7 +321,7 @@ xfs_inode_to_disk(
> >  		to->di_changecount = cpu_to_be64(inode_peek_iversion(inode));
> >  		to->di_crtime.t_sec = cpu_to_be32(from->di_crtime.tv_sec);
> >  		to->di_crtime.t_nsec = cpu_to_be32(from->di_crtime.tv_nsec);
> > -		to->di_flags2 = cpu_to_be64(from->di_flags2);
> > +		to->di_flags2 = cpu_to_be64(ip->i_diflags2);
> >  		to->di_cowextsize = cpu_to_be32(ip->i_cowextsize);
> >  		to->di_ino = cpu_to_be64(ip->i_ino);
> >  		to->di_lsn = cpu_to_be64(lsn);
> > diff --git a/fs/xfs/libxfs/xfs_inode_buf.h b/fs/xfs/libxfs/xfs_inode_buf.h
> > index 5c6a6ac521b11d..4bfad6d6d5710a 100644
> > --- a/fs/xfs/libxfs/xfs_inode_buf.h
> > +++ b/fs/xfs/libxfs/xfs_inode_buf.h
> > @@ -19,8 +19,6 @@ struct xfs_icdinode {
> >  	uint32_t	di_dmevmask;	/* DMIG event mask */
> >  	uint16_t	di_dmstate;	/* DMIG state info */
> >  
> > -	uint64_t	di_flags2;	/* more random flags */
> > -
> >  	struct timespec64 di_crtime;	/* time created */
> >  };
> >  
> > diff --git a/fs/xfs/xfs_bmap_util.c b/fs/xfs/xfs_bmap_util.c
> > index 0b944aad75e618..8f85a4131983a6 100644
> > --- a/fs/xfs/xfs_bmap_util.c
> > +++ b/fs/xfs/xfs_bmap_util.c
> > @@ -1332,9 +1332,9 @@ xfs_swap_extent_rmap(
> >  	 * rmap functions when we go to fix up the rmaps.  The flags
> >  	 * will be switch for reals later.
> >  	 */
> > -	tip_flags2 = tip->i_d.di_flags2;
> > -	if (ip->i_d.di_flags2 & XFS_DIFLAG2_REFLINK)
> > -		tip->i_d.di_flags2 |= XFS_DIFLAG2_REFLINK;
> > +	tip_flags2 = tip->i_diflags2;
> > +	if (ip->i_diflags2 & XFS_DIFLAG2_REFLINK)
> > +		tip->i_diflags2 |= XFS_DIFLAG2_REFLINK;
> >  
> >  	offset_fsb = 0;
> >  	end_fsb = XFS_B_TO_FSB(ip->i_mount, i_size_read(VFS_I(ip)));
> > @@ -1405,12 +1405,12 @@ xfs_swap_extent_rmap(
> >  		offset_fsb += ilen;
> >  	}
> >  
> > -	tip->i_d.di_flags2 = tip_flags2;
> > +	tip->i_diflags2 = tip_flags2;
> >  	return 0;
> >  
> >  out:
> >  	trace_xfs_swap_extent_rmap_error(ip, error, _RET_IP_);
> > -	tip->i_d.di_flags2 = tip_flags2;
> > +	tip->i_diflags2 = tip_flags2;
> >  	return error;
> >  }
> >  
> > @@ -1708,13 +1708,13 @@ xfs_swap_extents(
> >  		goto out_trans_cancel;
> >  
> >  	/* Do we have to swap reflink flags? */
> > -	if ((ip->i_d.di_flags2 & XFS_DIFLAG2_REFLINK) ^
> > -	    (tip->i_d.di_flags2 & XFS_DIFLAG2_REFLINK)) {
> > -		f = ip->i_d.di_flags2 & XFS_DIFLAG2_REFLINK;
> > -		ip->i_d.di_flags2 &= ~XFS_DIFLAG2_REFLINK;
> > -		ip->i_d.di_flags2 |= tip->i_d.di_flags2 & XFS_DIFLAG2_REFLINK;
> > -		tip->i_d.di_flags2 &= ~XFS_DIFLAG2_REFLINK;
> > -		tip->i_d.di_flags2 |= f & XFS_DIFLAG2_REFLINK;
> > +	if ((ip->i_diflags2 & XFS_DIFLAG2_REFLINK) ^
> > +	    (tip->i_diflags2 & XFS_DIFLAG2_REFLINK)) {
> > +		f = ip->i_diflags2 & XFS_DIFLAG2_REFLINK;
> > +		ip->i_diflags2 &= ~XFS_DIFLAG2_REFLINK;
> > +		ip->i_diflags2 |= tip->i_diflags2 & XFS_DIFLAG2_REFLINK;
> > +		tip->i_diflags2 &= ~XFS_DIFLAG2_REFLINK;
> > +		tip->i_diflags2 |= f & XFS_DIFLAG2_REFLINK;
> >  	}
> >  
> >  	/* Swap the cow forks. */
> > diff --git a/fs/xfs/xfs_file.c b/fs/xfs/xfs_file.c
> > index 4f08793f3d6db4..193352df48f6bd 100644
> > --- a/fs/xfs/xfs_file.c
> > +++ b/fs/xfs/xfs_file.c
> > @@ -1052,9 +1052,9 @@ xfs_file_remap_range(
> >  	 */
> >  	cowextsize = 0;
> >  	if (pos_in == 0 && len == i_size_read(inode_in) &&
> > -	    (src->i_d.di_flags2 & XFS_DIFLAG2_COWEXTSIZE) &&
> > +	    (src->i_diflags2 & XFS_DIFLAG2_COWEXTSIZE) &&
> >  	    pos_out == 0 && len >= i_size_read(inode_out) &&
> > -	    !(dest->i_d.di_flags2 & XFS_DIFLAG2_COWEXTSIZE))
> > +	    !(dest->i_diflags2 & XFS_DIFLAG2_COWEXTSIZE))
> >  		cowextsize = src->i_cowextsize;
> >  
> >  	ret = xfs_reflink_update_dest(dest, pos_out + len, cowextsize,
> > diff --git a/fs/xfs/xfs_inode.c b/fs/xfs/xfs_inode.c
> > index 479342ac8851f4..593e8c5c2fd658 100644
> > --- a/fs/xfs/xfs_inode.c
> > +++ b/fs/xfs/xfs_inode.c
> > @@ -81,7 +81,7 @@ xfs_get_cowextsz_hint(
> >  	xfs_extlen_t		a, b;
> >  
> >  	a = 0;
> > -	if (ip->i_d.di_flags2 & XFS_DIFLAG2_COWEXTSIZE)
> > +	if (ip->i_diflags2 & XFS_DIFLAG2_COWEXTSIZE)
> >  		a = ip->i_cowextsize;
> >  	b = xfs_get_extsz_hint(ip);
> >  
> > @@ -671,9 +671,7 @@ uint
> >  xfs_ip2xflags(
> >  	struct xfs_inode	*ip)
> >  {
> > -	struct xfs_icdinode	*dic = &ip->i_d;
> > -
> > -	return _xfs_dic2xflags(ip->i_diflags, dic->di_flags2, XFS_IFORK_Q(ip));
> > +	return _xfs_dic2xflags(ip->i_diflags, ip->i_diflags2, XFS_IFORK_Q(ip));
> >  }
> >  
> >  /*
> > @@ -841,7 +839,7 @@ xfs_ialloc(
> >  
> >  	if (xfs_sb_version_has_v3inode(&mp->m_sb)) {
> >  		inode_set_iversion(inode, 1);
> > -		ip->i_d.di_flags2 = 0;
> > +		ip->i_diflags2 = 0;
> >  		ip->i_cowextsize = 0;
> >  		ip->i_d.di_crtime = tv;
> >  	}
> > @@ -898,13 +896,13 @@ xfs_ialloc(
> >  
> >  			ip->i_diflags |= di_flags;
> >  		}
> > -		if (pip && (pip->i_d.di_flags2 & XFS_DIFLAG2_ANY)) {
> > -			if (pip->i_d.di_flags2 & XFS_DIFLAG2_COWEXTSIZE) {
> > -				ip->i_d.di_flags2 |= XFS_DIFLAG2_COWEXTSIZE;
> > +		if (pip && (pip->i_diflags2 & XFS_DIFLAG2_ANY)) {
> > +			if (pip->i_diflags2 & XFS_DIFLAG2_COWEXTSIZE) {
> > +				ip->i_diflags2 |= XFS_DIFLAG2_COWEXTSIZE;
> >  				ip->i_cowextsize = pip->i_cowextsize;
> >  			}
> > -			if (pip->i_d.di_flags2 & XFS_DIFLAG2_DAX)
> > -				ip->i_d.di_flags2 |= XFS_DIFLAG2_DAX;
> > +			if (pip->i_diflags2 & XFS_DIFLAG2_DAX)
> > +				ip->i_diflags2 |= XFS_DIFLAG2_DAX;
> >  		}
> >  		/* FALLTHROUGH */
> >  	case S_IFLNK:
> > @@ -1456,7 +1454,7 @@ xfs_itruncate_clear_reflink_flags(
> >  	dfork = XFS_IFORK_PTR(ip, XFS_DATA_FORK);
> >  	cfork = XFS_IFORK_PTR(ip, XFS_COW_FORK);
> >  	if (dfork->if_bytes == 0 && cfork->if_bytes == 0)
> > -		ip->i_d.di_flags2 &= ~XFS_DIFLAG2_REFLINK;
> > +		ip->i_diflags2 &= ~XFS_DIFLAG2_REFLINK;
> >  	if (cfork->if_bytes == 0)
> >  		xfs_inode_clear_cowblocks_tag(ip);
> >  }
> > @@ -2756,7 +2754,7 @@ xfs_ifree(
> >  
> >  	VFS_I(ip)->i_mode = 0;		/* mark incore inode as free */
> >  	ip->i_diflags = 0;
> > -	ip->i_d.di_flags2 = 0;
> > +	ip->i_diflags2 = 0;
> >  	ip->i_d.di_dmevmask = 0;
> >  	ip->i_forkoff = 0;		/* mark the attr fork not in use */
> >  	ip->i_df.if_format = XFS_DINODE_FMT_EXTENTS;
> > diff --git a/fs/xfs/xfs_inode.h b/fs/xfs/xfs_inode.h
> > index 7673c841d89154..709f04fadde65e 100644
> > --- a/fs/xfs/xfs_inode.h
> > +++ b/fs/xfs/xfs_inode.h
> > @@ -65,6 +65,7 @@ typedef struct xfs_inode {
> >  	};
> >  	uint8_t			i_forkoff;	/* attr fork offset >> 3 */
> >  	uint16_t		i_diflags;	/* XFS_DIFLAG_... */
> > +	uint64_t		i_diflags2;	/* XFS_DIFLAG2_... */
> >  
> >  	struct xfs_icdinode	i_d;		/* most of ondisk inode */
> >  
> > @@ -193,7 +194,7 @@ xfs_get_initial_prid(struct xfs_inode *dp)
> >  
> >  static inline bool xfs_is_reflink_inode(struct xfs_inode *ip)
> >  {
> > -	return ip->i_d.di_flags2 & XFS_DIFLAG2_REFLINK;
> > +	return ip->i_diflags2 & XFS_DIFLAG2_REFLINK;
> >  }
> >  
> >  /*
> > diff --git a/fs/xfs/xfs_inode_item.c b/fs/xfs/xfs_inode_item.c
> > index 6af8e829dd0172..04e671d2957ca2 100644
> > --- a/fs/xfs/xfs_inode_item.c
> > +++ b/fs/xfs/xfs_inode_item.c
> > @@ -342,7 +342,7 @@ xfs_inode_to_log_dinode(
> >  		to->di_changecount = inode_peek_iversion(inode);
> >  		to->di_crtime.t_sec = from->di_crtime.tv_sec;
> >  		to->di_crtime.t_nsec = from->di_crtime.tv_nsec;
> > -		to->di_flags2 = from->di_flags2;
> > +		to->di_flags2 = ip->i_diflags2;
> >  		to->di_cowextsize = ip->i_cowextsize;
> >  		to->di_ino = ip->i_ino;
> >  		to->di_lsn = lsn;
> > diff --git a/fs/xfs/xfs_ioctl.c b/fs/xfs/xfs_ioctl.c
> > index 326991f4d98096..d05b86e7930e84 100644
> > --- a/fs/xfs/xfs_ioctl.c
> > +++ b/fs/xfs/xfs_ioctl.c
> > @@ -1110,7 +1110,7 @@ xfs_fill_fsxattr(
> >  	simple_fill_fsxattr(fa, xfs_ip2xflags(ip));
> >  	fa->fsx_extsize = XFS_FSB_TO_B(mp, ip->i_extsize);
> >  	if (xfs_sb_version_has_v3inode(&mp->m_sb) &&
> > -	    (ip->i_d.di_flags2 & XFS_DIFLAG2_COWEXTSIZE))
> > +	    (ip->i_diflags2 & XFS_DIFLAG2_COWEXTSIZE))
> >  		fa->fsx_cowextsize = XFS_FSB_TO_B(mp, ip->i_cowextsize);
> >  	fa->fsx_projid = ip->i_projid;
> >  	if (ifp && (ifp->if_flags & XFS_IFEXTENTS))
> > @@ -1183,15 +1183,14 @@ xfs_flags2diflags2(
> >  	struct xfs_inode	*ip,
> >  	unsigned int		xflags)
> >  {
> > -	uint64_t		di_flags2 =
> > -		(ip->i_d.di_flags2 & XFS_DIFLAG2_REFLINK);
> > +	uint64_t		i_flags2 = (ip->i_diflags2 & XFS_DIFLAG2_REFLINK);
> >  
> >  	if (xflags & FS_XFLAG_DAX)
> > -		di_flags2 |= XFS_DIFLAG2_DAX;
> > +		i_flags2 |= XFS_DIFLAG2_DAX;
> >  	if (xflags & FS_XFLAG_COWEXTSIZE)
> > -		di_flags2 |= XFS_DIFLAG2_COWEXTSIZE;
> > +		i_flags2 |= XFS_DIFLAG2_COWEXTSIZE;
> >  
> > -	return di_flags2;
> > +	return i_flags2;
> >  }
> >  
> >  static int
> > @@ -1201,7 +1200,7 @@ xfs_ioctl_setattr_xflags(
> >  	struct fsxattr		*fa)
> >  {
> >  	struct xfs_mount	*mp = ip->i_mount;
> > -	uint64_t		di_flags2;
> > +	uint64_t		i_flags2;
> >  
> >  	/* Can't change realtime flag if any extents are allocated. */
> >  	if ((ip->i_df.if_nextents || ip->i_delayed_blks) &&
> > @@ -1217,19 +1216,19 @@ xfs_ioctl_setattr_xflags(
> >  
> >  	/* Clear reflink if we are actually able to set the rt flag. */
> >  	if ((fa->fsx_xflags & FS_XFLAG_REALTIME) && xfs_is_reflink_inode(ip))
> > -		ip->i_d.di_flags2 &= ~XFS_DIFLAG2_REFLINK;
> > +		ip->i_diflags2 &= ~XFS_DIFLAG2_REFLINK;
> >  
> >  	/* Don't allow us to set DAX mode for a reflinked file for now. */
> >  	if ((fa->fsx_xflags & FS_XFLAG_DAX) && xfs_is_reflink_inode(ip))
> >  		return -EINVAL;
> >  
> >  	/* diflags2 only valid for v3 inodes. */
> > -	di_flags2 = xfs_flags2diflags2(ip, fa->fsx_xflags);
> > -	if (di_flags2 && !xfs_sb_version_has_v3inode(&mp->m_sb))
> > +	i_flags2 = xfs_flags2diflags2(ip, fa->fsx_xflags);
> > +	if (i_flags2 && !xfs_sb_version_has_v3inode(&mp->m_sb))
> >  		return -EINVAL;
> >  
> >  	ip->i_diflags = xfs_flags2diflags(ip, fa->fsx_xflags);
> > -	ip->i_d.di_flags2 = di_flags2;
> > +	ip->i_diflags2 = i_flags2;
> >  
> >  	xfs_diflags_to_iflags(ip, false);
> >  	xfs_trans_ichgtime(tp, ip, XFS_ICHGTIME_CHG);
> > @@ -1575,7 +1574,7 @@ xfs_ioctl_setattr(
> >  	else
> >  		ip->i_extsize = 0;
> >  	if (xfs_sb_version_has_v3inode(&mp->m_sb) &&
> > -	    (ip->i_d.di_flags2 & XFS_DIFLAG2_COWEXTSIZE))
> > +	    (ip->i_diflags2 & XFS_DIFLAG2_COWEXTSIZE))
> >  		ip->i_cowextsize = fa->fsx_cowextsize >> mp->m_sb.sb_blocklog;
> >  	else
> >  		ip->i_cowextsize = 0;
> > diff --git a/fs/xfs/xfs_iops.c b/fs/xfs/xfs_iops.c
> > index f37154fc9828fd..3642f9935cae3f 100644
> > --- a/fs/xfs/xfs_iops.c
> > +++ b/fs/xfs/xfs_iops.c
> > @@ -1265,7 +1265,7 @@ xfs_inode_should_enable_dax(
> >  		return false;
> >  	if (ip->i_mount->m_flags & XFS_MOUNT_DAX_ALWAYS)
> >  		return true;
> > -	if (ip->i_d.di_flags2 & XFS_DIFLAG2_DAX)
> > +	if (ip->i_diflags2 & XFS_DIFLAG2_DAX)
> >  		return true;
> >  	return false;
> >  }
> > diff --git a/fs/xfs/xfs_itable.c b/fs/xfs/xfs_itable.c
> > index 7937af9f2ea779..4d1509437c3576 100644
> > --- a/fs/xfs/xfs_itable.c
> > +++ b/fs/xfs/xfs_itable.c
> > @@ -111,7 +111,7 @@ xfs_bulkstat_one_int(
> >  	buf->bs_version = XFS_BULKSTAT_VERSION_V5;
> >  
> >  	if (xfs_sb_version_has_v3inode(&mp->m_sb)) {
> > -		if (dic->di_flags2 & XFS_DIFLAG2_COWEXTSIZE)
> > +		if (ip->i_diflags2 & XFS_DIFLAG2_COWEXTSIZE)
> >  			buf->bs_cowextsize_blks = ip->i_cowextsize;
> >  	}
> >  
> > diff --git a/fs/xfs/xfs_reflink.c b/fs/xfs/xfs_reflink.c
> > index 0e07fa7e43117e..476ba54d84a9a3 100644
> > --- a/fs/xfs/xfs_reflink.c
> > +++ b/fs/xfs/xfs_reflink.c
> > @@ -882,7 +882,7 @@ xfs_reflink_set_inode_flag(
> >  	if (!xfs_is_reflink_inode(src)) {
> >  		trace_xfs_reflink_set_inode_flag(src);
> >  		xfs_trans_ijoin(tp, src, XFS_ILOCK_EXCL);
> > -		src->i_d.di_flags2 |= XFS_DIFLAG2_REFLINK;
> > +		src->i_diflags2 |= XFS_DIFLAG2_REFLINK;
> >  		xfs_trans_log_inode(tp, src, XFS_ILOG_CORE);
> >  		xfs_ifork_init_cow(src);
> >  	} else
> > @@ -894,7 +894,7 @@ xfs_reflink_set_inode_flag(
> >  	if (!xfs_is_reflink_inode(dest)) {
> >  		trace_xfs_reflink_set_inode_flag(dest);
> >  		xfs_trans_ijoin(tp, dest, XFS_ILOCK_EXCL);
> > -		dest->i_d.di_flags2 |= XFS_DIFLAG2_REFLINK;
> > +		dest->i_diflags2 |= XFS_DIFLAG2_REFLINK;
> >  		xfs_trans_log_inode(tp, dest, XFS_ILOG_CORE);
> >  		xfs_ifork_init_cow(dest);
> >  	} else
> > @@ -943,7 +943,7 @@ xfs_reflink_update_dest(
> >  
> >  	if (cowextsize) {
> >  		dest->i_cowextsize = cowextsize;
> > -		dest->i_d.di_flags2 |= XFS_DIFLAG2_COWEXTSIZE;
> > +		dest->i_diflags2 |= XFS_DIFLAG2_COWEXTSIZE;
> >  	}
> >  
> >  	xfs_trans_log_inode(tp, dest, XFS_ILOG_CORE);
> > @@ -1463,7 +1463,7 @@ xfs_reflink_clear_inode_flag(
> >  
> >  	/* Clear the inode flag. */
> >  	trace_xfs_reflink_unset_inode_flag(ip);
> > -	ip->i_d.di_flags2 &= ~XFS_DIFLAG2_REFLINK;
> > +	ip->i_diflags2 &= ~XFS_DIFLAG2_REFLINK;
> >  	xfs_inode_clear_cowblocks_tag(ip);
> >  	xfs_trans_log_inode(*tpp, ip, XFS_ILOG_CORE);
> >  
> > 
> 
> 
> 


-- 
chandan






[Index of Archives]     [XFS Filesystem Development (older mail)]     [Linux Filesystem Development]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux RAID]     [Linux SCSI]


  Powered by Linux