2007-04-27 22:42:41 +00:00
|
|
|
#
|
|
|
|
! $Source$
|
|
|
|
! $State$
|
|
|
|
! $Revision$
|
|
|
|
|
2019-06-10 21:54:23 +00:00
|
|
|
#
|
|
|
|
#include "asm.h"
|
2007-04-27 22:42:41 +00:00
|
|
|
|
|
|
|
.define .trp
|
2019-06-10 22:12:00 +00:00
|
|
|
.define EARRAY, ERANGE, ESET, EIOVFL, EFOVFL, EFUNFL, EIDIVZ, EIDIVZ
|
|
|
|
.define EFDIVZ, EIUND, EFUND, ECONV, ESTACK, EHEAP, EILLINS, EODDZ
|
|
|
|
.define ECASE, EMEMFLT, EBADPTR, EBADPC, EBADLAE, EBADMON, EBADLIN, EBADGTO
|
|
|
|
.define EUNIMPL
|
2007-04-27 22:42:41 +00:00
|
|
|
|
|
|
|
! Trap routine
|
|
|
|
! Expects trap number on stack.
|
|
|
|
! Just returns if trap has to be ignored.
|
|
|
|
! Otherwise it calls a user-defined trap handler if provided.
|
|
|
|
! When no user-defined trap handler is provided or when the user-defined
|
|
|
|
! trap handler causes a new trap, a message is printed
|
|
|
|
! and control is returned to the monitor.
|
|
|
|
|
|
|
|
EARRAY = 0
|
|
|
|
ERANGE = 1
|
|
|
|
ESET = 2
|
|
|
|
EIOVFL = 3
|
|
|
|
EFOVFL = 4
|
|
|
|
EFUNFL = 5
|
|
|
|
EIDIVZ = 6
|
|
|
|
EFDIVZ = 7
|
|
|
|
EIUND = 8
|
|
|
|
EFUND = 9
|
|
|
|
ECONV = 10
|
|
|
|
ESTACK = 16
|
|
|
|
EHEAP = 17
|
|
|
|
EILLINS = 18
|
|
|
|
EODDZ = 19
|
|
|
|
ECASE = 20
|
|
|
|
EMEMFLT = 21
|
|
|
|
EBADPTR = 22
|
|
|
|
EBADPC = 23
|
|
|
|
EBADLAE = 24
|
|
|
|
EBADMON = 25
|
|
|
|
EBADLIN = 26
|
|
|
|
EBADGTO = 27
|
|
|
|
EUNIMPL = 63 ! unimplemented em-instruction called
|
|
|
|
|
|
|
|
.trp:
|
|
|
|
pop h
|
|
|
|
xthl
|
|
|
|
push h ! trap number and return address exchanged
|
|
|
|
mov a,l
|
|
|
|
cpi 16
|
|
|
|
jnc 3f ! jump if trap cannot be ignored
|
|
|
|
|
|
|
|
! check if trap has to be ignored
|
|
|
|
xchg ! de = trap number
|
|
|
|
lhld .ignmask
|
|
|
|
push h ! hl = set to be tested
|
|
|
|
push d
|
|
|
|
call .inn2 ! de = 1 if bit is set, 0 otherwise
|
|
|
|
mov a,e
|
|
|
|
rar
|
|
|
|
jnc 3f ! jump if trap should not be ignored
|
|
|
|
pop h ! remove trap number
|
|
|
|
ret ! OGEN DICHT EN ... SPRING!!!
|
|
|
|
|
|
|
|
3:
|
|
|
|
lhld .trapproc ! user defined trap handler?
|
|
|
|
mov a,l
|
|
|
|
ora h
|
|
|
|
jz 1f ! jump if there was not
|
|
|
|
xra a
|
|
|
|
sta .trapproc ! .trapproc := 0
|
|
|
|
sta .trapproc+1
|
|
|
|
lxi d,2f
|
|
|
|
push d
|
|
|
|
pchl ! call user defined trap handler
|
|
|
|
2:
|
|
|
|
pop d
|
|
|
|
ret
|
|
|
|
1:
|
2019-06-10 21:54:23 +00:00
|
|
|
lxi d, text
|
|
|
|
mvi c, 9 ! write $-terminated string
|
|
|
|
call 0x0005
|
|
|
|
rst 0 ! abend
|
2007-04-27 22:42:41 +00:00
|
|
|
|
|
|
|
.sect .rom
|
2019-06-10 21:54:23 +00:00
|
|
|
text: .ascii "TRAP!\r\n$"
|
2007-04-27 22:42:41 +00:00
|
|
|
|