Commit 494eec70 authored by john.hubbard@gmail.com's avatar john.hubbard@gmail.com Committed by Linus Torvalds

mm: page_cache_add_speculative(): refactor out some code duplication

From: John Hubbard <jhubbard@nvidia.com>

This combines the common elements of these routines:

    page_cache_get_speculative()
    page_cache_add_speculative()

This was anticipated by the original author, as shown by the comment in
commit ce0ad7f0 ("powerpc/mm: Lockless get_user_pages_fast() for
64-bit (v3)"):

    "Same as above, but add instead of inc (could just be merged)"

There is no intention to introduce any behavioral change, but there is a
small risk of that, due to slightly differing ways of expressing the
TINY_RCU and related configurations.

This also removes the VM_BUG_ON(in_interrupt()) that was in
page_cache_add_speculative(), but not in page_cache_get_speculative().
This provides slightly less detection of such bugs, but it given that it
was only there on the "add" path anyway, we can likely do without it
just fine.

And it removes the
VM_BUG_ON_PAGE(PageCompound(page) && page != compound_head(page), page);
that page_cache_add_speculative() had.

Link: http://lkml.kernel.org/r/20190206231016.22734-2-jhubbard@nvidia.comSigned-off-by: default avatarJohn Hubbard <jhubbard@nvidia.com>
Reviewed-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Dave Kleikamp <shaggy@linux.vnet.ibm.com>
Cc: Hugh Dickins <hughd@google.com>
Cc: Jeff Layton <jlayton@kernel.org>
Cc: Matthew Wilcox <willy@infradead.org>
Cc: Nicholas Piggin <npiggin@gmail.com>
Cc: Vlastimil Babka <vbabka@suse.cz>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent f900482d
...@@ -164,7 +164,7 @@ void release_pages(struct page **pages, int nr); ...@@ -164,7 +164,7 @@ void release_pages(struct page **pages, int nr);
* will find the page or it will not. Likewise, the old find_get_page could run * will find the page or it will not. Likewise, the old find_get_page could run
* either before the insertion or afterwards, depending on timing. * either before the insertion or afterwards, depending on timing.
*/ */
static inline int page_cache_get_speculative(struct page *page) static inline int __page_cache_add_speculative(struct page *page, int count)
{ {
#ifdef CONFIG_TINY_RCU #ifdef CONFIG_TINY_RCU
# ifdef CONFIG_PREEMPT_COUNT # ifdef CONFIG_PREEMPT_COUNT
...@@ -180,10 +180,10 @@ static inline int page_cache_get_speculative(struct page *page) ...@@ -180,10 +180,10 @@ static inline int page_cache_get_speculative(struct page *page)
* SMP requires. * SMP requires.
*/ */
VM_BUG_ON_PAGE(page_count(page) == 0, page); VM_BUG_ON_PAGE(page_count(page) == 0, page);
page_ref_inc(page); page_ref_add(page, count);
#else #else
if (unlikely(!get_page_unless_zero(page))) { if (unlikely(!page_ref_add_unless(page, count, 0))) {
/* /*
* Either the page has been freed, or will be freed. * Either the page has been freed, or will be freed.
* In either case, retry here and the caller should * In either case, retry here and the caller should
...@@ -197,27 +197,14 @@ static inline int page_cache_get_speculative(struct page *page) ...@@ -197,27 +197,14 @@ static inline int page_cache_get_speculative(struct page *page)
return 1; return 1;
} }
/* static inline int page_cache_get_speculative(struct page *page)
* Same as above, but add instead of inc (could just be merged)
*/
static inline int page_cache_add_speculative(struct page *page, int count)
{ {
VM_BUG_ON(in_interrupt()); return __page_cache_add_speculative(page, 1);
}
#if !defined(CONFIG_SMP) && defined(CONFIG_TREE_RCU)
# ifdef CONFIG_PREEMPT_COUNT
VM_BUG_ON(!in_atomic() && !irqs_disabled());
# endif
VM_BUG_ON_PAGE(page_count(page) == 0, page);
page_ref_add(page, count);
#else
if (unlikely(!page_ref_add_unless(page, count, 0)))
return 0;
#endif
VM_BUG_ON_PAGE(PageCompound(page) && page != compound_head(page), page);
return 1; static inline int page_cache_add_speculative(struct page *page, int count)
{
return __page_cache_add_speculative(page, count);
} }
#ifdef CONFIG_NUMA #ifdef CONFIG_NUMA
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment