1*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=hexagon -mcpu=hexagonv5 -enable-pipeliner < %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker; Make sure we attempt to pipeline all inner most loops. 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Worker; Check if the first loop is pipelined. 6*9880d681SAndroid Build Coastguard Worker; CHECK: loop0(.LBB0_[[LOOP:.]], 7*9880d681SAndroid Build Coastguard Worker; CHECK: .LBB0_[[LOOP]]: 8*9880d681SAndroid Build Coastguard Worker; CHECK: add(r{{[0-9]+}}, r{{[0-9]+}}) 9*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: memw(r{{[0-9]+}}{{.*}}++{{.*}}#4) 10*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: endloop0 11*9880d681SAndroid Build Coastguard Worker 12*9880d681SAndroid Build Coastguard Worker; Check if the second loop is pipelined. 13*9880d681SAndroid Build Coastguard Worker; CHECK: loop0(.LBB0_[[LOOP:.]], 14*9880d681SAndroid Build Coastguard Worker; CHECK: .LBB0_[[LOOP]]: 15*9880d681SAndroid Build Coastguard Worker; CHECK: add(r{{[0-9]+}}, r{{[0-9]+}}) 16*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: memw(r{{[0-9]+}}{{.*}}++{{.*}}#4) 17*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: endloop0 18*9880d681SAndroid Build Coastguard Worker 19*9880d681SAndroid Build Coastguard Workerdefine i32 @test(i32* %a, i32 %n, i32 %l) { 20*9880d681SAndroid Build Coastguard Workerentry: 21*9880d681SAndroid Build Coastguard Worker %cmp23 = icmp sgt i32 %n, 0 22*9880d681SAndroid Build Coastguard Worker br i1 %cmp23, label %for.body3.lr.ph.preheader, label %for.end14 23*9880d681SAndroid Build Coastguard Worker 24*9880d681SAndroid Build Coastguard Workerfor.body3.lr.ph.preheader: 25*9880d681SAndroid Build Coastguard Worker br label %for.body3.lr.ph 26*9880d681SAndroid Build Coastguard Worker 27*9880d681SAndroid Build Coastguard Workerfor.body3.lr.ph: 28*9880d681SAndroid Build Coastguard Worker %sum1.026 = phi i32 [ %add8, %for.inc12 ], [ 0, %for.body3.lr.ph.preheader ] 29*9880d681SAndroid Build Coastguard Worker %sum.025 = phi i32 [ %add, %for.inc12 ], [ 0, %for.body3.lr.ph.preheader ] 30*9880d681SAndroid Build Coastguard Worker %j.024 = phi i32 [ %inc13, %for.inc12 ], [ 0, %for.body3.lr.ph.preheader ] 31*9880d681SAndroid Build Coastguard Worker br label %for.body3 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Workerfor.body3: 34*9880d681SAndroid Build Coastguard Worker %sum.118 = phi i32 [ %sum.025, %for.body3.lr.ph ], [ %add, %for.body3 ] 35*9880d681SAndroid Build Coastguard Worker %arrayidx.phi = phi i32* [ %a, %for.body3.lr.ph ], [ %arrayidx.inc, %for.body3 ] 36*9880d681SAndroid Build Coastguard Worker %i.017 = phi i32 [ 0, %for.body3.lr.ph ], [ %inc, %for.body3 ] 37*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %arrayidx.phi, align 4 38*9880d681SAndroid Build Coastguard Worker %add = add nsw i32 %0, %sum.118 39*9880d681SAndroid Build Coastguard Worker %inc = add nsw i32 %i.017, 1 40*9880d681SAndroid Build Coastguard Worker %exitcond = icmp eq i32 %inc, %n 41*9880d681SAndroid Build Coastguard Worker %arrayidx.inc = getelementptr i32, i32* %arrayidx.phi, i32 1 42*9880d681SAndroid Build Coastguard Worker br i1 %exitcond, label %for.end, label %for.body3 43*9880d681SAndroid Build Coastguard Worker 44*9880d681SAndroid Build Coastguard Workerfor.end: 45*9880d681SAndroid Build Coastguard Worker tail call void @bar(i32* %a) #2 46*9880d681SAndroid Build Coastguard Worker br label %for.body6 47*9880d681SAndroid Build Coastguard Worker 48*9880d681SAndroid Build Coastguard Workerfor.body6: 49*9880d681SAndroid Build Coastguard Worker %sum1.121 = phi i32 [ %sum1.026, %for.end ], [ %add8, %for.body6 ] 50*9880d681SAndroid Build Coastguard Worker %arrayidx7.phi = phi i32* [ %a, %for.end ], [ %arrayidx7.inc, %for.body6 ] 51*9880d681SAndroid Build Coastguard Worker %i.120 = phi i32 [ 0, %for.end ], [ %inc10, %for.body6 ] 52*9880d681SAndroid Build Coastguard Worker %1 = load i32, i32* %arrayidx7.phi, align 4 53*9880d681SAndroid Build Coastguard Worker %add8 = add nsw i32 %1, %sum1.121 54*9880d681SAndroid Build Coastguard Worker %inc10 = add nsw i32 %i.120, 1 55*9880d681SAndroid Build Coastguard Worker %exitcond29 = icmp eq i32 %inc10, %n 56*9880d681SAndroid Build Coastguard Worker %arrayidx7.inc = getelementptr i32, i32* %arrayidx7.phi, i32 1 57*9880d681SAndroid Build Coastguard Worker br i1 %exitcond29, label %for.inc12, label %for.body6 58*9880d681SAndroid Build Coastguard Worker 59*9880d681SAndroid Build Coastguard Workerfor.inc12: 60*9880d681SAndroid Build Coastguard Worker %inc13 = add nsw i32 %j.024, 1 61*9880d681SAndroid Build Coastguard Worker %exitcond30 = icmp eq i32 %inc13, %n 62*9880d681SAndroid Build Coastguard Worker br i1 %exitcond30, label %for.end14.loopexit, label %for.body3.lr.ph 63*9880d681SAndroid Build Coastguard Worker 64*9880d681SAndroid Build Coastguard Workerfor.end14.loopexit: 65*9880d681SAndroid Build Coastguard Worker br label %for.end14 66*9880d681SAndroid Build Coastguard Worker 67*9880d681SAndroid Build Coastguard Workerfor.end14: 68*9880d681SAndroid Build Coastguard Worker %sum1.0.lcssa = phi i32 [ 0, %entry ], [ %add8, %for.end14.loopexit ] 69*9880d681SAndroid Build Coastguard Worker %sum.0.lcssa = phi i32 [ 0, %entry ], [ %add, %for.end14.loopexit ] 70*9880d681SAndroid Build Coastguard Worker %add15 = add nsw i32 %sum1.0.lcssa, %sum.0.lcssa 71*9880d681SAndroid Build Coastguard Worker ret i32 %add15 72*9880d681SAndroid Build Coastguard Worker} 73*9880d681SAndroid Build Coastguard Worker 74*9880d681SAndroid Build Coastguard Workerdeclare void @bar(i32*) 75*9880d681SAndroid Build Coastguard Worker 76