2019-04-29 22:36:58 +02:00
|
|
|
|
NEW
|
|
|
|
|
AUTO 3,1
|
|
|
|
|
* object code = mli_3
|
|
|
|
|
*
|
|
|
|
|
* this routine handles interrupts and is coded to reach 'lreset' precisely at
|
|
|
|
|
* address $FFCB (ROM rts opcode) for rom switching to function.
|
|
|
|
|
|
2019-09-15 17:13:48 +02:00
|
|
|
|
lanirq pha $2D9B-2DFF moved to $FF9B-FFFF
|
2019-09-10 22:53:18 +02:00
|
|
|
|
lda accsav
|
|
|
|
|
sta oldacc
|
2019-09-10 17:46:56 +02:00
|
|
|
|
pla
|
2019-09-10 22:53:18 +02:00
|
|
|
|
sta accsav
|
2019-09-13 17:39:37 +02:00
|
|
|
|
pla get status register from stack
|
|
|
|
|
pha and put it back.
|
|
|
|
|
and #$10 is it a break or interrupt?
|
|
|
|
|
bne H2DC2 branch if break.
|
|
|
|
|
lda $D000 get ram bankid (LC1 = $D8, LC2=$EE)
|
|
|
|
|
eor #$D8 is the system active? ($D8)
|
|
|
|
|
beq sysactv branch if it is
|
2019-09-10 17:46:56 +02:00
|
|
|
|
lda #$FF
|
|
|
|
|
sysactv sta bankid
|
2019-09-10 22:53:18 +02:00
|
|
|
|
sta afbank
|
2019-09-13 17:39:37 +02:00
|
|
|
|
lda /aftirq setup return address
|
2019-09-10 17:46:56 +02:00
|
|
|
|
pha
|
2019-09-10 22:53:18 +02:00
|
|
|
|
lda #aftirq
|
2019-09-10 17:46:56 +02:00
|
|
|
|
pha
|
2019-09-13 17:39:37 +02:00
|
|
|
|
lda #$04 status reg with interrupt flag set
|
2019-09-10 17:46:56 +02:00
|
|
|
|
pha
|
2019-09-13 17:39:37 +02:00
|
|
|
|
H2DC2 lda /romirq setup ROM re-entry
|
2019-09-10 17:46:56 +02:00
|
|
|
|
pha
|
2019-09-10 22:53:18 +02:00
|
|
|
|
lda #romirq
|
2019-09-10 17:46:56 +02:00
|
|
|
|
pha
|
2019-09-15 17:13:48 +02:00
|
|
|
|
gorom sta RROMBNK2 hits ROM rts at $FFCB
|
2019-04-29 22:36:58 +02:00
|
|
|
|
|
|
|
|
|
* 'lreset' address must = $FFCB for rom switch i/o to work
|
|
|
|
|
|
2019-09-15 17:13:48 +02:00
|
|
|
|
lreset lda rreset+1
|
2019-09-10 17:46:56 +02:00
|
|
|
|
pha
|
2019-09-10 22:53:18 +02:00
|
|
|
|
lda rreset
|
2019-09-10 17:46:56 +02:00
|
|
|
|
pha
|
2019-09-10 22:53:18 +02:00
|
|
|
|
jmp gorom
|
2019-09-15 17:13:48 +02:00
|
|
|
|
rreset .DA resetv-1 rts to resetv
|
|
|
|
|
fix45 sta p8areg A register savearea
|
2019-09-10 22:53:18 +02:00
|
|
|
|
lda oldacc
|
|
|
|
|
sta accsav
|
2019-09-13 22:48:05 +02:00
|
|
|
|
lda RRAMWRAMBNK1 read/write RAM bank 1
|
2019-09-12 08:39:47 +02:00
|
|
|
|
lda RRAMWRAMBNK1
|
2019-09-10 22:53:18 +02:00
|
|
|
|
lda afbank
|
|
|
|
|
jmp irqxit0
|
2019-09-15 17:13:48 +02:00
|
|
|
|
stypfx sty newpfxptr fix appletalk PFI bug
|
2019-09-13 22:48:05 +02:00
|
|
|
|
sty preflag prefix flag
|
2019-09-10 17:46:56 +02:00
|
|
|
|
rts
|
2019-09-15 17:13:48 +02:00
|
|
|
|
stapfx sta newpfxptr
|
2019-09-10 22:53:18 +02:00
|
|
|
|
sta preflag
|
2019-09-10 17:46:56 +02:00
|
|
|
|
rts
|
2019-04-29 22:36:58 +02:00
|
|
|
|
|
|
|
|
|
* these 3 vectors hard-coded into processor
|
|
|
|
|
|
2019-09-13 22:48:05 +02:00
|
|
|
|
.DA nmivect nmi handler
|
|
|
|
|
.DA lreset reset handler
|
2019-09-15 17:13:48 +02:00
|
|
|
|
irqv .DA lanirq irq handler
|
2019-04-29 22:36:58 +02:00
|
|
|
|
|
|
|
|
|
* end of obj mli_3
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
MAN
|
2019-07-08 14:56:54 +02:00
|
|
|
|
SAVE USR/SRC/PRODOS.203/PRODOS.S.IRQ
|
|
|
|
|
LOAD USR/SRC/PRODOS.203/PRODOS.S
|
2019-04-29 22:36:58 +02:00
|
|
|
|
ASM
|