Go to the documentation of this file.
41 #ifndef __CPU_O3_FU_POOL_HH__
42 #define __CPU_O3_FU_POOL_HH__
51 #include "params/FUPool.hh"
107 inline void addFU(
int fu_idx);
154 int getUnit(OpClass capability);
188 #endif // __CPU_O3_FU_POOL_HH__
std::bitset< Num_OpClasses > capabilityList
Bitvector listing capabilities of this FU pool.
FUPool(const Params &p)
Constructs a FU pool.
std::vector< FuncUnit * > funcUnits
Functional units.
static constexpr auto NoCapableFU
Cycles getOpLatency(OpClass capability)
Returns the operation execution latency of the given capability.
void takeOverFrom()
Takes over from another CPU's thread.
std::vector< int > unitsToBeFreed
List of units to be freed at the end of this cycle.
void dump()
Debugging function used to dump FU information.
Class that implements a circular queue to hold FU indices.
Cycles is a wrapper class for representing cycle counts, i.e.
void freeUnitNextCycle(int fu_idx)
Frees a FU at the end of this cycle.
std::vector< int > funcUnitsIdx
Queue of FU indices.
bool isDrained() const
Have all the FUs drained?
std::vector< bool > unitBusy
Bitvector listing which FUs are busy.
void processFreeUnits()
Frees all FUs on the list.
int size
Size of the queue.
Abstract superclass for simulation objects.
std::array< bool, Num_OpClasses > pipelined
Whether op is pipelined or not.
bool isPipelined(OpClass capability)
Returns the issue latency of the given capability.
FUIdxQueue()
Constructs a circular queue of FU indices.
int idx
Circular queue index.
int getFU()
Returns the index of the FU at the head of the queue, and changes the index to the next element.
int size()
Returns the total number of FUs.
void addFU(int fu_idx)
Adds a FU to the queue.
std::vector< FuncUnit * >::iterator fuListIterator
std::array< Cycles, Num_OpClasses > maxOpLatencies
Maximum op execution latencies, per op class.
static const OpClass Num_OpClasses
static constexpr auto NoFreeFU
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
FUIdxQueue fuPerCapList[Num_OpClasses]
Per op class queues of FUs that provide that capability.
Pool of FU's, specific to the new CPU model.
int getUnit(OpClass capability)
Gets a FU providing the requested capability.
Generated on Wed May 4 2022 12:13:53 for gem5 by doxygen 1.8.17