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

#include <schedule_stage.hh>

Classes

struct  ScheduleStageStats
 

Public Types

enum  SchNonRdyType {
  SCH_SCALAR_ALU_NRDY, SCH_VECTOR_ALU_NRDY, SCH_VECTOR_MEM_ISSUE_NRDY, SCH_VECTOR_MEM_BUS_BUSY_NRDY,
  SCH_VECTOR_MEM_COALESCER_NRDY, SCH_VECTOR_MEM_REQS_NRDY, SCH_CEDE_SIMD_NRDY, SCH_SCALAR_MEM_ISSUE_NRDY,
  SCH_SCALAR_MEM_BUS_BUSY_NRDY, SCH_SCALAR_MEM_FIFO_NRDY, SCH_LOCAL_MEM_ISSUE_NRDY, SCH_LOCAL_MEM_BUS_BUSY_NRDY,
  SCH_LOCAL_MEM_FIFO_NRDY, SCH_FLAT_MEM_ISSUE_NRDY, SCH_FLAT_MEM_BUS_BUSY_NRDY, SCH_FLAT_MEM_COALESCER_NRDY,
  SCH_FLAT_MEM_REQS_NRDY, SCH_FLAT_MEM_FIFO_NRDY, SCH_RDY, SCH_NRDY_CONDITIONS
}
 
enum  schopdnonrdytype_e { SCH_VRF_OPD_NRDY, SCH_SRF_OPD_NRDY, SCH_RF_OPD_NRDY, SCH_RF_OPD_NRDY_CONDITIONS }
 
enum  schrfaccessnonrdytype_e {
  SCH_VRF_RD_ACCESS_NRDY, SCH_VRF_WR_ACCESS_NRDY, SCH_SRF_RD_ACCESS_NRDY, SCH_SRF_WR_ACCESS_NRDY,
  SCH_RF_ACCESS_NRDY, SCH_RF_ACCESS_NRDY_CONDITIONS
}
 
enum  SCH_STATUS { RFBUSY = 0, RFREADY }
 

Public Member Functions

 ScheduleStage (const ComputeUnitParams &p, ComputeUnit &cu, ScoreboardCheckToSchedule &from_scoreboard_check, ScheduleToExecute &to_execute)
 
 ~ScheduleStage ()
 
void init ()
 
void exec ()
 
const std::string & name () const
 
void deleteFromSch (Wavefront *w)
 

Protected Attributes

ScheduleStage::ScheduleStageStats stats
 

Private Member Functions

bool addToSchList (int exeType, const GPUDynInstPtr &gpu_dyn_inst)
 
void reinsertToSchList (int exeType, const GPUDynInstPtr &gpu_dyn_inst)
 
void checkRfOperandReadComplete ()
 
void checkMemResources ()
 
bool dispatchReady (const GPUDynInstPtr &gpu_dyn_inst)
 
void fillDispatchList ()
 
void arbitrateVrfToLdsBus ()
 
void scheduleRfDestOperands ()
 
bool schedRfWrites (int exeType, const GPUDynInstPtr &gpu_dyn_inst)
 
void reserveResources ()
 
void doDispatchListTransition (int unitId, DISPATCH_STATUS s, const GPUDynInstPtr &gpu_dyn_inst)
 
void doDispatchListTransition (int unitId, DISPATCH_STATUS s)
 

Private Attributes

ComputeUnitcomputeUnit
 
ScoreboardCheckToSchedulefromScoreboardCheck
 
ScheduleToExecutetoExecute
 
std::vector< Schedulerscheduler
 
const std::string _name
 
bool vectorAluRdy
 
bool scalarAluRdy
 
bool scalarMemBusRdy
 
bool scalarMemIssueRdy
 
bool glbMemBusRdy
 
bool glbMemIssueRdy
 
bool locMemBusRdy
 
bool locMemIssueRdy
 
std::unordered_set< uint64_t > wavesInSch
 
