xref: /linux/tools/build/Makefile.feature (revision 0f59a6c9c421a44e652353e3ec15cf2425b904fe)
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                      \
56*0f59a6c9STomas Glozar        libcpupower                     \
578ee46460SStephane Eranian        libcrypto                       \
58e6c76d62SJiri Olsa        libunwind                       \
59e6c76d62SJiri Olsa        pthread-attr-setaffinity-np     \
6025ab5abfSArnaldo Carvalho de Melo        pthread-barrier     		\
61db42a21aSJakub Kicinski        reallocarray                    \
62e6c76d62SJiri Olsa        stackprotector-all              \
63e6c76d62SJiri Olsa        timerfd                         \
64e6c76d62SJiri Olsa        libdw-dwarf-unwind              \
656c6f0f61SJiri Olsa        zlib                            \
66b0063dbfSArnaldo Carvalho de Melo        lzma                            \
67ed63f34cSWang Nan        get_cpuid                       \
68e26e63beSMasami Hiramatsu        bpf                             \
699e03608eSArnaldo Carvalho de Melo        scandirat			\
70120010cbSArnaldo Carvalho de Melo        sched_getcpu			\
7186bcdb5aSArnaldo Carvalho de Melo        sdt				\
72aa6292f4SMathieu Poirier        setns				\
738a1b1718SSong Liu        libaio				\
743b1c5d96SAlexey Budankov        libzstd				\
7549f550eaSNamhyung Kim        disassembler-four-args		\
76cfd59ca9SAndres Freund        disassembler-init-styled	\
7749f550eaSNamhyung Kim        file-handle
78e6c76d62SJiri Olsa
799fd4186aSWang Nan# FEATURE_TESTS_BASIC + FEATURE_TESTS_EXTRA is the complete list
809fd4186aSWang Nan# of all feature tests
819fd4186aSWang NanFEATURE_TESTS_EXTRA :=                  \
829fd4186aSWang Nan         bionic                         \
839fd4186aSWang Nan         compile-32                     \
849fd4186aSWang Nan         compile-x32                    \
859fd4186aSWang Nan         cplus-demangle                 \
864c72e2b3SIan Rogers         cxa-demangle                   \
874751bdddSArnaldo Carvalho de Melo         gtk2                           \
884751bdddSArnaldo Carvalho de Melo         gtk2-infobar                   \
899fd4186aSWang Nan         hello                          \
909fd4186aSWang Nan         libbabeltrace                  \
918b767db3SChangbin Du         libcapstone                    \
9214541b1eSStanislav Fomichev         libbfd-liberty                 \
9314541b1eSStanislav Fomichev         libbfd-liberty-z               \
941c3b28fdSArnaldo Carvalho de Melo         libopencsd                     \
955c4d7c82SArnaldo Carvalho de Melo         libunwind-x86                  \
965c4d7c82SArnaldo Carvalho de Melo         libunwind-x86_64               \
975c4d7c82SArnaldo Carvalho de Melo         libunwind-arm                  \
985c4d7c82SArnaldo Carvalho de Melo         libunwind-aarch64              \
99f9be7eefSHe Kuang         libunwind-debug-frame          \
100f9be7eefSHe Kuang         libunwind-debug-frame-arm      \
101bd476684SJiri Olsa         libunwind-debug-frame-aarch64  \
102bd476684SJiri Olsa         cxx                            \
103bd476684SJiri Olsa         llvm                           \
1047b65e203SJiri Olsa         clang                          \
1055ef86146SStephane Eranian         libbpf                         \
1060ae065a5SArnaldo Carvalho de Melo         libbpf-btf__load_from_kernel_by_id \
1075c83eff3SJiri Olsa         libbpf-bpf_prog_load           \
1088916d725SJiri Olsa         libbpf-bpf_object__next_program \
109739c9180SJiri Olsa         libbpf-bpf_object__next_map    \
110f1bdebbbSArnaldo Carvalho de Melo         libbpf-bpf_program__set_insns  \
111df76e003SArnaldo Carvalho de Melo         libbpf-bpf_create_map		\
112c7a14fdcSFrank Ch. Eigler         libpfm4                        \
113fbcdaa19SSong Liu         libdebuginfod			\
114fbcdaa19SSong Liu         clang-bpf-co-re
115fbcdaa19SSong Liu
1169fd4186aSWang Nan
1179fd4186aSWang NanFEATURE_TESTS ?= $(FEATURE_TESTS_BASIC)
1189fd4186aSWang Nan
1199fd4186aSWang Nanifeq ($(FEATURE_TESTS),all)
1209fd4186aSWang Nan  FEATURE_TESTS := $(FEATURE_TESTS_BASIC) $(FEATURE_TESTS_EXTRA)
1219fd4186aSWang Nanendif
1229fd4186aSWang Nan
1238135c8c7SWang NanFEATURE_DISPLAY ?=              \
124e6c76d62SJiri Olsa         dwarf                  \
125bd0419e2SArnaldo Carvalho de Melo         dwarf_getlocations     \
126e6c76d62SJiri Olsa         glibc                  \
127e6c76d62SJiri Olsa         libbfd                 \
128e71e19a9SArnaldo Carvalho de Melo         libbfd-buildid		\
12974d5f3d0SIgor Lubashev         libcap                 \
130e6c76d62SJiri Olsa         libelf                 \
131e6c76d62SJiri Olsa         libnuma                \
132f8ac8606SArnaldo Carvalho de Melo         numa_num_possible_cpus \
133e6c76d62SJiri Olsa         libperl                \
134e6c76d62SJiri Olsa         libpython              \
1358ee46460SStephane Eranian         libcrypto              \
136e6c76d62SJiri Olsa         libunwind              \
137e6c76d62SJiri Olsa         libdw-dwarf-unwind     \
1388b767db3SChangbin Du         libcapstone            \
139206dcfcaSJames Clark         llvm-perf              \
1406c6f0f61SJiri Olsa         zlib                   \
141b0063dbfSArnaldo Carvalho de Melo         lzma                   \
142ed63f34cSWang Nan         get_cpuid              \
1432a07d814SAlexey Budankov         bpf			\
1448a1b1718SSong Liu         libaio			\
145516ddaadSAndres Freund         libzstd
146e6c76d62SJiri Olsa
14774ef1cc9SRoberto Sassu#
14874ef1cc9SRoberto Sassu# Declare group members of a feature to display the logical OR of the detection
14974ef1cc9SRoberto Sassu# result instead of each member result.
15074ef1cc9SRoberto Sassu#
15174ef1cc9SRoberto SassuFEATURE_GROUP_MEMBERS-libbfd = libbfd-liberty libbfd-liberty-z
15274ef1cc9SRoberto Sassu
1538f61e98aSGuilherme Amadio#
1548f61e98aSGuilherme Amadio# Declare list of feature dependency packages that provide pkg-config files.
1558f61e98aSGuilherme Amadio#
1568f61e98aSGuilherme AmadioFEATURE_PKG_CONFIG ?=           \
1578f61e98aSGuilherme Amadio         libtraceevent          \
1588f61e98aSGuilherme Amadio         libtracefs
1598f61e98aSGuilherme Amadio
1608f61e98aSGuilherme Amadiofeature_pkg_config = $(eval $(feature_pkg_config_code))
1618f61e98aSGuilherme Amadiodefine feature_pkg_config_code
1628f61e98aSGuilherme Amadio  FEATURE_CHECK_CFLAGS-$(1) := $(shell $(PKG_CONFIG) --cflags $(1) 2>/dev/null)
1638f61e98aSGuilherme Amadio  FEATURE_CHECK_LDFLAGS-$(1) := $(shell $(PKG_CONFIG) --libs $(1) 2>/dev/null)
1648f61e98aSGuilherme Amadioendef
1658f61e98aSGuilherme Amadio
1668f61e98aSGuilherme Amadio# Set FEATURE_CHECK_(C|LD)FLAGS-$(package) for packages using pkg-config.
1678f61e98aSGuilherme Amadioifneq ($(PKG_CONFIG),)
1688f61e98aSGuilherme Amadio  $(foreach package,$(FEATURE_PKG_CONFIG),$(call feature_pkg_config,$(package)))
1698f61e98aSGuilherme Amadioendif
1708f61e98aSGuilherme Amadio
171e6c76d62SJiri Olsa# Set FEATURE_CHECK_(C|LD)FLAGS-all for all FEATURE_TESTS features.
172e6c76d62SJiri Olsa# If in the future we need per-feature checks/flags for features not
173e6c76d62SJiri Olsa# mentioned in this list we need to refactor this ;-).
174e6c76d62SJiri Olsaset_test_all_flags = $(eval $(set_test_all_flags_code))
175e6c76d62SJiri Olsadefine set_test_all_flags_code
176e6c76d62SJiri Olsa  FEATURE_CHECK_CFLAGS-all  += $(FEATURE_CHECK_CFLAGS-$(1))
177e6c76d62SJiri Olsa  FEATURE_CHECK_LDFLAGS-all += $(FEATURE_CHECK_LDFLAGS-$(1))
178e6c76d62SJiri Olsaendef
179e6c76d62SJiri Olsa
180e6c76d62SJiri Olsa$(foreach feat,$(FEATURE_TESTS),$(call set_test_all_flags,$(feat)))
181e6c76d62SJiri Olsa
182e6c76d62SJiri Olsa#
183e6c76d62SJiri Olsa# Special fast-path for the 'all features are available' case:
184e6c76d62SJiri Olsa#
185e6c76d62SJiri Olsa$(call feature_check,all,$(MSG))
186e6c76d62SJiri Olsa
187e6c76d62SJiri Olsa#
188e6c76d62SJiri Olsa# Just in case the build freshly failed, make sure we print the
189e6c76d62SJiri Olsa# feature matrix:
190e6c76d62SJiri Olsa#
191e6c76d62SJiri Olsaifeq ($(feature-all), 1)
192e6c76d62SJiri Olsa  #
193e6c76d62SJiri Olsa  # test-all.c passed - just set all the core feature flags to 1:
194e6c76d62SJiri Olsa  #
195e6c76d62SJiri Olsa  $(foreach feat,$(FEATURE_TESTS),$(call feature_set,$(feat)))
19676c4aaecSJiri Olsa  #
19776c4aaecSJiri Olsa  # test-all.c does not comprise these tests, so we need to
19876c4aaecSJiri Olsa  # for this case to get features proper values
19976c4aaecSJiri Olsa  #
20076c4aaecSJiri Olsa  $(call feature_check,compile-32)
20176c4aaecSJiri Olsa  $(call feature_check,compile-x32)
20276c4aaecSJiri Olsa  $(call feature_check,bionic)
20376c4aaecSJiri Olsa  $(call feature_check,libbabeltrace)
204e6c76d62SJiri Olsaelse
205e6c76d62SJiri Olsa  $(foreach feat,$(FEATURE_TESTS),$(call feature_check,$(feat)))
206e6c76d62SJiri Olsaendif
207e6c76d62SJiri Olsa
208e6c76d62SJiri Olsa#
209e6c76d62SJiri Olsa# Print the result of the feature test:
210e6c76d62SJiri Olsa#
211709533e5SRoberto Sassufeature_print_status = $(eval $(feature_print_status_code))
212e6c76d62SJiri Olsa
21374ef1cc9SRoberto Sassufeature_group = $(eval $(feature_gen_group)) $(GROUP)
21474ef1cc9SRoberto Sassu
21574ef1cc9SRoberto Sassudefine feature_gen_group
21674ef1cc9SRoberto Sassu  GROUP := $(1)
21774ef1cc9SRoberto Sassu  ifneq ($(feature_verbose),1)
21874ef1cc9SRoberto Sassu    GROUP += $(FEATURE_GROUP_MEMBERS-$(1))
21974ef1cc9SRoberto Sassu  endif
22074ef1cc9SRoberto Sassuendef
22174ef1cc9SRoberto Sassu
222e6c76d62SJiri Olsadefine feature_print_status_code
22374ef1cc9SRoberto Sassu  ifneq (,$(filter 1,$(foreach feat,$(call feature_group,$(feat)),$(feature-$(feat)))))
22474da7697SRoberto Sassu    MSG = $(shell printf '...%40s: [ \033[32mon\033[m  ]' $(1))
225e6c76d62SJiri Olsa  else
22674da7697SRoberto Sassu    MSG = $(shell printf '...%40s: [ \033[31mOFF\033[m ]' $(1))
227e6c76d62SJiri Olsa  endif
228e6c76d62SJiri Olsaendef
229e6c76d62SJiri Olsa
230709533e5SRoberto Sassufeature_print_text = $(eval $(feature_print_text_code))
231e6c76d62SJiri Olsadefine feature_print_text_code
23274da7697SRoberto Sassu    MSG = $(shell printf '...%40s: %s' $(1) $(2))
233e6c76d62SJiri Olsaendef
234e6c76d62SJiri Olsa
235c6a5f88fSJiri Olsa#
236c6a5f88fSJiri Olsa# generates feature value assignment for name, like:
237c6a5f88fSJiri Olsa#   $(call feature_assign,dwarf) == feature-dwarf=1
238c6a5f88fSJiri Olsa#
239c6a5f88fSJiri Olsafeature_assign = feature-$(1)=$(feature-$(1))
240c6a5f88fSJiri Olsa
24113e96db6SArnaldo Carvalho de MeloFEATURE_DUMP_FILENAME = $(OUTPUT)FEATURE-DUMP$(FEATURE_USER)
242936d120dSJiri OlsaFEATURE_DUMP := $(shell touch $(FEATURE_DUMP_FILENAME); cat $(FEATURE_DUMP_FILENAME))
243936d120dSJiri Olsa
244936d120dSJiri Olsafeature_dump_check = $(eval $(feature_dump_check_code))
245936d120dSJiri Olsadefine feature_dump_check_code
246936d120dSJiri Olsa  ifeq ($(findstring $(1),$(FEATURE_DUMP)),)
247936d120dSJiri Olsa    $(2) := 1
248936d120dSJiri Olsa  endif
249936d120dSJiri Olsaendef
250936d120dSJiri Olsa
251936d120dSJiri Olsa#
252936d120dSJiri Olsa# First check if any test from FEATURE_DISPLAY
253936d120dSJiri Olsa# and set feature_display := 1 if it does
254936d120dSJiri Olsa$(foreach feat,$(FEATURE_DISPLAY),$(call feature_dump_check,$(call feature_assign,$(feat)),feature_display))
255936d120dSJiri Olsa
256936d120dSJiri Olsa#
257936d120dSJiri Olsa# Now also check if any other test changed,
258936d120dSJiri Olsa# so we force FEATURE-DUMP generation
259936d120dSJiri Olsa$(foreach feat,$(FEATURE_TESTS),$(call feature_dump_check,$(call feature_assign,$(feat)),feature_dump_changed))
260e6c76d62SJiri Olsa
261e6c76d62SJiri Olsa# The $(feature_display) controls the default detection message
262e6c76d62SJiri Olsa# output. It's set if:
263e6c76d62SJiri Olsa# - detected features differes from stored features from
26413e96db6SArnaldo Carvalho de Melo#   last build (in $(FEATURE_DUMP_FILENAME) file)
265e6c76d62SJiri Olsa# - one of the $(FEATURE_DISPLAY) is not detected
266e6c76d62SJiri Olsa# - VF is enabled
267e6c76d62SJiri Olsa
268936d120dSJiri Olsaifeq ($(feature_dump_changed),1)
269936d120dSJiri Olsa  $(shell rm -f $(FEATURE_DUMP_FILENAME))
270936d120dSJiri Olsa  $(foreach feat,$(FEATURE_TESTS),$(shell echo "$(call feature_assign,$(feat))" >> $(FEATURE_DUMP_FILENAME)))
271e6c76d62SJiri Olsaendif
272e6c76d62SJiri Olsa
2736076e2a4SArnaldo Carvalho de Melofeature_display_check = $(eval $(feature_check_display_code))
274d0018b49SJiri Olsadefine feature_check_display_code
275e6c76d62SJiri Olsa  ifneq ($(feature-$(1)), 1)
276e6c76d62SJiri Olsa    feature_display := 1
277e6c76d62SJiri Olsa  endif
278e6c76d62SJiri Olsaendef
279e6c76d62SJiri Olsa
280e6c76d62SJiri Olsa$(foreach feat,$(FEATURE_DISPLAY),$(call feature_display_check,$(feat)))
281e6c76d62SJiri Olsa
282e6c76d62SJiri Olsaifeq ($(VF),1)
283e6c76d62SJiri Olsa  feature_display := 1
284e6c76d62SJiri Olsa  feature_verbose := 1
285e6c76d62SJiri Olsaendif
286e6c76d62SJiri Olsa
28774ef1cc9SRoberto Sassuifneq ($(feature_verbose),1)
28874ef1cc9SRoberto Sassu  #
28974ef1cc9SRoberto Sassu  # Determine the features to omit from the displayed message, as only the
29074ef1cc9SRoberto Sassu  # logical OR of the detection result will be shown.
29174ef1cc9SRoberto Sassu  #
29274ef1cc9SRoberto Sassu  FEATURE_OMIT := $(foreach feat,$(FEATURE_DISPLAY),$(FEATURE_GROUP_MEMBERS-$(feat)))
29374ef1cc9SRoberto Sassuendif
29474ef1cc9SRoberto Sassu
29519177bc3SArnaldo Carvalho de Melofeature_display_entries = $(eval $(feature_display_entries_code))
29619177bc3SArnaldo Carvalho de Melodefine feature_display_entries_code
297e6c76d62SJiri Olsa  ifeq ($(feature_display),1)
298709533e5SRoberto Sassu    $$(info )
299709533e5SRoberto Sassu    $$(info Auto-detecting system features:)
30074ef1cc9SRoberto Sassu    $(foreach feat,$(filter-out $(FEATURE_OMIT),$(FEATURE_DISPLAY)),$(call feature_print_status,$(feat),) $$(info $(MSG)))
301e6c76d62SJiri Olsa  endif
302e6c76d62SJiri Olsa
303e6c76d62SJiri Olsa  ifeq ($(feature_verbose),1)
304709533e5SRoberto Sassu    $(eval TMP := $(filter-out $(FEATURE_DISPLAY),$(FEATURE_TESTS)))
305709533e5SRoberto Sassu    $(foreach feat,$(TMP),$(call feature_print_status,$(feat),) $$(info $(MSG)))
306e6c76d62SJiri Olsa  endif
30719177bc3SArnaldo Carvalho de Meloendef
30819177bc3SArnaldo Carvalho de Melo
30919177bc3SArnaldo Carvalho de Meloifeq ($(FEATURE_DISPLAY_DEFERRED),)
31019177bc3SArnaldo Carvalho de Melo  $(call feature_display_entries)
311709533e5SRoberto Sassu  $(info )
31219177bc3SArnaldo Carvalho de Meloendif
313