29 #ifndef __DEV_X86_I8254_HH__ 30 #define __DEV_X86_I8254_HH__ 35 #include "params/I8254.hh" 74 if (if_name ==
"int_pin")
75 return *intPin.at(idx);
83 return dynamic_cast<const Params *
>(
_params);
89 for (
int i = 0;
i < p->port_int_pin_connection_count;
i++) {
91 "%s.int_pin[%d]",
name(),
i),
i,
this));
131 #endif //__DEV_X86_SOUTH_BRIDGE_I8254_HH__ Ports are used to interface objects to each other.
void writeControl(const CtrlReg data)
Write control word.
const PortID InvalidPortID
void counterInterrupt(unsigned int num)
Programmable Interval Timer (Intel 8254)
void counterInterrupt(unsigned int num)
uint8_t readCounter(unsigned int num)
void writeCounter(unsigned int num, const uint8_t data)
void startup()
Start ticking.
bool outputHigh(unsigned int num)
void writeCounter(unsigned int num, const uint8_t data)
std::string csprintf(const char *format, const Args &...args)
void writeControl(uint8_t val)
uint64_t Tick
Tick count type.
const std::string & name() const
bool outputHigh(unsigned int num)
X86Intel8254Timer(const std::string &name, I8254 *_parent)
uint8_t readCounter(unsigned int num)
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
const Params * params() const
std::ostream CheckpointOut
This is exposed globally, independent of the ISA.
const SimObjectParams * _params
Cached copy of the object parameters.
std::vector< IntSourcePin< I8254 > * > intPin
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
void serialize(const std::string &base, CheckpointOut &cp) const
Serialize this object to the given output stream.
void unserialize(const std::string &base, CheckpointIn &cp)
Reconstruct the state of this object from a checkpoint.