VirtualBox

source: vbox/trunk/src/VBox/Runtime/common/math/fesetexceptflag.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.4 KB
Line 
1; $Id: fesetexceptflag.asm 96213 2022-08-15 09:36:00Z vboxsync $
2;; @file
3; IPRT - No-CRT fesetexceptflag - 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; Gets the pending exceptions.
37;
38; @returns eax = 0 on success, non-zero on failure.
39; @param pfXcpts 32-bit: [xBP+8]; msc64: rcx; gcc64: rdi; -- pointer to fexcept_t (16-bit)
40; @param fXcptMask 32-bit: [xBP+c]; msc64: edx; gcc64: esi; -- X86_MXCSR_XCPT_FLAGS (X86_FSW_XCPT_MASK)
41; Accepts X86_FSW_SF.
42;
43RT_NOCRT_BEGINPROC fesetexceptflag
44 push xBP
45 SEH64_PUSH_xBP
46 mov xBP, xSP
47 SEH64_SET_FRAME_xBP 0
48 sub xSP, 10h
49 SEH64_ALLOCATE_STACK 20h
50 SEH64_END_PROLOGUE
51
52 ;
53 ; Load the parameter into ecx (*pfXcpts) and edx (fXcptMask) and validate the latter.
54 ;
55%ifdef ASM_CALL64_GCC
56 movzx ecx, word [rdi]
57 mov edx, esi
58%elifdef ASM_CALL64_MSC
59 movzx ecx, word [rcx]
60%elifdef RT_ARCH_X86
61 mov ecx, [xBP + xCB*2]
62 movzx ecx, word [ecx]
63 mov edx, [xBP + xCB*3]
64%endif
65%if 0
66 and ecx, X86_FSW_XCPT_MASK
67 and edx, X86_FSW_XCPT_MASK
68%else
69 or eax, -1
70 test edx, ~X86_FSW_XCPT_MASK
71 jnz .return
72 test ecx, ~X86_FSW_XCPT_MASK
73 jnz .return
74%endif
75
76 ;
77 ; Apply the AND mask to ECX and invert it so we can use it to clear flags
78 ; before OR'ing in the new values.
79 ;
80 and ecx, edx
81 not edx
82
83 ;
84 ; Make the modifications
85 ;
86
87 ; Modify the pending x87 exceptions (FSW).
88 fnstenv [xBP - 20h]
89 and [xBP - 20h + X86FSTENV32P.FSW], dx
90 or [xBP - 20h + X86FSTENV32P.FSW], cx
91 fldenv [xSP - 20h]
92
93%ifdef RT_ARCH_X86
94 ; SSE supported (ecx preserved)?
95 extern NAME(rtNoCrtHasSse)
96 call NAME(rtNoCrtHasSse)
97 test al, al
98 jz .return_ok
99%endif
100
101 ; Modify the pending SSE exceptions (same bit positions as in FSW).
102 stmxcsr [xBP - 10h]
103 mov eax, [xBP - 10h]
104 or edx, X86_FSW_XCPT_MASK & ~X86_MXCSR_XCPT_FLAGS ; Don't mix X86_FSW_SF with X86_MXCSR_DAZ.
105 and ecx, X86_MXCSR_XCPT_FLAGS ; Ditto
106 and eax, edx
107 or eax, ecx
108 mov [xBP - 10h], eax
109 ldmxcsr [xBP - 10h]
110
111.return_ok:
112 xor eax, eax
113.return:
114 leave
115 ret
116ENDPROC RT_NOCRT(fesetexceptflag)
117
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