31 #include "debug/I8254.hh" 56 }
else if (offset == 3) {
57 pkt->
setLE(uint8_t(-1));
59 panic(
"Read from undefined i8254 register.\n");
72 }
else if (offset == 3) {
75 panic(
"Write to undefined i8254 register.\n");
100 I8254Params::create()
#define panic(...)
This implements a cprintf based panic() function.
void writeControl(const CtrlReg data)
Write control word.
void counterInterrupt(unsigned int num)
void startup() override
startup() is the final initialization call before simulation.
uint8_t readCounter(unsigned int num)
void writeCounter(unsigned int num, const uint8_t data)
void startup()
Start ticking.
void setLE(T v)
Set the value in the data pointer to v as little endian.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void makeAtomicResponse()
uint64_t Tick
Tick count type.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
Declaration of the Packet class.
std::ostream CheckpointOut
std::vector< IntSourcePin< I8254 > * > intPin
T getLE() const
Get the data in the packet byte swapped from little endian to host endian.
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
void serialize(CheckpointOut &cp) const override
Serialize an object.
Addr pioAddr
Address that the device listens to.
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.