[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <8F5147DF-E0E2-4942-99D9-4242F3013635@zytor.com>
Date: Fri, 21 Nov 2025 16:06:11 -0800
From: "H. Peter Anvin" <hpa@...or.com>
To: Uros Bizjak <ubizjak@...il.com>, linux-hyperv@...r.kernel.org,
x86@...nel.org, linux-kernel@...r.kernel.org
CC: Michael Kelley <mhklinux@...look.com>,
"K. Y. Srinivasan" <kys@...rosoft.com>,
Haiyang Zhang <haiyangz@...rosoft.com>, Wei Liu <wei.liu@...nel.org>,
Dexuan Cui <decui@...rosoft.com>, Thomas Gleixner <tglx@...utronix.de>,
Ingo Molnar <mingo@...hat.com>, Borislav Petkov <bp@...en8.de>,
Dave Hansen <dave.hansen@...ux.intel.com>
Subject: Re: [PATCH v2 3/3] x86/hyperv: Remove ASM_CALL_CONSTRAINT with VMMCALL insn
On November 21, 2025 6:14:11 AM PST, Uros Bizjak <ubizjak@...il.com> wrote:
>Unlike CALL instruction, VMMCALL does not push to the stack, so it's
>OK to allow the compiler to insert it before the frame pointer gets
>set up by the containing function. ASM_CALL_CONSTRAINT is for CALLs
>that must be inserted after the frame pointer is set up, so it is
>over-constraining here and can be removed.
>
>Signed-off-by: Uros Bizjak <ubizjak@...il.com>
>Tested-by: Michael Kelley <mhklinux@...look.com>
>Cc: "K. Y. Srinivasan" <kys@...rosoft.com>
>Cc: Haiyang Zhang <haiyangz@...rosoft.com>
>Cc: Wei Liu <wei.liu@...nel.org>
>Cc: Dexuan Cui <decui@...rosoft.com>
>Cc: Thomas Gleixner <tglx@...utronix.de>
>Cc: Ingo Molnar <mingo@...hat.com>
>Cc: Borislav Petkov <bp@...en8.de>
>Cc: Dave Hansen <dave.hansen@...ux.intel.com>
>Cc: "H. Peter Anvin" <hpa@...or.com>
>---
>v2: Expand commit message and include ASM_CALL_CONSTRAINT explanation
>---
> arch/x86/hyperv/ivm.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
>diff --git a/arch/x86/hyperv/ivm.c b/arch/x86/hyperv/ivm.c
>index 7365d8f43181..be7fad43a88d 100644
>--- a/arch/x86/hyperv/ivm.c
>+++ b/arch/x86/hyperv/ivm.c
>@@ -392,7 +392,7 @@ u64 hv_snp_hypercall(u64 control, u64 param1, u64 param2)
>
> register u64 __r8 asm("r8") = param2;
> asm volatile("vmmcall"
>- : "=a" (hv_status), ASM_CALL_CONSTRAINT,
>+ : "=a" (hv_status),
> "+c" (control), "+d" (param1), "+r" (__r8)
> : : "cc", "memory", "r9", "r10", "r11");
>
I think it would be good to have a comment at the point where ASM_CALL_CONSTRAINT is defined explaining its proper use.
Specifically, instructions like syscall, vmcall, vmfunc, vmmcall, int xx and VM-specific escape instructions are not "calls" because they either don't modify the stack or create an exception frame (kernel) or signal frame (user space) which is completely special.
Powered by blists - more mailing lists