Go to the documentation of this file.
48 assert(
p.numThreads == 1);
50 "only one workload allowed");
57 fatal(
"The direct CPU requires the memory system to be in the "
58 "'atomic_noncaching' mode.\n");
72 auto callback = [
this](
const MemBackdoor &backdoor) {
75 if (it->second == &backdoor) {
80 panic(
"Got invalidation for unknown memory backdoor.");
82 bd->addInvalidationCallback(callback);
96 auto *
bd = bd_it->second;
#define fatal(...)
This implements a cprintf based fatal() function.
std::vector< SimpleExecContext * > threadInfo
Tick fetchInstMem() override
bool isAtomicMode() const
Is the system in atomic mode?
bool bypassCaches() const
Should caches be bypassed?
void verifyMemoryMode() const override
Verify that the system is in a memory mode supported by the CPU.
A RequestPort is a specialisation of a Port, which implements the default protocol for the three diff...
Tick sendAtomicBackdoor(PacketPtr pkt, MemBackdoorPtr &backdoor)
Send an atomic request packet like above, but also request a backdoor to the data being accessed.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
virtual Tick fetchInstMem()
uint64_t Tick
Tick count type.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
AddrRangeMap< MemBackdoorPtr, 1 > memBackdoors
bool FullSystem
The FullSystem variable can be used to determine the current mode of simulation.
NonCachingSimpleCPU(const NonCachingSimpleCPUParams &p)
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
#define panic(...)
This implements a cprintf based panic() function.
Tick sendPacket(RequestPort &port, const PacketPtr &pkt) override
Generated on Wed Jul 28 2021 12:10:24 for gem5 by doxygen 1.8.17