diff options
author | Dave Voutila <dv@cvs.openbsd.org> | 2022-04-09 01:49:44 +0000 |
---|---|---|
committer | Dave Voutila <dv@cvs.openbsd.org> | 2022-04-09 01:49:44 +0000 |
commit | 645a9e6f327ef15f229dc795b0130bde18358121 (patch) | |
tree | 3d306f2ab596776c764b04bad5a1804ece9094dc | |
parent | 2383978a0cf98694c5776dfd807135cc41327c8d (diff) |
Simplify vmx instruction error handling.
Removes jumps and shortens the code while keeping functionality the
same.
ok mlarkin@
-rw-r--r-- | sys/arch/amd64/amd64/vmm_support.S | 58 |
1 files changed, 8 insertions, 50 deletions
diff --git a/sys/arch/amd64/amd64/vmm_support.S b/sys/arch/amd64/amd64/vmm_support.S index 3be2f292a8a..cb500f56aeb 100644 --- a/sys/arch/amd64/amd64/vmm_support.S +++ b/sys/arch/amd64/amd64/vmm_support.S @@ -1,4 +1,4 @@ -/* $OpenBSD: vmm_support.S,v 1.18 2021/09/04 22:15:33 bluhm Exp $ */ +/* $OpenBSD: vmm_support.S,v 1.19 2022/04/09 01:49:43 dv Exp $ */ /* * Copyright (c) 2014 Mike Larkin <mlarkin@openbsd.org> * @@ -63,14 +63,8 @@ _C_LABEL(vmm_dispatch_intr): _C_LABEL(vmxon): RETGUARD_SETUP(vmxon, r11) vmxon (%rdi) - jz failed_on - jc failed_on xorq %rax, %rax - RETGUARD_CHECK(vmxon, r11) - ret - lfence -failed_on: - movq $0x01, %rax + setna %al RETGUARD_CHECK(vmxon, r11) ret lfence @@ -78,14 +72,8 @@ failed_on: _C_LABEL(vmxoff): RETGUARD_SETUP(vmxoff, r11) vmxoff - jz failed_off - jc failed_off xorq %rax, %rax - RETGUARD_CHECK(vmxoff, r11) - ret - lfence -failed_off: - movq $0x01, %rax + setna %al RETGUARD_CHECK(vmxoff, r11) ret lfence @@ -93,14 +81,8 @@ failed_off: _C_LABEL(vmclear): RETGUARD_SETUP(vmclear, r11) vmclear (%rdi) - jz failed_clear - jc failed_clear xorq %rax, %rax - RETGUARD_CHECK(vmclear, r11) - ret - lfence -failed_clear: - movq $0x01, %rax + setna %al RETGUARD_CHECK(vmclear, r11) ret lfence @@ -108,14 +90,8 @@ failed_clear: _C_LABEL(vmptrld): RETGUARD_SETUP(vmptrld, r11) vmptrld (%rdi) - jz failed_ptrld - jc failed_ptrld xorq %rax, %rax - RETGUARD_CHECK(vmptrld, r11) - ret - lfence -failed_ptrld: - movq $0x01, %rax + setna %al RETGUARD_CHECK(vmptrld, r11) ret lfence @@ -123,14 +99,8 @@ failed_ptrld: _C_LABEL(vmptrst): RETGUARD_SETUP(vmptrst, r11) vmptrst (%rdi) - jz failed_ptrst - jc failed_ptrst xorq %rax, %rax - RETGUARD_CHECK(vmptrst, r11) - ret - lfence -failed_ptrst: - movq $0x01, %rax + setna %al RETGUARD_CHECK(vmptrst, r11) ret lfence @@ -138,14 +108,8 @@ failed_ptrst: _C_LABEL(vmwrite): RETGUARD_SETUP(vmwrite, r11) vmwrite %rsi, %rdi - jz failed_write - jc failed_write xorq %rax, %rax - RETGUARD_CHECK(vmwrite, r11) - ret - lfence -failed_write: - movq $0x01, %rax + setna %al RETGUARD_CHECK(vmwrite, r11) ret lfence @@ -153,14 +117,8 @@ failed_write: _C_LABEL(vmread): RETGUARD_SETUP(vmread, r11) vmread %rdi, (%rsi) - jz failed_read - jc failed_read xorq %rax, %rax - RETGUARD_CHECK(vmread, r11) - ret - lfence -failed_read: - movq $0x01, %rax + setna %al RETGUARD_CHECK(vmread, r11) ret lfence |