Go to the documentation of this file.
50 #ifndef __DEV_ARM_VGIC_H__
51 #define __DEV_ARM_VGIC_H__
60 #include "params/VGic.hh"
160 : vctrl(0), hcr(0), eisr(0), VMGrp0En(0), VMGrp1En(0),
161 VMAckCtl(0), VMFiqEn(0), VMCBPR(0), VEM(0), VMABP(0), VMBP(0),
166 virtual ~vcpuIntData() {}
168 std::array<ListReg, NUM_LR> LR;
212 uint32_t
getMISR(
struct vcpuIntData *vid);
220 unsigned int pend = 0;
229 unsigned int valid = 0;
231 if (vid->LR[
i].State)
240 unsigned int prio = 0xff;
243 if ((vid->LR[
i].State &
LR_PENDING) && (vid->LR[
i].Priority < prio)) {
245 prio = vid->LR[
i].Priority;
254 if (vid->LR[
i].State &&
255 vid->LR[
i].VirtualID == virq &&
256 vid->LR[
i].CpuID == vcpu)
void unPostVInt(uint32_t cpu)
Tick readVCpu(PacketPtr pkt)
Bitfield< 27, 23 > Priority
void postVInt(uint32_t cpu, Tick when)
static const int GICH_LR3
This device is the base class which all devices senstive to an address range inherit from.
static const int GICH_LR2
static const int GICH_HCR
bool maintIntPosted[VGIC_CPU_MAX]
static const int GICV_HPPIR
void processPostVIntEvent(uint32_t cpu)
Post interrupt to CPU.
static const int GICV_APR0
static const int GICH_SIZE
void serialize(CheckpointOut &cp) const override
Serialize an object.
EndBitUnion(ListReg) BitUnion32(HCR) Bitfield< 31
void updateIntState(ContextID ctx_id)
static const uint32_t LR_ACTIVE
uint32_t getMISR(struct vcpuIntData *vid)
static const int GICH_VTR
static const int GICV_AEOIR
unsigned int lrValid(struct vcpuIntData *vid)
static const int GICV_AIAR
Bitfield< 9, 0 > VirtualID
static const int GICH_LR1
static const int VGIC_CPU_MAX
Basic support for object serialization.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
AddrRangeList getAddrRanges() const override
Every PIO device is obliged to provide an implementation that returns the address ranges the device r...
static const int GICV_AHPPIR
static const int GICV_EOIR
static const uint32_t LR_PENDING
static const int GICH_LR0
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
static const int GICH_EISR1
static const int GICH_EISR0
static const int GICH_ELSR0
static const int GICV_PMR
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
int findLRForVIRQ(struct vcpuIntData *vid, int virq, int vcpu)
static const int GICH_VMCR
static const int GICV_IAR
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Tick writeVCpu(PacketPtr pkt)
static const int GICH_MISR
static const int GICH_ELSR1
static const int GICV_RPR
void unPostMaintInt(uint32_t cpu)
static const int GICV_SIZE
Tick readCtrl(PacketPtr pkt)
unsigned int lrPending(struct vcpuIntData *vid)
static const int GICH_REG_SIZE
int ContextID
Globally unique thread context ID.
int findHighestPendingLR(struct vcpuIntData *vid)
Returns LR index or -1 if none pending.
Tick writeCtrl(PacketPtr pkt)
bool vIntPosted[VGIC_CPU_MAX]
static const int GICV_IIDR
static const int GICV_ABPR
std::ostream CheckpointOut
static const int GICV_CTLR
EndBitUnion(VCTLR) struct vcpuIntData struct std::array< vcpuIntData, VGIC_CPU_MAX > vcpuData
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
static const int GICH_APR0
void postMaintInt(uint32_t cpu)
static const int GICV_DIR
BitUnion32(ListReg) Bitfield< 31 > HW
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
EventFunctionWrapper * postVIntEvent[VGIC_CPU_MAX]
static const int GICV_BPR
Generated on Wed May 4 2022 12:13:56 for gem5 by doxygen 1.8.17