forked from KolibriOS/kolibrios
836c97f0ac
git-svn-id: svn://kolibrios.org@553 a494cfbc-eb01-0410-851d-a64ba20cac60
102 lines
4.1 KiB
NASM
102 lines
4.1 KiB
NASM
;*****************************************************************************
|
|
;*
|
|
;* 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
|
|
|
|
modstart i8fd386
|
|
|
|
xref __I8LS
|
|
xref __I8RS
|
|
|
|
; Convert signed 64-bit integer to double precision float
|
|
; Input: [EDX, EAX] = 64-bit integer
|
|
; Output: [EDX, EAX] = double
|
|
|
|
xdefp __I8FD
|
|
defp __I8FD
|
|
or EDX,EDX ; check sign
|
|
jns __U8FD ; if positive, just convert
|
|
neg EDX ;
|
|
neg EAX ; take absolute value of number
|
|
sbb EDX,0 ;
|
|
call __U8FD ; convert to FD
|
|
or EDX,80000000h ; set sign bit on
|
|
ret ; return
|
|
endproc __I8FD
|
|
|
|
; Convert unsigned 64-bit integer to double precision float
|
|
; Input: [EDX, EAX] = 64-bit integer
|
|
; Output: [EDX, EAX] = double
|
|
|
|
xdefp __U8FD
|
|
defp __U8FD
|
|
or EAX,EAX ; if lo is zero
|
|
_if e ;
|
|
or EDX,EDX ; and if hi is zero
|
|
_if e ;
|
|
ret ; - return
|
|
_endif
|
|
_endif ; endif
|
|
push ECX ; save ECX
|
|
push EBX ; save EBX
|
|
bsr ECX,EDX ; find most significant non-zero bit in hi
|
|
_if e ; if all zero bits
|
|
bsr ECX,EAX ; - find most significant non-zero bit in lo
|
|
_else ; else
|
|
add CL,32 ; - adjust shift count since hi was not 0
|
|
_endif ; endif
|
|
push ECX ; save shift count
|
|
neg CL ; calculate # of bits to shift by
|
|
add CL,63-11 ; ...
|
|
mov EBX,ECX ; set up for call
|
|
or CL,CL ; if mantissa should move left
|
|
_if ge ; then
|
|
call __I8LS ; - shift left
|
|
_else ; else
|
|
neg BL ; - make positive
|
|
call __I8RS ; - shift right
|
|
_endif ; endif
|
|
pop ECX ; restore shift count
|
|
and EDX,000FFFFFh ; mask out sign and exponent bits
|
|
add CX,1023 ; calculate exponent (excess 1023)
|
|
; and ECX,0FFFh ; isolate exponent (not required)
|
|
shl ECX,20 ; shift exponent into position
|
|
or EDX,ECX ; place into result
|
|
pop EBX ; restore EBX
|
|
pop ECX ; restore ECX
|
|
ret ; return
|
|
endproc __U8FD
|
|
|
|
endmod
|
|
end
|