Go to the documentation of this file.
46 #include "debug/Iob.hh"
84 panic(
"Invalid address reached Iob\n");
116 panic(
"Read to unknown IOB offset 0x%x\n", accessAddr);
166 panic(
"Read to unknown JBus offset 0x%x\n", accessAddr);
177 panic(
"Invalid address reached Iob\n");
232 panic(
"Write to unknown IOB offset 0x%x\n", accessAddr);
259 panic(
"Write to unknown JBus offset 0x%x\n", accessAddr);
270 DPRINTF(
Iob,
"Receiving Device interrupt: %d for cpu %d vec %d\n",
290 "Generating interrupt because of I/O write to cpu: "
293 tc->getCpuPtr()->postInterrupt(
297 warn(
"Sending reset to CPU: %d\n", cpu_id);
299 panic(
"Don't know how to set non-POR reset to cpu\n");
304 DPRINTF(
Iob,
"Idling CPU because of I/O write cpu: %d\n", cpu_id);
308 DPRINTF(
Iob,
"Resuming CPU because of I/O write cpu: %d\n", cpu_id);
312 panic(
"Invalid type to generate ipi\n");
324 DPRINTF(
Iob,
"Receiving jBus interrupt: %d for cpu %d vec %d\n",
333 tc->getCpuPtr()->postInterrupt(
IntMan intMan[NumDeviceIds]
const Addr JIntDataA0Addr
This device is the base class which all devices senstive to an address range inherit from.
#define UNSERIALIZE_SCALAR(scalar)
AddrRange RangeSize(Addr start, Addr size)
RequestPtr req
A pointer to the original request.
AddrRangeList getAddrRanges() const override
Every PIO device is obliged to provide an implementation that returns the address ranges the device r...
IntBusy jIntBusy[MaxNiagaraProcs]
void writeJBus(PacketPtr pkt)
uint64_t jBusData0[MaxNiagaraProcs]
std::string csprintf(const char *format, const Args &...args)
void makeAtomicResponse()
bool receiveJBusInterrupt(int cpu_id, int source, uint64_t d0, uint64_t d1)
constexpr uint64_t mask(unsigned nbits)
Generate a 64-bit mask of 'nbits' 1s, right justified.
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
void readJBus(PacketPtr pkt)
uint64_t jBusData1[MaxNiagaraProcs]
IntCtl intCtl[NumDeviceIds]
void writeIob(PacketPtr pkt)
const int MaxNiagaraProcs
const Params & params() const
T getBE() const
Get the data in the packet byte swapped from big endian to host endian.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
void receiveDeviceInterrupt(DeviceId devid)
void setBE(T v)
Set the value in the data pointer to v as big endian.
constexpr T bits(T val, unsigned first, unsigned last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it.
#define SERIALIZE_ARRAY(member, size)
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
#define SERIALIZE_SCALAR(scalar)
void serialize(CheckpointOut &cp) const override
Serialize an object.
void paramOut(CheckpointOut &cp, const std::string &name, ExtMachInst const &machInst)
#define UNSERIALIZE_ARRAY(member, size)
void generateIpi(Type type, int cpu_id, int vector)
void paramIn(CheckpointIn &cp, const std::string &name, ExtMachInst &machInst)
int ContextID
Globally unique thread context ID.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
std::ostream CheckpointOut
void invoke(ThreadContext *tc, const StaticInstPtr &inst=nullStaticInstPtr)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
const Addr JIntDataA1Addr
#define panic(...)
This implements a cprintf based panic() function.
void readIob(PacketPtr pkt)
Generated on Wed Jul 28 2021 12:10:26 for gem5 by doxygen 1.8.17