mirror of
https://github.com/elliotnunn/mac-rom.git
synced 2025-01-04 01:29:22 +00:00
174 lines
6.0 KiB
Plaintext
174 lines
6.0 KiB
Plaintext
|
;
|
|||
|
; File: FP020EQUS.a
|
|||
|
;
|
|||
|
; Contains: xxx put contents here xxx
|
|||
|
;
|
|||
|
; Written by: xxx put writers here xxx
|
|||
|
;
|
|||
|
; Copyright: <09> 1990 by Apple Computer, Inc., all rights reserved.
|
|||
|
;
|
|||
|
; Change History (most recent first):
|
|||
|
;
|
|||
|
; <2> 4/14/90 JJ Made changes to support new binary-to-decimal, 96-bit precision,
|
|||
|
; and improved Pack 5.
|
|||
|
; <1> 3/2/90 JJ First checked in.
|
|||
|
;
|
|||
|
; To Do:
|
|||
|
;
|
|||
|
|
|||
|
;-----------------------------------------------------------
|
|||
|
; File: FPEQUS.a
|
|||
|
;-----------------------------------------------------------
|
|||
|
|
|||
|
;-----------------------------------------------------------
|
|||
|
; 04JUL82: WRITTEN BY JEROME COONEN
|
|||
|
; Copyright Apple Computer, Inc., 1983,1984,1985,1989,1990
|
|||
|
; All Rights Reserved
|
|||
|
; 10AUG82: REMOVE OPWORD ERROR MASKS AND SET UP OPWORD
|
|||
|
; TESTS ON WORD, RATHER THAN LONG, BOUNDARY. (JTC)
|
|||
|
; 28AUG82: REMOVE FLAGS FOR STATE AREA ACCESS. (JTC)
|
|||
|
; 30AUG82: UNDERFLOW AND DIVBYZERO FLAGS SWAPPED (JTC)
|
|||
|
; 01SEP82: RND ENCODINGS CHANGED (JTC)
|
|||
|
; 03SEP82: FLAG ORDER REVERSED (JTC)
|
|||
|
; 13OCT82: ADD ROUND UP BIT (JTC)
|
|||
|
; 12DEC82: REMOVE PROJECTIVE MODE MATERIAL (JTC)
|
|||
|
; 13APR83: EXPAND COMMENT ABOUT STKREM... (JTC)
|
|||
|
; 29APR83: ADD OPHIBIT CONSTANT FOR DISTINGUISHING CLASS AND
|
|||
|
; COMPARE IN NANHANDLER. ADD NEXT CONSTANTS. (JTC)
|
|||
|
; 09MAY83: REPLACE STACK CONSTANTS WITH LINK CONSTANTS (JTC)
|
|||
|
; 26AUG83: MOVED FOR... EQUS FROM FPDRIVER TO HERE (JTC)
|
|||
|
; 01NOV83: PRECISION CONTROL TO MODE BITS (JTC)
|
|||
|
; 15APR84: MOVED FOR... EQUS BACK OUT TO FPDRIVER FROM HERE (JTC&DGH)
|
|||
|
; 26MAR85: ADDED QNANBIT=30 FOR CHANGE OF QUIET/SIGNAL NAN SENSE (JTC)
|
|||
|
; 24JAN90: MODIFICATIONS FOR 68020 SOFTWARE SANE (JPO)
|
|||
|
;
|
|||
|
; SOME BITS ARE ACCESSIBLE BY <TST; BMI> SEQUENCES BECAUSE
|
|||
|
; THEY OCCUR AT THE HIGH END OF A BYTE, WORD, OR LONG
|
|||
|
; SUBPIECE. WHENEVER SUCH TESTS ARE EXPLOITED (PREFERABLE
|
|||
|
; TO BTST), THE BIT NUMBER IS USED IN THE COMMENT.
|
|||
|
;-----------------------------------------------------------
|
|||
|
|
|||
|
;-----------------------------------------------------------
|
|||
|
; STACK FRAME INFORMATION. AFTER ENTRY DO A "LINK A6,#-2"
|
|||
|
; TO GET STACK:
|
|||
|
; CNT WORD < OLD A6 < RET < OP < ADR1 < ADR2...
|
|||
|
; WITH A6 POINTING TO OLD A6. THEN THE FOLLOWING LINK
|
|||
|
; OFFSETS ACCESS STACK ELEMENTS.
|
|||
|
;-----------------------------------------------------------
|
|||
|
LKCNT EQU -2 ; BYTE COUNT FOR TRAP
|
|||
|
LKA6 EQU 0 ; SAVED A6
|
|||
|
LKRET EQU 4 ; RETURN ADDRESS
|
|||
|
LKOP EQU 8 ; OPWORD
|
|||
|
LKADR1 EQU 10 ; FIRST ADDRESS
|
|||
|
LKADR2 EQU 14 ; SECOND ADDRESS
|
|||
|
LKADR3 EQU 18 ; THIRD ADDRESS
|
|||
|
|
|||
|
;-----------------------------------------------------------
|
|||
|
; WHEN A HALT EXIT IS TAKEN, THE STACK CONSISTS OF:
|
|||
|
; RET TO FP020 < OP < ADR1 < ADR2 < ADR3 < PTR
|
|||
|
; WHERE PTR REFERS TO THE THREE WORD STRUCTURE: CCR | D0
|
|||
|
; TO BE STUFFED AFTER RETURN TO PACKAGE.
|
|||
|
; TO RETURN TO EXECUTING PROGRAM JUST DO
|
|||
|
; MOVEA.L (SP)+,A0 ; RETURN ADRS
|
|||
|
; ADDA.W #18,SP ; KILL OP, 4 ADRS'S
|
|||
|
; JMP (A0)
|
|||
|
;-----------------------------------------------------------
|
|||
|
STKREM1 EQU 12 ; BYTES TO TOSS IF 1
|
|||
|
STKREM2 EQU 16 ; BYTES TO TOSS IF 2
|
|||
|
STKREM3 EQU 20 ; BYTES TO TOSS IF 3
|
|||
|
|
|||
|
;-----------------------------------------------------------
|
|||
|
; POSITION OF ERROR BITS IN BYTE. W-MASKS ARE FOR SETTING
|
|||
|
; MULTIPLE EXCEPTIONS IN BITS $1F00 OF A WORD.
|
|||
|
;-----------------------------------------------------------
|
|||
|
ERRX EQU 4 ; INEXACT
|
|||
|
ERRZ EQU 3 ; DIVISION BY ZERO
|
|||
|
ERRO EQU 2 ; OVERFLOW
|
|||
|
ERRU EQU 1 ; UNDERFLOW
|
|||
|
ERRI EQU 0 ; INVALID
|
|||
|
|
|||
|
ERRWXO EQU $1400 ; INEXACT AND OVERFLOW
|
|||
|
ERRWXU EQU $1200 ; INEXACT AND UNDERFLOW
|
|||
|
|
|||
|
;-----------------------------------------------------------
|
|||
|
; RESULTS OF COMPARISONS, BASED ON CPU MAP: XNZVC.
|
|||
|
;-----------------------------------------------------------
|
|||
|
CMPE EQU $04 ; EQUAL
|
|||
|
CMPL EQU $19 ; LESS
|
|||
|
CMPG EQU $00 ; GREATER
|
|||
|
CMPU EQU $02 ; UNORDERED
|
|||
|
|
|||
|
;-----------------------------------------------------------
|
|||
|
; CLASS OPERATOR RETURN CODES
|
|||
|
;-----------------------------------------------------------
|
|||
|
CLSNAN EQU 1 ; SIGNALING NAN
|
|||
|
CLQNAN EQU 2 ; QUIET NAN
|
|||
|
CLINF EQU 3 ; INFINITY
|
|||
|
CLZERO EQU 4 ; ZERO
|
|||
|
CLNORM EQU 5 ; NORMAL NUMBER
|
|||
|
CLDENORM EQU 6 ; DENORMAL NUMBER
|
|||
|
|
|||
|
;-----------------------------------------------------------
|
|||
|
; OPWORD BITS, BASED ON WORD VALUE.
|
|||
|
;-----------------------------------------------------------
|
|||
|
TWOADRS EQU 00 ; 1 IFF 2 ADDRESSES
|
|||
|
OPHIBIT EQU 04 ; 0010 = OPCODE LEAD BIT
|
|||
|
DSTOUT EQU 05 ; 1 IFF NOT COMPARISON
|
|||
|
SRCIN EQU 06 ; 1 IFF SRC INPUT
|
|||
|
DSTIN EQU 07 ; 1 IFF DST INPUT
|
|||
|
DSTLO EQU 08 ; LO BIT OF DST FORMAT
|
|||
|
DSTMD EQU 09 ; MED BIT OF DST FORMAT
|
|||
|
DSTINT EQU 10 ; 1 IFF INTEGER OUTPUT
|
|||
|
SRCLO EQU 11 ; LO BIT OF SRC FORMAT
|
|||
|
SRCMD EQU 12 ; MED BIT OF SRC FORMAT
|
|||
|
SRCHI EQU 13 ; HI BIT OF SRC FORMAT
|
|||
|
DPREC EQU 14 ; DOUBLE OPERATION
|
|||
|
SPREC EQU 15 ; SINGLE OPERATION (TST.L)
|
|||
|
|
|||
|
FPX96 EQU 05 ; 96-BIT EXTENDED FORMAT (IN OPWORD
|
|||
|
; ON STACK)
|
|||
|
|
|||
|
;-----------------------------------------------------------
|
|||
|
; TESTS FOR OPERATIONS, ALL AS WORD TESTS. AND SOME
|
|||
|
; USEFUL OPCODES FOR B<->D CONVERSIONS.
|
|||
|
;-----------------------------------------------------------
|
|||
|
OPIFCPX EQU 1 ; 1 IFF CMPX VS CMP
|
|||
|
OPIFTR EQU 1 ; 1 IFF TRUNC VS ROUND
|
|||
|
OPAMASK EQU $001E ; ISOLATE OPCODE BITS
|
|||
|
OPFOMASK EQU $3800 ; TO GET SRC FORMAT BITS
|
|||
|
OPADD EQU $0000 ; ADD OPCODE
|
|||
|
OPMUL EQU $0004 ; MULTIPLY OPCODE
|
|||
|
OPDIV EQU $0006 ; DIVIDE OPCODE
|
|||
|
OPCMP EQU $0008 ; COMPARE WITHOUT EXCEPTIONS
|
|||
|
OP2EXT EQU $000E ; CONVERT TO EXTENDED
|
|||
|
OPEXT2 EQU $0010 ; CONVERT FROM EXTENDED
|
|||
|
OPRINT EQU $0014 ; ROUND TO INTEGER
|
|||
|
OPCLASS EQU $001C ; CLASS
|
|||
|
|
|||
|
;-----------------------------------------------------------
|
|||
|
; MODE BITS AND MASKS IN BYTE.
|
|||
|
;-----------------------------------------------------------
|
|||
|
RNDMSK EQU $60 ; AS THOUGH IN LOW WORD
|
|||
|
RNDUP EQU $20
|
|||
|
RNDDN EQU $40
|
|||
|
RND0 EQU $60
|
|||
|
RNDLO EQU 5
|
|||
|
RNDHI EQU 6 ; LEAD RND BIT
|
|||
|
|
|||
|
DBRMSK EQU $8f ; KILL RND BITS AND INEXACT
|
|||
|
|
|||
|
RNDINC EQU 7 ; IN LOW BYTE OF WORD
|
|||
|
PRECMSK EQU RNDMSK ; IN LOW BYTE OF WORD
|
|||
|
|
|||
|
;-----------------------------------------------------------
|
|||
|
; CONSTANT TO TWEAK NAN BIT IN HIGH LONG WORD OF SIG FIELD <26MAR85>
|
|||
|
;-----------------------------------------------------------
|
|||
|
QNANBIT EQU 30 ; 1-QUIET 0-SIGNALING <26MAR85>
|
|||
|
|
|||
|
;-----------------------------------------------------------
|
|||
|
; ADDRESS OF ENVIRONMENT WORD AND HALTVECTOR IN LOW MEMORY
|
|||
|
;-----------------------------------------------------------
|
|||
|
FPSTATE EQU $A4A
|
|||
|
FPHV EQU $A4C
|
|||
|
|