std::vector< std::deque< std::pair< GPUDynInstPtr, SCH_STATUS > > > schList
 

Detailed Description

Definition at line 61 of file schedule_stage.hh.

Member Enumeration Documentation

◆ SCH_STATUS

Enumerator
RFBUSY 
RFREADY 

Definition at line 114 of file schedule_stage.hh.

◆ SchNonRdyType

Enumerator
SCH_SCALAR_ALU_NRDY 
SCH_VECTOR_ALU_NRDY 
SCH_VECTOR_MEM_ISSUE_NRDY 
SCH_VECTOR_MEM_BUS_BUSY_NRDY 
SCH_VECTOR_MEM_COALESCER_NRDY 
SCH_VECTOR_MEM_REQS_NRDY 
SCH_CEDE_SIMD_NRDY 
SCH_SCALAR_MEM_ISSUE_NRDY 
SCH_SCALAR_MEM_BUS_BUSY_NRDY 
SCH_SCALAR_MEM_FIFO_NRDY 
SCH_LOCAL_MEM_ISSUE_NRDY 
SCH_LOCAL_MEM_BUS_BUSY_NRDY 
SCH_LOCAL_MEM_FIFO_NRDY 
SCH_FLAT_MEM_ISSUE_NRDY 
SCH_FLAT_MEM_BUS_BUSY_NRDY 
SCH_FLAT_MEM_COALESCER_NRDY 
SCH_FLAT_MEM_REQS_NRDY 
SCH_FLAT_MEM_FIFO_NRDY 
SCH_RDY 
SCH_NRDY_CONDITIONS 

Definition at line 73 of file schedule_stage.hh.

◆ schopdnonrdytype_e

Enumerator
SCH_VRF_OPD_NRDY 
SCH_SRF_OPD_NRDY 
SCH_RF_OPD_NRDY 
SCH_RF_OPD_NRDY_CONDITIONS 

Definition at line 95 of file schedule_stage.hh.

◆ schrfaccessnonrdytype_e

Enumerator
SCH_VRF_RD_ACCESS_NRDY 
SCH_VRF_WR_ACCESS_NRDY 
SCH_SRF_RD_ACCESS_NRDY 
SCH_SRF_WR_ACCESS_NRDY 
SCH_RF_ACCESS_NRDY 
SCH_RF_ACCESS_NRDY_CONDITIONS 

Definition at line 101 of file schedule_stage.hh.

Constructor & Destructor Documentation

◆ ScheduleStage()

ScheduleStage::ScheduleStage ( const ComputeUnitParams &  p,
ComputeUnit cu,
ScoreboardCheckToSchedule from_scoreboard_check,
ScheduleToExecute to_execute 
)

◆ ~ScheduleStage()

ScheduleStage::~ScheduleStage ( )

Definition at line 66 of file schedule_stage.cc.

References scheduler, schList, and wavesInSch.

Member Function Documentation

◆ addToSchList()

bool ScheduleStage::addToSchList ( int  exeType,
const GPUDynInstPtr gpu_dyn_inst 
)
private

◆ arbitrateVrfToLdsBus()

void ScheduleStage::arbitrateVrfToLdsBus ( )
private

◆ checkMemResources()

void ScheduleStage::checkMemResources ( )
private

◆ checkRfOperandReadComplete()

void ScheduleStage::checkRfOperandReadComplete ( )
private

◆ deleteFromSch()

void ScheduleStage::deleteFromSch ( Wavefront w)

Definition at line 781 of file schedule_stage.cc.

References MipsISA::w, and wavesInSch.

◆ dispatchReady()

bool ScheduleStage::dispatchReady ( const GPUDynInstPtr gpu_dyn_inst)
private

◆ doDispatchListTransition() [1/2]

void ScheduleStage::doDispatchListTransition ( int  unitId,
DISPATCH_STATUS  s 
)
private

Definition at line 218 of file schedule_stage.cc.

References ScheduleToExecute::dispatchTransition(), ArmISA::s, and toExecute.

