From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-pd0-f172.google.com (mail-pd0-f172.google.com [209.85.192.172]) by kanga.kvack.org (Postfix) with ESMTP id 435806B0037 for ; Mon, 30 Jun 2014 17:11:14 -0400 (EDT) Received: by mail-pd0-f172.google.com with SMTP id w10so8854508pde.17 for ; Mon, 30 Jun 2014 14:11:13 -0700 (PDT) Received: from mail-pd0-x22b.google.com (mail-pd0-x22b.google.com [2607:f8b0:400e:c02::22b]) by mx.google.com with ESMTPS id sj10si24478855pab.159.2014.06.30.14.11.13 for (version=TLSv1 cipher=ECDHE-RSA-RC4-SHA bits=128/128); Mon, 30 Jun 2014 14:11:13 -0700 (PDT) Received: by mail-pd0-f171.google.com with SMTP id fp1so8859886pdb.2 for ; Mon, 30 Jun 2014 14:11:13 -0700 (PDT) Date: Mon, 30 Jun 2014 14:09:49 -0700 (PDT) From: Hugh Dickins Subject: [PATCH 2/2] mm: replace init_page_accessed by __SetPageReferenced In-Reply-To: Message-ID: References: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: owner-linux-mm@kvack.org List-ID: To: Mel Gorman Cc: Andrew Morton , linux-mm@kvack.org, linux-kernel@vger.kernel.org Do we really need an exported alias for __SetPageReferenced()? Its callers better know what they're doing, in which case the page would not be already marked referenced. Kill init_page_accessed(), just __SetPageReferenced() inline. Signed-off-by: Hugh Dickins --- include/linux/swap.h | 1 - mm/filemap.c | 4 ++-- mm/shmem.c | 2 +- mm/swap.c | 14 +++----------- 4 files changed, 6 insertions(+), 15 deletions(-) --- 3.16-rc3+/include/linux/swap.h 2014-06-16 00:28:54.916076526 -0700 +++ linux/include/linux/swap.h 2014-06-30 12:55:35.216149853 -0700 @@ -311,7 +311,6 @@ extern void lru_add_page_tail(struct pag struct lruvec *lruvec, struct list_head *head); extern void activate_page(struct page *); extern void mark_page_accessed(struct page *); -extern void init_page_accessed(struct page *page); extern void lru_add_drain(void); extern void lru_add_drain_cpu(int cpu); extern void lru_add_drain_all(void); --- 3.16-rc3+/mm/filemap.c 2014-06-16 00:28:55.100076530 -0700 +++ linux/mm/filemap.c 2014-06-30 12:55:35.216149853 -0700 @@ -1100,9 +1100,9 @@ no_page: if (WARN_ON_ONCE(!(fgp_flags & FGP_LOCK))) fgp_flags |= FGP_LOCK; - /* Init accessed so avoit atomic mark_page_accessed later */ + /* Init accessed so avoid atomic mark_page_accessed later */ if (fgp_flags & FGP_ACCESSED) - init_page_accessed(page); + __SetPageReferenced(page); err = add_to_page_cache_lru(page, mapping, offset, radix_gfp_mask); if (unlikely(err)) { --- 3.16-rc3+/mm/shmem.c 2014-06-30 12:15:52.204093217 -0700 +++ linux/mm/shmem.c 2014-06-30 12:55:35.216149853 -0700 @@ -1143,7 +1143,7 @@ repeat: __SetPageSwapBacked(page); __set_page_locked(page); if (sgp == SGP_WRITE) - init_page_accessed(page); + __SetPageReferenced(page); error = mem_cgroup_charge_file(page, current->mm, gfp & GFP_RECLAIM_MASK); --- 3.16-rc3+/mm/swap.c 2014-06-16 00:28:55.132076531 -0700 +++ linux/mm/swap.c 2014-06-30 12:55:35.216149853 -0700 @@ -589,6 +589,9 @@ static void __lru_cache_activate_page(st * inactive,unreferenced -> inactive,referenced * inactive,referenced -> active,unreferenced * active,unreferenced -> active,referenced + * + * When a newly allocated page is not yet visible, so safe for non-atomic ops, + * __SetPageReferenced(page) may be substituted for mark_page_accessed(page). */ void mark_page_accessed(struct page *page) { @@ -614,17 +617,6 @@ void mark_page_accessed(struct page *pag } EXPORT_SYMBOL(mark_page_accessed); -/* - * Used to mark_page_accessed(page) that is not visible yet and when it is - * still safe to use non-atomic ops - */ -void init_page_accessed(struct page *page) -{ - if (!PageReferenced(page)) - __SetPageReferenced(page); -} -EXPORT_SYMBOL(init_page_accessed); - static void __lru_cache_add(struct page *page) { struct pagevec *pvec = &get_cpu_var(lru_add_pvec); -- 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: email@kvack.org