Go to the documentation of this file.
   46 #include "debug/RubyCache.hh" 
   47 #include "debug/RubyStats.hh" 
   59     : 
SimObject(
p), addrRanges(
p.addr_ranges.begin(), 
p.addr_ranges.end())
 
   93         if (
r.contains(address)) {
 
  105         if (
r.contains(address)) {
 
  106             ret += 
r.getOffset(address);
 
  118     DPRINTF(RubyCache, 
"Looking up address: %#x\n", address);
 
  130     DPRINTF(RubyCache, 
"Looking up address: %#x\n", address);
 
  146     DPRINTF(RubyCache, 
"Removing entry for address: %#x\n", address);
 
  162     DPRINTF(RubyStats, 
"Recorded statistic: %s\n",
 
  163             DirectoryRequestType_to_string(requestType));
 
  
const AddrRangeList addrRanges
The address range for which the directory responds.
uint64_t mapAddressToLocalIdx(Addr address)
Return the index in the directory based on an address.
void changePermission(AccessPermission new_perm)
AbstractCacheEntry ** m_entries
static constexpr std::enable_if_t< std::is_integral_v< T >, int > floorLog2(T x)
static uint32_t getBlockSizeBytes()
void init()
init() is called after all C++ SimObjects have been created and all ports are connected.
AbstractCacheEntry * allocate(Addr address, AbstractCacheEntry *new_entry)
void recordRequestType(DirectoryRequestType requestType)
RubyDirectoryMemoryParams Params
bool isPresent(Addr address)
void deallocate(Addr address)
static uint32_t getBlockSizeBits()
DirectoryMemory(const Params &p)
Abstract superclass for simulation objects.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
AbstractCacheEntry * lookup(Addr address)
void print(std::ostream &out) const
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Generated on Thu Jul 28 2022 13:32:35 for gem5 by  doxygen 1.8.17