blob: 8f1c258b151a2ccc4d98ac1c66ced1f4ff204afb [file] [log] [blame]
Ingo Molnarbd69cc22013-10-02 11:49:08 +02001include ../scripts/Makefile.include
2
3# The default target of this Makefile is...
4all:
5
Arnaldo Carvalho de Meloca70c242016-03-18 13:57:20 -03006include ../scripts/utilities.mak
Ingo Molnarbd69cc22013-10-02 11:49:08 +02007
8# Define V to have a more verbose compile.
9#
Jiri Olsa0695e572014-02-19 16:52:54 +010010# Define VF to have a more verbose feature check output.
11#
Ingo Molnarbd69cc22013-10-02 11:49:08 +020012# Define O to save output files in a separate directory.
13#
14# Define ARCH as name of target architecture if you want cross-builds.
15#
16# Define CROSS_COMPILE as prefix name of compiler if you want cross-builds.
17#
18# Define NO_LIBPERL to disable perl script extension.
19#
20# Define NO_LIBPYTHON to disable python script extension.
21#
22# Define PYTHON to point to the python binary if the default
23# `python' is not correct; for example: PYTHON=python2
24#
25# Define PYTHON_CONFIG to point to the python-config binary if
26# the default `$(PYTHON)-config' is not correct.
27#
28# Define ASCIIDOC8 if you want to format documentation with AsciiDoc 8
29#
30# Define DOCBOOK_XSL_172 if you want to format man pages with DocBook XSL v1.72.
31#
32# Define LDFLAGS=-static to build a static binary.
33#
34# Define EXTRA_CFLAGS=-m64 or EXTRA_CFLAGS=-m32 as appropriate for cross-builds.
35#
36# Define NO_DWARF if you do not want debug-info analysis feature at all.
37#
38# Define WERROR=0 to disable treating any warnings as errors.
39#
40# Define NO_NEWT if you do not want TUI support. (deprecated)
41#
42# Define NO_SLANG if you do not want TUI support.
43#
44# Define NO_GTK2 if you do not want GTK+ GUI support.
45#
46# Define NO_DEMANGLE if you do not want C++ symbol demangling.
47#
48# Define NO_LIBELF if you do not want libelf dependency (e.g. cross-builds)
49#
50# Define NO_LIBUNWIND if you do not want libunwind dependency for dwarf
51# backtrace post unwind.
52#
53# Define NO_BACKTRACE if you do not want stack backtrace debug feature
54#
55# Define NO_LIBNUMA if you do not want numa perf benchmark
56#
57# Define NO_LIBAUDIT if you do not want libaudit support
58#
59# Define NO_LIBBIONIC if you do not want bionic support
Jiri Olsa5ea84152014-02-19 16:52:57 +010060#
Stephane Eranian8ee46462015-11-30 10:02:21 +010061# Define NO_LIBCRYPTO if you do not want libcrypto (openssl) support
62# used for generating build-ids for ELFs generated by jitdump.
63#
Jiri Olsa5ea84152014-02-19 16:52:57 +010064# Define NO_LIBDW_DWARF_UNWIND if you do not want libdw support
65# for dwarf backtrace post unwind.
Adrian Huntere477f3f2014-10-23 18:16:03 -030066#
67# Define NO_PERF_READ_VDSO32 if you do not want to build perf-read-vdso32
68# for reading the 32-bit compatibility VDSO in 64-bit mode
69#
70# Define NO_PERF_READ_VDSOX32 if you do not want to build perf-read-vdsox32
71# for reading the x32 mode 32-bit compatibility VDSO in 64-bit mode
Namhyung Kime92ce122014-10-31 16:51:38 +090072#
73# Define NO_ZLIB if you do not want to support compressed kernel modules
Jiri Olsa53d0a572015-02-20 23:16:58 +010074#
Jiri Olsa6ab2b762015-03-28 11:30:30 +010075# Define LIBBABELTRACE if you DO want libbabeltrace support
Jiri Olsa53d0a572015-02-20 23:16:58 +010076# for CTF data format.
Jiri Olsa80a32e5b2015-01-29 13:29:39 +010077#
78# Define NO_LZMA if you do not want to support compressed (xz) kernel modules
Adrian Huntere31f0d02015-04-30 17:37:27 +030079#
80# Define NO_AUXTRACE if you do not want AUX area tracing support
Wang Naned63f34c2015-10-14 12:41:12 +000081#
82# Define NO_LIBBPF if you do not want BPF support
Jiri Olsa96b9e702016-01-15 04:00:18 +000083#
Masami Hiramatsue26e63b2016-07-12 19:05:56 +090084# Define NO_SDT if you do not want to define SDT event in perf tools,
85# note that it doesn't disable SDT scanning support.
86#
Jiri Olsa96b9e702016-01-15 04:00:18 +000087# Define FEATURES_DUMP to provide features detection dump file
88# and bypass the feature detection
Jiri Olsad4dfdf02016-11-02 14:35:49 +010089#
90# Define NO_JVMTI if you do not want jvmti agent built
Wang Nand58ac0b2016-11-26 07:03:33 +000091#
92# Define LIBCLANGLLVM if you DO want builtin clang and llvm support.
93# When selected, pass LLVM_CONFIG=/path/to/llvm-config to `make' if
94# llvm-config is not in $PATH.
Jiri Olsa5ea84152014-02-19 16:52:57 +010095
Adrian Hunter237fae72015-08-13 10:14:55 +030096# As per kernel Makefile, avoid funny character set dependencies
97unexport LC_ALL
98LC_COLLATE=C
99LC_NUMERIC=C
100export LC_COLLATE LC_NUMERIC
101
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200102ifeq ($(srctree),)
103srctree := $(patsubst %/,%,$(dir $(shell pwd)))
104srctree := $(patsubst %/,%,$(dir $(srctree)))
105#$(info Determined 'srctree' to be $(srctree))
106endif
107
108ifneq ($(objtree),)
109#$(info Determined 'objtree' to be $(objtree))
110endif
111
112ifneq ($(OUTPUT),)
113#$(info Determined 'OUTPUT' to be $(OUTPUT))
Jiri Olsa9352aab2014-12-29 17:42:46 +0100114# Adding $(OUTPUT) as a directory to look for source files,
115# because use generated output files as sources dependency
116# for flex/bison parsers.
117VPATH += $(OUTPUT)
118export VPATH
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200119endif
120
Jiri Olsaceed2522015-01-11 23:59:55 +0100121ifeq ($(V),1)
122 Q =
123else
124 Q = @
125endif
126
Jiri Olsa6dd280c2015-01-10 21:43:32 +0100127# Do not use make's built-in rules
128# (this improves performance and avoids hard-to-debug behaviour);
129MAKEFLAGS += -r
130
Alexey Brodkin3c71ba32015-07-14 12:05:20 +0300131# Makefiles suck: This macro sets a default value of $(2) for the
132# variable named by $(1), unless the variable has been set by
133# environment or command line. This is necessary for CC and AR
134# because make sets default values, so the simpler ?= approach
135# won't work as expected.
136define allow-override
137 $(if $(or $(findstring environment,$(origin $(1))),\
138 $(findstring command line,$(origin $(1)))),,\
139 $(eval $(1) = $(2)))
140endef
141
142# Allow setting CC and AR and LD, or setting CROSS_COMPILE as a prefix.
143$(call allow-override,CC,$(CROSS_COMPILE)gcc)
144$(call allow-override,AR,$(CROSS_COMPILE)ar)
145$(call allow-override,LD,$(CROSS_COMPILE)ld)
Wang Nand58ac0b2016-11-26 07:03:33 +0000146$(call allow-override,CXX,$(CROSS_COMPILE)g++)
Alexey Brodkin3c71ba32015-07-14 12:05:20 +0300147
Zubair Lutfullah Kakakhel37b4e202016-02-09 13:33:38 +0000148LD += $(EXTRA_LDFLAGS)
149
Andi Kleen80eeb672016-09-19 17:39:33 -0300150HOSTCC ?= gcc
151HOSTLD ?= ld
152HOSTAR ?= ar
153
Mark Rutlanda8a5cd82014-01-15 10:44:08 +0000154PKG_CONFIG = $(CROSS_COMPILE)pkg-config
Wang Nand58ac0b2016-11-26 07:03:33 +0000155LLVM_CONFIG ?= llvm-config
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200156
157RM = rm -f
Arnaldo Carvalho de Melob52bc232013-09-24 11:56:36 -0300158LN = ln -f
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200159MKDIR = mkdir
160FIND = find
161INSTALL = install
162FLEX = flex
163BISON = bison
164STRIP = strip
Adrian Hunter237fae72015-08-13 10:14:55 +0300165AWK = awk
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200166
Jiri Olsa48425762016-08-01 20:02:33 +0200167# include Makefile.config by default and rule out
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200168# non-config cases
169config := 1
170
Jiri Olsad4dcade2016-12-04 21:42:57 +0100171NON_CONFIG_TARGETS := clean TAGS tags cscope help install-doc install-man install-html install-info install-pdf doc man html info pdf
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200172
173ifdef MAKECMDGOALS
174ifeq ($(filter-out $(NON_CONFIG_TARGETS),$(MAKECMDGOALS)),)
175 config := 0
176endif
177endif
178
Jiri Olsaabb26212016-12-06 14:18:49 +0100179# The fixdep build - we force fixdep tool to be built as
180# the first target in the separate make session not to be
181# disturbed by any parallel make jobs. Once fixdep is done
182# we issue the requested build with FIXDEP=1 variable.
183#
184# The fixdep build is disabled for $(NON_CONFIG_TARGETS)
185# targets, because it's not necessary.
186
187ifdef FIXDEP
188 force_fixdep := 0
189else
190 force_fixdep := $(config)
191endif
192
193export srctree OUTPUT RM CC CXX LD AR CFLAGS CXXFLAGS V BISON FLEX AWK
194export HOSTCC HOSTLD HOSTAR
195
196include $(srctree)/tools/build/Makefile.include
197
198ifeq ($(force_fixdep),1)
199goals := $(filter-out all sub-make, $(MAKECMDGOALS))
200
201$(goals) all: sub-make
202
203sub-make: fixdep
204 $(Q)$(MAKE) FIXDEP=1 -f Makefile.perf $(goals)
205
206else # force_fixdep
207
Jiri Olsa8ac1eb72016-12-06 14:18:50 +0100208LIB_DIR = $(srctree)/tools/lib/api/
209TRACE_EVENT_DIR = $(srctree)/tools/lib/traceevent/
210BPF_DIR = $(srctree)/tools/lib/bpf/
211SUBCMD_DIR = $(srctree)/tools/lib/subcmd/
212
Wang Nanc053a152016-01-25 09:55:51 +0000213# Set FEATURE_TESTS to 'all' so all possible feature checkers are executed.
214# Without this setting the output feature dump file misses some features, for
215# example, liberty. Select all checkers so we won't get an incomplete feature
216# dump file.
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200217ifeq ($(config),1)
Wang Nanc053a152016-01-25 09:55:51 +0000218ifdef MAKECMDGOALS
219ifeq ($(filter feature-dump,$(MAKECMDGOALS)),feature-dump)
220FEATURE_TESTS := all
221endif
222endif
Jiri Olsa48425762016-08-01 20:02:33 +0200223include Makefile.config
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200224endif
225
Arnaldo Carvalho de Melo1b700c92016-04-04 19:05:36 -0300226ifeq ($(config),0)
227include $(srctree)/tools/scripts/Makefile.arch
228-include arch/$(ARCH)/Makefile
229endif
230
Jiri Olsa96b9e702016-01-15 04:00:18 +0000231# The FEATURE_DUMP_EXPORT holds location of the actual
232# FEATURE_DUMP file to be used to bypass feature detection
233# (for bpf or any other subproject)
234ifeq ($(FEATURES_DUMP),)
235FEATURE_DUMP_EXPORT := $(realpath $(OUTPUT)FEATURE-DUMP)
236else
237FEATURE_DUMP_EXPORT := $(FEATURES_DUMP)
238endif
239
Jiri Olsa3d7c0142013-12-03 14:09:21 +0100240export prefix bindir sharedir sysconfdir DESTDIR
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200241
242# sparse is architecture-neutral, which means that we need to tell it
243# explicitly what architecture to check for. Fix this up for yours..
244SPARSE_FLAGS = -D__BIG_ENDIAN__ -D__powerpc__
245
246# Guard against environment variables
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200247PYRF_OBJS =
248SCRIPT_SH =
249
250SCRIPT_SH += perf-archive.sh
Adrian Hunterc501e902014-07-31 09:01:12 +0300251SCRIPT_SH += perf-with-kcore.sh
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200252
253grep-libs = $(filter -l%,$(1))
254strip-libs = $(filter-out -l%,$(1))
255
256ifneq ($(OUTPUT),)
257 TE_PATH=$(OUTPUT)
Wang Naned63f34c2015-10-14 12:41:12 +0000258 BPF_PATH=$(OUTPUT)
Josh Poimboeuf4b6ab942015-12-15 09:39:39 -0600259 SUBCMD_PATH=$(OUTPUT)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200260ifneq ($(subdir),)
Josh Poimboeuf212e9842015-12-13 22:18:06 -0600261 API_PATH=$(OUTPUT)/../lib/api/
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200262else
Josh Poimboeuf212e9842015-12-13 22:18:06 -0600263 API_PATH=$(OUTPUT)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200264endif
265else
266 TE_PATH=$(TRACE_EVENT_DIR)
Josh Poimboeuf212e9842015-12-13 22:18:06 -0600267 API_PATH=$(LIB_DIR)
Wang Naned63f34c2015-10-14 12:41:12 +0000268 BPF_PATH=$(BPF_DIR)
Josh Poimboeuf4b6ab942015-12-15 09:39:39 -0600269 SUBCMD_PATH=$(SUBCMD_DIR)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200270endif
271
272LIBTRACEEVENT = $(TE_PATH)libtraceevent.a
273export LIBTRACEEVENT
274
He Kuange3d09ec2015-05-28 13:28:54 +0000275LIBTRACEEVENT_DYNAMIC_LIST = $(TE_PATH)libtraceevent-dynamic-list
Wang Nan5d618322015-06-17 14:46:29 +0000276LIBTRACEEVENT_DYNAMIC_LIST_LDFLAGS = -Xlinker --dynamic-list=$(LIBTRACEEVENT_DYNAMIC_LIST)
He Kuange3d09ec2015-05-28 13:28:54 +0000277
Josh Poimboeuf212e9842015-12-13 22:18:06 -0600278LIBAPI = $(API_PATH)libapi.a
Jiri Olsa285a8f22015-01-10 20:53:13 +0100279export LIBAPI
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200280
Wang Naned63f34c2015-10-14 12:41:12 +0000281LIBBPF = $(BPF_PATH)libbpf.a
282
Josh Poimboeuf4b6ab942015-12-15 09:39:39 -0600283LIBSUBCMD = $(SUBCMD_PATH)libsubcmd.a
284
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200285# python extension build directories
286PYTHON_EXTBUILD := $(OUTPUT)python_ext_build/
287PYTHON_EXTBUILD_LIB := $(PYTHON_EXTBUILD)lib/
288PYTHON_EXTBUILD_TMP := $(PYTHON_EXTBUILD)tmp/
289export PYTHON_EXTBUILD_LIB PYTHON_EXTBUILD_TMP
290
Ingo Molnar8ec19c02013-10-09 11:49:26 +0200291python-clean := $(call QUIET_CLEAN, python) $(RM) -r $(PYTHON_EXTBUILD) $(OUTPUT)python/perf.so
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200292
293PYTHON_EXT_SRCS := $(shell grep -v ^\# util/python-ext-sources)
Jiri Olsa285a8f22015-01-10 20:53:13 +0100294PYTHON_EXT_DEPS := util/python-ext-sources util/setup.py $(LIBTRACEEVENT) $(LIBAPI)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200295
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200296SCRIPTS = $(patsubst %.sh,%,$(SCRIPT_SH))
297
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200298PROGRAMS += $(OUTPUT)perf
299
Adrian Huntere477f3f2014-10-23 18:16:03 -0300300ifndef NO_PERF_READ_VDSO32
301PROGRAMS += $(OUTPUT)perf-read-vdso32
302endif
303
304ifndef NO_PERF_READ_VDSOX32
305PROGRAMS += $(OUTPUT)perf-read-vdsox32
306endif
307
Jiri Olsad4dfdf02016-11-02 14:35:49 +0100308LIBJVMTI = libperf-jvmti.so
309
310ifndef NO_JVMTI
311PROGRAMS += $(OUTPUT)$(LIBJVMTI)
312endif
313
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200314# what 'all' will build and 'install' will install, in perfexecdir
315ALL_PROGRAMS = $(PROGRAMS) $(SCRIPTS)
316
317# what 'all' will build but not install in perfexecdir
318OTHER_PROGRAMS = $(OUTPUT)perf
319
320# Set paths to tools early so that they can be used for version tests.
321ifndef SHELL_PATH
322 SHELL_PATH = /bin/sh
323endif
324ifndef PERL_PATH
325 PERL_PATH = /usr/bin/perl
326endif
327
328export PERL_PATH
329
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200330LIB_FILE=$(OUTPUT)libperf.a
331
Josh Poimboeuf4b6ab942015-12-15 09:39:39 -0600332PERFLIBS = $(LIB_FILE) $(LIBAPI) $(LIBTRACEEVENT) $(LIBSUBCMD)
Wang Naned63f34c2015-10-14 12:41:12 +0000333ifndef NO_LIBBPF
334 PERFLIBS += $(LIBBPF)
335endif
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200336
337# We choose to avoid "if .. else if .. else .. endif endif"
338# because maintaining the nesting to match is a pain. If
339# we had "elif" things would have been much nicer...
340
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200341ifneq ($(OUTPUT),)
342 CFLAGS += -I$(OUTPUT)
343endif
344
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200345ifndef NO_GTK2
Namhyung Kimfc672972013-09-13 15:27:43 +0900346 ALL_PROGRAMS += $(OUTPUT)libperf-gtk.so
Jiri Olsa88aeea02014-12-30 00:34:23 +0100347 GTK_IN := $(OUTPUT)gtk-in.o
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200348endif
349
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200350ifdef ASCIIDOC8
351 export ASCIIDOC8
352endif
353
354LIBS = -Wl,--whole-archive $(PERFLIBS) -Wl,--no-whole-archive -Wl,--start-group $(EXTLIBS) -Wl,--end-group
355
Wang Nand58ac0b2016-11-26 07:03:33 +0000356ifeq ($(USE_CLANG), 1)
357 CLANGLIBS_LIST = AST Basic CodeGen Driver Frontend Lex Tooling Edit Sema Analysis Parse Serialization
358 LIBCLANG = $(foreach l,$(CLANGLIBS_LIST),$(wildcard $(shell $(LLVM_CONFIG) --libdir)/libclang$(l).a))
359 LIBS += -Wl,--start-group $(LIBCLANG) -Wl,--end-group
360endif
361
362ifeq ($(USE_LLVM), 1)
363 LIBLLVM = $(shell $(LLVM_CONFIG) --libs all) $(shell $(LLVM_CONFIG) --system-libs)
364 LIBS += -L$(shell $(LLVM_CONFIG) --libdir) $(LIBLLVM)
365endif
366
367ifeq ($(USE_CXX), 1)
368 LIBS += -lstdc++
369endif
370
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200371export INSTALL SHELL_PATH
372
373### Build rules
374
375SHELL = $(SHELL_PATH)
376
377all: shell_compatibility_test $(ALL_PROGRAMS) $(LANG_BINDINGS) $(OTHER_PROGRAMS)
378
Jiri Olsa0b4d4b02016-12-04 21:42:55 +0100379$(OUTPUT)python/perf.so: $(PYTHON_EXT_SRCS) $(PYTHON_EXT_DEPS) $(LIBTRACEEVENT_DYNAMIC_LIST)
380 $(QUIET_GEN)LDSHARED="$(CC) -pthread -shared" \
381 CFLAGS='$(CFLAGS)' LDFLAGS='$(LDFLAGS) $(LIBTRACEEVENT_DYNAMIC_LIST_LDFLAGS)' \
382 $(PYTHON_WORD) util/setup.py \
383 --quiet build_ext; \
384 mkdir -p $(OUTPUT)python && \
385 cp $(PYTHON_EXTBUILD_LIB)perf.so $(OUTPUT)python/
386
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200387please_set_SHELL_PATH_to_a_more_modern_shell:
Jiri Olsaceed2522015-01-11 23:59:55 +0100388 $(Q)$$(:)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200389
390shell_compatibility_test: please_set_SHELL_PATH_to_a_more_modern_shell
391
392strip: $(PROGRAMS) $(OUTPUT)perf
393 $(STRIP) $(STRIP_OPTS) $(PROGRAMS) $(OUTPUT)perf
394
Jiri Olsa72965b82014-12-29 13:52:36 +0100395PERF_IN := $(OUTPUT)perf-in.o
396
Andi Kleen80eeb672016-09-19 17:39:33 -0300397JEVENTS := $(OUTPUT)pmu-events/jevents
398JEVENTS_IN := $(OUTPUT)pmu-events/jevents-in.o
399
400PMU_EVENTS_IN := $(OUTPUT)pmu-events/pmu-events-in.o
401
402export JEVENTS
403
404build := -f $(srctree)/tools/build/Makefile.build dir=. obj
405
Jiri Olsa324c8242015-09-23 12:34:01 +0200406$(PERF_IN): prepare FORCE
Arnaldo Carvalho de Meloc4b60142016-07-11 10:28:48 -0300407 @(test -f ../../include/uapi/linux/perf_event.h && ( \
408 (diff -B ../include/uapi/linux/perf_event.h ../../include/uapi/linux/perf_event.h >/dev/null) \
409 || echo "Warning: tools/include/uapi/linux/perf_event.h differs from kernel" >&2 )) || true
Arnaldo Carvalho de Meloae3c14a2016-07-18 18:39:36 -0300410 @(test -f ../../include/linux/hash.h && ( \
411 (diff -B ../include/linux/hash.h ../../include/linux/hash.h >/dev/null) \
412 || echo "Warning: tools/include/linux/hash.h differs from kernel" >&2 )) || true
Arnaldo Carvalho de Melo4998a122016-07-11 23:37:18 -0300413 @(test -f ../../include/uapi/linux/hw_breakpoint.h && ( \
414 (diff -B ../include/uapi/linux/hw_breakpoint.h ../../include/uapi/linux/hw_breakpoint.h >/dev/null) \
415 || echo "Warning: tools/include/uapi/linux/hw_breakpoint.h differs from kernel" >&2 )) || true
Arnaldo Carvalho de Melo7d7d1bf2016-07-11 12:36:41 -0300416 @(test -f ../../arch/x86/include/asm/disabled-features.h && ( \
417 (diff -B ../arch/x86/include/asm/disabled-features.h ../../arch/x86/include/asm/disabled-features.h >/dev/null) \
418 || echo "Warning: tools/arch/x86/include/asm/disabled-features.h differs from kernel" >&2 )) || true
419 @(test -f ../../arch/x86/include/asm/required-features.h && ( \
420 (diff -B ../arch/x86/include/asm/required-features.h ../../arch/x86/include/asm/required-features.h >/dev/null) \
421 || echo "Warning: tools/arch/x86/include/asm/required-features.h differs from kernel" >&2 )) || true
422 @(test -f ../../arch/x86/include/asm/cpufeatures.h && ( \
423 (diff -B ../arch/x86/include/asm/cpufeatures.h ../../arch/x86/include/asm/cpufeatures.h >/dev/null) \
424 || echo "Warning: tools/arch/x86/include/asm/cpufeatures.h differs from kernel" >&2 )) || true
425 @(test -f ../../arch/x86/lib/memcpy_64.S && ( \
Arnaldo Carvalho de Meloe0c47582016-10-25 16:39:21 -0300426 (diff -B -I "^EXPORT_SYMBOL" -I "^#include <asm/export.h>" ../arch/x86/lib/memcpy_64.S ../../arch/x86/lib/memcpy_64.S >/dev/null) \
Arnaldo Carvalho de Melo7d7d1bf2016-07-11 12:36:41 -0300427 || echo "Warning: tools/arch/x86/lib/memcpy_64.S differs from kernel" >&2 )) || true
428 @(test -f ../../arch/x86/lib/memset_64.S && ( \
Arnaldo Carvalho de Meloe0c47582016-10-25 16:39:21 -0300429 (diff -B -I "^EXPORT_SYMBOL" -I "^#include <asm/export.h>" ../arch/x86/lib/memset_64.S ../../arch/x86/lib/memset_64.S >/dev/null) \
Arnaldo Carvalho de Melo7d7d1bf2016-07-11 12:36:41 -0300430 || echo "Warning: tools/arch/x86/lib/memset_64.S differs from kernel" >&2 )) || true
Arnaldo Carvalho de Melo12f02032016-07-11 21:16:52 -0300431 @(test -f ../../arch/arm/include/uapi/asm/perf_regs.h && ( \
432 (diff -B ../arch/arm/include/uapi/asm/perf_regs.h ../../arch/arm/include/uapi/asm/perf_regs.h >/dev/null) \
433 || echo "Warning: tools/arch/arm/include/uapi/asm/perf_regs.h differs from kernel" >&2 )) || true
434 @(test -f ../../arch/arm64/include/uapi/asm/perf_regs.h && ( \
435 (diff -B ../arch/arm64/include/uapi/asm/perf_regs.h ../../arch/arm64/include/uapi/asm/perf_regs.h >/dev/null) \
436 || echo "Warning: tools/arch/arm64/include/uapi/asm/perf_regs.h differs from kernel" >&2 )) || true
437 @(test -f ../../arch/powerpc/include/uapi/asm/perf_regs.h && ( \
438 (diff -B ../arch/powerpc/include/uapi/asm/perf_regs.h ../../arch/powerpc/include/uapi/asm/perf_regs.h >/dev/null) \
439 || echo "Warning: tools/arch/powerpc/include/uapi/asm/perf_regs.h differs from kernel" >&2 )) || true
440 @(test -f ../../arch/x86/include/uapi/asm/perf_regs.h && ( \
441 (diff -B ../arch/x86/include/uapi/asm/perf_regs.h ../../arch/x86/include/uapi/asm/perf_regs.h >/dev/null) \
442 || echo "Warning: tools/arch/x86/include/uapi/asm/perf_regs.h differs from kernel" >&2 )) || true
Arnaldo Carvalho de Melodd7bd102016-07-12 10:57:25 -0300443 @(test -f ../../arch/x86/include/uapi/asm/kvm.h && ( \
444 (diff -B ../arch/x86/include/uapi/asm/kvm.h ../../arch/x86/include/uapi/asm/kvm.h >/dev/null) \
445 || echo "Warning: tools/arch/x86/include/uapi/asm/kvm.h differs from kernel" >&2 )) || true
446 @(test -f ../../arch/x86/include/uapi/asm/kvm_perf.h && ( \
447 (diff -B ../arch/x86/include/uapi/asm/kvm_perf.h ../../arch/x86/include/uapi/asm/kvm_perf.h >/dev/null) \
448 || echo "Warning: tools/arch/x86/include/uapi/asm/kvm_perf.h differs from kernel" >&2 )) || true
449 @(test -f ../../arch/x86/include/uapi/asm/svm.h && ( \
450 (diff -B ../arch/x86/include/uapi/asm/svm.h ../../arch/x86/include/uapi/asm/svm.h >/dev/null) \
451 || echo "Warning: tools/arch/x86/include/uapi/asm/svm.h differs from kernel" >&2 )) || true
452 @(test -f ../../arch/x86/include/uapi/asm/vmx.h && ( \
453 (diff -B ../arch/x86/include/uapi/asm/vmx.h ../../arch/x86/include/uapi/asm/vmx.h >/dev/null) \
454 || echo "Warning: tools/arch/x86/include/uapi/asm/vmx.h differs from kernel" >&2 )) || true
455 @(test -f ../../arch/powerpc/include/uapi/asm/kvm.h && ( \
456 (diff -B ../arch/powerpc/include/uapi/asm/kvm.h ../../arch/powerpc/include/uapi/asm/kvm.h >/dev/null) \
457 || echo "Warning: tools/arch/powerpc/include/uapi/asm/kvm.h differs from kernel" >&2 )) || true
458 @(test -f ../../arch/s390/include/uapi/asm/kvm.h && ( \
459 (diff -B ../arch/s390/include/uapi/asm/kvm.h ../../arch/s390/include/uapi/asm/kvm.h >/dev/null) \
460 || echo "Warning: tools/arch/s390/include/uapi/asm/kvm.h differs from kernel" >&2 )) || true
461 @(test -f ../../arch/s390/include/uapi/asm/kvm_perf.h && ( \
462 (diff -B ../arch/s390/include/uapi/asm/kvm_perf.h ../../arch/s390/include/uapi/asm/kvm_perf.h >/dev/null) \
463 || echo "Warning: tools/arch/s390/include/uapi/asm/kvm_perf.h differs from kernel" >&2 )) || true
464 @(test -f ../../arch/s390/include/uapi/asm/sie.h && ( \
465 (diff -B ../arch/s390/include/uapi/asm/sie.h ../../arch/s390/include/uapi/asm/sie.h >/dev/null) \
466 || echo "Warning: tools/arch/s390/include/uapi/asm/sie.h differs from kernel" >&2 )) || true
467 @(test -f ../../arch/arm/include/uapi/asm/kvm.h && ( \
468 (diff -B ../arch/arm/include/uapi/asm/kvm.h ../../arch/arm/include/uapi/asm/kvm.h >/dev/null) \
469 || echo "Warning: tools/arch/arm/include/uapi/asm/kvm.h differs from kernel" >&2 )) || true
470 @(test -f ../../arch/arm64/include/uapi/asm/kvm.h && ( \
471 (diff -B ../arch/arm64/include/uapi/asm/kvm.h ../../arch/arm64/include/uapi/asm/kvm.h >/dev/null) \
472 || echo "Warning: tools/arch/arm64/include/uapi/asm/kvm.h differs from kernel" >&2 )) || true
Arnaldo Carvalho de Melode1e17b2016-07-18 18:13:22 -0300473 @(test -f ../../include/asm-generic/bitops/arch_hweight.h && ( \
474 (diff -B ../include/asm-generic/bitops/arch_hweight.h ../../include/asm-generic/bitops/arch_hweight.h >/dev/null) \
475 || echo "Warning: tools/include/asm-generic/bitops/arch_hweight.h differs from kernel" >&2 )) || true
476 @(test -f ../../include/asm-generic/bitops/const_hweight.h && ( \
477 (diff -B ../include/asm-generic/bitops/const_hweight.h ../../include/asm-generic/bitops/const_hweight.h >/dev/null) \
478 || echo "Warning: tools/include/asm-generic/bitops/const_hweight.h differs from kernel" >&2 )) || true
479 @(test -f ../../include/asm-generic/bitops/__fls.h && ( \
480 (diff -B ../include/asm-generic/bitops/__fls.h ../../include/asm-generic/bitops/__fls.h >/dev/null) \
481 || echo "Warning: tools/include/asm-generic/bitops/__fls.h differs from kernel" >&2 )) || true
482 @(test -f ../../include/asm-generic/bitops/fls.h && ( \
483 (diff -B ../include/asm-generic/bitops/fls.h ../../include/asm-generic/bitops/fls.h >/dev/null) \
484 || echo "Warning: tools/include/asm-generic/bitops/fls.h differs from kernel" >&2 )) || true
485 @(test -f ../../include/asm-generic/bitops/fls64.h && ( \
486 (diff -B ../include/asm-generic/bitops/fls64.h ../../include/asm-generic/bitops/fls64.h >/dev/null) \
487 || echo "Warning: tools/include/asm-generic/bitops/fls64.h differs from kernel" >&2 )) || true
Mathieu Poirier39ff5262016-08-11 10:20:56 -0600488 @(test -f ../../include/linux/coresight-pmu.h && ( \
489 (diff -B ../include/linux/coresight-pmu.h ../../include/linux/coresight-pmu.h >/dev/null) \
490 || echo "Warning: tools/include/linux/coresight-pmu.h differs from kernel" >&2 )) || true
Wang Nan0a4a7e42016-09-12 12:54:31 +0000491 @(test -f ../../include/uapi/asm-generic/mman-common.h && ( \
492 (diff -B ../include/uapi/asm-generic/mman-common.h ../../include/uapi/asm-generic/mman-common.h >/dev/null) \
493 || echo "Warning: tools/include/uapi/asm-generic/mman-common.h differs from kernel" >&2 )) || true
494 @(test -f ../../include/uapi/asm-generic/mman.h && ( \
495 (diff -B -I "^#include <\(uapi/\)*asm-generic/mman-common.h>$$" ../include/uapi/asm-generic/mman.h ../../include/uapi/asm-generic/mman.h >/dev/null) \
496 || echo "Warning: tools/include/uapi/asm-generic/mman.h differs from kernel" >&2 )) || true
497 @(test -f ../../include/uapi/linux/mman.h && ( \
498 (diff -B -I "^#include <\(uapi/\)*asm/mman.h>$$" ../include/uapi/linux/mman.h ../../include/uapi/linux/mman.h >/dev/null) \
499 || echo "Warning: tools/include/uapi/linux/mman.h differs from kernel" >&2 )) || true
Jiri Olsaceed2522015-01-11 23:59:55 +0100500 $(Q)$(MAKE) $(build)=perf
Jiri Olsa72965b82014-12-29 13:52:36 +0100501
Andi Kleen80eeb672016-09-19 17:39:33 -0300502$(JEVENTS_IN): FORCE
503 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=pmu-events obj=jevents
504
505$(JEVENTS): $(JEVENTS_IN)
506 $(QUIET_LINK)$(HOSTCC) $(JEVENTS_IN) -o $@
507
508$(PMU_EVENTS_IN): $(JEVENTS) FORCE
509 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=pmu-events obj=pmu-events
510
511$(OUTPUT)perf: $(PERFLIBS) $(PERF_IN) $(PMU_EVENTS_IN) $(LIBTRACEEVENT_DYNAMIC_LIST)
Wang Nan5d618322015-06-17 14:46:29 +0000512 $(QUIET_LINK)$(CC) $(CFLAGS) $(LDFLAGS) $(LIBTRACEEVENT_DYNAMIC_LIST_LDFLAGS) \
Andi Kleen80eeb672016-09-19 17:39:33 -0300513 $(PERF_IN) $(PMU_EVENTS_IN) $(LIBS) -o $@
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200514
Jiri Olsaabb26212016-12-06 14:18:49 +0100515$(GTK_IN): FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100516 $(Q)$(MAKE) $(build)=gtk
Namhyung Kimfc672972013-09-13 15:27:43 +0900517
Jiri Olsa88aeea02014-12-30 00:34:23 +0100518$(OUTPUT)libperf-gtk.so: $(GTK_IN) $(PERFLIBS)
Jiri Olsae27a08f2014-04-27 11:12:21 +0200519 $(QUIET_LINK)$(CC) -o $@ -shared $(LDFLAGS) $(filter %.o,$^) $(GTK_LIBS)
Namhyung Kimfc672972013-09-13 15:27:43 +0900520
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200521$(OUTPUT)common-cmds.h: util/generate-cmdlist.sh command-list.txt
522
523$(OUTPUT)common-cmds.h: $(wildcard Documentation/perf-*.txt)
524 $(QUIET_GEN). util/generate-cmdlist.sh > $@+ && mv $@+ $@
525
526$(SCRIPTS) : % : %.sh
527 $(QUIET_GEN)$(INSTALL) '$@.sh' '$(OUTPUT)$@'
528
Jiri Olsa16e2ef42016-12-06 14:18:48 +0100529$(OUTPUT)PERF-VERSION-FILE: ../../.git/HEAD
530 $(Q)$(SHELL_PATH) util/PERF-VERSION-GEN $(OUTPUT)
531 $(Q)touch $(OUTPUT)PERF-VERSION-FILE
532
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200533# These can record PERF_VERSION
Jiri Olsacb4e67f2014-12-30 17:09:15 +0100534perf.spec $(SCRIPTS) \
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200535 : $(OUTPUT)PERF-VERSION-FILE
536
537.SUFFIXES:
Ingo Molnar1f7c6452013-10-04 12:14:59 +0200538
539#
540# If a target does not match any of the later rules then prefix it by $(OUTPUT)
541# This makes targets like 'make O=/tmp/perf perf.o' work in a natural way.
542#
543ifneq ($(OUTPUT),)
544%.o: $(OUTPUT)%.o
545 @echo " # Redirected target $@ => $(OUTPUT)$@"
Andi Kleen80eeb672016-09-19 17:39:33 -0300546pmu-events/%.o: $(OUTPUT)pmu-events/%.o
547 @echo " # Redirected target $@ => $(OUTPUT)$@"
Ingo Molnar1f7c6452013-10-04 12:14:59 +0200548util/%.o: $(OUTPUT)util/%.o
Ingo Molnarcee972c2013-10-10 07:42:56 +0200549 @echo " # Redirected target $@ => $(OUTPUT)$@"
Ingo Molnar1f7c6452013-10-04 12:14:59 +0200550bench/%.o: $(OUTPUT)bench/%.o
Ingo Molnarcee972c2013-10-10 07:42:56 +0200551 @echo " # Redirected target $@ => $(OUTPUT)$@"
Ingo Molnar1f7c6452013-10-04 12:14:59 +0200552tests/%.o: $(OUTPUT)tests/%.o
Ingo Molnarcee972c2013-10-10 07:42:56 +0200553 @echo " # Redirected target $@ => $(OUTPUT)$@"
Ingo Molnar1f7c6452013-10-04 12:14:59 +0200554endif
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200555
556# These two need to be here so that when O= is not used they take precedence
557# over the general rule for .o
558
Jiri Olsa19993072014-12-30 18:44:38 +0100559# get relative building directory (to $(OUTPUT))
560# and '.' if it's $(OUTPUT) itself
561__build-dir = $(subst $(OUTPUT),,$(dir $@))
562build-dir = $(if $(__build-dir),$(__build-dir),.)
563
Jiri Olsaabb26212016-12-06 14:18:49 +0100564prepare: $(OUTPUT)PERF-VERSION-FILE $(OUTPUT)common-cmds.h archheaders
Jiri Olsa19993072014-12-30 18:44:38 +0100565
Jiri Olsa324c8242015-09-23 12:34:01 +0200566$(OUTPUT)%.o: %.c prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100567 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
Jiri Olsa19993072014-12-30 18:44:38 +0100568
Jiri Olsa324c8242015-09-23 12:34:01 +0200569$(OUTPUT)%.i: %.c prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100570 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
Jiri Olsa19993072014-12-30 18:44:38 +0100571
Jiri Olsa324c8242015-09-23 12:34:01 +0200572$(OUTPUT)%.s: %.c prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100573 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
Jiri Olsa19993072014-12-30 18:44:38 +0100574
Jiri Olsa324c8242015-09-23 12:34:01 +0200575$(OUTPUT)%-bison.o: %.c prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100576 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
Jiri Olsa19993072014-12-30 18:44:38 +0100577
Jiri Olsa324c8242015-09-23 12:34:01 +0200578$(OUTPUT)%-flex.o: %.c prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100579 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
Jiri Olsa19993072014-12-30 18:44:38 +0100580
Jiri Olsa324c8242015-09-23 12:34:01 +0200581$(OUTPUT)%.o: %.S prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100582 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
Jiri Olsa19993072014-12-30 18:44:38 +0100583
Jiri Olsa324c8242015-09-23 12:34:01 +0200584$(OUTPUT)%.i: %.S prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100585 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200586
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200587$(OUTPUT)perf-%: %.o $(PERFLIBS)
588 $(QUIET_LINK)$(CC) $(CFLAGS) -o $@ $(LDFLAGS) $(filter %.o,$^) $(LIBS)
589
Adrian Huntere477f3f2014-10-23 18:16:03 -0300590ifndef NO_PERF_READ_VDSO32
591$(OUTPUT)perf-read-vdso32: perf-read-vdso.c util/find-vdso-map.c
592 $(QUIET_CC)$(CC) -m32 $(filter -static,$(LDFLAGS)) -Wall -Werror -o $@ perf-read-vdso.c
593endif
594
595ifndef NO_PERF_READ_VDSOX32
596$(OUTPUT)perf-read-vdsox32: perf-read-vdso.c util/find-vdso-map.c
597 $(QUIET_CC)$(CC) -mx32 $(filter -static,$(LDFLAGS)) -Wall -Werror -o $@ perf-read-vdso.c
598endif
599
Jiri Olsad4dfdf02016-11-02 14:35:49 +0100600ifndef NO_JVMTI
601LIBJVMTI_IN := $(OUTPUT)jvmti/jvmti-in.o
602
603$(LIBJVMTI_IN): FORCE
604 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=jvmti obj=jvmti
605
606$(OUTPUT)$(LIBJVMTI): $(LIBJVMTI_IN)
607 $(QUIET_LINK)$(CC) -shared -Wl,-soname -Wl,$(LIBJVMTI) -o $@ $< -lelf -lrt
608endif
609
Jiri Olsa8e499ac2014-12-30 16:51:35 +0100610$(patsubst perf-%,%.o,$(PROGRAMS)): $(wildcard */*.h)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200611
Jiri Olsa9352aab2014-12-29 17:42:46 +0100612LIBPERF_IN := $(OUTPUT)libperf-in.o
613
Jiri Olsaabb26212016-12-06 14:18:49 +0100614$(LIBPERF_IN): prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100615 $(Q)$(MAKE) $(build)=libperf
Jiri Olsa9352aab2014-12-29 17:42:46 +0100616
Jiri Olsa8e499ac2014-12-30 16:51:35 +0100617$(LIB_FILE): $(LIBPERF_IN)
Jiri Olsa9352aab2014-12-29 17:42:46 +0100618 $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $(LIBPERF_IN) $(LIB_OBJS)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200619
Jiri Olsa3d7c0142013-12-03 14:09:21 +0100620LIBTRACEEVENT_FLAGS += plugin_dir=$(plugindir_SQ)
621
Jiri Olsaabb26212016-12-06 14:18:49 +0100622$(LIBTRACEEVENT): FORCE
He Kuange3d09ec2015-05-28 13:28:54 +0000623 $(Q)$(MAKE) -C $(TRACE_EVENT_DIR) $(LIBTRACEEVENT_FLAGS) O=$(OUTPUT) $(OUTPUT)libtraceevent.a
624
Jiri Olsaabb26212016-12-06 14:18:49 +0100625libtraceevent_plugins: FORCE
He Kuange3d09ec2015-05-28 13:28:54 +0000626 $(Q)$(MAKE) -C $(TRACE_EVENT_DIR) $(LIBTRACEEVENT_FLAGS) O=$(OUTPUT) plugins
627
628$(LIBTRACEEVENT_DYNAMIC_LIST): libtraceevent_plugins
629 $(Q)$(MAKE) -C $(TRACE_EVENT_DIR) $(LIBTRACEEVENT_FLAGS) O=$(OUTPUT) $(OUTPUT)libtraceevent-dynamic-list
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200630
631$(LIBTRACEEVENT)-clean:
Ingo Molnar8ec19c02013-10-09 11:49:26 +0200632 $(call QUIET_CLEAN, libtraceevent)
Jiri Olsaceed2522015-01-11 23:59:55 +0100633 $(Q)$(MAKE) -C $(TRACE_EVENT_DIR) O=$(OUTPUT) clean >/dev/null
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200634
Jiri Olsa67befc62015-11-26 14:54:04 +0100635install-traceevent-plugins: libtraceevent_plugins
Jiri Olsaceed2522015-01-11 23:59:55 +0100636 $(Q)$(MAKE) -C $(TRACE_EVENT_DIR) $(LIBTRACEEVENT_FLAGS) O=$(OUTPUT) install_plugins
Jiri Olsa3d7c0142013-12-03 14:09:21 +0100637
Jiri Olsaabb26212016-12-06 14:18:49 +0100638$(LIBAPI): FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100639 $(Q)$(MAKE) -C $(LIB_DIR) O=$(OUTPUT) $(OUTPUT)libapi.a
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200640
Jiri Olsa285a8f22015-01-10 20:53:13 +0100641$(LIBAPI)-clean:
642 $(call QUIET_CLEAN, libapi)
Jiri Olsaceed2522015-01-11 23:59:55 +0100643 $(Q)$(MAKE) -C $(LIB_DIR) O=$(OUTPUT) clean >/dev/null
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200644
Jiri Olsaabb26212016-12-06 14:18:49 +0100645$(LIBBPF): FORCE
Jiri Olsa96b9e702016-01-15 04:00:18 +0000646 $(Q)$(MAKE) -C $(BPF_DIR) O=$(OUTPUT) $(OUTPUT)libbpf.a FEATURES_DUMP=$(FEATURE_DUMP_EXPORT)
Wang Naned63f34c2015-10-14 12:41:12 +0000647
648$(LIBBPF)-clean:
649 $(call QUIET_CLEAN, libbpf)
650 $(Q)$(MAKE) -C $(BPF_DIR) O=$(OUTPUT) clean >/dev/null
651
Jiri Olsaabb26212016-12-06 14:18:49 +0100652$(LIBSUBCMD): FORCE
Josh Poimboeuf4b6ab942015-12-15 09:39:39 -0600653 $(Q)$(MAKE) -C $(SUBCMD_DIR) O=$(OUTPUT) $(OUTPUT)libsubcmd.a
654
655$(LIBSUBCMD)-clean:
656 $(call QUIET_CLEAN, libsubcmd)
657 $(Q)$(MAKE) -C $(SUBCMD_DIR) O=$(OUTPUT) clean
658
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200659help:
660 @echo 'Perf make targets:'
661 @echo ' doc - make *all* documentation (see below)'
662 @echo ' man - make manpage documentation (access with man <foo>)'
663 @echo ' html - make html documentation'
664 @echo ' info - make GNU info documentation (access with info <foo>)'
665 @echo ' pdf - make pdf documentation'
666 @echo ' TAGS - use etags to make tag information for source browsing'
667 @echo ' tags - use ctags to make tag information for source browsing'
668 @echo ' cscope - use cscope to make interactive browsing database'
669 @echo ''
670 @echo 'Perf install targets:'
671 @echo ' NOTE: documentation build requires asciidoc, xmlto packages to be installed'
Jianyu Zhanfc9cabe2014-06-03 00:44:34 +0800672 @echo ' HINT: use "prefix" or "DESTDIR" to install to a particular'
673 @echo ' path like "make prefix=/usr/local install install-doc"'
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200674 @echo ' install - install compiled binaries'
675 @echo ' install-doc - install *all* documentation'
676 @echo ' install-man - install manpage documentation'
677 @echo ' install-html - install html documentation'
678 @echo ' install-info - install GNU info documentation'
679 @echo ' install-pdf - install pdf documentation'
680 @echo ''
681 @echo ' quick-install-doc - alias for quick-install-man'
682 @echo ' quick-install-man - install the documentation quickly'
683 @echo ' quick-install-html - install the html documentation quickly'
684 @echo ''
685 @echo 'Perf maintainer targets:'
686 @echo ' clean - clean all binary objects and build output'
687
688
689DOC_TARGETS := doc man html info pdf
690
691INSTALL_DOC_TARGETS := $(patsubst %,install-%,$(DOC_TARGETS)) try-install-man
692INSTALL_DOC_TARGETS += quick-install-doc quick-install-man quick-install-html
693
694# 'make doc' should call 'make -C Documentation all'
695$(DOC_TARGETS):
696 $(QUIET_SUBDIR0)Documentation $(QUIET_SUBDIR1) $(@:doc=all)
697
Jiri Olsa685c8412016-01-07 10:14:06 +0100698TAG_FOLDERS= . ../lib ../include
Sebastian Andrzej Siewior16a64332014-05-28 10:19:18 +0200699TAG_FILES= ../../include/uapi/linux/perf_event.h
700
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200701TAGS:
Jiri Olsab0815d02014-06-04 14:43:58 +0200702 $(QUIET_GEN)$(RM) TAGS; \
Sebastian Andrzej Siewior16a64332014-05-28 10:19:18 +0200703 $(FIND) $(TAG_FOLDERS) -name '*.[hcS]' -print | xargs etags -a $(TAG_FILES)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200704
705tags:
Jiri Olsab0815d02014-06-04 14:43:58 +0200706 $(QUIET_GEN)$(RM) tags; \
Sebastian Andrzej Siewior16a64332014-05-28 10:19:18 +0200707 $(FIND) $(TAG_FOLDERS) -name '*.[hcS]' -print | xargs ctags -a $(TAG_FILES)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200708
709cscope:
Jiri Olsab0815d02014-06-04 14:43:58 +0200710 $(QUIET_GEN)$(RM) cscope*; \
Sebastian Andrzej Siewior16a64332014-05-28 10:19:18 +0200711 $(FIND) $(TAG_FOLDERS) -name '*.[hcS]' -print | xargs cscope -b $(TAG_FILES)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200712
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200713### Testing rules
714
715# GNU make supports exporting all variables by "export" without parameters.
716# However, the environment gets quite big, and some programs have problems
717# with that.
718
719check: $(OUTPUT)common-cmds.h
720 if sparse; \
721 then \
722 for i in *.c */*.c; \
723 do \
724 sparse $(CFLAGS) $(SPARSE_FLAGS) $$i || exit; \
725 done; \
726 else \
727 exit 1; \
728 fi
729
730### Installation rules
731
Jiri Olsa5c319a62016-12-04 21:42:54 +0100732ifndef NO_GTK2
733install-gtk: $(OUTPUT)libperf-gtk.so
734 $(call QUIET_INSTALL, 'GTK UI') \
735 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(libdir_SQ)'; \
736 $(INSTALL) $(OUTPUT)libperf-gtk.so '$(DESTDIR_SQ)$(libdir_SQ)'
737else
Namhyung Kimfc672972013-09-13 15:27:43 +0900738install-gtk:
Jiri Olsa5c319a62016-12-04 21:42:54 +0100739endif
Namhyung Kimfc672972013-09-13 15:27:43 +0900740
Nam T. Nguyen128c32e2015-05-18 11:37:27 -0700741install-tools: all install-gtk
Ingo Molnar8a5411e92013-10-09 11:49:29 +0200742 $(call QUIET_INSTALL, binaries) \
743 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(bindir_SQ)'; \
744 $(INSTALL) $(OUTPUT)perf '$(DESTDIR_SQ)$(bindir_SQ)'; \
745 $(LN) '$(DESTDIR_SQ)$(bindir_SQ)/perf' '$(DESTDIR_SQ)$(bindir_SQ)/trace'
Adrian Huntere477f3f2014-10-23 18:16:03 -0300746ifndef NO_PERF_READ_VDSO32
747 $(call QUIET_INSTALL, perf-read-vdso32) \
748 $(INSTALL) $(OUTPUT)perf-read-vdso32 '$(DESTDIR_SQ)$(bindir_SQ)';
749endif
750ifndef NO_PERF_READ_VDSOX32
751 $(call QUIET_INSTALL, perf-read-vdsox32) \
752 $(INSTALL) $(OUTPUT)perf-read-vdsox32 '$(DESTDIR_SQ)$(bindir_SQ)';
753endif
Jiri Olsad4dfdf02016-11-02 14:35:49 +0100754ifndef NO_JVMTI
755 $(call QUIET_INSTALL, $(LIBJVMTI)) \
756 $(INSTALL) $(OUTPUT)$(LIBJVMTI) '$(DESTDIR_SQ)$(libdir_SQ)';
757endif
Ingo Molnar8a5411e92013-10-09 11:49:29 +0200758 $(call QUIET_INSTALL, libexec) \
759 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)'
760 $(call QUIET_INSTALL, perf-archive) \
761 $(INSTALL) $(OUTPUT)perf-archive -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)'
Adrian Hunterc501e902014-07-31 09:01:12 +0300762 $(call QUIET_INSTALL, perf-with-kcore) \
763 $(INSTALL) $(OUTPUT)perf-with-kcore -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)'
Arnaldo Carvalho de Melo005438a82015-07-20 12:02:09 -0300764ifndef NO_LIBAUDIT
765 $(call QUIET_INSTALL, strace/groups) \
766 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(STRACE_GROUPS_INSTDIR_SQ)'; \
767 $(INSTALL) trace/strace/groups/* -t '$(DESTDIR_SQ)$(STRACE_GROUPS_INSTDIR_SQ)'
768endif
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200769ifndef NO_LIBPERL
Ingo Molnar8a5411e92013-10-09 11:49:29 +0200770 $(call QUIET_INSTALL, perl-scripts) \
771 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/perl/Perf-Trace-Util/lib/Perf/Trace'; \
772 $(INSTALL) scripts/perl/Perf-Trace-Util/lib/Perf/Trace/* -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/perl/Perf-Trace-Util/lib/Perf/Trace'; \
773 $(INSTALL) scripts/perl/*.pl -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/perl'; \
774 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/perl/bin'; \
775 $(INSTALL) scripts/perl/bin/* -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/perl/bin'
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200776endif
777ifndef NO_LIBPYTHON
Ingo Molnar8a5411e92013-10-09 11:49:29 +0200778 $(call QUIET_INSTALL, python-scripts) \
779 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/python/Perf-Trace-Util/lib/Perf/Trace'; \
780 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/python/bin'; \
781 $(INSTALL) scripts/python/Perf-Trace-Util/lib/Perf/Trace/* -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/python/Perf-Trace-Util/lib/Perf/Trace'; \
782 $(INSTALL) scripts/python/*.py -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/python'; \
783 $(INSTALL) scripts/python/bin/* -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/python/bin'
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200784endif
Ramkumar Ramachandraa8b4c7012013-11-17 21:43:27 +0530785 $(call QUIET_INSTALL, perf_completion-script) \
Ingo Molnar8a5411e92013-10-09 11:49:29 +0200786 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(sysconfdir_SQ)/bash_completion.d'; \
Ramkumar Ramachandraa8b4c7012013-11-17 21:43:27 +0530787 $(INSTALL) perf-completion.sh '$(DESTDIR_SQ)$(sysconfdir_SQ)/bash_completion.d/perf'
Namhyung Kim14cbfbe2016-01-07 20:41:53 +0900788 $(call QUIET_INSTALL, perf-tip) \
789 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(tip_instdir_SQ)'; \
790 $(INSTALL) Documentation/tips.txt -t '$(DESTDIR_SQ)$(tip_instdir_SQ)'
Nam T. Nguyen128c32e2015-05-18 11:37:27 -0700791
792install-tests: all install-gtk
Ingo Molnar8a5411e92013-10-09 11:49:29 +0200793 $(call QUIET_INSTALL, tests) \
794 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/tests'; \
795 $(INSTALL) tests/attr.py '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/tests'; \
796 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/tests/attr'; \
797 $(INSTALL) tests/attr/* '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/tests/attr'
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200798
Nam T. Nguyen128c32e2015-05-18 11:37:27 -0700799install-bin: install-tools install-tests
800
Jiri Olsa3d7c0142013-12-03 14:09:21 +0100801install: install-bin try-install-man install-traceevent-plugins
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200802
803install-python_ext:
804 $(PYTHON_WORD) util/setup.py --quiet install --root='/$(DESTDIR_SQ)'
805
806# 'make install-doc' should call 'make -C Documentation install'
807$(INSTALL_DOC_TARGETS):
808 $(QUIET_SUBDIR0)Documentation $(QUIET_SUBDIR1) $(@:-doc=)
809
810### Cleaning rules
811
812#
Jiri Olsa48425762016-08-01 20:02:33 +0200813# This is here, not in Makefile.config, because Makefile.config does
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200814# not get included for the clean target:
815#
816config-clean:
Ingo Molnar8ec19c02013-10-09 11:49:26 +0200817 $(call QUIET_CLEAN, config)
Josh Poimboeuf8f46dfd2015-12-13 22:18:05 -0600818 $(Q)$(MAKE) -C $(srctree)/tools/build/feature/ $(if $(OUTPUT),OUTPUT=$(OUTPUT)feature/,) clean >/dev/null
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200819
Arnaldo Carvalho de Melo1b700c92016-04-04 19:05:36 -0300820clean:: $(LIBTRACEEVENT)-clean $(LIBAPI)-clean $(LIBBPF)-clean $(LIBSUBCMD)-clean config-clean
Jiri Olsa8e499ac2014-12-30 16:51:35 +0100821 $(call QUIET_CLEAN, core-objs) $(RM) $(LIB_FILE) $(OUTPUT)perf-archive $(OUTPUT)perf-with-kcore $(LANG_BINDINGS)
Josh Poimboeuf8f46dfd2015-12-13 22:18:05 -0600822 $(Q)find $(if $(OUTPUT),$(OUTPUT),.) -name '*.o' -delete -o -name '\.*.cmd' -delete -o -name '\.*.d' -delete
Aaro Koskinen642273792015-07-01 14:54:42 +0300823 $(Q)$(RM) $(OUTPUT).config-detected
Jiri Olsad4dfdf02016-11-02 14:35:49 +0100824 $(call QUIET_CLEAN, core-progs) $(RM) $(ALL_PROGRAMS) perf perf-read-vdso32 perf-read-vdsox32 $(OUTPUT)pmu-events/jevents $(OUTPUT)$(LIBJVMTI).so
Adrian Hunter237fae72015-08-13 10:14:55 +0300825 $(call QUIET_CLEAN, core-gen) $(RM) *.spec *.pyc *.pyo */*.pyc */*.pyo $(OUTPUT)common-cmds.h TAGS tags cscope* $(OUTPUT)PERF-VERSION-FILE $(OUTPUT)FEATURE-DUMP $(OUTPUT)util/*-bison* $(OUTPUT)util/*-flex* \
Josh Poimboeuf8f46dfd2015-12-13 22:18:05 -0600826 $(OUTPUT)util/intel-pt-decoder/inat-tables.c $(OUTPUT)fixdep \
Andi Kleen80eeb672016-09-19 17:39:33 -0300827 $(OUTPUT)tests/llvm-src-{base,kbuild,prologue,relocation}.c \
828 $(OUTPUT)pmu-events/pmu-events.c
Borislav Petkov553873e2013-12-09 17:14:23 +0100829 $(QUIET_SUBDIR0)Documentation $(QUIET_SUBDIR1) clean
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200830 $(python-clean)
831
832#
Jiri Olsab8e52be2016-01-15 04:00:17 +0000833# To provide FEATURE-DUMP into $(FEATURE_DUMP_COPY)
834# file if defined, with no further action.
835feature-dump:
836ifdef FEATURE_DUMP_COPY
837 @cp $(OUTPUT)FEATURE-DUMP $(FEATURE_DUMP_COPY)
838 @echo "FEATURE-DUMP file copied into $(FEATURE_DUMP_COPY)"
839else
840 @echo "FEATURE-DUMP file available in $(OUTPUT)FEATURE-DUMP"
841endif
842
843#
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200844# Trick: if ../../.git does not exist - we are building out of tree for example,
845# then force version regeneration:
846#
847ifeq ($(wildcard ../../.git/HEAD),)
848 GIT-HEAD-PHONY = ../../.git/HEAD
849else
850 GIT-HEAD-PHONY =
851endif
852
Jiri Olsa72965b82014-12-29 13:52:36 +0100853FORCE:
854
Namhyung Kimfc672972013-09-13 15:27:43 +0900855.PHONY: all install clean config-clean strip install-gtk
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200856.PHONY: shell_compatibility_test please_set_SHELL_PATH_to_a_more_modern_shell
Jiri Olsa324c8242015-09-23 12:34:01 +0200857.PHONY: $(GIT-HEAD-PHONY) TAGS tags cscope FORCE prepare
Arnaldo Carvalho de Melo1b700c92016-04-04 19:05:36 -0300858.PHONY: libtraceevent_plugins archheaders
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200859
Jiri Olsaabb26212016-12-06 14:18:49 +0100860endif # force_fixdep