VirtualBox

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

Last change on this file since 96240 was 96213, checked in by vboxsync, 2 years ago

IPRT/nocrt: Implemented feraiseexcept and adjusted relevan code for X86_FSW_XCPT_MASK containg a bit more than X86_MXCSR_XCPT_FLAGS. bugref:10261

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 3.2 KB
Line 
1; $Id: feenableexcept.asm 96213 2022-08-15 09:36:00Z 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%ifdef ASM_CALL64_GCC
55 mov ecx, edi
56%elifdef RT_ARCH_X86
57 mov ecx, [xBP + xCB*2]
58%endif
59 or eax, -1
60 test ecx, ~X86_FCW_XCPT_MASK
61%ifndef RT_STRICT
62 jnz .return
63%else
64 jz .input_ok
65 int3
66 jmp .return
67.input_ok:
68%endif
69
70 ; Invert the mask as we're enabling the exceptions, not masking them.
71 not ecx
72
73 ;
74 ; Make the changes (old mask in eax).
75 ;
76
77 ; Modify the x87 mask first (ecx preserved).
78 fstcw [xBP - 10h]
79%ifdef RT_ARCH_X86 ; Return the inverted x87 mask in 32-bit mode.
80 mov ax, word [xBP - 10h]
81 and eax, X86_FCW_XCPT_MASK
82%endif
83 and word [xBP - 10h], cx
84 fldcw [xBP - 10h]
85
86%ifdef RT_ARCH_X86
87 ; SSE supported (ecx preserved)?
88 extern NAME(rtNoCrtHasSse)
89 call NAME(rtNoCrtHasSse)
90 test al, al
91 jz .return_ok
92%endif
93
94 ; Modify the SSE mask (modifies ecx).
95 stmxcsr [xBP - 10h]
96%ifdef RT_ARCH_AMD64 ; Return the inverted MXCSR exception mask on AMD64 because windows doesn't necessarily set the x87 one.
97 mov eax, [xBP - 10h]
98 and eax, X86_MXCSR_XCPT_MASK
99 shr eax, X86_MXCSR_XCPT_MASK_SHIFT
100%endif
101 rol ecx, X86_MXCSR_XCPT_MASK_SHIFT
102 and [xBP - 10h], ecx
103 ldmxcsr [xBP - 10h]
104
105.return_ok:
106 not eax ; Invert it as we return the enabled rather than masked exceptions.
107.return:
108 leave
109 ret
110ENDPROC RT_NOCRT(feenableexcept)
111
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