From: Filipe Manana <[email protected]>
To: Stefan Roesch <[email protected]>
Cc: [email protected], [email protected],
[email protected], [email protected],
[email protected]
Subject: Re: [PATCH v2 07/12] btrfs: make prepare_pages nowait compatible
Date: Thu, 8 Sep 2022 11:17:47 +0100 [thread overview]
Message-ID: <CAL3q7H77thY5_1zMiwVZ8oBk3b4KwFUsff=DojUSgJdAMP-2DQ@mail.gmail.com> (raw)
In-Reply-To: <[email protected]>
On Thu, Sep 8, 2022 at 1:26 AM Stefan Roesch <[email protected]> wrote:
>
> Add nowait parameter to the prepare_pages function. In case nowait is
> specified for an async buffered write request, do a nowait allocation or
> return -EAGAIN.
>
> Signed-off-by: Stefan Roesch <[email protected]>
> ---
> fs/btrfs/file.c | 43 ++++++++++++++++++++++++++++++++++++-------
> 1 file changed, 36 insertions(+), 7 deletions(-)
>
> diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c
> index cf19d381ead6..a154a3cec44b 100644
> --- a/fs/btrfs/file.c
> +++ b/fs/btrfs/file.c
> @@ -1339,26 +1339,55 @@ static int prepare_uptodate_page(struct inode *inode,
> return 0;
> }
>
> +static int get_prepare_fgp_flags(bool nowait)
> +{
> + int fgp_flags;
> +
> + fgp_flags = FGP_LOCK|FGP_ACCESSED|FGP_CREAT;
Please follow the existing code style and add a space before and after
each bitwise or operator.
Not only does it conform to the btrfs style, it's also easier to read.
The assignment could also be done when declaring the variable, since
it's short and simple.
Thanks.
> + if (nowait)
> + fgp_flags |= FGP_NOWAIT;
> +
> + return fgp_flags;
> +}
> +
> +static gfp_t get_prepare_gfp_flags(struct inode *inode, bool nowait)
> +{
> + gfp_t gfp;
> +
> + gfp = btrfs_alloc_write_mask(inode->i_mapping);
> + if (nowait) {
> + gfp &= ~__GFP_DIRECT_RECLAIM;
> + gfp |= GFP_NOWAIT;
> + }
> +
> + return gfp;
> +}
> +
> /*
> * this just gets pages into the page cache and locks them down.
> */
> static noinline int prepare_pages(struct inode *inode, struct page **pages,
> size_t num_pages, loff_t pos,
> - size_t write_bytes, bool force_uptodate)
> + size_t write_bytes, bool force_uptodate,
> + bool nowait)
> {
> int i;
> unsigned long index = pos >> PAGE_SHIFT;
> - gfp_t mask = btrfs_alloc_write_mask(inode->i_mapping);
> + gfp_t mask = get_prepare_gfp_flags(inode, nowait);
> + int fgp_flags = get_prepare_fgp_flags(nowait);
> int err = 0;
> int faili;
>
> for (i = 0; i < num_pages; i++) {
> again:
> - pages[i] = find_or_create_page(inode->i_mapping, index + i,
> - mask | __GFP_WRITE);
> + pages[i] = pagecache_get_page(inode->i_mapping, index + i,
> + fgp_flags, mask | __GFP_WRITE);
> if (!pages[i]) {
> faili = i - 1;
> - err = -ENOMEM;
> + if (nowait)
> + err = -EAGAIN;
> + else
> + err = -ENOMEM;
> goto fail;
> }
>
> @@ -1376,7 +1405,7 @@ static noinline int prepare_pages(struct inode *inode, struct page **pages,
> pos + write_bytes, false);
> if (err) {
> put_page(pages[i]);
> - if (err == -EAGAIN) {
> + if (!nowait && err == -EAGAIN) {
> err = 0;
> goto again;
> }
> @@ -1716,7 +1745,7 @@ static noinline ssize_t btrfs_buffered_write(struct kiocb *iocb,
> */
> ret = prepare_pages(inode, pages, num_pages,
> pos, write_bytes,
> - force_page_uptodate);
> + force_page_uptodate, false);
> if (ret) {
> btrfs_delalloc_release_extents(BTRFS_I(inode),
> reserve_bytes);
> --
> 2.30.2
>
next prev parent reply other threads:[~2022-09-08 10:18 UTC|newest]
Thread overview: 33+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-09-08 0:26 [PATCH v2 00/12] io-uring/btrfs: support async buffered writes Stefan Roesch
2022-09-08 0:26 ` [PATCH v2 01/12] mm: export balance_dirty_pages_ratelimited_flags() Stefan Roesch
2022-09-08 10:18 ` Filipe Manana
2022-09-08 0:26 ` [PATCH v2 02/12] btrfs: implement a nowait option for tree searches Stefan Roesch
2022-09-08 13:19 ` Josef Bacik
2022-09-08 18:05 ` Stefan Roesch
2022-09-08 0:26 ` [PATCH v2 03/12] btrfs: make can_nocow_extent nowait compatible Stefan Roesch
2022-09-08 0:26 ` [PATCH v2 04/12] btrfs: add the ability to use NO_FLUSH for data reservations Stefan Roesch
2022-09-08 0:26 ` [PATCH v2 05/12] btrfs: add btrfs_try_lock_ordered_range Stefan Roesch
2022-09-08 10:18 ` Filipe Manana
2022-09-08 18:12 ` Stefan Roesch
2022-09-08 0:26 ` [PATCH v2 06/12] btrfs: make btrfs_check_nocow_lock nowait compatible Stefan Roesch
2022-09-08 10:18 ` Filipe Manana
2022-09-08 18:23 ` Stefan Roesch
2022-09-08 0:26 ` [PATCH v2 07/12] btrfs: make prepare_pages " Stefan Roesch
2022-09-08 10:17 ` Filipe Manana [this message]
2022-09-08 18:33 ` Stefan Roesch
2022-09-08 0:26 ` [PATCH v2 08/12] btrfs: make lock_and_cleanup_extent_if_need " Stefan Roesch
2022-09-08 10:17 ` Filipe Manana
2022-09-08 18:38 ` Stefan Roesch
2022-09-08 0:26 ` [PATCH v2 09/12] btrfs: btrfs: plumb NOWAIT through the write path Stefan Roesch
2022-09-08 10:16 ` Filipe Manana
2022-09-08 18:44 ` Stefan Roesch
2022-09-08 0:26 ` [PATCH v2 10/12] btrfs: make balance_dirty_pages nowait compatible Stefan Roesch
2022-09-08 10:16 ` Filipe Manana
2022-09-08 18:48 ` Stefan Roesch
2022-09-08 0:26 ` [PATCH v2 11/12] btrfs: add assert to search functions Stefan Roesch
2022-09-08 10:15 ` Filipe Manana
2022-09-08 19:10 ` Stefan Roesch
2022-09-08 0:26 ` [PATCH v2 12/12] btrfs: enable nowait async buffered writes Stefan Roesch
2022-09-08 10:14 ` Filipe Manana
2022-09-08 19:14 ` Stefan Roesch
2022-09-08 10:14 ` [PATCH v2 00/12] io-uring/btrfs: support " Filipe Manana
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='CAL3q7H77thY5_1zMiwVZ8oBk3b4KwFUsff=DojUSgJdAMP-2DQ@mail.gmail.com' \
[email protected] \
[email protected] \
[email protected] \
[email protected] \
[email protected] \
[email protected] \
[email protected] \
/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