VirtualBox

source: vbox/trunk/src/VBox/Runtime/common/math/fesetexceptflag.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.2 KB
Line 
1; $Id: fesetexceptflag.asm 96205 2022-08-14 23:40:55Z 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_FSW_XCPT_MASK
41;
42RT_NOCRT_BEGINPROC fesetexceptflag
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 20h
49 SEH64_END_PROLOGUE
50
51 ;
52 ; Load the parameter into ecx (*pfXcpts) and edx (fXcptMask).
53 ;
54%ifdef ASM_CALL64_GCC
55 movzx ecx, word [rdi]
56 mov edx, esi
57%elifdef ASM_CALL64_MSC
58 movzx ecx, word [rcx]
59%elifdef RT_ARCH_X86
60 mov ecx, [xBP + xCB*2]
61 movzx ecx, word [ecx]
62 mov edx, [xBP + xCB*3]
63%endif
64%if 0
65 and ecx, X86_FSW_XCPT_MASK
66 and edx, X86_FSW_XCPT_MASK
67%else
68 or eax, -1
69 test edx, ~X86_FSW_XCPT_MASK
70 jnz .return
71 test ecx, ~X86_FSW_XCPT_MASK
72 jnz .return
73%endif
74
75 ; Apply the AND mask to ECX and invert it so we can use it to clear flags
76 ; before OR'ing in the new values.
77 and ecx, edx
78 not edx
79
80 ;
81 ; Make the modifications
82 ;
83
84 ; Modify the pending x87 exceptions (FSW).
85 fnstenv [xBP - 20h]
86 mov ax, [xBP - 20h + 4] ; FSW is the 2nd qword in the 32-bit protected mode layout
87 and ax, dx
88 or ax, cx
89 mov [xBP - 20h + 4], ax
90 fldenv [xSP - 20h]
91
92%ifdef RT_ARCH_X86
93 ; SSE supported (ecx preserved)?
94 extern NAME(rtNoCrtHasSse)
95 call NAME(rtNoCrtHasSse)
96 test al, al
97 jz .return_ok
98%endif
99
100 ; Modify the pending SSE exceptions (same bit positions as in FSW).
101 stmxcsr [xBP - 10h]
102 mov eax, [xBP - 10h]
103 and eax, edx
104 or eax, ecx
105 mov [xBP - 10h], eax
106 ldmxcsr [xBP - 10h]
107
108.return_ok:
109 xor eax, eax
110.return:
111 leave
112 ret
113ENDPROC RT_NOCRT(fesetexceptflag)
114
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