From: Jan Kara <jack@suse.cz>
To: Mel Gorman <mgorman@techsingularity.net>
Cc: Andrew Morton <akpm@linux-foundation.org>,
Hugh Dickins <hughd@google.com>, Jan Kara <jack@suse.cz>,
Linux-FSDevel <linux-fsdevel@vger.kernel.org>,
Linux-MM <linux-mm@kvack.org>,
LKML <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH 1/2] mm: filemap: Remove redundant code in do_read_cache_page
Date: Mon, 25 Jan 2016 12:35:44 +0100 [thread overview]
Message-ID: <20160125113544.GF20933@quack.suse.cz> (raw)
In-Reply-To: <1453716204-20409-2-git-send-email-mgorman@techsingularity.net>
On Mon 25-01-16 10:03:23, Mel Gorman wrote:
> do_read_cache_page and __read_cache_page duplicates page filler code
> when filling the page for the first time. This patch simply removes the
> duplicate logic.
>
> Signed-off-by: Mel Gorman <mgorman@techsingularity.net>
Looks good to me. You can add:
Reviewed-by: Jan Kara <jack@suse.cz>
Honza
> ---
> mm/filemap.c | 43 ++++++++++++-------------------------------
> 1 file changed, 12 insertions(+), 31 deletions(-)
>
> diff --git a/mm/filemap.c b/mm/filemap.c
> index bc943867d68c..aa38593d0cd5 100644
> --- a/mm/filemap.c
> +++ b/mm/filemap.c
> @@ -2283,7 +2283,7 @@ static struct page *wait_on_page_read(struct page *page)
> return page;
> }
>
> -static struct page *__read_cache_page(struct address_space *mapping,
> +static struct page *do_read_cache_page(struct address_space *mapping,
> pgoff_t index,
> int (*filler)(void *, struct page *),
> void *data,
> @@ -2305,31 +2305,19 @@ static struct page *__read_cache_page(struct address_space *mapping,
> /* Presumably ENOMEM for radix tree node */
> return ERR_PTR(err);
> }
> +
> +filler:
> err = filler(data, page);
> if (err < 0) {
> page_cache_release(page);
> - page = ERR_PTR(err);
> - } else {
> - page = wait_on_page_read(page);
> + return ERR_PTR(err);
> }
> - }
> - return page;
> -}
> -
> -static struct page *do_read_cache_page(struct address_space *mapping,
> - pgoff_t index,
> - int (*filler)(void *, struct page *),
> - void *data,
> - gfp_t gfp)
> -
> -{
> - struct page *page;
> - int err;
>
> -retry:
> - page = __read_cache_page(mapping, index, filler, data, gfp);
> - if (IS_ERR(page))
> - return page;
> + page = wait_on_page_read(page);
> + if (IS_ERR(page))
> + return page;
> + goto out;
> + }
> if (PageUptodate(page))
> goto out;
>
> @@ -2337,21 +2325,14 @@ static struct page *do_read_cache_page(struct address_space *mapping,
> if (!page->mapping) {
> unlock_page(page);
> page_cache_release(page);
> - goto retry;
> + goto repeat;
> }
> if (PageUptodate(page)) {
> unlock_page(page);
> goto out;
> }
> - err = filler(data, page);
> - if (err < 0) {
> - page_cache_release(page);
> - return ERR_PTR(err);
> - } else {
> - page = wait_on_page_read(page);
> - if (IS_ERR(page))
> - return page;
> - }
> + goto filler;
> +
> out:
> mark_page_accessed(page);
> return page;
> --
> 2.6.4
>
--
Jan Kara <jack@suse.com>
SUSE Labs, CR
--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@kvack.org. For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>
WARNING: multiple messages have this Message-ID (diff)
From: Jan Kara <jack@suse.cz>
To: Mel Gorman <mgorman@techsingularity.net>
Cc: Andrew Morton <akpm@linux-foundation.org>,
Hugh Dickins <hughd@google.com>, Jan Kara <jack@suse.cz>,
Linux-FSDevel <linux-fsdevel@vger.kernel.org>,
Linux-MM <linux-mm@kvack.org>,
LKML <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH 1/2] mm: filemap: Remove redundant code in do_read_cache_page
Date: Mon, 25 Jan 2016 12:35:44 +0100 [thread overview]
Message-ID: <20160125113544.GF20933@quack.suse.cz> (raw)
In-Reply-To: <1453716204-20409-2-git-send-email-mgorman@techsingularity.net>
On Mon 25-01-16 10:03:23, Mel Gorman wrote:
> do_read_cache_page and __read_cache_page duplicates page filler code
> when filling the page for the first time. This patch simply removes the
> duplicate logic.
>
> Signed-off-by: Mel Gorman <mgorman@techsingularity.net>
Looks good to me. You can add:
Reviewed-by: Jan Kara <jack@suse.cz>
Honza
> ---
> mm/filemap.c | 43 ++++++++++++-------------------------------
> 1 file changed, 12 insertions(+), 31 deletions(-)
>
> diff --git a/mm/filemap.c b/mm/filemap.c
> index bc943867d68c..aa38593d0cd5 100644
> --- a/mm/filemap.c
> +++ b/mm/filemap.c
> @@ -2283,7 +2283,7 @@ static struct page *wait_on_page_read(struct page *page)
> return page;
> }
>
> -static struct page *__read_cache_page(struct address_space *mapping,
> +static struct page *do_read_cache_page(struct address_space *mapping,
> pgoff_t index,
> int (*filler)(void *, struct page *),
> void *data,
> @@ -2305,31 +2305,19 @@ static struct page *__read_cache_page(struct address_space *mapping,
> /* Presumably ENOMEM for radix tree node */
> return ERR_PTR(err);
> }
> +
> +filler:
> err = filler(data, page);
> if (err < 0) {
> page_cache_release(page);
> - page = ERR_PTR(err);
> - } else {
> - page = wait_on_page_read(page);
> + return ERR_PTR(err);
> }
> - }
> - return page;
> -}
> -
> -static struct page *do_read_cache_page(struct address_space *mapping,
> - pgoff_t index,
> - int (*filler)(void *, struct page *),
> - void *data,
> - gfp_t gfp)
> -
> -{
> - struct page *page;
> - int err;
>
> -retry:
> - page = __read_cache_page(mapping, index, filler, data, gfp);
> - if (IS_ERR(page))
> - return page;
> + page = wait_on_page_read(page);
> + if (IS_ERR(page))
> + return page;
> + goto out;
> + }
> if (PageUptodate(page))
> goto out;
>
> @@ -2337,21 +2325,14 @@ static struct page *do_read_cache_page(struct address_space *mapping,
> if (!page->mapping) {
> unlock_page(page);
> page_cache_release(page);
> - goto retry;
> + goto repeat;
> }
> if (PageUptodate(page)) {
> unlock_page(page);
> goto out;
> }
> - err = filler(data, page);
> - if (err < 0) {
> - page_cache_release(page);
> - return ERR_PTR(err);
> - } else {
> - page = wait_on_page_read(page);
> - if (IS_ERR(page))
> - return page;
> - }
> + goto filler;
> +
> out:
> mark_page_accessed(page);
> return page;
> --
> 2.6.4
>
--
Jan Kara <jack@suse.com>
SUSE Labs, CR
next prev parent reply other threads:[~2016-01-25 11:35 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-01-25 10:03 [PATCH 0/2] Avoid unnecessary page locks in the generic read path Mel Gorman
2016-01-25 10:03 ` Mel Gorman
2016-01-25 10:03 ` [PATCH 1/2] mm: filemap: Remove redundant code in do_read_cache_page Mel Gorman
2016-01-25 10:03 ` Mel Gorman
2016-01-25 11:35 ` Jan Kara [this message]
2016-01-25 11:35 ` Jan Kara
2016-01-25 10:03 ` [PATCH 2/2] mm: filemap: Avoid unnecessary calls to lock_page when waiting for IO to complete during a read Mel Gorman
2016-01-25 10:03 ` Mel Gorman
2016-01-25 11:35 ` Jan Kara
2016-01-25 11:35 ` Jan Kara
2016-01-25 14:05 ` Mel Gorman
2016-01-25 14:05 ` Mel Gorman
-- strict thread matches above, loose matches on Subject: below --
2016-01-26 14:09 [PATCH 0/2] Avoid unnecessary page locks in the generic read path v2r1 Mel Gorman
2016-01-26 14:09 ` [PATCH 1/2] mm: filemap: Remove redundant code in do_read_cache_page Mel Gorman
2016-01-26 14:09 ` Mel Gorman
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=20160125113544.GF20933@quack.suse.cz \
--to=jack@suse.cz \
--cc=akpm@linux-foundation.org \
--cc=hughd@google.com \
--cc=linux-fsdevel@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=mgorman@techsingularity.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.