• David Hildenbrand's avatar
    mm/khugepaged: remove reuse_swap_page() usage · 363106c4
    David Hildenbrand authored
    reuse_swap_page() currently indicates if we can write to an anon page
    without COW.  A COW is required if the page is shared by multiple
    processes (either already mapped or via swap entries) or if there is
    concurrent writeback that cannot tolerate concurrent page modifications.
    
    However, in the context of khugepaged we're not actually going to write to
    a read-only mapped page, we'll copy the page content to our newly
    allocated THP and map that THP writable.  All we have to make sure is that
    the read-only mapped page we're about to copy won't get reused by another
    process sharing the page, otherwise, page content would get modified.  But
    that is already guaranteed via multiple mechanisms (e.g., holding a
    reference, holding the page lock, removing the rmap after copying the
    page).
    
    The swapcache handling was introduced in commit 10359213 ("mm:
    incorporate read-only pages into transparent huge pages") and it sounds
    like it merely wanted to mimic what do_swap_page() would do when trying to
    map a page obtained via the swapcache writable.
    
    As that logic is unnecessary, let's just remove it, removing the last user
    of reuse_swap_page().
    
    Link: https://lkml.kernel.org/r/20220131162940.210846-7-david@redhat.com
    
    Signed-off-by: default avatarDavid Hildenbrand <david@redhat.com>
    Reviewed-by: default avatarYang Shi <shy828301@gmail.com>
    Acked-by: default avatarVlastimil Babka <vbabka@suse.cz>
    Cc: Andrea Arcangeli <aarcange@redhat.com>
    Cc: Christoph Hellwig <hch@lst.de>
    Cc: David Rientjes <rientjes@google.com>
    Cc: Don Dutile <ddutile@redhat.com>
    Cc: Hugh Dickins <hughd@google.com>
    Cc: Jan Kara <jack@suse.cz>
    Cc: Jann Horn <jannh@google.com>
    Cc: Jason Gunthorpe <jgg@nvidia.com>
    Cc: John Hubbard <jhubbard@nvidia.com>
    Cc: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
    Cc: Liang Zhang <zhangliang5@huawei.com>
    Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
    Cc: Michal Hocko <mhocko@kernel.org>
    Cc: Mike Kravetz <mike.kravetz@oracle.com>
    Cc: Mike Rapoport <rppt@linux.ibm.com>
    Cc: Nadav Amit <nadav.amit@gmail.com>
    Cc: Oleg Nesterov <oleg@redhat.com>
    Cc: Peter Xu <peterx@redhat.com>
    Cc: Rik van Riel <riel@surriel.com>
    Cc: Roman Gushchin <roman.gushchin@linux.dev>
    Cc: Shakeel Butt <shakeelb@google.com>
    Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
    Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
    363106c4
khugepaged.c 60.1 KB