Google
 

Trailing-Edge - PDP-10 Archives - cobol12c - dpadd.mac
There are 7 other files named dpadd.mac in the archive. Click here to see a list.
; UPD ID= 3549 on 5/14/81 at 1:29 PM by NIXON                           
TITLE	DPADD FOR LIBOL V12C
SUBTTL	DOUBLE-PRECISION INTEGER ADDITION	PETE WILSON/ALB/CAM



	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.

;V12B****
;EDIT	  DATE		WHO	DESCRIPTION
;
;1107	16-JAN-84	JEH	Don't clear overflow flags in ADD.21,
;				 they're needed to produce 'on size error'
;
;V12*****
;	 6-OCT-78	[540] ADD QUAD-WORD ROUNDING FUNCTION

;V10*****
;	5/10/75		/DBT	ADD BIS CODE
;***********

	SEARCH	LBLPRM
	%%LBLP==:%%LBLP
	BIS==:BIS

	HISEG

	.COPYRIGHT		;Put COPYRIGHT statement in .REL file.

;CALLING SEQUENCE:
;	MOVE 16,<Z AC,OPERAND B>
;	PUSHJ 17,ADD.12/ADD.21/ADD.22

;ENTER WITH FIRST OPERAND (OPERAND A) IN ACCUMULATOR SPECIFIED BY AC-FIELD OF PARAMETER
;SECOND OPERAND (OPERAND B) IS ACCESSED VIA AC 16 (WHERE THE UUO IS).
; IF DOUBLE-PRECISION:
;	0(16) GETS HIGH-ORDER WORD, 1(16) REFERENCES LOW HALF.
; IF SINGLE-PRECISION:
;	0(16) REFERENCES SINGLE WORD.
;EXIT WITH TWO-WORD RESULT IN AC'S SPECIFIED BY AC-FIELD OF PARAMETER

	ENTRY	ADD.12	;ADD TWO WORDS IN MEMORY TO ONE WORD IN AC 1.
	ENTRY	ADD.21	;ADD ONE WORD IN MEMORY TO TWO WORDS IN AC'S 0 AND 1.
	ENTRY	ADD.22	;ADD TWO WORDS IN MEMORY TO TWO WORDS IN AC'S 0 AND 1.
IFN BIS,<
	ENTRY	ADD.4R	;[540] ADD ONE WORD IN ACC 4 TO 4 WORDS IN ACCS 0-3
>

RS=11		;RESULT AC POINTER
TA=13		;TEMPORARY
TB=14		;TEMPORARY
TC=15		;TEMPORARY
PA=16		;POINTER TO OPERAND B.
PP=17		;PUSH-DOWN POINTER.

IFE	BIS,<

ADD.21:	SKIPL	0(PA)		;ADD SINGLE TO DOUBLE, CHECK SIGN OF LOW B OPERAND.
	TDZA	TC,TC		;MAKE SIGN OF HIGH-ORDER B OPERAND AGREE
	SETO	TC,		;  WITH LOW-ORDER SIGN.
	SOJA	PA,ADDXX		;THEN ADJUST POINTER AND ENTER MAIN LINE.

ADD.12:	LDB	RS,[POINT 4,PA,12]	;GET INPUT AC
	MOVE	TA,0(RS)	;GET OPERAND
	MULI	TA,1		;CREATE DOUBLE-PRECISION
	MOVE	TC,0(PA)	;GET HI-PART OF OTHER OPERAND
	JRST	ADDXX1

ADD.22:	MOVE	TC,0(PA)	;ADD DOUBLE TO DOUBLE, GET HIGH-ORDER B WORD.

ADDXX:	LDB	RS,[POINT 4,PA,12] ;GET OPERAND AC
	MOVE	TA,0(RS)	;GET OPERAND
	MOVE	TB,1(RS)
ADDXX1:	JFCL	2,.+1		;[1107] ONLY CLEAR CARRY 1 FLAG
	PUSHJ	PP,CHECK	;BE SURE SIGNS AGREE
	ADD	TB,1(PA)	;ADD LOW-ORDER WORDS.
	JCRY1	CARRYS		;IF A CARRY OCCURRED, GO ADJUST HIGH-ORDER WORD.
ADDXX2:	ADD	TA,TC		;ADD TWO HIGH-ORDER WORDS.
	PUSHJ	PP,CHECK	;BE SURE SIGNS AGREE
	MOVEM	TA,0(RS)	;STASH HI-PART
	MOVEM	TB,1(RS)	;STASH LOW PART
	POPJ	PP,		;RETURN

CHECK:	TLNE	TA,1B18		;MAKE SIGN OF LOW-ORDER PART
	TLOA	TB,1B18		;  AGREE WITH SIGN OF
	TLZ	TB,1B18		;  HIGH-ORDER RESULT.
	POPJ	PP,

;COME HERE ON CARRY GENERATED IN ADDITION OF LOW-ORDER WORDS.
CARRYS:	ADDI	TA,1		;ADD CARRY TO HIGH-ORDER HALF.
	PUSHJ	PP,CHECK	;THEN GO CHECK FOR SIGN CHANGE IN HIGH HALF.
	JRST	ADDXX2		;[1107] GO ADD HIGH-ORDER WORDS.

>	;END OF NON-BIS
IFN	BIS,<

ADD.12:
	LDB	TA,PACFL.##	; GET AC NUMBER
	MOVE	TB,(TA)		;GET LOW ORDER WORD.
	MOVEM	TB,1(TA)	;PUT IT WHERE IT SHOULD BE.
	SETZM	(TA)		;CLEAR HIGH ORDER AC
	SKIPGE	1(TA)		;IS LOW ORDER NEGATIVE
	SETOM	(TA)		;YES - EXTEND SIGN

ADD.22:
	;CHANGE PA INTO A DADD

	TLZ	PA,777000	;JUST TO BE SAFE
	TLO	PA,(DADD)		;PUT IN OP CODE
	XCT	PA		;DO IT
	POPJ	PP,		;DONE

ADD.21:
	MOVE	TA,0(PA)	;GET WORD IN MEMORY
	ASHC	TA,-^D35	;EXTEND SIGN
	HRRI	PA,TA		;WE WILL ADD IN TA
	TLZ	PA,777000	;JUST TO BE SURE
	TLO	PA,(DADD)		;SET OP CODE
	XCT	PA
	POPJ	PP,		;DONE

;[540] HERE TO DO ROUNDING TO QUAD-WORD VALUE

ADD.4R:	ASHC	4,-^D35		;[540] EXTEND SIGN
	JFCL	17,.+1		;[540] CLEAR FLAGS
	DADD	2,4		;[540] ADD IN ROUNDING CONSTANT
	JOV	CARRY4		;[540] OVERFLOW OCCURED
	POPJ	PP,		;[540] NO, ALL DONE

CARRY4:	SKIPL	5,4		;[540] IF IT WAS NEGATIVE USE -1
	MOVEI	5,1		;[540] NO, SO ADD 1
	DADD	0,4		;[540] ADJUST HIGH WORD
	POPJ	PP,		;[540] AND RETURN

>	;END BIS
	END