98 lines
3.3 KiB
C
98 lines
3.3 KiB
C
|
|
||
|
//===------------ 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
|