Go to the documentation of this file.
39 #include "debug/MC146818.hh"
50 result += (
val / 10) << 4;
59 result += (
val >> 4) * 10;
69 mon = time.tm_mon + 1;
76 wday = time.tm_wday + 1;
92 const struct tm time,
bool bcd,
Tick frequency)
107 DPRINTFN(
"Real-time clock set to %s", asctime(&time));
117 MC146818::rega_dv_disabled(
const RtcRegA &
reg)
131 if (!rega_dv_disabled(stat_regA))
138 bool panic_unsupported(
false);
152 RtcRegA old_rega(stat_regA);
155 stat_regA.uip = old_rega;
157 if (!rega_dv_disabled(stat_regA) &&
159 inform(
"RTC: Unimplemented divider configuration: %i\n",
161 panic_unsupported =
true;
165 inform(
"RTC: Unimplemented interrupt rate: %i\n",
167 panic_unsupported =
true;
170 if (rega_dv_disabled(stat_regA)) {
175 }
else if (rega_dv_disabled(old_rega)) {
187 inform(
"RTC: Unimplemented interrupt configuration: %s %s\n",
190 panic_unsupported =
true;
194 inform(
"RTC: The binary interface is not fully implemented.\n");
195 panic_unsupported =
true;
199 inform(
"RTC: The 12h time format not supported.\n");
200 panic_unsupported =
true;
204 inform(
"RTC: Automatic daylight saving time not supported.\n");
205 panic_unsupported =
true;
210 event.scheduleIntr();
218 panic(
"RTC status registers C and D are not implemented.\n");
223 if (panic_unsupported)
224 panic(
"Unimplemented RTC configuration!\n");
237 stat_regA.uip = !stat_regA.uip;
248 panic(
"Shouldn't be here");
256 assert(!rega_dv_disabled(stat_regA));
268 uint8_t regA_serial(stat_regA);
272 paramOut(cp,
base +
".stat_regA", (uint8_t)regA_serial);
273 paramOut(cp,
base +
".stat_regB", (uint8_t)regB_serial);
279 Tick rtcTimerInterruptTickOffset =
event.when() -
curTick();
301 Tick rtcTimerInterruptTickOffset;
303 event.offset = rtcTimerInterruptTickOffset;
304 Tick rtcClockTickOffset;
310 : parent(_parent), interval(
i),
offset(
i)
318 parent->schedule(
this,
curTick() + interval);
325 parent->schedule(
this,
curTick() + interval);
326 parent->handleEvent();
332 return "RTC interrupt";
346 return "RTC clock tick";
Tick curTick()
The universal simulation clock.
static const int RTC_STAT_REGA
Tick when() const
Get the time that the event is scheduled.
static const int RTC_STAT_REGD
#define UNSERIALIZE_SCALAR(scalar)
void setTime(const struct tm time)
RTCEvent event
RTC periodic interrupt event.
void schedule(Event &event, Tick when)
MC146818(EventManager *em, const std::string &name, const struct tm time, bool bcd, Tick frequency)
static const int RTC_STAT_REGB
RTCEvent(MC146818 *_parent, Tick i)
static const int RTCA_DV_DISABLED1
RtcRegB stat_regB
RTC status register B.
virtual void startup()
Start ticking.
uint64_t Tick
Tick count type.
static const int RTCA_DV_DISABLED0
static uint8_t bcdize(uint8_t val)
virtual const char * description() const
Event description.
void writeData(const uint8_t addr, const uint8_t data)
RTC write data.
virtual void process()
Event process to occur at interrupt.
#define SERIALIZE_SCALAR(scalar)
decltype(std::begin(std::declval< const T & >()), std::end(std::declval< const T & >()), void()) arrayParamOut(CheckpointOut &os, const std::string &name, const T ¶m)
void deschedule(Event &event)
static const int RTCA_DV_32768HZ
void process()
Event process to occur at interrupt.
const char * description() const
Event description.
static const int RTCA_RS_1024HZ
time_t mkutctime(struct tm *time)
void paramOut(CheckpointOut &cp, const std::string &name, ExtMachInst const &machInst)
static const int RTC_STAT_REGC
void serialize(const std::string &base, CheckpointOut &cp) const
Serialize this object to the given output stream.
void paramIn(CheckpointIn &cp, const std::string &name, ExtMachInst &machInst)
void scheduleIntr()
Schedule the RTC periodic interrupt.
std::ostream CheckpointOut
void arrayParamIn(CheckpointIn &cp, const std::string &name, CircleBuf< T > ¶m)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
static uint8_t unbcdize(uint8_t val)
void unserialize(const std::string &base, CheckpointIn &cp)
Reconstruct the state of this object from a checkpoint.
uint8_t readData(const uint8_t addr)
RTC read data.
RTCTickEvent tickEvent
RTC tick event.
Real-Time Clock (MC146818)
bool scheduled() const
Determine if the current event is scheduled.
#define panic(...)
This implements a cprintf based panic() function.
Generated on Wed Jul 13 2022 10:39:20 for gem5 by doxygen 1.8.17