All of lore.kernel.org
 help / color / mirror / Atom feed
From: sashiko-bot@kernel.org
To: "Ackerley Tng via B4 Relay" <devnull+ackerleytng.google.com@kernel.org>
Cc: kvm@vger.kernel.org
Subject: Re: [PATCH v8 38/46] KVM: selftests: Add helpers to pin pages with CONFIG_GUP_TEST
Date: Fri, 19 Jun 2026 03:02:19 +0000	[thread overview]
Message-ID: <20260619030219.8C4DE1F000E9@smtp.kernel.org> (raw)
In-Reply-To: <20260618-gmem-inplace-conversion-v8-38-9d2959357853@google.com>

Thank you for your contribution! Sashiko AI review found 3 potential issue(s) to consider:

New issues:
- [Medium] System-wide exclusivity of `gup_test` prevents parallel execution of KVM selftests and causes spurious failures.
- [Low] Incorrect relative include path for `gup_test.h` breaks the build or relies on accidental `-I` path traversal.

Pre-existing issues:
- [High] The `gup_test_release()` function calls `pin_longterm_test_stop()` without acquiring the `pin_longterm_test_mutex`, leading to a data race, double free, and Use-After-Free.
--

commit 23065bfd3ffa48cfd9620c8d5f059f9ef6b27ced
Author: Ackerley Tng <ackerleytng@google.com>

KVM: selftests: Add helpers to pin pages with CONFIG_GUP_TEST

This commit adds helper functions allowing KVM selftests to pin memory using
the /sys/kernel/debug/gup_test interface. It implements pin_pages() and
unpin_pages() by wrapping ioctl calls to PIN_LONGTERM_TEST_START and
PIN_LONGTERM_TEST_STOP.

> diff --git a/tools/testing/selftests/kvm/lib/kvm_util.c b/tools/testing/selftests/kvm/lib/kvm_util.c
> index b73817f7bc803..524ef97d634bf 100644
> --- a/tools/testing/selftests/kvm/lib/kvm_util.c
> +++ b/tools/testing/selftests/kvm/lib/kvm_util.c
> @@ -18,6 +18,8 @@
>  #include <unistd.h>
>  #include <linux/kernel.h>
>  
> +#include "../../../../mm/gup_test.h"

[Severity: Low]
Is this relative include path correct?

Four levels up from tools/testing/selftests/kvm/lib/ only reaches the
tools/ directory, causing the compiler to search for tools/mm/gup_test.h.

Does the build only succeed because the compiler falls back to the
-I ../rseq include path defined in the KVM selftests Makefile?

[ ... ]

