blob: 593d765d62abf36e524c773eed50b862c0fd6167 [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
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200131$(OUTPUT)PERF-VERSION-FILE: ../../.git/HEAD
Jiri Olsaceed2522015-01-11 23:59:55 +0100132 $(Q)$(SHELL_PATH) util/PERF-VERSION-GEN $(OUTPUT)
133 $(Q)touch $(OUTPUT)PERF-VERSION-FILE
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200134
Alexey Brodkin3c71ba32015-07-14 12:05:20 +0300135# Makefiles suck: This macro sets a default value of $(2) for the
136# variable named by $(1), unless the variable has been set by
137# environment or command line. This is necessary for CC and AR
138# because make sets default values, so the simpler ?= approach
139# won't work as expected.
140define allow-override
141 $(if $(or $(findstring environment,$(origin $(1))),\
142 $(findstring command line,$(origin $(1)))),,\
143 $(eval $(1) = $(2)))
144endef
145
146# Allow setting CC and AR and LD, or setting CROSS_COMPILE as a prefix.
147$(call allow-override,CC,$(CROSS_COMPILE)gcc)
148$(call allow-override,AR,$(CROSS_COMPILE)ar)
149$(call allow-override,LD,$(CROSS_COMPILE)ld)
Wang Nand58ac0b2016-11-26 07:03:33 +0000150$(call allow-override,CXX,$(CROSS_COMPILE)g++)
Alexey Brodkin3c71ba32015-07-14 12:05:20 +0300151
Zubair Lutfullah Kakakhel37b4e202016-02-09 13:33:38 +0000152LD += $(EXTRA_LDFLAGS)
153
Andi Kleen80eeb672016-09-19 17:39:33 -0300154HOSTCC ?= gcc
155HOSTLD ?= ld
156HOSTAR ?= ar
157
Mark Rutlanda8a5cd82014-01-15 10:44:08 +0000158PKG_CONFIG = $(CROSS_COMPILE)pkg-config
Wang Nand58ac0b2016-11-26 07:03:33 +0000159LLVM_CONFIG ?= llvm-config
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200160
161RM = rm -f
Arnaldo Carvalho de Melob52bc232013-09-24 11:56:36 -0300162LN = ln -f
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200163MKDIR = mkdir
164FIND = find
165INSTALL = install
166FLEX = flex
167BISON = bison
168STRIP = strip
Adrian Hunter237fae72015-08-13 10:14:55 +0300169AWK = awk
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200170
Josh Poimboeuf4b6ab942015-12-15 09:39:39 -0600171LIB_DIR = $(srctree)/tools/lib/api/
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200172TRACE_EVENT_DIR = $(srctree)/tools/lib/traceevent/
Josh Poimboeuf4b6ab942015-12-15 09:39:39 -0600173BPF_DIR = $(srctree)/tools/lib/bpf/
174SUBCMD_DIR = $(srctree)/tools/lib/subcmd/
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200175
Jiri Olsa48425762016-08-01 20:02:33 +0200176# include Makefile.config by default and rule out
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200177# non-config cases
178config := 1
179
Rui Teng11196b72016-08-10 16:49:08 +0800180NON_CONFIG_TARGETS := clean TAGS tags cscope help install-doc
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200181
182ifdef MAKECMDGOALS
183ifeq ($(filter-out $(NON_CONFIG_TARGETS),$(MAKECMDGOALS)),)
184 config := 0
185endif
186endif
187
Wang Nanc053a152016-01-25 09:55:51 +0000188# Set FEATURE_TESTS to 'all' so all possible feature checkers are executed.
189# Without this setting the output feature dump file misses some features, for
190# example, liberty. Select all checkers so we won't get an incomplete feature
191# dump file.
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200192ifeq ($(config),1)
Wang Nanc053a152016-01-25 09:55:51 +0000193ifdef MAKECMDGOALS
194ifeq ($(filter feature-dump,$(MAKECMDGOALS)),feature-dump)
195FEATURE_TESTS := all
196endif
197endif
Jiri Olsa48425762016-08-01 20:02:33 +0200198include Makefile.config
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200199endif
200
Arnaldo Carvalho de Melo1b700c92016-04-04 19:05:36 -0300201ifeq ($(config),0)
202include $(srctree)/tools/scripts/Makefile.arch
203-include arch/$(ARCH)/Makefile
204endif
205
Jiri Olsa96b9e702016-01-15 04:00:18 +0000206# The FEATURE_DUMP_EXPORT holds location of the actual
207# FEATURE_DUMP file to be used to bypass feature detection
208# (for bpf or any other subproject)
209ifeq ($(FEATURES_DUMP),)
210FEATURE_DUMP_EXPORT := $(realpath $(OUTPUT)FEATURE-DUMP)
211else
212FEATURE_DUMP_EXPORT := $(FEATURES_DUMP)
213endif
214
Jiri Olsa3d7c0142013-12-03 14:09:21 +0100215export prefix bindir sharedir sysconfdir DESTDIR
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200216
217# sparse is architecture-neutral, which means that we need to tell it
218# explicitly what architecture to check for. Fix this up for yours..
219SPARSE_FLAGS = -D__BIG_ENDIAN__ -D__powerpc__
220
221# Guard against environment variables
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200222PYRF_OBJS =
223SCRIPT_SH =
224
225SCRIPT_SH += perf-archive.sh
Adrian Hunterc501e902014-07-31 09:01:12 +0300226SCRIPT_SH += perf-with-kcore.sh
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200227
228grep-libs = $(filter -l%,$(1))
229strip-libs = $(filter-out -l%,$(1))
230
231ifneq ($(OUTPUT),)
232 TE_PATH=$(OUTPUT)
Wang Naned63f34c2015-10-14 12:41:12 +0000233 BPF_PATH=$(OUTPUT)
Josh Poimboeuf4b6ab942015-12-15 09:39:39 -0600234 SUBCMD_PATH=$(OUTPUT)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200235ifneq ($(subdir),)
Josh Poimboeuf212e9842015-12-13 22:18:06 -0600236 API_PATH=$(OUTPUT)/../lib/api/
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200237else
Josh Poimboeuf212e9842015-12-13 22:18:06 -0600238 API_PATH=$(OUTPUT)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200239endif
240else
241 TE_PATH=$(TRACE_EVENT_DIR)
Josh Poimboeuf212e9842015-12-13 22:18:06 -0600242 API_PATH=$(LIB_DIR)
Wang Naned63f34c2015-10-14 12:41:12 +0000243 BPF_PATH=$(BPF_DIR)
Josh Poimboeuf4b6ab942015-12-15 09:39:39 -0600244 SUBCMD_PATH=$(SUBCMD_DIR)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200245endif
246
247LIBTRACEEVENT = $(TE_PATH)libtraceevent.a
248export LIBTRACEEVENT
249
He Kuange3d09ec2015-05-28 13:28:54 +0000250LIBTRACEEVENT_DYNAMIC_LIST = $(TE_PATH)libtraceevent-dynamic-list
Wang Nan5d618322015-06-17 14:46:29 +0000251LIBTRACEEVENT_DYNAMIC_LIST_LDFLAGS = -Xlinker --dynamic-list=$(LIBTRACEEVENT_DYNAMIC_LIST)
He Kuange3d09ec2015-05-28 13:28:54 +0000252
Josh Poimboeuf212e9842015-12-13 22:18:06 -0600253LIBAPI = $(API_PATH)libapi.a
Jiri Olsa285a8f22015-01-10 20:53:13 +0100254export LIBAPI
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200255
Wang Naned63f34c2015-10-14 12:41:12 +0000256LIBBPF = $(BPF_PATH)libbpf.a
257
Josh Poimboeuf4b6ab942015-12-15 09:39:39 -0600258LIBSUBCMD = $(SUBCMD_PATH)libsubcmd.a
259
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200260# python extension build directories
261PYTHON_EXTBUILD := $(OUTPUT)python_ext_build/
262PYTHON_EXTBUILD_LIB := $(PYTHON_EXTBUILD)lib/
263PYTHON_EXTBUILD_TMP := $(PYTHON_EXTBUILD)tmp/
264export PYTHON_EXTBUILD_LIB PYTHON_EXTBUILD_TMP
265
Ingo Molnar8ec19c02013-10-09 11:49:26 +0200266python-clean := $(call QUIET_CLEAN, python) $(RM) -r $(PYTHON_EXTBUILD) $(OUTPUT)python/perf.so
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200267
268PYTHON_EXT_SRCS := $(shell grep -v ^\# util/python-ext-sources)
Jiri Olsa285a8f22015-01-10 20:53:13 +0100269PYTHON_EXT_DEPS := util/python-ext-sources util/setup.py $(LIBTRACEEVENT) $(LIBAPI)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200270
Wang Nana35489a2015-06-12 03:17:11 +0000271$(OUTPUT)python/perf.so: $(PYTHON_EXT_SRCS) $(PYTHON_EXT_DEPS) $(LIBTRACEEVENT_DYNAMIC_LIST)
He Kuang48d8d5d2016-06-22 06:57:05 +0000272 $(QUIET_GEN)LDSHARED="$(CC) -pthread -shared" \
273 CFLAGS='$(CFLAGS)' LDFLAGS='$(LDFLAGS) $(LIBTRACEEVENT_DYNAMIC_LIST_LDFLAGS)' \
Wang Nan5d618322015-06-17 14:46:29 +0000274 $(PYTHON_WORD) util/setup.py \
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200275 --quiet build_ext; \
276 mkdir -p $(OUTPUT)python && \
277 cp $(PYTHON_EXTBUILD_LIB)perf.so $(OUTPUT)python/
278#
279# No Perl scripts right now:
280#
281
282SCRIPTS = $(patsubst %.sh,%,$(SCRIPT_SH))
283
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200284PROGRAMS += $(OUTPUT)perf
285
Adrian Huntere477f3f2014-10-23 18:16:03 -0300286ifndef NO_PERF_READ_VDSO32
287PROGRAMS += $(OUTPUT)perf-read-vdso32
288endif
289
290ifndef NO_PERF_READ_VDSOX32
291PROGRAMS += $(OUTPUT)perf-read-vdsox32
292endif
293
Jiri Olsad4dfdf02016-11-02 14:35:49 +0100294LIBJVMTI = libperf-jvmti.so
295
296ifndef NO_JVMTI
297PROGRAMS += $(OUTPUT)$(LIBJVMTI)
298endif
299
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200300# what 'all' will build and 'install' will install, in perfexecdir
301ALL_PROGRAMS = $(PROGRAMS) $(SCRIPTS)
302
303# what 'all' will build but not install in perfexecdir
304OTHER_PROGRAMS = $(OUTPUT)perf
305
306# Set paths to tools early so that they can be used for version tests.
307ifndef SHELL_PATH
308 SHELL_PATH = /bin/sh
309endif
310ifndef PERL_PATH
311 PERL_PATH = /usr/bin/perl
312endif
313
314export PERL_PATH
315
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200316LIB_FILE=$(OUTPUT)libperf.a
317
Josh Poimboeuf4b6ab942015-12-15 09:39:39 -0600318PERFLIBS = $(LIB_FILE) $(LIBAPI) $(LIBTRACEEVENT) $(LIBSUBCMD)
Wang Naned63f34c2015-10-14 12:41:12 +0000319ifndef NO_LIBBPF
320 PERFLIBS += $(LIBBPF)
321endif
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200322
323# We choose to avoid "if .. else if .. else .. endif endif"
324# because maintaining the nesting to match is a pain. If
325# we had "elif" things would have been much nicer...
326
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200327ifneq ($(OUTPUT),)
328 CFLAGS += -I$(OUTPUT)
329endif
330
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200331ifndef NO_GTK2
Namhyung Kimfc672972013-09-13 15:27:43 +0900332 ALL_PROGRAMS += $(OUTPUT)libperf-gtk.so
Jiri Olsa88aeea02014-12-30 00:34:23 +0100333 GTK_IN := $(OUTPUT)gtk-in.o
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200334endif
335
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200336ifdef ASCIIDOC8
337 export ASCIIDOC8
338endif
339
340LIBS = -Wl,--whole-archive $(PERFLIBS) -Wl,--no-whole-archive -Wl,--start-group $(EXTLIBS) -Wl,--end-group
341
Wang Nand58ac0b2016-11-26 07:03:33 +0000342ifeq ($(USE_CLANG), 1)
343 CLANGLIBS_LIST = AST Basic CodeGen Driver Frontend Lex Tooling Edit Sema Analysis Parse Serialization
344 LIBCLANG = $(foreach l,$(CLANGLIBS_LIST),$(wildcard $(shell $(LLVM_CONFIG) --libdir)/libclang$(l).a))
345 LIBS += -Wl,--start-group $(LIBCLANG) -Wl,--end-group
346endif
347
348ifeq ($(USE_LLVM), 1)
349 LIBLLVM = $(shell $(LLVM_CONFIG) --libs all) $(shell $(LLVM_CONFIG) --system-libs)
350 LIBS += -L$(shell $(LLVM_CONFIG) --libdir) $(LIBLLVM)
351endif
352
353ifeq ($(USE_CXX), 1)
354 LIBS += -lstdc++
355endif
356
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200357export INSTALL SHELL_PATH
358
359### Build rules
360
361SHELL = $(SHELL_PATH)
362
363all: shell_compatibility_test $(ALL_PROGRAMS) $(LANG_BINDINGS) $(OTHER_PROGRAMS)
364
365please_set_SHELL_PATH_to_a_more_modern_shell:
Jiri Olsaceed2522015-01-11 23:59:55 +0100366 $(Q)$$(:)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200367
368shell_compatibility_test: please_set_SHELL_PATH_to_a_more_modern_shell
369
370strip: $(PROGRAMS) $(OUTPUT)perf
371 $(STRIP) $(STRIP_OPTS) $(PROGRAMS) $(OUTPUT)perf
372
Jiri Olsa72965b82014-12-29 13:52:36 +0100373PERF_IN := $(OUTPUT)perf-in.o
374
Wang Nand58ac0b2016-11-26 07:03:33 +0000375export srctree OUTPUT RM CC CXX LD AR CFLAGS CXXFLAGS V BISON FLEX AWK
Andi Kleen80eeb672016-09-19 17:39:33 -0300376export HOSTCC HOSTLD HOSTAR
Jiri Olsaab6201d2015-09-23 12:33:56 +0200377include $(srctree)/tools/build/Makefile.include
Jiri Olsa72965b82014-12-29 13:52:36 +0100378
Andi Kleen80eeb672016-09-19 17:39:33 -0300379JEVENTS := $(OUTPUT)pmu-events/jevents
380JEVENTS_IN := $(OUTPUT)pmu-events/jevents-in.o
381
382PMU_EVENTS_IN := $(OUTPUT)pmu-events/pmu-events-in.o
383
384export JEVENTS
385
386build := -f $(srctree)/tools/build/Makefile.build dir=. obj
387
Jiri Olsa324c8242015-09-23 12:34:01 +0200388$(PERF_IN): prepare FORCE
Arnaldo Carvalho de Meloc4b60142016-07-11 10:28:48 -0300389 @(test -f ../../include/uapi/linux/perf_event.h && ( \
390 (diff -B ../include/uapi/linux/perf_event.h ../../include/uapi/linux/perf_event.h >/dev/null) \
391 || echo "Warning: tools/include/uapi/linux/perf_event.h differs from kernel" >&2 )) || true
Arnaldo Carvalho de Meloae3c14a2016-07-18 18:39:36 -0300392 @(test -f ../../include/linux/hash.h && ( \
393 (diff -B ../include/linux/hash.h ../../include/linux/hash.h >/dev/null) \
394 || echo "Warning: tools/include/linux/hash.h differs from kernel" >&2 )) || true
Arnaldo Carvalho de Melo4998a122016-07-11 23:37:18 -0300395 @(test -f ../../include/uapi/linux/hw_breakpoint.h && ( \
396 (diff -B ../include/uapi/linux/hw_breakpoint.h ../../include/uapi/linux/hw_breakpoint.h >/dev/null) \
397 || echo "Warning: tools/include/uapi/linux/hw_breakpoint.h differs from kernel" >&2 )) || true
Arnaldo Carvalho de Melo7d7d1bf2016-07-11 12:36:41 -0300398 @(test -f ../../arch/x86/include/asm/disabled-features.h && ( \
399 (diff -B ../arch/x86/include/asm/disabled-features.h ../../arch/x86/include/asm/disabled-features.h >/dev/null) \
400 || echo "Warning: tools/arch/x86/include/asm/disabled-features.h differs from kernel" >&2 )) || true
401 @(test -f ../../arch/x86/include/asm/required-features.h && ( \
402 (diff -B ../arch/x86/include/asm/required-features.h ../../arch/x86/include/asm/required-features.h >/dev/null) \
403 || echo "Warning: tools/arch/x86/include/asm/required-features.h differs from kernel" >&2 )) || true
404 @(test -f ../../arch/x86/include/asm/cpufeatures.h && ( \
405 (diff -B ../arch/x86/include/asm/cpufeatures.h ../../arch/x86/include/asm/cpufeatures.h >/dev/null) \
406 || echo "Warning: tools/arch/x86/include/asm/cpufeatures.h differs from kernel" >&2 )) || true
407 @(test -f ../../arch/x86/lib/memcpy_64.S && ( \
Arnaldo Carvalho de Meloe0c47582016-10-25 16:39:21 -0300408 (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 -0300409 || echo "Warning: tools/arch/x86/lib/memcpy_64.S differs from kernel" >&2 )) || true
410 @(test -f ../../arch/x86/lib/memset_64.S && ( \
Arnaldo Carvalho de Meloe0c47582016-10-25 16:39:21 -0300411 (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 -0300412 || echo "Warning: tools/arch/x86/lib/memset_64.S differs from kernel" >&2 )) || true
Arnaldo Carvalho de Melo12f02032016-07-11 21:16:52 -0300413 @(test -f ../../arch/arm/include/uapi/asm/perf_regs.h && ( \
414 (diff -B ../arch/arm/include/uapi/asm/perf_regs.h ../../arch/arm/include/uapi/asm/perf_regs.h >/dev/null) \
415 || echo "Warning: tools/arch/arm/include/uapi/asm/perf_regs.h differs from kernel" >&2 )) || true
416 @(test -f ../../arch/arm64/include/uapi/asm/perf_regs.h && ( \
417 (diff -B ../arch/arm64/include/uapi/asm/perf_regs.h ../../arch/arm64/include/uapi/asm/perf_regs.h >/dev/null) \
418 || echo "Warning: tools/arch/arm64/include/uapi/asm/perf_regs.h differs from kernel" >&2 )) || true
419 @(test -f ../../arch/powerpc/include/uapi/asm/perf_regs.h && ( \
420 (diff -B ../arch/powerpc/include/uapi/asm/perf_regs.h ../../arch/powerpc/include/uapi/asm/perf_regs.h >/dev/null) \
421 || echo "Warning: tools/arch/powerpc/include/uapi/asm/perf_regs.h differs from kernel" >&2 )) || true
422 @(test -f ../../arch/x86/include/uapi/asm/perf_regs.h && ( \
423 (diff -B ../arch/x86/include/uapi/asm/perf_regs.h ../../arch/x86/include/uapi/asm/perf_regs.h >/dev/null) \
424 || 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 -0300425 @(test -f ../../arch/x86/include/uapi/asm/kvm.h && ( \
426 (diff -B ../arch/x86/include/uapi/asm/kvm.h ../../arch/x86/include/uapi/asm/kvm.h >/dev/null) \
427 || echo "Warning: tools/arch/x86/include/uapi/asm/kvm.h differs from kernel" >&2 )) || true
428 @(test -f ../../arch/x86/include/uapi/asm/kvm_perf.h && ( \
429 (diff -B ../arch/x86/include/uapi/asm/kvm_perf.h ../../arch/x86/include/uapi/asm/kvm_perf.h >/dev/null) \
430 || echo "Warning: tools/arch/x86/include/uapi/asm/kvm_perf.h differs from kernel" >&2 )) || true
431 @(test -f ../../arch/x86/include/uapi/asm/svm.h && ( \
432 (diff -B ../arch/x86/include/uapi/asm/svm.h ../../arch/x86/include/uapi/asm/svm.h >/dev/null) \
433 || echo "Warning: tools/arch/x86/include/uapi/asm/svm.h differs from kernel" >&2 )) || true
434 @(test -f ../../arch/x86/include/uapi/asm/vmx.h && ( \
435 (diff -B ../arch/x86/include/uapi/asm/vmx.h ../../arch/x86/include/uapi/asm/vmx.h >/dev/null) \
436 || echo "Warning: tools/arch/x86/include/uapi/asm/vmx.h differs from kernel" >&2 )) || true
437 @(test -f ../../arch/powerpc/include/uapi/asm/kvm.h && ( \
438 (diff -B ../arch/powerpc/include/uapi/asm/kvm.h ../../arch/powerpc/include/uapi/asm/kvm.h >/dev/null) \
439 || echo "Warning: tools/arch/powerpc/include/uapi/asm/kvm.h differs from kernel" >&2 )) || true
440 @(test -f ../../arch/s390/include/uapi/asm/kvm.h && ( \
441 (diff -B ../arch/s390/include/uapi/asm/kvm.h ../../arch/s390/include/uapi/asm/kvm.h >/dev/null) \
442 || echo "Warning: tools/arch/s390/include/uapi/asm/kvm.h differs from kernel" >&2 )) || true
443 @(test -f ../../arch/s390/include/uapi/asm/kvm_perf.h && ( \
444 (diff -B ../arch/s390/include/uapi/asm/kvm_perf.h ../../arch/s390/include/uapi/asm/kvm_perf.h >/dev/null) \
445 || echo "Warning: tools/arch/s390/include/uapi/asm/kvm_perf.h differs from kernel" >&2 )) || true
446 @(test -f ../../arch/s390/include/uapi/asm/sie.h && ( \
447 (diff -B ../arch/s390/include/uapi/asm/sie.h ../../arch/s390/include/uapi/asm/sie.h >/dev/null) \
448 || echo "Warning: tools/arch/s390/include/uapi/asm/sie.h differs from kernel" >&2 )) || true
449 @(test -f ../../arch/arm/include/uapi/asm/kvm.h && ( \
450 (diff -B ../arch/arm/include/uapi/asm/kvm.h ../../arch/arm/include/uapi/asm/kvm.h >/dev/null) \
451 || echo "Warning: tools/arch/arm/include/uapi/asm/kvm.h differs from kernel" >&2 )) || true
452 @(test -f ../../arch/arm64/include/uapi/asm/kvm.h && ( \
453 (diff -B ../arch/arm64/include/uapi/asm/kvm.h ../../arch/arm64/include/uapi/asm/kvm.h >/dev/null) \
454 || echo "Warning: tools/arch/arm64/include/uapi/asm/kvm.h differs from kernel" >&2 )) || true
Arnaldo Carvalho de Melode1e17b2016-07-18 18:13:22 -0300455 @(test -f ../../include/asm-generic/bitops/arch_hweight.h && ( \
456 (diff -B ../include/asm-generic/bitops/arch_hweight.h ../../include/asm-generic/bitops/arch_hweight.h >/dev/null) \
457 || echo "Warning: tools/include/asm-generic/bitops/arch_hweight.h differs from kernel" >&2 )) || true
458 @(test -f ../../include/asm-generic/bitops/const_hweight.h && ( \
459 (diff -B ../include/asm-generic/bitops/const_hweight.h ../../include/asm-generic/bitops/const_hweight.h >/dev/null) \
460 || echo "Warning: tools/include/asm-generic/bitops/const_hweight.h differs from kernel" >&2 )) || true
461 @(test -f ../../include/asm-generic/bitops/__fls.h && ( \
462 (diff -B ../include/asm-generic/bitops/__fls.h ../../include/asm-generic/bitops/__fls.h >/dev/null) \
463 || echo "Warning: tools/include/asm-generic/bitops/__fls.h differs from kernel" >&2 )) || true
464 @(test -f ../../include/asm-generic/bitops/fls.h && ( \
465 (diff -B ../include/asm-generic/bitops/fls.h ../../include/asm-generic/bitops/fls.h >/dev/null) \
466 || echo "Warning: tools/include/asm-generic/bitops/fls.h differs from kernel" >&2 )) || true
467 @(test -f ../../include/asm-generic/bitops/fls64.h && ( \
468 (diff -B ../include/asm-generic/bitops/fls64.h ../../include/asm-generic/bitops/fls64.h >/dev/null) \
469 || echo "Warning: tools/include/asm-generic/bitops/fls64.h differs from kernel" >&2 )) || true
Mathieu Poirier39ff5262016-08-11 10:20:56 -0600470 @(test -f ../../include/linux/coresight-pmu.h && ( \
471 (diff -B ../include/linux/coresight-pmu.h ../../include/linux/coresight-pmu.h >/dev/null) \
472 || echo "Warning: tools/include/linux/coresight-pmu.h differs from kernel" >&2 )) || true
Wang Nan0a4a7e42016-09-12 12:54:31 +0000473 @(test -f ../../include/uapi/asm-generic/mman-common.h && ( \
474 (diff -B ../include/uapi/asm-generic/mman-common.h ../../include/uapi/asm-generic/mman-common.h >/dev/null) \
475 || echo "Warning: tools/include/uapi/asm-generic/mman-common.h differs from kernel" >&2 )) || true
476 @(test -f ../../include/uapi/asm-generic/mman.h && ( \
477 (diff -B -I "^#include <\(uapi/\)*asm-generic/mman-common.h>$$" ../include/uapi/asm-generic/mman.h ../../include/uapi/asm-generic/mman.h >/dev/null) \
478 || echo "Warning: tools/include/uapi/asm-generic/mman.h differs from kernel" >&2 )) || true
479 @(test -f ../../include/uapi/linux/mman.h && ( \
480 (diff -B -I "^#include <\(uapi/\)*asm/mman.h>$$" ../include/uapi/linux/mman.h ../../include/uapi/linux/mman.h >/dev/null) \
481 || echo "Warning: tools/include/uapi/linux/mman.h differs from kernel" >&2 )) || true
Jiri Olsaceed2522015-01-11 23:59:55 +0100482 $(Q)$(MAKE) $(build)=perf
Jiri Olsa72965b82014-12-29 13:52:36 +0100483
Andi Kleen80eeb672016-09-19 17:39:33 -0300484$(JEVENTS_IN): FORCE
485 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=pmu-events obj=jevents
486
487$(JEVENTS): $(JEVENTS_IN)
488 $(QUIET_LINK)$(HOSTCC) $(JEVENTS_IN) -o $@
489
490$(PMU_EVENTS_IN): $(JEVENTS) FORCE
491 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=pmu-events obj=pmu-events
492
493$(OUTPUT)perf: $(PERFLIBS) $(PERF_IN) $(PMU_EVENTS_IN) $(LIBTRACEEVENT_DYNAMIC_LIST)
Wang Nan5d618322015-06-17 14:46:29 +0000494 $(QUIET_LINK)$(CC) $(CFLAGS) $(LDFLAGS) $(LIBTRACEEVENT_DYNAMIC_LIST_LDFLAGS) \
Andi Kleen80eeb672016-09-19 17:39:33 -0300495 $(PERF_IN) $(PMU_EVENTS_IN) $(LIBS) -o $@
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200496
Jiri Olsa7c422f52015-09-23 12:34:02 +0200497$(GTK_IN): fixdep FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100498 $(Q)$(MAKE) $(build)=gtk
Namhyung Kimfc672972013-09-13 15:27:43 +0900499
Jiri Olsa88aeea02014-12-30 00:34:23 +0100500$(OUTPUT)libperf-gtk.so: $(GTK_IN) $(PERFLIBS)
Jiri Olsae27a08f2014-04-27 11:12:21 +0200501 $(QUIET_LINK)$(CC) -o $@ -shared $(LDFLAGS) $(filter %.o,$^) $(GTK_LIBS)
Namhyung Kimfc672972013-09-13 15:27:43 +0900502
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200503$(OUTPUT)common-cmds.h: util/generate-cmdlist.sh command-list.txt
504
505$(OUTPUT)common-cmds.h: $(wildcard Documentation/perf-*.txt)
506 $(QUIET_GEN). util/generate-cmdlist.sh > $@+ && mv $@+ $@
507
508$(SCRIPTS) : % : %.sh
509 $(QUIET_GEN)$(INSTALL) '$@.sh' '$(OUTPUT)$@'
510
511# These can record PERF_VERSION
Jiri Olsacb4e67f2014-12-30 17:09:15 +0100512perf.spec $(SCRIPTS) \
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200513 : $(OUTPUT)PERF-VERSION-FILE
514
515.SUFFIXES:
Ingo Molnar1f7c6452013-10-04 12:14:59 +0200516
517#
518# If a target does not match any of the later rules then prefix it by $(OUTPUT)
519# This makes targets like 'make O=/tmp/perf perf.o' work in a natural way.
520#
521ifneq ($(OUTPUT),)
522%.o: $(OUTPUT)%.o
523 @echo " # Redirected target $@ => $(OUTPUT)$@"
Andi Kleen80eeb672016-09-19 17:39:33 -0300524pmu-events/%.o: $(OUTPUT)pmu-events/%.o
525 @echo " # Redirected target $@ => $(OUTPUT)$@"
Ingo Molnar1f7c6452013-10-04 12:14:59 +0200526util/%.o: $(OUTPUT)util/%.o
Ingo Molnarcee972c2013-10-10 07:42:56 +0200527 @echo " # Redirected target $@ => $(OUTPUT)$@"
Ingo Molnar1f7c6452013-10-04 12:14:59 +0200528bench/%.o: $(OUTPUT)bench/%.o
Ingo Molnarcee972c2013-10-10 07:42:56 +0200529 @echo " # Redirected target $@ => $(OUTPUT)$@"
Ingo Molnar1f7c6452013-10-04 12:14:59 +0200530tests/%.o: $(OUTPUT)tests/%.o
Ingo Molnarcee972c2013-10-10 07:42:56 +0200531 @echo " # Redirected target $@ => $(OUTPUT)$@"
Ingo Molnar1f7c6452013-10-04 12:14:59 +0200532endif
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200533
534# These two need to be here so that when O= is not used they take precedence
535# over the general rule for .o
536
Jiri Olsa19993072014-12-30 18:44:38 +0100537# get relative building directory (to $(OUTPUT))
538# and '.' if it's $(OUTPUT) itself
539__build-dir = $(subst $(OUTPUT),,$(dir $@))
540build-dir = $(if $(__build-dir),$(__build-dir),.)
541
Arnaldo Carvalho de Melo1b700c92016-04-04 19:05:36 -0300542prepare: $(OUTPUT)PERF-VERSION-FILE $(OUTPUT)common-cmds.h fixdep archheaders
Jiri Olsa19993072014-12-30 18:44:38 +0100543
Jiri Olsa324c8242015-09-23 12:34:01 +0200544$(OUTPUT)%.o: %.c prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100545 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
Jiri Olsa19993072014-12-30 18:44:38 +0100546
Jiri Olsa324c8242015-09-23 12:34:01 +0200547$(OUTPUT)%.i: %.c prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100548 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
Jiri Olsa19993072014-12-30 18:44:38 +0100549
Jiri Olsa324c8242015-09-23 12:34:01 +0200550$(OUTPUT)%.s: %.c prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100551 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
Jiri Olsa19993072014-12-30 18:44:38 +0100552
Jiri Olsa324c8242015-09-23 12:34:01 +0200553$(OUTPUT)%-bison.o: %.c prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100554 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
Jiri Olsa19993072014-12-30 18:44:38 +0100555
Jiri Olsa324c8242015-09-23 12:34:01 +0200556$(OUTPUT)%-flex.o: %.c prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100557 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
Jiri Olsa19993072014-12-30 18:44:38 +0100558
Jiri Olsa324c8242015-09-23 12:34:01 +0200559$(OUTPUT)%.o: %.S prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100560 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
Jiri Olsa19993072014-12-30 18:44:38 +0100561
Jiri Olsa324c8242015-09-23 12:34:01 +0200562$(OUTPUT)%.i: %.S prepare FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100563 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200564
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200565$(OUTPUT)perf-%: %.o $(PERFLIBS)
566 $(QUIET_LINK)$(CC) $(CFLAGS) -o $@ $(LDFLAGS) $(filter %.o,$^) $(LIBS)
567
Adrian Huntere477f3f2014-10-23 18:16:03 -0300568ifndef NO_PERF_READ_VDSO32
569$(OUTPUT)perf-read-vdso32: perf-read-vdso.c util/find-vdso-map.c
570 $(QUIET_CC)$(CC) -m32 $(filter -static,$(LDFLAGS)) -Wall -Werror -o $@ perf-read-vdso.c
571endif
572
573ifndef NO_PERF_READ_VDSOX32
574$(OUTPUT)perf-read-vdsox32: perf-read-vdso.c util/find-vdso-map.c
575 $(QUIET_CC)$(CC) -mx32 $(filter -static,$(LDFLAGS)) -Wall -Werror -o $@ perf-read-vdso.c
576endif
577
Jiri Olsad4dfdf02016-11-02 14:35:49 +0100578ifndef NO_JVMTI
579LIBJVMTI_IN := $(OUTPUT)jvmti/jvmti-in.o
580
581$(LIBJVMTI_IN): FORCE
582 $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=jvmti obj=jvmti
583
584$(OUTPUT)$(LIBJVMTI): $(LIBJVMTI_IN)
585 $(QUIET_LINK)$(CC) -shared -Wl,-soname -Wl,$(LIBJVMTI) -o $@ $< -lelf -lrt
586endif
587
Jiri Olsa8e499ac2014-12-30 16:51:35 +0100588$(patsubst perf-%,%.o,$(PROGRAMS)): $(wildcard */*.h)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200589
Jiri Olsa9352aab2014-12-29 17:42:46 +0100590LIBPERF_IN := $(OUTPUT)libperf-in.o
591
Arnaldo Carvalho de Melo1b700c92016-04-04 19:05:36 -0300592$(LIBPERF_IN): prepare fixdep FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100593 $(Q)$(MAKE) $(build)=libperf
Jiri Olsa9352aab2014-12-29 17:42:46 +0100594
Jiri Olsa8e499ac2014-12-30 16:51:35 +0100595$(LIB_FILE): $(LIBPERF_IN)
Jiri Olsa9352aab2014-12-29 17:42:46 +0100596 $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $(LIBPERF_IN) $(LIB_OBJS)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200597
Jiri Olsa3d7c0142013-12-03 14:09:21 +0100598LIBTRACEEVENT_FLAGS += plugin_dir=$(plugindir_SQ)
599
Jiri Olsa7c422f52015-09-23 12:34:02 +0200600$(LIBTRACEEVENT): fixdep FORCE
He Kuange3d09ec2015-05-28 13:28:54 +0000601 $(Q)$(MAKE) -C $(TRACE_EVENT_DIR) $(LIBTRACEEVENT_FLAGS) O=$(OUTPUT) $(OUTPUT)libtraceevent.a
602
Jiri Olsa7c422f52015-09-23 12:34:02 +0200603libtraceevent_plugins: fixdep FORCE
He Kuange3d09ec2015-05-28 13:28:54 +0000604 $(Q)$(MAKE) -C $(TRACE_EVENT_DIR) $(LIBTRACEEVENT_FLAGS) O=$(OUTPUT) plugins
605
606$(LIBTRACEEVENT_DYNAMIC_LIST): libtraceevent_plugins
607 $(Q)$(MAKE) -C $(TRACE_EVENT_DIR) $(LIBTRACEEVENT_FLAGS) O=$(OUTPUT) $(OUTPUT)libtraceevent-dynamic-list
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200608
609$(LIBTRACEEVENT)-clean:
Ingo Molnar8ec19c02013-10-09 11:49:26 +0200610 $(call QUIET_CLEAN, libtraceevent)
Jiri Olsaceed2522015-01-11 23:59:55 +0100611 $(Q)$(MAKE) -C $(TRACE_EVENT_DIR) O=$(OUTPUT) clean >/dev/null
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200612
Jiri Olsa67befc62015-11-26 14:54:04 +0100613install-traceevent-plugins: libtraceevent_plugins
Jiri Olsaceed2522015-01-11 23:59:55 +0100614 $(Q)$(MAKE) -C $(TRACE_EVENT_DIR) $(LIBTRACEEVENT_FLAGS) O=$(OUTPUT) install_plugins
Jiri Olsa3d7c0142013-12-03 14:09:21 +0100615
Jiri Olsa7c422f52015-09-23 12:34:02 +0200616$(LIBAPI): fixdep FORCE
Jiri Olsaceed2522015-01-11 23:59:55 +0100617 $(Q)$(MAKE) -C $(LIB_DIR) O=$(OUTPUT) $(OUTPUT)libapi.a
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200618
Jiri Olsa285a8f22015-01-10 20:53:13 +0100619$(LIBAPI)-clean:
620 $(call QUIET_CLEAN, libapi)
Jiri Olsaceed2522015-01-11 23:59:55 +0100621 $(Q)$(MAKE) -C $(LIB_DIR) O=$(OUTPUT) clean >/dev/null
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200622
Jiri Olsa50f1e6d2015-10-28 21:44:50 +0100623$(LIBBPF): fixdep FORCE
Jiri Olsa96b9e702016-01-15 04:00:18 +0000624 $(Q)$(MAKE) -C $(BPF_DIR) O=$(OUTPUT) $(OUTPUT)libbpf.a FEATURES_DUMP=$(FEATURE_DUMP_EXPORT)
Wang Naned63f34c2015-10-14 12:41:12 +0000625
626$(LIBBPF)-clean:
627 $(call QUIET_CLEAN, libbpf)
628 $(Q)$(MAKE) -C $(BPF_DIR) O=$(OUTPUT) clean >/dev/null
629
Josh Poimboeuf4b6ab942015-12-15 09:39:39 -0600630$(LIBSUBCMD): fixdep FORCE
631 $(Q)$(MAKE) -C $(SUBCMD_DIR) O=$(OUTPUT) $(OUTPUT)libsubcmd.a
632
633$(LIBSUBCMD)-clean:
634 $(call QUIET_CLEAN, libsubcmd)
635 $(Q)$(MAKE) -C $(SUBCMD_DIR) O=$(OUTPUT) clean
636
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200637help:
638 @echo 'Perf make targets:'
639 @echo ' doc - make *all* documentation (see below)'
640 @echo ' man - make manpage documentation (access with man <foo>)'
641 @echo ' html - make html documentation'
642 @echo ' info - make GNU info documentation (access with info <foo>)'
643 @echo ' pdf - make pdf documentation'
644 @echo ' TAGS - use etags to make tag information for source browsing'
645 @echo ' tags - use ctags to make tag information for source browsing'
646 @echo ' cscope - use cscope to make interactive browsing database'
647 @echo ''
648 @echo 'Perf install targets:'
649 @echo ' NOTE: documentation build requires asciidoc, xmlto packages to be installed'
Jianyu Zhanfc9cabe2014-06-03 00:44:34 +0800650 @echo ' HINT: use "prefix" or "DESTDIR" to install to a particular'
651 @echo ' path like "make prefix=/usr/local install install-doc"'
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200652 @echo ' install - install compiled binaries'
653 @echo ' install-doc - install *all* documentation'
654 @echo ' install-man - install manpage documentation'
655 @echo ' install-html - install html documentation'
656 @echo ' install-info - install GNU info documentation'
657 @echo ' install-pdf - install pdf documentation'
658 @echo ''
659 @echo ' quick-install-doc - alias for quick-install-man'
660 @echo ' quick-install-man - install the documentation quickly'
661 @echo ' quick-install-html - install the html documentation quickly'
662 @echo ''
663 @echo 'Perf maintainer targets:'
664 @echo ' clean - clean all binary objects and build output'
665
666
667DOC_TARGETS := doc man html info pdf
668
669INSTALL_DOC_TARGETS := $(patsubst %,install-%,$(DOC_TARGETS)) try-install-man
670INSTALL_DOC_TARGETS += quick-install-doc quick-install-man quick-install-html
671
672# 'make doc' should call 'make -C Documentation all'
673$(DOC_TARGETS):
674 $(QUIET_SUBDIR0)Documentation $(QUIET_SUBDIR1) $(@:doc=all)
675
Jiri Olsa685c8412016-01-07 10:14:06 +0100676TAG_FOLDERS= . ../lib ../include
Sebastian Andrzej Siewior16a64332014-05-28 10:19:18 +0200677TAG_FILES= ../../include/uapi/linux/perf_event.h
678
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200679TAGS:
Jiri Olsab0815d02014-06-04 14:43:58 +0200680 $(QUIET_GEN)$(RM) TAGS; \
Sebastian Andrzej Siewior16a64332014-05-28 10:19:18 +0200681 $(FIND) $(TAG_FOLDERS) -name '*.[hcS]' -print | xargs etags -a $(TAG_FILES)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200682
683tags:
Jiri Olsab0815d02014-06-04 14:43:58 +0200684 $(QUIET_GEN)$(RM) tags; \
Sebastian Andrzej Siewior16a64332014-05-28 10:19:18 +0200685 $(FIND) $(TAG_FOLDERS) -name '*.[hcS]' -print | xargs ctags -a $(TAG_FILES)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200686
687cscope:
Jiri Olsab0815d02014-06-04 14:43:58 +0200688 $(QUIET_GEN)$(RM) cscope*; \
Sebastian Andrzej Siewior16a64332014-05-28 10:19:18 +0200689 $(FIND) $(TAG_FOLDERS) -name '*.[hcS]' -print | xargs cscope -b $(TAG_FILES)
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200690
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200691### Testing rules
692
693# GNU make supports exporting all variables by "export" without parameters.
694# However, the environment gets quite big, and some programs have problems
695# with that.
696
697check: $(OUTPUT)common-cmds.h
698 if sparse; \
699 then \
700 for i in *.c */*.c; \
701 do \
702 sparse $(CFLAGS) $(SPARSE_FLAGS) $$i || exit; \
703 done; \
704 else \
705 exit 1; \
706 fi
707
708### Installation rules
709
Jiri Olsa5c319a62016-12-04 21:42:54 +0100710ifndef NO_GTK2
711install-gtk: $(OUTPUT)libperf-gtk.so
712 $(call QUIET_INSTALL, 'GTK UI') \
713 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(libdir_SQ)'; \
714 $(INSTALL) $(OUTPUT)libperf-gtk.so '$(DESTDIR_SQ)$(libdir_SQ)'
715else
Namhyung Kimfc672972013-09-13 15:27:43 +0900716install-gtk:
Jiri Olsa5c319a62016-12-04 21:42:54 +0100717endif
Namhyung Kimfc672972013-09-13 15:27:43 +0900718
Nam T. Nguyen128c32e2015-05-18 11:37:27 -0700719install-tools: all install-gtk
Ingo Molnar8a5411e92013-10-09 11:49:29 +0200720 $(call QUIET_INSTALL, binaries) \
721 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(bindir_SQ)'; \
722 $(INSTALL) $(OUTPUT)perf '$(DESTDIR_SQ)$(bindir_SQ)'; \
723 $(LN) '$(DESTDIR_SQ)$(bindir_SQ)/perf' '$(DESTDIR_SQ)$(bindir_SQ)/trace'
Adrian Huntere477f3f2014-10-23 18:16:03 -0300724ifndef NO_PERF_READ_VDSO32
725 $(call QUIET_INSTALL, perf-read-vdso32) \
726 $(INSTALL) $(OUTPUT)perf-read-vdso32 '$(DESTDIR_SQ)$(bindir_SQ)';
727endif
728ifndef NO_PERF_READ_VDSOX32
729 $(call QUIET_INSTALL, perf-read-vdsox32) \
730 $(INSTALL) $(OUTPUT)perf-read-vdsox32 '$(DESTDIR_SQ)$(bindir_SQ)';
731endif
Jiri Olsad4dfdf02016-11-02 14:35:49 +0100732ifndef NO_JVMTI
733 $(call QUIET_INSTALL, $(LIBJVMTI)) \
734 $(INSTALL) $(OUTPUT)$(LIBJVMTI) '$(DESTDIR_SQ)$(libdir_SQ)';
735endif
Ingo Molnar8a5411e92013-10-09 11:49:29 +0200736 $(call QUIET_INSTALL, libexec) \
737 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)'
738 $(call QUIET_INSTALL, perf-archive) \
739 $(INSTALL) $(OUTPUT)perf-archive -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)'
Adrian Hunterc501e902014-07-31 09:01:12 +0300740 $(call QUIET_INSTALL, perf-with-kcore) \
741 $(INSTALL) $(OUTPUT)perf-with-kcore -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)'
Arnaldo Carvalho de Melo005438a82015-07-20 12:02:09 -0300742ifndef NO_LIBAUDIT
743 $(call QUIET_INSTALL, strace/groups) \
744 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(STRACE_GROUPS_INSTDIR_SQ)'; \
745 $(INSTALL) trace/strace/groups/* -t '$(DESTDIR_SQ)$(STRACE_GROUPS_INSTDIR_SQ)'
746endif
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200747ifndef NO_LIBPERL
Ingo Molnar8a5411e92013-10-09 11:49:29 +0200748 $(call QUIET_INSTALL, perl-scripts) \
749 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/perl/Perf-Trace-Util/lib/Perf/Trace'; \
750 $(INSTALL) scripts/perl/Perf-Trace-Util/lib/Perf/Trace/* -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/perl/Perf-Trace-Util/lib/Perf/Trace'; \
751 $(INSTALL) scripts/perl/*.pl -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/perl'; \
752 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/perl/bin'; \
753 $(INSTALL) scripts/perl/bin/* -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/perl/bin'
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200754endif
755ifndef NO_LIBPYTHON
Ingo Molnar8a5411e92013-10-09 11:49:29 +0200756 $(call QUIET_INSTALL, python-scripts) \
757 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/python/Perf-Trace-Util/lib/Perf/Trace'; \
758 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/python/bin'; \
759 $(INSTALL) scripts/python/Perf-Trace-Util/lib/Perf/Trace/* -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/python/Perf-Trace-Util/lib/Perf/Trace'; \
760 $(INSTALL) scripts/python/*.py -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/python'; \
761 $(INSTALL) scripts/python/bin/* -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/python/bin'
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200762endif
Ramkumar Ramachandraa8b4c7012013-11-17 21:43:27 +0530763 $(call QUIET_INSTALL, perf_completion-script) \
Ingo Molnar8a5411e92013-10-09 11:49:29 +0200764 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(sysconfdir_SQ)/bash_completion.d'; \
Ramkumar Ramachandraa8b4c7012013-11-17 21:43:27 +0530765 $(INSTALL) perf-completion.sh '$(DESTDIR_SQ)$(sysconfdir_SQ)/bash_completion.d/perf'
Namhyung Kim14cbfbe2016-01-07 20:41:53 +0900766 $(call QUIET_INSTALL, perf-tip) \
767 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(tip_instdir_SQ)'; \
768 $(INSTALL) Documentation/tips.txt -t '$(DESTDIR_SQ)$(tip_instdir_SQ)'
Nam T. Nguyen128c32e2015-05-18 11:37:27 -0700769
770install-tests: all install-gtk
Ingo Molnar8a5411e92013-10-09 11:49:29 +0200771 $(call QUIET_INSTALL, tests) \
772 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/tests'; \
773 $(INSTALL) tests/attr.py '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/tests'; \
774 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/tests/attr'; \
775 $(INSTALL) tests/attr/* '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/tests/attr'
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200776
Nam T. Nguyen128c32e2015-05-18 11:37:27 -0700777install-bin: install-tools install-tests
778
Jiri Olsa3d7c0142013-12-03 14:09:21 +0100779install: install-bin try-install-man install-traceevent-plugins
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200780
781install-python_ext:
782 $(PYTHON_WORD) util/setup.py --quiet install --root='/$(DESTDIR_SQ)'
783
784# 'make install-doc' should call 'make -C Documentation install'
785$(INSTALL_DOC_TARGETS):
786 $(QUIET_SUBDIR0)Documentation $(QUIET_SUBDIR1) $(@:-doc=)
787
788### Cleaning rules
789
790#
Jiri Olsa48425762016-08-01 20:02:33 +0200791# This is here, not in Makefile.config, because Makefile.config does
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200792# not get included for the clean target:
793#
794config-clean:
Ingo Molnar8ec19c02013-10-09 11:49:26 +0200795 $(call QUIET_CLEAN, config)
Josh Poimboeuf8f46dfd2015-12-13 22:18:05 -0600796 $(Q)$(MAKE) -C $(srctree)/tools/build/feature/ $(if $(OUTPUT),OUTPUT=$(OUTPUT)feature/,) clean >/dev/null
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200797
Arnaldo Carvalho de Melo1b700c92016-04-04 19:05:36 -0300798clean:: $(LIBTRACEEVENT)-clean $(LIBAPI)-clean $(LIBBPF)-clean $(LIBSUBCMD)-clean config-clean
Jiri Olsa8e499ac2014-12-30 16:51:35 +0100799 $(call QUIET_CLEAN, core-objs) $(RM) $(LIB_FILE) $(OUTPUT)perf-archive $(OUTPUT)perf-with-kcore $(LANG_BINDINGS)
Josh Poimboeuf8f46dfd2015-12-13 22:18:05 -0600800 $(Q)find $(if $(OUTPUT),$(OUTPUT),.) -name '*.o' -delete -o -name '\.*.cmd' -delete -o -name '\.*.d' -delete
Aaro Koskinen642273792015-07-01 14:54:42 +0300801 $(Q)$(RM) $(OUTPUT).config-detected
Jiri Olsad4dfdf02016-11-02 14:35:49 +0100802 $(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 +0300803 $(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 -0600804 $(OUTPUT)util/intel-pt-decoder/inat-tables.c $(OUTPUT)fixdep \
Andi Kleen80eeb672016-09-19 17:39:33 -0300805 $(OUTPUT)tests/llvm-src-{base,kbuild,prologue,relocation}.c \
806 $(OUTPUT)pmu-events/pmu-events.c
Borislav Petkov553873e2013-12-09 17:14:23 +0100807 $(QUIET_SUBDIR0)Documentation $(QUIET_SUBDIR1) clean
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200808 $(python-clean)
809
810#
Jiri Olsab8e52be2016-01-15 04:00:17 +0000811# To provide FEATURE-DUMP into $(FEATURE_DUMP_COPY)
812# file if defined, with no further action.
813feature-dump:
814ifdef FEATURE_DUMP_COPY
815 @cp $(OUTPUT)FEATURE-DUMP $(FEATURE_DUMP_COPY)
816 @echo "FEATURE-DUMP file copied into $(FEATURE_DUMP_COPY)"
817else
818 @echo "FEATURE-DUMP file available in $(OUTPUT)FEATURE-DUMP"
819endif
820
821#
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200822# Trick: if ../../.git does not exist - we are building out of tree for example,
823# then force version regeneration:
824#
825ifeq ($(wildcard ../../.git/HEAD),)
826 GIT-HEAD-PHONY = ../../.git/HEAD
827else
828 GIT-HEAD-PHONY =
829endif
830
Jiri Olsa72965b82014-12-29 13:52:36 +0100831FORCE:
832
Namhyung Kimfc672972013-09-13 15:27:43 +0900833.PHONY: all install clean config-clean strip install-gtk
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200834.PHONY: shell_compatibility_test please_set_SHELL_PATH_to_a_more_modern_shell
Jiri Olsa324c8242015-09-23 12:34:01 +0200835.PHONY: $(GIT-HEAD-PHONY) TAGS tags cscope FORCE prepare
Arnaldo Carvalho de Melo1b700c92016-04-04 19:05:36 -0300836.PHONY: libtraceevent_plugins archheaders
Ingo Molnarbd69cc22013-10-02 11:49:08 +0200837