Go to the documentation of this file.
42 #ifndef __CPU_O3_FREE_LIST_HH__
43 #define __CPU_O3_FREE_LIST_HH__
54 #include "debug/FreeList.hh"
62 class UnifiedRenameMap;
86 template<
class InputIt>
89 std::for_each(first, last, [
this](
typename InputIt::value_type&
reg) {
165 template<
class InputIt>
169 std::for_each(first, last, [
this](
auto &
reg) {
addReg(&
reg); });
197 #endif // __CPU_O3_FREE_LIST_HH__
std::queue< PhysRegIdPtr > freeRegs
The actual free list.
std::string name() const
Gives the name of the freelist.
Free list for a single class of registers (e.g., integer or floating point).
UnifiedFreeList(const std::string &_my_name, PhysRegFile *_regFile)
Constructs a free list.
FreeList class that simply holds the list of free integer and floating point registers.
unsigned numFreeRegs() const
Return the number of free registers on the list.
bool hasFreeRegs(RegClassType type) const
Checks if there are any free registers of type type.
void addRegs(InputIt first, InputIt last)
Add physical registers to the free list.
PhysRegFile * regFile
The register file object is used only to distinguish integer from floating-point physical register in...
PhysRegIdPtr getReg(RegClassType type)
Gets a free register of type type.
Simple physical register file class.
void addRegs(InputIt first, InputIt last)
Adds a register back to the free list.
void addReg(PhysRegIdPtr reg)
Add a physical register to the free list.
PhysRegIdPtr getReg()
Get the next available register from the free list.
unsigned numFreeRegs(RegClassType type) const
Returns the number of free registers of type type.
RegClassType
Enumerate the classes of registers.
bool hasFreeRegs() const
True iff there are free registers on the list.
std::array< SimpleFreeList, CCRegClass+1 > freeLists
const std::string _name
The object name, for DPRINTF.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
constexpr RegClassType classValue() const
Class accessor.
void addReg(PhysRegIdPtr freed_reg)
Adds a register back to the free list.
Unified register rename map for all classes of registers.
Generated on Thu Jun 16 2022 10:41:47 for gem5 by doxygen 1.8.17