[DAGCombiner] Add target hook function to decide folding (mul (add x, c1), c2)
[llvm-project.git] / llvm / test / Transforms / InstCombine / dont-distribute-phi.ll
blobf7cf72851940915f32674e63d6ac20afa4b68be1
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt < %s -instcombine -S | FileCheck %s
4 ; This test ensures that InstCombine does not distribute And over Xor
5 ; using simplifications involving undef.
7 define zeroext i1 @foo(i32 %arg) {
8 ; CHECK-LABEL: @foo(
9 ; CHECK-NEXT:  entry:
10 ; CHECK-NEXT:    [[CMP1:%.*]] = icmp eq i32 [[ARG:%.*]], 37
11 ; CHECK-NEXT:    br i1 [[CMP1]], label [[BB_THEN:%.*]], label [[BB_ELSE:%.*]]
12 ; CHECK:       bb_then:
13 ; CHECK-NEXT:    call void @bar()
14 ; CHECK-NEXT:    br label [[BB_EXIT:%.*]]
15 ; CHECK:       bb_else:
16 ; CHECK-NEXT:    [[CMP2:%.*]] = icmp slt i32 [[ARG]], 17
17 ; CHECK-NEXT:    br label [[BB_EXIT]]
18 ; CHECK:       bb_exit:
19 ; CHECK-NEXT:    [[PHI1:%.*]] = phi i1 [ [[CMP2]], [[BB_ELSE]] ], [ undef, [[BB_THEN]] ]
20 ; CHECK-NEXT:    [[XOR1:%.*]] = xor i1 [[CMP1]], true
21 ; CHECK-NEXT:    [[AND1:%.*]] = and i1 [[PHI1]], [[XOR1]]
22 ; CHECK-NEXT:    ret i1 [[AND1]]
25 entry:
26   %cmp1 = icmp eq i32 %arg, 37
27   br i1 %cmp1, label %bb_then, label %bb_else
29 bb_then:
30   call void @bar()
31   br label %bb_exit
33 bb_else:
34   %cmp2 = icmp slt i32 %arg, 17
35   br label %bb_exit
37 bb_exit:
38   %phi1 = phi i1 [ %cmp2, %bb_else ], [ undef, %bb_then ]
39   %xor1 = xor i1 %cmp1, true
40   %and1 = and i1 %phi1, %xor1
41   ret i1 %and1
44 define zeroext i1 @foo_logical(i32 %arg) {
45 ; CHECK-LABEL: @foo_logical(
46 ; CHECK-NEXT:  entry:
47 ; CHECK-NEXT:    [[CMP1:%.*]] = icmp eq i32 [[ARG:%.*]], 37
48 ; CHECK-NEXT:    br i1 [[CMP1]], label [[BB_THEN:%.*]], label [[BB_ELSE:%.*]]
49 ; CHECK:       bb_then:
50 ; CHECK-NEXT:    call void @bar()
51 ; CHECK-NEXT:    br label [[BB_EXIT:%.*]]
52 ; CHECK:       bb_else:
53 ; CHECK-NEXT:    [[CMP2:%.*]] = icmp slt i32 [[ARG]], 17
54 ; CHECK-NEXT:    br label [[BB_EXIT]]
55 ; CHECK:       bb_exit:
56 ; CHECK-NEXT:    [[PHI1:%.*]] = phi i1 [ [[CMP2]], [[BB_ELSE]] ], [ undef, [[BB_THEN]] ]
57 ; CHECK-NEXT:    [[XOR1:%.*]] = xor i1 [[CMP1]], true
58 ; CHECK-NEXT:    [[AND1:%.*]] = select i1 [[PHI1]], i1 [[XOR1]], i1 false
59 ; CHECK-NEXT:    ret i1 [[AND1]]
62 entry:
63   %cmp1 = icmp eq i32 %arg, 37
64   br i1 %cmp1, label %bb_then, label %bb_else
66 bb_then:
67   call void @bar()
68   br label %bb_exit
70 bb_else:
71   %cmp2 = icmp slt i32 %arg, 17
72   br label %bb_exit
74 bb_exit:
75   %phi1 = phi i1 [ %cmp2, %bb_else ], [ undef, %bb_then ]
76   %xor1 = xor i1 %cmp1, true
77   %and1 = select i1 %phi1, i1 %xor1, i1 false
78   ret i1 %and1
81 declare void @bar()