4cade/src/4cade.a

201 lines
7.1 KiB
Plaintext
Raw Normal View History

2018-12-29 13:38:18 -05:00
;license:MIT
2020-03-16 21:58:05 -04:00
;(c) 2018-2020 by 4am
2018-12-29 13:38:18 -05:00
;
2018-08-23 16:02:48 -04:00
!cpu 6502
!to "build/LAUNCHER.SYSTEM",plain
*=$2000
2019-06-18 21:49:12 -07:00
!ifndef RELBASE {
RELBASE=$2000
}
!source "src/constants.a" ; no code in these
2018-08-26 15:33:32 -04:00
!source "src/macros.a"
2018-11-10 08:36:36 -05:00
; first-run initialization, relocates code to language card and jumps
; to |Reenter|
!source "src/4cade.init.a"
2020-08-12 08:35:21 -07:00
!source "src/4cade.init.cffa.a"
2020-08-13 16:12:57 -07:00
!source "src/4cade.init.gs.a"
2018-10-23 15:44:06 -04:00
FirstMover
2019-06-18 21:49:12 -07:00
!pseudopc RELBASE {
;------------------------------------------------------------------------------
; Reenter
; This is the primary entry point for returning to the launcher from anywhere.
; - Self-running demos call this when the user presses a key or when the demo
; cycles ends naturally.
; - It is set as the reset vector, so the user can play a game then press
; Ctrl-Reset to return to the launcher and choose another.
; - It also functions as a reset vector while the launcher is running.
; - It is also called on program startup, after the first-run initialization.
;
; When execution reaches this point, we may have previously backed up the stack
; and stack pointer, in which case it is now our job to restore it and return
; to the caller. This allows magic like 'JSR PlayGame' then continuing once the
; JSR returns.
;
; If there is no stack to restore, this exits via SearchMode.
;
; in: none
; out: see above
;------------------------------------------------------------------------------
Reenter
cld
2019-11-27 13:51:43 -08:00
ldx #$ff
txs ; so that we never trash the reset vector
2019-09-25 20:01:59 -07:00
jsr SwitchToBank2
2019-10-08 13:19:20 -04:00
jsr DisableAccelerator ; back to 1 MHz (especially important on IIgs
; which restores default speed on Ctrl-Reset)
jsr CloseHandles ; close any open handles to restore ProRWTS
2020-07-30 10:21:42 -07:00
ldx #(end_promote-promote-1)
- lda promote,x ; copy ProDOS shim to main memory for GS/OS exit
sta $bf00,x
dex
bpl -
ldx #5
- lda ResetVector,x ; copy reentry wrapper to bottom of stack
2020-02-28 15:33:10 -08:00
sta $100,x ; (used as reset vector because //e always
dex ; switches to ROM on Ctrl-Reset)
bpl -
inx
stx $3F2 ; page 3 reset vector to ($100)
2020-02-28 15:33:10 -08:00
sei
2019-12-11 19:21:14 -08:00
stx $3FE ; page 3 IRQ vector to ($100)
inx
2019-12-11 19:21:14 -08:00
stx $3FF
2020-02-28 15:33:10 -08:00
cli
stx $3F3
ldx #$A4
stx $3F4
RestoreStackNextTime
2019-09-30 11:18:57 -07:00
bne SearchMode ; (SMC) not an unconditional branch because code
; might change the branch target to the next opcode
; If we fall through to here, it's because we backed up the stack and
; stack pointer and wanted this routine to restore it and return to
; caller.
2019-09-30 11:18:57 -07:00
lda #(SearchMode - RestoreStackNextTime) - 2
; reset to branch so we don't try to
sta RestoreStackNextTime + 1
; restore the same stack twice
STACKPTR
ldx #$D1 ; SMC, restore stack pointer
txs
inx
- lda STACKBASE - $100 + gStackSize,x
2021-10-26 22:05:15 -07:00
; restore stack
2019-01-08 14:10:26 -05:00
sta $100,x
inx
bne -
2020-03-13 17:11:59 -07:00
SwitchToBank1
+READ_RAM1_WRITE_RAM1
rts
ResetVector ; 6 bytes, copied to $100
+READ_RAM1_NO_WRITE
jmp Reenter
2018-10-27 18:47:27 -04:00
; these routines will only be called after relocating to language card
2019-10-08 13:19:20 -04:00
!source "src/ui.search.mode.a" ; \__ execution falls through
!source "src/ui.animation.a" ; /
2020-03-25 16:56:35 -04:00
!source "src/ui.browse.mode.a"
!source "src/ui.attract.mode.a"
2020-03-25 16:56:35 -04:00
!source "src/ui.attract.hgr.a"
!source "src/ui.attract.dhgr.a"
2019-01-14 19:06:58 -05:00
!source "src/ui.attract.shr.a"
!source "src/ui.attract.gr.a"
2020-03-25 16:56:35 -04:00
!source "src/ui.offscreen.a"
!source "src/ui.cheats.a"
2020-03-25 16:56:35 -04:00
!source "src/ui.credits.a"
2020-07-28 18:06:36 -07:00
!source "src/ui.reboot.a"
2020-03-25 16:56:35 -04:00
!source "src/ui.common.a"
!source "src/ui.font.a"
!source "src/ui.overlay.a"
2019-10-08 14:47:47 -04:00
!source "src/parse.prefs.a"
2020-03-25 16:56:35 -04:00
!source "src/glue.launch.a"
2019-10-08 14:47:47 -04:00
!source "src/glue.prorwts2.a"
2020-03-15 11:23:56 -04:00
!source "src/glue.decompress.a"
2020-03-25 16:56:35 -04:00
!source "src/textrank.a"
!source "src/okvs.a"
!source "src/wait.a"
2019-10-08 13:31:41 -04:00
2020-03-25 16:56:35 -04:00
; add new files above here
!source "src/hw.vbl.a"
2020-03-25 16:56:35 -04:00
!source "src/ui.wait.a"
gSearchStore
!word $6000
2019-06-30 15:10:09 -04:00
gSlideshowStore
!word $0800
2018-11-10 10:08:14 -05:00
gGlobalPrefsStore
2020-03-29 19:52:35 -04:00
!word $D001 ; leave $D000 alone because FastChip accelerator
; flips out if it has certain values (it will
; be set to $55 as part of the 64K memory test,
; which is apparently one of the acceptable values)
SwitchToBank2
+READ_RAM2_WRITE_RAM2
rts
2019-10-09 21:26:18 -07:00
!source "src/prodos.path.a" ; paths end up on the same page
2021-10-15 13:00:40 -07:00
; iLoadFileDirect (label is in constants.a)
jmp LoadFileDirect ; no direct calling - target can move
2020-03-25 16:56:35 -04:00
; WaitForVBL (label is in constants.a)
2020-03-18 19:53:50 -07:00
jmp WaitForVBL_iie ; SMC to RTS on a II+
2020-03-25 16:56:35 -04:00
; UnwaitForVBL (label is in constants.a)
2020-03-18 19:53:50 -07:00
rts ; SMC to JMP on a IIc
!word iUnwaitForVBL
2020-03-25 16:56:35 -04:00
; MockingboardStuff (label is in constants.a)
2020-02-28 15:33:10 -08:00
; slot number where Mockingboard was detected and type of board
; #$00 if no Mockingboard detected
2020-02-28 15:33:10 -08:00
!byte $FD ; MockingboardStuff ($FFF8)
; MachineStatus (label is in constants.a so prelaunchers can use it)
; 7 6 5 4 3 2 1 0
; | | | | | | | +- bit 0 reserved
; | | | | | | +--- bit 1 reserved
2019-11-20 20:05:35 -08:00
; | | | | | +----- bit 2 reserved
2020-03-05 12:38:53 -05:00
; | | | | +------- bit 3 = 1 if cheats are enabled
; | | | +--------- bit 4 = 1 if VidHD
; | | +----------- bit 5 = 1 if IIgs
; | +------------- bit 6 = 1 if 128K
; +--------------- bit 7 = 1 if joystick
; Use the bit masks defined in constants.a
!byte $FD ; MachineStatus ($FFF9)
2019-06-21 09:43:43 -07:00
!word Reenter ; NMI vector ($FFFA-B)
!word Reenter ; reset vector ($FFFC-D)
2019-11-19 21:55:33 -08:00
!word Ignore ; IRQ vector ($FFFE-F)
2018-08-29 15:27:30 -04:00
}
LastMover
COPYSRC = *
!pseudopc hdddataend {
COPYDST = *
2019-10-09 13:04:39 -04:00
!source "src/prodos.impl.lc2.a"
!source "src/glue.prorwts2.lc2.a"
!source "src/glue.launch.lc2.a"
!source "src/hw.accel.lc2.a"
STACKBASE = *
2021-10-29 12:59:35 -07:00
OKVS_CACHE = STACKBASE + gStackSize
LCRAM2_END = OKVS_CACHE + 5
2020-05-23 15:47:16 -07:00
!if LCRAM2_END >= DisableAccelerator {
!error "code is too large: ends at ", LCRAM2_END
2019-09-09 18:40:59 -07:00
}
2021-10-27 20:17:35 -04:00
FONTDST = $E000
}
2019-09-06 15:12:17 -07:00
EvenLasterMover
2019-09-30 11:18:57 -07:00
FONTSRC = *
!pseudopc FONTDST {
2021-10-28 00:40:20 -04:00
!source "src/ui.font.data.a"
2019-09-30 11:18:57 -07:00
}
2019-06-18 21:49:12 -07:00
!if RELBASE = $2000 {
!ifdef PASS2 {
} else { ;PASS2
!set PASS2=1
2019-11-20 20:05:35 -08:00
!warn "ProRWTS ends at ", hdddataend - 1
2019-09-30 11:18:57 -07:00
!warn "STACK at ", STACKBASE
2021-10-29 12:59:35 -07:00
!warn "OKVS CACHE at ", OKVS_CACHE
2020-05-23 15:47:16 -07:00
!warn "LCRAM2 ends at ", LCRAM2_END
2019-06-21 09:43:43 -07:00
!warn "RELBASE = ", $10000 - (LastMover - FirstMover)
2019-06-18 21:49:12 -07:00
}
}