Fix similar missing optimization opportunity in XOR.
llvm-svn: 31123
This commit is contained in:
		
							parent
							
								
									bb3084546a
								
							
						
					
					
						commit
						6f5c30fcec
					
				| 
						 | 
					@ -349,19 +349,28 @@ namespace {
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        } break;
 | 
					        } break;
 | 
				
			||||||
        case Instruction::Xor: {
 | 
					        case Instruction::Xor: {
 | 
				
			||||||
          ConstantIntegral *CI = dyn_cast<ConstantIntegral>(V1);
 | 
					          if (ConstantIntegral *CI = dyn_cast<ConstantIntegral>(V1)) {
 | 
				
			||||||
	  if (!CI) break;
 | 
					            const Type *Ty = BO->getType();
 | 
				
			||||||
          if (CI->isAllOnesValue()) {
 | 
					            if (CI->isAllOnesValue()) {
 | 
				
			||||||
            if (BO->getOperand(0) == V1)
 | 
					              if (BO->getOperand(0) == V1)
 | 
				
			||||||
              add(Opcode, ConstantBool::getFalse(), BO->getOperand(1), false);
 | 
					                add(Opcode, Constant::getNullValue(Ty),
 | 
				
			||||||
            if (BO->getOperand(1) == V1)
 | 
					                    BO->getOperand(1), false);
 | 
				
			||||||
              add(Opcode, ConstantBool::getFalse(), BO->getOperand(0), false);
 | 
					              if (BO->getOperand(1) == V1)
 | 
				
			||||||
          }
 | 
					                add(Opcode, Constant::getNullValue(Ty),
 | 
				
			||||||
          if (CI->isNullValue()) {
 | 
					                    BO->getOperand(0), false);
 | 
				
			||||||
            if (BO->getOperand(0) == ConstantBool::getTrue())
 | 
					            }
 | 
				
			||||||
              add(Opcode, ConstantBool::getTrue(), BO->getOperand(1), false);
 | 
					            if (CI->isNullValue()) {
 | 
				
			||||||
            if (BO->getOperand(1) == ConstantBool::getTrue())
 | 
					              ConstantIntegral *Op0 =
 | 
				
			||||||
              add(Opcode, ConstantBool::getTrue(), BO->getOperand(0), false);
 | 
					                  dyn_cast<ConstantIntegral>(BO->getOperand(0));
 | 
				
			||||||
 | 
					              ConstantIntegral *Op1 =
 | 
				
			||||||
 | 
					                  dyn_cast<ConstantIntegral>(BO->getOperand(1));
 | 
				
			||||||
 | 
					              if (Op0 && Op0->isAllOnesValue())
 | 
				
			||||||
 | 
					                add(Opcode, ConstantIntegral::getAllOnesValue(Ty),
 | 
				
			||||||
 | 
					                    BO->getOperand(1), false);
 | 
				
			||||||
 | 
					              if (Op1 && Op1->isAllOnesValue())
 | 
				
			||||||
 | 
					                add(Opcode, ConstantIntegral::getAllOnesValue(Ty),
 | 
				
			||||||
 | 
					                    BO->getOperand(0), false);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        } break;
 | 
					        } break;
 | 
				
			||||||
        default:
 | 
					        default:
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in New Issue