29 #ifndef __DEV_X86_CMOS_HH__ 30 #define __DEV_X86_CMOS_HH__ 35 #include "params/Cmos.hh" 61 MC146818(em, n, time, bcd, frequency)
63 for (
int i = 0;
i < int_pin_count;
i++) {
76 rtc(this,
name() +
".rtc", p->time, true,
ULL(5000000000),
77 p->port_int_pin_connection_count)
79 memset(regs, 0, numRegs *
sizeof(uint8_t));
86 if (if_name ==
"int_pin")
104 #endif //__DEV_X86_CMOS_HH__ void writeRegister(uint8_t reg, uint8_t val)
Ports are used to interface objects to each other.
std::vector< IntSourcePin< X86RTC > * > intPin
const PortID InvalidPortID
uint8_t readRegister(uint8_t reg)
Real-Time Clock (MC146818)
std::string csprintf(const char *format, const Args &...args)
void serialize(const std::string &base, CheckpointOut &cp) const
Serialize this object to the given output stream.
uint64_t frequency() const
uint64_t Tick
Tick count type.
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
X86RTC(EventManager *em, const std::string &n, const struct tm time, bool bcd, Tick frequency, int int_pin_count)
#define ULL(N)
uint64_t constant
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
std::ostream CheckpointOut
This is exposed globally, independent of the ISA.
virtual void startup()
Start ticking.
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
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.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
const std::string & name() const