VirtualBox

source: vbox/trunk/src/VBox/Runtime/common/math/feclearexcept.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.1 KB
Line 
1; $Id: feclearexcept.asm 96213 2022-08-15 09:36:00Z vboxsync $
2;; @file
3; IPRT - No-CRT feclearexcept - 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; Sets the hardware rounding mode.
37;
38; @returns eax = 0 on success, non-zero on failure.
39; @param fXcpts 32-bit: [xBP+8]; msc64: ecx; gcc64: edi; -- Zero or more bits from X86_FSW_XCPT_MASK
40;
41RT_NOCRT_BEGINPROC feclearexcept
42 push xBP
43 SEH64_PUSH_xBP
44 mov xBP, xSP
45 SEH64_SET_FRAME_xBP 0
46 sub xSP, 20h
47 SEH64_ALLOCATE_STACK 20h
48 SEH64_END_PROLOGUE
49
50 ;
51 ; Load the parameter into ecx, validate and adjust it.
52 ;
53%ifdef ASM_CALL64_GCC
54 mov ecx, edi
55%elifdef RT_ARCH_X86
56 mov ecx, [xBP + xCB*2]
57%endif
58%if 0
59 and ecx, X86_FSW_XCPT_MASK
60%else
61 or eax, -1
62 test ecx, ~X86_FSW_XCPT_MASK
63 jnz .return
64%endif
65
66 ; #IE implies #SF
67 mov al, cl
68 and al, X86_FSW_IE
69 shl al, X86_FSW_SF_BIT - X86_FSW_IE_BIT
70 or cl, al
71
72 ; Make it into and AND mask suitable for clearing the specified exceptions.
73 not ecx
74
75 ;
76 ; Make the changes.
77 ;
78
79 ; Modify the x87 flags first (ecx preserved).
80 cmp ecx, ~X86_FSW_XCPT_MASK ; This includes all the x87 exceptions, including stack error.
81 jne .partial_mask
82 fnclex
83 jmp .do_sse
84
85.partial_mask:
86 fnstenv [xBP - 20h]
87 and word [xBP - 20h + 4], cx ; The FCW is at offset 4 in the 32-bit prot mode layout
88 fldenv [xBP - 20h] ; Recalculates the FSW.ES flag.
89.do_sse:
90
91%ifdef RT_ARCH_X86
92 ; SSE supported (ecx preserved)?
93 extern NAME(rtNoCrtHasSse)
94 call NAME(rtNoCrtHasSse)
95 test al, al
96 jz .return_ok
97%endif
98
99 ; Modify the SSE flags (modifies ecx).
100 stmxcsr [xBP - 10h]
101 or ecx, X86_FSW_XCPT_MASK & ~X86_MXCSR_XCPT_FLAGS ; Don't mix X86_FSW_SF with X86_MXCSR_DAZ.
102 and [xBP - 10h], ecx
103 ldmxcsr [xBP - 10h]
104
105.return_ok:
106 xor eax, eax
107.return:
108 leave
109 ret
110ENDPROC RT_NOCRT(feclearexcept)
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