1*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=hexagon < %s 2*9880d681SAndroid Build Coastguard Worker; REQUIRES: asserts 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Workertarget triple = "hexagon" 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.lifetime.start(i64, i8* nocapture) #0 7*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.lifetime.end(i64, i8* nocapture) #0 8*9880d681SAndroid Build Coastguard Workerdeclare signext i16 @cat(i16 signext) #1 9*9880d681SAndroid Build Coastguard Workerdeclare void @danny(i16 signext, i16 signext, i16 signext, i16* nocapture readonly, i16 signext, i16* nocapture) #1 10*9880d681SAndroid Build Coastguard Workerdeclare void @sammy(i16* nocapture readonly, i16* nocapture readonly, i16* nocapture readonly, i32* nocapture, i16* nocapture, i16 signext, i16 signext, i16 signext) #1 11*9880d681SAndroid Build Coastguard Workerdeclare i8* @llvm.stacksave() #2 12*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.stackrestore(i8*) #2 13*9880d681SAndroid Build Coastguard Worker 14*9880d681SAndroid Build Coastguard Workerdefine i32 @fred(i16 signext %p0, i16 signext %p1, i16* nocapture readonly %p2, i16 signext %p3, i16* nocapture readonly %p4, i16* nocapture %p5) #1 { 15*9880d681SAndroid Build Coastguard Workerentry: 16*9880d681SAndroid Build Coastguard Worker %0 = tail call i8* @llvm.stacksave() 17*9880d681SAndroid Build Coastguard Worker %vla = alloca i16, i32 undef, align 8 18*9880d681SAndroid Build Coastguard Worker %call17 = call signext i16 @cat(i16 signext 1) #1 19*9880d681SAndroid Build Coastguard Worker br i1 undef, label %for.cond23.preheader, label %for.end47 20*9880d681SAndroid Build Coastguard Worker 21*9880d681SAndroid Build Coastguard Workerfor.cond23.preheader: ; preds = %for.end40, %entry 22*9880d681SAndroid Build Coastguard Worker %i.190 = phi i16 [ %inc46, %for.end40 ], [ 0, %entry ] 23*9880d681SAndroid Build Coastguard Worker br i1 undef, label %for.body27, label %for.end40 24*9880d681SAndroid Build Coastguard Worker 25*9880d681SAndroid Build Coastguard Workerfor.body27: ; preds = %for.body27, %for.cond23.preheader 26*9880d681SAndroid Build Coastguard Worker %indvars.iv = phi i32 [ %indvars.iv.next, %for.body27 ], [ 0, %for.cond23.preheader ] 27*9880d681SAndroid Build Coastguard Worker %call30 = call signext i16 @cat(i16 signext 7) #1 28*9880d681SAndroid Build Coastguard Worker %arrayidx32 = getelementptr inbounds i16, i16* %vla, i32 %indvars.iv 29*9880d681SAndroid Build Coastguard Worker store i16 %call30, i16* %arrayidx32, align 2 30*9880d681SAndroid Build Coastguard Worker %arrayidx37 = getelementptr inbounds i16, i16* undef, i32 %indvars.iv 31*9880d681SAndroid Build Coastguard Worker %indvars.iv.next = add nuw nsw i32 %indvars.iv, 1 32*9880d681SAndroid Build Coastguard Worker %exitcond = icmp eq i16 undef, %p3 33*9880d681SAndroid Build Coastguard Worker br i1 %exitcond, label %for.end40, label %for.body27 34*9880d681SAndroid Build Coastguard Worker 35*9880d681SAndroid Build Coastguard Workerfor.end40: ; preds = %for.body27, %for.cond23.preheader 36*9880d681SAndroid Build Coastguard Worker call void @sammy(i16* nonnull undef, i16* undef, i16* %p4, i32* null, i16* undef, i16 signext undef, i16 signext undef, i16 signext undef) #1 37*9880d681SAndroid Build Coastguard Worker %inc46 = add nuw nsw i16 %i.190, 1 38*9880d681SAndroid Build Coastguard Worker %exitcond94 = icmp eq i16 %inc46, %call17 39*9880d681SAndroid Build Coastguard Worker br i1 %exitcond94, label %for.end47.loopexit, label %for.cond23.preheader 40*9880d681SAndroid Build Coastguard Worker 41*9880d681SAndroid Build Coastguard Workerfor.end47.loopexit: ; preds = %for.end40 42*9880d681SAndroid Build Coastguard Worker %.pre = load i16, i16* undef, align 2 43*9880d681SAndroid Build Coastguard Worker br label %for.end47 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Workerfor.end47: ; preds = %for.end47.loopexit, %entry 46*9880d681SAndroid Build Coastguard Worker %1 = phi i16 [ %.pre, %for.end47.loopexit ], [ 0, %entry ] 47*9880d681SAndroid Build Coastguard Worker call void @danny(i16 signext %1, i16 signext %p0, i16 signext %p1, i16* %p2, i16 signext %p3, i16* %p5) #1 48*9880d681SAndroid Build Coastguard Worker call void @llvm.stackrestore(i8* %0) 49*9880d681SAndroid Build Coastguard Worker ret i32 undef 50*9880d681SAndroid Build Coastguard Worker} 51*9880d681SAndroid Build Coastguard Worker 52*9880d681SAndroid Build Coastguard Worker 53*9880d681SAndroid Build Coastguard Workerattributes #0 = { argmemonly nounwind } 54*9880d681SAndroid Build Coastguard Workerattributes #1 = { optsize } 55*9880d681SAndroid Build Coastguard Workerattributes #2 = { nounwind } 56