> @@ -639,6 +641,27 @@ int __pin_task_to_cpu(pthread_t task, int cpu)
>  	return pthread_setaffinity_np(task, sizeof(cpuset), &cpuset);
>  }
>  
> +static int gup_test_fd = -1;
> +
> +void pin_pages(void *vaddr, uint64_t size)
> +{
> +	const struct pin_longterm_test args = {
> +		.addr = (uint64_t)vaddr,
> +		.size = size,
> +		.flags = PIN_LONGTERM_TEST_FLAG_USE_WRITE,
> +	};
> +
> +	gup_test_fd = __open_path_or_exit("/sys/kernel/debug/gup_test", O_RDWR,
> +					  "Is CONFIG_GUP_TEST enabled?");
> +
> +	TEST_ASSERT_EQ(ioctl(gup_test_fd, PIN_LONGTERM_TEST_START, &args), 0);

[Severity: Medium]
Will this cause spurious failures when running tests in parallel?

The /sys/kernel/debug/gup_test interface relies on system-wide global
state (pin_longterm_test_pages) rather than per-file-descriptor state.

If multiple tests run concurrently, won't the kernel return -EINVAL to all
but the first caller because the global state is already occupied?

Furthermore, when one test exits, its file descriptor closure unpins the
memory of whichever test was actively using it.

[Severity: High]
This isn't a bug introduced by this patch, but interacting with the gup_test
file descriptor exposes a data race in the kernel.

In mm/gup_test.c, closing the file descriptor calls gup_test_release(),
which invokes pin_longterm_test_stop() without holding the
pin_longterm_test_mutex:

mm/gup_test.c:gup_test_release() {
    pin_longterm_test_stop();
    return 0;
}

If multiple file descriptors are closed concurrently (e.g., multithreaded
test applications or concurrent test processes exiting), multiple threads
can race inside pin_longterm_test_stop() and concurrently call
unpin_user_pages() and kvfree() on the same global pin_longterm_test_pages
pointer, leading to a double free and use-after-free.

-- 
Sashiko AI review · https://sashiko.dev/#/patchset/20260618-gmem-inplace-conversion-v8-0-9d2959357853@google.com?part=38

  reply	other threads:[~2026-06-19  3:02 UTC|newest]

Thread overview: 126+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-06-19  0:31 [PATCH v8 00/46] guest_memfd: In-place conversion support Ackerley Tng
2026-06-19  0:31 ` Ackerley Tng via B4 Relay
2026-06-19  0:31 ` [PATCH v8 01/46] KVM: guest_memfd: Introduce per-gmem attributes, use to guard user mappings Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  0:31 ` [PATCH v8 02/46] KVM: Rename KVM_GENERIC_MEMORY_ATTRIBUTES to KVM_VM_MEMORY_ATTRIBUTES Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  0:31 ` [PATCH v8 03/46] KVM: Move KVM_VM_MEMORY_ATTRIBUTES config definition to x86 Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  0:31 ` [PATCH v8 04/46] KVM: Decouple kvm_has_arch_private_mem from CONFIG_KVM_VM_MEMORY_ATTRIBUTES Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  8:10   ` Fuad Tabba
2026-06-19  0:31 ` [PATCH v8 05/46] KVM: Make CONFIG_KVM_VM_MEMORY_ATTRIBUTES selectable Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  8:12   ` Fuad Tabba
2026-06-19 12:51   ` Julian Braha
2026-06-19  0:31 ` [PATCH v8 06/46] KVM: Enumerate support for PRIVATE memory iff kvm_arch_has_private_mem is defined Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  0:31 ` [PATCH v8 07/46] KVM: Rename memory attribute APIs to prepare for in-place gmem conversion Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  0:55   ` sashiko-bot
2026-06-19  8:17     ` Fuad Tabba
2026-06-19  8:16   ` Fuad Tabba
2026-06-19  0:31 ` [PATCH v8 08/46] KVM: Provide generic interface for checking memory private/shared status Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  0:51   ` sashiko-bot
2026-06-19  8:19   ` Fuad Tabba
2026-06-19  8:21     ` Fuad Tabba
2026-06-19  9:57       ` Suzuki K Poulose
2026-06-19  0:31 ` [PATCH v8 09/46] KVM: guest_memfd: Introduce function to check GFN " Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  0:49   ` sashiko-bot
2026-06-19  8:24     ` Fuad Tabba
2026-06-19  8:25   ` Fuad Tabba
2026-06-19  0:31 ` [PATCH v8 10/46] KVM: guest_memfd: Wire up core private/shared attribute interfaces Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  8:34   ` Fuad Tabba
2026-06-19  0:31 ` [PATCH v8 11/46] KVM: Consolidate private memory and guest_memfd ifdeffery in kvm_host.h Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19 11:02   ` Fuad Tabba
2026-06-19  0:31 ` [PATCH v8 12/46] KVM: guest_memfd: Only prepare folios for private pages Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  0:31 ` [PATCH v8 13/46] KVM: guest_memfd: Add base support for KVM_SET_MEMORY_ATTRIBUTES2 Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  9:25   ` Fuad Tabba
2026-06-19  0:31 ` [PATCH v8 14/46] KVM: guest_memfd: Ensure pages are not in use before conversion Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  0:31 ` [PATCH v8 15/46] KVM: guest_memfd: Call arch invalidate hooks on conversion Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19 10:09   ` Fuad Tabba
2026-06-19  0:31 ` [PATCH v8 16/46] KVM: guest_memfd: Return early if range already has requested attributes Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  0:31 ` [PATCH v8 17/46] KVM: guest_memfd: Advertise KVM_SET_MEMORY_ATTRIBUTES2 ioctl Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  0:53   ` sashiko-bot
2026-06-19 10:35     ` Fuad Tabba
2026-06-19 10:35   ` Fuad Tabba
2026-06-19  0:31 ` [PATCH v8 18/46] KVM: guest_memfd: Handle lru_add fbatch refcounts during conversion safety check Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  0:31 ` [PATCH v8 19/46] KVM: guest_memfd: Use actual size for invalidation in kvm_gmem_release() Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  0:49   ` sashiko-bot
2026-06-19 10:46   ` Fuad Tabba
2026-06-19  0:31 ` [PATCH v8 20/46] KVM: guest_memfd: Determine invalidation filter from memory attributes Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19  0:31 ` [PATCH v8 21/46] KVM: guest_memfd: Zero page while getting pfn Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19 10:51   ` Fuad Tabba
2026-06-19  0:31 ` [PATCH v8 22/46] KVM: SEV: Make 'uaddr' parameter optional for KVM_SEV_SNP_LAUNCH_UPDATE Ackerley Tng
2026-06-19  0:31   ` Ackerley Tng via B4 Relay
2026-06-19 11:01   ` Fuad Tabba
2026-06-19  0:32 ` [PATCH v8 23/46] KVM: TDX: Make source page optional for KVM_TDX_INIT_MEM_REGION Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:58   ` sashiko-bot
2026-06-19 11:09   ` Fuad Tabba
2026-06-19  0:32 ` [PATCH v8 24/46] KVM: guest_memfd: Make in-place conversion the default Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:58   ` sashiko-bot
2026-06-19  0:32 ` [PATCH v8 25/46] KVM: guest_memfd: Enable INIT_SHARED on guest_memfd for x86 Coco VMs Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 26/46] KVM: selftests: Create gmem fd before "regular" fd when adding memslot Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 27/46] KVM: selftests: Rename guest_memfd{,_offset} to gmem_{fd,offset} Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:56   ` sashiko-bot
2026-06-19  0:32 ` [PATCH v8 28/46] KVM: selftests: Add support for mmap() on guest_memfd in core library Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 29/46] KVM: selftests: Add selftests global for guest memory attributes capability Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 30/46] KVM: selftests: Add helpers for calling ioctls on guest_memfd Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 31/46] KVM: selftests: Test basic single-page conversion flow Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 32/46] KVM: selftests: Test conversion flow when INIT_SHARED Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 33/46] KVM: selftests: Test conversion precision in guest_memfd Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 34/46] KVM: selftests: Test conversion before allocation Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 35/46] KVM: selftests: Convert with allocated folios in different layouts Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 36/46] KVM: selftests: Test that truncation does not change shared/private status Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 37/46] KVM: selftests: Test that shared/private status is consistent across processes Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  1:02   ` sashiko-bot
2026-06-19  0:32 ` [PATCH v8 38/46] KVM: selftests: Add helpers to pin pages with CONFIG_GUP_TEST Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  3:02   ` sashiko-bot [this message]
2026-06-19  0:32 ` [PATCH v8 39/46] KVM: selftests: Test conversion with elevated page refcount Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  1:07   ` sashiko-bot
2026-06-19  0:32 ` [PATCH v8 40/46] KVM: selftests: Reset shared memory after hole-punching Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 41/46] KVM: selftests: Provide function to look up guest_memfd details from gpa Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 42/46] KVM: selftests: Provide common function to set memory attributes Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 43/46] KVM: selftests: Check fd/flags provided to mmap() when setting up memslot Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 44/46] KVM: selftests: Make TEST_EXPECT_SIGBUS thread-safe Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 45/46] KVM: selftests: Update private_mem_conversions_test to mmap() guest_memfd Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19  0:32 ` [PATCH v8 46/46] KVM: selftests: Update private memory exits test to work with per-gmem attributes Ackerley Tng
2026-06-19  0:32   ` Ackerley Tng via B4 Relay
2026-06-19 12:28 ` [PATCH v8 00/46] guest_memfd: In-place conversion support Garg, Shivank

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20260619030219.8C4DE1F000E9@smtp.kernel.org \
    --to=sashiko-bot@kernel.org \
    --cc=devnull+ackerleytng.google.com@kernel.org \
    --cc=kvm@vger.kernel.org \
    --cc=sashiko-reviews@lists.linux.dev \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.