atan87_.asm
来自「开放源码的编译器open watcom 1.6.0版的源代码」· 汇编 代码 · 共 104 行
ASM
104 行
;*****************************************************************************
;*
;* 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!
;*
;*****************************************************************************
include mdef.inc
include struct.inc
include math387.inc
extern_chipbug
modstart atan87
.8087
xdefp __atan87 ; calc atan(fac1)
;<><><><><><><><><><><><><><><><><><><><><><><><><><><><><><><><><><><><>
;<> <>
;<> _atan - compute arctan(st0) using 8087 <>
;<> <>
;<><><><><><><><><><><><><><><><><><><><><><><><><><><><><><><><><><><><>
defp __atan87
push BP ; save BP
mov BP,SP ; get access to stack
push AX ; push argument
push BX ; . . .
push CX ; . . .
push DX ; . . .
fld qword ptr -8[BP]; load argument
sub CX,CX ; init 'negate' flag
ftst ; get sign of argument
fstsw -2[BP] ; . . .
fwait ; . . .
mov AX,-2[BP] ; . . .
sahf ; get flags ZF = C3, CF = C0
_if b ; if argument is negative
fchs ; - make argument positive
not CX ; - indicate result to be negated
_endif ; endif
fld1 ; load 1.0
fcom st(1) ; compare argument with 1.0
fstsw -2[BP] ; get result of compare
fwait ; . . .
mov AX,-2[BP] ; . . .
and AX,4100h ; isolate condition codes
_if ne ; if argument > 1.0
fxch st(1) ; - st = arg, st1 = 1.0
do_fpatan ; - calculate arctangent(1/argument)
mov AX,2 ; - compute pi/2 - atn(1/argument)
mov -2[BP],AX ; - push 2
fldpi ; - load pi
fidiv word ptr -2[BP] ; - calculate pi/2
fsubrp st(1),st(0) ; - calculate pi/2 - atn(1/argument)
_else ; else
do_fpatan ; - calculate artangent(argument)
_endif ; endif
or CX,CX ; if original argument was negative
_if ne ; then
fchs ; - negate the answer
_endif ; endif
fstp qword ptr -8[BP]; store result
fwait ; wait
pop DX ; load result
pop CX ; . . .
pop BX ; . . .
pop AX ; . . .
pop BP ; restore BP
ret ; return
endproc __atan87
endmod
end
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?