12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- //===------------ MIRVRegNamerUtils.h - MIR VReg Renaming Utilities -------===//
- //
- // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
- // See https://llvm.org/LICENSE.txt for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- //
- //===----------------------------------------------------------------------===//
- //
- // The purpose of these utilities is to abstract out parts of the MIRCanon pass
- // that are responsible for renaming virtual registers with the purpose of
- // sharing code with a MIRVRegNamer pass that could be the analog of the
- // opt -instnamer pass.
- //
- //===----------------------------------------------------------------------===//
- #ifndef LLVM_LIB_CODEGEN_MIRVREGNAMERUTILS_H
- #define LLVM_LIB_CODEGEN_MIRVREGNAMERUTILS_H
- #include "llvm/CodeGen/Register.h"
- #include <map>
- #include <vector>
- #include <string>
- namespace llvm {
- class MachineBasicBlock;
- class MachineInstr;
- class MachineRegisterInfo;
- class StringRef;
- /// VRegRenamer - This class is used for renaming vregs in a machine basic
- /// block according to semantics of the instruction.
- class VRegRenamer {
- class NamedVReg {
- Register Reg;
- std::string Name;
- public:
- NamedVReg(Register Reg, std::string Name = "") : Reg(Reg), Name(Name) {}
- NamedVReg(std::string Name = "") : Reg(~0U), Name(Name) {}
- const std::string &getName() const { return Name; }
- Register getReg() const { return Reg; }
- };
- MachineRegisterInfo &MRI;
- unsigned CurrentBBNumber = 0;
- /// Given an Instruction, construct a hash of the operands
- /// of the instructions along with the opcode.
- /// When dealing with virtual registers, just hash the opcode of
- /// the instruction defining that vreg.
- /// Handle immediates, registers (physical and virtual) explicitly,
- /// and return a common value for the other cases.
- /// Instruction will be named in the following scheme
- /// bb<block_no>_hash_<collission_count>.
- std::string getInstructionOpcodeHash(MachineInstr &MI);
- /// For all the VRegs that are candidates for renaming,
- /// return a mapping from old vregs to new vregs with names.
- std::map<unsigned, unsigned>
- getVRegRenameMap(const std::vector<NamedVReg> &VRegs);
- /// Perform replacing of registers based on the <old,new> vreg map.
- bool doVRegRenaming(const std::map<unsigned, unsigned> &VRegRenameMap);
- /// createVirtualRegister - Given an existing vreg, create a named vreg to
- /// take its place. The name is determined by calling
- /// getInstructionOpcodeHash.
- unsigned createVirtualRegister(unsigned VReg);
- /// Create a vreg with name and return it.
- unsigned createVirtualRegisterWithLowerName(unsigned VReg, StringRef Name);
- /// Linearly traverse the MachineBasicBlock and rename each instruction's
- /// vreg definition based on the semantics of the instruction.
- /// Names are as follows bb<BBNum>_hash_[0-9]+
- bool renameInstsInMBB(MachineBasicBlock *MBB);
- public:
- VRegRenamer() = delete;
- VRegRenamer(MachineRegisterInfo &MRI) : MRI(MRI) {}
- /// Same as the above, but sets a BBNum depending on BB traversal that
- /// will be used as prefix for the vreg names.
- bool renameVRegs(MachineBasicBlock *MBB, unsigned BBNum) {
- CurrentBBNumber = BBNum;
- return renameInstsInMBB(MBB);
- }
- };
- } // namespace llvm
- #endif
|