VirtualBox

source: vbox/trunk/src/VBox/Runtime/common/math/fedisableexcept.asm@ 96205

Last change on this file since 96205 was 96205, checked in by vboxsync, 3 years ago

IPRT/nocrt: Implemented x86 and amd64 fenv.h to assist with the testing. More tests. bugref:10261

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 2.9 KB
Line 
1; $Id: fedisableexcept.asm 96205 2022-08-14 23:40:55Z vboxsync $
2;; @file
3; IPRT - No-CRT fedisableexcept - AMD64 & X86.
4;
5
6;
7; Copyright (C) 2022 Oracle Corporation
8;
9; This file is part of VirtualBox Open Source Edition (OSE), as
10; available from http://www.215389.xyz. This file is free software;
11; you can redistribute it and/or modify it under the terms of the GNU
12; General Public License (GPL) as published by the Free Software
13; Foundation, in version 2 as it comes in the "COPYING" file of the
14; VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15; hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16;
17; The contents of this file may alternatively be used under the terms
18; of the Common Development and Distribution License Version 1.0
19; (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20; VirtualBox OSE distribution, in which case the provisions of the
21; CDDL are applicable instead of those of the GPL.
22;
23; You may elect to license modified versions of this file under the
24; terms and conditions of either the GPL or the CDDL or both.
25;
26
27
28%define RT_ASM_WITH_SEH64
29%include "iprt/asmdefs.mac"
30%include "iprt/x86.mac"
31
32
33BEGINCODE
34
35;;
36; Enables a set of exceptions (BSD/GNU extension).
37;
38; @returns eax = Previous enabled exceptions on success (not subject to fXcpt),
39; -1 on failure.
40; @param fXcpt 32-bit: [xBP+8] msc64: ecx gcc64: edi - Mask of exceptions to disable.
41;
42RT_NOCRT_BEGINPROC fedisableexcept
43 push xBP
44 SEH64_PUSH_xBP
45 mov xBP, xSP
46 SEH64_SET_FRAME_xBP 0
47 sub xSP, 10h
48 SEH64_ALLOCATE_STACK 10h
49 SEH64_END_PROLOGUE
50
51 ;
52 ; Load the parameter into ecx.
53 ;
54 or eax, -1
55%ifdef ASM_CALL64_GCC
56 mov ecx, edi
57%elifdef RT_ARCH_X86
58 mov ecx, [xBP + xCB*2]
59%endif
60 test ecx, ~X86_FCW_XCPT_MASK
61 jnz .return
62
63 ;
64 ; Make the changes (old mask in eax).
65 ;
66
67 ; Modify the x87 mask first (ecx preserved).
68 fstcw [xBP - 10h]
69%ifdef RT_ARCH_X86 ; Return the inverted x87 mask in 32-bit mode.
70 movzx eax, word [xBP - 10h]
71%endif
72 or word [xBP - 10h], cx
73 fldcw [xBP - 10h]
74
75%ifdef RT_ARCH_X86
76 ; SSE supported (ecx preserved)?
77 extern NAME(rtNoCrtHasSse)
78 call NAME(rtNoCrtHasSse)
79 test al, al
80 jz .return_ok
81%endif
82
83 ; Modify the SSE mask (modifies ecx).
84 stmxcsr [xBP - 10h]
85%ifdef RT_ARCH_AMD64 ; Return the inverted MXCSR exception mask on AMD64 because windows doesn't necessarily set the x87 one.
86 mov eax, [xBP - 10h]
87 shr eax, X86_MXCSR_XCPT_MASK_SHIFT
88%endif
89 shl ecx, X86_MXCSR_XCPT_MASK_SHIFT
90 or [xBP - 10h], ecx
91 ldmxcsr [xBP - 10h]
92
93.return_ok:
94 not eax ; Invert it as we return the enabled rather than masked exceptions.
95 and eax, X86_FCW_XCPT_MASK
96.return:
97 leave
98 ret
99ENDPROC RT_NOCRT(fedisableexcept)
100
Note: See TracBrowser for help on using the repository browser.

© 2025 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette