2014-02-01 20:26:39 -05:00
|
|
|
Reset:: ; 150
|
2013-08-20 03:26:37 -04:00
|
|
|
di
|
2015-11-11 23:38:57 -05:00
|
|
|
call MapSetup_Sound_Off
|
2013-08-20 03:26:37 -04:00
|
|
|
xor a
|
2015-11-05 14:06:03 -05:00
|
|
|
ld [hMapAnims], a
|
2013-08-20 03:26:37 -04:00
|
|
|
call ClearPalettes
|
|
|
|
xor a
|
|
|
|
ld [rIF], a
|
|
|
|
ld a, 1 ; VBlank int
|
|
|
|
ld [rIE], a
|
|
|
|
ei
|
|
|
|
|
2015-02-10 15:14:41 -08:00
|
|
|
ld hl, wcfbe
|
2013-08-20 03:26:37 -04:00
|
|
|
set 7, [hl]
|
|
|
|
|
|
|
|
ld c, 32
|
|
|
|
call DelayFrames
|
|
|
|
|
|
|
|
jr Init
|
|
|
|
; 16e
|
|
|
|
|
|
|
|
|
2014-02-01 20:26:39 -05:00
|
|
|
_Start:: ; 16e
|
2013-08-20 03:26:37 -04:00
|
|
|
cp $11
|
2015-12-26 18:11:55 -05:00
|
|
|
jr z, .cgb
|
2013-08-20 03:26:37 -04:00
|
|
|
xor a
|
2015-12-26 18:11:55 -05:00
|
|
|
jr .load
|
2013-08-20 03:26:37 -04:00
|
|
|
|
2015-12-26 18:11:55 -05:00
|
|
|
.cgb
|
2013-08-20 03:26:37 -04:00
|
|
|
ld a, $1
|
|
|
|
|
2015-12-26 18:11:55 -05:00
|
|
|
.load
|
2013-08-20 03:26:37 -04:00
|
|
|
ld [hCGB], a
|
|
|
|
ld a, $1
|
2018-01-19 14:49:43 -05:00
|
|
|
ld [hSystemBooted], a
|
2013-08-20 03:26:37 -04:00
|
|
|
; 17d
|
|
|
|
|
|
|
|
|
2014-02-01 20:26:39 -05:00
|
|
|
Init:: ; 17d
|
2013-08-20 03:26:37 -04:00
|
|
|
|
|
|
|
di
|
|
|
|
|
|
|
|
xor a
|
|
|
|
ld [rIF], a
|
|
|
|
ld [rIE], a
|
|
|
|
ld [rRP], a
|
|
|
|
ld [rSCX], a
|
|
|
|
ld [rSCY], a
|
|
|
|
ld [rSB], a
|
|
|
|
ld [rSC], a
|
|
|
|
ld [rWX], a
|
|
|
|
ld [rWY], a
|
|
|
|
ld [rBGP], a
|
|
|
|
ld [rOBP0], a
|
|
|
|
ld [rOBP1], a
|
|
|
|
ld [rTMA], a
|
|
|
|
ld [rTAC], a
|
2018-01-03 00:19:54 -05:00
|
|
|
ld [WRAM1_Begin], a
|
2013-08-20 03:26:37 -04:00
|
|
|
|
|
|
|
ld a, %100 ; Start timer at 4096Hz
|
|
|
|
ld [rTAC], a
|
|
|
|
|
|
|
|
.wait
|
|
|
|
ld a, [rLY]
|
2017-12-29 18:53:21 +01:00
|
|
|
cp LY_VBLANK + 1
|
2013-08-20 03:26:37 -04:00
|
|
|
jr nz, .wait
|
|
|
|
|
|
|
|
xor a
|
|
|
|
ld [rLCDC], a
|
|
|
|
|
|
|
|
; Clear WRAM bank 0
|
2017-12-26 23:18:05 -05:00
|
|
|
ld hl, WRAM0_Begin
|
|
|
|
ld bc, WRAM0_End - WRAM0_Begin
|
2016-04-10 14:42:14 -04:00
|
|
|
.ByteFill:
|
2013-08-20 03:26:37 -04:00
|
|
|
ld [hl], 0
|
|
|
|
inc hl
|
|
|
|
dec bc
|
|
|
|
ld a, b
|
|
|
|
or c
|
2015-12-26 18:11:55 -05:00
|
|
|
jr nz, .ByteFill
|
2013-08-20 03:26:37 -04:00
|
|
|
|
2018-01-23 16:49:58 -05:00
|
|
|
ld sp, wStack
|
2013-08-20 03:26:37 -04:00
|
|
|
|
|
|
|
; Clear HRAM
|
|
|
|
ld a, [hCGB]
|
|
|
|
push af
|
2018-01-19 14:49:43 -05:00
|
|
|
ld a, [hSystemBooted]
|
2013-08-20 03:26:37 -04:00
|
|
|
push af
|
|
|
|
xor a
|
2017-12-26 23:18:05 -05:00
|
|
|
ld hl, HRAM_Begin
|
|
|
|
ld bc, HRAM_End - HRAM_Begin
|
2013-08-20 03:26:37 -04:00
|
|
|
call ByteFill
|
|
|
|
pop af
|
2018-01-19 14:49:43 -05:00
|
|
|
ld [hSystemBooted], a
|
2013-08-20 03:26:37 -04:00
|
|
|
pop af
|
|
|
|
ld [hCGB], a
|
|
|
|
|
|
|
|
call ClearWRAM
|
2018-01-18 01:25:19 -05:00
|
|
|
ld a, 1
|
2013-08-20 03:26:37 -04:00
|
|
|
ld [rSVBK], a
|
|
|
|
call ClearVRAM
|
|
|
|
call ClearSprites
|
2016-05-10 12:31:49 -04:00
|
|
|
call ClearsScratch
|
2013-08-20 03:26:37 -04:00
|
|
|
|
|
|
|
|
2018-01-30 14:47:14 -05:00
|
|
|
ld a, BANK(WriteOAMDMACodeToHRAM)
|
2013-08-20 03:26:37 -04:00
|
|
|
rst Bankswitch
|
|
|
|
|
2018-01-30 14:47:14 -05:00
|
|
|
call WriteOAMDMACodeToHRAM
|
2013-08-20 03:26:37 -04:00
|
|
|
|
|
|
|
xor a
|
2015-11-05 14:06:03 -05:00
|
|
|
ld [hMapAnims], a
|
2013-08-20 03:26:37 -04:00
|
|
|
ld [hSCX], a
|
|
|
|
ld [hSCY], a
|
|
|
|
ld [rJOYP], a
|
|
|
|
|
|
|
|
ld a, $8 ; HBlank int enable
|
|
|
|
ld [rSTAT], a
|
|
|
|
|
|
|
|
ld a, $90
|
|
|
|
ld [hWY], a
|
|
|
|
ld [rWY], a
|
|
|
|
|
|
|
|
ld a, 7
|
|
|
|
ld [hWX], a
|
|
|
|
ld [rWX], a
|
|
|
|
|
2017-12-29 19:22:33 +01:00
|
|
|
ld a, LCDC_DEFAULT ; %11100011
|
2013-08-20 03:26:37 -04:00
|
|
|
; LCD on
|
|
|
|
; Win tilemap 1
|
|
|
|
; Win on
|
|
|
|
; BG/Win tiledata 0
|
|
|
|
; BG Tilemap 0
|
|
|
|
; OBJ 8x8
|
|
|
|
; OBJ on
|
|
|
|
; BG on
|
|
|
|
ld [rLCDC], a
|
|
|
|
|
2018-01-19 19:31:45 -05:00
|
|
|
ld a, CONNECTION_NOT_ESTABLISHED
|
2018-01-19 14:49:43 -05:00
|
|
|
ld [hSerialConnectionStatus], a
|
2013-08-20 03:26:37 -04:00
|
|
|
|
2017-12-24 12:47:30 -05:00
|
|
|
farcall InitCGBPals
|
2013-08-20 03:26:37 -04:00
|
|
|
|
2017-12-28 13:32:33 +01:00
|
|
|
ld a, HIGH(vBGMap1)
|
2015-10-19 16:49:29 -04:00
|
|
|
ld [hBGMapAddress + 1], a
|
2017-12-28 13:32:33 +01:00
|
|
|
xor a ; LOW(vBGMap1)
|
2013-08-20 03:26:37 -04:00
|
|
|
ld [hBGMapAddress], a
|
|
|
|
|
2017-12-24 12:47:30 -05:00
|
|
|
farcall StartClock
|
2013-08-20 03:26:37 -04:00
|
|
|
|
|
|
|
xor a
|
|
|
|
ld [MBC3LatchClock], a
|
|
|
|
ld [MBC3SRamEnable], a
|
|
|
|
|
|
|
|
ld a, [hCGB]
|
|
|
|
and a
|
2016-05-05 15:07:37 -04:00
|
|
|
jr z, .no_double_speed
|
2013-09-08 03:12:48 -04:00
|
|
|
call NormalSpeed
|
2016-05-05 15:07:37 -04:00
|
|
|
.no_double_speed
|
2013-08-20 03:26:37 -04:00
|
|
|
|
|
|
|
xor a
|
|
|
|
ld [rIF], a
|
|
|
|
ld a, %1111 ; VBlank, LCDStat, Timer, Serial interrupts
|
|
|
|
ld [rIE], a
|
|
|
|
ei
|
|
|
|
|
|
|
|
call DelayFrame
|
|
|
|
|
2018-01-16 14:30:10 -05:00
|
|
|
predef InitSGBBorder ; SGB init
|
2013-08-20 03:26:37 -04:00
|
|
|
|
2015-11-11 23:38:57 -05:00
|
|
|
call MapSetup_Sound_Off
|
2013-08-20 03:26:37 -04:00
|
|
|
xor a
|
2014-05-21 16:21:46 -04:00
|
|
|
ld [wMapMusic], a
|
2013-08-20 03:26:37 -04:00
|
|
|
jp GameInit
|
|
|
|
; 245
|
|
|
|
|
|
|
|
|
2014-02-01 20:26:39 -05:00
|
|
|
ClearVRAM:: ; 245
|
2013-08-20 03:26:37 -04:00
|
|
|
; Wipe VRAM banks 0 and 1
|
|
|
|
|
|
|
|
ld a, 1
|
|
|
|
ld [rVBK], a
|
|
|
|
call .clear
|
|
|
|
|
2018-01-18 01:25:19 -05:00
|
|
|
xor a ; 0
|
2013-08-20 03:26:37 -04:00
|
|
|
ld [rVBK], a
|
|
|
|
.clear
|
2018-01-18 01:25:19 -05:00
|
|
|
ld hl, VRAM_Begin
|
|
|
|
ld bc, VRAM_End - VRAM_Begin
|
2013-08-20 03:26:37 -04:00
|
|
|
xor a
|
|
|
|
call ByteFill
|
|
|
|
ret
|
|
|
|
; 25a
|
|
|
|
|
2014-02-01 20:26:39 -05:00
|
|
|
ClearWRAM:: ; 25a
|
2013-08-20 03:26:37 -04:00
|
|
|
; Wipe swappable WRAM banks (1-7)
|
2016-05-10 12:31:49 -04:00
|
|
|
; Assumes CGB or AGB
|
2013-08-20 03:26:37 -04:00
|
|
|
|
|
|
|
ld a, 1
|
2016-05-10 12:31:49 -04:00
|
|
|
.bank_loop
|
2013-08-20 03:26:37 -04:00
|
|
|
push af
|
|
|
|
ld [rSVBK], a
|
|
|
|
xor a
|
2017-12-26 23:18:05 -05:00
|
|
|
ld hl, WRAM1_Begin
|
|
|
|
ld bc, WRAM1_End - WRAM1_Begin
|
2013-08-20 03:26:37 -04:00
|
|
|
call ByteFill
|
|
|
|
pop af
|
|
|
|
inc a
|
|
|
|
cp 8
|
2016-05-19 08:11:44 -04:00
|
|
|
jr nc, .bank_loop ; Should be jr c
|
2013-08-20 03:26:37 -04:00
|
|
|
ret
|
|
|
|
; 270
|
|
|
|
|
2016-05-10 12:31:49 -04:00
|
|
|
ClearsScratch:: ; 270
|
|
|
|
; Wipe the first 32 bytes of sScratch
|
|
|
|
|
|
|
|
ld a, BANK(sScratch)
|
2013-08-20 03:26:37 -04:00
|
|
|
call GetSRAMBank
|
2016-05-10 12:31:49 -04:00
|
|
|
ld hl, sScratch
|
|
|
|
ld bc, $20
|
2013-08-20 03:26:37 -04:00
|
|
|
xor a
|
|
|
|
call ByteFill
|
|
|
|
call CloseSRAM
|
|
|
|
ret
|
|
|
|
; 283
|