
BlockFrequencyInfo calculates block frequencies as Scaled64 numbers but as a last step converts them to unsigned 64bit integers (`BlockFrequency`). This improves the factors picked for this conversion so that: * Avoid big numbers close to UINT64_MAX to avoid users overflowing/saturating when adding multiply frequencies together or when multiplying with integers. This leaves the topmost 10 bits unused to allow for some room. * Spread the difference between hottest/coldest block as much as possible to increase precision. * If the hot/cold spread cannot be represented loose precision at the lower end, but keep the frequencies at the upper end for hot blocks differentiable.
44 lines
851 B
LLVM
44 lines
851 B
LLVM
; RUN: opt -S -passes=jump-threading %s | FileCheck %s
|
|
|
|
; Test if edge weights are properly updated after jump threading.
|
|
|
|
; CHECK: !2 = !{!"branch_weights", i32 1561806291, i32 585677357}
|
|
|
|
define void @foo(i32 %n) !prof !0 {
|
|
entry:
|
|
%cmp = icmp sgt i32 %n, 10
|
|
br i1 %cmp, label %if.then.1, label %if.else.1, !prof !1
|
|
|
|
if.then.1:
|
|
tail call void @a()
|
|
br label %if.cond
|
|
|
|
if.else.1:
|
|
tail call void @b()
|
|
br label %if.cond
|
|
|
|
if.cond:
|
|
%cmp1 = icmp sgt i32 %n, 5
|
|
br i1 %cmp1, label %if.then.2, label %if.else.2, !prof !2
|
|
|
|
if.then.2:
|
|
tail call void @c()
|
|
br label %if.end
|
|
|
|
if.else.2:
|
|
tail call void @d()
|
|
br label %if.end
|
|
|
|
if.end:
|
|
ret void
|
|
}
|
|
|
|
declare void @a()
|
|
declare void @b()
|
|
declare void @c()
|
|
declare void @d()
|
|
|
|
!0 = !{!"function_entry_count", i64 1}
|
|
!1 = !{!"branch_weights", i32 10, i32 5}
|
|
!2 = !{!"branch_weights", i32 10, i32 1}
|