VirtualBox

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

Last change on this file since 96282 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.0 KB
Line 
1; $Id: fedisableexcept.asm 96213 2022-08-15 09:36:00Z 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.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 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%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 ;
71 ; Make the changes (old mask in eax).
72 ;
73
74 ; Modify the x87 mask first (ecx preserved).
75 fstcw [xBP - 10h]
76%ifdef RT_ARCH_X86 ; Return the inverted x87 mask in 32-bit mode.
77 movzx eax, word [xBP - 10h]
78%endif
79 or word [xBP - 10h], cx
80 fldcw [xBP - 10h]
81
82%ifdef RT_ARCH_X86
83 ; SSE supported (ecx preserved)?
84 extern NAME(rtNoCrtHasSse)
85 call NAME(rtNoCrtHasSse)
86 test al, al
87 jz .return_ok
88%endif
89
90 ; Modify the SSE mask (modifies ecx).
91 stmxcsr [xBP - 10h]
92%ifdef RT_ARCH_AMD64 ; Return the inverted MXCSR exception mask on AMD64 because windows doesn't necessarily set the x87 one.
93 mov eax, [xBP - 10h]
94 shr eax, X86_MXCSR_XCPT_MASK_SHIFT
95%endif
96 shl ecx, X86_MXCSR_XCPT_MASK_SHIFT
97 or [xBP - 10h], ecx
98 ldmxcsr [xBP - 10h]
99
100.return_ok:
101 not eax ; Invert it as we return the enabled rather than masked exceptions.
102 and eax, X86_FCW_XCPT_MASK
103.return:
104 leave
105 ret
106ENDPROC RT_NOCRT(fedisableexcept)
107
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