Go to the documentation of this file.
68 int retval = funcUnitsIdx[idx++];
117 for (;
j != end; ++
j) {
123 for (
int k = 0;
k < (*i)->number; ++
k)
127 fu->addCapability((*j)->opClass, (*j)->opLat, (*j)->pipelined);
132 if (!(*j)->pipelined)
139 fu->name = (*i)->name() +
"(0)";
142 for (
int c = 1;
c < (*i)->number; ++
c) {
143 std::ostringstream
s;
147 s << (*i)->name() <<
"(" <<
c <<
")";
170 int start_idx = fu_idx;
176 if (fu_idx == start_idx) {
182 assert(fu_idx <
numFU);
212 std::cout <<
"Function Unit Pool (" <<
name() <<
")\n";
213 std::cout <<
"======================================\n";
214 std::cout <<
"Free List:\n";
221 std::cout <<
" [" <<
i <<
"] : ";
228 std::cout <<
"======================================\n";
229 std::cout <<
"Busy List:\n";
235 std::cout <<
" [" <<
i <<
"] : ";
246 bool is_drained =
true;
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.
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.
Cycles is a wrapper class for representing cycle counts, i.e.
std::vector< OpDesc * >::const_iterator OPDDiterator
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?
virtual std::string name() const
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::vector< FUDesc * >::const_iterator FUDDiterator
std::array< bool, Num_OpClasses > pipelined
Whether op is pipelined or not.
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.
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.
int getUnit(OpClass capability)
Gets a FU providing the requested capability.
Generated on Thu Jun 16 2022 10:41:47 for gem5 by doxygen 1.8.17