interconnect: qcom: icc-rpm: Fix peak rate calculation
[linux-2.6-microblaze.git] / tools / perf / util / Build
1 include $(srctree)/tools/scripts/Makefile.include
2 include $(srctree)/tools/scripts/utilities.mak
3
4 perf-y += arm64-frame-pointer-unwind-support.o
5 perf-y += addr_location.o
6 perf-y += annotate.o
7 perf-y += block-info.o
8 perf-y += block-range.o
9 perf-y += build-id.o
10 perf-y += cacheline.o
11 perf-y += config.o
12 perf-y += copyfile.o
13 perf-y += ctype.o
14 perf-y += db-export.o
15 perf-y += env.o
16 perf-y += event.o
17 perf-y += evlist.o
18 perf-y += sideband_evlist.o
19 perf-y += evsel.o
20 perf-y += evsel_fprintf.o
21 perf-y += perf_event_attr_fprintf.o
22 perf-y += evswitch.o
23 perf-y += find_bit.o
24 perf-y += get_current_dir_name.o
25 perf-y += levenshtein.o
26 perf-y += mmap.o
27 perf-y += memswap.o
28 perf-y += parse-events.o
29 perf-y += print-events.o
30 perf-y += tracepoint.o
31 perf-y += perf_regs.o
32 perf-y += perf-regs-arch/
33 perf-y += path.o
34 perf-y += print_binary.o
35 perf-y += rlimit.o
36 perf-y += argv_split.o
37 perf-y += rbtree.o
38 perf-y += libstring.o
39 perf-y += bitmap.o
40 perf-y += hweight.o
41 perf-y += smt.o
42 perf-y += strbuf.o
43 perf-y += string.o
44 perf-y += strlist.o
45 perf-y += strfilter.o
46 perf-y += top.o
47 perf-y += usage.o
48 perf-y += dso.o
49 perf-y += dsos.o
50 perf-y += symbol.o
51 perf-y += symbol_fprintf.o
52 perf-y += map_symbol.o
53 perf-y += color.o
54 perf-y += color_config.o
55 perf-y += metricgroup.o
56 perf-y += header.o
57 perf-y += callchain.o
58 perf-y += values.o
59 perf-y += debug.o
60 perf-y += fncache.o
61 perf-y += machine.o
62 perf-y += map.o
63 perf-y += maps.o
64 perf-y += pstack.o
65 perf-y += session.o
66 perf-y += sample-raw.o
67 perf-y += s390-sample-raw.o
68 perf-y += amd-sample-raw.o
69 perf-$(CONFIG_TRACE) += syscalltbl.o
70 perf-y += ordered-events.o
71 perf-y += namespaces.o
72 perf-y += comm.o
73 perf-y += thread.o
74 perf-y += thread_map.o
75 perf-y += parse-events-flex.o
76 perf-y += parse-events-bison.o
77 perf-y += pmu.o
78 perf-y += pmus.o
79 perf-y += pmu-flex.o
80 perf-y += pmu-bison.o
81 perf-y += svghelper.o
82 perf-$(CONFIG_LIBTRACEEVENT) += trace-event-info.o
83 perf-y += trace-event-scripting.o
84 perf-$(CONFIG_LIBTRACEEVENT) += trace-event.o
85 perf-$(CONFIG_LIBTRACEEVENT) += trace-event-parse.o
86 perf-$(CONFIG_LIBTRACEEVENT) += trace-event-read.o
87 perf-y += sort.o
88 perf-y += hist.o
89 perf-y += util.o
90 perf-y += cpumap.o
91 perf-y += affinity.o
92 perf-y += cputopo.o
93 perf-y += cgroup.o
94 perf-y += target.o
95 perf-y += rblist.o
96 perf-y += intlist.o
97 perf-y += vdso.o
98 perf-y += counts.o
99 perf-y += stat.o
100 perf-y += stat-shadow.o
101 perf-y += stat-display.o
102 perf-y += perf_api_probe.o
103 perf-y += record.o
104 perf-y += srcline.o
105 perf-y += srccode.o
106 perf-y += synthetic-events.o
107 perf-y += data.o
108 perf-y += tsc.o
109 perf-y += cloexec.o
110 perf-y += call-path.o
111 perf-y += rwsem.o
112 perf-y += thread-stack.o
113 perf-y += spark.o
114 perf-y += topdown.o
115 perf-y += iostat.o
116 perf-y += stream.o
117 perf-$(CONFIG_AUXTRACE) += auxtrace.o
118 perf-$(CONFIG_AUXTRACE) += intel-pt-decoder/
119 perf-$(CONFIG_AUXTRACE) += intel-pt.o
120 perf-$(CONFIG_AUXTRACE) += intel-bts.o
121 perf-$(CONFIG_AUXTRACE) += arm-spe.o
122 perf-$(CONFIG_AUXTRACE) += arm-spe-decoder/
123 perf-$(CONFIG_AUXTRACE) += hisi-ptt.o
124 perf-$(CONFIG_AUXTRACE) += hisi-ptt-decoder/
125 perf-$(CONFIG_AUXTRACE) += s390-cpumsf.o
126
127 ifdef CONFIG_LIBOPENCSD
128 perf-$(CONFIG_AUXTRACE) += cs-etm.o
129 perf-$(CONFIG_AUXTRACE) += cs-etm-decoder/
130 endif
131 perf-$(CONFIG_AUXTRACE) += cs-etm-base.o
132
133 perf-y += parse-branch-options.o
134 perf-y += dump-insn.o
135 perf-y += parse-regs-options.o
136 perf-y += parse-sublevel-options.o
137 perf-y += term.o
138 perf-y += help-unknown-cmd.o
139 perf-y += dlfilter.o
140 perf-y += mem-events.o
141 perf-y += vsprintf.o
142 perf-y += units.o
143 perf-y += time-utils.o
144 perf-y += expr-flex.o
145 perf-y += expr-bison.o
146 perf-y += expr.o
147 perf-y += branch.o
148 perf-y += mem2node.o
149 perf-y += clockid.o
150 perf-y += list_sort.o
151 perf-y += mutex.o
152 perf-y += sharded_mutex.o
153
154 perf-$(CONFIG_LIBBPF) += bpf_map.o
155 perf-$(CONFIG_PERF_BPF_SKEL) += bpf_counter.o
156 perf-$(CONFIG_PERF_BPF_SKEL) += bpf_counter_cgroup.o
157 perf-$(CONFIG_PERF_BPF_SKEL) += bpf_ftrace.o
158 perf-$(CONFIG_PERF_BPF_SKEL) += bpf_off_cpu.o
159 perf-$(CONFIG_PERF_BPF_SKEL) += bpf-filter.o
160 perf-$(CONFIG_PERF_BPF_SKEL) += bpf-filter-flex.o
161 perf-$(CONFIG_PERF_BPF_SKEL) += bpf-filter-bison.o
162
163 ifeq ($(CONFIG_LIBTRACEEVENT),y)
164   perf-$(CONFIG_PERF_BPF_SKEL) += bpf_lock_contention.o
165 endif
166
167 ifeq ($(CONFIG_LIBTRACEEVENT),y)
168   perf-$(CONFIG_PERF_BPF_SKEL) += bpf_kwork.o
169   perf-$(CONFIG_PERF_BPF_SKEL) += bpf_kwork_top.o
170 endif
171
172 perf-$(CONFIG_LIBELF) += symbol-elf.o
173 perf-$(CONFIG_LIBELF) += probe-file.o
174 perf-$(CONFIG_LIBELF) += probe-event.o
175
176 ifdef CONFIG_LIBBPF_DYNAMIC
177   hashmap := 1
178 endif
179 ifndef CONFIG_LIBBPF
180   hashmap := 1
181 endif
182
183 ifdef hashmap
184 perf-y += hashmap.o
185 endif
186
187 ifndef CONFIG_LIBELF
188 perf-y += symbol-minimal.o
189 endif
190
191 ifndef CONFIG_SETNS
192 perf-y += setns.o
193 endif
194
195 perf-$(CONFIG_DWARF) += probe-finder.o
196 perf-$(CONFIG_DWARF) += dwarf-aux.o
197 perf-$(CONFIG_DWARF) += dwarf-regs.o
198
199 perf-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o
200 perf-$(CONFIG_LOCAL_LIBUNWIND)    += unwind-libunwind-local.o
201 perf-$(CONFIG_LIBUNWIND)          += unwind-libunwind.o
202 perf-$(CONFIG_LIBUNWIND_X86)      += libunwind/x86_32.o
203 perf-$(CONFIG_LIBUNWIND_AARCH64)  += libunwind/arm64.o
204
205 ifeq ($(CONFIG_LIBTRACEEVENT),y)
206   perf-$(CONFIG_LIBBABELTRACE) += data-convert-bt.o
207 endif
208
209 perf-y += data-convert-json.o
210
211 perf-y += scripting-engines/
212
213 perf-$(CONFIG_ZLIB) += zlib.o
214 perf-$(CONFIG_LZMA) += lzma.o
215 perf-$(CONFIG_ZSTD) += zstd.o
216
217 perf-$(CONFIG_LIBCAP) += cap.o
218
219 perf-$(CONFIG_CXX_DEMANGLE) += demangle-cxx.o
220 perf-y += demangle-ocaml.o
221 perf-y += demangle-java.o
222 perf-y += demangle-rust.o
223
224 ifdef CONFIG_JITDUMP
225 perf-$(CONFIG_LIBELF) += jitdump.o
226 perf-$(CONFIG_LIBELF) += genelf.o
227 perf-$(CONFIG_DWARF) += genelf_debug.o
228 endif
229
230 perf-y += perf-hooks.o
231
232 perf-$(CONFIG_LIBBPF) += bpf-event.o
233 perf-$(CONFIG_LIBBPF) += bpf-utils.o
234
235 perf-$(CONFIG_LIBPFM4) += pfm.o
236
237 CFLAGS_config.o   += -DETC_PERFCONFIG="BUILD_STR($(ETC_PERFCONFIG_SQ))"
238
239 # avoid compiler warnings in 32-bit mode
240 CFLAGS_genelf_debug.o  += -Wno-packed
241
242 $(OUTPUT)util/parse-events-flex.c $(OUTPUT)util/parse-events-flex.h: util/parse-events.l $(OUTPUT)util/parse-events-bison.c
243         $(call rule_mkdir)
244         $(Q)$(call echo-cmd,flex)$(FLEX) -o $(OUTPUT)util/parse-events-flex.c \
245                 --header-file=$(OUTPUT)util/parse-events-flex.h $(PARSER_DEBUG_FLEX) $<
246
247 $(OUTPUT)util/parse-events-bison.c $(OUTPUT)util/parse-events-bison.h: util/parse-events.y
248         $(call rule_mkdir)
249         $(Q)$(call echo-cmd,bison)$(BISON) -v $< -d $(PARSER_DEBUG_BISON) $(BISON_FILE_PREFIX_MAP) $(BISON_FALLBACK_FLAGS) \
250                 -o $(OUTPUT)util/parse-events-bison.c -p parse_events_
251
252 $(OUTPUT)util/expr-flex.c $(OUTPUT)util/expr-flex.h: util/expr.l $(OUTPUT)util/expr-bison.c
253         $(call rule_mkdir)
254         $(Q)$(call echo-cmd,flex)$(FLEX) -o $(OUTPUT)util/expr-flex.c \
255                 --header-file=$(OUTPUT)util/expr-flex.h $(PARSER_DEBUG_FLEX) $<
256
257 $(OUTPUT)util/expr-bison.c $(OUTPUT)util/expr-bison.h: util/expr.y
258         $(call rule_mkdir)
259         $(Q)$(call echo-cmd,bison)$(BISON) -v $< -d $(PARSER_DEBUG_BISON) $(BISON_FILE_PREFIX_MAP) \
260                 -o $(OUTPUT)util/expr-bison.c -p expr_
261
262 $(OUTPUT)util/pmu-flex.c $(OUTPUT)util/pmu-flex.h: util/pmu.l $(OUTPUT)util/pmu-bison.c
263         $(call rule_mkdir)
264         $(Q)$(call echo-cmd,flex)$(FLEX) -o $(OUTPUT)util/pmu-flex.c \
265                 --header-file=$(OUTPUT)util/pmu-flex.h $(PARSER_DEBUG_FLEX) $<
266
267 $(OUTPUT)util/pmu-bison.c $(OUTPUT)util/pmu-bison.h: util/pmu.y
268         $(call rule_mkdir)
269         $(Q)$(call echo-cmd,bison)$(BISON) -v $< -d $(PARSER_DEBUG_BISON) $(BISON_FILE_PREFIX_MAP) \
270                 -o $(OUTPUT)util/pmu-bison.c -p perf_pmu_
271
272 $(OUTPUT)util/bpf-filter-flex.c $(OUTPUT)util/bpf-filter-flex.h: util/bpf-filter.l $(OUTPUT)util/bpf-filter-bison.c
273         $(call rule_mkdir)
274         $(Q)$(call echo-cmd,flex)$(FLEX) -o $(OUTPUT)util/bpf-filter-flex.c \
275                 --header-file=$(OUTPUT)util/bpf-filter-flex.h $(PARSER_DEBUG_FLEX) $<
276
277 $(OUTPUT)util/bpf-filter-bison.c $(OUTPUT)util/bpf-filter-bison.h: util/bpf-filter.y
278         $(call rule_mkdir)
279         $(Q)$(call echo-cmd,bison)$(BISON) -v $< -d $(PARSER_DEBUG_BISON) $(BISON_FILE_PREFIX_MAP) \
280                 -o $(OUTPUT)util/bpf-filter-bison.c -p perf_bpf_filter_
281
282 FLEX_VERSION := $(shell $(FLEX) --version | cut -d' ' -f2)
283
284 FLEX_GE_260 := $(call version-ge3,$(FLEX_VERSION),2.6.0)
285 ifeq ($(FLEX_GE_260),1)
286   flex_flags := -Wno-redundant-decls -Wno-switch-default -Wno-unused-function -Wno-misleading-indentation
287
288   # Some newer clang and gcc version complain about this
289   # util/parse-events-bison.c:1317:9: error: variable 'parse_events_nerrs' set but not used [-Werror,-Wunused-but-set-variable]
290   #  int yynerrs = 0;
291
292   flex_flags += -Wno-unused-but-set-variable
293
294   FLEX_LT_262 := $(call version-lt3,$(FLEX_VERSION),2.6.2)
295   ifeq ($(FLEX_LT_262),1)
296     flex_flags += -Wno-sign-compare
297   endif
298 else
299   flex_flags := -w
300 endif
301
302 # Some newer clang and gcc version complain about this
303 # util/parse-events-bison.c:1317:9: error: variable 'parse_events_nerrs' set but not used [-Werror,-Wunused-but-set-variable]
304 #  int yynerrs = 0;
305
306 bison_flags := -DYYENABLE_NLS=0 -Wno-unused-but-set-variable
307
308 # Old clangs don't grok -Wno-unused-but-set-variable, remove it
309 ifeq ($(CC_NO_CLANG), 0)
310   CLANG_VERSION := $(shell $(CLANG) --version | head -1 | sed 's/.*clang version \([[:digit:]]\+.[[:digit:]]\+.[[:digit:]]\+\).*/\1/g')
311   ifeq ($(call version-lt3,$(CLANG_VERSION),13.0.0),1)
312     bison_flags := $(subst -Wno-unused-but-set-variable,,$(bison_flags))
313     flex_flags := $(subst -Wno-unused-but-set-variable,,$(flex_flags))
314   endif
315 endif
316
317 BISON_GE_382 := $(shell expr $(shell $(BISON) --version | grep bison | sed -e 's/.\+ \([0-9]\+\).\([0-9]\+\).\([0-9]\+\)/\1\2\3/g') \>\= 382)
318 ifeq ($(BISON_GE_382),1)
319   bison_flags += -Wno-switch-enum
320 else
321   bison_flags += -w
322 endif
323
324 BISON_LT_381 := $(shell expr $(shell $(BISON) --version | grep bison | sed -e 's/.\+ \([0-9]\+\).\([0-9]\+\).\([0-9]\+\)/\1\2\3/g') \< 381)
325 ifeq ($(BISON_LT_381),1)
326   bison_flags += -DYYNOMEM=YYABORT
327 endif
328
329 CFLAGS_parse-events-flex.o  += $(flex_flags) -Wno-unused-label
330 CFLAGS_pmu-flex.o           += $(flex_flags)
331 CFLAGS_expr-flex.o          += $(flex_flags)
332 CFLAGS_bpf-filter-flex.o    += $(flex_flags)
333
334 CFLAGS_parse-events-bison.o += $(bison_flags)
335 CFLAGS_pmu-bison.o          += -DYYLTYPE_IS_TRIVIAL=0 $(bison_flags)
336 CFLAGS_expr-bison.o         += -DYYLTYPE_IS_TRIVIAL=0 $(bison_flags)
337 CFLAGS_bpf-filter-bison.o   += -DYYLTYPE_IS_TRIVIAL=0 $(bison_flags)
338
339 $(OUTPUT)util/parse-events.o: $(OUTPUT)util/parse-events-flex.c $(OUTPUT)util/parse-events-bison.c
340 $(OUTPUT)util/pmu.o: $(OUTPUT)util/pmu-flex.c $(OUTPUT)util/pmu-bison.c
341 $(OUTPUT)util/expr.o: $(OUTPUT)util/expr-flex.c $(OUTPUT)util/expr-bison.c
342 $(OUTPUT)util/bpf-filter.o: $(OUTPUT)util/bpf-filter-flex.c $(OUTPUT)util/bpf-filter-bison.c
343
344 CFLAGS_bitmap.o        += -Wno-unused-parameter -DETC_PERFCONFIG="BUILD_STR($(ETC_PERFCONFIG_SQ))"
345 CFLAGS_find_bit.o      += -Wno-unused-parameter -DETC_PERFCONFIG="BUILD_STR($(ETC_PERFCONFIG_SQ))"
346 CFLAGS_rbtree.o        += -Wno-unused-parameter -DETC_PERFCONFIG="BUILD_STR($(ETC_PERFCONFIG_SQ))"
347 CFLAGS_libstring.o     += -Wno-unused-parameter -DETC_PERFCONFIG="BUILD_STR($(ETC_PERFCONFIG_SQ))"
348 CFLAGS_hweight.o       += -Wno-unused-parameter -DETC_PERFCONFIG="BUILD_STR($(ETC_PERFCONFIG_SQ))"
349 CFLAGS_header.o        += -include $(OUTPUT)PERF-VERSION-FILE
350 CFLAGS_arm-spe.o       += -I$(srctree)/tools/arch/arm64/include/ -I$(srctree)/tools/arch/arm64/include/generated/
351
352 $(OUTPUT)util/argv_split.o: ../lib/argv_split.c FORCE
353         $(call rule_mkdir)
354         $(call if_changed_dep,cc_o_c)
355
356 $(OUTPUT)util/bitmap.o: ../lib/bitmap.c FORCE
357         $(call rule_mkdir)
358         $(call if_changed_dep,cc_o_c)
359
360 $(OUTPUT)util/ctype.o: ../lib/ctype.c FORCE
361         $(call rule_mkdir)
362         $(call if_changed_dep,cc_o_c)
363
364 $(OUTPUT)util/find_bit.o: ../lib/find_bit.c FORCE
365         $(call rule_mkdir)
366         $(call if_changed_dep,cc_o_c)
367
368 $(OUTPUT)util/rbtree.o: ../lib/rbtree.c FORCE
369         $(call rule_mkdir)
370         $(call if_changed_dep,cc_o_c)
371
372 $(OUTPUT)util/libstring.o: ../lib/string.c FORCE
373         $(call rule_mkdir)
374         $(call if_changed_dep,cc_o_c)
375
376 $(OUTPUT)util/hweight.o: ../lib/hweight.c FORCE
377         $(call rule_mkdir)
378         $(call if_changed_dep,cc_o_c)
379
380 $(OUTPUT)util/vsprintf.o: ../lib/vsprintf.c FORCE
381         $(call rule_mkdir)
382         $(call if_changed_dep,cc_o_c)
383
384 $(OUTPUT)util/list_sort.o: ../lib/list_sort.c FORCE
385         $(call rule_mkdir)
386         $(call if_changed_dep,cc_o_c)