]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
x86/xen: fix xen_hypercall_hvm() to not clobber %rbx
authorJuergen Gross <jgross@suse.com>
Wed, 5 Feb 2025 08:43:31 +0000 (09:43 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 13 Mar 2025 11:47:05 +0000 (12:47 +0100)
[ Upstream commit 98a5cfd2320966f40fe049a9855f8787f0126825 ]

xen_hypercall_hvm(), which is used when running as a Xen PVH guest at
most only once during early boot, is clobbering %rbx. Depending on
whether the caller relies on %rbx to be preserved across the call or
not, this clobbering might result in an early crash of the system.

This can be avoided by using an already saved register instead of %rbx.

Fixes: b4845bb63838 ("x86/xen: add central hypercall functions")
Signed-off-by: Juergen Gross <jgross@suse.com>
Reviewed-by: Jan Beulich <jbeulich@suse.com>
Reviewed-by: Andrew Cooper <andrew.cooper3@citrix.com>
Signed-off-by: Juergen Gross <jgross@suse.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
arch/x86/xen/xen-head.S

index 152bbe900a174a123f194587e91d525155fce81c..0dce73077c8cb7be7728f90742492f0f6056133d 100644 (file)
@@ -115,8 +115,8 @@ SYM_FUNC_START(xen_hypercall_hvm)
        pop %ebx
        pop %eax
 #else
-       lea xen_hypercall_amd(%rip), %rbx
-       cmp %rax, %rbx
+       lea xen_hypercall_amd(%rip), %rcx
+       cmp %rax, %rcx
 #ifdef CONFIG_FRAME_POINTER
        pop %rax        /* Dummy pop. */
 #endif