Go to the documentation of this file.
40 #include <linux/kvm.h>
43 #include "debug/GIC.hh"
44 #include "debug/Interrupt.hh"
45 #include "params/MuxingKvmGic.hh"
52 : cpuRange(
RangeSize(cpu_addr, KVM_VGIC_V2_CPU_SIZE)),
53 distRange(
RangeSize(dist_addr, KVM_VGIC_V2_DIST_SIZE)),
55 kdev(
vm.createDevice(KVM_DEV_TYPE_ARM_VGIC_V2))
62 KVM_DEV_ARM_VGIC_GRP_ADDR, KVM_VGIC_V2_ADDR_TYPE_DIST, dist_addr);
64 KVM_DEV_ARM_VGIC_GRP_ADDR, KVM_VGIC_V2_ADDR_TYPE_CPU, cpu_addr);
66 kdev.
setAttr<uint32_t>(KVM_DEV_ARM_VGIC_GRP_NR_IRQS, 0, it_lines);
94 setIntState(KVM_ARM_IRQ_TYPE_PPI, vcpu, ppi,
false);
101 assert(
type <= KVM_ARM_IRQ_TYPE_MASK);
102 assert(vcpu <= KVM_ARM_IRQ_VCPU_MASK);
103 assert(
irq <= KVM_ARM_IRQ_NUM_MASK);
105 (
type << KVM_ARM_IRQ_TYPE_SHIFT) |
106 (vcpu << KVM_ARM_IRQ_VCPU_SHIFT) |
107 (
irq << KVM_ARM_IRQ_NUM_SHIFT));
117 assert(vcpu <= KVM_ARM_IRQ_VCPU_MASK);
119 ((uint64_t)vcpu << KVM_DEV_ARM_VGIC_CPUID_SHIFT) |
120 (
offset << KVM_DEV_ARM_VGIC_OFFSET_SHIFT));
123 return (uint32_t)
reg;
130 uint64_t
reg = value;
132 assert(vcpu <= KVM_ARM_IRQ_VCPU_MASK);
134 ((uint64_t)vcpu << KVM_DEV_ARM_VGIC_CPUID_SHIFT) |
135 (
offset << KVM_DEV_ARM_VGIC_OFFSET_SHIFT));
144 return getGicReg(KVM_DEV_ARM_VGIC_GRP_DIST_REGS, vcpu, daddr);
151 return getGicReg(KVM_DEV_ARM_VGIC_GRP_CPU_REGS, vcpu, daddr);
158 setGicReg(KVM_DEV_ARM_VGIC_GRP_DIST_REGS, vcpu, daddr,
data);
177 if (
vm && !
p.simulate_gic) {
225 panic(
"MuxingKvmGic: PIO from gem5 is currently unsupported\n");
234 panic(
"MuxingKvmGic: PIO from gem5 is currently unsupported\n");
292 DPRINTF(GIC,
"copy dist 0x%x 0x%08x\n", daddr,
val);
293 to->writeDistributor(ctx, daddr,
val);
301 DPRINTF(GIC,
"copy cpu 0x%x 0x%08x\n", daddr,
val);
302 to->writeCpu(ctx, daddr,
val);
307 Addr daddr,
size_t size)
310 for (
auto a = daddr;
a < daddr + size;
a += 4)
316 Addr daddr,
size_t size)
319 for (
auto a = daddr;
a < daddr + size;
a += 4)
320 to->writeDistributor(ctx,
a, 0xFFFFFFFF);
325 Addr daddr,
size_t size)
327 for (
auto a = daddr;
a < daddr + size;
a += 4)
333 Addr daddr,
size_t size)
335 for (
auto a = daddr;
a < daddr + size;
a += 4)
336 to->writeDistributor(0,
a, 0xFFFFFFFF);
367 set += 4, clear += 4, size -= 4;
378 set += 4, clear += 4, size -= 4;
389 set += 4, clear += 4, size -= 4;
void clearInt(ContextID ctx, uint32_t int_num)
Clears a cpu IRQ or FIQ signal.
System & system
System this interrupt controller belongs to.
void fromGicV2ToKvm()
Multiplexing implementation.
Addr start() const
Get the start address of the range.
static const AddrRange GICD_IPRIORITYR
MuxingKvmGic(const MuxingKvmGicParams &p)
void clearSPI(unsigned spi)
Clear a shared peripheral interrupt.
AddrRange RangeSize(Addr start, Addr size)
void setPPI(unsigned vcpu, unsigned ppi)
Raise a private peripheral interrupt.
void drainResume() override
Resume execution after a successful drain.
static const AddrRange GICD_ISPENDR
void drainResume() override
Resume execution after a successful drain.
void clearPPInt(uint32_t num, uint32_t cpu) override
static const AddrRange GICD_ICPENDR
virtual uint32_t readCpu(ContextID ctx, Addr daddr)=0
uint32_t getGicReg(unsigned group, unsigned vcpu, unsigned offset)
Get value of GIC register "from" a cpu.
void setAttr(uint32_t group, uint64_t attr, const T &data) const
Get the value of an attribute.
void sendPPInt(uint32_t num, uint32_t cpu) override
Interface call for private peripheral interrupts.
void setIntState(unsigned type, unsigned vcpu, unsigned irq, bool high)
Update the kernel's VGIC interrupt state.
void sendInt(uint32_t number) override
Post an interrupt from a device that is connected to the GIC.
DrainState
Object drain/handover states.
void setAttrPtr(uint32_t group, uint64_t attr, const void *data) const
KvmDevice kdev
Kernel interface to the GIC.
void clearDistRange(BaseGicRegisters *to, Addr daddr, size_t size)
KvmVM * getKvmVM()
Get a pointer to the Kernel Virtual Machine (KVM) SimObject, if present.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
static const AddrRange GICD_ISENABLER
void writeDistributor(ContextID ctx, Addr daddr, uint32_t data) override
void setSPI(unsigned spi)
Raise a shared peripheral interrupt.
virtual void updateIntState(int hint)
See if some processor interrupt flags need to be enabled/disabled.
Tick write(PacketPtr pkt) override
A PIO read to the device, immediately split up into writeDistributor() or writeCpu()
virtual ~KvmKernelGicV2()
void setIRQLine(uint32_t irq, bool high)
Set the status of an IRQ line using KVM_IRQ_LINE.
void clearInt(uint32_t num) override
Clear an interrupt from a device that is connected to the GIC.
void enableKernelIRQChip()
Tell the VM and VCPUs to use an in-kernel IRQ chip for interrupt delivery.
static const AddrRange GICD_ICFGR
static const AddrRange GICD_ICENABLER
static const AddrRange GICD_ISACTIVER
Tick read(PacketPtr pkt) override
A PIO read to the device, immediately split up into readDistributor() or readCpu()
void setGicReg(unsigned group, unsigned vcpu, unsigned offset, unsigned value)
Set value of GIC register "from" a cpu.
uint32_t readDistributor(ContextID ctx, Addr daddr) override
BaseGicRegisters interface.
uint8_t cpuPriority[CPU_MAX]
CPU priority.
long contextIdToVCpuId(ContextID ctx) const
Get the VCPUID for a given context.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void sendInt(uint32_t num) override
Post an interrupt from a device that is connected to the GIC.
virtual uint32_t readDistributor(ContextID ctx, Addr daddr)=0
void copyDistRegister(BaseGicRegisters *from, BaseGicRegisters *to, ContextID ctx, Addr daddr)
void updateIntState(int hint) override
See if some processor interrupt flags need to be enabled/disabled.
void clearPPInt(uint32_t num, uint32_t cpu) override
uint32_t readCpu(ContextID ctx, Addr daddr) override
uint32_t itLines
Number of itLines enabled.
static const AddrRange GICD_ITARGETSR
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
KvmKernelGicV2 * kernelGic
Kernel GIC device.
KvmVM & vm
KVM VM in the parent system.
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
virtual void startup()
startup() is the final initialization call before simulation.
static const AddrRange GICD_ICACTIVER
DrainState drain() override
Draining is the process of clearing out the states of SimObjects.These are the SimObjects that are pa...
int ContextID
Globally unique thread context ID.
bool validKvmEnvironment() const
Verify gem5 configuration will support KVM emulation.
KvmKernelGicV2(KvmVM &vm, Addr cpu_addr, Addr dist_addr, unsigned it_lines)
Instantiate a KVM in-kernel GIC model.
void clearPPI(unsigned vcpu, unsigned ppi)
Clear a private peripheral interrupt.
void startup() override
startup() is the final initialization call before simulation.
void getAttrPtr(uint32_t group, uint64_t attr, void *data) const
void copyCpuRegister(BaseGicRegisters *from, BaseGicRegisters *to, ContextID ctx, Addr daddr)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void writeCpu(ContextID ctx, Addr daddr, uint32_t data) override
DrainState drain() override
Draining is the process of clearing out the states of SimObjects.These are the SimObjects that are pa...
void copyBankedDistRange(BaseGicRegisters *from, BaseGicRegisters *to, Addr daddr, size_t size)
void clearBankedDistRange(BaseGicRegisters *to, Addr daddr, size_t size)
void sendPPInt(uint32_t num, uint32_t cpu) override
Interface call for private peripheral interrupts.
void copyDistRange(BaseGicRegisters *from, BaseGicRegisters *to, Addr daddr, size_t size)
KVM in-kernel GIC abstraction.
#define panic(...)
This implements a cprintf based panic() function.
void copyGicState(BaseGicRegisters *from, BaseGicRegisters *to)
Generated on Tue Dec 21 2021 11:34:19 for gem5 by doxygen 1.8.17