gem5  v21.0.1.0
Public Member Functions | Private Attributes | List of all members
Scoreboard Class Reference

Implements a simple scoreboard to track which registers are ready. More...

#include <scoreboard.hh>

Public Member Functions

 Scoreboard (const std::string &_my_name, unsigned _numPhysicalRegs)
 Constructs a scoreboard. More...
 
 ~Scoreboard ()
 Destructor. More...
 
std::string name () const
 Returns the name of the scoreboard. More...
 
bool getReg (PhysRegIdPtr phys_reg) const
 Checks if the register is ready. More...
 
void setReg (PhysRegIdPtr phys_reg)
 Sets the register as ready. More...
 
void unsetReg (PhysRegIdPtr phys_reg)
 Sets the register as not ready. More...
 

Private Attributes

const std::string _name
 The object name, for DPRINTF. More...
 
std::vector< bool > regScoreBoard
 Scoreboard of physical integer registers, saying whether or not they are ready. More...
 
M5_CLASS_VAR_USED unsigned numPhysRegs
 The number of actual physical registers. More...
 

Detailed Description

Implements a simple scoreboard to track which registers are ready.

This class operates on the unified physical register space, because the different classes of registers do not need to be distinguished. Registers being part of a fixed mapping are always considered ready.

Definition at line 46 of file scoreboard.hh.

Constructor & Destructor Documentation

◆ Scoreboard()

Scoreboard::Scoreboard ( const std::string &  _my_name,
unsigned  _numPhysicalRegs 
)

Constructs a scoreboard.

Parameters
_numPhysicalRegsNumber of physical registers.
_numMiscRegsNumber of miscellaneous registers.

Definition at line 32 of file scoreboard.cc.

◆ ~Scoreboard()

Scoreboard::~Scoreboard ( )
inline

Destructor.

Definition at line 69 of file scoreboard.hh.

Member Function Documentation

◆ getReg()

bool Scoreboard::getReg ( PhysRegIdPtr  phys_reg) const
inline

Checks if the register is ready.

Definition at line 75 of file scoreboard.hh.

References PhysRegId::flatIndex(), PhysRegId::isFixedMapping(), PhysRegId::isZeroReg(), numPhysRegs, and regScoreBoard.

Referenced by DefaultRename< Impl >::renameSrcRegs().

◆ name()

std::string Scoreboard::name ( ) const
inline

Returns the name of the scoreboard.

Definition at line 72 of file scoreboard.hh.

References _name.

◆ setReg()

void Scoreboard::setReg ( PhysRegIdPtr  phys_reg)
inline

◆ unsetReg()

void Scoreboard::unsetReg ( PhysRegIdPtr  phys_reg)
inline

Sets the register as not ready.

Definition at line 110 of file scoreboard.hh.

References PhysRegId::flatIndex(), PhysRegId::isFixedMapping(), PhysRegId::isZeroReg(), numPhysRegs, and regScoreBoard.

Referenced by DefaultRename< Impl >::renameDestRegs().

Member Data Documentation

◆ _name

const std::string Scoreboard::_name
private

The object name, for DPRINTF.

We have to declare this explicitly because Scoreboard is not a SimObject.

Definition at line 51 of file scoreboard.hh.

Referenced by name().

◆ numPhysRegs

M5_CLASS_VAR_USED unsigned Scoreboard::numPhysRegs
private

The number of actual physical registers.

Definition at line 58 of file scoreboard.hh.

Referenced by getReg(), setReg(), and unsetReg().

◆ regScoreBoard

std::vector<bool> Scoreboard::regScoreBoard
private

Scoreboard of physical integer registers, saying whether or not they are ready.

Definition at line 55 of file scoreboard.hh.

Referenced by getReg(), setReg(), and unsetReg().


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

Generated on Tue Jun 22 2021 15:28:43 for gem5 by doxygen 1.8.17