A2osX/ProDOS.203/ProDOS.S.IRQ.txt

69 lines
1.7 KiB
Plaintext
Raw Normal View History

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