提交 33540408 编写于 作者: D David Chinner 提交者: Lachlan McIlroy

[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: NDavid Chinner <dgc@sgi.com>
Signed-off-by: NChristoph Hellwig <hch@infradead.org>
Signed-off-by: NLachlan McIlroy <lachlan@sgi.com>
上级 bad55843
...@@ -2118,13 +2118,6 @@ xfs_iunlink_remove( ...@@ -2118,13 +2118,6 @@ xfs_iunlink_remove(
return 0; 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 STATIC void
xfs_ifree_cluster( xfs_ifree_cluster(
xfs_inode_t *free_ip, xfs_inode_t *free_ip,
...@@ -3004,7 +2997,6 @@ xfs_iflush_cluster( ...@@ -3004,7 +2997,6 @@ xfs_iflush_cluster(
int ilist_size; int ilist_size;
xfs_inode_t **ilist; xfs_inode_t **ilist;
xfs_inode_t *iq; xfs_inode_t *iq;
xfs_inode_log_item_t *iip;
int nr_found; int nr_found;
int clcount = 0; int clcount = 0;
int bufwasdelwri; int bufwasdelwri;
...@@ -3040,13 +3032,8 @@ xfs_iflush_cluster( ...@@ -3040,13 +3032,8 @@ xfs_iflush_cluster(
* is a candidate for flushing. These checks will be repeated * is a candidate for flushing. These checks will be repeated
* later after the appropriate locks are acquired. * later after the appropriate locks are acquired.
*/ */
iip = iq->i_itemp; if (xfs_inode_clean(iq) && xfs_ipincount(iq) == 0)
if ((iq->i_update_core == 0) &&
((iip == NULL) ||
!(iip->ili_format.ilf_fields & XFS_ILOG_ALL)) &&
xfs_ipincount(iq) == 0) {
continue; continue;
}
/* /*
* Try to get locks. If any are unavailable or it is pinned, * Try to get locks. If any are unavailable or it is pinned,
...@@ -3069,10 +3056,8 @@ xfs_iflush_cluster( ...@@ -3069,10 +3056,8 @@ xfs_iflush_cluster(
* arriving here means that this inode can be flushed. First * arriving here means that this inode can be flushed. First
* re-check that it's dirty before flushing. * re-check that it's dirty before flushing.
*/ */
iip = iq->i_itemp; if (!xfs_inode_clean(iq)) {
if ((iq->i_update_core != 0) || ((iip != NULL) && int error;
(iip->ili_format.ilf_fields & XFS_ILOG_ALL))) {
int error;
error = xfs_iflush_int(iq, bp); error = xfs_iflush_int(iq, bp);
if (error) { if (error) {
xfs_iunlock(iq, XFS_ILOCK_SHARED); xfs_iunlock(iq, XFS_ILOCK_SHARED);
...@@ -3176,8 +3161,7 @@ xfs_iflush( ...@@ -3176,8 +3161,7 @@ xfs_iflush(
* If the inode isn't dirty, then just release the inode * If the inode isn't dirty, then just release the inode
* flush lock and do nothing. * flush lock and do nothing.
*/ */
if ((ip->i_update_core == 0) && if (xfs_inode_clean(ip)) {
((iip == NULL) || !(iip->ili_format.ilf_fields & XFS_ILOG_ALL))) {
ASSERT((iip != NULL) ? ASSERT((iip != NULL) ?
!(iip->ili_item.li_flags & XFS_LI_IN_AIL) : 1); !(iip->ili_item.li_flags & XFS_LI_IN_AIL) : 1);
xfs_ifunlock(ip); xfs_ifunlock(ip);
...@@ -3343,8 +3327,7 @@ xfs_iflush_int( ...@@ -3343,8 +3327,7 @@ xfs_iflush_int(
* If the inode isn't dirty, then just release the inode * If the inode isn't dirty, then just release the inode
* flush lock and do nothing. * flush lock and do nothing.
*/ */
if ((ip->i_update_core == 0) && if (xfs_inode_clean(ip)) {
((iip == NULL) || !(iip->ili_format.ilf_fields & XFS_ILOG_ALL))) {
xfs_ifunlock(ip); xfs_ifunlock(ip);
return 0; return 0;
} }
......
...@@ -168,6 +168,14 @@ static inline int xfs_ilog_fext(int w) ...@@ -168,6 +168,14 @@ static inline int xfs_ilog_fext(int w)
return (w == XFS_DATA_FORK ? XFS_ILOG_DEXT : XFS_ILOG_AEXT); 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__ #ifdef __KERNEL__
extern void xfs_inode_item_init(struct xfs_inode *, struct xfs_mount *); extern void xfs_inode_item_init(struct xfs_inode *, struct xfs_mount *);
......
...@@ -3454,7 +3454,6 @@ xfs_inode_flush( ...@@ -3454,7 +3454,6 @@ xfs_inode_flush(
int flags) int flags)
{ {
xfs_mount_t *mp = ip->i_mount; xfs_mount_t *mp = ip->i_mount;
xfs_inode_log_item_t *iip = ip->i_itemp;
int error = 0; int error = 0;
if (XFS_FORCED_SHUTDOWN(mp)) if (XFS_FORCED_SHUTDOWN(mp))
...@@ -3464,8 +3463,7 @@ xfs_inode_flush( ...@@ -3464,8 +3463,7 @@ xfs_inode_flush(
* Bypass inodes which have already been cleaned by * Bypass inodes which have already been cleaned by
* the inode flush clustering code inside xfs_iflush * the inode flush clustering code inside xfs_iflush
*/ */
if ((ip->i_update_core == 0) && if (xfs_inode_clean(ip))
((iip == NULL) || !(iip->ili_format.ilf_fields & XFS_ILOG_ALL)))
return 0; return 0;
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册