Update Polly tests to handle explicitly typed gep changes in LLVM
[polly-mirror.git] / test / ScopDetect / simple_non_single_entry.ll
blobc4f2bd8f47aea8fbefc13244ac229b9eae438a72
1 ; RUN: opt %loadPolly -polly-detect-unprofitable -polly-detect-scops-in-regions-without-loops -polly-detect -analyze < %s | FileCheck %s
2 ; RUN: opt %loadPolly -polly-detect-unprofitable -polly-detect-scops-in-regions-without-loops -polly-detect -analyze < %s | FileCheck %s
4 ; void f(long A[], long N) {
5 ;   long i;
7 ;  if (true){
8 ;    i = 0;
9 ;    goto next;
10 ;  }else{
11 ;    i = 1;
12 ;    goto next;
13 ; }
15 ; next:
16 ;  if (true)
17 ;    goto for.i;
18 ;  else
19 ;    goto for.i;
21 ; for.i:
22 ;   for (i = 0; i < N; ++i)
23 ;     A[i] = i;
24 ; }
26 target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
27 target triple = "x86_64-unknown-linux-gnu"
29 define void @f(i64* %A, i64 %N) nounwind {
30 entry:
31   fence seq_cst
32   br i1 true, label %then1, label %else1
34 then1:
35   br label %next
37 else1:
38   br label %next
40 next:
41   br i1 true, label %then, label %else
43 then:
44   br label %for.i.head
46 else:
47   br label %for.i.head
49 for.i.head:
50   br label %for.i.head1
52 for.i.head1:
53   br label %for.i
55 for.i:
56   %indvar = phi i64 [ 0, %for.i.head1], [ %indvar.next, %for.i ]
57   fence seq_cst
58   %scevgep = getelementptr i64, i64* %A, i64 %indvar
59   store i64 %indvar, i64* %scevgep
60   %indvar.next = add nsw i64 %indvar, 1
61   %exitcond = icmp eq i64 %indvar.next, %N
62   br i1 %exitcond, label %return, label %for.i
64 return:
65   fence seq_cst
66   ret void
69 ; CHECK: Valid Region for Scop: next => for.i.head1