Go to the documentation of this file.
35 #ifndef __MEM_RUBY_SYSTEM_RUBYSYSTEM_HH__
36 #define __MEM_RUBY_SYSTEM_RUBYSYSTEM_HH__
38 #include <unordered_map>
46 #include "params/RubySystem.hh"
61 class AbstractController;
101 void init()
override;
125 uint64_t cache_trace_size,
126 uint64_t block_size_bytes);
130 uint64_t &uncompressed_trace_size);
132 uint64_t uncompressed_trace_size);
155 std::unordered_map<unsigned, std::vector<AbstractController*>>
netCntrls;
166 #endif //__MEM_RUBY_SYSTEM_RUBYSYSTEM_HH__
static bool m_warmup_enabled
RubySystem(const Params &p)
void regStats() override
Callback to set stat parameters.
bool functionalRead(Packet *ptr)
void startup() override
startup() is the final initialization call before simulation.
std::unordered_map< MachineID, unsigned > machineToNetwork
static uint32_t getMemorySizeBits()
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
void serialize(CheckpointOut &cp) const override
Serialize an object.
std::unordered_map< unsigned, std::vector< AbstractController * > > netCntrls
std::vector< std::map< uint32_t, AbstractController * > > m_abstract_controls
static uint32_t getBlockSizeBytes()
void schedule(Event &event, Tick when)
The simple memory is a basic single-ported memory controller with a configurable throughput and laten...
void resetStats() override
Callback to reset stats.
bool getAccessBackingStore()
memory::SimpleMemory * m_phys_mem
static void writeCompressedTrace(uint8_t *raw_data, std::string file, uint64_t uncompressed_trace_size)
Cycles is a wrapper class for representing cycle counts, i.e.
void registerAbstractController(AbstractController *)
const bool m_access_backing_store
std::vector< std::unique_ptr< Network > > m_networks
static void readCompressedTrace(std::string filename, uint8_t *&raw_data, uint64_t &uncompressed_trace_size)
RubySystem & operator=(const RubySystem &obj)
static bool m_randomization
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
CacheRecorder * m_cache_recorder
uint64_t Tick
Tick count type.
std::vector< AbstractController * > m_abs_cntrl_vec
EventQueue * eventq
A pointer to this object's event queue.
static uint32_t getBlockSizeBits()
static int getRandomization()
bool empty() const
Returns true if no events are queued.
static uint32_t m_block_size_bytes
void memWriteback() override
Write back dirty buffers to memory using functional writes.
static bool getCooldownEnabled()
void registerRequestorIDs()
virtual void regStats()
Callback to set stat parameters.
void makeCacheRecorder(uint8_t *uncompressed_trace, uint64_t cache_trace_size, uint64_t block_size_bytes)
void registerMachineID(const MachineID &mach_id, Network *network)
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
std::unordered_map< RequestorID, unsigned > requestorToNetwork
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void drainResume() override
Resume execution after a successful drain.
static uint32_t m_memory_size_bits
static unsigned m_systems_to_warmup
static bool getWarmupEnabled()
void enqueueRubyEvent(Tick tick)
memory::SimpleMemory * getPhysMem()
bool functionalWrite(Packet *ptr)
std::ostream CheckpointOut
ClockedObjectParams Params
Parameters of ClockedObject.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
static bool m_cooldown_enabled
void registerNetwork(Network *)
static uint32_t m_block_size_bits
Generated on Wed Jul 13 2022 10:39:26 for gem5 by doxygen 1.8.17