aboutsummaryrefslogtreecommitdiff
path: root/lib/Transforms/LevelRaise.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2002-07-16 21:41:31 +0000
committerChris Lattner <sabre@nondot.org>2002-07-16 21:41:31 +0000
commit3fb2ddd368828fbb73ebef98c5b88dc30822dca9 (patch)
tree4bf6bd5ffa799f16353ff36246bc462e481efff2 /lib/Transforms/LevelRaise.cpp
parent4069c8400bcd8d7fde0057fe856879065ea7ac3e (diff)
Fix bug: test/Regression/Transforms/LevelRaise/2002-07-16-RaiseCrash2.ll
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2932 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/LevelRaise.cpp')
-rw-r--r--lib/Transforms/LevelRaise.cpp4
1 files changed, 3 insertions, 1 deletions
diff --git a/lib/Transforms/LevelRaise.cpp b/lib/Transforms/LevelRaise.cpp
index 54a2930fc0..1defda4d84 100644
--- a/lib/Transforms/LevelRaise.cpp
+++ b/lib/Transforms/LevelRaise.cpp
@@ -68,7 +68,9 @@ static bool HandleCastToPointer(BasicBlock::iterator BI,
for (Value::use_iterator I = CI.use_begin(), E = CI.use_end();
I != E; ++I) {
if (BinaryOperator *BO = dyn_cast<BinaryOperator>(*I)) {
- if (BO->getOpcode() != Instruction::Add)
+ if (BO->getOpcode() != Instruction::Add ||
+ // Avoid add sbyte* %X, %X cases...
+ BO->getOperand(0) == BO->getOperand(1))
return false;
} else {
return false;