summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/LiveRegMatrix.cpp
diff options
context:
space:
mode:
authorJakob Stoklund Olesen <stoklund@2pi.dk>2012-06-15 22:24:22 +0000
committerJakob Stoklund Olesen <stoklund@2pi.dk>2012-06-15 22:24:22 +0000
commit13dffcb76658d9b5ce615f3e5d3f46722e1292df (patch)
tree5c682e17b98831926a6aa3b3f6b1b114efd766eb /llvm/lib/CodeGen/LiveRegMatrix.cpp
parentf14a6e5f13fedb97e6955151d3f4fb7a3c2bc0cc (diff)
downloadbcm5719-llvm-13dffcb76658d9b5ce615f3e5d3f46722e1292df.tar.gz
bcm5719-llvm-13dffcb76658d9b5ce615f3e5d3f46722e1292df.zip
Accept null PhysReg arguments to checkRegMaskInterference.
Calling checkRegMaskInterference(VirtReg) checks if VirtReg crosses any regmask operands, regardless of the registers they clobber. llvm-svn: 158563
Diffstat (limited to 'llvm/lib/CodeGen/LiveRegMatrix.cpp')
-rw-r--r--llvm/lib/CodeGen/LiveRegMatrix.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/LiveRegMatrix.cpp b/llvm/lib/CodeGen/LiveRegMatrix.cpp
index 61e1432b0e2..cdb17768129 100644
--- a/llvm/lib/CodeGen/LiveRegMatrix.cpp
+++ b/llvm/lib/CodeGen/LiveRegMatrix.cpp
@@ -110,7 +110,7 @@ bool LiveRegMatrix::checkRegMaskInterference(LiveInterval &VirtReg,
// The BitVector is indexed by PhysReg, not register unit.
// Regmask interference is more fine grained than regunits.
// For example, a Win64 call can clobber %ymm8 yet preserve %xmm8.
- return !RegMaskUsable.empty() && !RegMaskUsable.test(PhysReg);
+ return !RegMaskUsable.empty() && (!PhysReg || !RegMaskUsable.test(PhysReg));
}
bool LiveRegMatrix::checkRegUnitInterference(LiveInterval &VirtReg,
OpenPOWER on IntegriCloud