; RUN: opt %loadPolly -polly-process-unprofitable=false \ ; RUN: -polly-detect -analyze < %s | FileCheck %s ; RUN: opt %loadPolly -polly-allow-nonaffine-loops \ ; RUN: -polly-detect -analyze < %s | FileCheck %s --check-prefix=NALOOPS ; RUN: opt %loadPolly -polly-allow-nonaffine-loops -polly-detect -analyze \ ; RUN: -polly-process-unprofitable=false < %s | \ ; RUN: FileCheck %s --check-prefix=PROFIT ; The latch conditions of the outer loop are not affine, thus the loop cannot ; handled by the domain generation and needs to be overapproximated. ; CHECK-NOT: Valid ; NALOOPS: Valid Region for Scop: for.body.6 => for.end.45 ; PROFIT-NOT: Valid ; ModuleID = '/home/johannes/Downloads/bug.ll' target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" ; Function Attrs: nounwind uwtable define void @kernel_reg_detect([6 x i32]* %path) #0 { entry: br label %for.body.6 for.body.6: ; preds = %for.inc.43, %for.body.6, %entry %indvars.iv9 = phi i64 [ %indvars.iv.next10, %for.body.6 ], [ 0, %for.inc.43 ], [ 0, %entry ] %indvars.iv.next10 = add nuw nsw i64 %indvars.iv9, 1 %lftr.wideiv = trunc i64 %indvars.iv.next10 to i32 %exitcond = icmp ne i32 %lftr.wideiv, 6 br i1 %exitcond, label %for.body.6, label %for.inc.40 for.inc.40: ; preds = %for.inc.40, %for.body.6 %arrayidx28 = getelementptr inbounds [6 x i32], [6 x i32]* %path, i64 0, i64 0 %tmp = load i32, i32* %arrayidx28, align 4 %arrayidx36 = getelementptr inbounds [6 x i32], [6 x i32]* %path, i64 0, i64 0 store i32 0, i32* %arrayidx36, align 4 %exitcond22 = icmp ne i64 0, 6 br i1 %exitcond22, label %for.inc.40, label %for.inc.43 for.inc.43: ; preds = %for.inc.40 %exitcond23 = icmp ne i32 0, 10000 br i1 %exitcond23, label %for.body.6, label %for.end.45 for.end.45: ; preds = %for.inc.43 ret void }