◆ doDispatchListTransition() [2/2]

void ScheduleStage::doDispatchListTransition ( int  unitId,
DISPATCH_STATUS  s,
const GPUDynInstPtr gpu_dyn_inst 
)
private

◆ exec()

void ScheduleStage::exec ( )

◆ fillDispatchList()

void ScheduleStage::fillDispatchList ( )
private

◆ init()

void ScheduleStage::init ( )

◆ name()

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

Definition at line 72 of file schedule_stage.hh.

References _name.

◆ reinsertToSchList()

void ScheduleStage::reinsertToSchList ( int  exeType,
const GPUDynInstPtr gpu_dyn_inst 
)
private

Definition at line 360 of file schedule_stage.cc.

References RFREADY, and schList.

Referenced by arbitrateVrfToLdsBus(), and scheduleRfDestOperands().

◆ reserveResources()

void ScheduleStage::reserveResources ( )
private

◆ schedRfWrites()

bool ScheduleStage::schedRfWrites ( int  exeType,
const GPUDynInstPtr gpu_dyn_inst 
)
private

◆ scheduleRfDestOperands()

void ScheduleStage::scheduleRfDestOperands ( )
private

Member Data Documentation

◆ _name

const std::string ScheduleStage::_name
private

Definition at line 129 of file schedule_stage.hh.

Referenced by name().

◆ computeUnit

ComputeUnit& ScheduleStage::computeUnit
private

◆ fromScoreboardCheck

ScoreboardCheckToSchedule& ScheduleStage::fromScoreboardCheck
private

Definition at line 122 of file schedule_stage.hh.

Referenced by exec(), and init().

◆ glbMemBusRdy

bool ScheduleStage::glbMemBusRdy
private

Definition at line 143 of file schedule_stage.hh.

Referenced by checkMemResources(), and dispatchReady().

◆ glbMemIssueRdy

bool ScheduleStage::glbMemIssueRdy
private

Definition at line 144 of file schedule_stage.hh.

Referenced by checkMemResources(), and dispatchReady().

◆ locMemBusRdy

bool ScheduleStage::locMemBusRdy
private

Definition at line 145 of file schedule_stage.hh.

Referenced by checkMemResources(), and dispatchReady().

◆ locMemIssueRdy

bool ScheduleStage::locMemIssueRdy
private

Definition at line 146 of file schedule_stage.hh.

Referenced by checkMemResources(), and dispatchReady().

◆ scalarAluRdy

bool ScheduleStage::scalarAluRdy
private

Definition at line 140 of file schedule_stage.hh.

Referenced by dispatchReady().

◆ scalarMemBusRdy

bool ScheduleStage::scalarMemBusRdy
private

Definition at line 141 of file schedule_stage.hh.

Referenced by checkMemResources(), and dispatchReady().

◆ scalarMemIssueRdy

bool ScheduleStage::scalarMemIssueRdy
private

Definition at line 142 of file schedule_stage.hh.

Referenced by checkMemResources(), and dispatchReady().

◆ scheduler

std::vector<Scheduler> ScheduleStage::scheduler
private

Definition at line 127 of file schedule_stage.hh.

Referenced by exec(), init(), ScheduleStage(), and ~ScheduleStage().

◆ schList

std::vector<std::deque<std::pair<GPUDynInstPtr, SCH_STATUS> > > ScheduleStage::schList
private

◆ stats

ScheduleStage::ScheduleStageStats ScheduleStage::stats
protected

◆ toExecute

ScheduleToExecute& ScheduleStage::toExecute
private

◆ vectorAluRdy

bool ScheduleStage::vectorAluRdy
private

Definition at line 139 of file schedule_stage.hh.

Referenced by dispatchReady().

◆ wavesInSch

std::unordered_set<uint64_t> ScheduleStage::wavesInSch
private

Definition at line 170 of file schedule_stage.hh.

Referenced by addToSchList(), deleteFromSch(), exec(), ScheduleStage(), and ~ScheduleStage().


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