Go to the documentation of this file.
42 #ifndef __DEV_ARM_BASE_GIC_H__
43 #define __DEV_ARM_BASE_GIC_H__
45 #include <unordered_map>
50 #include "enums/ArmInterruptType.hh"
59 struct ArmInterruptPinParams;
84 virtual void sendInt(uint32_t num) = 0;
92 virtual void sendPPInt(uint32_t num, uint32_t cpu) = 0;
93 virtual void clearPPInt(uint32_t num, uint32_t cpu) = 0;
103 virtual void clearInt(uint32_t num) = 0;
173 std::unordered_map<ContextID, ArmPPI*>
pins;
202 virtual void raise() = 0;
204 virtual void clear() = 0;
245 void raise()
override;
246 void clear()
override;
256 void raise()
override;
257 void clear()
override;
Private Peripheral Interrupt Generator Since PPIs are banked in the GIC, this class is capable of gen...
ArmSPI(const ArmSPIParams &p)
void clear() override
Clear a signalled interrupt.
ArmSPIGen(const ArmSPIParams &p)
virtual ArmInterruptPin * get(ThreadContext *tc=nullptr)=0
std::unordered_map< ContextID, ArmPPI * > pins
virtual void clear()=0
Clear a signalled interrupt.
Basic support for object serialization.
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)
virtual bool supportsVersion(GicVersion version)=0
Check if version supported.
const Params & params() const
uint32_t num() const
Get interrupt number.
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.
const ArmInterruptType triggerType
Interrupt triggering type.
ArmInterruptPin * get(ThreadContext *tc=nullptr) override
Shared Peripheral Interrupt Generator It is capable of generating one interrupt only: it maintains a ...
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.
Platform * platform
Platform this GIC belongs to.
ArmInterruptPinGen(const ArmInterruptPinParams &p)
virtual void writeCpu(ContextID ctx, Addr daddr, uint32_t data)=0
virtual void writeDistributor(ContextID ctx, Addr daddr, uint32_t data)=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
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
RealView *const platform
Arm platform to use for interrupt generation.
bool active() const
True if interrupt pin is active, false otherwise.
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.
virtual uint32_t readDistributor(ContextID ctx, Addr daddr)=0
Generic representation of an Arm interrupt pin.
std::ostream CheckpointOut
ArmSystem * getSystem() const
virtual void sendPPInt(uint32_t num, uint32_t cpu)=0
Interface call for private peripheral interrupts.
ArmPPIGen(const Params &p)
void serialize(CheckpointOut &cp) const override
Serialize an object.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
virtual uint32_t readCpu(ContextID ctx, Addr daddr)=0
Abstract superclass for simulation objects.
Generated on Tue Mar 23 2021 19:41:25 for gem5 by doxygen 1.8.17