Go to the documentation of this file.
46 #include "arch/vecregs.hh"
49 #include "debug/Rename.hh"
82 renamed_reg = prev_reg;
89 renamed_reg = prev_reg;
99 DPRINTF(
Rename,
"Renamed reg %d to physical reg %d (%d) old mapping was"
int getNumPinnedWrites() const
Free list for a single class of registers (e.g., integer or floating point).
int getNumPinnedWrites() const
SimpleFreeList * freeList
Pointer to the free list from which new physical registers should be allocated in rename()
FreeList class that simply holds the list of free integer and floating point registers.
void decrNumPinnedWrites()
const RegIndex & flatIndex() const
Flat index accessor.
Simple physical register file class.
constexpr bool is(RegClassType reg_class) const
RenameInfo rename(const RegId &arch_reg)
Tell rename map to get a new free physical register to remap the specified architectural register.
std::array< SimpleRenameMap, CCRegClass+1 > renameMaps
std::pair< PhysRegIdPtr, PhysRegIdPtr > RenameInfo
Pair of a physical register and a physical register.
PhysRegIdPtr getReg()
Get the next available register from the free list.
Rename handles both single threaded and SMT rename.
void init(const RegClass ®_class, SimpleFreeList *_freeList)
Because we have an array of rename maps (one per thread) in the CPU, it's awkward to initialize this ...
RegClassType
Enumerate the classes of registers.
std::array< SimpleFreeList, CCRegClass+1 > freeLists
bool canRename(DynInstPtr inst) const
Return whether there are enough registers to serve the request.
void setNumPinnedWrites(int numWrites)
void setNumPinnedWritesToComplete(int numWrites)
constexpr RegIndex index() const
Index accessors.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void init(const BaseISA::RegClasses ®Classes, PhysRegFile *_regFile, UnifiedFreeList *freeList)
Initializes rename map with given parameters.
constexpr bool is(RegClassType reg_class) const
Arch2PhysMap map
The acutal arch-to-phys register map.
PhysRegFile * regFile
The register file object is used only to get PhysRegIdPtr on MiscRegs, as they are stored in it.
Register ID: describe an architectural register with its class and index.
constexpr size_t numRegs() const
Generated on Wed Jul 13 2022 10:39:16 for gem5 by doxygen 1.8.17