2020-06-17 17:03:38 -04:00
|
|
|
OpenSRAM::
|
2013-09-08 02:50:06 -04:00
|
|
|
; if invalid bank, sram is disabled
|
|
|
|
cp NUM_SRAM_BANKS
|
2020-06-17 17:03:38 -04:00
|
|
|
jr c, .valid
|
2020-07-13 13:05:05 -04:00
|
|
|
if DEF(_DEBUG)
|
|
|
|
push af
|
|
|
|
push bc
|
|
|
|
ld b, 1
|
|
|
|
.loop
|
|
|
|
sla b
|
|
|
|
dec a
|
|
|
|
jr nz, .loop
|
|
|
|
ld a, BANK(sOpenedInvalidSRAM)
|
|
|
|
call OpenSRAM
|
|
|
|
ld a, [sOpenedInvalidSRAM]
|
|
|
|
or b
|
|
|
|
ld [sOpenedInvalidSRAM], a
|
|
|
|
pop bc
|
|
|
|
pop af
|
|
|
|
endc
|
2013-09-08 02:50:06 -04:00
|
|
|
jr CloseSRAM
|
|
|
|
|
2020-06-17 17:03:38 -04:00
|
|
|
.valid:
|
2013-09-08 02:50:06 -04:00
|
|
|
; switch to sram bank a
|
|
|
|
push af
|
|
|
|
; latch clock data
|
|
|
|
ld a, 1
|
|
|
|
ld [MBC3LatchClock], a
|
|
|
|
; enable sram/clock write
|
|
|
|
ld a, SRAM_ENABLE
|
|
|
|
ld [MBC3SRamEnable], a
|
|
|
|
; select sram bank
|
|
|
|
pop af
|
|
|
|
ld [MBC3SRamBank], a
|
|
|
|
ret
|
|
|
|
|
2018-06-24 16:09:41 +02:00
|
|
|
CloseSRAM::
|
2013-09-08 02:50:06 -04:00
|
|
|
push af
|
|
|
|
ld a, SRAM_DISABLE
|
|
|
|
; reset clock latch for next time
|
|
|
|
ld [MBC3LatchClock], a
|
|
|
|
; disable sram/clock write
|
|
|
|
ld [MBC3SRamEnable], a
|
|
|
|
pop af
|
|
|
|
ret
|