SYMBiFACE II:Realtime clock
This is the documentation about the realtime clock of the SYMBiFACE II expansion card.
SYMBiFACE II uses a Dallas DS12887A RTC chip. Source
This chip is a modernized version of the MC146818, the original RTC chip used in the IBM PC/AT. It includes a built-in battery and crystal. It is a PC compatible RTC chip and is programmed in the same way.
It has 14 bytes of registers and 114 bytes of battery-backed static RAM. Century register doesn't exist on this particular model. The chip also provides time-of-day alarm, three maskable interrupts with a common interrupt output, and a programmable square wave output.
Ports
- #FD15 (write only) register select
- #FD14 (read/write) read from or write into selected register
Registers
Number Content Values #00 actual second 00-59 (bcd or binary) #01 alarm second 00-59 (bcd or binary) #02 actual minute 00-59 (bcd or binary) #03 alarm minute 00-59 (bcd or binary) #04 actual hour 00-23 (bcd or binary) #05 alarm hour 00-23 (bcd or binary) #06 day of the week ?? #07 day of the month 01-31 (bcd or binary) #08 month 01-12 (bcd or binary) #09 year 00-99 (bcd or binary) #0A status A see below #0B status B see below #0C status C see below #0D status D see below #?? memory all other registers from #0E to #7F can be freely used as persistent memory
Note: Register B, Bit 2 allows to select BCD or Binary mode for registers 0..9
Note 1: In the discmag Future View IV a proposal is given how to use the non volatile RAM of the SYMBiFACE II and the CPC-Booster+.
Status registers
- Status A
bit0-3 [not used] interrupt frequency bit4-6 time frequency (must be 010; if not, set it to this value, otherwise the RTC will not work correctly) bit7 1 = time is being updated at the moment, so don't read it!
- Status B
bit0 1 = take summer time into account bit1 0 = 12 hours time format, 1 = 24 hours time format bit2 0 = all values in BCD format, 1 = all values in binary format bit3 1 = [not used] activate rectangle generator bit4 1 = [not used] generate interrupt after time update bit5 1 = [not used] generate interrupt if alarm bit6 1 = [not used] generate periodic interrupt (see status A, bit0-3) bit7 1 = stop time update; set this, during you update the time and reset it after the update!
- Status C
bit4 1 = [not used] interrupt has been generated because of time update (see status B, bit4) bit5 1 = [not used] interrupt has been generated because of alarm (see status B, bit5) bit6 1 = [not used] interrupt has been generated because of periodic (see status B, bit6)
- Status D
bit7 0 = battery is nearly empty, please charge or replace
Software
The RTC of the SYMBiFACE II is supported by FutureOS and SymbOS
