xref: /linux/tools/build/Makefile.feature (revision 60675d4ca1ef0857e44eba5849b74a3a998d0c0f)
1ec8f24b7SThomas Gleixner# SPDX-License-Identifier: GPL-2.0-only
2e6c76d62SJiri Olsafeature_dir := $(srctree)/tools/build/feature
3e6c76d62SJiri Olsa
4e6c76d62SJiri Olsaifneq ($(OUTPUT),)
5e6c76d62SJiri Olsa  OUTPUT_FEATURES = $(OUTPUT)feature/
6e6c76d62SJiri Olsa  $(shell mkdir -p $(OUTPUT_FEATURES))
7e6c76d62SJiri Olsaendif
8e6c76d62SJiri Olsa
9e6c76d62SJiri Olsafeature_check = $(eval $(feature_check_code))
10e6c76d62SJiri Olsadefine feature_check_code
11fa5c8931SDaniel Díaz  feature-$(1) := $(shell $(MAKE) OUTPUT=$(OUTPUT_FEATURES) CC="$(CC)" CXX="$(CXX)" CFLAGS="$(EXTRA_CFLAGS) $(FEATURE_CHECK_CFLAGS-$(1))" CXXFLAGS="$(EXTRA_CXXFLAGS) $(FEATURE_CHECK_CXXFLAGS-$(1))" LDFLAGS="$(LDFLAGS) $(FEATURE_CHECK_LDFLAGS-$(1))" -C $(feature_dir) $(OUTPUT_FEATURES)test-$1.bin >/dev/null 2>/dev/null && echo 1 || echo 0)
12e6c76d62SJiri Olsaendef
13e6c76d62SJiri Olsa
14e6c76d62SJiri Olsafeature_set = $(eval $(feature_set_code))
15e6c76d62SJiri Olsadefine feature_set_code
16e6c76d62SJiri Olsa  feature-$(1) := 1
17e6c76d62SJiri Olsaendef
18e6c76d62SJiri Olsa
19e6c76d62SJiri Olsa#
20e6c76d62SJiri Olsa# Build the feature check binaries in parallel, ignore errors, ignore return value and suppress output:
21e6c76d62SJiri Olsa#
22e6c76d62SJiri Olsa
23e6c76d62SJiri Olsa#
24e6c76d62SJiri Olsa# Note that this is not a complete list of all feature tests, just
25e6c76d62SJiri Olsa# those that are typically built on a fully configured system.
26e6c76d62SJiri Olsa#
27e6c76d62SJiri Olsa# [ Feature tests not mentioned here have to be built explicitly in
28e6c76d62SJiri Olsa#   the rule that uses them - an example for that is the 'bionic'
29e6c76d62SJiri Olsa#   feature check. ]
30e6c76d62SJiri Olsa#
319fd4186aSWang NanFEATURE_TESTS_BASIC :=                  \
32e6c76d62SJiri Olsa        backtrace                       \
33*7c943261SIan Rogers        libdw                           \
3411c6cbe7SArnaldo Carvalho de Melo        eventfd                         \
35e6c76d62SJiri Olsa        fortify-source                  \
368feb8efeSArnaldo Carvalho de Melo        get_current_dir_name            \
374541a8bbSArnaldo Carvalho de Melo        gettid				\
38e6c76d62SJiri Olsa        glibc                           \
39e6c76d62SJiri Olsa        libbfd                          \
40e71e19a9SArnaldo Carvalho de Melo        libbfd-buildid			\
4174d5f3d0SIgor Lubashev        libcap                          \
42e6c76d62SJiri Olsa        libelf                          \
43e6c76d62SJiri Olsa        libelf-getphdrnum               \
441c1a3a47SArnaldo Carvalho de Melo        libelf-gelf_getnote             \
452492c465SArnaldo Carvalho de Melo        libelf-getshdrstrndx            \
46e6c76d62SJiri Olsa        libnuma                         \
47f8ac8606SArnaldo Carvalho de Melo        numa_num_possible_cpus          \
48e6c76d62SJiri Olsa        libperl                         \
49e6c76d62SJiri Olsa        libpython                       \
50e6c76d62SJiri Olsa        libslang                        \
51cbefd24fSArnaldo Carvalho de Melo        libslang-include-subdir         \
5256d32d4cSMichael Petlan        libtraceevent                   \
53b758a61bSIan Rogers        libtracefs                      \
540f59a6c9STomas Glozar        libcpupower                     \
558ee46460SStephane Eranian        libcrypto                       \
56e6c76d62SJiri Olsa        libunwind                       \
57e6c76d62SJiri Olsa        pthread-attr-setaffinity-np     \
5825ab5abfSArnaldo Carvalho de Melo        pthread-barrier     		\
59db42a21aSJakub Kicinski        reallocarray                    \
60e6c76d62SJiri Olsa        stackprotector-all              \
61e6c76d62SJiri Olsa        timerfd                         \
626c6f0f61SJiri Olsa        zlib                            \
63b0063dbfSArnaldo Carvalho de Melo        lzma                            \
64ed63f34cSWang Nan        get_cpuid                       \
65e26e63beSMasami Hiramatsu        bpf                             \
669e03608eSArnaldo Carvalho de Melo        scandirat			\
67120010cbSArnaldo Carvalho de Melo        sched_getcpu			\
6886bcdb5aSArnaldo Carvalho de Melo        sdt				\
69aa6292f4SMathieu Poirier        setns				\
708a1b1718SSong Liu        libaio				\
713b1c5d96SAlexey Budankov        libzstd				\
7249f550eaSNamhyung Kim        disassembler-four-args		\
73cfd59ca9SAndres Freund        disassembler-init-styled	\
7449f550eaSNamhyung Kim        file-handle
75e6c76d62SJiri Olsa
769fd4186aSWang Nan# FEATURE_TESTS_BASIC + FEATURE_TESTS_EXTRA is the complete list
779fd4186aSWang Nan# of all feature tests
789fd4186aSWang NanFEATURE_TESTS_EXTRA :=                  \
799fd4186aSWang Nan         bionic                         \
809fd4186aSWang Nan         compile-32                     \
819fd4186aSWang Nan         compile-x32                    \
829fd4186aSWang Nan         cplus-demangle                 \
834c72e2b3SIan Rogers         cxa-demangle                   \
844751bdddSArnaldo Carvalho de Melo         gtk2                           \
854751bdddSArnaldo Carvalho de Melo         gtk2-infobar                   \
869fd4186aSWang Nan         hello                          \
879fd4186aSWang Nan         libbabeltrace                  \
888b767db3SChangbin Du         libcapstone                    \
8914541b1eSStanislav Fomichev         libbfd-liberty                 \
9014541b1eSStanislav Fomichev         libbfd-liberty-z               \
911c3b28fdSArnaldo Carvalho de Melo         libopencsd                     \
925c4d7c82SArnaldo Carvalho de Melo         libunwind-x86                  \
935c4d7c82SArnaldo Carvalho de Melo         libunwind-x86_64               \
945c4d7c82SArnaldo Carvalho de Melo         libunwind-arm                  \
955c4d7c82SArnaldo Carvalho de Melo         libunwind-aarch64              \
96f9be7eefSHe Kuang         libunwind-debug-frame          \
97f9be7eefSHe Kuang         libunwind-debug-frame-arm      \
98bd476684SJiri Olsa         libunwind-debug-frame-aarch64  \
99bd476684SJiri Olsa         cxx                            \
100bd476684SJiri Olsa         llvm                           \
1017b65e203SJiri Olsa         clang                          \
1025ef86146SStephane Eranian         libbpf                         \
1030ae065a5SArnaldo Carvalho de Melo         libbpf-btf__load_from_kernel_by_id \
1045c83eff3SJiri Olsa         libbpf-bpf_prog_load           \
1058916d725SJiri Olsa         libbpf-bpf_object__next_program \
106739c9180SJiri Olsa         libbpf-bpf_object__next_map    \
107f1bdebbbSArnaldo Carvalho de Melo         libbpf-bpf_program__set_insns  \
108df76e003SArnaldo Carvalho de Melo         libbpf-bpf_create_map		\
109c7a14fdcSFrank Ch. Eigler         libpfm4                        \
110fbcdaa19SSong Liu         libdebuginfod			\
111fbcdaa19SSong Liu         clang-bpf-co-re
112fbcdaa19SSong Liu
1139fd4186aSWang Nan
1149fd4186aSWang NanFEATURE_TESTS ?= $(FEATURE_TESTS_BASIC)
1159fd4186aSWang Nan
1169fd4186aSWang Nanifeq ($(FEATURE_TESTS),all)
1179fd4186aSWang Nan  FEATURE_TESTS := $(FEATURE_TESTS_BASIC) $(FEATURE_TESTS_EXTRA)
1189fd4186aSWang Nanendif
1199fd4186aSWang Nan
1208135c8c7SWang NanFEATURE_DISPLAY ?=              \
121*7c943261SIan Rogers         libdw                  \
122e6c76d62SJiri Olsa         glibc                  \
123e6c76d62SJiri Olsa         libbfd                 \
124e71e19a9SArnaldo Carvalho de Melo         libbfd-buildid		\
12574d5f3d0SIgor Lubashev         libcap                 \
126e6c76d62SJiri Olsa         libelf                 \
127e6c76d62SJiri Olsa         libnuma                \
128f8ac8606SArnaldo Carvalho de Melo         numa_num_possible_cpus \
129e6c76d62SJiri Olsa         libperl                \
130e6c76d62SJiri Olsa         libpython              \
1318ee46460SStephane Eranian         libcrypto              \
132e6c76d62SJiri Olsa         libunwind              \
1338b767db3SChangbin Du         libcapstone            \
134206dcfcaSJames Clark         llvm-perf              \
1356c6f0f61SJiri Olsa         zlib                   \
136b0063dbfSArnaldo Carvalho de Melo         lzma                   \
137ed63f34cSWang Nan         get_cpuid              \
1382a07d814SAlexey Budankov         bpf			\
1398a1b1718SSong Liu         libaio			\
140516ddaadSAndres Freund         libzstd
141e6c76d62SJiri Olsa
14274ef1cc9SRoberto Sassu#
14374ef1cc9SRoberto Sassu# Declare group members of a feature to display the logical OR of the detection
14474ef1cc9SRoberto Sassu# result instead of each member result.
14574ef1cc9SRoberto Sassu#
14674ef1cc9SRoberto SassuFEATURE_GROUP_MEMBERS-libbfd = libbfd-liberty libbfd-liberty-z
14774ef1cc9SRoberto Sassu
1488f61e98aSGuilherme Amadio#
1498f61e98aSGuilherme Amadio# Declare list of feature dependency packages that provide pkg-config files.
1508f61e98aSGuilherme Amadio#
1518f61e98aSGuilherme AmadioFEATURE_PKG_CONFIG ?=           \
1528f61e98aSGuilherme Amadio         libtraceevent          \
1538f61e98aSGuilherme Amadio         libtracefs
1548f61e98aSGuilherme Amadio
1558f61e98aSGuilherme Amadiofeature_pkg_config = $(eval $(feature_pkg_config_code))
1568f61e98aSGuilherme Amadiodefine feature_pkg_config_code
1578f61e98aSGuilherme Amadio  FEATURE_CHECK_CFLAGS-$(1) := $(shell $(PKG_CONFIG) --cflags $(1) 2>/dev/null)
1588f61e98aSGuilherme Amadio  FEATURE_CHECK_LDFLAGS-$(1) := $(shell $(PKG_CONFIG) --libs $(1) 2>/dev/null)
1598f61e98aSGuilherme Amadioendef
1608f61e98aSGuilherme Amadio
1618f61e98aSGuilherme Amadio# Set FEATURE_CHECK_(C|LD)FLAGS-$(package) for packages using pkg-config.
1628f61e98aSGuilherme Amadioifneq ($(PKG_CONFIG),)
1638f61e98aSGuilherme Amadio  $(foreach package,$(FEATURE_PKG_CONFIG),$(call feature_pkg_config,$(package)))
1648f61e98aSGuilherme Amadioendif
1658f61e98aSGuilherme Amadio
166e6c76d62SJiri Olsa# Set FEATURE_CHECK_(C|LD)FLAGS-all for all FEATURE_TESTS features.
167e6c76d62SJiri Olsa# If in the future we need per-feature checks/flags for features not
168e6c76d62SJiri Olsa# mentioned in this list we need to refactor this ;-).
169e6c76d62SJiri Olsaset_test_all_flags = $(eval $(set_test_all_flags_code))
170e6c76d62SJiri Olsadefine set_test_all_flags_code
171e6c76d62SJiri Olsa  FEATURE_CHECK_CFLAGS-all  += $(FEATURE_CHECK_CFLAGS-$(1))
172e6c76d62SJiri Olsa  FEATURE_CHECK_LDFLAGS-all += $(FEATURE_CHECK_LDFLAGS-$(1))
173e6c76d62SJiri Olsaendef
174e6c76d62SJiri Olsa
175e6c76d62SJiri Olsa$(foreach feat,$(FEATURE_TESTS),$(call set_test_all_flags,$(feat)))
176e6c76d62SJiri Olsa
177e6c76d62SJiri Olsa#
178e6c76d62SJiri Olsa# Special fast-path for the 'all features are available' case:
179e6c76d62SJiri Olsa#
180e6c76d62SJiri Olsa$(call feature_check,all,$(MSG))
181e6c76d62SJiri Olsa
182e6c76d62SJiri Olsa#
183e6c76d62SJiri Olsa# Just in case the build freshly failed, make sure we print the
184e6c76d62SJiri Olsa# feature matrix:
185e6c76d62SJiri Olsa#
186e6c76d62SJiri Olsaifeq ($(feature-all), 1)
187e6c76d62SJiri Olsa  #
188e6c76d62SJiri Olsa  # test-all.c passed - just set all the core feature flags to 1:
189e6c76d62SJiri Olsa  #
190e6c76d62SJiri Olsa  $(foreach feat,$(FEATURE_TESTS),$(call feature_set,$(feat)))
19176c4aaecSJiri Olsa  #
19276c4aaecSJiri Olsa  # test-all.c does not comprise these tests, so we need to
19376c4aaecSJiri Olsa  # for this case to get features proper values
19476c4aaecSJiri Olsa  #
19576c4aaecSJiri Olsa  $(call feature_check,compile-32)
19676c4aaecSJiri Olsa  $(call feature_check,compile-x32)
19776c4aaecSJiri Olsa  $(call feature_check,bionic)
19876c4aaecSJiri Olsa  $(call feature_check,libbabeltrace)
199e6c76d62SJiri Olsaelse
200e6c76d62SJiri Olsa  $(foreach feat,$(FEATURE_TESTS),$(call feature_check,$(feat)))
201e6c76d62SJiri Olsaendif
202e6c76d62SJiri Olsa
203e6c76d62SJiri Olsa#
204e6c76d62SJiri Olsa# Print the result of the feature test:
205e6c76d62SJiri Olsa#
206709533e5SRoberto Sassufeature_print_status = $(eval $(feature_print_status_code))
207e6c76d62SJiri Olsa
20874ef1cc9SRoberto Sassufeature_group = $(eval $(feature_gen_group)) $(GROUP)
20974ef1cc9SRoberto Sassu
21074ef1cc9SRoberto Sassudefine feature_gen_group
21174ef1cc9SRoberto Sassu  GROUP := $(1)
21274ef1cc9SRoberto Sassu  ifneq ($(feature_verbose),1)
21374ef1cc9SRoberto Sassu    GROUP += $(FEATURE_GROUP_MEMBERS-$(1))
21474ef1cc9SRoberto Sassu  endif
21574ef1cc9SRoberto Sassuendef
21674ef1cc9SRoberto Sassu
217e6c76d62SJiri Olsadefine feature_print_status_code
21874ef1cc9SRoberto Sassu  ifneq (,$(filter 1,$(foreach feat,$(call feature_group,$(feat)),$(feature-$(feat)))))
21974da7697SRoberto Sassu    MSG = $(shell printf '...%40s: [ \033[32mon\033[m  ]' $(1))
220e6c76d62SJiri Olsa  else
22174da7697SRoberto Sassu    MSG = $(shell printf '...%40s: [ \033[31mOFF\033[m ]' $(1))
222e6c76d62SJiri Olsa  endif
223e6c76d62SJiri Olsaendef
224e6c76d62SJiri Olsa
225709533e5SRoberto Sassufeature_print_text = $(eval $(feature_print_text_code))
226e6c76d62SJiri Olsadefine feature_print_text_code
22774da7697SRoberto Sassu    MSG = $(shell printf '...%40s: %s' $(1) $(2))
228e6c76d62SJiri Olsaendef
229e6c76d62SJiri Olsa
230c6a5f88fSJiri Olsa#
231c6a5f88fSJiri Olsa# generates feature value assignment for name, like:
232*7c943261SIan Rogers#   $(call feature_assign,libdw) == feature-libdw=1
233c6a5f88fSJiri Olsa#
234c6a5f88fSJiri Olsafeature_assign = feature-$(1)=$(feature-$(1))
235c6a5f88fSJiri Olsa
23613e96db6SArnaldo Carvalho de MeloFEATURE_DUMP_FILENAME = $(OUTPUT)FEATURE-DUMP$(FEATURE_USER)
237936d120dSJiri OlsaFEATURE_DUMP := $(shell touch $(FEATURE_DUMP_FILENAME); cat $(FEATURE_DUMP_FILENAME))
238936d120dSJiri Olsa
239936d120dSJiri Olsafeature_dump_check = $(eval $(feature_dump_check_code))
240936d120dSJiri Olsadefine feature_dump_check_code
241936d120dSJiri Olsa  ifeq ($(findstring $(1),$(FEATURE_DUMP)),)
242936d120dSJiri Olsa    $(2) := 1
243936d120dSJiri Olsa  endif
244936d120dSJiri Olsaendef
245936d120dSJiri Olsa
246936d120dSJiri Olsa#
247936d120dSJiri Olsa# First check if any test from FEATURE_DISPLAY
248936d120dSJiri Olsa# and set feature_display := 1 if it does
249936d120dSJiri Olsa$(foreach feat,$(FEATURE_DISPLAY),$(call feature_dump_check,$(call feature_assign,$(feat)),feature_display))
250936d120dSJiri Olsa
251936d120dSJiri Olsa#
252936d120dSJiri Olsa# Now also check if any other test changed,
253936d120dSJiri Olsa# so we force FEATURE-DUMP generation
254936d120dSJiri Olsa$(foreach feat,$(FEATURE_TESTS),$(call feature_dump_check,$(call feature_assign,$(feat)),feature_dump_changed))
255e6c76d62SJiri Olsa
256e6c76d62SJiri Olsa# The $(feature_display) controls the default detection message
257e6c76d62SJiri Olsa# output. It's set if:
258e6c76d62SJiri Olsa# - detected features differes from stored features from
25913e96db6SArnaldo Carvalho de Melo#   last build (in $(FEATURE_DUMP_FILENAME) file)
260e6c76d62SJiri Olsa# - one of the $(FEATURE_DISPLAY) is not detected
261e6c76d62SJiri Olsa# - VF is enabled
262e6c76d62SJiri Olsa
263936d120dSJiri Olsaifeq ($(feature_dump_changed),1)
264936d120dSJiri Olsa  $(shell rm -f $(FEATURE_DUMP_FILENAME))
265936d120dSJiri Olsa  $(foreach feat,$(FEATURE_TESTS),$(shell echo "$(call feature_assign,$(feat))" >> $(FEATURE_DUMP_FILENAME)))
266e6c76d62SJiri Olsaendif
267e6c76d62SJiri Olsa
2686076e2a4SArnaldo Carvalho de Melofeature_display_check = $(eval $(feature_check_display_code))
269d0018b49SJiri Olsadefine feature_check_display_code
270e6c76d62SJiri Olsa  ifneq ($(feature-$(1)), 1)
271e6c76d62SJiri Olsa    feature_display := 1
272e6c76d62SJiri Olsa  endif
273e6c76d62SJiri Olsaendef
274e6c76d62SJiri Olsa
275e6c76d62SJiri Olsa$(foreach feat,$(FEATURE_DISPLAY),$(call feature_display_check,$(feat)))
276e6c76d62SJiri Olsa
277e6c76d62SJiri Olsaifeq ($(VF),1)
278e6c76d62SJiri Olsa  feature_display := 1
279e6c76d62SJiri Olsa  feature_verbose := 1
280e6c76d62SJiri Olsaendif
281e6c76d62SJiri Olsa
28274ef1cc9SRoberto Sassuifneq ($(feature_verbose),1)
28374ef1cc9SRoberto Sassu  #
28474ef1cc9SRoberto Sassu  # Determine the features to omit from the displayed message, as only the
28574ef1cc9SRoberto Sassu  # logical OR of the detection result will be shown.
28674ef1cc9SRoberto Sassu  #
28774ef1cc9SRoberto Sassu  FEATURE_OMIT := $(foreach feat,$(FEATURE_DISPLAY),$(FEATURE_GROUP_MEMBERS-$(feat)))
28874ef1cc9SRoberto Sassuendif
28974ef1cc9SRoberto Sassu
29019177bc3SArnaldo Carvalho de Melofeature_display_entries = $(eval $(feature_display_entries_code))
29119177bc3SArnaldo Carvalho de Melodefine feature_display_entries_code
292e6c76d62SJiri Olsa  ifeq ($(feature_display),1)
293709533e5SRoberto Sassu    $$(info )
294709533e5SRoberto Sassu    $$(info Auto-detecting system features:)
29574ef1cc9SRoberto Sassu    $(foreach feat,$(filter-out $(FEATURE_OMIT),$(FEATURE_DISPLAY)),$(call feature_print_status,$(feat),) $$(info $(MSG)))
296e6c76d62SJiri Olsa  endif
297e6c76d62SJiri Olsa
298e6c76d62SJiri Olsa  ifeq ($(feature_verbose),1)
299709533e5SRoberto Sassu    $(eval TMP := $(filter-out $(FEATURE_DISPLAY),$(FEATURE_TESTS)))
300709533e5SRoberto Sassu    $(foreach feat,$(TMP),$(call feature_print_status,$(feat),) $$(info $(MSG)))
301e6c76d62SJiri Olsa  endif
30219177bc3SArnaldo Carvalho de Meloendef
30319177bc3SArnaldo Carvalho de Melo
30419177bc3SArnaldo Carvalho de Meloifeq ($(FEATURE_DISPLAY_DEFERRED),)
30519177bc3SArnaldo Carvalho de Melo  $(call feature_display_entries)
306709533e5SRoberto Sassu  $(info )
30719177bc3SArnaldo Carvalho de Meloendif
308