5 # Compile several crates to gather execution PGO profiles.
6 # Arg0 => builds (Debug, Opt)
7 # Arg1 => runs (Full, IncrFull, All)
8 # Arg2 => crates (syn, cargo, ...)
12 # Compile libcore, both in opt-level=0 and opt-level=3
13 RUSTC_BOOTSTRAP=1 ./build/$PGO_HOST/stage2/bin/rustc \
14 --edition=2021 --crate-type=lib ../library/core/src/lib.rs
15 RUSTC_BOOTSTRAP=1 ./build/$PGO_HOST/stage2/bin/rustc \
16 --edition=2021 --crate-type=lib -Copt-level=3 ../library/core/src/lib.rs
20 # Run rustc-perf benchmarks
21 # Benchmark using profile_local with eprintln, which essentially just means
22 # don't actually benchmark -- just make sure we run rustc a bunch of times.
23 RUST_LOG=collector=debug \
24 RUSTC=/checkout/obj/build/$PGO_HOST/stage0/bin/rustc \
26 /checkout/obj/build/$PGO_HOST/stage0/bin/cargo run -p collector --bin collector -- \
29 /checkout/obj/build/$PGO_HOST/stage2/bin/rustc \
32 --cargo /checkout/obj/build/$PGO_HOST/stage0/bin/cargo \
41 # We collect LLVM profiling information and rustc profiling information in
42 # separate phases. This increases build time -- though not by a huge amount --
43 # but prevents any problems from arising due to different profiling runtimes
44 # being simultaneously linked in.
46 python3 ../x.py build --target=$PGO_HOST --host=$PGO_HOST \
47 --stage 2 library/std \
48 --llvm-profile-generate
50 # Profile libcore compilation in opt-level=0 and opt-level=3
51 RUSTC_BOOTSTRAP=1 ./build/$PGO_HOST/stage2/bin/rustc \
52 --edition=2021 --crate-type=lib ../library/core/src/lib.rs
53 RUSTC_BOOTSTRAP=1 ./build/$PGO_HOST/stage2/bin/rustc \
54 --edition=2021 --crate-type=lib -Copt-level=3 ../library/core/src/lib.rs
57 cp -r /tmp/rustc-perf ./
58 chown -R $(whoami): ./rustc-perf
61 # Build the collector ahead of time, which is needed to make sure the rustc-fake
62 # binary used by the collector is present.
63 RUSTC=/checkout/obj/build/$PGO_HOST/stage0/bin/rustc \
65 /checkout/obj/build/$PGO_HOST/stage0/bin/cargo build -p collector
67 gather_profiles "Debug,Opt" "Full" "syn,cargo,serde,ripgrep,regex,clap-rs,hyper-2"
69 # Merge the profile data we gathered for LLVM
70 # Note that this uses the profdata from the clang we used to build LLVM,
71 # which likely has a different version than our in-tree clang.
72 /rustroot/bin/llvm-profdata \
73 merge -o /tmp/llvm-pgo.profdata ./build/$PGO_HOST/llvm/build/profiles
75 # Rustbuild currently doesn't support rebuilding LLVM when PGO options
76 # change (or any other llvm-related options); so just clear out the relevant
77 # directories ourselves.
78 rm -r ./build/$PGO_HOST/llvm ./build/$PGO_HOST/lld
80 # Okay, LLVM profiling is done, switch to rustc PGO.
82 python3 ../x.py build --target=$PGO_HOST --host=$PGO_HOST \
83 --stage 2 library/std \
84 --rust-profile-generate=/tmp/rustc-pgo
86 gather_profiles "Check,Debug,Opt" "All" \
87 "externs,ctfe-stress-4,inflate,cargo,token-stream-stress,match-stress-enum"
89 # Merge the profile data we gathered
90 ./build/$PGO_HOST/llvm/bin/llvm-profdata \
91 merge -o /tmp/rustc-pgo.profdata /tmp/rustc-pgo
93 # Rustbuild currently doesn't support rebuilding LLVM when PGO options
94 # change (or any other llvm-related options); so just clear out the relevant
95 # directories ourselves.
96 rm -r ./build/$PGO_HOST/llvm ./build/$PGO_HOST/lld
98 # This produces the actual final set of artifacts, using both the LLVM and rustc
99 # collected profiling data.
101 --rust-profile-use=/tmp/rustc-pgo.profdata \
102 --llvm-profile-use=/tmp/llvm-pgo.profdata