summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen
diff options
context:
space:
mode:
authorQuentin Colombet <qcolombet@apple.com>2016-04-12 00:30:14 +0000
committerQuentin Colombet <qcolombet@apple.com>2016-04-12 00:30:14 +0000
commit5aacb1da008d17056e455fc9267da58b88dd9770 (patch)
treedc3e6299d3482afe921957f03b393d1aacb2c892 /llvm/lib/CodeGen
parent99d19d89e92a361580f9b16bd41c967f99b0dc85 (diff)
downloadbcm5719-llvm-5aacb1da008d17056e455fc9267da58b88dd9770.tar.gz
bcm5719-llvm-5aacb1da008d17056e455fc9267da58b88dd9770.zip
[RegisterBankInfo] Do not provide a default mapping for non-reg of phi
operations. llvm-svn: 266027
Diffstat (limited to 'llvm/lib/CodeGen')
-rw-r--r--llvm/lib/CodeGen/GlobalISel/RegisterBankInfo.cpp7
1 files changed, 7 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/GlobalISel/RegisterBankInfo.cpp b/llvm/lib/CodeGen/GlobalISel/RegisterBankInfo.cpp
index e22401ad352..68173e955fd 100644
--- a/llvm/lib/CodeGen/GlobalISel/RegisterBankInfo.cpp
+++ b/llvm/lib/CodeGen/GlobalISel/RegisterBankInfo.cpp
@@ -309,10 +309,17 @@ RegisterBankInfo::getInstrMappingImpl(const MachineInstr &MI) const {
// Propagate RegBank to all operands that do not have a
// mapping yet.
for (unsigned OpIdx = 0, End = MI.getNumOperands(); OpIdx != End; ++OpIdx) {
+ const MachineOperand &MO = MI.getOperand(OpIdx);
+ // Don't assign a mapping for non-reg operands.
+ if (!MO.isReg())
+ continue;
+
+ // If a mapping already exists, do not touch it.
if (!static_cast<const InstructionMapping *>(&Mapping)
->getOperandMapping(OpIdx)
.BreakDown.empty())
continue;
+
Mapping.setOperandMapping(OpIdx, RegSize, *RegBank);
}
return Mapping;
OpenPOWER on IntegriCloud