1*9880d681SAndroid Build Coastguard Worker; This test makes sure that add instructions are properly eliminated. 2*9880d681SAndroid Build Coastguard Worker; This test is for Integer BitWidth <= 64 && BitWidth % 8 != 0. 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -instcombine -S | \ 5*9880d681SAndroid Build Coastguard Worker; RUN: grep -v OK | not grep add 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Worker 8*9880d681SAndroid Build Coastguard Workerdefine i1 @test1(i1 %x) { 9*9880d681SAndroid Build Coastguard Worker %tmp.2 = xor i1 %x, 1 10*9880d681SAndroid Build Coastguard Worker ;; Add of sign bit -> xor of sign bit. 11*9880d681SAndroid Build Coastguard Worker %tmp.4 = add i1 %tmp.2, 1 12*9880d681SAndroid Build Coastguard Worker ret i1 %tmp.4 13*9880d681SAndroid Build Coastguard Worker} 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Workerdefine i47 @test2(i47 %x) { 16*9880d681SAndroid Build Coastguard Worker %tmp.2 = xor i47 %x, 70368744177664 17*9880d681SAndroid Build Coastguard Worker ;; Add of sign bit -> xor of sign bit. 18*9880d681SAndroid Build Coastguard Worker %tmp.4 = add i47 %tmp.2, 70368744177664 19*9880d681SAndroid Build Coastguard Worker ret i47 %tmp.4 20*9880d681SAndroid Build Coastguard Worker} 21*9880d681SAndroid Build Coastguard Worker 22*9880d681SAndroid Build Coastguard Workerdefine i15 @test3(i15 %x) { 23*9880d681SAndroid Build Coastguard Worker %tmp.2 = xor i15 %x, 16384 24*9880d681SAndroid Build Coastguard Worker ;; Add of sign bit -> xor of sign bit. 25*9880d681SAndroid Build Coastguard Worker %tmp.4 = add i15 %tmp.2, 16384 26*9880d681SAndroid Build Coastguard Worker ret i15 %tmp.4 27*9880d681SAndroid Build Coastguard Worker} 28*9880d681SAndroid Build Coastguard Worker 29*9880d681SAndroid Build Coastguard Workerdefine i49 @test6(i49 %x) { 30*9880d681SAndroid Build Coastguard Worker ;; (x & 254)+1 -> (x & 254)|1 31*9880d681SAndroid Build Coastguard Worker %tmp.2 = and i49 %x, 562949953421310 32*9880d681SAndroid Build Coastguard Worker %tmp.4 = add i49 %tmp.2, 1 33*9880d681SAndroid Build Coastguard Worker ret i49 %tmp.4 34*9880d681SAndroid Build Coastguard Worker} 35