ack/lang/m2/libm2/EM.e

101 lines
1.7 KiB
Plaintext
Raw Permalink Normal View History

1987-06-23 17:12:42 +00:00
#
1988-02-19 15:54:01 +00:00
;
; (c) copyright 1988 by the Vrije Universiteit, Amsterdam, The Netherlands.
; See the copyright notice in the ACK home directory, in the file "Copyright".
;
;
; Module: Interface to some EM instructions and data
; Author: Ceriel J.H. Jacobs
1994-06-24 14:02:31 +00:00
; Version: $Id$
1988-02-19 15:54:01 +00:00
;
1987-06-23 17:12:42 +00:00
mes 2,EM_WSIZE,EM_PSIZE
#define ARG1 0
#define ARG2 EM_DSIZE
#define IRES 2*EM_DSIZE
; FIF is called with three parameters:
; - address of integer part result (IRES)
; - float two (ARG2)
; - float one (ARG1)
; and returns an EM_DSIZE-byte floating point number
; Definition:
; PROCEDURE FIF(ARG1, ARG2: LONGREAL; VAR IRES: LONGREAL) : LONGREAL;
exp $FIF
pro $FIF,0
lal 0
loi 2*EM_DSIZE
fif EM_DSIZE
lal IRES
loi EM_PSIZE
sti EM_DSIZE
ret EM_DSIZE
end ?
#define FARG 0
#define ERES EM_DSIZE
; FEF is called with two parameters:
; - address of base 2 exponent result (ERES)
; - floating point number to be split (FARG)
; and returns an EM_DSIZE-byte floating point number (the mantissa)
; Definition:
; PROCEDURE FEF(FARG: LONGREAL; VAR ERES: integer): LONGREAL;
exp $FEF
pro $FEF,0
lal FARG
loi EM_DSIZE
fef EM_DSIZE
lal ERES
loi EM_PSIZE
sti EM_WSIZE
ret EM_DSIZE
end ?
#define TRAP 0
; TRP is called with one parameter:
; - trap number (TRAP)
; Definition:
; PROCEDURE TRP(trapno: INTEGER);
exp $TRP
pro $TRP, 0
lol TRAP
trp
ret 0
end ?
1987-06-26 15:59:52 +00:00
#define PROC 0
; SIG is called with one parameter:
; - procedure instance identifier (PROC)
; and returns the old traphandler.
1988-03-23 17:55:57 +00:00
exa handler
1987-06-26 15:59:52 +00:00
exp $SIG
pro $SIG, 0
1988-03-23 17:55:57 +00:00
lae handler
1988-03-16 09:20:36 +00:00
loi EM_PSIZE
1987-06-26 15:59:52 +00:00
lal PROC
loi EM_PSIZE
1988-03-23 17:55:57 +00:00
lae handler
1988-03-16 09:20:36 +00:00
sti EM_PSIZE
1987-06-26 15:59:52 +00:00
ret EM_PSIZE
end ?
exp $LINO
pro $LINO,0
loe 0
ret EM_WSIZE
end ?
exp $FILN
pro $FILN,0
lae 4
loi EM_PSIZE
ret EM_PSIZE
end ?