mirror of https://github.com/bsnes-emu/bsnes.git
91 lines
1.6 KiB
C++
91 lines
1.6 KiB
C++
//Epson RTC-4513 Real-Time Clock
|
|
|
|
struct EpsonRTC : Thread {
|
|
using Thread::synchronize;
|
|
|
|
static auto Enter() -> void;
|
|
auto main() -> void;
|
|
|
|
auto initialize() -> void;
|
|
auto power() -> void;
|
|
auto synchronize(uint64 timestamp) -> void;
|
|
|
|
auto read(uint24 addr, uint8 data) -> uint8;
|
|
auto write(uint24 addr, uint8 data) -> void;
|
|
|
|
auto serialize(serializer&) -> void;
|
|
|
|
uint21 clocks;
|
|
uint seconds;
|
|
|
|
uint2 chipselect;
|
|
enum class State : uint { Mode, Seek, Read, Write } state;
|
|
uint4 mdr;
|
|
uint4 offset;
|
|
uint wait;
|
|
uint1 ready;
|
|
uint1 holdtick;
|
|
|
|
uint4 secondlo;
|
|
uint3 secondhi;
|
|
uint1 batteryfailure;
|
|
|
|
uint4 minutelo;
|
|
uint3 minutehi;
|
|
uint1 resync;
|
|
|
|
uint4 hourlo;
|
|
uint2 hourhi;
|
|
uint1 meridian;
|
|
|
|
uint4 daylo;
|
|
uint2 dayhi;
|
|
uint1 dayram;
|
|
|
|
uint4 monthlo;
|
|
uint1 monthhi;
|
|
uint2 monthram;
|
|
|
|
uint4 yearlo;
|
|
uint4 yearhi;
|
|
|
|
uint3 weekday;
|
|
|
|
uint1 hold;
|
|
uint1 calendar;
|
|
uint1 irqflag;
|
|
uint1 roundseconds;
|
|
|
|
uint1 irqmask;
|
|
uint1 irqduty;
|
|
uint2 irqperiod;
|
|
|
|
uint1 pause;
|
|
uint1 stop;
|
|
uint1 atime; //astronomical time (24-hour mode)
|
|
uint1 test;
|
|
|
|
//memory.cpp
|
|
auto rtcReset() -> void;
|
|
auto rtcRead(uint4 addr) -> uint4;
|
|
auto rtcWrite(uint4 addr, uint4 data) -> void;
|
|
|
|
auto load(const uint8* data) -> void;
|
|
auto save(uint8* data) -> void;
|
|
|
|
//time.cpp
|
|
auto irq(uint2 period) -> void;
|
|
auto duty() -> void;
|
|
auto roundSeconds() -> void;
|
|
auto tick() -> void;
|
|
|
|
auto tickSecond() -> void;
|
|
auto tickMinute() -> void;
|
|
auto tickHour() -> void;
|
|
auto tickDay() -> void;
|
|
auto tickMonth() -> void;
|
|
auto tickYear() -> void;
|
|
};
|
|
|
|
extern EpsonRTC epsonrtc;
|