Go to the documentation of this file.
   61 #include "debug/Checkpoint.hh" 
   62 #include "debug/GICV2M.hh" 
   73             fatal(
"Gicv2m: Frame %d's SPI base (%d) is not in SPI space\n",
 
   78               "a power-of-two number of frames\n");
 
  103         pkt->
setLE<uint32_t>((
frames[frame]->spi_base << 16) |
 
  114         pkt->
setLE<uint32_t>(0);
 
  133         uint32_t 
m = pkt->
getLE<uint32_t>();
 
  134         if (
m >= 
frames[frame]->spi_base &&
 
  136             DPRINTF(GICV2M, 
"GICv2m: Frame %d raising MSI %d\n", frame, 
m);
 
  151     for (
int i = 0; 
i < 
frames.size(); 
i++) {
 
  
#define fatal(...)
This implements a cprintf based fatal() function.
void makeAtomicResponse()
const Tick pioDelay
Latency for an MMIO operation.
static const int MSI_TYPER
static const int FRAME_SIZE
unsigned int log2framenum
Count of number of configured frames, as log2(frames)
uint64_t Tick
Tick count type.
virtual Tick read(PacketPtr pkt)
A PIO read to the device.
BaseGic * gic
Gic to which we fire interrupts.
This device is the base class which all devices senstive to an address range inherit from.
static const int MSI_SETSPI_NSR
virtual AddrRangeList getAddrRanges() const
Return the address ranges used by the Gicv2m This is the set of frame addresses.
virtual Tick write(PacketPtr pkt)
A PIO read to the device.
AddrRange RangeSize(Addr start, Addr size)
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
virtual void sendInt(uint32_t num)=0
Post an interrupt from a device that is connected to the GIC.
std::vector< Gicv2mFrame * > frames
A set of configured hardware frames.
std::enable_if_t< std::is_integral< T >::value, int > floorLog2(T x)
T getLE() const
Get the data in the packet byte swapped from little endian to host endian.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
void setLE(T v)
Set the value in the data pointer to v as little endian.
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
bool isPowerOf2(const T &n)
int frameFromAddr(Addr a) const
Determine which frame a PIO access lands in.
Generated on Tue Jun 22 2021 15:28:27 for gem5 by  doxygen 1.8.17