[DAGCombiner] Add target hook function to decide folding (mul (add x, c1), c2)
[llvm-project.git] / llvm / test / Transforms / LoopLoadElim / pr-48150.ll
bloba88fd9b9d938f468c2416a264a4bf96a9880c234
1 ; RUN: opt -passes=loop-load-elim -S < %s | FileCheck %s
3 target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128-ni:1-p2:32:8:8:32-ni:2"
4 target triple = "x86_64-unknown-linux-gnu"
6 define void @test() {
7 ; CHECK-LABEL: test
8 bb:
9   br i1 undef, label %bb1, label %bb2
11 bb1:                                              ; preds = %bb
12   ret void
14 bb2:                                              ; preds = %bb29, %bb
15   %tmp = phi i64 [ %tmp30, %bb29 ], [ 2, %bb ]
16   %tmp3 = add nuw nsw i64 %tmp, 99
17   br label %bb4
19 bb4:                                              ; preds = %bb4, %bb2
20   %tmp5 = phi i64 [ %tmp9, %bb4 ], [ 1, %bb2 ]
21   %tmp6 = phi i32 [ %tmp10, %bb4 ], [ undef, %bb2 ]
22   %tmp7 = trunc i64 %tmp5 to i32
23   %tmp8 = add i32 %tmp6, %tmp7
24   %tmp9 = add nuw nsw i64 %tmp5, 1
25   %tmp10 = add i32 %tmp8, -1
26   %tmp11 = icmp ugt i64 %tmp3, %tmp5
27   br i1 %tmp11, label %bb4, label %bb12
29 bb12:                                             ; preds = %bb4
30   %tmp13 = sext i32 %tmp8 to i64
31   %tmp14 = add i64 0, %tmp13
32   %tmp15 = mul i64 %tmp14, undef
33   %tmp16 = add i64 %tmp15, 83
34   %tmp17 = and i64 %tmp16, -2
35   br label %bb18
37 bb18:                                             ; preds = %bb18, %bb12
38   %tmp19 = phi i64 [ 0, %bb12 ], [ %tmp27, %bb18 ]
39   %tmp20 = add i64 %tmp19, 3
40   %tmp21 = add i64 %tmp19, 5
41   %tmp22 = getelementptr inbounds i32, i32 addrspace(1)* undef, i64 %tmp20
42   %tmp23 = bitcast i32 addrspace(1)* %tmp22 to <2 x i32> addrspace(1)*
43   %tmp24 = load <2 x i32>, <2 x i32> addrspace(1)* %tmp23, align 4
44   %tmp25 = getelementptr inbounds i32, i32 addrspace(1)* undef, i64 %tmp21
45   %tmp26 = bitcast i32 addrspace(1)* %tmp25 to <2 x i32> addrspace(1)*
46   store <2 x i32> undef, <2 x i32> addrspace(1)* %tmp26, align 4
47   %tmp27 = add i64 %tmp19, 2
48   %tmp28 = icmp eq i64 %tmp27, %tmp17
49   br i1 %tmp28, label %bb29, label %bb18
51 bb29:                                             ; preds = %bb18
52   %tmp30 = add nuw nsw i64 %tmp, 1
53   br label %bb2