Go to the documentation of this file.
41 #ifndef __DEV_ARM_GICV3_H__
42 #define __DEV_ARM_GICV3_H__
46 #include "params/Gicv3.hh"
51 class Gicv3CPUInterface;
52 class Gicv3Distributor;
53 class Gicv3Redistributor;
108 void clearInt(uint32_t int_id)
override;
109 void clearPPInt(uint32_t int_id, uint32_t cpu)
override;
117 void init()
override;
123 void sendInt(uint32_t int_id)
override;
124 void sendPPInt(uint32_t int_id, uint32_t cpu)
override;
169 #endif //__DEV_ARM_GICV3_H__
static const int INTID_NONSECURE
Gicv3Redistributor * getRedistributor(ContextID context_id) const
bool haveAsserted(uint32_t cpu) const
Gicv3CPUInterface * getCPUInterface(int cpu_id) const
Gicv3Distributor * getDistributor() const
Gicv3Redistributor * getRedistributorByAddr(Addr address) const
void deassertAll(uint32_t cpu)
void clearPPInt(uint32_t int_id, uint32_t cpu) override
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
void sendPPInt(uint32_t int_id, uint32_t cpu) override
Interface call for private peripheral interrupts.
void postInt(uint32_t cpu, ArmISA::InterruptTypes int_type)
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void serialize(CheckpointOut &cp) const override
Serialize an object.
std::vector< Gicv3CPUInterface * > cpuInterfaces
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
uint64_t Tick
Tick count type.
static const int INTID_SPURIOUS
Gicv3Distributor * distributor
std::vector< Gicv3Redistributor * > redistributors
void sendInt(uint32_t int_id) override
Post an interrupt from a device that is connected to the GIC.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Gicv3Redistributor * getRedistributorByAffinity(uint32_t affinity) const
int ContextID
Globally unique thread context ID.
static const int INTID_SECURE
std::ostream CheckpointOut
void deassertInt(uint32_t cpu, ArmISA::InterruptTypes int_type)
AddrRangeList getAddrRanges() const override
Every PIO device is obliged to provide an implementation that returns the address ranges the device r...
The AddrRange class encapsulates an address range, and supports a number of tests to check if two ran...
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void clearInt(uint32_t int_id) override
Clear an interrupt from a device that is connected to the GIC.
bool supportsVersion(GicVersion version) override
Check if version supported.
Generated on Wed Jul 28 2021 12:10:25 for gem5 by doxygen 1.8.17