modf387.asm
来自「开放源码的编译器open watcom 1.6.0版的源代码」· 汇编 代码 · 共 103 行
ASM
103 行
;*****************************************************************************
;*
;* Open Watcom Project
;*
;* Portions Copyright (c) 1983-2002 Sybase, Inc. All Rights Reserved.
;*
;* ========================================================================
;*
;* This file contains Original Code and/or Modifications of Original
;* Code as defined in and that are subject to the Sybase Open Watcom
;* Public License version 1.0 (the 'License'). You may not use this file
;* except in compliance with the License. BY USING THIS FILE YOU AGREE TO
;* ALL TERMS AND CONDITIONS OF THE LICENSE. A copy of the License is
;* provided with the Original Code and Modifications, and is also
;* available at www.sybase.com/developer/opensource.
;*
;* The Original Code and all software distributed under the License are
;* distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
;* EXPRESS OR IMPLIED, AND SYBASE AND ALL CONTRIBUTORS HEREBY DISCLAIM
;* ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF
;* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR
;* NON-INFRINGEMENT. Please see the License for the specific language
;* governing rights and limitations under the License.
;*
;* ========================================================================
;*
;* Description: WHEN YOU FIGURE OUT WHAT THIS FILE DOES, PLEASE
;* DESCRIBE IT HERE!
;*
;*****************************************************************************
ifdef __386__
.387
else
.8087
endif
include mdef.inc
include math387.inc
xref __8087 ; indicate that NDP instructions are present
modstart modf387
xref __CHP
xdefp "C",modf ; double modf( double x, double *iptr )
; input: x - on the stack
; iptr on the stack
; output: signed fractional part of x in EDX:EAX
; *iptr gets the integer part of x
;
defp modf
ifdef __386__
push EAX ; save EAX
fld qword ptr 8[ESP]; load x
fld st(0) ; duplicate it
call __CHP ; calculate integer part
fsub st(1),st(0) ; subtract integer part from x
mov EAX,16[ESP] ; get iptr
fstp qword ptr [EAX] ; store integer part
pop EAX ; restore EAX
loadres ; load result
fwait ; wait
ret_pop 12 ; return
else
if _MODEL and _BIG_CODE
argx equ 6
else
argx equ 4
endif
iptr equ argx+8
push BP ; save BP
mov BP,SP ; get access to parms
push BX ; save BX
if _MODEL and (_BIG_DATA or _HUGE_DATA)
push DS ; save DS
lds BX,iptr[BP] ; get segment and offset of iptr
popamt equ 8+4
else
mov BX,iptr[BP] ; get iptr
popamt equ 8+2
endif
fld qword ptr argx[BP]; load argument
fld st(0) ; dup x
docall __CHP ; calculate integer part
fsub st(1),st(0) ; subtract integer part from x
fstp qword ptr [bx] ; store integer part
if _MODEL and (_BIG_DATA or _HUGE_DATA)
pop DS ; restore DS
endif
pop BX ; restore BX
fwait ; wait
pop BP ; restore BP
ret popamt ; return
endif
endproc modf
endmod
end
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?