1; RUN: opt %loadPolly -basic-aa -polly-ast -analyze \ 2; RUN: -polly-invariant-load-hoisting=true < %s | FileCheck %s 3 4;#include <string.h> 5;#include <stdio.h> 6;#define N 1021 7; 8;int main () { 9; int i; 10; int A[N]; 11; int RED[1]; 12; 13; memset(A, 0, sizeof(int) * N); 14; 15; A[0] = 1; 16; A[1] = 1; 17; RED[0] = 0; 18; 19; for (i = 2; i < N; i++) { 20; A[i] = A[i-1] + A[i-2]; 21; RED[0] += A[i-2]; 22; } 23; 24; if (RED[0] != 382399368) 25; return 1; 26;} 27 28target 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-n8:16:32:64" 29 30define i32 @main() nounwind { 31entry: 32 %A = alloca [1021 x i32], align 4 ; <[1021 x i32]*> [#uses=6] 33 %RED = alloca [1 x i32], align 4 ; <[1 x i32]*> [#uses=3] 34 %arraydecay = getelementptr inbounds [1021 x i32], [1021 x i32]* %A, i32 0, i32 0 ; <i32*> [#uses=1] 35 %conv = bitcast i32* %arraydecay to i8* ; <i8*> [#uses=1] 36 call void @llvm.memset.p0i8.i64(i8* %conv, i8 0, i64 4084, i32 1, i1 false) 37 %arraydecay1 = getelementptr inbounds [1021 x i32], [1021 x i32]* %A, i32 0, i32 0 ; <i32*> [#uses=1] 38 %arrayidx = getelementptr inbounds i32, i32* %arraydecay1, i64 0 ; <i32*> [#uses=1] 39 store i32 1, i32* %arrayidx 40 %arraydecay2 = getelementptr inbounds [1021 x i32], [1021 x i32]* %A, i32 0, i32 0 ; <i32*> [#uses=1] 41 %arrayidx3 = getelementptr inbounds i32, i32* %arraydecay2, i64 1 ; <i32*> [#uses=1] 42 store i32 1, i32* %arrayidx3 43 %arraydecay4 = getelementptr inbounds [1 x i32], [1 x i32]* %RED, i32 0, i32 0 ; <i32*> [#uses=1] 44 %arrayidx5 = getelementptr inbounds i32, i32* %arraydecay4, i64 0 ; <i32*> [#uses=1] 45 store i32 0, i32* %arrayidx5 46 br label %for.cond 47 48for.cond: ; preds = %for.inc, %entry 49 %indvar = phi i64 [ %indvar.next, %for.inc ], [ 0, %entry ] ; <i64> [#uses=5] 50 %arrayidx15 = getelementptr [1021 x i32], [1021 x i32]* %A, i64 0, i64 %indvar ; <i32*> [#uses=2] 51 %tmp = add i64 %indvar, 2 ; <i64> [#uses=1] 52 %arrayidx20 = getelementptr [1021 x i32], [1021 x i32]* %A, i64 0, i64 %tmp ; <i32*> [#uses=1] 53 %tmp1 = add i64 %indvar, 1 ; <i64> [#uses=1] 54 %arrayidx9 = getelementptr [1021 x i32], [1021 x i32]* %A, i64 0, i64 %tmp1 ; <i32*> [#uses=1] 55 %exitcond = icmp ne i64 %indvar, 1019 ; <i1> [#uses=1] 56 br i1 %exitcond, label %for.body, label %for.end 57 58for.body: ; preds = %for.cond 59 %tmp10 = load i32, i32* %arrayidx9 ; <i32> [#uses=1] 60 %tmp16 = load i32, i32* %arrayidx15 ; <i32> [#uses=1] 61 %add = add nsw i32 %tmp10, %tmp16 ; <i32> [#uses=1] 62 store i32 %add, i32* %arrayidx20 63 %tmp26 = load i32, i32* %arrayidx15 ; <i32> [#uses=1] 64 %arraydecay27 = getelementptr inbounds [1 x i32], [1 x i32]* %RED, i32 0, i32 0 ; <i32*> [#uses=1] 65 %arrayidx28 = getelementptr inbounds i32, i32* %arraydecay27, i64 0 ; <i32*> [#uses=2] 66 %tmp29 = load i32, i32* %arrayidx28 ; <i32> [#uses=1] 67 %add30 = add nsw i32 %tmp29, %tmp26 ; <i32> [#uses=1] 68 store i32 %add30, i32* %arrayidx28 69 br label %for.inc 70 71for.inc: ; preds = %for.body 72 %indvar.next = add i64 %indvar, 1 ; <i64> [#uses=1] 73 br label %for.cond 74 75for.end: ; preds = %for.cond 76 %arraydecay32 = getelementptr inbounds [1 x i32], [1 x i32]* %RED, i32 0, i32 0 ; <i32*> [#uses=1] 77 %arrayidx33 = getelementptr inbounds i32, i32* %arraydecay32, i64 0 ; <i32*> [#uses=1] 78 %tmp34 = load i32, i32* %arrayidx33 ; <i32> [#uses=1] 79 %cmp35 = icmp ne i32 %tmp34, 382399368 ; <i1> [#uses=1] 80 br i1 %cmp35, label %if.then, label %if.end 81 82if.then: ; preds = %for.end 83 br label %if.end 84 85if.end: ; preds = %if.then, %for.end 86 %retval.0 = phi i32 [ 1, %if.then ], [ 0, %for.end ] ; <i32> [#uses=1] 87 ret i32 %retval.0 88} 89 90declare void @llvm.memset.p0i8.i64(i8* nocapture, i8, i64, i32, i1) nounwind 91 92; This is a negative test. We can prove that RED[0] in the conditional after 93; the loop is dereferencable and consequently expand the SCoP from the 94; loop to include the conditional. However, during SCoP generation we realize 95; that, while RED[0] is invariant, it is written to as part of the same scop 96; and can consequently not be hoisted. Hence, we invalidate the scop. 97; 98; CHECK-NOT: for (int c0 = 0; c0 <= 1018; c0 += 1) 99