pokecrystal-board/home/init.asm

220 lines
2.7 KiB
NASM
Raw Normal View History

2018-06-24 07:09:41 -07:00
Reset::
2013-08-20 00:26:37 -07:00
di
2015-11-11 20:38:57 -08:00
call MapSetup_Sound_Off
2013-08-20 00:26:37 -07:00
xor a
2015-11-05 11:06:03 -08:00
ld [hMapAnims], a
2013-08-20 00:26:37 -07: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 00:26:37 -07:00
set 7, [hl]
ld c, 32
call DelayFrames
jr Init
2018-06-24 07:09:41 -07:00
_Start::
2013-08-20 00:26:37 -07:00
cp $11
jr z, .cgb
2013-08-20 00:26:37 -07:00
xor a
jr .load
2013-08-20 00:26:37 -07:00
.cgb
2013-08-20 00:26:37 -07:00
ld a, $1
.load
2013-08-20 00:26:37 -07:00
ld [hCGB], a
ld a, $1
ld [hSystemBooted], a
2013-08-20 00:26:37 -07:00
2018-06-24 07:09:41 -07:00
Init::
2013-08-20 00:26:37 -07: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 00:26:37 -07:00
ld a, %100 ; Start timer at 4096Hz
ld [rTAC], a
.wait
ld a, [rLY]
2017-12-29 09:53:21 -08:00
cp LY_VBLANK + 1
2013-08-20 00:26:37 -07: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 00:26:37 -07:00
ld [hl], 0
inc hl
dec bc
ld a, b
or c
jr nz, .ByteFill
2013-08-20 00:26:37 -07:00
2018-01-23 13:49:58 -08:00
ld sp, wStack
2013-08-20 00:26:37 -07:00
; Clear HRAM
ld a, [hCGB]
push af
ld a, [hSystemBooted]
2013-08-20 00:26:37 -07:00
push af
xor a
ld hl, HRAM_Begin
ld bc, HRAM_End - HRAM_Begin
2013-08-20 00:26:37 -07:00
call ByteFill
pop af
ld [hSystemBooted], a
2013-08-20 00:26:37 -07:00
pop af
ld [hCGB], a
call ClearWRAM
2018-01-17 22:25:19 -08:00
ld a, 1
2013-08-20 00:26:37 -07:00
ld [rSVBK], a
call ClearVRAM
call ClearSprites
call ClearsScratch
2013-08-20 00:26:37 -07:00
2018-01-30 11:47:14 -08:00
ld a, BANK(WriteOAMDMACodeToHRAM)
2013-08-20 00:26:37 -07:00
rst Bankswitch
2018-01-30 11:47:14 -08:00
call WriteOAMDMACodeToHRAM
2013-08-20 00:26:37 -07:00
xor a
2015-11-05 11:06:03 -08:00
ld [hMapAnims], a
2013-08-20 00:26:37 -07: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 10:22:33 -08:00
ld a, LCDC_DEFAULT ; %11100011
2013-08-20 00:26:37 -07: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 00:26:37 -07:00
2017-12-24 09:47:30 -08:00
farcall InitCGBPals
2013-08-20 00:26:37 -07:00
2017-12-28 04:32:33 -08:00
ld a, HIGH(vBGMap1)
2015-10-19 13:49:29 -07:00
ld [hBGMapAddress + 1], a
2017-12-28 04:32:33 -08:00
xor a ; LOW(vBGMap1)
2013-08-20 00:26:37 -07:00
ld [hBGMapAddress], a
2017-12-24 09:47:30 -08:00
farcall StartClock
2013-08-20 00:26:37 -07:00
xor a
ld [MBC3LatchClock], a
ld [MBC3SRamEnable], a
ld a, [hCGB]
and a
2016-05-05 12:07:37 -07:00
jr z, .no_double_speed
2013-09-08 00:12:48 -07:00
call NormalSpeed
2016-05-05 12:07:37 -07:00
.no_double_speed
2013-08-20 00:26:37 -07: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 00:26:37 -07:00
2015-11-11 20:38:57 -08:00
call MapSetup_Sound_Off
2013-08-20 00:26:37 -07:00
xor a
2014-05-21 13:21:46 -07:00
ld [wMapMusic], a
2013-08-20 00:26:37 -07:00
jp GameInit
2018-06-24 07:09:41 -07:00
ClearVRAM::
2013-08-20 00:26:37 -07:00
; Wipe VRAM banks 0 and 1
ld a, 1
ld [rVBK], a
call .clear
2018-01-17 22:25:19 -08:00
xor a ; 0
2013-08-20 00:26:37 -07:00
ld [rVBK], a
.clear
2018-01-17 22:25:19 -08:00
ld hl, VRAM_Begin
ld bc, VRAM_End - VRAM_Begin
2013-08-20 00:26:37 -07:00
xor a
call ByteFill
ret
2018-06-24 07:09:41 -07:00
ClearWRAM::
2013-08-20 00:26:37 -07:00
; Wipe swappable WRAM banks (1-7)
; Assumes CGB or AGB
2013-08-20 00:26:37 -07:00
ld a, 1
.bank_loop
2013-08-20 00:26:37 -07:00
push af
ld [rSVBK], a
xor a
ld hl, WRAM1_Begin
ld bc, WRAM1_End - WRAM1_Begin
2013-08-20 00:26:37 -07:00
call ByteFill
pop af
inc a
cp 8
2016-05-19 05:11:44 -07:00
jr nc, .bank_loop ; Should be jr c
2013-08-20 00:26:37 -07:00
ret
2018-06-24 07:09:41 -07:00
ClearsScratch::
; Wipe the first 32 bytes of sScratch
ld a, BANK(sScratch)
2013-08-20 00:26:37 -07:00
call GetSRAMBank
ld hl, sScratch
ld bc, $20
2013-08-20 00:26:37 -07:00
xor a
call ByteFill
call CloseSRAM
ret