46#include "debug/RubyCache.hh" 
   47#include "debug/RubyStats.hh" 
   95        if (
r.contains(address)) {
 
 
  107        if (
r.contains(address)) {
 
  108            ret += 
r.getOffset(address);
 
 
  120    DPRINTF(RubyCache, 
"Looking up address: %#x\n", address);
 
 
  132    DPRINTF(RubyCache, 
"Looking up address: %#x\n", address);
 
 
  150    DPRINTF(RubyCache, 
"Removing entry for address: %#x\n", address);
 
 
  166    DPRINTF(RubyStats, 
"Recorded statistic: %s\n",
 
  167            DirectoryRequestType_to_string(requestType));
 
 
virtual void setRubySystem(RubySystem *rs)
void changePermission(AccessPermission new_perm)
virtual void initBlockSize(int block_size)
void deallocate(Addr address)
AbstractCacheEntry ** m_entries
const AddrRangeList addrRanges
The address range for which the directory responds.
RubySystem * m_ruby_system
void print(std::ostream &out) const
void init()
init() is called after all C++ SimObjects have been created and all ports are connected.
bool isPresent(Addr address)
RubyDirectoryMemoryParams Params
AbstractCacheEntry * lookup(Addr address)
AbstractCacheEntry * allocate(Addr address, AbstractCacheEntry *new_entry)
uint64_t mapAddressToLocalIdx(Addr address)
Return the index in the directory based on an address.
void recordRequestType(DirectoryRequestType requestType)
DirectoryMemory(const Params &p)
static constexpr std::enable_if_t< std::is_integral_v< T >, int > floorLog2(T x)
SimObject(const Params &p)
Copyright (c) 2024 Arm Limited All rights reserved.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.