diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-06 03:01:46 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-06 03:01:46 +0000 |
commit | f8fe689a81f906d1b91bb3220acde2a4ecb14c5b (patch) | |
tree | 26484e9d7e2c67806c2d1760196ff01aaa858e8c /src/VBox/VMM/testcase/tstX86-FpuSaveRestoreA.asm | |
parent | Initial commit. (diff) | |
download | virtualbox-f8fe689a81f906d1b91bb3220acde2a4ecb14c5b.tar.xz virtualbox-f8fe689a81f906d1b91bb3220acde2a4ecb14c5b.zip |
Adding upstream version 6.0.4-dfsg.upstream/6.0.4-dfsgupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r-- | src/VBox/VMM/testcase/tstX86-FpuSaveRestoreA.asm | 117 |
1 files changed, 117 insertions, 0 deletions
diff --git a/src/VBox/VMM/testcase/tstX86-FpuSaveRestoreA.asm b/src/VBox/VMM/testcase/tstX86-FpuSaveRestoreA.asm new file mode 100644 index 00000000..f6f3a1fe --- /dev/null +++ b/src/VBox/VMM/testcase/tstX86-FpuSaveRestoreA.asm @@ -0,0 +1,117 @@ +; $Id: tstX86-FpuSaveRestoreA.asm $ +;; @file +; tstX86-FpuSaveRestore - Experimenting with saving and restoring FPU, assembly bits. +; + +; +; Copyright (C) 2013-2019 Oracle Corporation +; +; This file is part of VirtualBox Open Source Edition (OSE), as +; available from http://www.virtualbox.org. This file is free software; +; you can redistribute it and/or modify it under the terms of the GNU +; General Public License (GPL) as published by the Free Software +; Foundation, in version 2 as it comes in the "COPYING" file of the +; VirtualBox OSE distribution. VirtualBox OSE is distributed in the +; hope that it will be useful, but WITHOUT ANY WARRANTY of any kind. +; + + + +;******************************************************************************* +;* Header Files * +;******************************************************************************* +%include "iprt/asmdefs.mac" +%include "iprt/x86.mac" + + +;******************************************************************************* +;* Global Variables * +;******************************************************************************* +BEGINCODE +g_r80_Zero: dt 0.0 +g_r80_One: dt 1.0 + + +BEGINCODE + +;; Prepares a FPU exception. +BEGINPROC MyFpuPrepXcpt + fld tword [g_r80_One xWrtRIP] + fld tword [g_r80_Zero xWrtRIP] + fdiv st0 + ret +ENDPROC MyFpuPrepXcpt + + +;; Same as above, just different address. +BEGINPROC MyFpuPrepXcpt2 + fld tword [g_r80_One xWrtRIP] + fld tword [g_r80_Zero xWrtRIP] + fdiv st0 + ret +ENDPROC MyFpuPrepXcpt2 + + +BEGINPROC MyFpuSave +%ifdef ASM_CALL64_MSC + o64 fxsave [rcx] +%elifdef ASM_CALL64_GCC + o64 fxsave [rdi] +%elifdef RT_ARCH_X86 + mov ecx, [esp + 4] + fxsave [ecx] +%else + %error "Unsupported architecture." + bad arch +%endif + ret +ENDPROC MyFpuSave + + +BEGINPROC MyFpuStoreEnv +%ifdef ASM_CALL64_MSC + fstenv [rcx] +%elifdef ASM_CALL64_GCC + fstenv [rdi] +%elifdef RT_ARCH_X86 + mov ecx, [esp + 4] + fstenv [ecx] +%else + %error "Unsupported architecture." + bad arch +%endif + ret +ENDPROC MyFpuStoreEnv + + +BEGINPROC MyFpuRestore +%ifdef ASM_CALL64_MSC + o64 fxrstor [rcx] +%elifdef ASM_CALL64_GCC + o64 fxrstor [rdi] +%elifdef RT_ARCH_X86 + mov ecx, [esp + 4] + fxrstor [ecx] +%else + %error "Unsupported architecture." + bad arch +%endif + ret +ENDPROC MyFpuRestore + + +BEGINPROC MyFpuLoadEnv +%ifdef ASM_CALL64_MSC + fldenv [rcx] +%elifdef ASM_CALL64_GCC + fldenv [rdi] +%elifdef RT_ARCH_X86 + mov ecx, [esp + 4] + fldenv [ecx] +%else + %error "Unsupported architecture." + bad arch +%endif + ret +ENDPROC MyFpuLoadEnv + |