49 fatal(
"The direct CPU requires the memory system to be in the " 50 "'atomic_noncaching' mode.\n");
66 NonCachingSimpleCPUParams::create()
70 fatal(
"only one workload allowed");
A MasterPort is a specialisation of a BaseMasterPort, which implements the default protocol for the t...
NonCachingSimpleCPU(NonCachingSimpleCPUParams *p)
#define fatal(...)
This implements a cprintf based fatal() function.
Tick sendPacket(MasterPort &port, const PacketPtr &pkt) override
ThreadID numThreads
Number of threads we're actually simulating (<= SMT_MAX_THREADS).
bool FullSystem
The FullSystem variable can be used to determine the current mode of simulation.
The NonCachingSimpleCPU is an AtomicSimpleCPU using the 'atomic_noncaching' memory mode instead of ju...
bool isAtomicMode() const
Is the system in atomic mode?
void verifyMemoryMode() const override
Verify that the system is in a memory mode supported by the CPU.
bool isMemAddr(Addr addr) const
Check if a physical address is within a range of a memory that is part of the global address map...
uint64_t Tick
Tick count type.
void access(PacketPtr pkt)
Perform an untimed memory access and update all the state (e.g.
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
bool bypassCaches() const
Should caches be bypassed?
PhysicalMemory & getPhysMem()
Get a pointer to access the physical memory of the system.
Tick sendAtomic(PacketPtr pkt)
Send an atomic request packet, where the data is moved and the state is updated in zero time...