1*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -analyze -branch-prob | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -passes='print<branch-prob>' -disable-output 2>&1 | FileCheck %s 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Worker; In this test, the else clause is taken about 90% of the time. This was not 5*9880d681SAndroid Build Coastguard Worker; reflected in the probability computation because the weight is larger than 6*9880d681SAndroid Build Coastguard Worker; the branch weight cap (about 2 billion). 7*9880d681SAndroid Build Coastguard Worker; 8*9880d681SAndroid Build Coastguard Worker; CHECK: edge for.body -> if.then probability is 0x0cccba45 / 0x80000000 = 10.00% 9*9880d681SAndroid Build Coastguard Worker; CHECK: edge for.body -> if.else probability is 0x733345bb / 0x80000000 = 90.00% [HOT edge] 10*9880d681SAndroid Build Coastguard Worker 11*9880d681SAndroid Build Coastguard Worker@y = common global i64 0, align 8 12*9880d681SAndroid Build Coastguard Worker@x = common global i64 0, align 8 13*9880d681SAndroid Build Coastguard Worker@.str = private unnamed_addr constant [17 x i8] c"x = %lu\0Ay = %lu\0A\00", align 1 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Worker; Function Attrs: inlinehint nounwind uwtable 16*9880d681SAndroid Build Coastguard Workerdefine i32 @main() #0 { 17*9880d681SAndroid Build Coastguard Workerentry: 18*9880d681SAndroid Build Coastguard Worker %retval = alloca i32, align 4 19*9880d681SAndroid Build Coastguard Worker %i = alloca i64, align 8 20*9880d681SAndroid Build Coastguard Worker store i32 0, i32* %retval 21*9880d681SAndroid Build Coastguard Worker store i64 0, i64* @y, align 8 22*9880d681SAndroid Build Coastguard Worker store i64 0, i64* @x, align 8 23*9880d681SAndroid Build Coastguard Worker call void @srand(i32 422304) #3 24*9880d681SAndroid Build Coastguard Worker store i64 0, i64* %i, align 8 25*9880d681SAndroid Build Coastguard Worker br label %for.cond 26*9880d681SAndroid Build Coastguard Worker 27*9880d681SAndroid Build Coastguard Workerfor.cond: ; preds = %for.inc, %entry 28*9880d681SAndroid Build Coastguard Worker %0 = load i64, i64* %i, align 8 29*9880d681SAndroid Build Coastguard Worker %cmp = icmp ult i64 %0, 13000000000 30*9880d681SAndroid Build Coastguard Worker br i1 %cmp, label %for.body, label %for.end, !prof !1 31*9880d681SAndroid Build Coastguard Worker 32*9880d681SAndroid Build Coastguard Workerfor.body: ; preds = %for.cond 33*9880d681SAndroid Build Coastguard Worker %call = call i32 @rand() #3 34*9880d681SAndroid Build Coastguard Worker %conv = sitofp i32 %call to double 35*9880d681SAndroid Build Coastguard Worker %mul = fmul double %conv, 1.000000e+02 36*9880d681SAndroid Build Coastguard Worker %div = fdiv double %mul, 0x41E0000000000000 37*9880d681SAndroid Build Coastguard Worker %cmp1 = fcmp ogt double %div, 9.000000e+01 38*9880d681SAndroid Build Coastguard Worker br i1 %cmp1, label %if.then, label %if.else, !prof !2 39*9880d681SAndroid Build Coastguard Worker 40*9880d681SAndroid Build Coastguard Workerif.then: ; preds = %for.body 41*9880d681SAndroid Build Coastguard Worker %1 = load i64, i64* @x, align 8 42*9880d681SAndroid Build Coastguard Worker %inc = add i64 %1, 1 43*9880d681SAndroid Build Coastguard Worker store i64 %inc, i64* @x, align 8 44*9880d681SAndroid Build Coastguard Worker br label %if.end 45*9880d681SAndroid Build Coastguard Worker 46*9880d681SAndroid Build Coastguard Workerif.else: ; preds = %for.body 47*9880d681SAndroid Build Coastguard Worker %2 = load i64, i64* @y, align 8 48*9880d681SAndroid Build Coastguard Worker %inc3 = add i64 %2, 1 49*9880d681SAndroid Build Coastguard Worker store i64 %inc3, i64* @y, align 8 50*9880d681SAndroid Build Coastguard Worker br label %if.end 51*9880d681SAndroid Build Coastguard Worker 52*9880d681SAndroid Build Coastguard Workerif.end: ; preds = %if.else, %if.then 53*9880d681SAndroid Build Coastguard Worker br label %for.inc 54*9880d681SAndroid Build Coastguard Worker 55*9880d681SAndroid Build Coastguard Workerfor.inc: ; preds = %if.end 56*9880d681SAndroid Build Coastguard Worker %3 = load i64, i64* %i, align 8 57*9880d681SAndroid Build Coastguard Worker %inc4 = add i64 %3, 1 58*9880d681SAndroid Build Coastguard Worker store i64 %inc4, i64* %i, align 8 59*9880d681SAndroid Build Coastguard Worker br label %for.cond 60*9880d681SAndroid Build Coastguard Worker 61*9880d681SAndroid Build Coastguard Workerfor.end: ; preds = %for.cond 62*9880d681SAndroid Build Coastguard Worker %4 = load i64, i64* @x, align 8 63*9880d681SAndroid Build Coastguard Worker %5 = load i64, i64* @y, align 8 64*9880d681SAndroid Build Coastguard Worker %call5 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([17 x i8], [17 x i8]* @.str, i32 0, i32 0), i64 %4, i64 %5) 65*9880d681SAndroid Build Coastguard Worker ret i32 0 66*9880d681SAndroid Build Coastguard Worker} 67*9880d681SAndroid Build Coastguard Worker 68*9880d681SAndroid Build Coastguard Worker; Function Attrs: nounwind 69*9880d681SAndroid Build Coastguard Workerdeclare void @srand(i32) #1 70*9880d681SAndroid Build Coastguard Worker 71*9880d681SAndroid Build Coastguard Worker; Function Attrs: nounwind 72*9880d681SAndroid Build Coastguard Workerdeclare i32 @rand() #1 73*9880d681SAndroid Build Coastguard Worker 74*9880d681SAndroid Build Coastguard Workerdeclare i32 @printf(i8*, ...) #2 75*9880d681SAndroid Build Coastguard Worker 76*9880d681SAndroid Build Coastguard Workerattributes #0 = { inlinehint nounwind uwtable "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" "target-cpu"="x86-64" "target-features"="+sse,+sse2" "unsafe-fp-math"="false" "use-soft-float"="false" } 77*9880d681SAndroid Build Coastguard Workerattributes #1 = { 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" "target-cpu"="x86-64" "target-features"="+sse,+sse2" "unsafe-fp-math"="false" "use-soft-float"="false" } 78*9880d681SAndroid Build Coastguard Workerattributes #2 = { "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" "target-cpu"="x86-64" "target-features"="+sse,+sse2" "unsafe-fp-math"="false" "use-soft-float"="false" } 79*9880d681SAndroid Build Coastguard Workerattributes #3 = { nounwind } 80*9880d681SAndroid Build Coastguard Worker 81*9880d681SAndroid Build Coastguard Worker!llvm.ident = !{!0} 82*9880d681SAndroid Build Coastguard Worker 83*9880d681SAndroid Build Coastguard Worker!0 = !{!"clang version 3.7.0 (trunk 236218) (llvm/trunk 236235)"} 84*9880d681SAndroid Build Coastguard Worker!1 = !{!"branch_weights", i32 -1044967295, i32 1} 85*9880d681SAndroid Build Coastguard Worker!2 = !{!"branch_weights", i32 433323762, i32 -394957723} 86