mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-31 20:51:52 +01:00
f6eeeaf04e
This broke Chromium's PGO build, it seems because hot-cold-splitting got turned on unintentionally. See comment on the code review for repro etc. > This patch adds -f[no-]split-cold-code CC1 options to clang. This allows > the splitting pass to be toggled on/off. The current method of passing > `-mllvm -hot-cold-split=true` to clang isn't ideal as it may not compose > correctly (say, with `-O0` or `-Oz`). > > To implement the -fsplit-cold-code option, an attribute is applied to > functions to indicate that they may be considered for splitting. This > removes some complexity from the old/new PM pipeline builders, and > behaves as expected when LTO is enabled. > > Co-authored by: Saleem Abdulrasool <compnerd@compnerd.org> > Differential Revision: https://reviews.llvm.org/D57265 > Reviewed By: Aditya Kumar, Vedant Kumar > Reviewers: Teresa Johnson, Aditya Kumar, Fedor Sergeev, Philip Pfaffe, Vedant Kumar This reverts commit 273c299d5d649a0222fbde03c9a41e41913751b4.
30 lines
759 B
LLVM
30 lines
759 B
LLVM
; RUN: opt -passes="function(slp-vectorizer),module(hotcoldsplit),function(slp-vectorizer,print<assumptions>)" -disable-output %s 2>&1 | FileCheck %s
|
|
;
|
|
; Make sure this compiles. Check that function assumption cache is refreshed
|
|
; after extracting blocks with assume calls from the function.
|
|
|
|
; CHECK: Cached assumptions for function: fun
|
|
; CHECK-NEXT: Cached assumptions for function: fun.cold
|
|
; CHECK-NOT: icmp uge
|
|
|
|
declare void @fun2(i32) #0
|
|
|
|
define void @fun(i32 %x) {
|
|
entry:
|
|
br i1 undef, label %if.then, label %if.else
|
|
|
|
if.then:
|
|
ret void
|
|
|
|
if.else:
|
|
%cmp = icmp uge i32 %x, 64
|
|
call void @llvm.assume(i1 %cmp)
|
|
call void @fun2(i32 %x)
|
|
unreachable
|
|
}
|
|
|
|
declare void @llvm.assume(i1) #1
|
|
|
|
attributes #0 = { alwaysinline }
|
|
attributes #1 = { nounwind }
|