From: Chao Yu <chao@kernel.org>
To: Fengnan Chang <fengnanchang@gmail.com>, jaegeuk@kernel.org
Cc: Fengnan Chang <changfengnan@vivo.com>,
linux-f2fs-devel@lists.sourceforge.net
Subject: Re: [f2fs-dev] [PATCH v3 1/3] f2fs: intorduce f2fs_all_cluster_page_ready
Date: Sun, 24 Jul 2022 17:33:45 +0800 [thread overview]
Message-ID: <6be3acca-578b-9b8c-f85d-c9ed0091c0d6@kernel.org> (raw)
In-Reply-To: <20220717053207.192372-2-fengnanchang@gmail.com>
On 2022/7/17 13:32, Fengnan Chang wrote:
> From: Fengnan Chang <changfengnan@vivo.com>
>
> When write total cluster, all pages is uptodate, there is no need to call
> f2fs_prepare_compress_overwrite, intorduce f2fs_all_cluster_page_ready
> to avoid this.
>
> Signed-off-by: Fengnan Chang <changfengnan@vivo.com>
> ---
> fs/f2fs/compress.c | 17 +++++++++++++----
> fs/f2fs/data.c | 8 ++++++--
> fs/f2fs/f2fs.h | 4 ++--
> 3 files changed, 21 insertions(+), 8 deletions(-)
>
> diff --git a/fs/f2fs/compress.c b/fs/f2fs/compress.c
> index 24824cd96f36..28619d45b5c9 100644
> --- a/fs/f2fs/compress.c
> +++ b/fs/f2fs/compress.c
> @@ -871,20 +871,29 @@ bool f2fs_cluster_can_merge_page(struct compress_ctx *cc, pgoff_t index)
> return is_page_in_cluster(cc, index);
> }
>
> -bool f2fs_all_cluster_page_loaded(struct compress_ctx *cc, struct pagevec *pvec,
> - int index, int nr_pages)
> +bool f2fs_all_cluster_page_ready(struct compress_ctx *cc, struct pagevec *pvec,
> + int index, int nr_pages, bool uptodate)
> {
> unsigned long pgidx;
> - int i;
> + int i = uptodate ? 0 : 1;
> +
> + /*
> + * when uptodate set to true, try to check all pages in cluster is
> + * uptodate or not.
> + */
> + if (uptodate && (pgidx % cc->cluster_size))
pgidx is uninitialized...
Thanks,
> + return false;
>
> if (nr_pages - index < cc->cluster_size)
> return false;
>
> pgidx = pvec->pages[index]->index;
>
> - for (i = 1; i < cc->cluster_size; i++) {
> + for (; i < cc->cluster_size; i++) {
> if (pvec->pages[index + i]->index != pgidx + i)
> return false;
> + if (uptodate && !PageUptodate(pvec->pages[index + i]))
> + return false;
> }
>
> return true;
> diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c
> index 7fcbcf979737..022d0a8715c5 100644
> --- a/fs/f2fs/data.c
> +++ b/fs/f2fs/data.c
> @@ -2996,6 +2996,10 @@ static int f2fs_write_cache_pages(struct address_space *mapping,
> if (!f2fs_cluster_is_empty(&cc))
> goto lock_page;
>
> + if (f2fs_all_cluster_page_ready(&cc,
> + &pvec, i, nr_pages, true))
> + goto lock_page;
> +
> ret2 = f2fs_prepare_compress_overwrite(
> inode, &pagep,
> page->index, &fsdata);
> @@ -3006,8 +3010,8 @@ static int f2fs_write_cache_pages(struct address_space *mapping,
> } else if (ret2 &&
> (!f2fs_compress_write_end(inode,
> fsdata, page->index, 1) ||
> - !f2fs_all_cluster_page_loaded(&cc,
> - &pvec, i, nr_pages))) {
> + !f2fs_all_cluster_page_ready(&cc,
> + &pvec, i, nr_pages, false))) {
> retry = 1;
> break;
> }
> diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h
> index d9bbecd008d2..df07c15a5202 100644
> --- a/fs/f2fs/f2fs.h
> +++ b/fs/f2fs/f2fs.h
> @@ -4163,8 +4163,8 @@ void f2fs_end_read_compressed_page(struct page *page, bool failed,
> block_t blkaddr);
> bool f2fs_cluster_is_empty(struct compress_ctx *cc);
> bool f2fs_cluster_can_merge_page(struct compress_ctx *cc, pgoff_t index);
> -bool f2fs_all_cluster_page_loaded(struct compress_ctx *cc, struct pagevec *pvec,
> - int index, int nr_pages);
> +bool f2fs_all_cluster_page_ready(struct compress_ctx *cc, struct pagevec *pvec,
> + int index, int nr_pages, bool uptodate);
> bool f2fs_sanity_check_cluster(struct dnode_of_data *dn);
> void f2fs_compress_ctx_add_page(struct compress_ctx *cc, struct page *page);
> int f2fs_write_multi_pages(struct compress_ctx *cc,
_______________________________________________
Linux-f2fs-devel mailing list
Linux-f2fs-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel
next prev parent reply other threads:[~2022-07-24 9:34 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-07-17 5:32 [f2fs-dev] [PATCH v3 0/3] support compressed file write/read amplifiction Fengnan Chang
2022-07-17 5:32 ` [f2fs-dev] [PATCH v3 1/3] f2fs: intorduce f2fs_all_cluster_page_ready Fengnan Chang
2022-07-24 9:33 ` Chao Yu [this message]
2022-07-17 5:32 ` [f2fs-dev] [PATCH v3 2/3] f2fs: use onstack pages instead of pvec Fengnan Chang
2022-07-17 5:32 ` [f2fs-dev] [PATCH v3 3/3] f2fs: support compressed file write/read amplifiction Fengnan Chang
2022-07-24 9:58 ` Chao Yu
2022-07-25 13:00 ` fengnan chang
2022-07-24 9:36 ` [f2fs-dev] [PATCH v3 0/3] " Chao Yu
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=6be3acca-578b-9b8c-f85d-c9ed0091c0d6@kernel.org \
--to=chao@kernel.org \
--cc=changfengnan@vivo.com \
--cc=fengnanchang@gmail.com \
--cc=jaegeuk@kernel.org \
--cc=linux-f2fs-devel@lists.sourceforge.net \
/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).