[flang] Fix length handling in character kind implicit conversion (#74586)
[llvm-project.git] / polly / test / Simplify / sweep_mapped_value.ll
blob2e2f9c37febe19f308e59c3615bfcdafaf0d72ef
1 ; RUN: opt %loadPolly -polly-import-jscop -polly-import-jscop-postfix=transformed -polly-print-simplify -disable-output < %s | FileCheck %s -match-full-lines
3 ; Map %val to A[j], so the scalar write on Stmt_for_bodyB can be removed.
5 ; for (int j = 0; j < n; j += 1) {
6 ; bodyA:
7 ;   double val = 21.0 + 21.0;
8 ;   A[j] = val;
10 ; bodyB:
11 ;   B[j] = val;
12 ; }
15 define void @sweep_mapped_value(i32 %n, ptr noalias nonnull %A, ptr noalias nonnull %B) {
16 entry:
17   br label %for
19 for:
20   %j = phi i32 [0, %entry], [%j.inc, %inc]
21   %j.cmp = icmp slt i32 %j, %n
22   br i1 %j.cmp, label %bodyA, label %exit
24     bodyA:
25       %val = fadd double 21.0, 21.0
26       %A_idx = getelementptr inbounds double, ptr %A, i32 %j
27       store double %val, ptr %A_idx
28       br label %bodyB
30     bodyB:
31       %B_idx = getelementptr inbounds double, ptr %B, i32 %j
32       store double %val, ptr %B_idx
33       br label %inc
35 inc:
36   %j.inc = add nuw nsw i32 %j, 1
37   br label %for
39 exit:
40   br label %return
42 return:
43   ret void
47 ; CHECK: Statistics {
48 ; CHECK:     Dead accesses removed: 1
49 ; CHECK: }
51 ; CHECK:      After accesses {
52 ; CHECK-NEXT:     Stmt_bodyA
53 ; CHECK-NEXT:             MustWriteAccess :=  [Reduction Type: NONE] [Scalar: 0]
54 ; CHECK-NEXT:                 [n] -> { Stmt_bodyA[i0] -> MemRef_A[i0] };
55 ; CHECK-NEXT:     Stmt_bodyB
56 ; CHECK-NEXT:             MustWriteAccess :=  [Reduction Type: NONE] [Scalar: 0]
57 ; CHECK-NEXT:                 [n] -> { Stmt_bodyB[i0] -> MemRef_B[i0] };
58 ; CHECK-NEXT:             ReadAccess :=       [Reduction Type: NONE] [Scalar: 1]
59 ; CHECK-NEXT:                 [n] -> { Stmt_bodyB[i0] -> MemRef_val[] };
60 ; CHECK-NEXT:            new: [n] -> { Stmt_bodyB[i0] -> MemRef_A[i0] };
61 ; CHECK-NEXT: }