1*9880d681SAndroid Build Coastguard Worker; RUN: llc -regalloc=greedy -arm-atomic-cfg-tidy=0 < %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker; LSR shouldn't introduce more induction variables than needed, increasing 4*9880d681SAndroid Build Coastguard Worker; register pressure and therefore spilling. There is more room for improvement 5*9880d681SAndroid Build Coastguard Worker; here. 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Worker; CHECK: sub sp, #{{40|36|32|28|24}} 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Worker; CHECK: %for.inc 10*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: ldr 11*9880d681SAndroid Build Coastguard Worker; CHECK: add 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p:32:32:32-i1:8:32-i8:8:32-i16:16:32-i32:32:32-i64:32:32-f32:32:32-f64:32:32-v64:32:64-v128:32:128-a0:0:32-n32" 14*9880d681SAndroid Build Coastguard Workertarget triple = "thumbv7-apple-ios" 15*9880d681SAndroid Build Coastguard Worker 16*9880d681SAndroid Build Coastguard Worker%struct.partition_entry = type { i32, i32, i64, i64 } 17*9880d681SAndroid Build Coastguard Worker 18*9880d681SAndroid Build Coastguard Workerdefine i32 @partition_overlap_check(%struct.partition_entry* nocapture %part, i32 %num_entries) nounwind readonly optsize ssp { 19*9880d681SAndroid Build Coastguard Workerentry: 20*9880d681SAndroid Build Coastguard Worker %cmp79 = icmp sgt i32 %num_entries, 0 21*9880d681SAndroid Build Coastguard Worker br i1 %cmp79, label %outer.loop, label %for.end72 22*9880d681SAndroid Build Coastguard Worker 23*9880d681SAndroid Build Coastguard Workerouter.loop: ; preds = %for.inc69, %entry 24*9880d681SAndroid Build Coastguard Worker %overlap.081 = phi i32 [ %overlap.4, %for.inc69 ], [ 0, %entry ] 25*9880d681SAndroid Build Coastguard Worker %0 = phi i32 [ %inc71, %for.inc69 ], [ 0, %entry ] 26*9880d681SAndroid Build Coastguard Worker %offset = getelementptr %struct.partition_entry, %struct.partition_entry* %part, i32 %0, i32 2 27*9880d681SAndroid Build Coastguard Worker %len = getelementptr %struct.partition_entry, %struct.partition_entry* %part, i32 %0, i32 3 28*9880d681SAndroid Build Coastguard Worker %tmp5 = load i64, i64* %offset, align 4 29*9880d681SAndroid Build Coastguard Worker %tmp15 = load i64, i64* %len, align 4 30*9880d681SAndroid Build Coastguard Worker %add = add nsw i64 %tmp15, %tmp5 31*9880d681SAndroid Build Coastguard Worker br label %inner.loop 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Workerinner.loop: ; preds = %for.inc, %outer.loop 34*9880d681SAndroid Build Coastguard Worker %overlap.178 = phi i32 [ %overlap.081, %outer.loop ], [ %overlap.4, %for.inc ] 35*9880d681SAndroid Build Coastguard Worker %1 = phi i32 [ 0, %outer.loop ], [ %inc, %for.inc ] 36*9880d681SAndroid Build Coastguard Worker %cmp23 = icmp eq i32 %0, %1 37*9880d681SAndroid Build Coastguard Worker br i1 %cmp23, label %for.inc, label %if.end 38*9880d681SAndroid Build Coastguard Worker 39*9880d681SAndroid Build Coastguard Workerif.end: ; preds = %inner.loop 40*9880d681SAndroid Build Coastguard Worker %len39 = getelementptr %struct.partition_entry, %struct.partition_entry* %part, i32 %1, i32 3 41*9880d681SAndroid Build Coastguard Worker %offset28 = getelementptr %struct.partition_entry, %struct.partition_entry* %part, i32 %1, i32 2 42*9880d681SAndroid Build Coastguard Worker %tmp29 = load i64, i64* %offset28, align 4 43*9880d681SAndroid Build Coastguard Worker %tmp40 = load i64, i64* %len39, align 4 44*9880d681SAndroid Build Coastguard Worker %add41 = add nsw i64 %tmp40, %tmp29 45*9880d681SAndroid Build Coastguard Worker %cmp44 = icmp sge i64 %tmp29, %tmp5 46*9880d681SAndroid Build Coastguard Worker %cmp47 = icmp slt i64 %tmp29, %add 47*9880d681SAndroid Build Coastguard Worker %or.cond = and i1 %cmp44, %cmp47 48*9880d681SAndroid Build Coastguard Worker %overlap.2 = select i1 %or.cond, i32 1, i32 %overlap.178 49*9880d681SAndroid Build Coastguard Worker %cmp52 = icmp sle i64 %add41, %add 50*9880d681SAndroid Build Coastguard Worker %cmp56 = icmp sgt i64 %add41, %tmp5 51*9880d681SAndroid Build Coastguard Worker %or.cond74 = and i1 %cmp52, %cmp56 52*9880d681SAndroid Build Coastguard Worker %overlap.3 = select i1 %or.cond74, i32 1, i32 %overlap.2 53*9880d681SAndroid Build Coastguard Worker %cmp61 = icmp sgt i64 %tmp29, %tmp5 54*9880d681SAndroid Build Coastguard Worker %cmp65 = icmp slt i64 %add41, %add 55*9880d681SAndroid Build Coastguard Worker %or.cond75 = or i1 %cmp61, %cmp65 56*9880d681SAndroid Build Coastguard Worker br i1 %or.cond75, label %for.inc, label %if.then66 57*9880d681SAndroid Build Coastguard Worker 58*9880d681SAndroid Build Coastguard Workerif.then66: ; preds = %if.end 59*9880d681SAndroid Build Coastguard Worker br label %for.inc 60*9880d681SAndroid Build Coastguard Worker 61*9880d681SAndroid Build Coastguard Workerfor.inc: ; preds = %if.end, %if.then66, %inner.loop 62*9880d681SAndroid Build Coastguard Worker %overlap.4 = phi i32 [ %overlap.178, %inner.loop ], [ 1, %if.then66 ], [ %overlap.3, %if.end ] 63*9880d681SAndroid Build Coastguard Worker %inc = add nsw i32 %1, 1 64*9880d681SAndroid Build Coastguard Worker %exitcond = icmp eq i32 %inc, %num_entries 65*9880d681SAndroid Build Coastguard Worker br i1 %exitcond, label %for.inc69, label %inner.loop 66*9880d681SAndroid Build Coastguard Worker 67*9880d681SAndroid Build Coastguard Workerfor.inc69: ; preds = %for.inc 68*9880d681SAndroid Build Coastguard Worker %inc71 = add nsw i32 %0, 1 69*9880d681SAndroid Build Coastguard Worker %exitcond83 = icmp eq i32 %inc71, %num_entries 70*9880d681SAndroid Build Coastguard Worker br i1 %exitcond83, label %for.end72, label %outer.loop 71*9880d681SAndroid Build Coastguard Worker 72*9880d681SAndroid Build Coastguard Workerfor.end72: ; preds = %for.inc69, %entry 73*9880d681SAndroid Build Coastguard Worker %overlap.0.lcssa = phi i32 [ 0, %entry ], [ %overlap.4, %for.inc69 ] 74*9880d681SAndroid Build Coastguard Worker ret i32 %overlap.0.lcssa 75*9880d681SAndroid Build Coastguard Worker} 76