KVM: VMX: Use RAX as the scratch register during vCPU-run

...to prepare for making the sub-routine callable from C code.  That
means returning the result in RAX.  Since RAX will be used to return the
result, use it as the scratch register as well to make the code readable
and to document that the scratch register is more or less arbitrary.

Signed-off-by: Sean Christopherson <sean.j.christopherson@intel.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
Sean Christopherson 2019-01-25 07:41:15 -08:00 committed by Paolo Bonzini
parent ee2fc635ef
commit a62fd5a76c

View File

@ -103,31 +103,31 @@ ENTRY(__vmx_vcpu_run)
lea -WORD_SIZE(%_ASM_SP), %_ASM_ARG2 lea -WORD_SIZE(%_ASM_SP), %_ASM_ARG2
call vmx_update_host_rsp call vmx_update_host_rsp
/* Load @regs to RCX. */ /* Load @regs to RAX. */
mov (%_ASM_SP), %_ASM_CX mov (%_ASM_SP), %_ASM_AX
/* Check if vmlaunch or vmresume is needed */ /* Check if vmlaunch or vmresume is needed */
cmpb $0, %bl cmpb $0, %bl
/* Load guest registers. Don't clobber flags. */ /* Load guest registers. Don't clobber flags. */
mov VCPU_RAX(%_ASM_CX), %_ASM_AX mov VCPU_RBX(%_ASM_AX), %_ASM_BX
mov VCPU_RBX(%_ASM_CX), %_ASM_BX mov VCPU_RCX(%_ASM_AX), %_ASM_CX
mov VCPU_RDX(%_ASM_CX), %_ASM_DX mov VCPU_RDX(%_ASM_AX), %_ASM_DX
mov VCPU_RSI(%_ASM_CX), %_ASM_SI mov VCPU_RSI(%_ASM_AX), %_ASM_SI
mov VCPU_RDI(%_ASM_CX), %_ASM_DI mov VCPU_RDI(%_ASM_AX), %_ASM_DI
mov VCPU_RBP(%_ASM_CX), %_ASM_BP mov VCPU_RBP(%_ASM_AX), %_ASM_BP
#ifdef CONFIG_X86_64 #ifdef CONFIG_X86_64
mov VCPU_R8 (%_ASM_CX), %r8 mov VCPU_R8 (%_ASM_AX), %r8
mov VCPU_R9 (%_ASM_CX), %r9 mov VCPU_R9 (%_ASM_AX), %r9
mov VCPU_R10(%_ASM_CX), %r10 mov VCPU_R10(%_ASM_AX), %r10
mov VCPU_R11(%_ASM_CX), %r11 mov VCPU_R11(%_ASM_AX), %r11
mov VCPU_R12(%_ASM_CX), %r12 mov VCPU_R12(%_ASM_AX), %r12
mov VCPU_R13(%_ASM_CX), %r13 mov VCPU_R13(%_ASM_AX), %r13
mov VCPU_R14(%_ASM_CX), %r14 mov VCPU_R14(%_ASM_AX), %r14
mov VCPU_R15(%_ASM_CX), %r15 mov VCPU_R15(%_ASM_AX), %r15
#endif #endif
/* Load guest RCX. This kills the vmx_vcpu pointer! */ /* Load guest RAX. This kills the vmx_vcpu pointer! */
mov VCPU_RCX(%_ASM_CX), %_ASM_CX mov VCPU_RAX(%_ASM_AX), %_ASM_AX
/* Enter guest mode */ /* Enter guest mode */
call vmx_vmenter call vmx_vmenter
@ -135,29 +135,29 @@ ENTRY(__vmx_vcpu_run)
/* Jump on VM-Fail. */ /* Jump on VM-Fail. */
jbe 2f jbe 2f
/* Temporarily save guest's RCX. */ /* Temporarily save guest's RAX. */
push %_ASM_CX push %_ASM_AX
/* Reload @regs to RCX. */ /* Reload @regs to RAX. */
mov WORD_SIZE(%_ASM_SP), %_ASM_CX mov WORD_SIZE(%_ASM_SP), %_ASM_AX
/* Save all guest registers, including RCX from the stack */ /* Save all guest registers, including RAX from the stack */
mov %_ASM_AX, VCPU_RAX(%_ASM_CX) __ASM_SIZE(pop) VCPU_RAX(%_ASM_AX)
mov %_ASM_BX, VCPU_RBX(%_ASM_CX) mov %_ASM_BX, VCPU_RBX(%_ASM_AX)
__ASM_SIZE(pop) VCPU_RCX(%_ASM_CX) mov %_ASM_CX, VCPU_RCX(%_ASM_AX)
mov %_ASM_DX, VCPU_RDX(%_ASM_CX) mov %_ASM_DX, VCPU_RDX(%_ASM_AX)
mov %_ASM_SI, VCPU_RSI(%_ASM_CX) mov %_ASM_SI, VCPU_RSI(%_ASM_AX)
mov %_ASM_DI, VCPU_RDI(%_ASM_CX) mov %_ASM_DI, VCPU_RDI(%_ASM_AX)
mov %_ASM_BP, VCPU_RBP(%_ASM_CX) mov %_ASM_BP, VCPU_RBP(%_ASM_AX)
#ifdef CONFIG_X86_64 #ifdef CONFIG_X86_64
mov %r8, VCPU_R8 (%_ASM_CX) mov %r8, VCPU_R8 (%_ASM_AX)
mov %r9, VCPU_R9 (%_ASM_CX) mov %r9, VCPU_R9 (%_ASM_AX)
mov %r10, VCPU_R10(%_ASM_CX) mov %r10, VCPU_R10(%_ASM_AX)
mov %r11, VCPU_R11(%_ASM_CX) mov %r11, VCPU_R11(%_ASM_AX)
mov %r12, VCPU_R12(%_ASM_CX) mov %r12, VCPU_R12(%_ASM_AX)
mov %r13, VCPU_R13(%_ASM_CX) mov %r13, VCPU_R13(%_ASM_AX)
mov %r14, VCPU_R14(%_ASM_CX) mov %r14, VCPU_R14(%_ASM_AX)
mov %r15, VCPU_R15(%_ASM_CX) mov %r15, VCPU_R15(%_ASM_AX)
#endif #endif
/* Clear EBX to indicate VM-Exit (as opposed to VM-Fail). */ /* Clear EBX to indicate VM-Exit (as opposed to VM-Fail). */