diff options
author | Dimitry Andric <dim@FreeBSD.org> | 2021-08-22 19:00:43 +0000 |
---|---|---|
committer | Dimitry Andric <dim@FreeBSD.org> | 2021-11-13 20:39:49 +0000 |
commit | fe6060f10f634930ff71b7c50291ddc610da2475 (patch) | |
tree | 1483580c790bd4d27b6500a7542b5ee00534d3cc /contrib/llvm-project/llvm/include/llvm/CodeGen/LiveRangeEdit.h | |
parent | b61bce17f346d79cecfd8f195a64b10f77be43b1 (diff) | |
parent | 344a3780b2e33f6ca763666c380202b18aab72a3 (diff) | |
download | src-fe6060f10f634930ff71b7c50291ddc610da2475.tar.gz src-fe6060f10f634930ff71b7c50291ddc610da2475.zip |
Merge llvm-project main llvmorg-13-init-16847-g88e66fa60ae5
This updates llvm, clang, compiler-rt, libc++, libunwind, lld, lldb and
openmp to llvmorg-13-init-16847-g88e66fa60ae5, the last commit before
the upstream release/13.x branch was created.
PR: 258209
MFC after: 2 weeks
Diffstat (limited to 'contrib/llvm-project/llvm/include/llvm/CodeGen/LiveRangeEdit.h')
-rw-r--r-- | contrib/llvm-project/llvm/include/llvm/CodeGen/LiveRangeEdit.h | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/contrib/llvm-project/llvm/include/llvm/CodeGen/LiveRangeEdit.h b/contrib/llvm-project/llvm/include/llvm/CodeGen/LiveRangeEdit.h index 87d48adc7f27..fa4e80179eec 100644 --- a/contrib/llvm-project/llvm/include/llvm/CodeGen/LiveRangeEdit.h +++ b/contrib/llvm-project/llvm/include/llvm/CodeGen/LiveRangeEdit.h @@ -41,6 +41,7 @@ class MachineOperand; class TargetInstrInfo; class TargetRegisterInfo; class VirtRegMap; +class VirtRegAuxInfo; class LiveRangeEdit : private MachineRegisterInfo::Delegate { public: @@ -96,11 +97,6 @@ private: /// scanRemattable - Identify the Parent values that may rematerialize. void scanRemattable(AAResults *aa); - /// allUsesAvailableAt - Return true if all registers used by OrigMI at - /// OrigIdx are also available with the same value at UseIdx. - bool allUsesAvailableAt(const MachineInstr *OrigMI, SlotIndex OrigIdx, - SlotIndex UseIdx) const; - /// foldAsLoad - If LI has a single use and a single def that can be folded as /// a load, eliminate the register by folding the def into the use. bool foldAsLoad(LiveInterval *LI, SmallVectorImpl<MachineInstr *> &Dead); @@ -206,6 +202,11 @@ public: explicit Remat(VNInfo *ParentVNI) : ParentVNI(ParentVNI) {} }; + /// allUsesAvailableAt - Return true if all registers used by OrigMI at + /// OrigIdx are also available with the same value at UseIdx. + bool allUsesAvailableAt(const MachineInstr *OrigMI, SlotIndex OrigIdx, + SlotIndex UseIdx) const; + /// canRematerializeAt - Determine if ParentVNI can be rematerialized at /// UseIdx. It is assumed that parent_.getVNINfoAt(UseIdx) == ParentVNI. /// When cheapAsAMove is set, only cheap remats are allowed. @@ -248,8 +249,7 @@ public: /// calculateRegClassAndHint - Recompute register class and hint for each new /// register. - void calculateRegClassAndHint(MachineFunction &, const MachineLoopInfo &, - const MachineBlockFrequencyInfo &); + void calculateRegClassAndHint(MachineFunction &, VirtRegAuxInfo &); }; } // end namespace llvm |