bsnes/sfc/coprocessor/epsonrtc/epsonrtc.hpp

92 lines
1.6 KiB
C++

//Epson RTC-4513 Real-Time Clock
struct EpsonRTC : Coprocessor {
static auto Enter() -> void;
auto enter() -> void;
auto init() -> void;
auto load() -> void;
auto unload() -> void;
auto power() -> void;
auto reset() -> void;
auto sync() -> void;
auto read(uint addr, uint8 data) -> uint8;
auto write(uint 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 rtc_reset() -> void;
auto rtc_read(uint4 addr) -> uint4;
auto rtc_write(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 round_seconds() -> void;
auto tick() -> void;
auto tick_second() -> void;
auto tick_minute() -> void;
auto tick_hour() -> void;
auto tick_day() -> void;
auto tick_month() -> void;
auto tick_year() -> void;
};
extern EpsonRTC epsonrtc;