Go to the documentation of this file.
42 #include "params/ArmInterruptPin.hh"
43 #include "params/ArmPPI.hh"
44 #include "params/ArmSigInterruptPin.hh"
45 #include "params/ArmSPI.hh"
46 #include "params/BaseGic.hh"
61 fatal_if(!rv,
"GIC model can't register with platform code");
106 panic_if(!tc,
"Invalid Thread Context\n");
109 auto pin_it =
pins.find(cid);
111 if (pin_it !=
pins.end()) {
113 return pin_it->second;
118 pins.insert({cid, pin});
137 if (if_name ==
"irq") {
153 : threadContext(tc), platform(dynamic_cast<
RealView*>(
p.platform)),
154 intNum(
p.num), triggerType(
p.
int_type), _active(false)
163 "InterruptLine::setThreadContext called twice\n");
172 "call to InterruptLine::setThreadContext.\n");
189 const ArmSPIParams &
p)
void setGic(BaseGic *_gic)
Give platform a pointer to interrupt controller.
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.
virtual Port & getPort(const std::string &if_name, PortID idx=InvalidPortID)
Get a port with a given name and index.
const ThreadContext * threadContext
Pointer to the thread context that owns this interrupt in case it is a thread-/CPU-private interrupt.
ArmSystem * getSystem() const
const uint32_t intNum
Interrupt number to generate.
ArmInterruptPin * get(ThreadContext *tc=nullptr) override
This device is the base class which all devices senstive to an address range inherit from.
#define UNSERIALIZE_SCALAR(scalar)
ArmSPIGen(const ArmSPIParams &p)
std::vector< std::unique_ptr< IntSourcePin< ArmSigInterruptPinGen > > > sigPin
void raise() override
Signal an interrupt.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
ArmSigInterruptPinGen(const ArmSigInterruptPinParams &p)
const SimObjectParams & _params
Cached copy of the object parameters.
virtual ContextID contextId() const =0
ArmSPI(const ArmSPIParams &p)
std::string csprintf(const char *format, const Args &...args)
const PortID InvalidPortID
ArmInterruptPin(const ArmInterruptPinParams &p, ThreadContext *tc)
ContextID targetContext() const
Get the target context ID of this interrupt.
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
void clear() override
Clear a signalled interrupt.
std::unordered_map< ContextID, ArmPPI * > pins
ArmSigInterruptPin(const ArmSigInterruptPinParams &p)
void clear() override
Clear a signalled interrupt.
ThreadContext is the external interface to all thread state for anything outside of the CPU.
virtual std::string name() const
virtual void clearPPInt(uint32_t num, uint32_t cpu)=0
const Params & params() const
ArmInterruptPin * get(ThreadContext *tc=nullptr) override
bool _active
True if interrupt pin is active, false otherwise.
ArmInterruptPin * get(ThreadContext *tc=nullptr) override
const Params & params() const
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
Abstract superclass for simulation objects.
virtual void sendInt(uint32_t num)=0
Post an interrupt from a device that is connected to the GIC.
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
ArmPPIGen(const Params &p)
void raise() override
Signal an interrupt.
#define SERIALIZE_SCALAR(scalar)
RealView *const platform
Arm platform to use for interrupt generation.
void clear() override
Clear a signalled interrupt.
ArmPPI(const ArmPPIParams &p, ThreadContext *tc)
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
void setThreadContext(ThreadContext *tc)
Set the thread context owning this interrupt.
virtual void clearInt(uint32_t num)=0
Clear an interrupt from a device that is connected to the GIC.
Ports are used to interface objects to each other.
int ContextID
Globally unique thread context ID.
void setGIC(BaseGic *gic)
Sets the pointer to the GIC.
Generic representation of an Arm interrupt pin.
std::ostream CheckpointOut
ArmInterruptPinGen(const ArmInterruptPinParams &p)
virtual void sendPPInt(uint32_t num, uint32_t cpu)=0
Interface call for private peripheral interrupts.
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
This SimObject is instantiated in the python world and serves as an ArmInterruptPin generator.
void raise() override
Signal an interrupt.
Generated on Tue Dec 21 2021 11:34:27 for gem5 by doxygen 1.8.17