From: "Darrick J. Wong" <djwong@kernel.org>
To: djwong@kernel.org
Cc: linux-xfs@vger.kernel.org, david@fromorbit.com, hch@infradead.org
Subject: [PATCH 08/14] xfs: remove indirect calls from xfs_inode_walk{,_ag}
Date: Tue, 01 Jun 2021 17:53:16 -0700 [thread overview]
Message-ID: <162259519664.662681.8440195387091934320.stgit@locust> (raw)
In-Reply-To: <162259515220.662681.6750744293005850812.stgit@locust>
From: Darrick J. Wong <djwong@kernel.org>
It turns out that there is a 1:1 mapping between the execute and goal
parameters that are passed to xfs_inode_walk_ag:
xfs_blockgc_scan_inode <=> XFS_ICWALK_BLOCKGC
xfs_dqrele_inode <=> XFS_ICWALK_DQRELE
Because of this exact correspondence, we don't need the execute function
pointer and can replace it with a direct call.
For the price of a forward static declaration, we can eliminate the
indirect function call. This likely has a negligible impact on
performance (since the execute function runs transactions), but it also
simplifies the function signature.
Signed-off-by: Darrick J. Wong <djwong@kernel.org>
---
fs/xfs/xfs_icache.c | 46 ++++++++++++++++++++++------------------------
1 file changed, 22 insertions(+), 24 deletions(-)
diff --git a/fs/xfs/xfs_icache.c b/fs/xfs/xfs_icache.c
index 2e13e9347147..5c17bed8edb2 100644
--- a/fs/xfs/xfs_icache.c
+++ b/fs/xfs/xfs_icache.c
@@ -50,11 +50,9 @@ xfs_icwalk_tagged(enum xfs_icwalk_goal goal)
}
static int xfs_inode_walk(struct xfs_mount *mp,
- int (*execute)(struct xfs_inode *ip, void *args),
- void *args, enum xfs_icwalk_goal goal);
+ enum xfs_icwalk_goal goal, void *args);
static int xfs_inode_walk_ag(struct xfs_perag *pag,
- int (*execute)(struct xfs_inode *ip, void *args),
- void *args, enum xfs_icwalk_goal goal);
+ enum xfs_icwalk_goal goal, void *args);
/*
* Allocate and initialise an xfs_inode.
@@ -844,11 +842,11 @@ xfs_dqrele_all_inodes(
if (qflags & XFS_PQUOTA_ACCT)
eofb.eof_flags |= XFS_EOFB_DROP_PDQUOT;
- return xfs_inode_walk(mp, xfs_dqrele_inode, &eofb,
- XFS_ICWALK_DQRELE);
+ return xfs_inode_walk(mp, XFS_ICWALK_DQRELE, &eofb);
}
#else
# define xfs_dqrele_igrab(ip) (false)
+# define xfs_dqrele_inode(ip, priv) (0)
#endif /* CONFIG_XFS_QUOTA */
/*
@@ -1591,8 +1589,7 @@ xfs_blockgc_worker(
if (!sb_start_write_trylock(mp->m_super))
return;
- error = xfs_inode_walk_ag(pag, xfs_blockgc_scan_inode, NULL,
- XFS_ICWALK_BLOCKGC);
+ error = xfs_inode_walk_ag(pag, XFS_ICWALK_BLOCKGC, NULL);
if (error)
xfs_info(mp, "AG %u preallocation gc worker failed, err=%d",
pag->pag_agno, error);
@@ -1610,8 +1607,7 @@ xfs_blockgc_free_space(
{
trace_xfs_blockgc_free_space(mp, eofb, _RET_IP_);
- return xfs_inode_walk(mp, xfs_blockgc_scan_inode, eofb,
- XFS_ICWALK_BLOCKGC);
+ return xfs_inode_walk(mp, XFS_ICWALK_BLOCKGC, eofb);
}
/*
@@ -1698,15 +1694,14 @@ xfs_grabbed_for_walk(
}
/*
- * For a given per-AG structure @pag, grab, @execute, and rele all incore
- * inodes with the given radix tree @tag.
+ * For a given per-AG structure @pag and a goal, grab qualifying inodes and
+ * process them in some manner.
*/
static int
xfs_inode_walk_ag(
struct xfs_perag *pag,
- int (*execute)(struct xfs_inode *ip, void *args),
- void *args,
- enum xfs_icwalk_goal goal)
+ enum xfs_icwalk_goal goal,
+ void *args)
{
struct xfs_mount *mp = pag->pag_mount;
uint32_t first_index;
@@ -1777,7 +1772,14 @@ xfs_inode_walk_ag(
for (i = 0; i < nr_found; i++) {
if (!batch[i])
continue;
- error = execute(batch[i], args);
+ switch (goal) {
+ case XFS_ICWALK_DQRELE:
+ error = xfs_dqrele_inode(batch[i], args);
+ break;
+ case XFS_ICWALK_BLOCKGC:
+ error = xfs_blockgc_scan_inode(batch[i], args);
+ break;
+ }
xfs_irele(batch[i]);
if (error == -EAGAIN) {
skipped++;
@@ -1814,16 +1816,12 @@ xfs_inode_walk_get_perag(
return xfs_perag_get_tag(mp, agno, goal);
}
-/*
- * Call the @execute function on all incore inodes matching the radix tree
- * @tag.
- */
+/* Walk all incore inodes to achieve a given goal. */
static int
xfs_inode_walk(
struct xfs_mount *mp,
- int (*execute)(struct xfs_inode *ip, void *args),
- void *args,
- enum xfs_icwalk_goal goal)
+ enum xfs_icwalk_goal goal,
+ void *args)
{
struct xfs_perag *pag;
int error = 0;
@@ -1833,7 +1831,7 @@ xfs_inode_walk(
ag = 0;
while ((pag = xfs_inode_walk_get_perag(mp, ag, goal))) {
ag = pag->pag_agno + 1;
- error = xfs_inode_walk_ag(pag, execute, args, goal);
+ error = xfs_inode_walk_ag(pag, goal, args);
xfs_perag_put(pag);
if (error) {
last_error = error;
next prev parent reply other threads:[~2021-06-02 0:53 UTC|newest]
Thread overview: 29+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-06-02 0:52 [PATCHSET v5 00/14] xfs: clean up incore inode walk functions Darrick J. Wong
2021-06-02 0:52 ` [PATCH 01/14] xfs: move the quotaoff dqrele inode walk into xfs_icache.c Darrick J. Wong
2021-06-02 1:23 ` Dave Chinner
2021-06-02 0:52 ` [PATCH 02/14] xfs: detach inode dquots at the end of inactivation Darrick J. Wong
2021-06-02 0:52 ` [PATCH 03/14] xfs: move the inode walk functions further down Darrick J. Wong
2021-06-02 1:26 ` Dave Chinner
2021-06-02 0:52 ` [PATCH 04/14] xfs: pass the goal of the incore inode walk to xfs_inode_walk() Darrick J. Wong
2021-06-02 1:42 ` Dave Chinner
2021-06-02 0:53 ` [PATCH 05/14] xfs: separate the dqrele_all inode grab logic from xfs_inode_walk_ag_grab Darrick J. Wong
2021-06-02 1:51 ` Dave Chinner
2021-06-02 3:28 ` Darrick J. Wong
2021-06-02 0:53 ` [PATCH 06/14] xfs: move xfs_inew_wait call into xfs_dqrele_inode Darrick J. Wong
2021-06-02 1:52 ` Dave Chinner
2021-06-02 0:53 ` [PATCH 07/14] xfs: remove iter_flags parameter from xfs_inode_walk_* Darrick J. Wong
2021-06-02 1:53 ` Dave Chinner
2021-06-02 0:53 ` Darrick J. Wong [this message]
2021-06-02 2:00 ` [PATCH 08/14] xfs: remove indirect calls from xfs_inode_walk{,_ag} Dave Chinner
2021-06-02 0:53 ` [PATCH 09/14] xfs: clean up the blockgc grab and scan calls a little Darrick J. Wong
2021-06-02 0:53 ` [PATCH 10/14] xfs: clean up xfs_dqrele_inode calling conventions Darrick J. Wong
2021-06-02 0:53 ` [PATCH 11/14] xfs: fix radix tree tag signs Darrick J. Wong
2021-06-02 2:02 ` Dave Chinner
2021-06-02 0:53 ` [PATCH 12/14] xfs: pass struct xfs_eofblocks to the inode scan callback Darrick J. Wong
2021-06-02 2:04 ` Dave Chinner
2021-06-02 6:15 ` Darrick J. Wong
2021-06-02 0:53 ` [PATCH 13/14] xfs: merge xfs_reclaim_inodes_ag into xfs_inode_walk_ag Darrick J. Wong
2021-06-02 2:10 ` Dave Chinner
2021-06-02 6:16 ` Darrick J. Wong
2021-06-02 0:53 ` [PATCH 14/14] xfs: refactor per-AG inode tagging functions Darrick J. Wong
2021-06-02 2:22 ` Dave Chinner
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=162259519664.662681.8440195387091934320.stgit@locust \
--to=djwong@kernel.org \
--cc=david@fromorbit.com \
--cc=hch@infradead.org \
--cc=linux-xfs@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox