Matthias Braun e3cf80c5c1
BlockFrequencyInfoImpl: Avoid big numbers, increase precision for small spreads
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.
2023-10-24 20:27:39 -07:00

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}