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
46
47
| ; RUN: opt %loadPolly -polly-detect -analyze < %s | \
; RUN: FileCheck %s -check-prefix=DETECT
; RUN: opt %loadPolly -polly-scops -analyze < %s | \
; RUN: FileCheck %s -check-prefix=SCOP
; DETECT: Valid Region for Scop: loop => barrier
; DETECT-NEXT: Valid Region for Scop: branch => end
; SCOP: Statements {
; SCOP-NEXT: Stmt_then
; SCOP-NEXT: Domain :=
; SCOP-NEXT: [p_0] -> { Stmt_then[] : p_0 <= -2 or p_0 >= 0 };
; SCOP-NEXT: Schedule :=
; SCOP-NEXT: [p_0] -> { Stmt_then[] -> [] };
; SCOP-NEXT: MustWriteAccess := [Reduction Type: NONE] [Scalar: 0]
; SCOP-NEXT: [p_0] -> { Stmt_then[] -> MemRef_A[0] };
; SCOP-NEXT: }
target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128"
target triple = "aarch64--linux-android"
define void @f(i16 %event, float* %A) {
entry:
br label %loop
loop:
%indvar = phi i8 [ 0, %entry ], [ %indvar.next, %loop ]
%indvar.next = add i8 %indvar, -1
store float 1.0, float* %A
%cmp = icmp eq i8 %indvar.next, 0
br i1 false, label %barrier, label %loop
barrier:
fence seq_cst
br label %branch
branch:
br i1 %cmp, label %branch, label %then
then:
store float 1.0, float* %A
br label %end
end:
ret void
}
|