VirtualBox

source: vbox/trunk/src/VBox/Runtime/common/math/feclearexcept.asm@ 96205

最後變更 在這個檔案從96205是 96205,由 vboxsync 提交於 3 年 前

IPRT/nocrt: Implemented x86 and amd64 fenv.h to assist with the testing. More tests. bugref:10261

  • 屬性 svn:eol-style 設為 native
  • 屬性 svn:keywords 設為 Author Date Id Revision
檔案大小: 2.8 KB
 
1; $Id: feclearexcept.asm 96205 2022-08-14 23:40:55Z 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.alldomusa.eu.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 - 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.
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 ; Make it into and AND mask suitable for clearing the specified exceptions.
67 not ecx
68
69 ;
70 ; Make the changes.
71 ;
72
73 ; Modify the x87 flags first (ecx preserved).
74 cmp ecx, X86_FSW_XCPT_MASK
75 jne .partial_mask
76 fnclex
77 jmp .do_sse
78
79.partial_mask:
80 fnstenv [xBP - 20h]
81 and word [xBP - 20h + 4], cx ; The FCW is at offset 4 in the 32-bit prot mode layout
82 fldenv [xBP - 20h] ; Recalculates the FSW.ES flag.
83.do_sse:
84
85%ifdef RT_ARCH_X86
86 ; SSE supported (ecx preserved)?
87 extern NAME(rtNoCrtHasSse)
88 call NAME(rtNoCrtHasSse)
89 test al, al
90 jz .return_ok
91%endif
92
93 ; Modify the SSE flags (modifies ecx).
94 stmxcsr [xBP - 10h]
95 and [xBP - 10h], ecx
96 ldmxcsr [xBP - 10h]
97
98.return_ok:
99 xor eax, eax
100.return:
101 leave
102 ret
103ENDPROC RT_NOCRT(feclearexcept)
104
注意: 瀏覽 TracBrowser 來幫助您使用儲存庫瀏覽器

© 2025 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette