KVM: selftests: Add vcpu_arch_put_guest() to do writes from guest code
authorSean Christopherson <seanjc@google.com>
Thu, 14 Mar 2024 18:54:57 +0000 (11:54 -0700)
committerSean Christopherson <seanjc@google.com>
Mon, 29 Apr 2024 19:50:43 +0000 (12:50 -0700)
commit2f2bc6af6aa8cc07f84291d625f7113fd13d68e5
tree189b0c0aee4354a9c6ab2310e892e487748c23c1
parente1ff11525d3c52159a8f262c209e5b9a9ef84918
KVM: selftests: Add vcpu_arch_put_guest() to do writes from guest code

Introduce a macro, vcpu_arch_put_guest(), for "putting" values to memory
from guest code in "interesting" situations, e.g. when writing memory that
is being dirty logged.  Structure the macro so that arch code can provide
a custom implementation, e.g. x86 will use the macro to force emulation of
the access.

Use the helper in dirty_log_test, which is of particular interest (see
above), and in xen_shinfo_test, which isn't all that interesting, but
provides a second usage of the macro with a different size operand
(uint8_t versus uint64_t), i.e. to help verify that the macro works for
more than just 64-bit values.

Use "put" as the verb to align with the kernel's {get,put}_user()
terminology.

Link: https://lore.kernel.org/r/20240314185459.2439072-5-seanjc@google.com
Signed-off-by: Sean Christopherson <seanjc@google.com>
tools/testing/selftests/kvm/dirty_log_test.c
tools/testing/selftests/kvm/include/kvm_util_base.h
tools/testing/selftests/kvm/x86_64/xen_shinfo_test.c