summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/InstCombine/and-or-not.ll
blob: 144e42e74868840e70559e099770ca76f064c832 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
; RUN: opt < %s -instcombine -S | FileCheck %s

; PR1510

; These are all equivalent to A^B

define i32 @test1(i32 %a, i32 %b) {
        %tmp3 = or i32 %b, %a           ; <i32> [#uses=1]
        %tmp3not = xor i32 %tmp3, -1            ; <i32> [#uses=1]
        %tmp6 = and i32 %b, %a          ; <i32> [#uses=1]
        %tmp7 = or i32 %tmp6, %tmp3not          ; <i32> [#uses=1]
        %tmp7not = xor i32 %tmp7, -1            ; <i32> [#uses=1]
        ret i32 %tmp7not

; CHECK-LABEL: @test1(
; CHECK-NEXT:    [[TMP7NOT:%.*]] = xor i32 %b, %a
; CHECK-NEXT:    ret i32 [[TMP7NOT]]
}

define i32 @test2(i32 %a, i32 %b) {
        %tmp3 = or i32 %b, %a           ; <i32> [#uses=1]
        %tmp6 = and i32 %b, %a          ; <i32> [#uses=1]
        %tmp6not = xor i32 %tmp6, -1            ; <i32> [#uses=1]
        %tmp7 = and i32 %tmp3, %tmp6not         ; <i32> [#uses=1]
        ret i32 %tmp7

; CHECK-LABEL: @test2(
; CHECK-NEXT:    [[TMP7:%.*]] = xor i32 %b, %a
; CHECK-NEXT:    ret i32 [[TMP7]]
}

define <4 x i32> @test3(<4 x i32> %a, <4 x i32> %b) {
        %tmp3 = or <4 x i32> %a, %b             ; <<4 x i32>> [#uses=1]
        %tmp3not = xor <4 x i32> %tmp3, < i32 -1, i32 -1, i32 -1, i32 -1 >              ; <<4 x i32>> [#uses=1]
        %tmp6 = and <4 x i32> %a, %b            ; <<4 x i32>> [#uses=1]
        %tmp7 = or <4 x i32> %tmp6, %tmp3not            ; <<4 x i32>> [#uses=1]
        %tmp7not = xor <4 x i32> %tmp7, < i32 -1, i32 -1, i32 -1, i32 -1 >              ; <<4 x i32>> [#uses=1]
        ret <4 x i32> %tmp7not

; CHECK-LABEL: @test3(
; CHECK-NEXT:    [[TMP7NOT:%.*]] = xor <4 x i32> %a, %b
; CHECK-NEXT:    ret <4 x i32> [[TMP7NOT]]
}

define <4 x i32> @test4(<4 x i32> %a, <4 x i32> %b) {
        %tmp3 = or <4 x i32> %a, %b             ; <<4 x i32>> [#uses=1]
        %tmp6 = and <4 x i32> %a, %b            ; <<4 x i32>> [#uses=1]
        %tmp6not = xor <4 x i32> %tmp6, < i32 -1, i32 -1, i32 -1, i32 -1 >              ; <<4 x i32>> [#uses=1]
        %tmp7 = and <4 x i32> %tmp3, %tmp6not           ; <<4 x i32>> [#uses=1]
        ret <4 x i32> %tmp7

; CHECK-LABEL: @test4(
; CHECK-NEXT:    [[TMP7:%.*]] = xor <4 x i32> %a, %b
; CHECK-NEXT:    ret <4 x i32> [[TMP7]]
}

OpenPOWER on IntegriCloud