Trailing-Edge
-
PDP-10 Archives
-
cobol12c
-
fix.mac
There are 7 other files named fix.mac in the archive. Click here to see a list.
; UPD ID= 3156 on 9/29/80 at 11:36 AM by NIXON
TITLE FIX FOR LIBOL V12C
SUBTTL CONVERT FLOATING-POINT TO 2-WORD COMPUTATIONAL AL BLACKINGTON/CAM/DMN
SEARCH COPYRT
SALL
;COPYRIGHT (C) DIGITAL EQUIPMENT CORPORATION 1974, 1985
;ALL RIGHTS RESERVED.
;
;THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY BE USED AND COPIED
;ONLY IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE.
SEARCH LBLPRM
HISEG
.COPYRIGHT ;Put COPYRIGHT statement in .REL file.
; EDIT HISTORY
;NAME DATE COMMENTS
;V12A**************
;JEH 30-Jun-83 [1072] Don't turn on sign bit if value is zero
;JSM 5-Oct-81 [1004] FOR BIS TURN ON CORRECT SECOND WORD SIGN BIT
;V12**************
;DMN 29-SEP-80 [647] DON'T TURN ON LOW-WORD SIGN BIT IF RESULT IS ZERO.
;EHM 27-APR-78 [527] TEST FOR OVERFLOW AND UNDERFLOW
EXTERNAL OVFLO.
ENTRY FIX.,FIX.2
;CALLING SEQUENCE:
; MOVE AC,<FLOATING-POINT NUMBER>
; MOVE PA,[Z AC,<RESULT>]
; PUSHJ PP,FIX./FIX.2
FIX.: LDB IN,[POINT 4,PA,12]
MOVE IN,0(IN)
TDNN IN,[XWD 777,-1] ;IS IT ZERO?
JRST CC3C2D ;YES
MOVM TA,IN ;NO--GET
CAMLE TA,[DEC 9.9999999E+18] ;[527] IS IT TOO LARGE?
JRST FIXTL ;[527] YES
CAMGE TA,[DEC 1.0E-18] ;[527] IS IT TOO SMALL?
JRST FIXTS ;[527] YES
MULI TA,400 ; GET EXPONENT
MOVEI TC,0
ASHC TB,-306(TA) ;SHIFT TO GET INTEGER
CC3C2B: JUMPGE IN,CC3C2C ;WAS INPUT POSITIVE?
IFE BIS,<
SETCA TB, ;NO--NEGATE THE 2-WORD RESULT
MOVNS TC
SKIPN TC
ADDI TB,1
SKIPGE TB
TLO TC,1B18
CC3C2C: MOVEM TB,0(PA) ;STASH RESULT
MOVEM TC,1(PA)
POPJ PP,
>
IFN BIS,<
DMOVN TB,TB ;MAKE RESULT NEGATIVE
SKIPN TB ;[1072] UNLESS RESULT IS ZERO
SKIPE TC ;[1072]
TLO TC,(1B0) ;FIX 2ND WORD SIGN BIT ;[M1004]
CC3C2C: DMOVEM TB,0(PA) ;STASH RESULT
POPJ PP,
>
FIXTS: SETOM OVFLO. ;[527] TURN ON OVERFLOW
CC3C2D: SETZM 0(PA) ;INPUT IS ZERO--ZERO THE RESULT
SETZM 1(PA)
POPJ PP,
FIXTL2: MOVE IN,(IN) ;GET SIGN IN D.P. CASE
FIXTL: SETOM OVFLO. ;[527] TURN ON OVERFLOW
HRLOI TB,377777 ;[527] GIVE USER A LARGE NUMBER
HRLOI TC,377777 ;[527] IN CASE NO ON SIZE ERROR
JRST CC3C2B ;[527] STASH RESULT & EXIT
;D.P. FLOATING POINT TO 2-WORD COMP
FIX.2: LDB IN,[POINT 4,PA,12]
DMOVE TA,(IN) ;GET SOURCE
TDNN TA,[777,,-1] ;IS IT ZERO?
JUMPE TB,CC3C2D ;YES
SKIPGE TA ;GET MAGNITUDE ONLY
DMOVN TA,TA ;FOR SIZE TESTS
CAMN TA,[307400,,0] ;1.1805916E+21
CAIGE TB,0 ;WHICH IS MAX. POSSIBLE 2 WORD INTEGER
CAML TA,[307400,,0]
JRST FIXTL2 ;TOO BIG
CAMN TA,[105477,,113564] ;1.0E-18
CAML TB,[164441,,653502]
CAMG TA,[105477,,113564]
JRST FIXTS ;TOO SMALL
DMOVE TA,(IN) ;GET SOURCE AGAIN
HLRE TC,TA ;ISOLATE EXPONENT
ASH TC,-9 ;...
JUMPGE TA,.+3 ;IF NEGATIVE
DMOVN TA,TA ;MAKE POSITIVE
TRC TC,-1 ;BUT REMEMBER NEGATIVE SIGN
TLZ TA,777000 ;CLEAR EXPONENT FIELD
ASHC TA,-276(TC) ;SHIFT INTEGER INTO POSITION
JUMPGE TC,FIX.2R ;IF ORIGINAL NUMBER WAS POSITIVE STORE RESULT
SKIPN TA ;[647] TEST FOR EXACTLY ZERO
JUMPE TB,FIX.2R ;[647] IN WHICH CASE DON'T TURN ON SIGN BIT
DMOVN TA,TA ;OTHERWISE MAKE RESULT NEGATIVE
TLO TB,(1B0) ;FIX 2ND WORD SIGN BIT
FIX.2R: DMOVEM TA,0(PA) ;AND STORE
POPJ PP,
IN=11 ;INPUT ACCUMULATOR
TA=13 ;SCRATCH
TB=TA+1 ;SCRATCH
TC=TA+2 ;SCRATCH
PA=16 ;ADDRESS OF RESULT
PP=17 ;PUSH-DOWN POINTER
END