Go to the documentation of this file.
39 #include "debug/MC146818.hh"
47 result += (
val / 10) << 4;
56 result += (
val >> 4) * 10;
66 mon = time.tm_mon + 1;
73 wday = time.tm_wday + 1;
89 const struct tm time,
bool bcd,
Tick frequency)
104 DPRINTFN(
"Real-time clock set to %s", asctime(&time));
114 MC146818::rega_dv_disabled(
const RtcRegA &
reg)
128 if (!rega_dv_disabled(stat_regA))
135 bool panic_unsupported(
false);
149 RtcRegA old_rega(stat_regA);
152 stat_regA.uip = old_rega;
154 if (!rega_dv_disabled(stat_regA) &&
156 inform(
"RTC: Unimplemented divider configuration: %i\n",
158 panic_unsupported =
true;
162 inform(
"RTC: Unimplemented interrupt rate: %i\n",
164 panic_unsupported =
true;
167 if (rega_dv_disabled(stat_regA)) {
172 }
else if (rega_dv_disabled(old_rega)) {
184 inform(
"RTC: Unimplemented interrupt configuration: %s %s\n",
187 panic_unsupported =
true;
191 inform(
"RTC: The binary interface is not fully implemented.\n");
192 panic_unsupported =
true;
196 inform(
"RTC: The 12h time format not supported.\n");
197 panic_unsupported =
true;
201 inform(
"RTC: Automatic daylight saving time not supported.\n");
202 panic_unsupported =
true;
207 event.scheduleIntr();
215 panic(
"RTC status registers C and D are not implemented.\n");
220 if (panic_unsupported)
221 panic(
"Unimplemented RTC configuration!\n");
234 stat_regA.uip = !stat_regA.uip;
245 panic(
"Shouldn't be here");
253 assert(!rega_dv_disabled(stat_regA));
265 uint8_t regA_serial(stat_regA);
276 Tick rtcTimerInterruptTickOffset =
event.when() -
curTick();
298 Tick rtcTimerInterruptTickOffset;
300 event.offset = rtcTimerInterruptTickOffset;
301 Tick rtcClockTickOffset;
307 : parent(_parent), interval(
i),
offset(
i)
315 parent->schedule(
this,
curTick() + interval);
322 parent->schedule(
this,
curTick() + interval);
323 parent->handleEvent();
329 return "RTC interrupt";
343 return "RTC clock tick";
static uint8_t unbcdize(uint8_t val)
static const int RTC_STAT_REGA
bool scheduled() const
Determine if the current event is scheduled.
void unserialize(const std::string &base, CheckpointIn &cp)
Reconstruct the state of this object from a checkpoint.
static const int RTC_STAT_REGD
#define UNSERIALIZE_SCALAR(scalar)
void scheduleIntr()
Schedule the RTC periodic interrupt.
time_t mkutctime(struct tm *time)
const char * description() const
Event description.
uint64_t Tick
Tick count type.
void deschedule(Event &event)
RtcRegB stat_regB
RTC status register B.
RTCTickEvent tickEvent
RTC tick event.
static const int RTC_STAT_REGB
Tick when() const
Get the time that the event is scheduled.
static const int RTCA_DV_DISABLED1
void serialize(const std::string &base, CheckpointOut &cp) const
Serialize this object to the given output stream.
void schedule(Event &event, Tick when)
decltype(std::begin(std::declval< const T & >()), std::end(std::declval< const T & >()), void()) arrayParamOut(CheckpointOut &os, const std::string &name, const T ¶m)
uint8_t readData(const uint8_t addr)
RTC read data.
static const int RTCA_DV_DISABLED0
RTCEvent(MC146818 *_parent, Tick i)
virtual void process()
Event process to occur at interrupt.
Real-Time Clock (MC146818)
virtual const char * description() const
Event description.
void process()
Event process to occur at interrupt.
#define SERIALIZE_SCALAR(scalar)
void paramOut(CheckpointOut &cp, const std::string &name, ExtMachInst const &machInst)
static uint8_t bcdize(uint8_t val)
static const int RTCA_DV_32768HZ
static const int RTCA_RS_1024HZ
void writeData(const uint8_t addr, const uint8_t data)
RTC write data.
static const int RTC_STAT_REGC
MC146818(EventManager *em, const std::string &name, const struct tm time, bool bcd, Tick frequency)
std::ostream CheckpointOut
void arrayParamIn(CheckpointIn &cp, const std::string &name, CircleBuf< T > ¶m)
Tick curTick()
The universal simulation clock.
void setTime(const struct tm time)
void paramIn(CheckpointIn &cp, const std::string &name, ExtMachInst &machInst)
RTCEvent event
RTC periodic interrupt event.
#define panic(...)
This implements a cprintf based panic() function.
virtual void startup()
Start ticking.
Generated on Tue Jun 22 2021 15:28:28 for gem5 by doxygen 1.8.17