[JITLink][arm64] Support arm64e JIT'd code (initially enabled for MachO only).
[llvm-project.git] / polly / test / Simplify / coalesce_overlapping.ll
blobee716fc12f0956d22187a66d9542ed3665c86e15
1 ; RUN: opt %loadNPMPolly -polly-stmt-granularity=bb '-passes=polly-import-jscop,print<polly-simplify>' -polly-import-jscop-postfix=transformed -disable-output < %s | FileCheck -match-full-lines %s
3 ; Combine two partial stores (with overlapping domains) into one.
5 ; for (int j = 0; j < n; j += 1) {
6 ;   A[0] = 42.0;
7 ;   A[0] = 42.0;
8 ; }
10 define void @coalesce_overlapping(i32 %n, ptr noalias nonnull %A) {
11 entry:
12   br label %for
14 for:
15   %j = phi i32 [0, %entry], [%j.inc, %inc]
16   %j.cmp = icmp slt i32 %j, %n
17   br i1 %j.cmp, label %body, label %exit
19     body:
20       store double 42.0, ptr %A
21       store double 42.0, ptr %A
22       br label %inc
24 inc:
25   %j.inc = add nuw nsw i32 %j, 1
26   br label %for
28 exit:
29   br label %return
31 return:
32   ret void
36 ; CHECK: Statistics {
37 ; CHECK:     Overwrites removed: 0
38 ; CHECK:     Partial writes coalesced: 1
39 ; CHECK: }
41 ; CHECK:      After accesses {
42 ; CHECK-NEXT:     Stmt_body
43 ; CHECK-NEXT:             MustWriteAccess :=  [Reduction Type: NONE] [Scalar: 0]
44 ; CHECK-NEXT:                 [n] -> { Stmt_body[i0] -> MemRef_A[0] };
45 ; CHECK-NEXT:            new: [n] -> { Stmt_body[i0] -> MemRef_A[0] };
46 ; CHECK-NEXT: }