diff options
| author | Quentin Colombet <qcolombet@apple.com> | 2016-04-12 00:30:14 +0000 |
|---|---|---|
| committer | Quentin Colombet <qcolombet@apple.com> | 2016-04-12 00:30:14 +0000 |
| commit | 5aacb1da008d17056e455fc9267da58b88dd9770 (patch) | |
| tree | dc3e6299d3482afe921957f03b393d1aacb2c892 /llvm/lib/CodeGen | |
| parent | 99d19d89e92a361580f9b16bd41c967f99b0dc85 (diff) | |
| download | bcm5719-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.cpp | 7 |
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; |

