29 #ifndef __DEV_X86_I8259_HH__ 30 #define __DEV_X86_I8259_HH__ 34 #include "enums/X86I8259CascadeMode.hh" 35 #include "params/I8259.hh" 51 Enums::X86I8259CascadeMode
mode;
88 return dynamic_cast<const Params *
>(
_params);
96 if (if_name ==
"inputs")
97 return *inputs.at(idx);
98 else if (if_name ==
"output")
99 return *output.at(idx);
130 #endif //__DEV_X86_I8259_HH__ Ports are used to interface objects to each other.
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
const PortID InvalidPortID
void unserialize(CheckpointIn &cp) override
Unserialize an object.
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
void serialize(CheckpointOut &cp) const override
Serialize an object.
std::vector< IntSinkPin< I8259 > * > inputs
uint64_t Tick
Tick count type.
static const int NumLines
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
void raiseInterruptPin(int number)
Enums::X86I8259CascadeMode mode
const Params * params() const
std::ostream CheckpointOut
This is exposed globally, independent of the ISA.
const SimObjectParams * _params
Cached copy of the object parameters.
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
std::vector< IntSourcePin< I8259 > * > output
void signalInterrupt(int line)
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
void lowerInterruptPin(int number)
void requestInterrupt(int line)