Skip to content

Commit 4c7d418

Browse files
committed
depends: Improve id string robustness
Environment variables and search paths can drastically effect the operation of build tools. Include these in our id string to mitigate against false cache hits.
1 parent b3bdff4 commit 4c7d418

File tree

1 file changed

+18
-10
lines changed

1 file changed

+18
-10
lines changed

depends/Makefile

Lines changed: 18 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -112,19 +112,27 @@ include builders/$(build_os).mk
112112
include builders/default.mk
113113
include packages/packages.mk
114114

115+
full_env=$(shell printenv)
116+
115117
build_id_string:=$(BUILD_ID_SALT)
116-
build_id_string+=$(shell $(build_CC) --version 2>/dev/null)
117-
build_id_string+=$(shell $(build_AR) --version 2>/dev/null)
118-
build_id_string+=$(shell $(build_CXX) --version 2>/dev/null)
119-
build_id_string+=$(shell $(build_RANLIB) --version 2>/dev/null)
120-
build_id_string+=$(shell $(build_STRIP) --version 2>/dev/null)
118+
119+
# GCC only prints COLLECT_LTO_WRAPPER when invoked with just "-v", but we want
120+
# the information from "-v -E -" as well, so just include both.
121+
#
122+
# '3>&1 1>&2 2>&3 > /dev/null' is supposed to swap stdin and stdout and silence
123+
# stdin, since we only want the stderr output
124+
build_id_string+=$(shell $(build_CC) -v < /dev/null 3>&1 1>&2 2>&3 > /dev/null) $(shell $(build_CC) -v -E - < /dev/null 3>&1 1>&2 2>&3 > /dev/null)
125+
build_id_string+=$(shell $(build_AR) --version 2>/dev/null) $(filter AR_%,$(full_env)) ZERO_AR_DATE=$(ZERO_AR_DATE)
126+
build_id_string+=$(shell $(build_CXX) -v < /dev/null 3>&1 1>&2 2>&3 > /dev/null) $(shell $(build_CXX) -v -E - < /dev/null 3>&1 1>&2 2>&3 > /dev/null)
127+
build_id_string+=$(shell $(build_RANLIB) --version 2>/dev/null) $(filter RANLIB_%,$(full_env))
128+
build_id_string+=$(shell $(build_STRIP) --version 2>/dev/null) $(filter STRIP_%,$(full_env))
121129

122130
$(host_arch)_$(host_os)_id_string:=$(HOST_ID_SALT)
123-
$(host_arch)_$(host_os)_id_string+=$(shell $(host_CC) --version 2>/dev/null)
124-
$(host_arch)_$(host_os)_id_string+=$(shell $(host_AR) --version 2>/dev/null)
125-
$(host_arch)_$(host_os)_id_string+=$(shell $(host_CXX) --version 2>/dev/null)
126-
$(host_arch)_$(host_os)_id_string+=$(shell $(host_RANLIB) --version 2>/dev/null)
127-
$(host_arch)_$(host_os)_id_string+=$(shell $(host_STRIP) --version 2>/dev/null)
131+
$(host_arch)_$(host_os)_id_string+=$(shell $(host_CC) -v < /dev/null 3>&1 1>&2 2>&3 > /dev/null) $(shell $(host_CC) -v -E - < /dev/null 3>&1 1>&2 2>&3 > /dev/null)
132+
$(host_arch)_$(host_os)_id_string+=$(shell $(host_AR) --version 2>/dev/null) $(filter AR_%,$(full_env)) ZERO_AR_DATE=$(ZERO_AR_DATE)
133+
$(host_arch)_$(host_os)_id_string+=$(shell $(host_CXX) -v < /dev/null 3>&1 1>&2 2>&3 > /dev/null) $(shell $(host_CXX) -v -E - < /dev/null 3>&1 1>&2 2>&3 > /dev/null)
134+
$(host_arch)_$(host_os)_id_string+=$(shell $(host_RANLIB) --version 2>/dev/null) $(filter RANLIB_%,$(full_env))
135+
$(host_arch)_$(host_os)_id_string+=$(shell $(host_STRIP) --version 2>/dev/null) $(filter STRIP_%,$(full_env))
128136

129137
ifneq ($(strip $(FORCE_USE_SYSTEM_CLANG)),)
130138
# Make sure that cache is invalidated when switching between system and

0 commit comments

Comments
 (0)