From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from lists.ozlabs.org (lists.ozlabs.org [112.213.38.117]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 3820EFD9E3A for ; Fri, 27 Feb 2026 20:09:17 +0000 (UTC) Received: from boromir.ozlabs.org (localhost [127.0.0.1]) by lists.ozlabs.org (Postfix) with ESMTP id 4fMztg1kfWz2xYw; Sat, 28 Feb 2026 07:09:15 +1100 (AEDT) Authentication-Results: lists.ozlabs.org; arc=none smtp.remote-ip="2600:3c04:e001:324:0:1991:8:25" ARC-Seal: i=1; a=rsa-sha256; d=lists.ozlabs.org; s=201707; t=1772222955; cv=none; b=V7U4SVzCb+AUhnqAZpzZz5fWnmMS91ZV178ckYsU8eWOd4F05AiMsQru/+YeD3uGhK+36z+twE6SsEvr+kPwMohA9Ko1PqWc6qMVLOpf7ljtsBt8VyQnQlrtHjhWbBXuhQmTljrKneEyd718KzUHYkcf+m9dlkKF4YuZ44Mj7tgbt8i396EOisnw08ehFPZn+6zuqiwerHE3DEbn0rGlNcEgyHiVgMqA+CODZUS5BZFmuOyLLH394SADWcyTUrPHhV9tVBwYwhha7cKT5fW8nMopmHbFAaqOvIpD7mT7UvYOLiHQNKENarOTfHJ8npiT8TOcfbseFFlxmvJb2U1ynA== ARC-Message-Signature: i=1; a=rsa-sha256; d=lists.ozlabs.org; s=201707; t=1772222955; c=relaxed/relaxed; bh=Vvf+Q0fyJ0WZ546dSDkkC4qI/jyE57BnwDyTXGB58lE=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version:Content-Type; b=HGPyehAIsghM+1dpVRldlYk9wOIPDYKE4AKyaibvMlWMR0YrvF4lY+Qw9RDYx5FLlv8GHDlD5ZfiJc4pQYdADtE7Q2gsT8jNr0R9ITq06kLXv7Wu/2du+ZT9QDwKyVucbGbv9jSIu5RmRyV51ePT1XTljs6FnCbNyIoWMRB5DylRABzgQzcyROeSKvHEIR8iV6KXEVTvwrqeCWkXI5E4rsWVFTO+ElSaVi2f/HIt4uXOMrvuA7Xird7ezZ7F5F6xiE/SIbyqj9o4AvQcUNNEjad1hoiQCAhNi4Nipv9K+n9Uc5oo90bkAN9WDenK9YjCy8UkwP8zPKpvd2Sl9nYOwg== ARC-Authentication-Results: i=1; lists.ozlabs.org; dmarc=pass (p=quarantine dis=none) header.from=kernel.org; dkim=pass (2048-bit key; unprotected) header.d=kernel.org header.i=@kernel.org header.a=rsa-sha256 header.s=k20201202 header.b=P+U9FbqK; dkim-atps=neutral; spf=pass (client-ip=2600:3c04:e001:324:0:1991:8:25; helo=tor.source.kernel.org; envelope-from=david@kernel.org; receiver=lists.ozlabs.org) smtp.mailfrom=kernel.org Authentication-Results: lists.ozlabs.org; dmarc=pass (p=quarantine dis=none) header.from=kernel.org Authentication-Results: lists.ozlabs.org; dkim=pass (2048-bit key; unprotected) header.d=kernel.org header.i=@kernel.org header.a=rsa-sha256 header.s=k20201202 header.b=P+U9FbqK; dkim-atps=neutral Authentication-Results: lists.ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=kernel.org (client-ip=2600:3c04:e001:324:0:1991:8:25; helo=tor.source.kernel.org; envelope-from=david@kernel.org; receiver=lists.ozlabs.org) Received: from tor.source.kernel.org (tor.source.kernel.org [IPv6:2600:3c04:e001:324:0:1991:8:25]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange x25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by lists.ozlabs.org (Postfix) with ESMTPS id 4fMztd3qfvz2xMt for ; Sat, 28 Feb 2026 07:09:12 +1100 (AEDT) Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by tor.source.kernel.org (Postfix) with ESMTP id C2E336013C; Fri, 27 Feb 2026 20:09:08 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 56E88C116C6; Fri, 27 Feb 2026 20:08:52 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1772222948; bh=uHYxem2rcFuwlV7scbCWwSyUtQMuMwhNJjysCrEHJOo=; h=From:To:Cc:Subject:Date:From; b=P+U9FbqKF3CgiBsEPqPexZzZ93XmAcCqzSbUwaOX1Y8siePI12ijG2mxzI5YIf0mL /ms5mDjzZ41zbR+y1lyjSjd5si16Ajj3yoCRxi8QeNf7VJlp5WbLWxR/Cm1nnjaTYO IOJj8irdOEN+aJhdaLJh+fKK7+dKb7KlCCDxdNslqcoGrctiSrHy1YeE9LnRXJRhDK ivNZRpe0JCZ8M0dux5O/xFyufs7KMwSQdWCOqjqmQAjFgGIXu0NS+l21cUs4WBsHt5 gFLiipJYdZxphu1iU6VvsVMrLyOefgdnpc25102oxNzG5Kz3JMlEpdrlW7fczulnx6 d9eorSp6XyA4Q== From: "David Hildenbrand (Arm)" To: linux-kernel@vger.kernel.org Cc: "linux-mm @ kvack . org" , "David Hildenbrand (Arm)" , Andrew Morton , Lorenzo Stoakes , "Liam R. Howlett" , Vlastimil Babka , Mike Rapoport , Suren Baghdasaryan , Michal Hocko , Jann Horn , Pedro Falcato , David Rientjes , Shakeel Butt , "Matthew Wilcox (Oracle)" , Alice Ryhl , Madhavan Srinivasan , Michael Ellerman , Christian Borntraeger , Janosch Frank , Claudio Imbrenda , Alexander Gordeev , Gerald Schaefer , Heiko Carstens , Vasily Gorbik , Jarkko Sakkinen , Thomas Gleixner , Ingo Molnar , Borislav Petkov , Greg Kroah-Hartman , =?UTF-8?q?Arve=20Hj=C3=B8nnev=C3=A5g?= , Todd Kjos , Christian Brauner , Carlos Llamas , Ian Abbott , H Hartley Sweeten , Jani Nikula , Joonas Lahtinen , Rodrigo Vivi , Tvrtko Ursulin , David Airlie , Simona Vetter , Jason Gunthorpe , Leon Romanovsky , Dimitri Sivanich , Arnd Bergmann , Alexei Starovoitov , Daniel Borkmann , Andrii Nakryiko , Peter Zijlstra , Arnaldo Carvalho de Melo , Namhyung Kim , Andy Lutomirski , Vincenzo Frascino , Eric Dumazet , Neal Cardwell , "David S. Miller" , David Ahern , Jakub Kicinski , Paolo Abeni , Miguel Ojeda , linuxppc-dev@lists.ozlabs.org, kvm@vger.kernel.org, linux-s390@vger.kernel.org, linux-sgx@vger.kernel.org, intel-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-rdma@vger.kernel.org, bpf@vger.kernel.org, linux-perf-users@vger.kernel.org, linux-fsdevel@vger.kernel.org, netdev@vger.kernel.org, rust-for-linux@vger.kernel.org, x86@kernel.org Subject: [PATCH v1 00/16] mm: cleanups around unmapping / zapping Date: Fri, 27 Feb 2026 21:08:31 +0100 Message-ID: <20260227200848.114019-1-david@kernel.org> X-Mailer: git-send-email 2.43.0 X-Mailing-List: linuxppc-dev@lists.ozlabs.org List-Id: List-Help: List-Owner: List-Post: List-Archive: , List-Subscribe: , , List-Unsubscribe: Precedence: list MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit A bunch of cleanups around unmapping and zapping. Mostly simplifications, code movements, documentation and renaming of zapping functions. With this series, we'll have the following high-level zap/unmap functions (excluding high-level folio zapping): * unmap_vmas() for actual unmapping (vmas will go away) * zap_vma(): zap all page table entries in a vma * zap_vma_for_reaping(): zap_vma() that must not block * zap_vma_range(): zap a range of page table entries * zap_vma_range_batched(): zap_vma_range() with more options and batching * zap_special_vma_range(): limited zap_vma_range() for modules * __zap_vma_range(): internal helper Patch #1 is not about unmapping/zapping, but I stumbled over it while verifying MADV_DONTNEED range handling. Patch #16 is related to [1], but makes sense even independent of that. [1] https://lore.kernel.org/r/aYSKyr7StGpGKNqW@google.com The CC list is already long enough. As these are simple changes to drivers/arch code, I'm only CCing maintainers of all changes but only reviewers of the MM bits. Cc: Andrew Morton Cc: Lorenzo Stoakes Cc: "Liam R. Howlett" Cc: Vlastimil Babka Cc: Mike Rapoport Cc: Suren Baghdasaryan Cc: Michal Hocko Cc: Jann Horn Cc: Pedro Falcato Cc: David Rientjes Cc: Shakeel Butt Cc: "Matthew Wilcox (Oracle)" Cc: Alice Ryhl Cc: Madhavan Srinivasan Cc: Michael Ellerman Cc: Christian Borntraeger Cc: Janosch Frank Cc: Claudio Imbrenda Cc: Alexander Gordeev Cc: Gerald Schaefer Cc: Heiko Carstens Cc: Vasily Gorbik Cc: Jarkko Sakkinen Cc: Thomas Gleixner Cc: Ingo Molnar Cc: Borislav Petkov Cc: Greg Kroah-Hartman Cc: "Arve Hjønnevåg" Cc: Todd Kjos Cc: Christian Brauner Cc: Carlos Llamas Cc: Alice Ryhl Cc: Ian Abbott Cc: H Hartley Sweeten Cc: Jani Nikula Cc: Joonas Lahtinen Cc: Rodrigo Vivi Cc: Tvrtko Ursulin Cc: David Airlie Cc: Simona Vetter Cc: Jason Gunthorpe Cc: Leon Romanovsky Cc: Dimitri Sivanich Cc: Arnd Bergmann Cc: Alexei Starovoitov Cc: Daniel Borkmann Cc: Andrii Nakryiko Cc: Peter Zijlstra Cc: Arnaldo Carvalho de Melo Cc: Namhyung Kim Cc: Andy Lutomirski Cc: Vincenzo Frascino Cc: Eric Dumazet Cc: Neal Cardwell Cc: "David S. Miller" Cc: David Ahern Cc: Jakub Kicinski Cc: Paolo Abeni Cc: Miguel Ojeda Cc: linuxppc-dev@lists.ozlabs.org Cc: kvm@vger.kernel.org Cc: linux-s390@vger.kernel.org Cc: linux-sgx@vger.kernel.org Cc: intel-gfx@lists.freedesktop.org Cc: dri-devel@lists.freedesktop.org Cc: linux-rdma@vger.kernel.org Cc: bpf@vger.kernel.org Cc: linux-perf-users@vger.kernel.org Cc: linux-fsdevel@vger.kernel.org Cc: netdev@vger.kernel.org Cc: rust-for-linux@vger.kernel.org Cc: x86@kernel.org David Hildenbrand (Arm) (16): mm/madvise: drop range checks in madvise_free_single_vma() mm/memory: remove "zap_details" parameter from zap_page_range_single() mm/memory: inline unmap_mapping_range_vma() into unmap_mapping_range_tree() mm/memory: simplify calculation in unmap_mapping_range_tree() mm/oom_kill: use MMU_NOTIFY_CLEAR in __oom_reap_task_mm() mm/oom_kill: factor out zapping of VMA into zap_vma_for_reaping() mm/memory: rename unmap_single_vma() to __zap_vma_range() mm/memory: move adjusting of address range to unmap_vmas() mm/memory: convert details->even_cows into details->skip_cows mm/memory: use __zap_vma_range() in zap_vma_for_reaping() mm/memory: inline unmap_page_range() into __zap_vma_range() mm: rename zap_vma_pages() to zap_vma() mm: rename zap_page_range_single_batched() to zap_vma_range_batched() mm: rename zap_page_range_single() to zap_vma_range() mm: rename zap_vma_ptes() to zap_special_vma_range() mm/memory: support VM_MIXEDMAP in zap_special_vma_range() arch/powerpc/platforms/book3s/vas-api.c | 2 +- arch/powerpc/platforms/pseries/vas.c | 2 +- arch/s390/mm/gmap_helpers.c | 2 +- arch/x86/kernel/cpu/sgx/encl.c | 2 +- drivers/android/binder/page_range.rs | 4 +- drivers/android/binder_alloc.c | 2 +- drivers/comedi/comedi_fops.c | 2 +- drivers/gpu/drm/i915/i915_mm.c | 4 +- drivers/infiniband/core/uverbs_main.c | 6 +- drivers/misc/sgi-gru/grumain.c | 2 +- include/linux/mm.h | 23 ++- kernel/bpf/arena.c | 3 +- kernel/events/core.c | 2 +- lib/vdso/datastore.c | 2 +- mm/internal.h | 7 +- mm/interval_tree.c | 5 - mm/madvise.c | 24 +-- mm/memory.c | 217 ++++++++++++------------ mm/oom_kill.c | 15 +- mm/page-writeback.c | 2 +- net/ipv4/tcp.c | 7 +- rust/kernel/mm/virt.rs | 4 +- 22 files changed, 162 insertions(+), 177 deletions(-) base-commit: df9c51269a5e2a6fbca2884a756a4011a5e78748 -- 2.43.0