Commit e467705a authored by Ian Rogers's avatar Ian Rogers Committed by Namhyung Kim

perf util: Make util its own library

Make the util directory into its own library. This is done to avoid
compiling code twice, once for the perf tool and once for the perf
python module. For convenience:
  arch/common.c
  scripts/perl/Perf-Trace-Util/Context.c
  scripts/python/Perf-Trace-Util/Context.c
are made part of this library.
Signed-off-by: default avatarIan Rogers <irogers@google.com>
Reviewed-by: default avatarJames Clark <james.clark@arm.com>
Cc: Suzuki K Poulose <suzuki.poulose@arm.com>
Cc: Kees Cook <keescook@chromium.org>
Cc: Palmer Dabbelt <palmer@dabbelt.com>
Cc: Albert Ou <aou@eecs.berkeley.edu>
Cc: Nick Terrell <terrelln@fb.com>
Cc: Gary Guo <gary@garyguo.net>
Cc: Alex Gaynor <alex.gaynor@gmail.com>
Cc: Boqun Feng <boqun.feng@gmail.com>
Cc: Wedson Almeida Filho <wedsonaf@gmail.com>
Cc: Ze Gao <zegao2021@gmail.com>
Cc: Alice Ryhl <aliceryhl@google.com>
Cc: Andrei Vagin <avagin@google.com>
Cc: Yicong Yang <yangyicong@hisilicon.com>
Cc: Jonathan Cameron <jonathan.cameron@huawei.com>
Cc: Guo Ren <guoren@kernel.org>
Cc: Miguel Ojeda <ojeda@kernel.org>
Cc: Will Deacon <will@kernel.org>
Cc: Mike Leach <mike.leach@linaro.org>
Cc: Leo Yan <leo.yan@linux.dev>
Cc: Oliver Upton <oliver.upton@linux.dev>
Cc: John Garry <john.g.garry@oracle.com>
Cc: Benno Lossin <benno.lossin@proton.me>
Cc: Björn Roy Baron <bjorn3_gh@protonmail.com>
Cc: Andreas Hindborg <a.hindborg@samsung.com>
Cc: Paul Walmsley <paul.walmsley@sifive.com>
Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
Link: https://lore.kernel.org/r/20240625214117.953777-7-irogers@google.com
parent 21cc3bc0
...@@ -53,11 +53,12 @@ CFLAGS_builtin-trace.o += -DSTRACE_GROUPS_DIR="BUILD_STR($(STRACE_GROUPS_DIR_ ...@@ -53,11 +53,12 @@ CFLAGS_builtin-trace.o += -DSTRACE_GROUPS_DIR="BUILD_STR($(STRACE_GROUPS_DIR_
CFLAGS_builtin-report.o += -DTIPDIR="BUILD_STR($(tipdir_SQ))" CFLAGS_builtin-report.o += -DTIPDIR="BUILD_STR($(tipdir_SQ))"
CFLAGS_builtin-report.o += -DDOCDIR="BUILD_STR($(srcdir_SQ)/Documentation)" CFLAGS_builtin-report.o += -DDOCDIR="BUILD_STR($(srcdir_SQ)/Documentation)"
perf-y += util/ perf-util-y += util/
perf-util-y += arch/
perf-y += arch/ perf-y += arch/
perf-test-y += arch/ perf-test-y += arch/
perf-ui-y += ui/ perf-ui-y += ui/
perf-y += scripts/ perf-util-y += scripts/
gtk-y += ui/gtk/ gtk-y += ui/gtk/
......
...@@ -434,6 +434,9 @@ LIBPERF_TEST := $(OUTPUT)libperf-test.a ...@@ -434,6 +434,9 @@ LIBPERF_TEST := $(OUTPUT)libperf-test.a
LIBPERF_UI_IN := $(OUTPUT)perf-ui-in.o LIBPERF_UI_IN := $(OUTPUT)perf-ui-in.o
LIBPERF_UI := $(OUTPUT)libperf-ui.a LIBPERF_UI := $(OUTPUT)libperf-ui.a
LIBPERF_UTIL_IN := $(OUTPUT)perf-util-in.o
LIBPERF_UTIL := $(OUTPUT)libperf-util.a
LIBPMU_EVENTS_IN := $(OUTPUT)pmu-events/pmu-events-in.o LIBPMU_EVENTS_IN := $(OUTPUT)pmu-events/pmu-events-in.o
LIBPMU_EVENTS := $(OUTPUT)libpmu-events.a LIBPMU_EVENTS := $(OUTPUT)libpmu-events.a
...@@ -441,7 +444,8 @@ PERFLIBS = $(LIBAPI) $(LIBPERF) $(LIBSUBCMD) $(LIBSYMBOL) ...@@ -441,7 +444,8 @@ PERFLIBS = $(LIBAPI) $(LIBPERF) $(LIBSUBCMD) $(LIBSYMBOL)
ifdef LIBBPF_STATIC ifdef LIBBPF_STATIC
PERFLIBS += $(LIBBPF) PERFLIBS += $(LIBBPF)
endif endif
PERFLIBS += $(LIBPERF_BENCH) $(LIBPERF_TEST) $(LIBPERF_UI) $(LIBPMU_EVENTS) PERFLIBS += $(LIBPERF_BENCH) $(LIBPERF_TEST) $(LIBPERF_UI) $(LIBPERF_UTIL)
PERFLIBS += $(LIBPMU_EVENTS)
# We choose to avoid "if .. else if .. else .. endif endif" # We choose to avoid "if .. else if .. else .. endif endif"
# because maintaining the nesting to match is a pain. If # because maintaining the nesting to match is a pain. If
...@@ -761,6 +765,12 @@ $(LIBPERF_UI_IN): FORCE prepare ...@@ -761,6 +765,12 @@ $(LIBPERF_UI_IN): FORCE prepare
$(LIBPERF_UI): $(LIBPERF_UI_IN) $(LIBPERF_UI): $(LIBPERF_UI_IN)
$(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $< $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $<
$(LIBPERF_UTIL_IN): FORCE prepare
$(Q)$(MAKE) $(build)=perf-util
$(LIBPERF_UTIL): $(LIBPERF_UTIL_IN)
$(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $<
$(OUTPUT)perf: $(PERFLIBS) $(PERF_IN) $(OUTPUT)perf: $(PERFLIBS) $(PERF_IN)
$(QUIET_LINK)$(CC) $(CFLAGS) $(LDFLAGS) \ $(QUIET_LINK)$(CC) $(CFLAGS) $(LDFLAGS) \
$(PERF_IN) $(LIBS) -o $@ $(PERF_IN) $(LIBS) -o $@
......
perf-y += common.o perf-util-y += common.o
perf-y += $(SRCARCH)/
perf-test-y += $(SRCARCH)/ perf-test-y += $(SRCARCH)/
perf-util-y += $(SRCARCH)/
perf-y += util/ perf-util-y += util/
perf-test-$(CONFIG_DWARF_UNWIND) += tests/ perf-test-$(CONFIG_DWARF_UNWIND) += tests/
perf-y += perf_regs.o perf-util-y += perf_regs.o
perf-$(CONFIG_DWARF) += dwarf-regs.o perf-util-$(CONFIG_DWARF) += dwarf-regs.o
perf-$(CONFIG_LOCAL_LIBUNWIND) += unwind-libunwind.o perf-util-$(CONFIG_LOCAL_LIBUNWIND) += unwind-libunwind.o
perf-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o perf-util-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o
perf-$(CONFIG_AUXTRACE) += pmu.o auxtrace.o cs-etm.o perf-util-$(CONFIG_AUXTRACE) += pmu.o auxtrace.o cs-etm.o
perf-y += util/ perf-util-y += util/
perf-test-y += tests/ perf-test-y += tests/
perf-y += header.o perf-util-y += header.o
perf-y += machine.o perf-util-y += machine.o
perf-y += perf_regs.o perf-util-y += perf_regs.o
perf-y += tsc.o perf-util-y += tsc.o
perf-y += pmu.o perf-util-y += pmu.o
perf-$(CONFIG_LIBTRACEEVENT) += kvm-stat.o perf-util-$(CONFIG_LIBTRACEEVENT) += kvm-stat.o
perf-$(CONFIG_DWARF) += dwarf-regs.o perf-util-$(CONFIG_DWARF) += dwarf-regs.o
perf-$(CONFIG_LOCAL_LIBUNWIND) += unwind-libunwind.o perf-util-$(CONFIG_LOCAL_LIBUNWIND) += unwind-libunwind.o
perf-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o perf-util-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o
perf-$(CONFIG_AUXTRACE) += ../../arm/util/pmu.o \ perf-util-$(CONFIG_AUXTRACE) += ../../arm/util/pmu.o \
../../arm/util/auxtrace.o \ ../../arm/util/auxtrace.o \
../../arm/util/cs-etm.o \ ../../arm/util/cs-etm.o \
arm-spe.o mem-events.o hisi-ptt.o arm-spe.o mem-events.o hisi-ptt.o
perf-y += util/ perf-util-y += util/
perf-y += perf_regs.o perf-util-y += perf_regs.o
perf-$(CONFIG_DWARF) += dwarf-regs.o perf-util-$(CONFIG_DWARF) += dwarf-regs.o
perf-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o perf-util-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o
perf-y += util/ perf-util-y += util/
perf-y += perf_regs.o perf-util-y += perf_regs.o
perf-$(CONFIG_DWARF) += dwarf-regs.o perf-util-$(CONFIG_DWARF) += dwarf-regs.o
perf-$(CONFIG_LOCAL_LIBUNWIND) += unwind-libunwind.o perf-util-$(CONFIG_LOCAL_LIBUNWIND) += unwind-libunwind.o
perf-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o perf-util-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o
perf-y += util/ perf-util-y += util/
perf-y += perf_regs.o perf-util-y += perf_regs.o
perf-$(CONFIG_DWARF) += dwarf-regs.o perf-util-$(CONFIG_DWARF) += dwarf-regs.o
perf-$(CONFIG_LOCAL_LIBUNWIND) += unwind-libunwind.o perf-util-$(CONFIG_LOCAL_LIBUNWIND) += unwind-libunwind.o
perf-y += util/ perf-util-y += util/
perf-test-y += tests/ perf-test-y += tests/
perf-y += header.o perf-util-y += header.o
perf-$(CONFIG_LIBTRACEEVENT) += kvm-stat.o perf-util-$(CONFIG_LIBTRACEEVENT) += kvm-stat.o
perf-y += perf_regs.o perf-util-y += perf_regs.o
perf-y += mem-events.o perf-util-y += mem-events.o
perf-y += pmu.o perf-util-y += pmu.o
perf-y += sym-handling.o perf-util-y += sym-handling.o
perf-y += evsel.o perf-util-y += evsel.o
perf-y += event.o perf-util-y += event.o
perf-$(CONFIG_DWARF) += dwarf-regs.o perf-util-$(CONFIG_DWARF) += dwarf-regs.o
perf-$(CONFIG_DWARF) += skip-callchain-idx.o perf-util-$(CONFIG_DWARF) += skip-callchain-idx.o
perf-$(CONFIG_LIBUNWIND) += unwind-libunwind.o perf-util-$(CONFIG_LIBUNWIND) += unwind-libunwind.o
perf-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o perf-util-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o
perf-y += util/ perf-util-y += util/
perf-y += perf_regs.o perf-util-y += perf_regs.o
perf-y += header.o perf-util-y += header.o
perf-$(CONFIG_DWARF) += dwarf-regs.o perf-util-$(CONFIG_DWARF) += dwarf-regs.o
perf-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o perf-util-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o
perf-y += util/ perf-util-y += util/
perf-y += header.o perf-util-y += header.o
perf-$(CONFIG_LIBTRACEEVENT) += kvm-stat.o perf-util-$(CONFIG_LIBTRACEEVENT) += kvm-stat.o
perf-y += perf_regs.o perf-util-y += perf_regs.o
perf-$(CONFIG_DWARF) += dwarf-regs.o perf-util-$(CONFIG_DWARF) += dwarf-regs.o
perf-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o perf-util-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o
perf-y += machine.o perf-util-y += machine.o
perf-y += pmu.o perf-util-y += pmu.o
perf-$(CONFIG_AUXTRACE) += auxtrace.o perf-util-$(CONFIG_AUXTRACE) += auxtrace.o
perf-y += util/ perf-util-y += util/
perf-$(CONFIG_DWARF) += dwarf-regs.o perf-util-$(CONFIG_DWARF) += dwarf-regs.o
perf-y += util/ perf-util-y += util/
perf-$(CONFIG_DWARF) += dwarf-regs.o perf-util-$(CONFIG_DWARF) += dwarf-regs.o
perf-y += util/ perf-util-y += util/
perf-test-y += tests/ perf-test-y += tests/
ifdef SHELLCHECK ifdef SHELLCHECK
......
perf-y += header.o perf-util-y += header.o
perf-y += tsc.o perf-util-y += tsc.o
perf-y += pmu.o perf-util-y += pmu.o
perf-$(CONFIG_LIBTRACEEVENT) += kvm-stat.o perf-util-$(CONFIG_LIBTRACEEVENT) += kvm-stat.o
perf-y += perf_regs.o perf-util-y += perf_regs.o
perf-y += topdown.o perf-util-y += topdown.o
perf-y += machine.o perf-util-y += machine.o
perf-y += event.o perf-util-y += event.o
perf-y += evlist.o perf-util-y += evlist.o
perf-y += mem-events.o perf-util-y += mem-events.o
perf-y += evsel.o perf-util-y += evsel.o
perf-y += iostat.o perf-util-y += iostat.o
perf-y += env.o perf-util-y += env.o
perf-$(CONFIG_DWARF) += dwarf-regs.o perf-util-$(CONFIG_DWARF) += dwarf-regs.o
perf-$(CONFIG_BPF_PROLOGUE) += dwarf-regs.o perf-util-$(CONFIG_BPF_PROLOGUE) += dwarf-regs.o
perf-$(CONFIG_LOCAL_LIBUNWIND) += unwind-libunwind.o perf-util-$(CONFIG_LOCAL_LIBUNWIND) += unwind-libunwind.o
perf-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o perf-util-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o
perf-$(CONFIG_AUXTRACE) += auxtrace.o perf-util-$(CONFIG_AUXTRACE) += auxtrace.o
perf-$(CONFIG_AUXTRACE) += archinsn.o perf-util-$(CONFIG_AUXTRACE) += archinsn.o
perf-$(CONFIG_AUXTRACE) += intel-pt.o perf-util-$(CONFIG_AUXTRACE) += intel-pt.o
perf-$(CONFIG_AUXTRACE) += intel-bts.o perf-util-$(CONFIG_AUXTRACE) += intel-bts.o
perf-y += util/ perf-util-y += util/
ifeq ($(CONFIG_LIBTRACEEVENT),y) ifeq ($(CONFIG_LIBTRACEEVENT),y)
perf-$(CONFIG_LIBPERL) += perl/Perf-Trace-Util/ perf-util-$(CONFIG_LIBPERL) += perl/Perf-Trace-Util/
endif endif
perf-$(CONFIG_LIBPYTHON) += python/Perf-Trace-Util/ perf-util-$(CONFIG_LIBPYTHON) += python/Perf-Trace-Util/
perf-y += Context.o perf-util-y += Context.o
CFLAGS_Context.o += $(PERL_EMBED_CCOPTS) -Wno-redundant-decls -Wno-strict-prototypes -Wno-bad-function-cast -Wno-declaration-after-statement -Wno-switch-enum CFLAGS_Context.o += $(PERL_EMBED_CCOPTS) -Wno-redundant-decls -Wno-strict-prototypes -Wno-bad-function-cast -Wno-declaration-after-statement -Wno-switch-enum
CFLAGS_Context.o += -Wno-unused-parameter -Wno-nested-externs -Wno-undef CFLAGS_Context.o += -Wno-unused-parameter -Wno-nested-externs -Wno-undef
......
perf-y += Context.o perf-util-y += Context.o
# -Wno-declaration-after-statement: The python headers have mixed code with declarations (decls after asserts, for instance) # -Wno-declaration-after-statement: The python headers have mixed code with declarations (decls after asserts, for instance)
CFLAGS_Context.o += $(PYTHON_EMBED_CCOPTS) -Wno-redundant-decls -Wno-strict-prototypes -Wno-unused-parameter -Wno-nested-externs -Wno-declaration-after-statement CFLAGS_Context.o += $(PYTHON_EMBED_CCOPTS) -Wno-redundant-decls -Wno-strict-prototypes -Wno-unused-parameter -Wno-nested-externs -Wno-declaration-after-statement
include $(srctree)/tools/scripts/Makefile.include include $(srctree)/tools/scripts/Makefile.include
include $(srctree)/tools/scripts/utilities.mak include $(srctree)/tools/scripts/utilities.mak
perf-y += arm64-frame-pointer-unwind-support.o perf-util-y += arm64-frame-pointer-unwind-support.o
perf-y += addr_location.o perf-util-y += addr_location.o
perf-y += annotate.o perf-util-y += annotate.o
perf-y += block-info.o perf-util-y += block-info.o
perf-y += block-range.o perf-util-y += block-range.o
perf-y += build-id.o perf-util-y += build-id.o
perf-y += cacheline.o perf-util-y += cacheline.o
perf-y += config.o perf-util-y += config.o
perf-y += copyfile.o perf-util-y += copyfile.o
perf-y += ctype.o perf-util-y += ctype.o
perf-y += db-export.o perf-util-y += db-export.o
perf-y += disasm.o perf-util-y += disasm.o
perf-y += env.o perf-util-y += env.o
perf-y += event.o perf-util-y += event.o
perf-y += evlist.o perf-util-y += evlist.o
perf-y += sideband_evlist.o perf-util-y += sideband_evlist.o
perf-y += evsel.o perf-util-y += evsel.o
perf-y += evsel_fprintf.o perf-util-y += evsel_fprintf.o
perf-y += perf_event_attr_fprintf.o perf-util-y += perf_event_attr_fprintf.o
perf-y += evswitch.o perf-util-y += evswitch.o
perf-y += find_bit.o perf-util-y += find_bit.o
perf-y += get_current_dir_name.o perf-util-y += get_current_dir_name.o
perf-y += levenshtein.o perf-util-y += levenshtein.o
perf-y += mmap.o perf-util-y += mmap.o
perf-y += memswap.o perf-util-y += memswap.o
perf-y += parse-events.o perf-util-y += parse-events.o
perf-y += print-events.o perf-util-y += print-events.o
perf-y += tracepoint.o perf-util-y += tracepoint.o
perf-y += perf_regs.o perf-util-y += perf_regs.o
perf-y += perf-regs-arch/ perf-util-y += perf-regs-arch/
perf-y += path.o perf-util-y += path.o
perf-y += print_binary.o perf-util-y += print_binary.o
perf-y += print_insn.o perf-util-y += print_insn.o
perf-y += rlimit.o perf-util-y += rlimit.o
perf-y += argv_split.o perf-util-y += argv_split.o
perf-y += rbtree.o perf-util-y += rbtree.o
perf-y += libstring.o perf-util-y += libstring.o
perf-y += bitmap.o perf-util-y += bitmap.o
perf-y += hweight.o perf-util-y += hweight.o
perf-y += smt.o perf-util-y += smt.o
perf-y += strbuf.o perf-util-y += strbuf.o
perf-y += string.o perf-util-y += string.o
perf-y += strlist.o perf-util-y += strlist.o
perf-y += strfilter.o perf-util-y += strfilter.o
perf-y += top.o perf-util-y += top.o
perf-y += usage.o perf-util-y += usage.o
perf-y += dso.o perf-util-y += dso.o
perf-y += dsos.o perf-util-y += dsos.o
perf-y += symbol.o perf-util-y += symbol.o
perf-y += symbol_fprintf.o perf-util-y += symbol_fprintf.o
perf-y += map_symbol.o perf-util-y += map_symbol.o
perf-y += color.o perf-util-y += color.o
perf-y += color_config.o perf-util-y += color_config.o
perf-y += metricgroup.o perf-util-y += metricgroup.o
perf-y += header.o perf-util-y += header.o
perf-y += callchain.o perf-util-y += callchain.o
perf-y += values.o perf-util-y += values.o
perf-y += debug.o perf-util-y += debug.o
perf-y += fncache.o perf-util-y += fncache.o
perf-y += machine.o perf-util-y += machine.o
perf-y += map.o perf-util-y += map.o
perf-y += maps.o perf-util-y += maps.o
perf-y += pstack.o perf-util-y += pstack.o
perf-y += session.o perf-util-y += session.o
perf-y += sample-raw.o perf-util-y += sample-raw.o
perf-y += s390-sample-raw.o perf-util-y += s390-sample-raw.o
perf-y += amd-sample-raw.o perf-util-y += amd-sample-raw.o
perf-$(CONFIG_TRACE) += syscalltbl.o perf-util-$(CONFIG_TRACE) += syscalltbl.o
perf-y += ordered-events.o perf-util-y += ordered-events.o
perf-y += namespaces.o perf-util-y += namespaces.o
perf-y += comm.o perf-util-y += comm.o
perf-y += thread.o perf-util-y += thread.o
perf-y += threads.o perf-util-y += threads.o
perf-y += thread_map.o perf-util-y += thread_map.o
perf-y += parse-events-flex.o perf-util-y += parse-events-flex.o
perf-y += parse-events-bison.o perf-util-y += parse-events-bison.o
perf-y += pmu.o perf-util-y += pmu.o
perf-y += pmus.o perf-util-y += pmus.o
perf-y += pmu-flex.o perf-util-y += pmu-flex.o
perf-y += pmu-bison.o perf-util-y += pmu-bison.o
perf-y += svghelper.o perf-util-y += svghelper.o
perf-$(CONFIG_LIBTRACEEVENT) += trace-event-info.o perf-util-$(CONFIG_LIBTRACEEVENT) += trace-event-info.o
perf-y += trace-event-scripting.o perf-util-y += trace-event-scripting.o
perf-$(CONFIG_LIBTRACEEVENT) += trace-event.o perf-util-$(CONFIG_LIBTRACEEVENT) += trace-event.o
perf-$(CONFIG_LIBTRACEEVENT) += trace-event-parse.o perf-util-$(CONFIG_LIBTRACEEVENT) += trace-event-parse.o
perf-$(CONFIG_LIBTRACEEVENT) += trace-event-read.o perf-util-$(CONFIG_LIBTRACEEVENT) += trace-event-read.o
perf-y += sort.o perf-util-y += sort.o
perf-y += hist.o perf-util-y += hist.o
perf-y += util.o perf-util-y += util.o
perf-y += cpumap.o perf-util-y += cpumap.o
perf-y += affinity.o perf-util-y += affinity.o
perf-y += cputopo.o perf-util-y += cputopo.o
perf-y += cgroup.o perf-util-y += cgroup.o
perf-y += target.o perf-util-y += target.o
perf-y += rblist.o perf-util-y += rblist.o
perf-y += intlist.o perf-util-y += intlist.o
perf-y += vdso.o perf-util-y += vdso.o
perf-y += counts.o perf-util-y += counts.o
perf-y += stat.o perf-util-y += stat.o
perf-y += stat-shadow.o perf-util-y += stat-shadow.o
perf-y += stat-display.o perf-util-y += stat-display.o
perf-y += perf_api_probe.o perf-util-y += perf_api_probe.o
perf-y += record.o perf-util-y += record.o
perf-y += srcline.o perf-util-y += srcline.o
perf-y += srccode.o perf-util-y += srccode.o
perf-y += synthetic-events.o perf-util-y += synthetic-events.o
perf-y += data.o perf-util-y += data.o
perf-y += tsc.o perf-util-y += tsc.o
perf-y += cloexec.o perf-util-y += cloexec.o
perf-y += call-path.o perf-util-y += call-path.o
perf-y += rwsem.o perf-util-y += rwsem.o
perf-y += thread-stack.o perf-util-y += thread-stack.o
perf-y += spark.o perf-util-y += spark.o
perf-y += topdown.o perf-util-y += topdown.o
perf-y += iostat.o perf-util-y += iostat.o
perf-y += stream.o perf-util-y += stream.o
perf-$(CONFIG_AUXTRACE) += auxtrace.o perf-util-$(CONFIG_AUXTRACE) += auxtrace.o
perf-$(CONFIG_AUXTRACE) += intel-pt-decoder/ perf-util-$(CONFIG_AUXTRACE) += intel-pt-decoder/
perf-$(CONFIG_AUXTRACE) += intel-pt.o perf-util-$(CONFIG_AUXTRACE) += intel-pt.o
perf-$(CONFIG_AUXTRACE) += intel-bts.o perf-util-$(CONFIG_AUXTRACE) += intel-bts.o
perf-$(CONFIG_AUXTRACE) += arm-spe.o perf-util-$(CONFIG_AUXTRACE) += arm-spe.o
perf-$(CONFIG_AUXTRACE) += arm-spe-decoder/ perf-util-$(CONFIG_AUXTRACE) += arm-spe-decoder/
perf-$(CONFIG_AUXTRACE) += hisi-ptt.o perf-util-$(CONFIG_AUXTRACE) += hisi-ptt.o
perf-$(CONFIG_AUXTRACE) += hisi-ptt-decoder/ perf-util-$(CONFIG_AUXTRACE) += hisi-ptt-decoder/
perf-$(CONFIG_AUXTRACE) += s390-cpumsf.o perf-util-$(CONFIG_AUXTRACE) += s390-cpumsf.o
ifdef CONFIG_LIBOPENCSD ifdef CONFIG_LIBOPENCSD
perf-$(CONFIG_AUXTRACE) += cs-etm.o perf-util-$(CONFIG_AUXTRACE) += cs-etm.o
perf-$(CONFIG_AUXTRACE) += cs-etm-decoder/ perf-util-$(CONFIG_AUXTRACE) += cs-etm-decoder/
endif endif
perf-$(CONFIG_AUXTRACE) += cs-etm-base.o perf-util-$(CONFIG_AUXTRACE) += cs-etm-base.o
perf-y += parse-branch-options.o perf-util-y += parse-branch-options.o
perf-y += dump-insn.o perf-util-y += dump-insn.o
perf-y += parse-regs-options.o perf-util-y += parse-regs-options.o
perf-y += parse-sublevel-options.o perf-util-y += parse-sublevel-options.o
perf-y += term.o perf-util-y += term.o
perf-y += help-unknown-cmd.o perf-util-y += help-unknown-cmd.o
perf-y += dlfilter.o perf-util-y += dlfilter.o
perf-y += mem-events.o perf-util-y += mem-events.o
perf-y += mem-info.o perf-util-y += mem-info.o
perf-y += vsprintf.o perf-util-y += vsprintf.o
perf-y += units.o perf-util-y += units.o
perf-y += time-utils.o perf-util-y += time-utils.o
perf-y += expr-flex.o perf-util-y += expr-flex.o
perf-y += expr-bison.o perf-util-y += expr-bison.o
perf-y += expr.o perf-util-y += expr.o
perf-y += branch.o perf-util-y += branch.o
perf-y += mem2node.o perf-util-y += mem2node.o
perf-y += clockid.o perf-util-y += clockid.o
perf-y += list_sort.o perf-util-y += list_sort.o
perf-y += mutex.o perf-util-y += mutex.o
perf-y += sharded_mutex.o perf-util-y += sharded_mutex.o
perf-$(CONFIG_LIBBPF) += bpf_map.o perf-util-$(CONFIG_LIBBPF) += bpf_map.o
perf-$(CONFIG_PERF_BPF_SKEL) += bpf_counter.o perf-util-$(CONFIG_PERF_BPF_SKEL) += bpf_counter.o
perf-$(CONFIG_PERF_BPF_SKEL) += bpf_counter_cgroup.o perf-util-$(CONFIG_PERF_BPF_SKEL) += bpf_counter_cgroup.o
perf-$(CONFIG_PERF_BPF_SKEL) += bpf_ftrace.o perf-util-$(CONFIG_PERF_BPF_SKEL) += bpf_ftrace.o
perf-$(CONFIG_PERF_BPF_SKEL) += bpf_off_cpu.o perf-util-$(CONFIG_PERF_BPF_SKEL) += bpf_off_cpu.o
perf-$(CONFIG_PERF_BPF_SKEL) += bpf-filter.o perf-util-$(CONFIG_PERF_BPF_SKEL) += bpf-filter.o
perf-$(CONFIG_PERF_BPF_SKEL) += bpf-filter-flex.o perf-util-$(CONFIG_PERF_BPF_SKEL) += bpf-filter-flex.o
perf-$(CONFIG_PERF_BPF_SKEL) += bpf-filter-bison.o perf-util-$(CONFIG_PERF_BPF_SKEL) += bpf-filter-bison.o
ifeq ($(CONFIG_LIBTRACEEVENT),y) ifeq ($(CONFIG_LIBTRACEEVENT),y)
perf-$(CONFIG_PERF_BPF_SKEL) += bpf_lock_contention.o perf-util-$(CONFIG_PERF_BPF_SKEL) += bpf_lock_contention.o
endif endif
ifeq ($(CONFIG_LIBTRACEEVENT),y) ifeq ($(CONFIG_LIBTRACEEVENT),y)
perf-$(CONFIG_PERF_BPF_SKEL) += bpf_kwork.o perf-util-$(CONFIG_PERF_BPF_SKEL) += bpf_kwork.o
perf-$(CONFIG_PERF_BPF_SKEL) += bpf_kwork_top.o perf-util-$(CONFIG_PERF_BPF_SKEL) += bpf_kwork_top.o
endif endif
perf-$(CONFIG_LIBELF) += symbol-elf.o perf-util-$(CONFIG_LIBELF) += symbol-elf.o
perf-$(CONFIG_LIBELF) += probe-file.o perf-util-$(CONFIG_LIBELF) += probe-file.o
perf-$(CONFIG_LIBELF) += probe-event.o perf-util-$(CONFIG_LIBELF) += probe-event.o
ifdef CONFIG_LIBBPF_DYNAMIC ifdef CONFIG_LIBBPF_DYNAMIC
hashmap := 1 hashmap := 1
...@@ -185,60 +185,60 @@ ifndef CONFIG_LIBBPF ...@@ -185,60 +185,60 @@ ifndef CONFIG_LIBBPF
endif endif
ifdef hashmap ifdef hashmap
perf-y += hashmap.o perf-util-y += hashmap.o
endif endif
ifndef CONFIG_LIBELF ifndef CONFIG_LIBELF
perf-y += symbol-minimal.o perf-util-y += symbol-minimal.o
endif endif
ifndef CONFIG_SETNS ifndef CONFIG_SETNS
perf-y += setns.o perf-util-y += setns.o
endif endif
perf-$(CONFIG_DWARF) += probe-finder.o perf-util-$(CONFIG_DWARF) += probe-finder.o
perf-$(CONFIG_DWARF) += dwarf-aux.o perf-util-$(CONFIG_DWARF) += dwarf-aux.o
perf-$(CONFIG_DWARF) += dwarf-regs.o perf-util-$(CONFIG_DWARF) += dwarf-regs.o
perf-$(CONFIG_DWARF) += debuginfo.o perf-util-$(CONFIG_DWARF) += debuginfo.o
perf-$(CONFIG_DWARF) += annotate-data.o perf-util-$(CONFIG_DWARF) += annotate-data.o
perf-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o perf-util-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o
perf-$(CONFIG_LOCAL_LIBUNWIND) += unwind-libunwind-local.o perf-util-$(CONFIG_LOCAL_LIBUNWIND) += unwind-libunwind-local.o
perf-$(CONFIG_LIBUNWIND) += unwind-libunwind.o perf-util-$(CONFIG_LIBUNWIND) += unwind-libunwind.o
perf-$(CONFIG_LIBUNWIND_X86) += libunwind/x86_32.o perf-util-$(CONFIG_LIBUNWIND_X86) += libunwind/x86_32.o
perf-$(CONFIG_LIBUNWIND_AARCH64) += libunwind/arm64.o perf-util-$(CONFIG_LIBUNWIND_AARCH64) += libunwind/arm64.o
ifeq ($(CONFIG_LIBTRACEEVENT),y) ifeq ($(CONFIG_LIBTRACEEVENT),y)
perf-$(CONFIG_LIBBABELTRACE) += data-convert-bt.o perf-util-$(CONFIG_LIBBABELTRACE) += data-convert-bt.o
endif endif
perf-y += data-convert-json.o perf-util-y += data-convert-json.o
perf-y += scripting-engines/ perf-util-y += scripting-engines/
perf-$(CONFIG_ZLIB) += zlib.o perf-util-$(CONFIG_ZLIB) += zlib.o
perf-$(CONFIG_LZMA) += lzma.o perf-util-$(CONFIG_LZMA) += lzma.o
perf-$(CONFIG_ZSTD) += zstd.o perf-util-$(CONFIG_ZSTD) += zstd.o
perf-$(CONFIG_LIBCAP) += cap.o perf-util-$(CONFIG_LIBCAP) += cap.o
perf-$(CONFIG_CXX_DEMANGLE) += demangle-cxx.o perf-util-$(CONFIG_CXX_DEMANGLE) += demangle-cxx.o
perf-y += demangle-ocaml.o perf-util-y += demangle-ocaml.o
perf-y += demangle-java.o perf-util-y += demangle-java.o
perf-y += demangle-rust.o perf-util-y += demangle-rust.o
ifdef CONFIG_JITDUMP ifdef CONFIG_JITDUMP
perf-$(CONFIG_LIBELF) += jitdump.o perf-util-$(CONFIG_LIBELF) += jitdump.o
perf-$(CONFIG_LIBELF) += genelf.o perf-util-$(CONFIG_LIBELF) += genelf.o
perf-$(CONFIG_DWARF) += genelf_debug.o perf-util-$(CONFIG_DWARF) += genelf_debug.o
endif endif
perf-y += perf-hooks.o perf-util-y += perf-hooks.o
perf-$(CONFIG_LIBBPF) += bpf-event.o perf-util-$(CONFIG_LIBBPF) += bpf-event.o
perf-$(CONFIG_LIBBPF) += bpf-utils.o perf-util-$(CONFIG_LIBBPF) += bpf-utils.o
perf-$(CONFIG_LIBPFM4) += pfm.o perf-util-$(CONFIG_LIBPFM4) += pfm.o
CFLAGS_config.o += -DETC_PERFCONFIG="BUILD_STR($(ETC_PERFCONFIG_SQ))" CFLAGS_config.o += -DETC_PERFCONFIG="BUILD_STR($(ETC_PERFCONFIG_SQ))"
...@@ -403,4 +403,4 @@ $(OUTPUT)%.shellcheck_log: % ...@@ -403,4 +403,4 @@ $(OUTPUT)%.shellcheck_log: %
$(call rule_mkdir) $(call rule_mkdir)
$(Q)$(call echo-cmd,test)shellcheck -a -S warning "$<" > $@ || (cat $@ && rm $@ && false) $(Q)$(call echo-cmd,test)shellcheck -a -S warning "$<" > $@ || (cat $@ && rm $@ && false)
perf-y += $(TEST_LOGS) perf-util-y += $(TEST_LOGS)
perf-$(CONFIG_AUXTRACE) += arm-spe-pkt-decoder.o arm-spe-decoder.o perf-util-$(CONFIG_AUXTRACE) += arm-spe-pkt-decoder.o arm-spe-decoder.o
perf-$(CONFIG_AUXTRACE) += cs-etm-decoder.o perf-util-$(CONFIG_AUXTRACE) += cs-etm-decoder.o
perf-$(CONFIG_AUXTRACE) += hisi-ptt-pkt-decoder.o perf-util-$(CONFIG_AUXTRACE) += hisi-ptt-pkt-decoder.o
perf-$(CONFIG_AUXTRACE) += intel-pt-pkt-decoder.o intel-pt-insn-decoder.o intel-pt-log.o intel-pt-decoder.o perf-util-$(CONFIG_AUXTRACE) += intel-pt-pkt-decoder.o intel-pt-insn-decoder.o intel-pt-log.o intel-pt-decoder.o
inat_tables_script = $(srctree)/tools/arch/x86/tools/gen-insn-attr-x86.awk inat_tables_script = $(srctree)/tools/arch/x86/tools/gen-insn-attr-x86.awk
inat_tables_maps = $(srctree)/tools/arch/x86/lib/x86-opcode-map.txt inat_tables_maps = $(srctree)/tools/arch/x86/lib/x86-opcode-map.txt
......
perf-y += perf_regs_aarch64.o perf-util-y += perf_regs_aarch64.o
perf-y += perf_regs_arm.o perf-util-y += perf_regs_arm.o
perf-y += perf_regs_csky.o perf-util-y += perf_regs_csky.o
perf-y += perf_regs_loongarch.o perf-util-y += perf_regs_loongarch.o
perf-y += perf_regs_mips.o perf-util-y += perf_regs_mips.o
perf-y += perf_regs_powerpc.o perf-util-y += perf_regs_powerpc.o
perf-y += perf_regs_riscv.o perf-util-y += perf_regs_riscv.o
perf-y += perf_regs_s390.o perf-util-y += perf_regs_s390.o
perf-y += perf_regs_x86.o perf-util-y += perf_regs_x86.o
ifeq ($(CONFIG_LIBTRACEEVENT),y) ifeq ($(CONFIG_LIBTRACEEVENT),y)
perf-$(CONFIG_LIBPERL) += trace-event-perl.o perf-util-$(CONFIG_LIBPERL) += trace-event-perl.o
endif endif
perf-$(CONFIG_LIBPYTHON) += trace-event-python.o perf-util-$(CONFIG_LIBPYTHON) += trace-event-python.o
CFLAGS_trace-event-perl.o += $(PERL_EMBED_CCOPTS) -Wno-redundant-decls -Wno-strict-prototypes -Wno-unused-parameter -Wno-shadow -Wno-nested-externs -Wno-undef -Wno-switch-default -Wno-bad-function-cast -Wno-declaration-after-statement -Wno-switch-enum CFLAGS_trace-event-perl.o += $(PERL_EMBED_CCOPTS) -Wno-redundant-decls -Wno-strict-prototypes -Wno-unused-parameter -Wno-shadow -Wno-nested-externs -Wno-undef -Wno-switch-default -Wno-bad-function-cast -Wno-declaration-after-statement -Wno-switch-enum
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment