[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / Transforms / CanonicalizeFreezeInLoops / func_from_mcf_r.ll
bloba7b72b5a33593d91ba1bc6a1c852230458891d05
1 ; RUN: opt < %s -passes=canon-freeze -S | FileCheck %s
2 ; REQUIRES: aarch64-registered-target
3 target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128"
4 target triple = "aarch64-unknown-linux-gnu"
6 %struct.arc = type { i32 }
7 %struct.g = type { i64, %struct.arc, i64, i64, i64 }
9 @m = global i64 0
10 @h = global ptr null
11 @j = global %struct.g zeroinitializer
13 define dso_local i32 @main() {
14 bb:
15   %tmp = load i64, ptr @j, align 8
16   %tmp1 = icmp sgt i64 %tmp, 0
17   br i1 %tmp1, label %bb2, label %bb35
19 bb2:                                              ; preds = %bb
20   %tmp3 = load i64, ptr @m, align 8
21   %tmp4 = load ptr, ptr @h, align 8
22 ; CHECK: %tmp3.frozen = freeze i64 %tmp3
23   br label %bb5
25 bb5:                                              ; preds = %bb28, %bb2
26   %tmp6 = phi ptr [ %tmp4, %bb2 ], [ %tmp31, %bb28 ]
27   %tmp7 = phi i64 [ %tmp3, %bb2 ], [ %tmp12, %bb28 ]
28 ; CHECK: %tmp7 = phi i64 [ %tmp3.frozen, %bb2 ], [ %tmp12, %bb28 ]
29   %tmp8 = phi i64 [ 0, %bb2 ], [ %tmp11, %bb28 ]
30   %tmp9 = trunc i64 %tmp7 to i32
31   store i32 %tmp9, ptr %tmp6, align 4
32   %tmp11 = add nuw nsw i64 %tmp8, 1
33   %tmp12 = add nsw i64 %tmp7, 1
34 ; CHECK: %tmp12 = add i64 %tmp7, 1
35   store i64 %tmp12, ptr @m, align 8
36   %tmp13 = load i64, ptr inttoptr (i64 16 to ptr), align 16
37   %tmp14 = freeze i64 %tmp12
38 ; CHECK-NOT: %tmp14 = freeze i64 %tmp12
39   %tmp15 = freeze i64 %tmp13
40   %tmp16 = sdiv i64 %tmp14, %tmp15
41   %tmp17 = mul i64 %tmp16, %tmp15
42   %tmp18 = sub i64 %tmp14, %tmp17
43   %tmp19 = load i64, ptr inttoptr (i64 24 to ptr), align 8
44   %tmp20 = icmp sgt i64 %tmp18, %tmp19
45   %tmp21 = load i64, ptr inttoptr (i64 32 to ptr), align 32
46   br i1 %tmp20, label %bb22, label %bb28
48 bb22:                                             ; preds = %bb5
49   %tmp23 = mul nsw i64 %tmp21, %tmp19
50   %tmp24 = sub nsw i64 %tmp18, %tmp19
51   %tmp25 = add nsw i64 %tmp21, -1
52   %tmp26 = mul nsw i64 %tmp25, %tmp24
53   %tmp27 = add nsw i64 %tmp26, %tmp23
54   br label %bb28
56 bb28:                                             ; preds = %bb22, %bb5
57   %tmp29 = phi i64 [ %tmp27, %bb22 ], [ %tmp21, %bb5 ]
58   %tmp30 = add nsw i64 %tmp29, %tmp16
59   %tmp31 = getelementptr inbounds %struct.arc, ptr getelementptr inbounds (%struct.g, ptr @j, i32 0, i32 1), i64 %tmp30
60   store ptr %tmp31, ptr @h, align 8
61   %tmp32 = load i64, ptr @j, align 8
62   %tmp33 = icmp slt i64 %tmp11, %tmp32
63   br i1 %tmp33, label %bb5, label %bb34
65 bb34:                                             ; preds = %bb28
66   br label %bb35
68 bb35:                                             ; preds = %bb34, %bb
69   ret i32 0