exit_phi_accesses.ll
1.43 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
; RUN: opt %loadPolly -analyze -polly-scops %s | FileCheck %s
; Check that PHI nodes only create PHI access and nothing else (e.g. unnecessary
; SCALAR accesses). In this case, for a PHI in the exit node, hence there is no
; PHI ReadAccess.
; CHECK-LABEL: Function: foo
;
; CHECK: Statements {
; CHECK-NEXT: Stmt_header
; CHECK-NEXT: Domain :=
; CHECK-NEXT: { Stmt_header[] };
; CHECK-NEXT: Schedule :=
; CHECK-NEXT: { Stmt_header[] -> [0, 0] };
; CHECK-NEXT: MustWriteAccess := [Reduction Type: NONE] [Scalar: 1]
; CHECK-NEXT: { Stmt_header[] -> MemRef_phi[] };
; CHECK-NEXT: Stmt_body
; CHECK-NEXT: Domain :=
; CHECK-NEXT: { Stmt_body[i0] : 0 <= i0 <= 100 };
; CHECK-NEXT: Schedule :=
; CHECK-NEXT: { Stmt_body[i0] -> [1, i0] };
; CHECK-NEXT: MustWriteAccess := [Reduction Type: NONE] [Scalar: 1]
; CHECK-NEXT: { Stmt_body[i0] -> MemRef_phi[] };
; CHECK-NEXT: }
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
define float @foo(float %sum, float* %A) {
entry:
br label %header
header:
br i1 true, label %body, label %exit
body:
%i = phi i64 [ 0, %header ], [ %next, %body ]
%scalar = fadd float 0.0, 0.0
%next = add nuw nsw i64 %i, 1
%cond = icmp ne i64 %i, 100
br i1 %cond, label %body, label %exit
exit:
%phi = phi float [%scalar, %body], [0.0, %header]
ret float %phi
}