blob: 93a3c1b214eedae35a06bcd4d7768837d3cd30ea [file] [log] [blame]
; RUN: opt %loadPolly %defaultOpts -polly-detect -analyze %s | FileCheck %s
; region-simplify make polly fail to detect the canonical induction variable.
; XFAIL:*
; ModuleID = './linear-algebra/solvers/lu/lu_without_param.ll'
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-n8:16:32:64"
target triple = "x86_64-unknown-linux-gnu"
%struct._IO_FILE = type { i32, i8*, i8*, i8*, i8*, i8*, i8*, i8*, i8*, i8*, i8*, i8*, %struct._IO_marker*, %struct._IO_FILE*, i32, i32, i64, i16, i8, [1 x i8], i8*, i64, i8*, i8*, i8*, i8*, i64, i32, [20 x i8] }
%struct._IO_marker = type { %struct._IO_marker*, %struct._IO_FILE*, i32 }
@A = common global [1024 x [1024 x double]] zeroinitializer, align 32
@stderr = external global %struct._IO_FILE*
@.str = private constant [8 x i8] c"%0.2lf \00", align 1
define void @scop_func() nounwind {
bb.nph28:
br label %bb2.preheader
bb1: ; preds = %bb1.preheader, %bb1
%indvar = phi i64 [ %indvar.next, %bb1 ], [ 0, %bb1.preheader ]
%tmp27 = add i64 %tmp26, %indvar
%scevgep = getelementptr [1024 x [1024 x double]]* @A, i64 0, i64 0, i64 %tmp27
%0 = load double* %scevgep, align 8
%1 = load double* %scevgep68, align 8
%2 = fdiv double %0, %1
store double %2, double* %scevgep, align 8
%indvar.next = add i64 %indvar, 1
%exitcond20 = icmp eq i64 %indvar.next, %tmp1
br i1 %exitcond20, label %bb8.loopexit, label %bb1
bb5: ; preds = %bb6.preheader, %bb5
%indvar33 = phi i64 [ %indvar.next34, %bb5 ], [ 0, %bb6.preheader ]
%tmp33 = add i64 %tmp26, %indvar33
%scevgep44 = getelementptr [1024 x [1024 x double]]* @A, i64 0, i64 %tmp31, i64 %tmp33
%scevgep45 = getelementptr [1024 x [1024 x double]]* @A, i64 0, i64 0, i64 %tmp33
%3 = load double* %scevgep44, align 8
%4 = load double* %scevgep54, align 8
%5 = load double* %scevgep45, align 8
%6 = fmul double %4, %5
%7 = fsub double %3, %6
store double %7, double* %scevgep44, align 8
%indvar.next34 = add i64 %indvar33, 1
%exitcond2 = icmp eq i64 %indvar.next34, %tmp1
br i1 %exitcond2, label %bb8.loopexit4, label %bb5
bb8.loopexit: ; preds = %bb1
br i1 %9, label %bb6.preheader.preheader, label %bb9
bb6.preheader.preheader: ; preds = %bb8.loopexit
br label %bb6.preheader
bb8.loopexit4: ; preds = %bb5
%exitcond11 = icmp eq i64 %tmp56, %tmp1
br i1 %exitcond11, label %bb9.loopexit, label %bb6.preheader
bb6.preheader: ; preds = %bb6.preheader.preheader, %bb8.loopexit4
%indvar38 = phi i64 [ %tmp56, %bb8.loopexit4 ], [ 0, %bb6.preheader.preheader ]
%tmp31 = add i64 %indvar38, 1
%scevgep54 = getelementptr [1024 x [1024 x double]]* @A, i64 0, i64 %tmp31, i64 %tmp25
%tmp56 = add i64 %indvar38, 1
br label %bb5
bb9.loopexit: ; preds = %bb8.loopexit4
br label %bb9
bb9: ; preds = %bb9.loopexit, %bb2.preheader, %bb8.loopexit
%exitcond = icmp eq i64 %8, 1024
br i1 %exitcond, label %return, label %bb2.preheader
bb2.preheader: ; preds = %bb9, %bb.nph28
%storemerge17 = phi i64 [ 0, %bb.nph28 ], [ %8, %bb9 ]
%tmp25 = mul i64 %storemerge17, 1025
%tmp26 = add i64 %tmp25, 1
%tmp29 = mul i64 %storemerge17, -1
%tmp1 = add i64 %tmp29, 1023
%storemerge15 = add i64 %storemerge17, 1
%scevgep68 = getelementptr [1024 x [1024 x double]]* @A, i64 0, i64 0, i64 %tmp25
%8 = add i64 %storemerge17, 1
%9 = icmp slt i64 %storemerge15, 1024
br i1 %9, label %bb1.preheader, label %bb9
bb1.preheader: ; preds = %bb2.preheader
br label %bb1
return: ; preds = %bb9
ret void
}
; CHECK: Valid Region for Scop: bb2.preheader => return