summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/LivePhysRegs.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/lib/CodeGen/LivePhysRegs.cpp')
-rw-r--r--llvm/lib/CodeGen/LivePhysRegs.cpp8
1 files changed, 5 insertions, 3 deletions
diff --git a/llvm/lib/CodeGen/LivePhysRegs.cpp b/llvm/lib/CodeGen/LivePhysRegs.cpp
index 9b5d7843463..a456cdec42d 100644
--- a/llvm/lib/CodeGen/LivePhysRegs.cpp
+++ b/llvm/lib/CodeGen/LivePhysRegs.cpp
@@ -144,13 +144,15 @@ bool LivePhysRegs::available(const MachineRegisterInfo &MRI,
void LivePhysRegs::addBlockLiveIns(const MachineBasicBlock &MBB) {
for (const auto &LI : MBB.liveins()) {
MCSubRegIndexIterator S(LI.PhysReg, TRI);
- if (LI.LaneMask == ~0u || (LI.LaneMask != 0 && !S.isValid())) {
+ if (LI.LaneMask.all() || (!LI.LaneMask.none() && !S.isValid())) {
addReg(LI.PhysReg);
continue;
}
- for (; S.isValid(); ++S)
- if (LI.LaneMask & TRI->getSubRegIndexLaneMask(S.getSubRegIndex()))
+ for (; S.isValid(); ++S) {
+ unsigned SI = S.getSubRegIndex();
+ if (!(LI.LaneMask & TRI->getSubRegIndexLaneMask(SI)).none())
addReg(S.getSubReg());
+ }
}
}
OpenPOWER on IntegriCloud