1*9880d681SAndroid Build Coastguard Worker; RUN: llc -O2 < %s 2*9880d681SAndroid Build Coastguard Worker; REQUIRES: asserts 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-m:e-p:32:32-i1:32-i64:64-a:0-v32:32-n16:32" 5*9880d681SAndroid Build Coastguard Workertarget triple = "hexagon-unknown--elf" 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Worker%struct.cpumask = type { [1 x i32] } 8*9880d681SAndroid Build Coastguard Worker%struct.load_weight = type { i32, i32 } 9*9880d681SAndroid Build Coastguard Worker 10*9880d681SAndroid Build Coastguard Worker@sysctl_sched_latency = global i32 6000000, align 4 11*9880d681SAndroid Build Coastguard Worker@normalized_sysctl_sched_latency = global i32 6000000, align 4 12*9880d681SAndroid Build Coastguard Worker@sysctl_sched_tunable_scaling = global i8 1, align 1 13*9880d681SAndroid Build Coastguard Worker@sysctl_sched_min_granularity = global i32 750000, align 4 14*9880d681SAndroid Build Coastguard Worker@normalized_sysctl_sched_min_granularity = global i32 750000, align 4 15*9880d681SAndroid Build Coastguard Worker@sysctl_sched_wakeup_granularity = global i32 1000000, align 4 16*9880d681SAndroid Build Coastguard Worker@normalized_sysctl_sched_wakeup_granularity = global i32 1000000, align 4 17*9880d681SAndroid Build Coastguard Worker@sysctl_sched_migration_cost = constant i32 500000, align 4 18*9880d681SAndroid Build Coastguard Worker@sysctl_sched_shares_window = global i32 10000000, align 4 19*9880d681SAndroid Build Coastguard Worker@sysctl_sched_child_runs_first = common global i32 0, align 4 20*9880d681SAndroid Build Coastguard Worker@cpu_online_mask = external constant %struct.cpumask* 21*9880d681SAndroid Build Coastguard Worker 22*9880d681SAndroid Build Coastguard Worker; Function Attrs: noinline nounwind 23*9880d681SAndroid Build Coastguard Workerdefine void @sched_init_granularity() #0 { 24*9880d681SAndroid Build Coastguard Workerentry: 25*9880d681SAndroid Build Coastguard Worker tail call fastcc void @update_sysctl() 26*9880d681SAndroid Build Coastguard Worker ret void 27*9880d681SAndroid Build Coastguard Worker} 28*9880d681SAndroid Build Coastguard Worker 29*9880d681SAndroid Build Coastguard Worker; Function Attrs: noinline nounwind 30*9880d681SAndroid Build Coastguard Workerdefine internal fastcc void @update_sysctl() #0 { 31*9880d681SAndroid Build Coastguard Workerentry: 32*9880d681SAndroid Build Coastguard Worker %call = tail call i32 @get_update_sysctl_factor() 33*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* @normalized_sysctl_sched_min_granularity, align 4, !tbaa !1 34*9880d681SAndroid Build Coastguard Worker %mul = mul i32 %0, %call 35*9880d681SAndroid Build Coastguard Worker store i32 %mul, i32* @sysctl_sched_min_granularity, align 4, !tbaa !1 36*9880d681SAndroid Build Coastguard Worker %1 = load i32, i32* @normalized_sysctl_sched_latency, align 4, !tbaa !1 37*9880d681SAndroid Build Coastguard Worker %mul1 = mul i32 %1, %call 38*9880d681SAndroid Build Coastguard Worker store i32 %mul1, i32* @sysctl_sched_latency, align 4, !tbaa !1 39*9880d681SAndroid Build Coastguard Worker %2 = load i32, i32* @normalized_sysctl_sched_wakeup_granularity, align 4, !tbaa !1 40*9880d681SAndroid Build Coastguard Worker %mul2 = mul i32 %2, %call 41*9880d681SAndroid Build Coastguard Worker store i32 %mul2, i32* @sysctl_sched_wakeup_granularity, align 4, !tbaa !1 42*9880d681SAndroid Build Coastguard Worker ret void 43*9880d681SAndroid Build Coastguard Worker} 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker; Function Attrs: noinline nounwind 46*9880d681SAndroid Build Coastguard Workerdefine i32 @calc_delta_mine(i32 %delta_exec, i32 %weight, %struct.load_weight* nocapture %lw) #0 { 47*9880d681SAndroid Build Coastguard Workerentry: 48*9880d681SAndroid Build Coastguard Worker %cmp = icmp ugt i32 %weight, 1 49*9880d681SAndroid Build Coastguard Worker %conv = zext i32 %delta_exec to i64 50*9880d681SAndroid Build Coastguard Worker br i1 %cmp, label %if.then, label %if.end, !prof !5 51*9880d681SAndroid Build Coastguard Worker 52*9880d681SAndroid Build Coastguard Workerif.then: ; preds = %entry 53*9880d681SAndroid Build Coastguard Worker %conv2 = zext i32 %weight to i64 54*9880d681SAndroid Build Coastguard Worker %mul = mul i64 %conv2, %conv 55*9880d681SAndroid Build Coastguard Worker br label %if.end 56*9880d681SAndroid Build Coastguard Worker 57*9880d681SAndroid Build Coastguard Workerif.end: ; preds = %entry, %if.then 58*9880d681SAndroid Build Coastguard Worker %tmp.0 = phi i64 [ %mul, %if.then ], [ %conv, %entry ] 59*9880d681SAndroid Build Coastguard Worker %inv_weight = getelementptr inbounds %struct.load_weight, %struct.load_weight* %lw, i32 0, i32 1 60*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %inv_weight, align 4, !tbaa !6 61*9880d681SAndroid Build Coastguard Worker %tobool4 = icmp eq i32 %0, 0 62*9880d681SAndroid Build Coastguard Worker br i1 %tobool4, label %if.then5, label %if.end22 63*9880d681SAndroid Build Coastguard Worker 64*9880d681SAndroid Build Coastguard Workerif.then5: ; preds = %if.end 65*9880d681SAndroid Build Coastguard Worker %weight7 = getelementptr inbounds %struct.load_weight, %struct.load_weight* %lw, i32 0, i32 0 66*9880d681SAndroid Build Coastguard Worker %1 = load i32, i32* %weight7, align 4, !tbaa !9 67*9880d681SAndroid Build Coastguard Worker %lnot9 = icmp eq i32 %1, 0 68*9880d681SAndroid Build Coastguard Worker br i1 %lnot9, label %if.then17, label %if.else19, !prof !10 69*9880d681SAndroid Build Coastguard Worker 70*9880d681SAndroid Build Coastguard Workerif.then17: ; preds = %if.then5 71*9880d681SAndroid Build Coastguard Worker store i32 -1, i32* %inv_weight, align 4, !tbaa !6 72*9880d681SAndroid Build Coastguard Worker br label %if.end22 73*9880d681SAndroid Build Coastguard Worker 74*9880d681SAndroid Build Coastguard Workerif.else19: ; preds = %if.then5 75*9880d681SAndroid Build Coastguard Worker %div = udiv i32 -1, %1 76*9880d681SAndroid Build Coastguard Worker store i32 %div, i32* %inv_weight, align 4, !tbaa !6 77*9880d681SAndroid Build Coastguard Worker br label %if.end22 78*9880d681SAndroid Build Coastguard Worker 79*9880d681SAndroid Build Coastguard Workerif.end22: ; preds = %if.end, %if.then17, %if.else19 80*9880d681SAndroid Build Coastguard Worker %2 = phi i32 [ %0, %if.end ], [ -1, %if.then17 ], [ %div, %if.else19 ] 81*9880d681SAndroid Build Coastguard Worker %cmp23 = icmp ugt i64 %tmp.0, 4294967295 82*9880d681SAndroid Build Coastguard Worker br i1 %cmp23, label %if.then31, label %if.else37, !prof !10 83*9880d681SAndroid Build Coastguard Worker 84*9880d681SAndroid Build Coastguard Workerif.then31: ; preds = %if.end22 85*9880d681SAndroid Build Coastguard Worker %add = add i64 %tmp.0, 32768 86*9880d681SAndroid Build Coastguard Worker %shr = lshr i64 %add, 16 87*9880d681SAndroid Build Coastguard Worker %conv33 = zext i32 %2 to i64 88*9880d681SAndroid Build Coastguard Worker %mul34 = mul i64 %conv33, %shr 89*9880d681SAndroid Build Coastguard Worker %add35 = add i64 %mul34, 32768 90*9880d681SAndroid Build Coastguard Worker %shr36 = lshr i64 %add35, 16 91*9880d681SAndroid Build Coastguard Worker br label %if.end43 92*9880d681SAndroid Build Coastguard Worker 93*9880d681SAndroid Build Coastguard Workerif.else37: ; preds = %if.end22 94*9880d681SAndroid Build Coastguard Worker %conv39 = zext i32 %2 to i64 95*9880d681SAndroid Build Coastguard Worker %mul40 = mul i64 %conv39, %tmp.0 96*9880d681SAndroid Build Coastguard Worker %add41 = add i64 %mul40, 2147483648 97*9880d681SAndroid Build Coastguard Worker %shr42 = lshr i64 %add41, 32 98*9880d681SAndroid Build Coastguard Worker br label %if.end43 99*9880d681SAndroid Build Coastguard Worker 100*9880d681SAndroid Build Coastguard Workerif.end43: ; preds = %if.else37, %if.then31 101*9880d681SAndroid Build Coastguard Worker %tmp.1 = phi i64 [ %shr36, %if.then31 ], [ %shr42, %if.else37 ] 102*9880d681SAndroid Build Coastguard Worker %cmp49 = icmp ult i64 %tmp.1, 2147483647 103*9880d681SAndroid Build Coastguard Worker %3 = trunc i64 %tmp.1 to i32 104*9880d681SAndroid Build Coastguard Worker %conv51 = select i1 %cmp49, i32 %3, i32 2147483647 105*9880d681SAndroid Build Coastguard Worker ret i32 %conv51 106*9880d681SAndroid Build Coastguard Worker} 107*9880d681SAndroid Build Coastguard Worker 108*9880d681SAndroid Build Coastguard Workerdeclare i32 @get_update_sysctl_factor() #0 109*9880d681SAndroid Build Coastguard Workerdeclare i32 @__bitmap_weight(i32*, i32) #1 110*9880d681SAndroid Build Coastguard Worker 111*9880d681SAndroid Build Coastguard Workerattributes #0 = { noinline nounwind "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" } 112*9880d681SAndroid Build Coastguard Workerattributes #1 = { "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" } 113*9880d681SAndroid Build Coastguard Workerattributes #2 = { nounwind } 114*9880d681SAndroid Build Coastguard Worker 115*9880d681SAndroid Build Coastguard Worker!llvm.ident = !{!0} 116*9880d681SAndroid Build Coastguard Worker 117*9880d681SAndroid Build Coastguard Worker!0 = !{!"Clang 3.1"} 118*9880d681SAndroid Build Coastguard Worker!1 = !{!2, !2, i64 0} 119*9880d681SAndroid Build Coastguard Worker!2 = !{!"int", !3, i64 0} 120*9880d681SAndroid Build Coastguard Worker!3 = !{!"omnipotent char", !4, i64 0} 121*9880d681SAndroid Build Coastguard Worker!4 = !{!"Simple C/C++ TBAA"} 122*9880d681SAndroid Build Coastguard Worker!5 = !{!"branch_weights", i32 64, i32 4} 123*9880d681SAndroid Build Coastguard Worker!6 = !{!7, !8, i64 4} 124*9880d681SAndroid Build Coastguard Worker!7 = !{!"load_weight", !8, i64 0, !8, i64 4} 125*9880d681SAndroid Build Coastguard Worker!8 = !{!"long", !3, i64 0} 126*9880d681SAndroid Build Coastguard Worker!9 = !{!7, !8, i64 0} 127*9880d681SAndroid Build Coastguard Worker!10 = !{!"branch_weights", i32 4, i32 64} 128*9880d681SAndroid Build Coastguard Worker!11 = !{!12, !12, i64 0} 129*9880d681SAndroid Build Coastguard Worker!12 = !{!"any pointer", !3, i64 0} 130*9880d681SAndroid Build Coastguard Worker!13 = !{!3, !3, i64 0} 131*9880d681SAndroid Build Coastguard Worker!14 = !{i32 45854, i32 45878} 132