From: "Darrick J. Wong" <djwong@kernel.org>
To: Dave Chinner <david@fromorbit.com>
Cc: linux-xfs@vger.kernel.org
Subject: Re: [PATCH 04/13] xfs: embed the xlog_op_header in the unmount record
Date: Thu, 25 Feb 2021 18:57:27 -0800 [thread overview]
Message-ID: <20210226025727.GO7272@magnolia> (raw)
In-Reply-To: <20210224063459.3436852-5-david@fromorbit.com>
On Wed, Feb 24, 2021 at 05:34:50PM +1100, Dave Chinner wrote:
> Subject: xfs: embed the xlog_op_header in the unmount record
Uh... isn't this embedding the xlog op header in the *commit* record?
(Just saying for my own lazy purposes because my scripts choke badly
when a patchset has multiple patches with the same subject...)
--D
> Remove the final case where xlog_write() has to prepend an opheader
> to a log transaction. Similar to the start record, the commit record
> is just an empty opheader with a XLOG_COMMIT_TRANS type, so we can
> just make this the payload for the region being passed to
> xlog_write() and remove the special handling in xlog_write() for
> the commit record.
>
> Signed-off-by: Dave Chinner <dchinner@redhat.com>
> ---
> fs/xfs/xfs_log.c | 33 +++++++++++++++------------------
> 1 file changed, 15 insertions(+), 18 deletions(-)
>
> diff --git a/fs/xfs/xfs_log.c b/fs/xfs/xfs_log.c
> index f3cb7482dfea..78b9c11b585f 100644
> --- a/fs/xfs/xfs_log.c
> +++ b/fs/xfs/xfs_log.c
> @@ -1596,9 +1596,14 @@ xlog_commit_record(
> struct xlog_in_core **iclog,
> xfs_lsn_t *lsn)
> {
> + struct xlog_op_header ophdr = {
> + .oh_clientid = XFS_TRANSACTION,
> + .oh_tid = cpu_to_be32(ticket->t_tid),
> + .oh_flags = XLOG_COMMIT_TRANS,
> + };
> struct xfs_log_iovec reg = {
> - .i_addr = NULL,
> - .i_len = 0,
> + .i_addr = &ophdr,
> + .i_len = sizeof(struct xlog_op_header),
> .i_type = XLOG_REG_TYPE_COMMIT,
> };
> struct xfs_log_vec vec = {
> @@ -1610,6 +1615,8 @@ xlog_commit_record(
> if (XLOG_FORCED_SHUTDOWN(log))
> return -EIO;
>
> + /* account for space used by record data */
> + ticket->t_curr_res -= reg.i_len;
> error = xlog_write(log, &vec, ticket, lsn, iclog, XLOG_COMMIT_TRANS);
> if (error)
> xfs_force_shutdown(log->l_mp, SHUTDOWN_LOG_IO_ERROR);
> @@ -2233,11 +2240,10 @@ xlog_write_calc_vec_length(
>
> /* Don't account for regions with embedded ophdrs */
> if (optype && headers > 0) {
> - if (optype & XLOG_UNMOUNT_TRANS)
> - headers--;
> + headers--;
> if (optype & XLOG_START_TRANS) {
> - ASSERT(headers >= 2);
> - headers -= 2;
> + ASSERT(headers >= 1);
> + headers--;
> }
> }
>
> @@ -2447,14 +2453,6 @@ xlog_write(
> int data_cnt = 0;
> int error = 0;
>
> - /*
> - * If this is a commit or unmount transaction, we don't need a start
> - * record to be written. We do, however, have to account for the commit
> - * header that gets written. Hence we always have to account for an
> - * extra xlog_op_header here for commit records.
> - */
> - if (optype & XLOG_COMMIT_TRANS)
> - ticket->t_curr_res -= sizeof(struct xlog_op_header);
> if (ticket->t_curr_res < 0) {
> xfs_alert_tag(log->l_mp, XFS_PTAG_LOGRES,
> "ctx ticket reservation ran out. Need to up reservation");
> @@ -2518,14 +2516,13 @@ xlog_write(
> /*
> * The XLOG_START_TRANS has embedded ophdrs for the
> * start record and transaction header. They will always
> - * be the first two regions in the lv chain.
> + * be the first two regions in the lv chain. Commit and
> + * unmount records also have embedded ophdrs.
> */
> - if (optype & XLOG_START_TRANS) {
> + if (optype) {
> ophdr = reg->i_addr;
> if (index)
> optype &= ~XLOG_START_TRANS;
> - } else if (optype & XLOG_UNMOUNT_TRANS) {
> - ophdr = reg->i_addr;
> } else {
> ophdr = xlog_write_setup_ophdr(log, ptr,
> ticket, optype);
> --
> 2.28.0
>
next prev parent reply other threads:[~2021-02-26 2:58 UTC|newest]
Thread overview: 32+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-02-24 6:34 [PATCH 0/13] xfs: rewrite xlog_write() Dave Chinner
2021-02-24 6:34 ` [PATCH 01/13] xfs: factor out the CIL transaction header building Dave Chinner
2021-02-25 9:12 ` Christoph Hellwig
2021-02-24 6:34 ` [PATCH 02/13] xfs: only CIL pushes require a start record Dave Chinner
2021-02-25 9:15 ` Christoph Hellwig
2021-02-25 22:11 ` Dave Chinner
2021-02-24 6:34 ` [PATCH 03/13] xfs: embed the xlog_op_header in the unmount record Dave Chinner
2021-02-25 9:26 ` Christoph Hellwig
2021-02-24 6:34 ` [PATCH 04/13] " Dave Chinner
2021-02-25 9:38 ` Christoph Hellwig
2021-02-25 22:13 ` Dave Chinner
2021-02-26 2:57 ` Darrick J. Wong [this message]
2021-02-26 4:23 ` Dave Chinner
2021-02-24 6:34 ` [PATCH 05/13] xfs: log tickets don't need log client id Dave Chinner
2021-02-25 9:20 ` Christoph Hellwig
2021-02-24 6:34 ` [PATCH 06/13] xfs: move log iovec alignment to preparation function Dave Chinner
2021-02-25 9:39 ` Christoph Hellwig
2021-02-24 6:34 ` [PATCH 07/13] xfs: reserve space and initialise xlog_op_header in item formatting Dave Chinner
2021-02-25 18:27 ` Christoph Hellwig
2021-02-25 22:16 ` Dave Chinner
2021-02-24 6:34 ` [PATCH 08/13] xfs: log ticket region debug is largely useless Dave Chinner
2021-02-25 9:21 ` Christoph Hellwig
2021-02-24 6:34 ` [PATCH 09/13] xfs: pass lv chain length and size into xlog_write() Dave Chinner
2021-02-25 18:30 ` Christoph Hellwig
2021-02-24 6:34 ` [PATCH 10/13] xfs: introduce xlog_write_single() Dave Chinner
2021-02-25 18:43 ` Christoph Hellwig
2021-02-25 22:21 ` Dave Chinner
2021-02-24 6:34 ` [PATCH 11/13] xfs:_introduce xlog_write_partial() Dave Chinner
2021-02-25 18:54 ` Christoph Hellwig
2021-02-25 22:23 ` Dave Chinner
2021-02-24 6:34 ` [PATCH 12/13] xfs: xlog_write() no longer needs contwr state Dave Chinner
2021-02-24 6:34 ` [PATCH 13/13] xfs: CIL context doesn't need to count iovecs 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=20210226025727.GO7272@magnolia \
--to=djwong@kernel.org \
--cc=david@fromorbit.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