process_added_dimensions.ll 5.68 KB
; 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
}