226 lines
2.7 KiB
NASM
Raw Normal View History

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
_Start:: ; 16e
2013-08-20 03:26:37 -04:00
cp $11
jr z, .cgb
2013-08-20 03:26:37 -04:00
xor a
jr .load
2013-08-20 03:26:37 -04:00
.cgb
2013-08-20 03:26:37 -04:00
ld a, $1
.load
2013-08-20 03:26:37 -04:00
ld [hCGB], a
ld a, $1
ld [hSystemBooted], a
2013-08-20 03:26:37 -04:00
; 17d
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
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
ld hl, WRAM0_Begin
ld bc, WRAM0_End - WRAM0_Begin
.ByteFill:
2013-08-20 03:26:37 -04:00
ld [hl], 0
inc hl
dec bc
ld a, b
or c
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
ld a, [hSystemBooted]
2013-08-20 03:26:37 -04:00
push af
xor a
ld hl, HRAM_Begin
ld bc, HRAM_End - HRAM_Begin
2013-08-20 03:26:37 -04:00
call ByteFill
pop af
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
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
ld a, CONNECTION_NOT_ESTABLISHED
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
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
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
ClearWRAM:: ; 25a
2013-08-20 03:26:37 -04:00
; Wipe swappable WRAM banks (1-7)
; Assumes CGB or AGB
2013-08-20 03:26:37 -04:00
ld a, 1
.bank_loop
2013-08-20 03:26:37 -04:00
push af
ld [rSVBK], a
xor a
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
ClearsScratch:: ; 270
; Wipe the first 32 bytes of sScratch
ld a, BANK(sScratch)
2013-08-20 03:26:37 -04:00
call GetSRAMBank
ld hl, sScratch
ld bc, $20
2013-08-20 03:26:37 -04:00
xor a
call ByteFill
call CloseSRAM
ret
; 283