Go to the documentation of this file.
   42 #include "params/ArmInterruptPin.hh" 
   43 #include "params/ArmPPI.hh" 
   44 #include "params/ArmSPI.hh" 
   45 #include "params/BaseGic.hh" 
   57     fatal_if(!rv, 
"GIC model can't register with platform code");
 
  102     panic_if(!tc, 
"Invalid Thread Context\n");
 
  105     auto pin_it = 
pins.find(cid);
 
  107     if (pin_it != 
pins.end()) {
 
  109         return pin_it->second;
 
  114         pins.insert({cid, pin});
 
  122       : threadContext(tc), platform(dynamic_cast<
RealView*>(
p.platform)),
 
  123         intNum(
p.num), triggerType(
p.
int_type), _active(false)
 
  132              "InterruptLine::setThreadContext called twice\n");
 
  141              "call to InterruptLine::setThreadContext.\n");
 
  158     const ArmSPIParams &
p)
 
  
void raise() override
Signal an interrupt.
ArmSPI(const ArmSPIParams &p)
void clear() override
Clear a signalled interrupt.
ArmSPIGen(const ArmSPIParams &p)
#define UNSERIALIZE_SCALAR(scalar)
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
std::unordered_map< ContextID, ArmPPI * > pins
void setGic(BaseGic *_gic)
Give platform a pointer to interrupt controller.
void setThreadContext(ThreadContext *tc)
Set the thread context owning this interrupt.
int ContextID
Globally unique thread context ID.
ArmInterruptPin * get(ThreadContext *tc=nullptr) override
ArmPPI(const ArmPPIParams &p, ThreadContext *tc)
bool _active
True if interrupt pin is active, false otherwise.
ArmInterruptPin(const ArmInterruptPinParams &p, ThreadContext *tc)
const Params & params() const
const uint32_t intNum
Interrupt number to generate.
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
ArmInterruptPin * get(ThreadContext *tc=nullptr) override
This device is the base class which all devices senstive to an address range inherit from.
ThreadContext is the external interface to all thread state for anything outside of the CPU.
ContextID targetContext() const
Get the target context ID of this interrupt.
This SimObject is instantiated in the python world and serves as an ArmInterruptPin generator.
void clear() override
Clear a signalled interrupt.
ArmInterruptPinGen(const ArmInterruptPinParams &p)
virtual ContextID contextId() const =0
const ThreadContext * threadContext
Pointer to the thread context that owns this interrupt in case it is a thread-/CPU-private interrupt.
virtual void clearPPInt(uint32_t num, uint32_t cpu)=0
const SimObjectParams & _params
Cached copy of the object parameters.
RealView *const platform
Arm platform to use for interrupt generation.
#define SERIALIZE_SCALAR(scalar)
virtual void sendInt(uint32_t num)=0
Post an interrupt from a device that is connected to the GIC.
virtual void clearInt(uint32_t num)=0
Clear an interrupt from a device that is connected to the GIC.
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
void setGIC(BaseGic *gic)
Sets the pointer to the GIC.
Generic representation of an Arm interrupt pin.
std::ostream CheckpointOut
ArmSystem * getSystem() const
void raise() override
Signal an interrupt.
const Params & params() const
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...
ArmPPIGen(const Params &p)
void serialize(CheckpointOut &cp) const override
Serialize an object.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
Abstract superclass for simulation objects.
Generated on Tue Jun 22 2021 15:28:27 for gem5 by  doxygen 1.8.17