diff options
| author | Chris Lattner <sabre@nondot.org> | 2005-05-07 23:49:08 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2005-05-07 23:49:08 +0000 | 
| commit | 4294cec0f1575232c99efcd13a2ed87015744864 (patch) | |
| tree | a15a0f2c6805745301d9c8498e08763ae1c035eb /llvm/lib/Transforms | |
| parent | 041f8b59c19f083f5fe99b94b07ddc5ca7113b67 (diff) | |
| download | bcm5719-llvm-4294cec0f1575232c99efcd13a2ed87015744864.tar.gz bcm5719-llvm-4294cec0f1575232c99efcd13a2ed87015744864.zip | |
Fix a miscompilation of crafty by clobbering the "A" variable.
llvm-svn: 21770
Diffstat (limited to 'llvm/lib/Transforms')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/InstructionCombining.cpp | 19 | 
1 files changed, 10 insertions, 9 deletions
| diff --git a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp index 72b45319c0c..6cafc257771 100644 --- a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp @@ -1856,8 +1856,16 @@ Instruction *InstCombiner::visitOr(BinaryOperator &I) {          return NV;    } -  // (A & C1)|(A & C2) == A & (C1|C2)    Value *A, *B; ConstantInt *C1, *C2; + +  if (match(Op0, m_And(m_Value(A), m_Value(B)))) +    if (A == Op1 || B == Op1)    // (A & ?) | A  --> A +      return ReplaceInstUsesWith(I, Op1); +  if (match(Op1, m_And(m_Value(A), m_Value(B)))) +    if (A == Op0 || B == Op0)    // A | (A & ?)  --> A +      return ReplaceInstUsesWith(I, Op0); + +  // (A & C1)|(A & C2) == A & (C1|C2)    if (match(Op0, m_And(m_Value(A), m_ConstantInt(C1))) &&        match(Op1, m_And(m_Value(B), m_ConstantInt(C2))) && A == B)      return BinaryOperator::createAnd(A, ConstantExpr::getOr(C1, C2)); @@ -1869,14 +1877,7 @@ Instruction *InstCombiner::visitOr(BinaryOperator &I) {    } else {      A = 0;    } - -  if (match(Op0, m_And(m_Value(A), m_Value(B)))) -    if (A == Op1 || B == Op1)    // (A & ?) | A  --> A -      return ReplaceInstUsesWith(I, Op1); -  if (match(Op1, m_And(m_Value(A), m_Value(B)))) -    if (A == Op0 || B == Op0)    // A | (A & ?)  --> A -      return ReplaceInstUsesWith(I, Op0); - +  // Note, A is still live here!    if (match(Op1, m_Not(m_Value(B)))) {   // Op0 | ~B      if (Op0 == B)        return ReplaceInstUsesWith(I, | 

