mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-01-20 13:24:11 +00:00
Since 66dfdff03d196e51 ("perf tools: Add Python 3 support") we don't use
the tools/build/feature/test-libpython-version.c version in any Makefile
feature check:
$ find tools/ -type f | xargs grep feature-libpython-version
$
The only place where this was used was removed in 66dfdff03d196e51:
- ifneq ($(feature-libpython-version), 1)
- $(warning Python 3 is not yet supported; please set)
- $(warning PYTHON and/or PYTHON_CONFIG appropriately.)
- $(warning If you also have Python 2 installed, then)
- $(warning try something like:)
- $(warning $(and ,))
- $(warning $(and ,) make PYTHON=python2)
- $(warning $(and ,))
- $(warning Otherwise, disable Python support entirely:)
- $(warning $(and ,))
- $(warning $(and ,) make NO_LIBPYTHON=1)
- $(warning $(and ,))
- $(error $(and ,))
- else
- LDFLAGS += $(PYTHON_EMBED_LDFLAGS)
- EXTLIBS += $(PYTHON_EMBED_LIBADD)
- LANG_BINDINGS += $(obj-perf)python/perf.so
- $(call detected,CONFIG_LIBPYTHON)
- endif
And nowadays we either build with PYTHON=python3 or just install the
python3 devel packages and perf will build against it.
But the leftover feature-libpython-version check made the fast path
feature detection to break in all cases except when python2 devel files
were installed:
$ rpm -qa | grep python.*devel
python3-devel-3.9.7-1.fc34.x86_64
$ rm -rf /tmp/build/perf ; mkdir -p /tmp/build/perf ;
$ make -C tools/perf O=/tmp/build/perf install-bin
make: Entering directory '/var/home/acme/git/perf/tools/perf'
BUILD: Doing 'make -j32' parallel build
HOSTCC /tmp/build/perf/fixdep.o
<SNIP>
$ cat /tmp/build/perf/feature/test-all.make.output
In file included from test-all.c:18:
test-libpython-version.c:5:10: error: #error
5 | #error
| ^~~~~
$ ldd ~/bin/perf | grep python
libpython3.9.so.1.0 => /lib64/libpython3.9.so.1.0 (0x00007fda6dbcf000)
$
As python3 is the norm these days, fix this by just removing the unused
feature-libpython-version feature check, making the test-all fast path
to work with the common case.
With this:
$ rm -rf /tmp/build/perf ; mkdir -p /tmp/build/perf ;
$ make -C tools/perf O=/tmp/build/perf install-bin |& head
make: Entering directory '/var/home/acme/git/perf/tools/perf'
BUILD: Doing 'make -j32' parallel build
HOSTCC /tmp/build/perf/fixdep.o
HOSTLD /tmp/build/perf/fixdep-in.o
LINK /tmp/build/perf/fixdep
Auto-detecting system features:
... dwarf: [ on ]
... dwarf_getlocations: [ on ]
... glibc: [ on ]
$ ldd ~/bin/perf | grep python
libpython3.9.so.1.0 => /lib64/libpython3.9.so.1.0 (0x00007f58800b0000)
$ cat /tmp/build/perf/feature/test-all.make.output
$
Reviewed-by: James Clark <james.clark@arm.com>
Fixes: 66dfdff03d196e51 ("perf tools: Add Python 3 support")
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Ian Rogers <irogers@google.com>
Cc: Jaroslav Škarvada <jskarvad@redhat.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Link: https://lore.kernel.org/lkml/YaYmeeC6CS2b8OSz@kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
344 lines
9.3 KiB
Makefile
344 lines
9.3 KiB
Makefile
# SPDX-License-Identifier: GPL-2.0
|
|
include ../../scripts/Makefile.include
|
|
|
|
FILES= \
|
|
test-all.bin \
|
|
test-backtrace.bin \
|
|
test-bionic.bin \
|
|
test-dwarf.bin \
|
|
test-dwarf_getlocations.bin \
|
|
test-eventfd.bin \
|
|
test-fortify-source.bin \
|
|
test-get_current_dir_name.bin \
|
|
test-glibc.bin \
|
|
test-gtk2.bin \
|
|
test-gtk2-infobar.bin \
|
|
test-hello.bin \
|
|
test-libaudit.bin \
|
|
test-libbfd.bin \
|
|
test-libbfd-buildid.bin \
|
|
test-disassembler-four-args.bin \
|
|
test-reallocarray.bin \
|
|
test-libbfd-liberty.bin \
|
|
test-libbfd-liberty-z.bin \
|
|
test-cplus-demangle.bin \
|
|
test-libcap.bin \
|
|
test-libelf.bin \
|
|
test-libelf-getphdrnum.bin \
|
|
test-libelf-gelf_getnote.bin \
|
|
test-libelf-getshdrstrndx.bin \
|
|
test-libdebuginfod.bin \
|
|
test-libnuma.bin \
|
|
test-numa_num_possible_cpus.bin \
|
|
test-libperl.bin \
|
|
test-libpython.bin \
|
|
test-libslang.bin \
|
|
test-libslang-include-subdir.bin \
|
|
test-libtraceevent.bin \
|
|
test-libtracefs.bin \
|
|
test-libcrypto.bin \
|
|
test-libunwind.bin \
|
|
test-libunwind-debug-frame.bin \
|
|
test-libunwind-x86.bin \
|
|
test-libunwind-x86_64.bin \
|
|
test-libunwind-arm.bin \
|
|
test-libunwind-aarch64.bin \
|
|
test-libunwind-debug-frame-arm.bin \
|
|
test-libunwind-debug-frame-aarch64.bin \
|
|
test-pthread-attr-setaffinity-np.bin \
|
|
test-pthread-barrier.bin \
|
|
test-stackprotector-all.bin \
|
|
test-timerfd.bin \
|
|
test-libdw-dwarf-unwind.bin \
|
|
test-libbabeltrace.bin \
|
|
test-compile-32.bin \
|
|
test-compile-x32.bin \
|
|
test-zlib.bin \
|
|
test-lzma.bin \
|
|
test-bpf.bin \
|
|
test-libbpf.bin \
|
|
test-get_cpuid.bin \
|
|
test-sdt.bin \
|
|
test-cxx.bin \
|
|
test-gettid.bin \
|
|
test-jvmti.bin \
|
|
test-jvmti-cmlr.bin \
|
|
test-sched_getcpu.bin \
|
|
test-setns.bin \
|
|
test-libopencsd.bin \
|
|
test-clang.bin \
|
|
test-llvm.bin \
|
|
test-llvm-version.bin \
|
|
test-libaio.bin \
|
|
test-libzstd.bin \
|
|
test-clang-bpf-co-re.bin \
|
|
test-file-handle.bin \
|
|
test-libpfm4.bin
|
|
|
|
FILES := $(addprefix $(OUTPUT),$(FILES))
|
|
|
|
PKG_CONFIG ?= $(CROSS_COMPILE)pkg-config
|
|
|
|
all: $(FILES)
|
|
|
|
__BUILD = $(CC) $(CFLAGS) -MD -Wall -Werror -o $@ $(patsubst %.bin,%.c,$(@F)) $(LDFLAGS)
|
|
BUILD = $(__BUILD) > $(@:.bin=.make.output) 2>&1
|
|
|
|
__BUILDXX = $(CXX) $(CXXFLAGS) -MD -Wall -Werror -o $@ $(patsubst %.bin,%.cpp,$(@F)) $(LDFLAGS)
|
|
BUILDXX = $(__BUILDXX) > $(@:.bin=.make.output) 2>&1
|
|
|
|
###############################
|
|
|
|
$(OUTPUT)test-all.bin:
|
|
$(BUILD) -fstack-protector-all -O2 -D_FORTIFY_SOURCE=2 -ldw -lelf -lnuma -lelf -lslang $(FLAGS_PERL_EMBED) $(FLAGS_PYTHON_EMBED) -DPACKAGE='"perf"' -lbfd -ldl -lz -llzma -lzstd -lcap
|
|
|
|
$(OUTPUT)test-hello.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-pthread-attr-setaffinity-np.bin:
|
|
$(BUILD) -D_GNU_SOURCE -lpthread
|
|
|
|
$(OUTPUT)test-pthread-barrier.bin:
|
|
$(BUILD) -lpthread
|
|
|
|
$(OUTPUT)test-stackprotector-all.bin:
|
|
$(BUILD) -fstack-protector-all
|
|
|
|
$(OUTPUT)test-fortify-source.bin:
|
|
$(BUILD) -O2 -D_FORTIFY_SOURCE=2
|
|
|
|
$(OUTPUT)test-bionic.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-libcap.bin:
|
|
$(BUILD) -lcap
|
|
|
|
$(OUTPUT)test-libelf.bin:
|
|
$(BUILD) -lelf
|
|
|
|
$(OUTPUT)test-eventfd.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-get_current_dir_name.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-glibc.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-sched_getcpu.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-setns.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-libopencsd.bin:
|
|
$(BUILD) # -lopencsd_c_api -lopencsd provided by
|
|
# $(FEATURE_CHECK_LDFLAGS-libopencsd)
|
|
|
|
DWARFLIBS := -ldw
|
|
ifeq ($(findstring -static,${LDFLAGS}),-static)
|
|
DWARFLIBS += -lelf -lebl -lz -llzma -lbz2
|
|
endif
|
|
|
|
$(OUTPUT)test-dwarf.bin:
|
|
$(BUILD) $(DWARFLIBS)
|
|
|
|
$(OUTPUT)test-dwarf_getlocations.bin:
|
|
$(BUILD) $(DWARFLIBS)
|
|
|
|
$(OUTPUT)test-libelf-getphdrnum.bin:
|
|
$(BUILD) -lelf
|
|
|
|
$(OUTPUT)test-libelf-gelf_getnote.bin:
|
|
$(BUILD) -lelf
|
|
|
|
$(OUTPUT)test-libelf-getshdrstrndx.bin:
|
|
$(BUILD) -lelf
|
|
|
|
$(OUTPUT)test-libdebuginfod.bin:
|
|
$(BUILD) -ldebuginfod
|
|
|
|
$(OUTPUT)test-libnuma.bin:
|
|
$(BUILD) -lnuma
|
|
|
|
$(OUTPUT)test-numa_num_possible_cpus.bin:
|
|
$(BUILD) -lnuma
|
|
|
|
$(OUTPUT)test-libunwind.bin:
|
|
$(BUILD) -lelf
|
|
|
|
$(OUTPUT)test-libunwind-debug-frame.bin:
|
|
$(BUILD) -lelf
|
|
$(OUTPUT)test-libunwind-x86.bin:
|
|
$(BUILD) -lelf -lunwind-x86
|
|
|
|
$(OUTPUT)test-libunwind-x86_64.bin:
|
|
$(BUILD) -lelf -lunwind-x86_64
|
|
|
|
$(OUTPUT)test-libunwind-arm.bin:
|
|
$(BUILD) -lelf -lunwind-arm
|
|
|
|
$(OUTPUT)test-libunwind-aarch64.bin:
|
|
$(BUILD) -lelf -lunwind-aarch64
|
|
|
|
$(OUTPUT)test-libunwind-debug-frame-arm.bin:
|
|
$(BUILD) -lelf -lunwind-arm
|
|
|
|
$(OUTPUT)test-libunwind-debug-frame-aarch64.bin:
|
|
$(BUILD) -lelf -lunwind-aarch64
|
|
|
|
$(OUTPUT)test-libaudit.bin:
|
|
$(BUILD) -laudit
|
|
|
|
$(OUTPUT)test-libslang.bin:
|
|
$(BUILD) -lslang
|
|
|
|
$(OUTPUT)test-libslang-include-subdir.bin:
|
|
$(BUILD) -lslang
|
|
|
|
$(OUTPUT)test-libtraceevent.bin:
|
|
$(BUILD) -ltraceevent
|
|
|
|
$(OUTPUT)test-libtracefs.bin:
|
|
$(BUILD) -ltracefs
|
|
|
|
$(OUTPUT)test-libcrypto.bin:
|
|
$(BUILD) -lcrypto
|
|
|
|
$(OUTPUT)test-gtk2.bin:
|
|
$(BUILD) $(shell $(PKG_CONFIG) --libs --cflags gtk+-2.0 2>/dev/null) -Wno-deprecated-declarations
|
|
|
|
$(OUTPUT)test-gtk2-infobar.bin:
|
|
$(BUILD) $(shell $(PKG_CONFIG) --libs --cflags gtk+-2.0 2>/dev/null)
|
|
|
|
grep-libs = $(filter -l%,$(1))
|
|
strip-libs = $(filter-out -l%,$(1))
|
|
|
|
PERL_EMBED_LDOPTS = $(shell perl -MExtUtils::Embed -e ldopts 2>/dev/null)
|
|
PERL_EMBED_LDFLAGS = $(call strip-libs,$(PERL_EMBED_LDOPTS))
|
|
PERL_EMBED_LIBADD = $(call grep-libs,$(PERL_EMBED_LDOPTS))
|
|
PERL_EMBED_CCOPTS = `perl -MExtUtils::Embed -e ccopts 2>/dev/null`
|
|
FLAGS_PERL_EMBED=$(PERL_EMBED_CCOPTS) $(PERL_EMBED_LDOPTS)
|
|
|
|
$(OUTPUT)test-libperl.bin:
|
|
$(BUILD) $(FLAGS_PERL_EMBED)
|
|
|
|
$(OUTPUT)test-libpython.bin:
|
|
$(BUILD) $(FLAGS_PYTHON_EMBED)
|
|
|
|
$(OUTPUT)test-libbfd.bin:
|
|
$(BUILD) -DPACKAGE='"perf"' -lbfd -ldl
|
|
|
|
$(OUTPUT)test-libbfd-buildid.bin:
|
|
$(BUILD) -DPACKAGE='"perf"' -lbfd -ldl
|
|
|
|
$(OUTPUT)test-disassembler-four-args.bin:
|
|
$(BUILD) -DPACKAGE='"perf"' -lbfd -lopcodes
|
|
|
|
$(OUTPUT)test-reallocarray.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-libbfd-liberty.bin:
|
|
$(CC) $(CFLAGS) -Wall -Werror -o $@ test-libbfd.c -DPACKAGE='"perf"' $(LDFLAGS) -lbfd -ldl -liberty
|
|
|
|
$(OUTPUT)test-libbfd-liberty-z.bin:
|
|
$(CC) $(CFLAGS) -Wall -Werror -o $@ test-libbfd.c -DPACKAGE='"perf"' $(LDFLAGS) -lbfd -ldl -liberty -lz
|
|
|
|
$(OUTPUT)test-cplus-demangle.bin:
|
|
$(BUILD) -liberty
|
|
|
|
$(OUTPUT)test-backtrace.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-timerfd.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-libdw-dwarf-unwind.bin:
|
|
$(BUILD) # -ldw provided by $(FEATURE_CHECK_LDFLAGS-libdw-dwarf-unwind)
|
|
|
|
$(OUTPUT)test-libbabeltrace.bin:
|
|
$(BUILD) # -lbabeltrace provided by $(FEATURE_CHECK_LDFLAGS-libbabeltrace)
|
|
|
|
$(OUTPUT)test-compile-32.bin:
|
|
$(CC) -m32 -o $@ test-compile.c
|
|
|
|
$(OUTPUT)test-compile-x32.bin:
|
|
$(CC) -mx32 -o $@ test-compile.c
|
|
|
|
$(OUTPUT)test-zlib.bin:
|
|
$(BUILD) -lz
|
|
|
|
$(OUTPUT)test-lzma.bin:
|
|
$(BUILD) -llzma
|
|
|
|
$(OUTPUT)test-get_cpuid.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-bpf.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-libbpf.bin:
|
|
$(BUILD) -lbpf
|
|
|
|
$(OUTPUT)test-sdt.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-cxx.bin:
|
|
$(BUILDXX) -std=gnu++11
|
|
|
|
$(OUTPUT)test-gettid.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-jvmti.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-jvmti-cmlr.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-llvm.bin:
|
|
$(BUILDXX) -std=gnu++14 \
|
|
-I$(shell $(LLVM_CONFIG) --includedir) \
|
|
-L$(shell $(LLVM_CONFIG) --libdir) \
|
|
$(shell $(LLVM_CONFIG) --libs Core BPF) \
|
|
$(shell $(LLVM_CONFIG) --system-libs) \
|
|
> $(@:.bin=.make.output) 2>&1
|
|
|
|
$(OUTPUT)test-llvm-version.bin:
|
|
$(BUILDXX) -std=gnu++14 \
|
|
-I$(shell $(LLVM_CONFIG) --includedir) \
|
|
> $(@:.bin=.make.output) 2>&1
|
|
|
|
$(OUTPUT)test-clang.bin:
|
|
$(BUILDXX) -std=gnu++14 \
|
|
-I$(shell $(LLVM_CONFIG) --includedir) \
|
|
-L$(shell $(LLVM_CONFIG) --libdir) \
|
|
-Wl,--start-group -lclangBasic -lclangDriver \
|
|
-lclangFrontend -lclangEdit -lclangLex \
|
|
-lclangAST -Wl,--end-group \
|
|
$(shell $(LLVM_CONFIG) --libs Core option) \
|
|
$(shell $(LLVM_CONFIG) --system-libs) \
|
|
> $(@:.bin=.make.output) 2>&1
|
|
|
|
-include $(OUTPUT)*.d
|
|
|
|
$(OUTPUT)test-libaio.bin:
|
|
$(BUILD) -lrt
|
|
|
|
$(OUTPUT)test-libzstd.bin:
|
|
$(BUILD) -lzstd
|
|
|
|
$(OUTPUT)test-clang-bpf-co-re.bin:
|
|
$(CLANG) -S -g -target bpf -o - $(patsubst %.bin,%.c,$(@F)) | \
|
|
grep BTF_KIND_VAR
|
|
|
|
$(OUTPUT)test-file-handle.bin:
|
|
$(BUILD)
|
|
|
|
$(OUTPUT)test-libpfm4.bin:
|
|
$(BUILD) -lpfm
|
|
|
|
###############################
|
|
|
|
clean:
|
|
rm -f $(FILES) $(OUTPUT)*.d $(FILES:.bin=.make.output)
|