From b2e6f333e9d22a882b5b30219789065e03278840 Mon Sep 17 00:00:00 2001 From: Pietro Albini Date: Mon, 25 Jan 2021 13:33:24 +0100 Subject: [PATCH] ci: use the monorepo's lockfile when building cargo for pgo profiling --- src/ci/pgo.sh | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/src/ci/pgo.sh b/src/ci/pgo.sh index 13b8ca91f890f..a5f47ca78ff59 100755 --- a/src/ci/pgo.sh +++ b/src/ci/pgo.sh @@ -24,6 +24,20 @@ pgo_perf_benchmark ctfe-stress-4 cp -pri ../src/tools/cargo /tmp/cargo +# The Cargo repository does not have a Cargo.lock in it, as it relies on the +# lockfile already present in the rust-lang/rust monorepo. This decision breaks +# down when Cargo is built outside the monorepo though (like in this case), +# resulting in a build without any dependency locking. +# +# To ensure Cargo is built with locked dependencies even during PGO profiling +# the following command copies the monorepo's lockfile into the Cargo temporary +# directory. Cargo will *not* keep that lockfile intact, as it will remove all +# the dependencies Cargo itself doesn't rely on. Still, it will prevent +# building Cargo with arbitrary dependency versions. +# +# See #81378 for the bug that prompted adding this. +cp -p ../Cargo.lock /tmp/cargo + # Build cargo (with some flags) function pgo_cargo { RUSTC=./build/$PGO_HOST/stage2/bin/rustc \