X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?p=palacios.git;a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fvmx_lowlevel.h;h=9ea6ffbc5e161cdec5ef8c6a950bca83edefbd5d;hp=b654414abc8527e3d1b49185e621b6e42042af8a;hb=9bc5c1ff326aa6ac111e1d3824c93770391aef23;hpb=a24a1722328a575cec8dd8578902fd0f68c72c1c diff --git a/palacios/include/palacios/vmx_lowlevel.h b/palacios/include/palacios/vmx_lowlevel.h index b654414..9ea6ffb 100644 --- a/palacios/include/palacios/vmx_lowlevel.h +++ b/palacios/include/palacios/vmx_lowlevel.h @@ -22,6 +22,7 @@ #ifdef __V3VEE__ +#include #define VMX_SUCCESS 0 #define VMX_FAIL_INVALID 1 @@ -134,10 +135,10 @@ static inline int vmcs_read(vmcs_field_t vmcs_field, void * dst) { __asm__ __volatile__ ( VMREAD_OPCODE EAX_ECX_MODRM - "seteb %0;" // fail valid + "seteb %1;" // fail valid "setnaeb %1;" // fail invalid - : "=q"(ret_valid), "=q"(ret_invalid), "=c"(val) // Use ECX - : "a" (vmcs_field), "0"(ret_valid), "1"(ret_invalid) + : "=c"(val), "=d"(ret_valid) //, "=r"(ret_invalid) // Use ECX + : "a" (vmcs_field), "0"(0), "1"(ret_valid) : "memory" ); @@ -169,8 +170,8 @@ static inline int vmcs_write(vmcs_field_t vmcs_field, addr_t value) { EAX_ECX_MODRM "seteb %0;" // fail valid (ZF=1) "setnaeb %1;" // fail invalid (CF=1) - : "=q" (ret_valid), "=q" (ret_invalid) - : "a" (vmcs_field), "c"(value), "0"(ret_valid), "1"(ret_invalid) + : "=r" (ret_valid), "=r" (ret_invalid) + : "a" (vmcs_field), "c"(value) : "memory"); CHECK_VMXFAIL(ret_valid, ret_invalid);