llvm-project/polly/test/ScopInfo/process_added_dimensions.ll

121 lines
5.7 KiB
LLVM

; RUN: opt %loadPolly -polly-stmt-granularity=bb -polly-scops -analyze < %s | FileCheck %s
; CHECK: Context:
; CHECK-NEXT: { : }
; CHECK: Assumed Context:
; CHECK-NEXT: { : }
; CHECK: Invalid Context:
; CHECK-NEXT: { : false }
; CHECK: Statements {
; CHECK-NEXT: Stmt_for_cond40_preheader_4
; CHECK-NEXT: Domain :=
; CHECK-NEXT: { Stmt_for_cond40_preheader_4[i0] : 0 <= i0 <= 1 };
; CHECK-NEXT: Schedule :=
; CHECK-NEXT: { Stmt_for_cond40_preheader_4[i0] -> [i0, 0] };
; CHECK-NEXT: MustWriteAccess := [Reduction Type: NONE] [Scalar: 0]
; CHECK-NEXT: { Stmt_for_cond40_preheader_4[i0] -> MemRef_call[5, 5, 0] };
; CHECK-NEXT: Stmt_for_cond40_preheader_5
; CHECK-NEXT: Domain :=
; CHECK-NEXT: { Stmt_for_cond40_preheader_5[i0] : 0 <= i0 <= 1 };
; CHECK-NEXT: Schedule :=
; CHECK-NEXT: { Stmt_for_cond40_preheader_5[i0] -> [i0, 1] };
; CHECK-NEXT: ReadAccess := [Reduction Type: NONE] [Scalar: 0]
; CHECK-NEXT: { Stmt_for_cond40_preheader_5[i0] -> MemRef_call[5, 5, 0] };
; CHECK-NEXT: MustWriteAccess := [Reduction Type: NONE] [Scalar: 1]
; CHECK-NEXT: { Stmt_for_cond40_preheader_5[i0] -> MemRef__pre160[] };
; CHECK-NEXT: }
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
target triple = "x86_64-unknown-linux-gnu"
declare noalias i8* @malloc()
define i32 @main() {
entry:
%call = tail call noalias i8* @malloc()
%0 = bitcast i8* %call to [6 x [6 x [64 x i32]]]*
%arrayidx51.5.phi.trans.insert = getelementptr inbounds i8, i8* %call, i64 8960
%1 = bitcast i8* %arrayidx51.5.phi.trans.insert to i32*
br label %for.cond40.preheader.4
for.end76: ; preds = %for.inc71.5
ret i32 %.pre160
for.cond40.preheader.4: ; preds = %for.inc71.5, %entry
%t.0131 = phi i32 [ 0, %entry ], [ %inc75, %for.inc71.5 ]
%indvars.iv.next135 = add nuw nsw i64 0, 1
%2 = trunc i64 %indvars.iv.next135 to i32
%indvars.iv.next = add nuw nsw i64 0, 1
%exitcond = icmp eq i64 %indvars.iv.next, 64
%exitcond137 = icmp eq i32 %2, 6
%indvars.iv.next135.1 = add nuw nsw i64 1, 1
%indvars.iv.next.1 = add nuw nsw i64 0, 1
%exitcond.1 = icmp eq i64 %indvars.iv.next.1, 64
%lftr.wideiv.1 = trunc i64 %indvars.iv.next135.1 to i32
%exitcond137.1 = icmp eq i32 %lftr.wideiv.1, 6
%indvars.iv.next135.2 = add nuw nsw i64 2, 1
%indvars.iv.next.2 = add nuw nsw i64 0, 1
%exitcond.2 = icmp eq i64 %indvars.iv.next.2, 64
%lftr.wideiv.2 = trunc i64 %indvars.iv.next135.2 to i32
%exitcond137.2 = icmp eq i32 %lftr.wideiv.2, 6
%indvars.iv.next135.3 = add nuw nsw i64 3, 1
%indvars.iv.next.3 = add nuw nsw i64 0, 1
%exitcond.3 = icmp eq i64 %indvars.iv.next.3, 64
%lftr.wideiv.3 = trunc i64 %indvars.iv.next135.3 to i32
%exitcond137.3 = icmp eq i32 %lftr.wideiv.3, 6
%indvars.iv.next135.4 = add nuw nsw i64 4, 1
%indvars.iv.next.4 = add nuw nsw i64 0, 1
%exitcond.4 = icmp eq i64 %indvars.iv.next.4, 64
%lftr.wideiv.4 = trunc i64 %indvars.iv.next135.4 to i32
%exitcond137.4 = icmp eq i32 %lftr.wideiv.4, 6
%arrayidx23.5 = getelementptr inbounds [6 x [6 x [64 x i32]]], [6 x [6 x [64 x i32]]]* %0, i64 0, i64 5, i64 5, i64 0
store i32 36, i32* %arrayidx23.5, align 4
%indvars.iv.next.5 = add nuw nsw i64 0, 1
%exitcond.5 = icmp eq i64 %indvars.iv.next.5, 64
%indvars.iv.next143 = add nuw nsw i64 1, 1
%exitcond145 = icmp eq i64 %indvars.iv.next143, 64
%indvars.iv.next149 = add nuw nsw i64 0, 1
%lftr.wideiv150 = trunc i64 %indvars.iv.next149 to i32
%exitcond151 = icmp eq i32 %lftr.wideiv150, 6
%indvars.iv.next143.1 = add nuw nsw i64 1, 1
%exitcond145.1 = icmp eq i64 %indvars.iv.next143.1, 64
%indvars.iv.next149.1 = add nuw nsw i64 1, 1
%lftr.wideiv150.1 = trunc i64 %indvars.iv.next149.1 to i32
%exitcond151.1 = icmp eq i32 %lftr.wideiv150.1, 6
%indvars.iv.next143.2 = add nuw nsw i64 1, 1
%exitcond145.2 = icmp eq i64 %indvars.iv.next143.2, 64
%indvars.iv.next149.2 = add nuw nsw i64 2, 1
%lftr.wideiv150.2 = trunc i64 %indvars.iv.next149.2 to i32
%exitcond151.2 = icmp eq i32 %lftr.wideiv150.2, 6
%indvars.iv.next143.3 = add nuw nsw i64 1, 1
%exitcond145.3 = icmp eq i64 %indvars.iv.next143.3, 64
%indvars.iv.next149.3 = add nuw nsw i64 3, 1
%lftr.wideiv150.3 = trunc i64 %indvars.iv.next149.3 to i32
%exitcond151.3 = icmp eq i32 %lftr.wideiv150.3, 6
br label %for.body44.4
for.body44.4: ; preds = %for.body44.4, %for.cond40.preheader.4
%indvars.iv142.4 = phi i64 [ 1, %for.cond40.preheader.4 ], [ %indvars.iv.next143.4, %for.body44.4 ]
%indvars.iv.next143.4 = add nuw nsw i64 %indvars.iv142.4, 1
%exitcond145.4 = icmp eq i64 %indvars.iv.next143.4, 64
br i1 %exitcond145.4, label %for.cond40.preheader.5, label %for.body44.4
for.cond40.preheader.5: ; preds = %for.body44.4
%indvars.iv.next149.4 = add nuw nsw i64 4, 1
%lftr.wideiv150.4 = trunc i64 %indvars.iv.next149.4 to i32
%exitcond151.4 = icmp eq i32 %lftr.wideiv150.4, 6
%.pre160 = load i32, i32* %1, align 4
br label %for.body44.5
for.body44.5: ; preds = %for.body44.5, %for.cond40.preheader.5
%indvars.iv142.5 = phi i64 [ 1, %for.cond40.preheader.5 ], [ %indvars.iv.next143.5, %for.body44.5 ]
%indvars.iv.next143.5 = add nuw nsw i64 %indvars.iv142.5, 1
%exitcond145.5 = icmp eq i64 %indvars.iv.next143.5, 64
br i1 %exitcond145.5, label %for.inc71.5, label %for.body44.5
for.inc71.5: ; preds = %for.body44.5
%inc75 = add nuw nsw i32 %t.0131, 1
%exitcond155 = icmp eq i32 %inc75, 2
br i1 %exitcond155, label %for.end76, label %for.cond40.preheader.4
}