Go to the documentation of this file.
   42 #include "debug/GIC.hh" 
   43 #include "params/ArmInterruptPin.hh" 
   44 #include "params/ArmPPI.hh" 
   45 #include "params/ArmSigInterruptPin.hh" 
   46 #include "params/ArmSPI.hh" 
   47 #include "params/BaseGic.hh" 
   62     fatal_if(!rv, 
"GIC model can't register with platform code");
 
  107     panic_if(!tc, 
"Invalid Thread Context\n");
 
  110     auto pin_it = 
pins.find(cid);
 
  112     if (pin_it != 
pins.end()) {
 
  114         return pin_it->second;
 
  119         pins.insert({cid, pin});
 
  138     if (if_name == 
"irq") {
 
  154       : threadContext(tc), platform(dynamic_cast<
RealView*>(
p.platform)),
 
  155         intNum(
p.num), triggerType(
p.
int_type), _active(false)
 
  164              "InterruptLine::setThreadContext called twice\n");
 
  173              "call to InterruptLine::setThreadContext.\n");
 
  190     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 Thu Jul 28 2022 13:32:30 for gem5 by  doxygen 1.8.17