69 warn_once(
"A9SCU with >4 CPUs is unsupported\n");
73 int smp_bits, core_cnt;
76 pkt->
setLE(smp_bits << 4 | core_cnt);
80 panic(
"Tried to read SCU at offset %#x\n", daddr);
97 warn(
"Tried to write SCU at offset %#x\n", daddr);
105 A9SCUParams::create()
107 return new A9SCU(
this);
#define panic(...)
This implements a cprintf based panic() function.
#define fatal(...)
This implements a cprintf based fatal() function.
virtual Tick write(PacketPtr pkt)
All writes are panic.
virtual Tick read(PacketPtr pkt)
Handle a read to the device.
void setLE(T v)
Set the value in the data pointer to v as little endian.
Addr pioSize
Size that the device's address range.
void makeAtomicResponse()
uint64_t Tick
Tick count type.
unsigned numContexts() const
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
Declaration of the Packet class.
Tick pioDelay
Delay that the device experinces on an access.
This defines the snoop control unit register on an A9.
Addr pioAddr
Address that the device listens to.
A9SCU(Params *p)
The constructor for RealView just registers itself with the MMU.