Go to the documentation of this file.
62 int retval = funcUnitsIdx[idx++];
111 for (;
j != end; ++
j) {
117 for (
int k = 0;
k < (*i)->number; ++
k)
121 fu->addCapability((*j)->opClass, (*j)->opLat, (*j)->pipelined);
126 if (!(*j)->pipelined)
133 fu->name = (*i)->name() +
"(0)";
136 for (
int c = 1;
c < (*i)->number; ++
c) {
137 std::ostringstream
s;
141 s << (*i)->name() <<
"(" <<
c <<
")";
164 int start_idx = fu_idx;
170 if (fu_idx == start_idx) {
176 assert(fu_idx <
numFU);
206 std::cout <<
"Function Unit Pool (" <<
name() <<
")\n";
207 std::cout <<
"======================================\n";
208 std::cout <<
"Free List:\n";
215 std::cout <<
" [" <<
i <<
"] : ";
222 std::cout <<
"======================================\n";
223 std::cout <<
"Busy List:\n";
229 std::cout <<
" [" <<
i <<
"] : ";
240 bool is_drained =
true;
std::vector< int > funcUnitsIdx
Queue of FU indices.
std::array< Cycles, Num_OpClasses > maxOpLatencies
Maximum op execution latencies, per op class.
std::bitset< Num_OpClasses > capabilityList
Bitvector listing capabilities of this FU pool.
void dump()
Debugging function used to dump FU information.
std::vector< FuncUnit * >::iterator fuListIterator
int getUnit(OpClass capability)
Gets a FU providing the requested capability.
std::vector< bool > unitBusy
Bitvector listing which FUs are busy.
FUPool(const Params &p)
Constructs a FU pool.
int size()
Returns the total number of FUs.
bool isDrained() const
Have all the FUs drained?
void addFU(int fu_idx)
Adds a FU to the queue.
virtual const std::string name() const
std::array< bool, Num_OpClasses > pipelined
Whether op is pipelined or not.
void processFreeUnits()
Frees all FUs on the list.
std::vector< FUDesc * >::const_iterator FUDDiterator
void freeUnitNextCycle(int fu_idx)
Frees a FU at the end of this cycle.
Cycles is a wrapper class for representing cycle counts, i.e.
int size
Size of the queue.
int getFU()
Returns the index of the FU at the head of the queue, and changes the index to the next element.
std::vector< FuncUnit * > funcUnits
Functional units.
std::vector< int > unitsToBeFreed
List of units to be freed at the end of this cycle.
std::vector< OpDesc * >::const_iterator OPDDiterator
FUIdxQueue fuPerCapList[Num_OpClasses]
Per op class queues of FUs that provide that capability.
Abstract superclass for simulation objects.
Generated on Tue Mar 23 2021 19:41:25 for gem5 by doxygen 1.8.17