Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 33540408 authored by David Chinner's avatar David Chinner Committed by Lachlan McIlroy
Browse files

[XFS] Use xfs_inode_clean() in more places



Remove open coded checks for the whether the inode is clean and replace
them with an inlined function.

SGI-PV: 977461
SGI-Modid: xfs-linux-melb:xfs-kern:30503a

Signed-off-by: default avatarDavid Chinner <dgc@sgi.com>
Signed-off-by: default avatarChristoph Hellwig <hch@infradead.org>
Signed-off-by: default avatarLachlan McIlroy <lachlan@sgi.com>
parent bad55843
Loading
Loading
Loading
Loading
+5 −22
Original line number Diff line number Diff line
@@ -2118,13 +2118,6 @@ xfs_iunlink_remove(
	return 0;
}

STATIC_INLINE int xfs_inode_clean(xfs_inode_t *ip)
{
	return (((ip->i_itemp == NULL) ||
		!(ip->i_itemp->ili_format.ilf_fields & XFS_ILOG_ALL)) &&
		(ip->i_update_core == 0));
}

STATIC void
xfs_ifree_cluster(
	xfs_inode_t	*free_ip,
@@ -3004,7 +2997,6 @@ xfs_iflush_cluster(
	int			ilist_size;
	xfs_inode_t		**ilist;
	xfs_inode_t		*iq;
	xfs_inode_log_item_t	*iip;
	int			nr_found;
	int			clcount = 0;
	int			bufwasdelwri;
@@ -3040,13 +3032,8 @@ xfs_iflush_cluster(
		 * is a candidate for flushing.  These checks will be repeated
		 * later after the appropriate locks are acquired.
		 */
		iip = iq->i_itemp;
		if ((iq->i_update_core == 0) &&
		    ((iip == NULL) ||
		     !(iip->ili_format.ilf_fields & XFS_ILOG_ALL)) &&
		      xfs_ipincount(iq) == 0) {
		if (xfs_inode_clean(iq) && xfs_ipincount(iq) == 0)
			continue;
		}

		/*
		 * Try to get locks.  If any are unavailable or it is pinned,
@@ -3069,9 +3056,7 @@ xfs_iflush_cluster(
		 * arriving here means that this inode can be flushed.  First
		 * re-check that it's dirty before flushing.
		 */
		iip = iq->i_itemp;
		if ((iq->i_update_core != 0) || ((iip != NULL) &&
		     (iip->ili_format.ilf_fields & XFS_ILOG_ALL))) {
		if (!xfs_inode_clean(iq)) {
			int	error;
			error = xfs_iflush_int(iq, bp);
			if (error) {
@@ -3176,8 +3161,7 @@ xfs_iflush(
	 * If the inode isn't dirty, then just release the inode
	 * flush lock and do nothing.
	 */
	if ((ip->i_update_core == 0) &&
	    ((iip == NULL) || !(iip->ili_format.ilf_fields & XFS_ILOG_ALL))) {
	if (xfs_inode_clean(ip)) {
		ASSERT((iip != NULL) ?
			 !(iip->ili_item.li_flags & XFS_LI_IN_AIL) : 1);
		xfs_ifunlock(ip);
@@ -3343,8 +3327,7 @@ xfs_iflush_int(
	 * If the inode isn't dirty, then just release the inode
	 * flush lock and do nothing.
	 */
	if ((ip->i_update_core == 0) &&
	    ((iip == NULL) || !(iip->ili_format.ilf_fields & XFS_ILOG_ALL))) {
	if (xfs_inode_clean(ip)) {
		xfs_ifunlock(ip);
		return 0;
	}
+8 −0
Original line number Diff line number Diff line
@@ -168,6 +168,14 @@ static inline int xfs_ilog_fext(int w)
	return (w == XFS_DATA_FORK ? XFS_ILOG_DEXT : XFS_ILOG_AEXT);
}

static inline int xfs_inode_clean(xfs_inode_t *ip)
{
	return (!ip->i_itemp ||
		!(ip->i_itemp->ili_format.ilf_fields & XFS_ILOG_ALL)) &&
	       !ip->i_update_core;
}


#ifdef __KERNEL__

extern void xfs_inode_item_init(struct xfs_inode *, struct xfs_mount *);
+1 −3
Original line number Diff line number Diff line
@@ -3454,7 +3454,6 @@ xfs_inode_flush(
	int		flags)
{
	xfs_mount_t	*mp = ip->i_mount;
	xfs_inode_log_item_t *iip = ip->i_itemp;
	int		error = 0;

	if (XFS_FORCED_SHUTDOWN(mp))
@@ -3464,8 +3463,7 @@ xfs_inode_flush(
	 * Bypass inodes which have already been cleaned by
	 * the inode flush clustering code inside xfs_iflush
	 */
	if ((ip->i_update_core == 0) &&
	    ((iip == NULL) || !(iip->ili_format.ilf_fields & XFS_ILOG_ALL)))
	if (xfs_inode_clean(ip))
		return 0;

	/*