aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/Transforms/InstCombine/and-sub-combine.ll
blob: 8b2f91b50beef594e4acb3a2a76f17500b65f1f1 (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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt < %s -passes=instcombine -S | FileCheck %s

define i8 @and_sub(i8 %a) {
; CHECK-LABEL: @and_sub(
; CHECK-NEXT:    [[RET:%.*]] = and i8 [[A:%.*]], 12
; CHECK-NEXT:    ret i8 [[RET]]
;
  %and1 = and i8 %a, 15
  %and2 = and i8 %a, 3

  %ret = sub i8 %and1, %and2
  ret i8 %ret
}

declare void @use(i8)
define i8 @and_sub_multi_use(i8 %a) {
; CHECK-LABEL: @and_sub_multi_use(
; CHECK-NEXT:    [[AND1:%.*]] = and i8 [[A:%.*]], 15
; CHECK-NEXT:    call void @use(i8 [[AND1]])
; CHECK-NEXT:    [[AND2:%.*]] = and i8 [[A]], 3
; CHECK-NEXT:    call void @use(i8 [[AND2]])
; CHECK-NEXT:    [[RET:%.*]] = and i8 [[A]], 12
; CHECK-NEXT:    ret i8 [[RET]]
;
  %and1 = and i8 %a, 15
  call void @use(i8 %and1)
  %and2 = and i8 %a, 3
  call void @use(i8 %and2)
  %ret = sub i8 %and1, %and2
  ret i8 %ret
}

define <2 x i32> @and_sub_vec(<2 x i32> %a) {
; CHECK-LABEL: @and_sub_vec(
; CHECK-NEXT:    [[RET:%.*]] = and <2 x i32> [[A:%.*]], <i32 3, i32 8>
; CHECK-NEXT:    ret <2 x i32> [[RET]]
;
  %and1 = and <2 x i32> %a, <i32 11, i32 10>
  %and2 = and <2 x i32> %a, <i32 8, i32 2>

  %ret = sub <2 x i32> %and1, %and2
  ret <2 x i32> %ret
}

define <2 x i32> @and_sub_vec_posion(<2 x i32> %a) {
; CHECK-LABEL: @and_sub_vec_posion(
; CHECK-NEXT:    ret <2 x i32> poison
;
  %and1 = and <2 x i32> %a, <i32 11, i32 poison>
  %and2 = and <2 x i32> %a, <i32 poison, i32 2>

  %ret = sub <2 x i32> %and1, %and2
  ret <2 x i32> %ret
}

define <2 x i32> @and_sub_vec_undef(<2 x i32> %a) {
; CHECK-LABEL: @and_sub_vec_undef(
; CHECK-NEXT:    [[AND1:%.*]] = and <2 x i32> [[A:%.*]], <i32 11, i32 undef>
; CHECK-NEXT:    [[AND2:%.*]] = and <2 x i32> [[A]], <i32 undef, i32 2>
; CHECK-NEXT:    [[RET:%.*]] = sub <2 x i32> [[AND1]], [[AND2]]
; CHECK-NEXT:    ret <2 x i32> [[RET]]
;
  %and1 = and <2 x i32> %a, <i32 11, i32 undef>
  %and2 = and <2 x i32> %a, <i32 undef, i32 2>

  %ret = sub <2 x i32> %and1, %and2
  ret <2 x i32> %ret
}

define i8 @and_sub_negtive(i8 %a) {
; CHECK-LABEL: @and_sub_negtive(
; CHECK-NEXT:    [[AND1:%.*]] = and i8 [[A:%.*]], 10
; CHECK-NEXT:    [[AND2:%.*]] = and i8 [[A]], 9
; CHECK-NEXT:    [[RET:%.*]] = sub nsw i8 [[AND1]], [[AND2]]
; CHECK-NEXT:    ret i8 [[RET]]
;
  %and1 = and i8 %a, 10
  %and2 = and i8 %a, 9

  %ret = sub i8 %and1, %and2
  ret i8 %ret
}