# ! $Source$ ! $State$ ! $Revision$ # #include "asm.h" .define .trp .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 ! 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: lxi d, text mvi c, 9 ! write $-terminated string call 0x0005 rst 0 ! abend .sect .rom text: .ascii "TRAP!\r\n$"