xref: /linux/tools/build/Makefile.feature (revision 3a39d672e7f48b8d6b91a09afa4b55352773b4b5)
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                       \
33e6c76d62SJiri Olsa        dwarf                           \
34bd0419e2SArnaldo Carvalho de Melo        dwarf_getlocations              \
35f67f2fdaSNamhyung Kim        dwarf_getcfi                    \
3611c6cbe7SArnaldo Carvalho de Melo        eventfd                         \
37e6c76d62SJiri Olsa        fortify-source                  \
388feb8efeSArnaldo Carvalho de Melo        get_current_dir_name            \
394541a8bbSArnaldo Carvalho de Melo        gettid				\
40e6c76d62SJiri Olsa        glibc                           \
41e6c76d62SJiri Olsa        libbfd                          \
42e71e19a9SArnaldo Carvalho de Melo        libbfd-buildid			\
4374d5f3d0SIgor Lubashev        libcap                          \
44e6c76d62SJiri Olsa        libelf                          \
45e6c76d62SJiri Olsa        libelf-getphdrnum               \
461c1a3a47SArnaldo Carvalho de Melo        libelf-gelf_getnote             \
472492c465SArnaldo Carvalho de Melo        libelf-getshdrstrndx            \
48e6c76d62SJiri Olsa        libnuma                         \
49f8ac8606SArnaldo Carvalho de Melo        numa_num_possible_cpus          \
50e6c76d62SJiri Olsa        libperl                         \
51e6c76d62SJiri Olsa        libpython                       \
52e6c76d62SJiri Olsa        libslang                        \
53cbefd24fSArnaldo Carvalho de Melo        libslang-include-subdir         \
5456d32d4cSMichael Petlan        libtraceevent                   \
55b758a61bSIan Rogers        libtracefs                      \
568ee46460SStephane Eranian        libcrypto                       \
57e6c76d62SJiri Olsa        libunwind                       \
58e6c76d62SJiri Olsa        pthread-attr-setaffinity-np     \
5925ab5abfSArnaldo Carvalho de Melo        pthread-barrier     		\
60db42a21aSJakub Kicinski        reallocarray                    \
61e6c76d62SJiri Olsa        stackprotector-all              \
62e6c76d62SJiri Olsa        timerfd                         \
63e6c76d62SJiri Olsa        libdw-dwarf-unwind              \
646c6f0f61SJiri Olsa        zlib                            \
65b0063dbfSArnaldo Carvalho de Melo        lzma                            \
66ed63f34cSWang Nan        get_cpuid                       \
67e26e63beSMasami Hiramatsu        bpf                             \
689e03608eSArnaldo Carvalho de Melo        scandirat			\
69120010cbSArnaldo Carvalho de Melo        sched_getcpu			\
7086bcdb5aSArnaldo Carvalho de Melo        sdt				\
71aa6292f4SMathieu Poirier        setns				\
728a1b1718SSong Liu        libaio				\
733b1c5d96SAlexey Budankov        libzstd				\
7449f550eaSNamhyung Kim        disassembler-four-args		\
75cfd59ca9SAndres Freund        disassembler-init-styled	\
7649f550eaSNamhyung Kim        file-handle
77e6c76d62SJiri Olsa
789fd4186aSWang Nan# FEATURE_TESTS_BASIC + FEATURE_TESTS_EXTRA is the complete list
799fd4186aSWang Nan# of all feature tests
809fd4186aSWang NanFEATURE_TESTS_EXTRA :=                  \
819fd4186aSWang Nan         bionic                         \
829fd4186aSWang Nan         compile-32                     \
839fd4186aSWang Nan         compile-x32                    \
849fd4186aSWang Nan         cplus-demangle                 \
854c72e2b3SIan Rogers         cxa-demangle                   \
864751bdddSArnaldo Carvalho de Melo         gtk2                           \
874751bdddSArnaldo Carvalho de Melo         gtk2-infobar                   \
889fd4186aSWang Nan         hello                          \
899fd4186aSWang Nan         libbabeltrace                  \
908b767db3SChangbin Du         libcapstone                    \
9114541b1eSStanislav Fomichev         libbfd-liberty                 \
9214541b1eSStanislav Fomichev         libbfd-liberty-z               \
931c3b28fdSArnaldo Carvalho de Melo         libopencsd                     \
945c4d7c82SArnaldo Carvalho de Melo         libunwind-x86                  \
955c4d7c82SArnaldo Carvalho de Melo         libunwind-x86_64               \
965c4d7c82SArnaldo Carvalho de Melo         libunwind-arm                  \
975c4d7c82SArnaldo Carvalho de Melo         libunwind-aarch64              \
98f9be7eefSHe Kuang         libunwind-debug-frame          \
99f9be7eefSHe Kuang         libunwind-debug-frame-arm      \
100bd476684SJiri Olsa         libunwind-debug-frame-aarch64  \
101bd476684SJiri Olsa         cxx                            \
102bd476684SJiri Olsa         llvm                           \
1037b65e203SJiri Olsa         clang                          \
1045ef86146SStephane Eranian         libbpf                         \
1050ae065a5SArnaldo Carvalho de Melo         libbpf-btf__load_from_kernel_by_id \
1065c83eff3SJiri Olsa         libbpf-bpf_prog_load           \
1078916d725SJiri Olsa         libbpf-bpf_object__next_program \
108739c9180SJiri Olsa         libbpf-bpf_object__next_map    \
109f1bdebbbSArnaldo Carvalho de Melo         libbpf-bpf_program__set_insns  \
110df76e003SArnaldo Carvalho de Melo         libbpf-bpf_create_map		\
111c7a14fdcSFrank Ch. Eigler         libpfm4                        \
112fbcdaa19SSong Liu         libdebuginfod			\
113fbcdaa19SSong Liu         clang-bpf-co-re
114fbcdaa19SSong Liu
1159fd4186aSWang Nan
1169fd4186aSWang NanFEATURE_TESTS ?= $(FEATURE_TESTS_BASIC)
1179fd4186aSWang Nan
1189fd4186aSWang Nanifeq ($(FEATURE_TESTS),all)
1199fd4186aSWang Nan  FEATURE_TESTS := $(FEATURE_TESTS_BASIC) $(FEATURE_TESTS_EXTRA)
1209fd4186aSWang Nanendif
1219fd4186aSWang Nan
1228135c8c7SWang NanFEATURE_DISPLAY ?=              \
123e6c76d62SJiri Olsa         dwarf                  \
124bd0419e2SArnaldo Carvalho de Melo         dwarf_getlocations     \
125e6c76d62SJiri Olsa         glibc                  \
126e6c76d62SJiri Olsa         libbfd                 \
127e71e19a9SArnaldo Carvalho de Melo         libbfd-buildid		\
12874d5f3d0SIgor Lubashev         libcap                 \
129e6c76d62SJiri Olsa         libelf                 \
130e6c76d62SJiri Olsa         libnuma                \
131f8ac8606SArnaldo Carvalho de Melo         numa_num_possible_cpus \
132e6c76d62SJiri Olsa         libperl                \
133e6c76d62SJiri Olsa         libpython              \
1348ee46460SStephane Eranian         libcrypto              \
135e6c76d62SJiri Olsa         libunwind              \
136e6c76d62SJiri Olsa         libdw-dwarf-unwind     \
1378b767db3SChangbin Du         libcapstone            \
138*206dcfcaSJames Clark         llvm-perf              \
1396c6f0f61SJiri Olsa         zlib                   \
140b0063dbfSArnaldo Carvalho de Melo         lzma                   \
141ed63f34cSWang Nan         get_cpuid              \
1422a07d814SAlexey Budankov         bpf			\
1438a1b1718SSong Liu         libaio			\
144516ddaadSAndres Freund         libzstd
145e6c76d62SJiri Olsa
14674ef1cc9SRoberto Sassu#
14774ef1cc9SRoberto Sassu# Declare group members of a feature to display the logical OR of the detection
14874ef1cc9SRoberto Sassu# result instead of each member result.
14974ef1cc9SRoberto Sassu#
15074ef1cc9SRoberto SassuFEATURE_GROUP_MEMBERS-libbfd = libbfd-liberty libbfd-liberty-z
15174ef1cc9SRoberto Sassu
1528f61e98aSGuilherme Amadio#
1538f61e98aSGuilherme Amadio# Declare list of feature dependency packages that provide pkg-config files.
1548f61e98aSGuilherme Amadio#
1558f61e98aSGuilherme AmadioFEATURE_PKG_CONFIG ?=           \
1568f61e98aSGuilherme Amadio         libtraceevent          \
1578f61e98aSGuilherme Amadio         libtracefs
1588f61e98aSGuilherme Amadio
1598f61e98aSGuilherme Amadiofeature_pkg_config = $(eval $(feature_pkg_config_code))
1608f61e98aSGuilherme Amadiodefine feature_pkg_config_code
1618f61e98aSGuilherme Amadio  FEATURE_CHECK_CFLAGS-$(1) := $(shell $(PKG_CONFIG) --cflags $(1) 2>/dev/null)
1628f61e98aSGuilherme Amadio  FEATURE_CHECK_LDFLAGS-$(1) := $(shell $(PKG_CONFIG) --libs $(1) 2>/dev/null)
1638f61e98aSGuilherme Amadioendef
1648f61e98aSGuilherme Amadio
1658f61e98aSGuilherme Amadio# Set FEATURE_CHECK_(C|LD)FLAGS-$(package) for packages using pkg-config.
1668f61e98aSGuilherme Amadioifneq ($(PKG_CONFIG),)
1678f61e98aSGuilherme Amadio  $(foreach package,$(FEATURE_PKG_CONFIG),$(call feature_pkg_config,$(package)))
1688f61e98aSGuilherme Amadioendif
1698f61e98aSGuilherme Amadio
170e6c76d62SJiri Olsa# Set FEATURE_CHECK_(C|LD)FLAGS-all for all FEATURE_TESTS features.
171e6c76d62SJiri Olsa# If in the future we need per-feature checks/flags for features not
172e6c76d62SJiri Olsa# mentioned in this list we need to refactor this ;-).
173e6c76d62SJiri Olsaset_test_all_flags = $(eval $(set_test_all_flags_code))
174e6c76d62SJiri Olsadefine set_test_all_flags_code
175e6c76d62SJiri Olsa  FEATURE_CHECK_CFLAGS-all  += $(FEATURE_CHECK_CFLAGS-$(1))
176e6c76d62SJiri Olsa  FEATURE_CHECK_LDFLAGS-all += $(FEATURE_CHECK_LDFLAGS-$(1))
177e6c76d62SJiri Olsaendef
178e6c76d62SJiri Olsa
179e6c76d62SJiri Olsa$(foreach feat,$(FEATURE_TESTS),$(call set_test_all_flags,$(feat)))
180e6c76d62SJiri Olsa
181e6c76d62SJiri Olsa#
182e6c76d62SJiri Olsa# Special fast-path for the 'all features are available' case:
183e6c76d62SJiri Olsa#
184e6c76d62SJiri Olsa$(call feature_check,all,$(MSG))
185e6c76d62SJiri Olsa
186e6c76d62SJiri Olsa#
187e6c76d62SJiri Olsa# Just in case the build freshly failed, make sure we print the
188e6c76d62SJiri Olsa# feature matrix:
189e6c76d62SJiri Olsa#
190e6c76d62SJiri Olsaifeq ($(feature-all), 1)
191e6c76d62SJiri Olsa  #
192e6c76d62SJiri Olsa  # test-all.c passed - just set all the core feature flags to 1:
193e6c76d62SJiri Olsa  #
194e6c76d62SJiri Olsa  $(foreach feat,$(FEATURE_TESTS),$(call feature_set,$(feat)))
19576c4aaecSJiri Olsa  #
19676c4aaecSJiri Olsa  # test-all.c does not comprise these tests, so we need to
19776c4aaecSJiri Olsa  # for this case to get features proper values
19876c4aaecSJiri Olsa  #
19976c4aaecSJiri Olsa  $(call feature_check,compile-32)
20076c4aaecSJiri Olsa  $(call feature_check,compile-x32)
20176c4aaecSJiri Olsa  $(call feature_check,bionic)
20276c4aaecSJiri Olsa  $(call feature_check,libbabeltrace)
203e6c76d62SJiri Olsaelse
204e6c76d62SJiri Olsa  $(foreach feat,$(FEATURE_TESTS),$(call feature_check,$(feat)))
205e6c76d62SJiri Olsaendif
206e6c76d62SJiri Olsa
207e6c76d62SJiri Olsa#
208e6c76d62SJiri Olsa# Print the result of the feature test:
209e6c76d62SJiri Olsa#
210709533e5SRoberto Sassufeature_print_status = $(eval $(feature_print_status_code))
211e6c76d62SJiri Olsa
21274ef1cc9SRoberto Sassufeature_group = $(eval $(feature_gen_group)) $(GROUP)
21374ef1cc9SRoberto Sassu
21474ef1cc9SRoberto Sassudefine feature_gen_group
21574ef1cc9SRoberto Sassu  GROUP := $(1)
21674ef1cc9SRoberto Sassu  ifneq ($(feature_verbose),1)
21774ef1cc9SRoberto Sassu    GROUP += $(FEATURE_GROUP_MEMBERS-$(1))
21874ef1cc9SRoberto Sassu  endif
21974ef1cc9SRoberto Sassuendef
22074ef1cc9SRoberto Sassu
221e6c76d62SJiri Olsadefine feature_print_status_code
22274ef1cc9SRoberto Sassu  ifneq (,$(filter 1,$(foreach feat,$(call feature_group,$(feat)),$(feature-$(feat)))))
22374da7697SRoberto Sassu    MSG = $(shell printf '...%40s: [ \033[32mon\033[m  ]' $(1))
224e6c76d62SJiri Olsa  else
22574da7697SRoberto Sassu    MSG = $(shell printf '...%40s: [ \033[31mOFF\033[m ]' $(1))
226e6c76d62SJiri Olsa  endif
227e6c76d62SJiri Olsaendef
228e6c76d62SJiri Olsa
229709533e5SRoberto Sassufeature_print_text = $(eval $(feature_print_text_code))
230e6c76d62SJiri Olsadefine feature_print_text_code
23174da7697SRoberto Sassu    MSG = $(shell printf '...%40s: %s' $(1) $(2))
232e6c76d62SJiri Olsaendef
233e6c76d62SJiri Olsa
234c6a5f88fSJiri Olsa#
235c6a5f88fSJiri Olsa# generates feature value assignment for name, like:
236c6a5f88fSJiri Olsa#   $(call feature_assign,dwarf) == feature-dwarf=1
237c6a5f88fSJiri Olsa#
238c6a5f88fSJiri Olsafeature_assign = feature-$(1)=$(feature-$(1))
239c6a5f88fSJiri Olsa
24013e96db6SArnaldo Carvalho de MeloFEATURE_DUMP_FILENAME = $(OUTPUT)FEATURE-DUMP$(FEATURE_USER)
241936d120dSJiri OlsaFEATURE_DUMP := $(shell touch $(FEATURE_DUMP_FILENAME); cat $(FEATURE_DUMP_FILENAME))
242936d120dSJiri Olsa
243936d120dSJiri Olsafeature_dump_check = $(eval $(feature_dump_check_code))
244936d120dSJiri Olsadefine feature_dump_check_code
245936d120dSJiri Olsa  ifeq ($(findstring $(1),$(FEATURE_DUMP)),)
246936d120dSJiri Olsa    $(2) := 1
247936d120dSJiri Olsa  endif
248936d120dSJiri Olsaendef
249936d120dSJiri Olsa
250936d120dSJiri Olsa#
251936d120dSJiri Olsa# First check if any test from FEATURE_DISPLAY
252936d120dSJiri Olsa# and set feature_display := 1 if it does
253936d120dSJiri Olsa$(foreach feat,$(FEATURE_DISPLAY),$(call feature_dump_check,$(call feature_assign,$(feat)),feature_display))
254936d120dSJiri Olsa
255936d120dSJiri Olsa#
256936d120dSJiri Olsa# Now also check if any other test changed,
257936d120dSJiri Olsa# so we force FEATURE-DUMP generation
258936d120dSJiri Olsa$(foreach feat,$(FEATURE_TESTS),$(call feature_dump_check,$(call feature_assign,$(feat)),feature_dump_changed))
259e6c76d62SJiri Olsa
260e6c76d62SJiri Olsa# The $(feature_display) controls the default detection message
261e6c76d62SJiri Olsa# output. It's set if:
262e6c76d62SJiri Olsa# - detected features differes from stored features from
26313e96db6SArnaldo Carvalho de Melo#   last build (in $(FEATURE_DUMP_FILENAME) file)
264e6c76d62SJiri Olsa# - one of the $(FEATURE_DISPLAY) is not detected
265e6c76d62SJiri Olsa# - VF is enabled
266e6c76d62SJiri Olsa
267936d120dSJiri Olsaifeq ($(feature_dump_changed),1)
268936d120dSJiri Olsa  $(shell rm -f $(FEATURE_DUMP_FILENAME))
269936d120dSJiri Olsa  $(foreach feat,$(FEATURE_TESTS),$(shell echo "$(call feature_assign,$(feat))" >> $(FEATURE_DUMP_FILENAME)))
270e6c76d62SJiri Olsaendif
271e6c76d62SJiri Olsa
2726076e2a4SArnaldo Carvalho de Melofeature_display_check = $(eval $(feature_check_display_code))
273d0018b49SJiri Olsadefine feature_check_display_code
274e6c76d62SJiri Olsa  ifneq ($(feature-$(1)), 1)
275e6c76d62SJiri Olsa    feature_display := 1
276e6c76d62SJiri Olsa  endif
277e6c76d62SJiri Olsaendef
278e6c76d62SJiri Olsa
279e6c76d62SJiri Olsa$(foreach feat,$(FEATURE_DISPLAY),$(call feature_display_check,$(feat)))
280e6c76d62SJiri Olsa
281e6c76d62SJiri Olsaifeq ($(VF),1)
282e6c76d62SJiri Olsa  feature_display := 1
283e6c76d62SJiri Olsa  feature_verbose := 1
284e6c76d62SJiri Olsaendif
285e6c76d62SJiri Olsa
28674ef1cc9SRoberto Sassuifneq ($(feature_verbose),1)
28774ef1cc9SRoberto Sassu  #
28874ef1cc9SRoberto Sassu  # Determine the features to omit from the displayed message, as only the
28974ef1cc9SRoberto Sassu  # logical OR of the detection result will be shown.
29074ef1cc9SRoberto Sassu  #
29174ef1cc9SRoberto Sassu  FEATURE_OMIT := $(foreach feat,$(FEATURE_DISPLAY),$(FEATURE_GROUP_MEMBERS-$(feat)))
29274ef1cc9SRoberto Sassuendif
29374ef1cc9SRoberto Sassu
29419177bc3SArnaldo Carvalho de Melofeature_display_entries = $(eval $(feature_display_entries_code))
29519177bc3SArnaldo Carvalho de Melodefine feature_display_entries_code
296e6c76d62SJiri Olsa  ifeq ($(feature_display),1)
297709533e5SRoberto Sassu    $$(info )
298709533e5SRoberto Sassu    $$(info Auto-detecting system features:)
29974ef1cc9SRoberto Sassu    $(foreach feat,$(filter-out $(FEATURE_OMIT),$(FEATURE_DISPLAY)),$(call feature_print_status,$(feat),) $$(info $(MSG)))
300e6c76d62SJiri Olsa  endif
301e6c76d62SJiri Olsa
302e6c76d62SJiri Olsa  ifeq ($(feature_verbose),1)
303709533e5SRoberto Sassu    $(eval TMP := $(filter-out $(FEATURE_DISPLAY),$(FEATURE_TESTS)))
304709533e5SRoberto Sassu    $(foreach feat,$(TMP),$(call feature_print_status,$(feat),) $$(info $(MSG)))
305e6c76d62SJiri Olsa  endif
30619177bc3SArnaldo Carvalho de Meloendef
30719177bc3SArnaldo Carvalho de Melo
30819177bc3SArnaldo Carvalho de Meloifeq ($(FEATURE_DISPLAY_DEFERRED),)
30919177bc3SArnaldo Carvalho de Melo  $(call feature_display_entries)
310709533e5SRoberto Sassu  $(info )
31119177bc3SArnaldo Carvalho de Meloendif
312