mirror of
https://github.com/cc65/cc65.git
synced 2025-01-12 17:30:50 +00:00
419eb700b5
The way we want to use the INITBSS segment - and especially the fact that it won't have the type bss on all ROM based targets - means that the name INITBSS is misleading. After all INIT is the best name from my perspective as it serves several purposes and therefore needs a rather generic name. Unfortunately this means that the current INIT segment needs to be renamed too. Looking for a short (ideally 4 letter) name I came up with ONCE as it contains all code (and data) accessed only once during initialization.
53 lines
961 B
ArmAsm
53 lines
961 B
ArmAsm
;
|
|
; IRQ handling (Gamate version)
|
|
;
|
|
|
|
.export initirq, doneirq, IRQStub
|
|
|
|
.import __INTERRUPTOR_COUNT__, callirq_y
|
|
|
|
.include "gamate.inc"
|
|
.include "extzp.inc"
|
|
|
|
; ------------------------------------------------------------------------
|
|
.segment "ONCE"
|
|
|
|
; a constructor
|
|
;
|
|
initirq:
|
|
rts
|
|
|
|
; ------------------------------------------------------------------------
|
|
.code
|
|
|
|
; a destructor
|
|
;
|
|
doneirq:
|
|
rts
|
|
|
|
; ------------------------------------------------------------------------
|
|
; 256*32 interrupts in about 1minute 60s = 136hz
|
|
; -> guess 16384 clock cycles = 135,28hz (might be audio signal 1/512?)
|
|
|
|
IRQStub:
|
|
; A and Y are saved by the BIOS
|
|
;pha
|
|
;tya
|
|
;pha
|
|
|
|
ldy #<(__INTERRUPTOR_COUNT__ * 2)
|
|
beq @L1
|
|
|
|
txa
|
|
pha
|
|
|
|
jsr callirq_y
|
|
|
|
pla
|
|
tax
|
|
|
|
@L1: ;pla
|
|
;tay
|
|
;pla
|
|
rts
|