From: Christoph Hellwig <hch@infradead.org>
To: Brian Foster <bfoster@redhat.com>
Cc: linux-xfs@vger.kernel.org, Dave Chinner <david@fromorbit.com>,
Zorro Lang <zlang@redhat.com>
Subject: Re: [PATCH] xfs: serialize unaligned dio writes against all other dio writes
Date: Mon, 25 Mar 2019 04:06:46 -0700 [thread overview]
Message-ID: <20190325110646.GA7890@infradead.org> (raw)
In-Reply-To: <20190322165242.40662-1-bfoster@redhat.com>
> if (unaligned_io) {
> + /* unaligned dio always waits, bail */
> + if (iocb->ki_flags & IOCB_NOWAIT)
> + return -EAGAIN;
> + else
> inode_dio_wait(inode);
No need for the else here.
> } else if (iolock == XFS_IOLOCK_EXCL) {
> xfs_ilock_demote(ip, XFS_IOLOCK_EXCL);
> iolock = XFS_IOLOCK_SHARED;
> @@ -548,6 +549,8 @@ xfs_file_dio_aio_write(
>
> trace_xfs_file_direct_write(ip, count, iocb->ki_pos);
> ret = iomap_dio_rw(iocb, from, &xfs_iomap_ops, xfs_dio_write_end_io);
> + if (unaligned_io && !is_sync_kiocb(iocb))
> + inode_dio_wait(inode);
Instead of explicittly waiting here I'd much rather just mark the
I/O as sync before submitting it. The only thing needed for that
is to clear iocb->ki_complete. To avoid too much low-level hacking
that is probably best done with a:
static inline void mark_kiocb_sync(struct kiocb *kiocb)
{
kiocb->ki_complete = NULL;
}
helper in fs.h.
next prev parent reply other threads:[~2019-03-25 11:06 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-03-22 16:52 [PATCH] xfs: serialize unaligned dio writes against all other dio writes Brian Foster
2019-03-22 20:46 ` Allison Henderson
2019-03-23 10:29 ` Zorro Lang
2019-03-25 3:47 ` Zorro Lang
2019-03-25 13:45 ` Brian Foster
2019-03-24 20:59 ` Dave Chinner
2019-03-25 13:48 ` Brian Foster
2019-03-25 11:06 ` Christoph Hellwig [this message]
2019-03-25 13:51 ` Brian Foster
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=20190325110646.GA7890@infradead.org \
--to=hch@infradead.org \
--cc=bfoster@redhat.com \
--cc=david@fromorbit.com \
--cc=linux-xfs@vger.kernel.org \
--cc=zlang@redhat.com \
/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;
as well as URLs for NNTP newsgroup(s).