gem5  v21.0.0.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
Classes | Public Types | Public Member Functions | Static Public Attributes | Private Types | Private Attributes | List of all members
AddressManager Class Reference

#include <address_manager.hh>

Classes

class  AtomicStruct
 
class  LastWriter
 

Public Types

typedef int32_t Value
 
typedef int32_t Location
 

Public Member Functions

 AddressManager (int n_atomic_locs, int numNormalLocsPerAtomic)
 
 ~AddressManager ()
 
Addr getAddress (Location loc)
 
Location getAtomicLoc ()
 
Location getLoadLoc (Location atomic_loc)
 
Location getStoreLoc (Location atomic_loc)
 
void finishLocSelection (Location atomic_loc)
 
void releaseLocation (Location atomic_loc, Location loc)
 
void updateLogTable (Location loc, int threadId, int episodeId, Value new_value, Tick curTick, int cuId=-1)
 
Value getLoggedValue (Location loc) const
 
bool validateAtomicResp (Location loc, Value ret_val)
 
std::string printLastWriter (Location loc) const
 

Static Public Attributes

static const int INVALID_VALUE = -1
 
static const int INVALID_LOCATION = -1
 

Private Types

typedef std::vector< AddrAddressMap
 
typedef std::vector< AtomicStruct * > AtomicStructTable
 
typedef std::vector< LastWriter * > LogTable
 

Private Attributes

int numAtomicLocs
 
int numLocsPerAtomic
 
int numNormalLocs
 
AddressMap randAddressMap
 
AtomicStructTable atomicStructs
 
LogTable logTable
 

Detailed Description

Definition at line 119 of file address_manager.hh.

Member Typedef Documentation

◆ AddressMap

Definition at line 262 of file address_manager.hh.

◆ AtomicStructTable

Definition at line 266 of file address_manager.hh.

◆ Location

typedef int32_t AddressManager::Location

Definition at line 126 of file address_manager.hh.

◆ LogTable

Definition at line 270 of file address_manager.hh.

◆ Value

typedef int32_t AddressManager::Value

Definition at line 125 of file address_manager.hh.

Constructor & Destructor Documentation

◆ AddressManager()

AddressManager::AddressManager ( int  n_atomic_locs,
int  numNormalLocsPerAtomic 
)

◆ ~AddressManager()

AddressManager::~AddressManager ( )

Definition at line 78 of file address_manager.cc.

References atomicStructs, and logTable.

Member Function Documentation

◆ finishLocSelection()

void AddressManager::finishLocSelection ( Location  atomic_loc)

Definition at line 116 of file address_manager.cc.

References atomicStructs, and numAtomicLocs.

Referenced by Episode::initActions().

◆ getAddress()

Addr AddressManager::getAddress ( Location  loc)

◆ getAtomicLoc()

AddressManager::Location AddressManager::getAtomicLoc ( )

Definition at line 94 of file address_manager.cc.

References atomicStructs, numAtomicLocs, and MipsISA::random.

Referenced by Episode::initActions().

◆ getLoadLoc()

AddressManager::Location AddressManager::getLoadLoc ( Location  atomic_loc)

Definition at line 102 of file address_manager.cc.

References atomicStructs, and numAtomicLocs.

◆ getLoggedValue()

AddressManager::Value AddressManager::getLoggedValue ( Location  loc) const

◆ getStoreLoc()

AddressManager::Location AddressManager::getStoreLoc ( Location  atomic_loc)

Definition at line 109 of file address_manager.cc.

References atomicStructs, and numAtomicLocs.

◆ printLastWriter()

std::string AddressManager::printLastWriter ( Location  loc) const

Definition at line 130 of file address_manager.cc.

References logTable.

Referenced by TesterThread::validateLoadResp().

◆ releaseLocation()

void AddressManager::releaseLocation ( Location  atomic_loc,
Location  loc 
)

Definition at line 123 of file address_manager.cc.

References atomicStructs, and numAtomicLocs.

Referenced by Episode::completeEpisode().

◆ updateLogTable()

void AddressManager::updateLogTable ( Location  loc,
int  threadId,
int  episodeId,
Value  new_value,
Tick  curTick,
int  cuId = -1 
)

Definition at line 412 of file address_manager.cc.

References logTable, numAtomicLocs, and numNormalLocs.

Referenced by DmaThread::hitCallback(), and GpuWavefront::hitCallback().

◆ validateAtomicResp()

bool AddressManager::validateAtomicResp ( Location  loc,
Value  ret_val 
)

Definition at line 427 of file address_manager.cc.

References atomicStructs, and numAtomicLocs.

Referenced by TesterThread::validateAtomicResp().

Member Data Documentation

◆ atomicStructs

AtomicStructTable AddressManager::atomicStructs
private

◆ INVALID_LOCATION

const int AddressManager::INVALID_LOCATION = -1
static

◆ INVALID_VALUE

const int AddressManager::INVALID_VALUE = -1
static

Definition at line 150 of file address_manager.hh.

Referenced by DmaThread::hitCallback(), and GpuWavefront::hitCallback().

◆ logTable

LogTable AddressManager::logTable
private

◆ numAtomicLocs

int AddressManager::numAtomicLocs
private

◆ numLocsPerAtomic

int AddressManager::numLocsPerAtomic
private

Definition at line 257 of file address_manager.hh.

Referenced by AddressManager().

◆ numNormalLocs

int AddressManager::numNormalLocs
private

Definition at line 259 of file address_manager.hh.

Referenced by AddressManager(), getLoggedValue(), and updateLogTable().

◆ randAddressMap

AddressMap AddressManager::randAddressMap
private

Definition at line 263 of file address_manager.hh.

Referenced by AddressManager(), and getAddress().


The documentation for this class was generated from the following files:

Generated on Tue Mar 23 2021 19:41:32 for gem5 by doxygen 1.8.17