VirtualBox

source: vbox/trunk/src/VBox/Runtime/common/math/feenableexcept.asm@ 96206

Last change on this file since 96206 was 96205, checked in by vboxsync, 2 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: 3.0 KB
Line 
1; $Id: feenableexcept.asm 96205 2022-08-14 23:40:55Z vboxsync $
2;; @file
3; IPRT - No-CRT feenableexcept - 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.virtualbox.org. 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 enable.
41;
42RT_NOCRT_BEGINPROC feenableexcept
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 ; Invert the mask as we're enabling the exceptions, not masking them.
64 not ecx
65
66 ;
67 ; Make the changes (old mask in eax).
68 ;
69
70 ; Modify the x87 mask first (ecx preserved).
71 fstcw [xBP - 10h]
72%ifdef RT_ARCH_X86 ; Return the inverted x87 mask in 32-bit mode.
73 movzx eax, word [xBP - 10h]
74%endif
75 and word [xBP - 10h], cx
76 fldcw [xBP - 10h]
77
78%ifdef RT_ARCH_X86
79 ; SSE supported (ecx preserved)?
80 extern NAME(rtNoCrtHasSse)
81 call NAME(rtNoCrtHasSse)
82 test al, al
83 jz .return_ok
84%endif
85
86 ; Modify the SSE mask (modifies ecx).
87 stmxcsr [xBP - 10h]
88%ifdef RT_ARCH_AMD64 ; Return the inverted MXCSR exception mask on AMD64 because windows doesn't necessarily set the x87 one.
89 mov eax, [xBP - 10h]
90 shr eax, X86_MXCSR_XCPT_MASK_SHIFT
91%endif
92 rol ecx, X86_MXCSR_XCPT_MASK_SHIFT
93 and [xBP - 10h], ecx
94 ldmxcsr [xBP - 10h]
95
96.return_ok:
97 not eax ; Invert it as we return the enabled rather than masked exceptions.
98 and eax, X86_FCW_XCPT_MASK
99.return:
100 leave
101 ret
102ENDPROC RT_NOCRT(feenableexcept)
103
Note: See TracBrowser for help on using the repository browser.

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