Go to the documentation of this file.
41 #include "params/RiscvRTC.hh"
45 rtc(this, params.
name, params.time, params.bcd,
46 params.frequency, params.port_int_pin_connection_count)
51 const struct tm time,
bool bcd,
Tick frequency,
int int_pin_count) :
54 for (
int i = 0;
i < int_pin_count;
i++) {
63 for (
auto &pin: intPin) {
72 if (if_name ==
"int_pin")
75 panic(
"Getting invalid port " + if_name);
void unserialize(const std::string &base, CheckpointIn &cp)
Reconstruct the state of this object from a checkpoint.
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
uint64_t Tick
Tick count type.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
void serialize(CheckpointOut &cp) const override
Serialize an object.
void serialize(const std::string &base, CheckpointOut &cp) const
Serialize this object to the given output stream.
void startup() override
startup() is the final initialization call before simulation.
Ports are used to interface objects to each other.
Real-Time Clock (MC146818)
const std::string & name()
RiscvRTC(const Params ¶ms)
std::vector< std::unique_ptr< IntSource > > intPin
void unserialize(CheckpointIn &cp) override
Unserialize an object.
std::ostream CheckpointOut
RTC(EventManager *em, const std::string &n, const struct tm time, bool bcd, Tick frequency, int int_pin_count)
std::string csprintf(const char *format, const Args &...args)
#define panic(...)
This implements a cprintf based panic() function.
Abstract superclass for simulation objects.
virtual void startup()
Start ticking.
Generated on Tue Mar 23 2021 19:41:26 for gem5 by doxygen 1.8.17