From: Jakob Stoklund Olesen Date: Wed, 9 Feb 2011 00:25:36 +0000 (+0000) Subject: Set an allocation hint when rematting before a COPY. X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=c3dca3f9d4a049102fa985aedbc65e53f4cf6c0d;p=oota-llvm.git Set an allocation hint when rematting before a COPY. This almost guarantees that the COPY will be coalesced. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@125140 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/InlineSpiller.cpp b/lib/CodeGen/InlineSpiller.cpp index 00ca3d5bb64..a1bd972d38e 100644 --- a/lib/CodeGen/InlineSpiller.cpp +++ b/lib/CodeGen/InlineSpiller.cpp @@ -154,6 +154,10 @@ bool InlineSpiller::reMaterializeFor(MachineBasicBlock::iterator MI) { LiveInterval &NewLI = edit_->create(mri_, lis_, vrm_); NewLI.markNotSpillable(); + // Rematting for a copy: Set allocation hint to be the destination register. + if (MI->isCopy()) + mri_.setRegAllocationHint(NewLI.reg, 0, MI->getOperand(0).getReg()); + // Finally we can rematerialize OrigMI before MI. SlotIndex DefIdx = edit_->rematerializeAt(*MI->getParent(), MI, NewLI.reg, RM, lis_, tii_, tri_);