[llvm] r293728 - Fix regalloc assignment of overlapping registers
Stanislav Mekhanoshin via llvm-commits
llvm-commits at lists.llvm.org
Tue Jan 31 17:18:36 PST 2017
Author: rampitec
Date: Tue Jan 31 19:18:36 2017
New Revision: 293728
URL: http://llvm.org/viewvc/llvm-project?rev=293728&view=rev
Log:
Fix regalloc assignment of overlapping registers
SplitEditor::defFromParent() can create a register copy.
If register is a tuple of other registers and not all lanes are used
a copy will be done on a full tuple regardless. Later register unit
for an unused lane will be considered free and another overlapping
register tuple can be assigned to a different value even though first
register is live at that point. That is because interference only look at
liveness info, while full register copy clobbers all lanes, even unused.
This patch fixes copy to only cover used lanes.
Differential Revision: https://reviews.llvm.org/D29105
Modified:
llvm/trunk/lib/CodeGen/SplitKit.cpp
Modified: llvm/trunk/lib/CodeGen/SplitKit.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/SplitKit.cpp?rev=293728&r1=293727&r2=293728&view=diff
==============================================================================
--- llvm/trunk/lib/CodeGen/SplitKit.cpp (original)
+++ llvm/trunk/lib/CodeGen/SplitKit.cpp Tue Jan 31 19:18:36 2017
@@ -522,6 +522,27 @@ VNInfo *SplitEditor::defFromParent(unsig
Def = LIS.getSlotIndexes()
->insertMachineInstrInMaps(*CopyMI, Late)
.getRegSlot();
+ if (LI->hasSubRanges()) {
+ LaneBitmask LM = LaneBitmask::getNone();
+ for (LiveInterval::SubRange &S : LI->subranges())
+ LM |= S.LaneMask;
+
+ if (MRI.getMaxLaneMaskForVReg(LI->reg) != LM) {
+ // Find subreg for the lane mask.
+ unsigned SubIdx = 0;
+ for (unsigned I = 1, E = TRI.getNumSubRegIndices(); I < E; ++I) {
+ if (TRI.getSubRegIndexLaneMask(I) == LM) {
+ SubIdx = I;
+ break;
+ }
+ }
+ if (SubIdx == 0)
+ report_fatal_error("Cannot find subreg index to cover all alive lanes");
+ CopyMI->getOperand(0).setSubReg(SubIdx);
+ CopyMI->getOperand(1).setSubReg(SubIdx);
+ CopyMI->getOperand(0).setIsUndef(true);
+ }
+ }
++NumCopies;
}
More information about the llvm-commits
mailing list