1*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -basicaa -loop-interchange -S | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker;; These are test that fail to interchange due to current limitation. This will go off once we extend the loop interchange pass. 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" 5*9880d681SAndroid Build Coastguard Workertarget triple = "x86_64-unknown-linux-gnu" 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Worker@A = common global [100 x [100 x i32]] zeroinitializer 8*9880d681SAndroid Build Coastguard Worker@B = common global [100 x [100 x [100 x i32]]] zeroinitializer 9*9880d681SAndroid Build Coastguard Worker 10*9880d681SAndroid Build Coastguard Worker;;--------------------------------------Test case 01------------------------------------ 11*9880d681SAndroid Build Coastguard Worker;; [FIXME] This loop though valid is currently not interchanged due to the limitation that we cannot split the inner loop latch due to multiple use of inner induction 12*9880d681SAndroid Build Coastguard Worker;; variable.(used to increment the loop counter and to access A[j+1][i+1] 13*9880d681SAndroid Build Coastguard Worker;; for(int i=0;i<N-1;i++) 14*9880d681SAndroid Build Coastguard Worker;; for(int j=1;j<N-1;j++) 15*9880d681SAndroid Build Coastguard Worker;; A[j+1][i+1] = A[j+1][i+1] + k; 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Workerdefine void @interchange_01(i32 %k, i32 %N) { 18*9880d681SAndroid Build Coastguard Worker entry: 19*9880d681SAndroid Build Coastguard Worker %sub = add nsw i32 %N, -1 20*9880d681SAndroid Build Coastguard Worker %cmp26 = icmp sgt i32 %N, 1 21*9880d681SAndroid Build Coastguard Worker br i1 %cmp26, label %for.cond1.preheader.lr.ph, label %for.end17 22*9880d681SAndroid Build Coastguard Worker 23*9880d681SAndroid Build Coastguard Worker for.cond1.preheader.lr.ph: 24*9880d681SAndroid Build Coastguard Worker %cmp324 = icmp sgt i32 %sub, 1 25*9880d681SAndroid Build Coastguard Worker %0 = add i32 %N, -2 26*9880d681SAndroid Build Coastguard Worker %1 = sext i32 %sub to i64 27*9880d681SAndroid Build Coastguard Worker br label %for.cond1.preheader 28*9880d681SAndroid Build Coastguard Worker 29*9880d681SAndroid Build Coastguard Worker for.cond.loopexit: 30*9880d681SAndroid Build Coastguard Worker %cmp = icmp slt i64 %indvars.iv.next29, %1 31*9880d681SAndroid Build Coastguard Worker br i1 %cmp, label %for.cond1.preheader, label %for.end17 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Worker for.cond1.preheader: 34*9880d681SAndroid Build Coastguard Worker %indvars.iv28 = phi i64 [ 0, %for.cond1.preheader.lr.ph ], [ %indvars.iv.next29, %for.cond.loopexit ] 35*9880d681SAndroid Build Coastguard Worker %indvars.iv.next29 = add nuw nsw i64 %indvars.iv28, 1 36*9880d681SAndroid Build Coastguard Worker br i1 %cmp324, label %for.body4, label %for.cond.loopexit 37*9880d681SAndroid Build Coastguard Worker 38*9880d681SAndroid Build Coastguard Worker for.body4: 39*9880d681SAndroid Build Coastguard Worker %indvars.iv = phi i64 [ %indvars.iv.next, %for.body4 ], [ 1, %for.cond1.preheader ] 40*9880d681SAndroid Build Coastguard Worker %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1 41*9880d681SAndroid Build Coastguard Worker %arrayidx7 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* @A, i64 0, i64 %indvars.iv.next, i64 %indvars.iv.next29 42*9880d681SAndroid Build Coastguard Worker %2 = load i32, i32* %arrayidx7 43*9880d681SAndroid Build Coastguard Worker %add8 = add nsw i32 %2, %k 44*9880d681SAndroid Build Coastguard Worker store i32 %add8, i32* %arrayidx7 45*9880d681SAndroid Build Coastguard Worker %lftr.wideiv = trunc i64 %indvars.iv to i32 46*9880d681SAndroid Build Coastguard Worker %exitcond = icmp eq i32 %lftr.wideiv, %0 47*9880d681SAndroid Build Coastguard Worker br i1 %exitcond, label %for.cond.loopexit, label %for.body4 48*9880d681SAndroid Build Coastguard Worker 49*9880d681SAndroid Build Coastguard Worker for.end17: 50*9880d681SAndroid Build Coastguard Worker ret void 51*9880d681SAndroid Build Coastguard Worker} 52*9880d681SAndroid Build Coastguard Worker;; Inner loop not split so it is not interchanged. 53*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @interchange_01 54*9880d681SAndroid Build Coastguard Worker; CHECK: for.body4: 55*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: %indvars.iv = phi i64 [ %indvars.iv.next, %for.body4 ], [ 1, %for.body4.preheader ] 56*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1 57*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: %arrayidx7 = getelementptr inbounds [100 x [100 x i32]], [100 x [100 x i32]]* @A, i64 0, i64 %indvars.iv.next, i64 %indvars.iv.next29 58*9880d681SAndroid Build Coastguard Worker 59