gem5  v21.0.1.0
Classes | Public Types | Public Member Functions | Protected Attributes | Private Member Functions | Private Attributes | List of all members
ScoreboardCheckStage Class Reference

#include <scoreboard_check_stage.hh>

Classes

struct  ScoreboardCheckStageStats
 

Public Types

enum  nonrdytype_e {
  NRDY_ILLEGAL, NRDY_WF_STOP, NRDY_IB_EMPTY, NRDY_WAIT_CNT,
  NRDY_SLEEP, NRDY_BARRIER_WAIT, NRDY_VGPR_NRDY, NRDY_SGPR_NRDY,
  INST_RDY, NRDY_CONDITIONS
}
 

Public Member Functions

 ScoreboardCheckStage (const ComputeUnitParams &p, ComputeUnit &cu, ScoreboardCheckToSchedule &to_schedule)
 
 ~ScoreboardCheckStage ()
 
void exec ()
 
const std::string & name () const
 

Protected Attributes

ScoreboardCheckStage::ScoreboardCheckStageStats stats
 

Private Member Functions

void collectStatistics (nonrdytype_e rdyStatus)
 
int mapWaveToExeUnit (Wavefront *w)
 
bool ready (Wavefront *w, nonrdytype_e *rdyStatus, int *exeResType, int wfSlot)
 

Private Attributes

ComputeUnitcomputeUnit
 
ScoreboardCheckToScheduletoSchedule
 Interface between scoreboard check and schedule stages. More...
 
const std::string _name
 

Detailed Description

Definition at line 60 of file scoreboard_check_stage.hh.

Member Enumeration Documentation

◆ nonrdytype_e

Enumerator
NRDY_ILLEGAL 
NRDY_WF_STOP 
NRDY_IB_EMPTY 
NRDY_WAIT_CNT 
NRDY_SLEEP 
NRDY_BARRIER_WAIT 
NRDY_VGPR_NRDY 
NRDY_SGPR_NRDY 
INST_RDY 
NRDY_CONDITIONS 

Definition at line 63 of file scoreboard_check_stage.hh.

Constructor & Destructor Documentation

◆ ScoreboardCheckStage()

ScoreboardCheckStage::ScoreboardCheckStage ( const ComputeUnitParams &  p,
ComputeUnit cu,
ScoreboardCheckToSchedule to_schedule 
)

Definition at line 47 of file scoreboard_check_stage.cc.

◆ ~ScoreboardCheckStage()

ScoreboardCheckStage::~ScoreboardCheckStage ( )

Definition at line 56 of file scoreboard_check_stage.cc.

Member Function Documentation

◆ collectStatistics()

void ScoreboardCheckStage::collectStatistics ( nonrdytype_e  rdyStatus)
private

◆ exec()

void ScoreboardCheckStage::exec ( )

Reset the ready list for all execution units; ready list will be constructed every cycle because resource availability may change.

Definition at line 247 of file scoreboard_check_stage.cc.

References collectStatistics(), computeUnit, DPRINTF, ScoreboardCheckToSchedule::markWFReady(), Shader::n_wf, Wavefront::nextInstr(), NRDY_ILLEGAL, ComputeUnit::numVectorALUs, ready(), ScoreboardCheckToSchedule::reset(), ComputeUnit::shader, Wavefront::simdId, toSchedule, Wavefront::wfDynId, and ComputeUnit::wfList.

Referenced by ComputeUnit::exec().

◆ mapWaveToExeUnit()

int ScoreboardCheckStage::mapWaveToExeUnit ( Wavefront w)
private

NOTE: Flat memory ops requires both GM and LM resources. The simulator models consumption of both GM and LM resources in the schedule stage. At instruction execution time, after the aperture check is performed, only the GM or LM pipe is actually reserved by the timing model. The GM unit is returned here since Flat ops occupy the GM slot in the ready and dispatch lists. They also consume the LM slot in the dispatch list.

Definition at line 205 of file scoreboard_check_stage.cc.

References computeUnit, ComputeUnit::numExeUnits(), panic, and MipsISA::w.

Referenced by ready().

◆ name()

const std::string& ScoreboardCheckStage::name ( ) const
inline

Definition at line 82 of file scoreboard_check_stage.hh.

References _name.

◆ ready()

bool ScoreboardCheckStage::ready ( Wavefront w,
nonrdytype_e rdyStatus,
int *  exeResType,
int  wfSlot 
)
private

The waitCnt checks have to be done BEFORE checking for Instruction buffer empty condition. Otherwise, it will result into a deadlock if the last instruction in the Instruction buffer is a waitCnt: after executing the waitCnt, the Instruction buffer would be empty and the ready check logic will exit BEFORE checking for wait counters being satisfied.

Definition at line 74 of file scoreboard_check_stage.cc.

References ComputeUnit::allAtBarrier(), computeUnit, ComputeUnit::cu_id, DPRINTF, INST_RDY, mapWaveToExeUnit(), NRDY_BARRIER_WAIT, NRDY_IB_EMPTY, NRDY_SGPR_NRDY, NRDY_SLEEP, NRDY_VGPR_NRDY, NRDY_WAIT_CNT, NRDY_WF_STOP, panic, ComputeUnit::releaseWFsFromBarrier(), ComputeUnit::resetBarrier(), Wavefront::S_BARRIER, Wavefront::S_RETURNING, Wavefront::S_STALLED, Wavefront::S_STALLED_SLEEP, Wavefront::S_STOPPED, Wavefront::S_WAITCNT, ComputeUnit::srf, ComputeUnit::vrf, and MipsISA::w.

Referenced by exec().

Member Data Documentation

◆ _name

const std::string ScoreboardCheckStage::_name
private

Definition at line 98 of file scoreboard_check_stage.hh.

Referenced by name().

◆ computeUnit

ComputeUnit& ScoreboardCheckStage::computeUnit
private

Definition at line 89 of file scoreboard_check_stage.hh.

Referenced by exec(), mapWaveToExeUnit(), and ready().

◆ stats

ScoreboardCheckStage::ScoreboardCheckStageStats ScoreboardCheckStage::stats
protected

Referenced by collectStatistics().

◆ toSchedule

ScoreboardCheckToSchedule& ScoreboardCheckStage::toSchedule
private

Interface between scoreboard check and schedule stages.

Each cycle the scoreboard check stage populates this interface with information needed by the schedule stage.

Definition at line 96 of file scoreboard_check_stage.hh.

Referenced by exec().


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