提交 55b36312 编写于 作者: D Darrick J. Wong 提交者: Zheng Zengkai

xfs: remove iter_flags parameter from xfs_inode_walk_*

mainline-inclusion
from mainline-v5.13-rc4
commit 7fdff526
category: bugfix
bugzilla: https://gitee.com/openeuler/kernel/issues/I4KIAO
CVE: NA

Reference: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=7fdff52623b4df9c9ae665fe8bb727978c29414e

-------------------------------------------------

The sole iter_flags is XFS_INODE_WALK_INEW_WAIT, and there are no users.
Remove the flag, and the parameter, and all the code that used it.
Signed-off-by: NDarrick J. Wong <djwong@kernel.org>
Reviewed-by: NDave Chinner <dchinner@redhat.com>
Signed-off-by: NLihong Kou <koulihong@huawei.com>
Reviewed-by: NZhang Yi <yi.zhang@huawei.com>
Signed-off-by: NZheng Zengkai <zhengzengkai@huawei.com>
上级 85d5f361
...@@ -54,10 +54,10 @@ xfs_icwalk_tag(enum xfs_icwalk_goal goal) ...@@ -54,10 +54,10 @@ xfs_icwalk_tag(enum xfs_icwalk_goal goal)
return goal < 0 ? XFS_ICWALK_NULL_TAG : goal; return goal < 0 ? XFS_ICWALK_NULL_TAG : goal;
} }
static int xfs_icwalk(struct xfs_mount *mp, int iter_flags, static int xfs_icwalk(struct xfs_mount *mp,
int (*execute)(struct xfs_inode *ip, void *args), int (*execute)(struct xfs_inode *ip, void *args),
void *args, enum xfs_icwalk_goal goal); void *args, enum xfs_icwalk_goal goal);
static int xfs_icwalk_ag(struct xfs_perag *pag, int iter_flags, static int xfs_icwalk_ag(struct xfs_perag *pag,
int (*execute)(struct xfs_inode *ip, void *args), int (*execute)(struct xfs_inode *ip, void *args),
void *args, enum xfs_icwalk_goal goal); void *args, enum xfs_icwalk_goal goal);
...@@ -281,7 +281,7 @@ xfs_inode_clear_reclaim_tag( ...@@ -281,7 +281,7 @@ xfs_inode_clear_reclaim_tag(
xfs_perag_clear_reclaim_tag(pag); xfs_perag_clear_reclaim_tag(pag);
} }
static void static inline void
xfs_inew_wait( xfs_inew_wait(
struct xfs_inode *ip) struct xfs_inode *ip)
{ {
...@@ -855,7 +855,7 @@ xfs_dqrele_all_inodes( ...@@ -855,7 +855,7 @@ xfs_dqrele_all_inodes(
if (qflags & XFS_PQUOTA_ACCT) if (qflags & XFS_PQUOTA_ACCT)
eofb.eof_flags |= XFS_ICWALK_FLAG_DROP_PDQUOT; eofb.eof_flags |= XFS_ICWALK_FLAG_DROP_PDQUOT;
return xfs_icwalk(mp, 0, xfs_dqrele_inode, &eofb, XFS_ICWALK_DQRELE); return xfs_icwalk(mp, xfs_dqrele_inode, &eofb, XFS_ICWALK_DQRELE);
} }
#else #else
# define xfs_dqrele_igrab(ip) (false) # define xfs_dqrele_igrab(ip) (false)
...@@ -1540,11 +1540,9 @@ xfs_blockgc_start( ...@@ -1540,11 +1540,9 @@ xfs_blockgc_start(
*/ */
static bool static bool
xfs_blockgc_igrab( xfs_blockgc_igrab(
struct xfs_inode *ip, struct xfs_inode *ip)
int flags)
{ {
struct inode *inode = VFS_I(ip); struct inode *inode = VFS_I(ip);
bool newinos = !!(flags & XFS_INODE_WALK_INEW_WAIT);
ASSERT(rcu_read_lock_held()); ASSERT(rcu_read_lock_held());
...@@ -1554,8 +1552,7 @@ xfs_blockgc_igrab( ...@@ -1554,8 +1552,7 @@ xfs_blockgc_igrab(
goto out_unlock_noent; goto out_unlock_noent;
/* avoid new or reclaimable inodes. Leave for reclaim code to flush */ /* avoid new or reclaimable inodes. Leave for reclaim code to flush */
if ((!newinos && __xfs_iflags_test(ip, XFS_INEW)) || if (__xfs_iflags_test(ip, XFS_INEW | XFS_IRECLAIMABLE | XFS_IRECLAIM))
__xfs_iflags_test(ip, XFS_IRECLAIMABLE | XFS_IRECLAIM))
goto out_unlock_noent; goto out_unlock_noent;
spin_unlock(&ip->i_flags_lock); spin_unlock(&ip->i_flags_lock);
...@@ -1607,7 +1604,7 @@ xfs_blockgc_worker( ...@@ -1607,7 +1604,7 @@ xfs_blockgc_worker(
if (!sb_start_write_trylock(mp->m_super)) if (!sb_start_write_trylock(mp->m_super))
return; return;
error = xfs_icwalk_ag(pag, 0, xfs_blockgc_scan_inode, NULL, error = xfs_icwalk_ag(pag, xfs_blockgc_scan_inode, NULL,
XFS_ICWALK_BLOCKGC); XFS_ICWALK_BLOCKGC);
if (error) if (error)
xfs_info(mp, "AG %u preallocation gc worker failed, err=%d", xfs_info(mp, "AG %u preallocation gc worker failed, err=%d",
...@@ -1626,7 +1623,7 @@ xfs_blockgc_free_space( ...@@ -1626,7 +1623,7 @@ xfs_blockgc_free_space(
{ {
trace_xfs_blockgc_free_space(mp, eofb, _RET_IP_); trace_xfs_blockgc_free_space(mp, eofb, _RET_IP_);
return xfs_icwalk(mp, 0, xfs_blockgc_scan_inode, eofb, return xfs_icwalk(mp, xfs_blockgc_scan_inode, eofb,
XFS_ICWALK_BLOCKGC); XFS_ICWALK_BLOCKGC);
} }
...@@ -1706,14 +1703,13 @@ xfs_blockgc_free_quota( ...@@ -1706,14 +1703,13 @@ xfs_blockgc_free_quota(
static inline bool static inline bool
xfs_icwalk_igrab( xfs_icwalk_igrab(
enum xfs_icwalk_goal goal, enum xfs_icwalk_goal goal,
struct xfs_inode *ip, struct xfs_inode *ip)
int iter_flags)
{ {
switch (goal) { switch (goal) {
case XFS_ICWALK_DQRELE: case XFS_ICWALK_DQRELE:
return xfs_dqrele_igrab(ip); return xfs_dqrele_igrab(ip);
case XFS_ICWALK_BLOCKGC: case XFS_ICWALK_BLOCKGC:
return xfs_blockgc_igrab(ip, iter_flags); return xfs_blockgc_igrab(ip);
default: default:
return false; return false;
} }
...@@ -1726,7 +1722,6 @@ xfs_icwalk_igrab( ...@@ -1726,7 +1722,6 @@ xfs_icwalk_igrab(
static int static int
xfs_icwalk_ag( xfs_icwalk_ag(
struct xfs_perag *pag, struct xfs_perag *pag,
int iter_flags,
int (*execute)(struct xfs_inode *ip, void *args), int (*execute)(struct xfs_inode *ip, void *args),
void *args, void *args,
enum xfs_icwalk_goal goal) enum xfs_icwalk_goal goal)
...@@ -1773,7 +1768,7 @@ xfs_icwalk_ag( ...@@ -1773,7 +1768,7 @@ xfs_icwalk_ag(
for (i = 0; i < nr_found; i++) { for (i = 0; i < nr_found; i++) {
struct xfs_inode *ip = batch[i]; struct xfs_inode *ip = batch[i];
if (done || !xfs_icwalk_igrab(goal, ip, iter_flags)) if (done || !xfs_icwalk_igrab(goal, ip))
batch[i] = NULL; batch[i] = NULL;
/* /*
...@@ -1801,9 +1796,6 @@ xfs_icwalk_ag( ...@@ -1801,9 +1796,6 @@ xfs_icwalk_ag(
for (i = 0; i < nr_found; i++) { for (i = 0; i < nr_found; i++) {
if (!batch[i]) if (!batch[i])
continue; continue;
if ((iter_flags & XFS_INODE_WALK_INEW_WAIT) &&
xfs_iflags_test(batch[i], XFS_INEW))
xfs_inew_wait(batch[i]);
error = execute(batch[i], args); error = execute(batch[i], args);
xfs_irele(batch[i]); xfs_irele(batch[i]);
if (error == -EAGAIN) { if (error == -EAGAIN) {
...@@ -1850,7 +1842,6 @@ xfs_icwalk_get_perag( ...@@ -1850,7 +1842,6 @@ xfs_icwalk_get_perag(
static int static int
xfs_icwalk( xfs_icwalk(
struct xfs_mount *mp, struct xfs_mount *mp,
int iter_flags,
int (*execute)(struct xfs_inode *ip, void *args), int (*execute)(struct xfs_inode *ip, void *args),
void *args, void *args,
enum xfs_icwalk_goal goal) enum xfs_icwalk_goal goal)
...@@ -1862,7 +1853,7 @@ xfs_icwalk( ...@@ -1862,7 +1853,7 @@ xfs_icwalk(
while ((pag = xfs_icwalk_get_perag(mp, agno, goal))) { while ((pag = xfs_icwalk_get_perag(mp, agno, goal))) {
agno = pag->pag_agno + 1; agno = pag->pag_agno + 1;
error = xfs_icwalk_ag(pag, iter_flags, execute, args, goal); error = xfs_icwalk_ag(pag, execute, args, goal);
xfs_perag_put(pag); xfs_perag_put(pag);
if (error) { if (error) {
last_error = error; last_error = error;
......
...@@ -25,11 +25,6 @@ struct xfs_eofblocks { ...@@ -25,11 +25,6 @@ struct xfs_eofblocks {
#define XFS_IGET_DONTCACHE 0x4 #define XFS_IGET_DONTCACHE 0x4
#define XFS_IGET_INCORE 0x8 /* don't read from disk or reinit */ #define XFS_IGET_INCORE 0x8 /* don't read from disk or reinit */
/*
* flags for AG inode iterator
*/
#define XFS_INODE_WALK_INEW_WAIT 0x1 /* wait on new inodes */
int xfs_iget(struct xfs_mount *mp, struct xfs_trans *tp, xfs_ino_t ino, int xfs_iget(struct xfs_mount *mp, struct xfs_trans *tp, xfs_ino_t ino,
uint flags, uint lock_flags, xfs_inode_t **ipp); uint flags, uint lock_flags, xfs_inode_t **ipp);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册