From: Allison Henderson <allison.henderson@oracle.com>
To: linux-xfs@vger.kernel.org
Subject: [PATCH v18 09/11] xfs: Hoist node transaction handling
Date: Wed, 28 Apr 2021 01:09:17 -0700 [thread overview]
Message-ID: <20210428080919.20331-10-allison.henderson@oracle.com> (raw)
In-Reply-To: <20210428080919.20331-1-allison.henderson@oracle.com>
This patch basically hoists the node transaction handling around the
leaf code we just hoisted. This will helps setup this area for the
state machine since the goto is easily replaced with a state since it
ends with a transaction roll.
Signed-off-by: Allison Henderson <allison.henderson@oracle.com>
Reviewed-by: Brian Foster <bfoster@redhat.com>
Reviewed-by: Darrick J. Wong <djwong@kernel.org>
Reviewed-by: Chandan Babu R <chandanrlinux@gmail.com>
---
fs/xfs/libxfs/xfs_attr.c | 55 +++++++++++++++++++++++++-----------------------
1 file changed, 29 insertions(+), 26 deletions(-)
diff --git a/fs/xfs/libxfs/xfs_attr.c b/fs/xfs/libxfs/xfs_attr.c
index 6edc3db..21f862e 100644
--- a/fs/xfs/libxfs/xfs_attr.c
+++ b/fs/xfs/libxfs/xfs_attr.c
@@ -309,10 +309,36 @@ xfs_attr_set_args(
if (xfs_attr_is_leaf(dp)) {
error = xfs_attr_leaf_try_add(args, bp);
- if (error == -ENOSPC)
+ if (error == -ENOSPC) {
+ /*
+ * Promote the attribute list to the Btree format.
+ */
+ error = xfs_attr3_leaf_to_node(args);
+ if (error)
+ return error;
+
+ /*
+ * Finish any deferred work items and roll the transaction once
+ * more. The goal here is to call node_addname with the inode
+ * and transaction in the same state (inode locked and joined,
+ * transaction clean) no matter how we got to this step.
+ */
+ error = xfs_defer_finish(&args->trans);
+ if (error)
+ return error;
+
+ /*
+ * Commit the current trans (including the inode) and
+ * start a new one.
+ */
+ error = xfs_trans_roll_inode(&args->trans, dp);
+ if (error)
+ return error;
+
goto node;
- else if (error)
+ } else if (error) {
return error;
+ }
/*
* Commit the transaction that added the attr name so that
@@ -402,32 +428,9 @@ xfs_attr_set_args(
/* bp is gone due to xfs_da_shrink_inode */
return error;
+ }
node:
- /*
- * Promote the attribute list to the Btree format.
- */
- error = xfs_attr3_leaf_to_node(args);
- if (error)
- return error;
-
- /*
- * Finish any deferred work items and roll the transaction once
- * more. The goal here is to call node_addname with the inode
- * and transaction in the same state (inode locked and joined,
- * transaction clean) no matter how we got to this step.
- */
- error = xfs_defer_finish(&args->trans);
- if (error)
- return error;
- /*
- * Commit the current trans (including the inode) and
- * start a new one.
- */
- error = xfs_trans_roll_inode(&args->trans, dp);
- if (error)
- return error;
- }
do {
error = xfs_attr_node_addname_find_attr(args, &state);
--
2.7.4
next prev parent reply other threads:[~2021-04-28 8:09 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-04-28 8:09 [PATCH v18 00/11] Delay Ready Attributes Allison Henderson
2021-04-28 8:09 ` [PATCH v18 01/11] xfs: Reverse apply 72b97ea40d Allison Henderson
2021-04-28 8:09 ` [PATCH v18 02/11] xfs: Add xfs_attr_node_remove_name Allison Henderson
2021-04-28 8:09 ` [PATCH v18 03/11] xfs: Hoist xfs_attr_set_shortform Allison Henderson
2021-04-28 8:09 ` [PATCH v18 04/11] xfs: Add helper xfs_attr_set_fmt Allison Henderson
2021-04-28 8:09 ` [PATCH v18 05/11] xfs: Separate xfs_attr_node_addname and xfs_attr_node_addname_clear_incomplete Allison Henderson
2021-04-29 7:40 ` Chandan Babu R
2021-04-28 8:09 ` [PATCH v18 06/11] xfs: Add helper xfs_attr_node_addname_find_attr Allison Henderson
2021-04-28 8:09 ` [PATCH v18 07/11] xfs: Hoist xfs_attr_node_addname Allison Henderson
2021-04-28 8:09 ` [PATCH v18 08/11] xfs: Hoist xfs_attr_leaf_addname Allison Henderson
2021-04-28 8:09 ` Allison Henderson [this message]
2021-04-28 8:09 ` [PATCH v18 10/11] xfs: Add delay ready attr remove routines Allison Henderson
2021-04-29 7:49 ` Chandan Babu R
2021-04-29 7:53 ` Chandan Babu R
2021-04-29 14:07 ` Brian Foster
2021-04-28 8:09 ` [PATCH v18 11/11] xfs: Add delay ready attr set routines Allison Henderson
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=20210428080919.20331-10-allison.henderson@oracle.com \
--to=allison.henderson@oracle.com \
--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