1*9880d681SAndroid Build Coastguard Worker; This test makes sure that the xor instructions are properly eliminated 2*9880d681SAndroid Build Coastguard Worker; when arbitrary precision integers are used. 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -instcombine -S | not grep xor 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Workerdefine i33 @test1(i33 %A) { 7*9880d681SAndroid Build Coastguard Worker %B = xor i33 %A, -1 8*9880d681SAndroid Build Coastguard Worker %C = xor i33 %B, -1 9*9880d681SAndroid Build Coastguard Worker ret i33 %C 10*9880d681SAndroid Build Coastguard Worker} 11*9880d681SAndroid Build Coastguard Worker 12*9880d681SAndroid Build Coastguard Workerdefine i1 @test2(i52 %A, i52 %B) { 13*9880d681SAndroid Build Coastguard Worker %cond = icmp ule i52 %A, %B ; Can change into uge 14*9880d681SAndroid Build Coastguard Worker %Ret = xor i1 %cond, true 15*9880d681SAndroid Build Coastguard Worker ret i1 %Ret 16*9880d681SAndroid Build Coastguard Worker} 17*9880d681SAndroid Build Coastguard Worker 18*9880d681SAndroid Build Coastguard Worker; Test that demorgans law can be instcombined 19*9880d681SAndroid Build Coastguard Workerdefine i47 @test3(i47 %A, i47 %B) { 20*9880d681SAndroid Build Coastguard Worker %a = xor i47 %A, -1 21*9880d681SAndroid Build Coastguard Worker %b = xor i47 %B, -1 22*9880d681SAndroid Build Coastguard Worker %c = and i47 %a, %b 23*9880d681SAndroid Build Coastguard Worker %d = xor i47 %c, -1 24*9880d681SAndroid Build Coastguard Worker ret i47 %d 25*9880d681SAndroid Build Coastguard Worker} 26*9880d681SAndroid Build Coastguard Worker 27*9880d681SAndroid Build Coastguard Worker; Test that demorgens law can work with constants 28*9880d681SAndroid Build Coastguard Workerdefine i61 @test4(i61 %A, i61 %B) { 29*9880d681SAndroid Build Coastguard Worker %a = xor i61 %A, -1 30*9880d681SAndroid Build Coastguard Worker %c = and i61 %a, 5 ; 5 = ~c2 31*9880d681SAndroid Build Coastguard Worker %d = xor i61 %c, -1 32*9880d681SAndroid Build Coastguard Worker ret i61 %d 33*9880d681SAndroid Build Coastguard Worker} 34*9880d681SAndroid Build Coastguard Worker 35*9880d681SAndroid Build Coastguard Worker; test the mirror of demorgans law... 36*9880d681SAndroid Build Coastguard Workerdefine i71 @test5(i71 %A, i71 %B) { 37*9880d681SAndroid Build Coastguard Worker %a = xor i71 %A, -1 38*9880d681SAndroid Build Coastguard Worker %b = xor i71 %B, -1 39*9880d681SAndroid Build Coastguard Worker %c = or i71 %a, %b 40*9880d681SAndroid Build Coastguard Worker %d = xor i71 %c, -1 41*9880d681SAndroid Build Coastguard Worker ret i71 %d 42*9880d681SAndroid Build Coastguard Worker} 43