290 lines
4.1 KiB
NASM
Raw Normal View History

; Functions relating to the timer interrupt and the real-time-clock.
2018-06-24 16:09:41 +02:00
AskTimer::
push af
ldh a, [hMobile]
and a
2015-11-17 23:29:14 -05:00
jr z, .not_mobile
call Timer
2015-11-17 23:29:14 -05:00
.not_mobile
pop af
reti
2018-06-24 16:09:41 +02:00
LatchClock::
; latch clock counter data
ld a, 0
ld [MBC3LatchClock], a
ld a, 1
ld [MBC3LatchClock], a
ret
2018-06-24 16:09:41 +02:00
UpdateTime::
call GetClock
call FixDays
call FixTime
2017-12-24 12:47:30 -05:00
farcall GetTimeOfDay
ret
2018-06-24 16:09:41 +02:00
GetClock::
; store clock data in hRTCDayHi-hRTCSeconds
; enable clock r/w
ld a, SRAM_ENABLE
ld [MBC3SRamEnable], a
; clock data is 'backwards' in hram
call LatchClock
ld hl, MBC3SRamBank
ld de, MBC3RTC
ld [hl], RTC_S
ld a, [de]
2016-05-15 21:50:31 -04:00
maskbits 60
ldh [hRTCSeconds], a
ld [hl], RTC_M
ld a, [de]
2016-05-15 21:50:31 -04:00
maskbits 60
ldh [hRTCMinutes], a
ld [hl], RTC_H
ld a, [de]
2016-05-15 21:50:31 -04:00
maskbits 24
ldh [hRTCHours], a
ld [hl], RTC_DL
ld a, [de]
ldh [hRTCDayLo], a
ld [hl], RTC_DH
ld a, [de]
ldh [hRTCDayHi], a
; unlatch clock / disable clock r/w
call CloseSRAM
ret
2018-06-24 16:09:41 +02:00
FixDays::
; fix day count
; mod by 140
; check if day count > 255 (bit 8 set)
ldh a, [hRTCDayHi] ; DH
bit 0, a
jr z, .daylo
; reset dh (bit 8)
res 0, a
ldh [hRTCDayHi], a ; DH
; mod 140
; mod twice since bit 8 (DH) was set
ldh a, [hRTCDayLo] ; DL
.modh
sub 140
jr nc, .modh
.modl
sub 140
jr nc, .modl
add 140
; update dl
ldh [hRTCDayLo], a ; DL
2015-11-20 11:47:52 -05:00
; flag for sRTCStatusFlags
ld a, %01000000
jr .set
.daylo
; quit if fewer than 140 days have passed
ldh a, [hRTCDayLo] ; DL
cp 140
jr c, .quit
; mod 140
.mod
sub 140
jr nc, .mod
add 140
; update dl
ldh [hRTCDayLo], a ; DL
2015-11-20 11:47:52 -05:00
; flag for sRTCStatusFlags
ld a, %00100000
.set
; update clock with modded day value
push af
call SetClock
pop af
scf
ret
.quit
xor a
ret
2018-06-24 16:09:41 +02:00
FixTime::
; add ingame time (set at newgame) to current time
; day hr min sec
2018-01-23 17:39:09 -05:00
; store time in wCurDay, hHours, hMinutes, hSeconds
; second
ldh a, [hRTCSeconds] ; S
ld c, a
2018-01-23 17:39:09 -05:00
ld a, [wStartSecond]
add c
sub 60
jr nc, .updatesec
add 60
.updatesec
ldh [hSeconds], a
; minute
ccf ; carry is set, so turn it off
ldh a, [hRTCMinutes] ; M
ld c, a
2018-01-23 17:39:09 -05:00
ld a, [wStartMinute]
adc c
sub 60
jr nc, .updatemin
add 60
.updatemin
ldh [hMinutes], a
; hour
ccf ; carry is set, so turn it off
ldh a, [hRTCHours] ; H
ld c, a
2018-01-23 17:39:09 -05:00
ld a, [wStartHour]
adc c
sub 24
jr nc, .updatehr
add 24
.updatehr
ldh [hHours], a
; day
ccf ; carry is set, so turn it off
ldh a, [hRTCDayLo] ; DL
ld c, a
2018-01-23 17:39:09 -05:00
ld a, [wStartDay]
adc c
2018-01-23 17:39:09 -05:00
ld [wCurDay], a
ret
2018-06-24 16:09:41 +02:00
InitTimeOfDay::
xor a
2018-01-23 17:39:09 -05:00
ld [wStringBuffer2], a
2015-11-17 23:29:14 -05:00
ld a, $0 ; useless
2018-01-23 17:39:09 -05:00
ld [wStringBuffer2 + 3], a
2015-12-18 20:07:09 -05:00
jr InitTime
2018-06-24 16:09:41 +02:00
InitDayOfWeek::
call UpdateTime
ldh a, [hHours]
2018-01-23 17:39:09 -05:00
ld [wStringBuffer2 + 1], a
ldh a, [hMinutes]
2018-01-23 17:39:09 -05:00
ld [wStringBuffer2 + 2], a
ldh a, [hSeconds]
2018-01-23 17:39:09 -05:00
ld [wStringBuffer2 + 3], a
2015-12-18 20:07:09 -05:00
jr InitTime ; useless
2018-06-24 16:09:41 +02:00
InitTime::
2017-12-24 12:47:30 -05:00
farcall _InitTime
ret
2018-06-24 16:09:41 +02:00
PanicResetClock::
2015-11-17 23:29:14 -05:00
call .ClearhRTC
call SetClock
ret
2018-06-24 16:09:41 +02:00
.ClearhRTC:
xor a
ldh [hRTCSeconds], a
ldh [hRTCMinutes], a
ldh [hRTCHours], a
ldh [hRTCDayLo], a
ldh [hRTCDayHi], a
ret
2018-06-24 16:09:41 +02:00
SetClock::
; set clock data from hram
; enable clock r/w
ld a, SRAM_ENABLE
ld [MBC3SRamEnable], a
; set clock data
; stored 'backwards' in hram
call LatchClock
ld hl, MBC3SRamBank
ld de, MBC3RTC
; seems to be a halt check that got partially commented out
; this block is totally pointless
ld [hl], RTC_DH
ld a, [de]
bit 6, a ; halt
ld [de], a
; seconds
ld [hl], RTC_S
ldh a, [hRTCSeconds]
ld [de], a
; minutes
ld [hl], RTC_M
ldh a, [hRTCMinutes]
ld [de], a
; hours
ld [hl], RTC_H
ldh a, [hRTCHours]
ld [de], a
; day lo
ld [hl], RTC_DL
ldh a, [hRTCDayLo]
ld [de], a
; day hi
ld [hl], RTC_DH
ldh a, [hRTCDayHi]
res 6, a ; make sure timer is active
ld [de], a
; cleanup
call CloseSRAM ; unlatch clock, disable clock r/w
ret
2018-06-24 16:09:41 +02:00
ClearRTCStatus::
2015-11-20 11:47:52 -05:00
; clear sRTCStatusFlags
xor a
push af
2015-11-20 11:47:52 -05:00
ld a, BANK(sRTCStatusFlags)
call GetSRAMBank
pop af
2015-11-20 11:47:52 -05:00
ld [sRTCStatusFlags], a
call CloseSRAM
ret
2018-06-24 16:09:41 +02:00
RecordRTCStatus::
2015-11-20 11:47:52 -05:00
; append flags to sRTCStatusFlags
ld hl, sRTCStatusFlags
push af
2015-11-20 11:47:52 -05:00
ld a, BANK(sRTCStatusFlags)
call GetSRAMBank
pop af
or [hl]
ld [hl], a
call CloseSRAM
ret
2018-06-24 16:09:41 +02:00
CheckRTCStatus::
2015-11-20 11:47:52 -05:00
; check sRTCStatusFlags
ld a, BANK(sRTCStatusFlags)
call GetSRAMBank
2015-11-20 11:47:52 -05:00
ld a, [sRTCStatusFlags]
call CloseSRAM
ret