1. 04 Jul, 2024 32 commits
    • David Hildenbrand's avatar
      mm/memory: cleanly support zeropage in vm_insert_page*(), vm_map_pages*() and vmf_insert_mixed() · fce831c9
      David Hildenbrand authored
      For now we only get the (small) zeropage mapped to user space in four
      cases (excluding VM_PFNMAP mappings, such as /proc/vmstat):
      
      (1) Read page faults in anonymous VMAs (MAP_PRIVATE|MAP_ANON):
          do_anonymous_page() will not refcount it and map it pte_mkspecial()
      (2) UFFDIO_ZEROPAGE on anonymous VMA or COW mapping of shmem
          (MAP_PRIVATE). mfill_atomic_pte_zeropage() will not refcount it and
          map it pte_mkspecial().
      (3) KSM in mergeable VMA (anonymous VMA or COW mapping).
          cmp_and_merge_page() will not refcount it and map it
          pte_mkspecial().
      (4) FSDAX as an optimization for holes.
          vmf_insert_mixed()->__vm_insert_mixed() might end up calling
          insert_page() without CONFIG_ARCH_HAS_PTE_SPECIAL, refcounting the
          zeropage and not mapping it pte_mkspecial(). With
          CONFIG_ARCH_HAS_PTE_SPECIAL, we'll call insert_pfn() where we will
          not refcount it and map it pte_mkspecial().
      
      In case (4), we might not have VM_MIXEDMAP set: while fs/fuse/dax.c sets
      VM_MIXEDMAP, we removed it for ext4 fsdax in commit e1fb4a08 ("dax:
      remove VM_MIXEDMAP for fsdax and device dax") and for XFS in commit
      e1fb4a08 ("dax: remove VM_MIXEDMAP for fsdax and device dax").
      
      Without CONFIG_ARCH_HAS_PTE_SPECIAL and with VM_MIXEDMAP, vm_normal_page()
      would currently return the zeropage.  We'll refcount the zeropage when
      mapping and when unmapping.
      
      Without CONFIG_ARCH_HAS_PTE_SPECIAL and without VM_MIXEDMAP,
      vm_normal_page() would currently refuse to return the zeropage.  So we'd
      refcount it when mapping but not when unmapping it ...  do we have fsdax
      without CONFIG_ARCH_HAS_PTE_SPECIAL in practice?  Hard to tell.
      
      Independent of that, we should never refcount the zeropage when we might
      be holding that reference for a long time, because even without an
      accounting imbalance we might overflow the refcount.  As there is interest
      in using the zeropage also in other VM_MIXEDMAP mappings, let's add clean
      support for that in the cases where it makes sense:
      
      (A) Never refcount the zeropage when mapping it:
      
      In insert_page(), special-case the zeropage, do not refcount it, and use
      pte_mkspecial().  Don't involve insert_pfn(), adjusting insert_page()
      looks cleaner than branching off to insert_pfn().
      
      (B) Never refcount the zeropage when unmapping it:
      
      In vm_normal_page(), also don't return the zeropage in a VM_MIXEDMAP
      mapping without CONFIG_ARCH_HAS_PTE_SPECIAL.  Add a VM_WARN_ON_ONCE()
      sanity check if we'd ever return the zeropage, which could happen if
      someone forgets to set pte_mkspecial() when mapping the zeropage. 
      Document that.
      
      (C) Allow the zeropage only where reasonable
      
      s390x never wants the zeropage in some processes running legacy KVM guests
      that make use of storage keys.  So disallow that.
      
      Further, using the zeropage in COW mappings is unproblematic (just what we
      do for other COW mappings), because FAULT_FLAG_UNSHARE can just unshare it
      and GUP with FOLL_LONGTERM would work as expected.
      
      Similarly, mappings that can never have writable PTEs (implying no write
      faults) are also not problematic, because nothing could end up mapping the
      PTE writable by mistake later.  But in case we could have writable PTEs,
      we'll only allow the zeropage in FSDAX VMAs, that are incompatible with
      GUP and are blocked there completely.
      
      We'll always require the zeropage to be mapped with pte_special(). 
      GUP-fast will reject the zeropage that way, but GUP-slow will allow it. 
      (Note that GUP does not refcount the zeropage with FOLL_PIN, because there
      were issues with overflowing the refcount in the past).
      
      Add sanity checks to can_change_pte_writable() and wp_page_reuse(), to
      catch early during testing if we'd ever find a zeropage unexpectedly in
      code that wants to upgrade write permissions.
      
      Convert the BUG_ON in vm_mixed_ok() to an ordinary check and simply fail
      with VM_FAULT_SIGBUS, like we do for other sanity checks.  Drop the stale
      comment regarding reserved pages from insert_page().
      
      Note that:
      * we won't mess with VM_PFNMAP mappings for now. remap_pfn_range() and
        vmf_insert_pfn() would allow the zeropage in some cases and
        not refcount it.
      * vmf_insert_pfn*() will reject the zeropage in VM_MIXEDMAP
        mappings and we'll leave that alone for now. People can simply use
        one of the other interfaces.
      * we won't bother with the huge zeropage for now. It's never
        PTE-mapped and also GUP does not special-case it yet.
      
      Link: https://lkml.kernel.org/r/20240522125713.775114-3-david@redhat.comSigned-off-by: default avatarDavid Hildenbrand <david@redhat.com>
      Cc: Dan Williams <dan.j.williams@intel.com>
      Cc: Vincent Donnefort <vdonnefort@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      fce831c9
    • David Hildenbrand's avatar
      mm/memory: move page_count() check into validate_page_before_insert() · 11b914ee
      David Hildenbrand authored
      Patch series "mm/memory: cleanly support zeropage in vm_insert_page*(),
      vm_map_pages*() and vmf_insert_mixed()", v2.
      
      There is interest in mapping zeropages via vm_insert_pages() [1] into
      MAP_SHARED mappings.
      
      For now, we only get zeropages in MAP_SHARED mappings via
      vmf_insert_mixed() from FSDAX code, and I think it's a bit shaky in some
      cases because we refcount the zeropage when mapping it but not necessarily
      always when unmapping it ...  and we should actually never refcount it.
      
      It's all a bit tricky, especially how zeropages in MAP_SHARED mappings
      interact with GUP (FOLL_LONGTERM), mprotect(), write-faults and s390x
      forbidding the shared zeropage (rewrite [2] s now upstream).
      
      This series tries to take the careful approach of only allowing the
      zeropage where it is likely safe to use (which should cover the existing
      FSDAX use case and [1]), preventing that it could accidentally get mapped
      writable during a write fault, mprotect() etc, and preventing issues with
      FOLL_LONGTERM in the future with other users.
      
      Tested with a patch from Vincent that uses the zeropage in context of
      [1].
      
      [1] https://lkml.kernel.org/r/20240430111354.637356-1-vdonnefort@google.com
      [2] https://lkml.kernel.org/r/20240411161441.910170-1-david@redhat.com
      
      
      This patch (of 3):
      
      We'll now also cover the case where insert_page() is called from
      __vm_insert_mixed(), which sounds like the right thing to do.
      
      Link: https://lkml.kernel.org/r/20240522125713.775114-2-david@redhat.comSigned-off-by: default avatarDavid Hildenbrand <david@redhat.com>
      Cc: Dan Williams <dan.j.williams@intel.com>
      Cc: Vincent Donnefort <vdonnefort@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      11b914ee
    • Muhammad Usama Anjum's avatar
      selftests: mm: check return values · c66b0a05
      Muhammad Usama Anjum authored
      Check return value and return error/skip the tests.
      
      Link: https://lkml.kernel.org/r/20240520185248.1801945-1-usama.anjum@collabora.com
      Fixes: 46fd75d4 ("selftests: mm: add pagemap ioctl tests")
      Signed-off-by: default avatarMuhammad Usama Anjum <usama.anjum@collabora.com>
      Cc: Shuah Khan <shuah@kernel.org>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      c66b0a05
    • Sidhartha Kumar's avatar
      mm/hugetlb: remove {Set,Clear}Hpage macros · 63818aaf
      Sidhartha Kumar authored
      All users have been converted to use the folio version of these macros, we
      can safely remove the page based interface.
      
      Link: https://lkml.kernel.org/r/20240520224407.110062-1-sidhartha.kumar@oracle.comSigned-off-by: default avatarSidhartha Kumar <sidhartha.kumar@oracle.com>
      Reviewed-by: default avatarMatthew Wilcox (Oracle) <willy@infradead.org>
      Reviewed-by: default avatarDavid Hildenbrand <david@redhat.com>
      Reviewed-by: default avatarOscar Salvador <osalvador@suse.de>
      Cc: Muchun Song <muchun.song@linux.dev>
      Cc: Peter Xu <peterx@redhat.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      63818aaf
    • Kairui Song's avatar
      mm/swap: reduce swap cache search space · 7aad25b4
      Kairui Song authored
      Currently we use one swap_address_space for every 64M chunk to reduce lock
      contention, this is like having a set of smaller swap files inside one
      swap device.  But when doing swap cache look up or insert, we are still
      using the offset of the whole large swap device.  This is OK for
      correctness, as the offset (key) is unique.
      
      But Xarray is specially optimized for small indexes, it creates the radix
      tree levels lazily to be just enough to fit the largest key stored in one
      Xarray.  So we are wasting tree nodes unnecessarily.
      
      For 64M chunk it should only take at most 3 levels to contain everything. 
      But if we are using the offset from the whole swap device, the offset
      (key) value will be way beyond 64M, and so will the tree level.
      
      Optimize this by using a new helper swap_cache_index to get a swap entry's
      unique offset in its own 64M swap_address_space.
      
      I see a ~1% performance gain in benchmark and actual workload with high
      memory pressure.
      
      Test with `time memhog 128G` inside a 8G memcg using 128G swap (ramdisk
      with SWP_SYNCHRONOUS_IO dropped, tested 3 times, results are stable.  The
      test result is similar but the improvement is smaller if
      SWP_SYNCHRONOUS_IO is enabled, as swap out path can never skip swap
      cache):
      
      Before:
      6.07user 250.74system 4:17.26elapsed 99%CPU (0avgtext+0avgdata 8373376maxresident)k
      0inputs+0outputs (55major+33555018minor)pagefaults 0swaps
      
      After (1.8% faster):
      6.08user 246.09system 4:12.58elapsed 99%CPU (0avgtext+0avgdata 8373248maxresident)k
      0inputs+0outputs (54major+33555027minor)pagefaults 0swaps
      
      Similar result with MySQL and sysbench using swap:
      Before:
      94055.61 qps
      
      After (0.8% faster):
      94834.91 qps
      
      Radix tree slab usage is also very slightly lower.
      
      Link: https://lkml.kernel.org/r/20240521175854.96038-12-ryncsn@gmail.comSigned-off-by: default avatarKairui Song <kasong@tencent.com>
      Reviewed-by: default avatar"Huang, Ying" <ying.huang@intel.com>
      Cc: Anna Schumaker <anna@kernel.org>
      Cc: Barry Song <v-songbaohua@oppo.com>
      Cc: Chao Yu <chao@kernel.org>
      Cc: Chris Li <chrisl@kernel.org>
      Cc: David Hildenbrand <david@redhat.com>
      Cc: David Howells <dhowells@redhat.com>
      Cc: Hugh Dickins <hughd@google.com>
      Cc: Ilya Dryomov <idryomov@gmail.com>
      Cc: Jaegeuk Kim <jaegeuk@kernel.org>
      Cc: Jeff Layton <jlayton@kernel.org>
      Cc: Marc Dionne <marc.dionne@auristor.com>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Cc: Minchan Kim <minchan@kernel.org>
      Cc: NeilBrown <neilb@suse.de>
      Cc: Ryan Roberts <ryan.roberts@arm.com>
      Cc: Ryusuke Konishi <konishi.ryusuke@gmail.com>
      Cc: Trond Myklebust <trond.myklebust@hammerspace.com>
      Cc: Xiubo Li <xiubli@redhat.com>
      Cc: Yosry Ahmed <yosryahmed@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      7aad25b4
    • Kairui Song's avatar
      mm: drop page_index and simplify folio_index · 05b0c7ed
      Kairui Song authored
      There are two helpers for retrieving the index within address space for
      mixed usage of swap cache and page cache:
      
      - page_index
      - folio_index
      
      This commit drops page_index, as we have eliminated all users, and
      converts folio_index's helper __page_file_index to use folio to avoid the
      page conversion.
      
      Link: https://lkml.kernel.org/r/20240521175854.96038-11-ryncsn@gmail.comSigned-off-by: default avatarKairui Song <kasong@tencent.com>
      Reviewed-by: default avatar"Huang, Ying" <ying.huang@intel.com>
      Cc: Anna Schumaker <anna@kernel.org>
      Cc: Barry Song <v-songbaohua@oppo.com>
      Cc: Chao Yu <chao@kernel.org>
      Cc: Chris Li <chrisl@kernel.org>
      Cc: David Hildenbrand <david@redhat.com>
      Cc: David Howells <dhowells@redhat.com>
      Cc: Hugh Dickins <hughd@google.com>
      Cc: Ilya Dryomov <idryomov@gmail.com>
      Cc: Jaegeuk Kim <jaegeuk@kernel.org>
      Cc: Jeff Layton <jlayton@kernel.org>
      Cc: Marc Dionne <marc.dionne@auristor.com>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Cc: Minchan Kim <minchan@kernel.org>
      Cc: NeilBrown <neilb@suse.de>
      Cc: Ryan Roberts <ryan.roberts@arm.com>
      Cc: Ryusuke Konishi <konishi.ryusuke@gmail.com>
      Cc: Trond Myklebust <trond.myklebust@hammerspace.com>
      Cc: Xiubo Li <xiubli@redhat.com>
      Cc: Yosry Ahmed <yosryahmed@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      05b0c7ed
    • Kairui Song's avatar
      mm: remove page_file_offset and folio_file_pos · 564a2ee9
      Kairui Song authored
      These two helpers were useful for mixed usage of swap cache and page
      cache, which help retrieve the corresponding file or swap device offset of
      a page or folio.
      
      They were introduced in commit f981c595 ("mm: methods for teaching
      filesystems about PG_swapcache pages") and used in commit d56b4ddf
      ("nfs: teach the NFS client how to treat PG_swapcache pages"), suppose to
      be used with direct_IO for swap over fs.
      
      But after commit e1209d3a ("mm: introduce ->swap_rw and use it for
      reads from SWP_FS_OPS swap-space"), swap with direct_IO is no more, and
      swap cache mapping is never exposed to fs.
      
      Now we have dropped all users of page_file_offset and folio_file_pos, so
      they can be deleted.
      
      Link: https://lkml.kernel.org/r/20240521175854.96038-10-ryncsn@gmail.comSigned-off-by: default avatarKairui Song <kasong@tencent.com>
      Reviewed-by: default avatar"Huang, Ying" <ying.huang@intel.com>
      Cc: Anna Schumaker <anna@kernel.org>
      Cc: Barry Song <v-songbaohua@oppo.com>
      Cc: Chao Yu <chao@kernel.org>
      Cc: Chris Li <chrisl@kernel.org>
      Cc: David Hildenbrand <david@redhat.com>
      Cc: David Howells <dhowells@redhat.com>
      Cc: Hugh Dickins <hughd@google.com>
      Cc: Ilya Dryomov <idryomov@gmail.com>
      Cc: Jaegeuk Kim <jaegeuk@kernel.org>
      Cc: Jeff Layton <jlayton@kernel.org>
      Cc: Marc Dionne <marc.dionne@auristor.com>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Cc: Minchan Kim <minchan@kernel.org>
      Cc: NeilBrown <neilb@suse.de>
      Cc: Ryan Roberts <ryan.roberts@arm.com>
      Cc: Ryusuke Konishi <konishi.ryusuke@gmail.com>
      Cc: Trond Myklebust <trond.myklebust@hammerspace.com>
      Cc: Xiubo Li <xiubli@redhat.com>
      Cc: Yosry Ahmed <yosryahmed@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      564a2ee9
    • Kairui Song's avatar
      mm/swap: get the swap device offset directly · 545ebe71
      Kairui Song authored
      folio_file_pos and page_file_offset are for mixed usage of swap cache and
      page cache, it can't be page cache here, so introduce a new helper to get
      the swap offset in swap device directly.
      
      Need to include swapops.h in mm/swap.h to ensure swp_offset is always
      defined before use.
      
      Link: https://lkml.kernel.org/r/20240521175854.96038-9-ryncsn@gmail.comSigned-off-by: default avatarKairui Song <kasong@tencent.com>
      Reviewed-by: default avatar"Huang, Ying" <ying.huang@intel.com>
      Cc: Anna Schumaker <anna@kernel.org>
      Cc: Barry Song <v-songbaohua@oppo.com>
      Cc: Chao Yu <chao@kernel.org>
      Cc: Chris Li <chrisl@kernel.org>
      Cc: David Hildenbrand <david@redhat.com>
      Cc: David Howells <dhowells@redhat.com>
      Cc: Hugh Dickins <hughd@google.com>
      Cc: Ilya Dryomov <idryomov@gmail.com>
      Cc: Jaegeuk Kim <jaegeuk@kernel.org>
      Cc: Jeff Layton <jlayton@kernel.org>
      Cc: Marc Dionne <marc.dionne@auristor.com>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Cc: Minchan Kim <minchan@kernel.org>
      Cc: NeilBrown <neilb@suse.de>
      Cc: Ryan Roberts <ryan.roberts@arm.com>
      Cc: Ryusuke Konishi <konishi.ryusuke@gmail.com>
      Cc: Trond Myklebust <trond.myklebust@hammerspace.com>
      Cc: Xiubo Li <xiubli@redhat.com>
      Cc: Yosry Ahmed <yosryahmed@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      545ebe71
    • Kairui Song's avatar
      nfs: drop usage of folio_file_pos · 237d2907
      Kairui Song authored
      folio_file_pos is only needed for mixed usage of page cache and swap
      cache, for pure page cache usage, the caller can just use folio_pos
      instead.
      
      After commit e1209d3a ("mm: introduce ->swap_rw and use it for reads
      from SWP_FS_OPS swap-space"), swap cache should never be exposed to nfs.
      
      So remove the usage of folio_file_pos in following NFS functions / helpers:
      
      - nfs_vm_page_mkwrite
      
        It's only used by nfs_file_vm_ops.page_mkwrite
      
      - trace event helper: nfs_folio_event
      - trace event helper: nfs_folio_event_done
      
        These two are used through DEFINE_NFS_FOLIO_EVENT and
        DEFINE_NFS_FOLIO_EVENT_DONE, which defined following events:
      
        - trace_nfs_aop_readpage{_done}: only called by nfs_read_folio
        - trace_nfs_writeback_folio: only called by nfs_wb_folio
        - trace_nfs_invalidate_folio: only called by nfs_invalidate_folio
        - trace_nfs_launder_folio_done: only called by nfs_launder_folio
      
        None of them could possibly be used on swap cache folio,
        nfs_read_folio only called by:
        .write_begin -> nfs_read_folio
        .read_folio
      
        nfs_wb_folio only called by nfs mapping:
        .release_folio -> nfs_wb_folio
        .launder_folio -> nfs_wb_folio
        .write_begin -> nfs_read_folio -> nfs_wb_folio
        .read_folio -> nfs_wb_folio
        .write_end -> nfs_update_folio -> nfs_writepage_setup -> nfs_setup_write_request -> nfs_try_to_update_request -> nfs_wb_folio
        .page_mkwrite -> nfs_update_folio -> nfs_writepage_setup -> nfs_setup_write_request -> nfs_try_to_update_request -> nfs_wb_folio
        .write_begin -> nfs_flush_incompatible -> nfs_wb_folio
        .page_mkwrite -> nfs_vm_page_mkwrite -> nfs_flush_incompatible -> nfs_wb_folio
      
        nfs_invalidate_folio is only called by .invalidate_folio.
        nfs_launder_folio is only called by .launder_folio
      
      - nfs_grow_file
      - nfs_update_folio
      
        nfs_grow_file is only called by nfs_update_folio, and all
        possible callers of them are:
      
        .write_end -> nfs_update_folio
        .page_mkwrite -> nfs_update_folio
      
      - nfs_wb_folio_cancel
      
        .invalidate_folio -> nfs_wb_folio_cancel
      
      Also, seeing from the swap side, swap_rw is now the only interface calling
      into fs, the offset info is always in iocb.ki_pos now.
      
      So we can remove all these folio_file_pos call safely.
      
      Link: https://lkml.kernel.org/r/20240521175854.96038-8-ryncsn@gmail.comSigned-off-by: default avatarKairui Song <kasong@tencent.com>
      Cc: Trond Myklebust <trond.myklebust@hammerspace.com>
      Cc: Anna Schumaker <anna@kernel.org>
      Cc: Barry Song <v-songbaohua@oppo.com>
      Cc: Chao Yu <chao@kernel.org>
      Cc: Chris Li <chrisl@kernel.org>
      Cc: David Hildenbrand <david@redhat.com>
      Cc: David Howells <dhowells@redhat.com>
      Cc: "Huang, Ying" <ying.huang@intel.com>
      Cc: Hugh Dickins <hughd@google.com>
      Cc: Ilya Dryomov <idryomov@gmail.com>
      Cc: Jaegeuk Kim <jaegeuk@kernel.org>
      Cc: Jeff Layton <jlayton@kernel.org>
      Cc: Marc Dionne <marc.dionne@auristor.com>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Cc: Minchan Kim <minchan@kernel.org>
      Cc: NeilBrown <neilb@suse.de>
      Cc: Ryan Roberts <ryan.roberts@arm.com>
      Cc: Ryusuke Konishi <konishi.ryusuke@gmail.com>
      Cc: Xiubo Li <xiubli@redhat.com>
      Cc: Yosry Ahmed <yosryahmed@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      237d2907
    • Kairui Song's avatar
      netfs: drop usage of folio_file_pos · 7084021c
      Kairui Song authored
      folio_file_pos is only needed for mixed usage of page cache and swap
      cache, for pure page cache usage, the caller can just use folio_pos
      instead.
      
      It can't be a swap cache page here.  Swap mapping may only call into fs
      through swap_rw and that is not supported for netfs.  So just drop it and
      use folio_pos instead.
      
      Link: https://lkml.kernel.org/r/20240521175854.96038-7-ryncsn@gmail.comSigned-off-by: default avatarKairui Song <kasong@tencent.com>
      Cc: David Howells <dhowells@redhat.com>
      Cc: Jeff Layton <jlayton@kernel.org>
      Cc: Anna Schumaker <anna@kernel.org>
      Cc: Barry Song <v-songbaohua@oppo.com>
      Cc: Chao Yu <chao@kernel.org>
      Cc: Chris Li <chrisl@kernel.org>
      Cc: David Hildenbrand <david@redhat.com>
      Cc: "Huang, Ying" <ying.huang@intel.com>
      Cc: Hugh Dickins <hughd@google.com>
      Cc: Ilya Dryomov <idryomov@gmail.com>
      Cc: Jaegeuk Kim <jaegeuk@kernel.org>
      Cc: Marc Dionne <marc.dionne@auristor.com>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Cc: Minchan Kim <minchan@kernel.org>
      Cc: NeilBrown <neilb@suse.de>
      Cc: Ryan Roberts <ryan.roberts@arm.com>
      Cc: Ryusuke Konishi <konishi.ryusuke@gmail.com>
      Cc: Trond Myklebust <trond.myklebust@hammerspace.com>
      Cc: Xiubo Li <xiubli@redhat.com>
      Cc: Yosry Ahmed <yosryahmed@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      7084021c
    • Kairui Song's avatar
      afs: drop usage of folio_file_pos · d4f43986
      Kairui Song authored
      folio_file_pos is only needed for mixed usage of page cache and swap
      cache, for pure page cache usage, the caller can just use folio_pos
      instead.
      
      It can't be a swap cache page here.  Swap mapping may only call into fs
      through swap_rw and that is not supported for afs.  So just drop it and
      use folio_pos instead.
      
      Link: https://lkml.kernel.org/r/20240521175854.96038-6-ryncsn@gmail.comSigned-off-by: default avatarKairui Song <kasong@tencent.com>
      Cc: David Howells <dhowells@redhat.com>
      Cc: Marc Dionne <marc.dionne@auristor.com>
      Cc: Anna Schumaker <anna@kernel.org>
      Cc: Barry Song <v-songbaohua@oppo.com>
      Cc: Chao Yu <chao@kernel.org>
      Cc: Chris Li <chrisl@kernel.org>
      Cc: David Hildenbrand <david@redhat.com>
      Cc: "Huang, Ying" <ying.huang@intel.com>
      Cc: Hugh Dickins <hughd@google.com>
      Cc: Ilya Dryomov <idryomov@gmail.com>
      Cc: Jaegeuk Kim <jaegeuk@kernel.org>
      Cc: Jeff Layton <jlayton@kernel.org>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Cc: Minchan Kim <minchan@kernel.org>
      Cc: NeilBrown <neilb@suse.de>
      Cc: Ryan Roberts <ryan.roberts@arm.com>
      Cc: Ryusuke Konishi <konishi.ryusuke@gmail.com>
      Cc: Trond Myklebust <trond.myklebust@hammerspace.com>
      Cc: Xiubo Li <xiubli@redhat.com>
      Cc: Yosry Ahmed <yosryahmed@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      d4f43986
    • Kairui Song's avatar
      NFS: remove nfs_page_lengthg and usage of page_index · 8586be3d
      Kairui Song authored
      This function is no longer used after commit 4fa7a717 ("NFS: Fix up
      nfs_vm_page_mkwrite() for folios"), all users have been converted to use
      folio instead, just delete it to remove usage of page_index.
      
      Link: https://lkml.kernel.org/r/20240521175854.96038-5-ryncsn@gmail.comSigned-off-by: default avatarKairui Song <kasong@tencent.com>
      Cc: Trond Myklebust <trond.myklebust@hammerspace.com>
      Cc: Anna Schumaker <anna@kernel.org>
      Cc: Barry Song <v-songbaohua@oppo.com>
      Cc: Chao Yu <chao@kernel.org>
      Cc: Chris Li <chrisl@kernel.org>
      Cc: David Hildenbrand <david@redhat.com>
      Cc: David Howells <dhowells@redhat.com>
      Cc: "Huang, Ying" <ying.huang@intel.com>
      Cc: Hugh Dickins <hughd@google.com>
      Cc: Ilya Dryomov <idryomov@gmail.com>
      Cc: Jaegeuk Kim <jaegeuk@kernel.org>
      Cc: Jeff Layton <jlayton@kernel.org>
      Cc: Marc Dionne <marc.dionne@auristor.com>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Cc: Minchan Kim <minchan@kernel.org>
      Cc: NeilBrown <neilb@suse.de>
      Cc: Ryan Roberts <ryan.roberts@arm.com>
      Cc: Ryusuke Konishi <konishi.ryusuke@gmail.com>
      Cc: Xiubo Li <xiubli@redhat.com>
      Cc: Yosry Ahmed <yosryahmed@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      8586be3d
    • Kairui Song's avatar
      ceph: drop usage of page_index · 5e425300
      Kairui Song authored
      page_index is needed for mixed usage of page cache and swap cache, for
      pure page cache usage, the caller can just use page->index instead.
      
      It can't be a swap cache page here, so just drop it.
      
      Link: https://lkml.kernel.org/r/20240521175854.96038-4-ryncsn@gmail.comSigned-off-by: default avatarKairui Song <kasong@tencent.com>
      Cc: Xiubo Li <xiubli@redhat.com>
      Cc: Ilya Dryomov <idryomov@gmail.com>
      Cc: Jeff Layton <jlayton@kernel.org>
      Cc: Anna Schumaker <anna@kernel.org>
      Cc: Barry Song <v-songbaohua@oppo.com>
      Cc: Chao Yu <chao@kernel.org>
      Cc: Chris Li <chrisl@kernel.org>
      Cc: David Hildenbrand <david@redhat.com>
      Cc: David Howells <dhowells@redhat.com>
      Cc: "Huang, Ying" <ying.huang@intel.com>
      Cc: Hugh Dickins <hughd@google.com>
      Cc: Jaegeuk Kim <jaegeuk@kernel.org>
      Cc: Marc Dionne <marc.dionne@auristor.com>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Cc: Minchan Kim <minchan@kernel.org>
      Cc: NeilBrown <neilb@suse.de>
      Cc: Ryan Roberts <ryan.roberts@arm.com>
      Cc: Ryusuke Konishi <konishi.ryusuke@gmail.com>
      Cc: Trond Myklebust <trond.myklebust@hammerspace.com>
      Cc: Yosry Ahmed <yosryahmed@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      5e425300
    • Kairui Song's avatar
      nilfs2: drop usage of page_index · 1f49c147
      Kairui Song authored
      Patch series "mm/swap: clean up and optimize swap cache index", v6.
      
      Currently we use one swap_address_space for every 64M chunk to reduce lock
      contention, this is like having a set of smaller files inside a swap
      device.  But when doing swap cache look up or insert, we are still using
      the offset of the whole large swap device.  This is OK for correctness, as
      the offset (key) is unique.
      
      But Xarray is specially optimized for small indexes, it creates the redix
      tree levels lazily to be just enough to fit the largest key stored in one
      Xarray.  So we are wasting tree nodes unnecessarily.
      
      For 64M chunk it should only take at most 3 level to contain everything. 
      But if we are using the offset from the whole swap device, the offset
      (key) value will be way beyond 64M, and so will the tree level.
      
      Optimize this by reduce the swap cache search space into 64M scope.
      
      Test with `time memhog 128G` inside a 8G memcg using 128G swap (ramdisk
      with SWP_SYNCHRONOUS_IO dropped, tested 3 times, results are stable.  The
      test result is similar but the improvement is smaller if
      SWP_SYNCHRONOUS_IO is enabled, as swap out path can never skip swap
      cache):
      
      Before:
      6.07user 250.74system 4:17.26elapsed 99%CPU (0avgtext+0avgdata 8373376maxresident)k
      0inputs+0outputs (55major+33555018minor)pagefaults 0swaps
      
      After (+1.8% faster):
      6.08user 246.09system 4:12.58elapsed 99%CPU (0avgtext+0avgdata 8373248maxresident)k
      0inputs+0outputs (54major+33555027minor)pagefaults 0swaps
      
      Similar result with MySQL and sysbench using swap:
      Before:
      94055.61 qps
      
      After (+0.8% faster):
      94834.91 qps
      
      There is alse a very slight drop of radix tree node slab usage:
      Before: 303952K
      After:  302224K
      
      For this series:
      
      There are multiple places that expect mixed type of pages (page cache or
      swap cache), eg. migration, huge memory split; There are four helpers
      for that:
      
      - page_index
      - page_file_offset
      - folio_index
      - folio_file_pos
      
      To keep the code clean and compatible, this series first cleaned up usage
      of them.
      
      page_file_offset and folio_file_pos are historical helpes that can be
      simply dropped after clean up.  And page_index can be all converted to
      folio_index or folio->index.
      
      Then introduce two new helpers swap_cache_index and swap_dev_pos for swap.
      Replace swp_offset with swap_cache_index when used to retrieve folio from
      swap cache, and use swap_dev_pos when needed to retrieve the device
      position of a swap entry.  This way, swap_cache_index can return the
      optimized value with no compatibility issue.
      
      The result is better performance and reduced LOC.
      
      Idealy, in the future, we may want to reduce SWAP_ADDRESS_SPACE_SHIFT from
      14 to 12: Default Xarray chunk offset is 6, so we have 3 level trees
      instead of 2 level trees just for 2 extra bits.  But swap cache is based
      on address_space struct, with 4 times more metadata sparsely distributed
      in memory it waste more cacheline, the performance gain from this series
      is almost canceled according to my test.  So first, just have a cleaner
      seperation of offsets and smaller search space.
      
      
      This patch (of 10):
      
      page_index is only for mixed usage of page cache and swap cache, for pure
      page cache usage, the caller can just use page->index instead.
      
      It can't be a swap cache page here (being part of buffer head), so just
      drop it.  And while we are at it, optimize the code by retrieving the
      offset of the buffer head within the folio directly using bh_offset, and
      get rid of the loop and usage of page helpers.
      
      Link: https://lkml.kernel.org/r/20240521175854.96038-1-ryncsn@gmail.com
      Link: https://lkml.kernel.org/r/20240521175854.96038-3-ryncsn@gmail.comSuggested-by: default avatarMatthew Wilcox <willy@infradead.org>
      Signed-off-by: default avatarKairui Song <kasong@tencent.com>
      Acked-by: default avatarRyusuke Konishi <konishi.ryusuke@gmail.com>
      Cc: Ryusuke Konishi <konishi.ryusuke@gmail.com>
      Cc: Anna Schumaker <anna@kernel.org>
      Cc: Barry Song <v-songbaohua@oppo.com>
      Cc: Chao Yu <chao@kernel.org>
      Cc: Chris Li <chrisl@kernel.org>
      Cc: David Hildenbrand <david@redhat.com>
      Cc: David Howells <dhowells@redhat.com>
      Cc: "Huang, Ying" <ying.huang@intel.com>
      Cc: Hugh Dickins <hughd@google.com>
      Cc: Ilya Dryomov <idryomov@gmail.com>
      Cc: Jaegeuk Kim <jaegeuk@kernel.org>
      Cc: Jeff Layton <jlayton@kernel.org>
      Cc: Marc Dionne <marc.dionne@auristor.com>
      Cc: Minchan Kim <minchan@kernel.org>
      Cc: NeilBrown <neilb@suse.de>
      Cc: Ryan Roberts <ryan.roberts@arm.com>
      Cc: Trond Myklebust <trond.myklebust@hammerspace.com>
      Cc: Xiubo Li <xiubli@redhat.com>
      Cc: Yosry Ahmed <yosryahmed@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      1f49c147
    • Kemeng Shi's avatar
      writeback: factor out balance_wb_limits to remove repeated code · 8246291e
      Kemeng Shi authored
      Factor out balance_wb_limits to remove repeated code
      
      [shikemeng@huaweicloud.com: add comment]
        Link: https://lkml.kernel.org/r/20240606033547.344376-1-shikemeng@huaweicloud.com
      [akpm@linux-foundation.org: s/fileds/fields/ in comment]
      Link: https://lkml.kernel.org/r/20240514125254.142203-9-shikemeng@huaweicloud.comSigned-off-by: default avatarKemeng Shi <shikemeng@huaweicloud.com>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Cc: Tejun Heo <tj@kernel.org>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      8246291e
    • Kemeng Shi's avatar
      writeback: factor out wb_dirty_exceeded to remove repeated code · 236d0f16
      Kemeng Shi authored
      Factor out wb_dirty_exceeded to remove repeated code
      
      Link: https://lkml.kernel.org/r/20240514125254.142203-8-shikemeng@huaweicloud.comSigned-off-by: default avatarKemeng Shi <shikemeng@huaweicloud.com>
      Acked-by: default avatarTejun Heo <tj@kernel.org>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      236d0f16
    • Kemeng Shi's avatar
      writeback: factor out balance_domain_limits to remove repeated code · 8c9918de
      Kemeng Shi authored
      Factor out balance_domain_limits to remove repeated code.
      
      Link: https://lkml.kernel.org/r/20240514125254.142203-7-shikemeng@huaweicloud.comSigned-off-by: default avatarKemeng Shi <shikemeng@huaweicloud.com>
      Acked-by: default avatarTejun Heo <tj@kernel.org>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      8c9918de
    • Kemeng Shi's avatar
      writeback: factor out wb_dirty_freerun to remove more repeated freerun code · 2530e239
      Kemeng Shi authored
      Factor out wb_dirty_freerun to remove more repeated freerun code.
      
      Link: https://lkml.kernel.org/r/20240514125254.142203-6-shikemeng@huaweicloud.comSigned-off-by: default avatarKemeng Shi <shikemeng@huaweicloud.com>
      Acked-by: default avatarTejun Heo <tj@kernel.org>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      2530e239
    • Kemeng Shi's avatar
      writeback: factor out code of freerun to remove repeated code · 9bb48a70
      Kemeng Shi authored
      Factor out code of freerun into new helper functions domain_poll_intv and
      domain_dirty_freerun to remove repeated code.
      
      Link: https://lkml.kernel.org/r/20240514125254.142203-5-shikemeng@huaweicloud.comSigned-off-by: default avatarKemeng Shi <shikemeng@huaweicloud.com>
      Acked-by: default avatarTejun Heo <tj@kernel.org>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      9bb48a70
    • Kemeng Shi's avatar
      writeback: factor out domain_over_bg_thresh to remove repeated code · 6e208329
      Kemeng Shi authored
      Factor out domain_over_bg_thresh from wb_over_bg_thresh to remove repeated
      code.
      
      Link: https://lkml.kernel.org/r/20240514125254.142203-4-shikemeng@huaweicloud.comSigned-off-by: default avatarKemeng Shi <shikemeng@huaweicloud.com>
      Acked-by: default avatarTejun Heo <tj@kernel.org>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      6e208329
    • Kemeng Shi's avatar
      writeback: add general function domain_dirty_avail to calculate dirty and avail of domain · ba62d5cf
      Kemeng Shi authored
      Add general function domain_dirty_avail to calculate dirty and avail for
      either dirty limit or background writeback in either global domain or wb
      domain.
      
      Link: https://lkml.kernel.org/r/20240514125254.142203-3-shikemeng@huaweicloud.comSigned-off-by: default avatarKemeng Shi <shikemeng@huaweicloud.com>
      Acked-by: default avatarTejun Heo <tj@kernel.org>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      ba62d5cf
    • Kemeng Shi's avatar
      writeback: factor out wb_bg_dirty_limits to remove repeated code · 7c0c629b
      Kemeng Shi authored
      Patch series "Add helper functions to remove repeated code and improve
      readability of cgroup writeback", v2.
      
      This series adds a lot of helpers to remove repeated code between domain
      and wb; dirty limit and dirty background; global domain and wb domain. 
      The helpers also improve readability.  More details can be found in the
      respective patches.
      
      A simple domain hierarchy is tested:
      global domain (> 20G)
      	|
      cgroup domain1(10G)
      	|
      	wb1
      	|
      	fio
      
      Test steps:
      /* make it easy to observe */
      echo 300000 > /proc/sys/vm/dirty_expire_centisecs
      echo 3000 > /proc/sys/vm/dirty_writeback_centisecs
      
      /* create cgroup domain */
      cd /sys/fs/cgroup
      echo "+memory +io" > cgroup.subtree_control
      mkdir group1
      cd group1
      echo 10G > memory.high
      echo 10G > memory.max
      echo $$ > cgroup.procs
      mkfs.ext4 -F /dev/vdb
      mount /dev/vdb /bdi1/
      
      /* run fio to generate dirty pages */
      fio -name test -filename=/bdi1/file -size=xxx -ioengine=libaio -bs=4K \
      -iodepth=1 -rw=write -direct=0 --time_based -runtime=600 -invalidate=0
      
      When fio size is 1G, the wb is in freerun state and dirty pages are only
      written back when dirty inode is expired after 30 seconds.  When fio size
      is 2G, the dirty pages keep being written back and bandwidth of fio is
      limited.
      
      
      This patch (of 8):
      
      Similar to wb_dirty_limits which calculates dirty and thresh of wb,
      wb_bg_dirty_limits calculates background dirty and background thresh of
      wb.  With wb_bg_dirty_limits, we could remove repeated code in
      wb_over_bg_thresh.
      
      Link: https://lkml.kernel.org/r/20240514125254.142203-1-shikemeng@huaweicloud.com
      Link: https://lkml.kernel.org/r/20240514125254.142203-2-shikemeng@huaweicloud.comSigned-off-by: default avatarKemeng Shi <shikemeng@huaweicloud.com>
      Acked-by: default avatarTejun Heo <tj@kernel.org>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      7c0c629b
    • Shakeel Butt's avatar
      mm: vmscan: reset sc->priority on retry · 462966dc
      Shakeel Butt authored
      The commit 6be5e186fd65 ("mm: vmscan: restore incremental cgroup
      iteration") added a retry reclaim heuristic to iterate all the cgroups
      before returning an unsuccessful reclaim but missed to reset the
      sc->priority.  Let's fix it.
      
      Link: https://lkml.kernel.org/r/20240529154911.3008025-1-shakeel.butt@linux.dev
      Fixes: 6be5e186fd65 ("mm: vmscan: restore incremental cgroup iteration")
      Signed-off-by: default avatarShakeel Butt <shakeel.butt@linux.dev>
      Reported-by: syzbot+17416257cb95200cba44@syzkaller.appspotmail.com
      Tested-by: syzbot+17416257cb95200cba44@syzkaller.appspotmail.com
      Reviewed-by: default avatarRoman Gushchin <roman.gushchin@linux.dev>
      Cc: Johannes Weiner <hannes@cmpxchg.org>
      Cc: Michal Hocko <mhocko@kernel.org>
      Cc: Rik van Riel <riel@surriel.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      462966dc
    • Johannes Weiner's avatar
      mm: vmscan: restore incremental cgroup iteration · b82b5307
      Johannes Weiner authored
      Currently, reclaim always walks the entire cgroup tree in order to ensure
      fairness between groups.  While overreclaim is limited in shrink_lruvec(),
      many of our systems have a sizable number of active groups, and an even
      bigger number of idle cgroups with cache left behind by previous jobs; the
      mere act of walking all these cgroups can impose significant latency on
      direct reclaimers.
      
      In the past, we've used a save-and-restore iterator that enabled
      incremental tree walks over multiple reclaim invocations.  This ensured
      fairness, while keeping the work of individual reclaimers small.
      
      However, in edge cases with a lot of reclaim concurrency, individual
      reclaimers would sometimes not see enough of the cgroup tree to make
      forward progress and (prematurely) declare OOM.  Consequently we switched
      to comprehensive walks in 1ba6fc9a ("mm: vmscan: do not share cgroup
      iteration between reclaimers").
      
      To address the latency problem without bringing back the premature OOM
      issue, reinstate the shared iteration, but with a restart condition to do
      the full walk in the OOM case - similar to what we do for memory.low
      enforcement and active page protection.
      
      In the worst case, we do one more full tree walk before declaring
      OOM. But the vast majority of direct reclaim scans can then finish
      much quicker, while fairness across the tree is maintained:
      
      - Before this patch, we observed that direct reclaim always takes more
        than 100us and most direct reclaim time is spent in reclaim cycles
        lasting between 1ms and 1 second. Almost 40% of direct reclaim time
        was spent on reclaim cycles exceeding 100ms.
      
      - With this patch, almost all page reclaim cycles last less than 10ms,
        and a good amount of direct page reclaim finishes in under 100us. No
        page reclaim cycles lasting over 100ms were observed anymore.
      
      The shared iterator state is maintaned inside the target cgroup, so
      fair and incremental walks are performed during both global reclaim
      and cgroup limit reclaim of complex subtrees.
      
      Link: https://lkml.kernel.org/r/20240514202641.2821494-1-hannes@cmpxchg.orgSigned-off-by: default avatarJohannes Weiner <hannes@cmpxchg.org>
      Signed-off-by: default avatarRik van Riel <riel@surriel.com>
      Reported-by: default avatarRik van Riel <riel@surriel.com>
      Reviewed-by: default avatarShakeel Butt <shakeel.butt@linux.dev>
      Reviewed-by: default avatarRoman Gushchin <roman.gushchin@linux.dev>
      Cc: Facebook Kernel Team <kernel-team@fb.com>
      Cc: Michal Hocko <mhocko@kernel.org>
      Cc: Rik van Riel <riel@surriel.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      b82b5307
    • Ran Xiaokai's avatar
      mm/huge_memory: mark racy access onhuge_anon_orders_always · 7f83bf14
      Ran Xiaokai authored
      huge_anon_orders_always is accessed lockless, it is better to use the
      READ_ONCE() wrapper.  This is not fixing any visible bug, hopefully this
      can cease some KCSAN complains in the future.  Also do that for
      huge_anon_orders_madvise.
      
      Link: https://lkml.kernel.org/r/20240515104754889HqrahFPePOIE1UlANHVAh@zte.com.cnSigned-off-by: default avatarRan Xiaokai <ran.xiaokai@zte.com.cn>
      Acked-by: default avatarDavid Hildenbrand <david@redhat.com>
      Reviewed-by: default avatarLu Zhongjun <lu.zhongjun@zte.com.cn>
      Reviewed-by: default avatarxu xin <xu.xin16@zte.com.cn>
      Cc: Yang Yang <yang.yang29@zte.com.cn>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Cc: Yang Shi <shy828301@gmail.com>
      Cc: Zi Yan <ziy@nvidia.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      7f83bf14
    • Kefeng Wang's avatar
      mm: shmem: use folio_alloc_mpol() in shmem_alloc_folio() · 6f775463
      Kefeng Wang authored
      Let's change shmem_alloc_folio() to take a order and use
      folio_alloc_mpol() helper, then directly use it for normal or large folio
      to cleanup code.
      
      Link: https://lkml.kernel.org/r/20240515070709.78529-5-wangkefeng.wang@huawei.comSigned-off-by: default avatarKefeng Wang <wangkefeng.wang@huawei.com>
      Cc: Hugh Dickins <hughd@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      6f775463
    • Kefeng Wang's avatar
      mm: mempolicy: use folio_alloc_mpol() in alloc_migration_target_by_mpol() · 1d9cb785
      Kefeng Wang authored
      Convert to use folio_alloc_mpol() to make vma_alloc_folio_noprof() to use
      folio throughout.
      
      Link: https://lkml.kernel.org/r/20240515070709.78529-4-wangkefeng.wang@huawei.comSigned-off-by: default avatarKefeng Wang <wangkefeng.wang@huawei.com>
      Cc: Hugh Dickins <hughd@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      1d9cb785
    • Kefeng Wang's avatar
      mm: mempolicy: use folio_alloc_mpol_noprof() in vma_alloc_folio_noprof() · 3174d70c
      Kefeng Wang authored
      Convert to use folio_alloc_mpol_noprof() to make vma_alloc_folio_noprof()
      to use folio throughout.
      
      Link: https://lkml.kernel.org/r/20240515070709.78529-3-wangkefeng.wang@huawei.comSigned-off-by: default avatarKefeng Wang <wangkefeng.wang@huawei.com>
      Cc: Hugh Dickins <hughd@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      3174d70c
    • Kefeng Wang's avatar
      mm: add folio_alloc_mpol() · a19621ed
      Kefeng Wang authored
      Patch series "mm: convert to folio_alloc_mpol()".
      
      
      This patch (of 4):
      
      This adds a new folio_alloc_mpol() like folio_alloc() but allocate folio
      according to NUMA mempolicy.
      
      Link: https://lkml.kernel.org/r/20240515070709.78529-1-wangkefeng.wang@huawei.com
      Link: https://lkml.kernel.org/r/20240515070709.78529-2-wangkefeng.wang@huawei.comSigned-off-by: default avatarKefeng Wang <wangkefeng.wang@huawei.com>
      Cc: Hugh Dickins <hughd@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      a19621ed
    • Oscar Salvador's avatar
      mm/hugetlb: drop node_alloc_noretry from alloc_fresh_hugetlb_folio · 6584a14a
      Oscar Salvador authored
      Since commit d67e32f2 ("hugetlb: restructure pool allocations"), the
      parameter node_alloc_noretry from alloc_fresh_hugetlb_folio() is not used,
      so drop it.
      
      Link: https://lkml.kernel.org/r/20240516081035.5651-1-osalvador@suse.deSigned-off-by: default avatarOscar Salvador <osalvador@suse.de>
      Reviewed-by: default avatarSidhartha Kumar <sidhartha.kumar@oracle.com>
      Reviewed-by: default avatarAnshuman Khandual <anshuman.khandual@arm.com>
      Reviewed-by: default avatarVishal Moola (Oracle) <vishal.moola@gmail.com>
      Reviewed-by: default avatarMuchun Song <muchun.song@linux.dev>
      Cc: Oscar Salvador <osalvador@suse.de>
      Cc: Peter Xu <peterx@redhat.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      6584a14a
    • Illia Ostapyshyn's avatar
      mm/vmscan: update stale references to shrink_page_list · 0ba5e806
      Illia Ostapyshyn authored
      Commit 49fd9b6d ("mm/vmscan: fix a lot of comments") renamed
      shrink_page_list() to shrink_folio_list().  Fix up the remaining
      references to the old name in comments and documentation.
      
      Link: https://lkml.kernel.org/r/20240517091348.1185566-1-illia@yshyn.comSigned-off-by: default avatarIllia Ostapyshyn <illia@yshyn.com>
      Cc: Jonathan Corbet <corbet@lwn.net>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      0ba5e806
    • Thomas Weißschuh's avatar
      mm/hugetlb: constify ctl_table arguments of utility functions · 525c3030
      Thomas Weißschuh authored
      The sysctl core is preparing to only expose instances of struct ctl_table
      as "const".  This will also affect the ctl_table argument of sysctl
      handlers.
      
      As the function prototype of all sysctl handlers throughout the tree
      needs to stay consistent that change will be done in one commit.
      
      To reduce the size of that final commit, switch utility functions which
      are not bound by "typedef proc_handler" to "const struct ctl_table".
      
      No functional change.
      
      Link: https://lkml.kernel.org/r/20240518-sysctl-const-handler-hugetlb-v1-1-47e34e2871b2@weissschuh.netSigned-off-by: default avatarThomas Weißschuh <linux@weissschuh.net>
      Reviewed-by: default avatarMuchun Song <muchun.song@linux.dev>
      Cc: Joel Granados <j.granados@samsung.com>
      Cc: Luis Chamberlain <mcgrof@kernel.org>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      525c3030
  2. 30 Jun, 2024 8 commits
    • Linus Torvalds's avatar
      Linux 6.10-rc6 · 22a40d14
      Linus Torvalds authored
      22a40d14
    • Linus Torvalds's avatar
      Merge tag 'ata-6.10-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/libata/linux · aca7c377
      Linus Torvalds authored
      Pull ata fixes from Niklas Cassel:
      
       - Add NOLPM quirk for for all Crucial BX SSD1 models.
      
         Considering that we now have had bug reports for 3 different BX SSD1
         variants from Crucial with the same product name, make the quirk more
         inclusive, to catch more device models from the same generation.
      
       - Fix a trivial NULL pointer dereference in the error path for
         ata_host_release().
      
       - Create a ata_port_free(), so that we don't miss freeing ata_port
         struct members when freeing a struct ata_port.
      
       - Fix a trivial double free in the error path for ata_host_alloc().
      
       - Ensure that we remove the libata "remapped NVMe device count" sysfs
         entry on .probe() error.
      
      * tag 'ata-6.10-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/libata/linux:
        ata: ahci: Clean up sysfs file on error
        ata: libata-core: Fix double free on error
        ata,scsi: libata-core: Do not leak memory for ata_port struct members
        ata: libata-core: Fix null pointer dereference on error
        ata: libata-core: Add ATA_HORKAGE_NOLPM for all Crucial BX SSD1 models
      aca7c377
    • Niklas Cassel's avatar
      ata: ahci: Clean up sysfs file on error · eeb25a09
      Niklas Cassel authored
      .probe() (ahci_init_one()) calls sysfs_add_file_to_group(), however,
      if probe() fails after this call, we currently never call
      sysfs_remove_file_from_group().
      
      (The sysfs_remove_file_from_group() call in .remove() (ahci_remove_one())
      does not help, as .remove() is not called on .probe() error.)
      
      Thus, if probe() fails after the sysfs_add_file_to_group() call, the next
      time we insmod the module we will get:
      
      sysfs: cannot create duplicate filename '/devices/pci0000:00/0000:00:04.0/remapped_nvme'
      CPU: 11 PID: 954 Comm: modprobe Not tainted 6.10.0-rc5 #43
      Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.16.3-2.fc40 04/01/2014
      Call Trace:
       <TASK>
       dump_stack_lvl+0x5d/0x80
       sysfs_warn_dup.cold+0x17/0x23
       sysfs_add_file_mode_ns+0x11a/0x130
       sysfs_add_file_to_group+0x7e/0xc0
       ahci_init_one+0x31f/0xd40 [ahci]
      
      Fixes: 894fba7f ("ata: ahci: Add sysfs attribute to show remapped NVMe device count")
      Cc: stable@vger.kernel.org
      Reviewed-by: default avatarDamien Le Moal <dlemoal@kernel.org>
      Reviewed-by: default avatarHannes Reinecke <hare@suse.de>
      Link: https://lore.kernel.org/r/20240629124210.181537-10-cassel@kernel.orgSigned-off-by: default avatarNiklas Cassel <cassel@kernel.org>
      eeb25a09
    • Niklas Cassel's avatar
      ata: libata-core: Fix double free on error · ab9e0c52
      Niklas Cassel authored
      If e.g. the ata_port_alloc() call in ata_host_alloc() fails, we will jump
      to the err_out label, which will call devres_release_group().
      devres_release_group() will trigger a call to ata_host_release().
      ata_host_release() calls kfree(host), so executing the kfree(host) in
      ata_host_alloc() will lead to a double free:
      
      kernel BUG at mm/slub.c:553!
      Oops: invalid opcode: 0000 [#1] PREEMPT SMP NOPTI
      CPU: 11 PID: 599 Comm: (udev-worker) Not tainted 6.10.0-rc5 #47
      Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.16.3-2.fc40 04/01/2014
      RIP: 0010:kfree+0x2cf/0x2f0
      Code: 5d 41 5e 41 5f 5d e9 80 d6 ff ff 4d 89 f1 41 b8 01 00 00 00 48 89 d9 48 89 da
      RSP: 0018:ffffc90000f377f0 EFLAGS: 00010246
      RAX: ffff888112b1f2c0 RBX: ffff888112b1f2c0 RCX: ffff888112b1f320
      RDX: 000000000000400b RSI: ffffffffc02c9de5 RDI: ffff888112b1f2c0
      RBP: ffffc90000f37830 R08: 0000000000000000 R09: 0000000000000000
      R10: ffffc90000f37610 R11: 617461203a736b6e R12: ffffea00044ac780
      R13: ffff888100046400 R14: ffffffffc02c9de5 R15: 0000000000000006
      FS:  00007f2f1cabe980(0000) GS:ffff88813b380000(0000) knlGS:0000000000000000
      CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
      CR2: 00007f2f1c3acf75 CR3: 0000000111724000 CR4: 0000000000750ef0
      PKRU: 55555554
      Call Trace:
       <TASK>
       ? __die_body.cold+0x19/0x27
       ? die+0x2e/0x50
       ? do_trap+0xca/0x110
       ? do_error_trap+0x6a/0x90
       ? kfree+0x2cf/0x2f0
       ? exc_invalid_op+0x50/0x70
       ? kfree+0x2cf/0x2f0
       ? asm_exc_invalid_op+0x1a/0x20
       ? ata_host_alloc+0xf5/0x120 [libata]
       ? ata_host_alloc+0xf5/0x120 [libata]
       ? kfree+0x2cf/0x2f0
       ata_host_alloc+0xf5/0x120 [libata]
       ata_host_alloc_pinfo+0x14/0xa0 [libata]
       ahci_init_one+0x6c9/0xd20 [ahci]
      
      Ensure that we will not call kfree(host) twice, by performing the kfree()
      only if the devres_open_group() call failed.
      
      Fixes: dafd6c49 ("libata: ensure host is free'd on error exit paths")
      Cc: stable@vger.kernel.org
      Reviewed-by: default avatarDamien Le Moal <dlemoal@kernel.org>
      Reviewed-by: default avatarHannes Reinecke <hare@suse.de>
      Link: https://lore.kernel.org/r/20240629124210.181537-9-cassel@kernel.orgSigned-off-by: default avatarNiklas Cassel <cassel@kernel.org>
      ab9e0c52
    • Niklas Cassel's avatar
      ata,scsi: libata-core: Do not leak memory for ata_port struct members · f6549f53
      Niklas Cassel authored
      libsas is currently not freeing all the struct ata_port struct members,
      e.g. ncq_sense_buf for a driver supporting Command Duration Limits (CDL).
      
      Add a function, ata_port_free(), that is used to free a ata_port,
      including its struct members. It makes sense to keep the code related to
      freeing a ata_port in its own function, which will also free all the
      struct members of struct ata_port.
      
      Fixes: 18bd7718 ("scsi: ata: libata: Handle completion of CDL commands using policy 0xD")
      Reviewed-by: default avatarJohn Garry <john.g.garry@oracle.com>
      Link: https://lore.kernel.org/r/20240629124210.181537-8-cassel@kernel.orgSigned-off-by: default avatarNiklas Cassel <cassel@kernel.org>
      f6549f53
    • Niklas Cassel's avatar
      ata: libata-core: Fix null pointer dereference on error · 5d92c7c5
      Niklas Cassel authored
      If the ata_port_alloc() call in ata_host_alloc() fails,
      ata_host_release() will get called.
      
      However, the code in ata_host_release() tries to free ata_port struct
      members unconditionally, which can lead to the following:
      
      BUG: unable to handle page fault for address: 0000000000003990
      PGD 0 P4D 0
      Oops: Oops: 0000 [#1] PREEMPT SMP NOPTI
      CPU: 10 PID: 594 Comm: (udev-worker) Not tainted 6.10.0-rc5 #44
      Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.16.3-2.fc40 04/01/2014
      RIP: 0010:ata_host_release.cold+0x2f/0x6e [libata]
      Code: e4 4d 63 f4 44 89 e2 48 c7 c6 90 ad 32 c0 48 c7 c7 d0 70 33 c0 49 83 c6 0e 41
      RSP: 0018:ffffc90000ebb968 EFLAGS: 00010246
      RAX: 0000000000000041 RBX: ffff88810fb52e78 RCX: 0000000000000000
      RDX: 0000000000000000 RSI: ffff88813b3218c0 RDI: ffff88813b3218c0
      RBP: ffff88810fb52e40 R08: 0000000000000000 R09: 6c65725f74736f68
      R10: ffffc90000ebb738 R11: 73692033203a746e R12: 0000000000000004
      R13: 0000000000000000 R14: 0000000000000011 R15: 0000000000000006
      FS:  00007f6cc55b9980(0000) GS:ffff88813b300000(0000) knlGS:0000000000000000
      CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
      CR2: 0000000000003990 CR3: 00000001122a2000 CR4: 0000000000750ef0
      PKRU: 55555554
      Call Trace:
       <TASK>
       ? __die_body.cold+0x19/0x27
       ? page_fault_oops+0x15a/0x2f0
       ? exc_page_fault+0x7e/0x180
       ? asm_exc_page_fault+0x26/0x30
       ? ata_host_release.cold+0x2f/0x6e [libata]
       ? ata_host_release.cold+0x2f/0x6e [libata]
       release_nodes+0x35/0xb0
       devres_release_group+0x113/0x140
       ata_host_alloc+0xed/0x120 [libata]
       ata_host_alloc_pinfo+0x14/0xa0 [libata]
       ahci_init_one+0x6c9/0xd20 [ahci]
      
      Do not access ata_port struct members unconditionally.
      
      Fixes: 633273a3 ("libata-pmp: hook PMP support and enable it")
      Cc: stable@vger.kernel.org
      Reviewed-by: default avatarDamien Le Moal <dlemoal@kernel.org>
      Reviewed-by: default avatarHannes Reinecke <hare@suse.de>
      Reviewed-by: default avatarJohn Garry <john.g.garry@oracle.com>
      Link: https://lore.kernel.org/r/20240629124210.181537-7-cassel@kernel.orgSigned-off-by: default avatarNiklas Cassel <cassel@kernel.org>
      5d92c7c5
    • Linus Torvalds's avatar
      Merge tag 'kbuild-fixes-v6.10-3' of... · e0b668b0
      Linus Torvalds authored
      Merge tag 'kbuild-fixes-v6.10-3' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild
      
      Pull Kbuild fixes from Masahiro Yamada:
      
       - Remove the executable bit from installed DTB files
      
       - Escape $ in subshell execution in the debian-orig target
      
       - Fix RPM builds with CONFIG_MODULES=n
      
       - Fix xconfig with the O= option
      
       - Fix scripts_gdb with the O= option
      
      * tag 'kbuild-fixes-v6.10-3' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild:
        kbuild: scripts/gdb: bring the "abspath" back
        kbuild: Use $(obj)/%.cc to fix host C++ module builds
        kbuild: rpm-pkg: fix build error with CONFIG_MODULES=n
        kbuild: Fix build target deb-pkg: ln: failed to create hard link
        kbuild: doc: Update default INSTALL_MOD_DIR from extra to updates
        kbuild: Install dtb files as 0644 in Makefile.dtbinst
      e0b668b0
    • Linus Torvalds's avatar
      x86-32: fix cmpxchg8b_emu build error with clang · 76932725
      Linus Torvalds authored
      The kernel test robot reported that clang no longer compiles the 32-bit
      x86 kernel in some configurations due to commit 95ece481
      ("locking/atomic/x86: Rewrite x86_32 arch_atomic64_{,fetch}_{and,or,xor}()
      functions").
      
      The build fails with
      
        arch/x86/include/asm/cmpxchg_32.h:149:9: error: inline assembly requires more registers than available
      
      and the reason seems to be that not only does the cmpxchg8b instruction
      need four fixed registers (EDX:EAX and ECX:EBX), with the emulation
      fallback the inline asm also wants a fifth fixed register for the
      address (it uses %esi for that, but that's just a software convention
      with cmpxchg8b_emu).
      
      Avoiding using another pointer input to the asm (and just forcing it to
      use the "0(%esi)" addressing that we end up requiring for the sw
      fallback) seems to fix the issue.
      Reported-by: default avatarkernel test robot <lkp@intel.com>
      Closes: https://lore.kernel.org/oe-kbuild-all/202406230912.F6XFIyA6-lkp@intel.com/
      Fixes: 95ece481 ("locking/atomic/x86: Rewrite x86_32 arch_atomic64_{,fetch}_{and,or,xor}() functions")
      Link: https://lore.kernel.org/all/202406230912.F6XFIyA6-lkp@intel.com/Suggested-by: default avatarUros Bizjak <ubizjak@gmail.com>
      Reviewed-and-Tested-by: default avatarUros Bizjak <ubizjak@gmail.com>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      76932725