mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	reapply benjamin's instcombine patch, I don't see anything wrong with it and can't repro any problems with a manual self-host.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@108320 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -1597,6 +1597,14 @@ Instruction *InstCombiner::visitOr(BinaryOperator &I) { | ||||
|       Instruction *Ret = FoldOrWithConstants(I, Op0, A, V1, D); | ||||
|       if (Ret) return Ret; | ||||
|     } | ||||
|  | ||||
|     // (A & ~D) | (B & D) -> ((B ^ A) & D) ^ A | ||||
|     if (Op0->hasOneUse() && Op1->hasOneUse() && | ||||
|         match(C, m_Not(m_Specific(D)))) { | ||||
|       Value *Xor = Builder->CreateXor(B, A, "xor"); | ||||
|       Value *And = Builder->CreateAnd(Xor, D, "and"); | ||||
|       return BinaryOperator::CreateXor(And, A); | ||||
|     } | ||||
|   } | ||||
|    | ||||
|   // (X >> Z) | (Y >> Z)  -> (X|Y) >> Z  for all shifts. | ||||
|   | ||||
| @@ -350,3 +350,16 @@ define <4 x i32> @test32(<4 x i1> %and.i1352, <4 x i32> %vecinit6.i176, <4 x i32 | ||||
| ; CHECK: or <4 x i32> %and.i, %and.i129 | ||||
| } | ||||
|  | ||||
| ; PR6773 | ||||
| define i32 @test33(i32 %x, i32 %y, i32 %z) nounwind readnone { | ||||
|   %and = and i32 %y, %x | ||||
|   %not = xor i32 %x, -1 | ||||
|   %and2 = and i32 %z, %not | ||||
|   %or = or i32 %and2, %and | ||||
|   ret i32 %or | ||||
| ; CHECK: @test33 | ||||
| ; CHECK-NEXT: xor i32 | ||||
| ; CHECK-NEXT: and i32 | ||||
| ; CHECK-NEXT: xor i32 | ||||
| ; CHECK-NEXT: ret i32 | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user