2019-04-25 13:11:08 +02:00
|
|
|
# needs-profiler-support
|
2020-08-24 11:58:04 +02:00
|
|
|
# ignore-windows-gnu
|
2023-08-30 13:45:57 +02:00
|
|
|
# ignore-cross-compile
|
2020-08-24 11:58:04 +02:00
|
|
|
|
|
|
|
# FIXME(mati865): MinGW GCC miscompiles compiler-rt profiling library but with Clang it works
|
|
|
|
# properly. Since we only have GCC on the CI ignore the test for now.
|
2019-04-25 13:11:08 +02:00
|
|
|
|
2022-08-23 00:00:00 +00:00
|
|
|
include ../tools.mk
|
2019-04-25 13:11:08 +02:00
|
|
|
|
|
|
|
# This test makes sure that PGO profiling data leads to cold functions being
|
|
|
|
# marked as `cold` and hot functions with `inlinehint`.
|
|
|
|
# The test program contains an `if` were actual execution only ever takes the
|
|
|
|
# `else` branch. Accordingly, we expect the function that is never called to
|
|
|
|
# be marked as cold.
|
|
|
|
#
|
2021-03-03 17:58:39 +01:00
|
|
|
# Disable the pre-inlining pass (i.e. a pass that does some inlining before
|
|
|
|
# it adds the profiling instrumentation). Disabling this pass leads to
|
|
|
|
# rather predictable IR which we need for this test to be stable.
|
2019-04-25 13:11:08 +02:00
|
|
|
|
2021-03-03 17:58:39 +01:00
|
|
|
COMMON_FLAGS=-Copt-level=2 -Ccodegen-units=1 -Cllvm-args=-disable-preinline
|
2019-04-25 13:11:08 +02:00
|
|
|
|
2019-04-30 17:38:01 +02:00
|
|
|
ifeq ($(UNAME),Darwin)
|
|
|
|
# macOS does not have the `tac` command, but `tail -r` does the same thing
|
|
|
|
TAC := tail -r
|
|
|
|
else
|
|
|
|
# some other platforms don't support the `-r` flag for `tail`, so use `tac`
|
|
|
|
TAC := tac
|
|
|
|
endif
|
|
|
|
|
2019-04-25 13:11:08 +02:00
|
|
|
all:
|
|
|
|
# Compile the test program with instrumentation
|
2019-05-28 16:48:03 +02:00
|
|
|
$(RUSTC) $(COMMON_FLAGS) -Cprofile-generate="$(TMPDIR)" main.rs
|
2019-04-25 13:11:08 +02:00
|
|
|
# Run it in order to generate some profiling data
|
|
|
|
$(call RUN,main some-argument) || exit 1
|
|
|
|
# Postprocess the profiling data so it can be used by the compiler
|
2019-04-29 14:40:07 +02:00
|
|
|
"$(LLVM_BIN_DIR)"/llvm-profdata merge \
|
2019-04-25 13:11:08 +02:00
|
|
|
-o "$(TMPDIR)"/merged.profdata \
|
|
|
|
"$(TMPDIR)"/default_*.profraw
|
|
|
|
# Compile the test program again, making use of the profiling data
|
2019-05-28 16:48:03 +02:00
|
|
|
$(RUSTC) $(COMMON_FLAGS) -Cprofile-use="$(TMPDIR)"/merged.profdata --emit=llvm-ir main.rs
|
2019-04-25 13:11:08 +02:00
|
|
|
# Check that the generate IR contains some things that we expect
|
|
|
|
#
|
|
|
|
# We feed the file into LLVM FileCheck tool *in reverse* so that we see the
|
|
|
|
# line with the function name before the line with the function attributes.
|
|
|
|
# FileCheck only supports checking that something matches on the next line,
|
|
|
|
# but not if something matches on the previous line.
|
2019-04-30 17:38:01 +02:00
|
|
|
$(TAC) "$(TMPDIR)"/main.ll | "$(LLVM_FILECHECK)" filecheck-patterns.txt
|