378ef0f5d9
Remove the LIBTRACEEVENT_DYNAMIC and LIBTRACEFS_DYNAMIC make command line variables. If libtraceevent isn't installed or NO_LIBTRACEEVENT=1 is passed to the build, don't compile in libtraceevent and libtracefs support. This also disables CONFIG_TRACE that controls "perf trace". CONFIG_LIBTRACEEVENT is used to control enablement in Build/Makefiles, HAVE_LIBTRACEEVENT is used in C code. Without HAVE_LIBTRACEEVENT tracepoints are disabled and as such the commands kmem, kwork, lock, sched and timechart are removed. The majority of commands continue to work including "perf test". Committer notes: Fixed up a tools/perf/util/Build reject and added: #include <traceevent/event-parse.h> to tools/perf/util/scripting-engines/trace-event-perl.c. Committer testing: $ rpm -qi libtraceevent-devel Name : libtraceevent-devel Version : 1.5.3 Release : 2.fc36 Architecture: x86_64 Install Date: Mon 25 Jul 2022 03:20:19 PM -03 Group : Unspecified Size : 27728 License : LGPLv2+ and GPLv2+ Signature : RSA/SHA256, Fri 15 Apr 2022 02:11:58 PM -03, Key ID 999f7cbf38ab71f4 Source RPM : libtraceevent-1.5.3-2.fc36.src.rpm Build Date : Fri 15 Apr 2022 10:57:01 AM -03 Build Host : buildvm-x86-05.iad2.fedoraproject.org Packager : Fedora Project Vendor : Fedora Project URL : https://git.kernel.org/pub/scm/libs/libtrace/libtraceevent.git/ Bug URL : https://bugz.fedoraproject.org/libtraceevent Summary : Development headers of libtraceevent Description : Development headers of libtraceevent-libs $ Default build: $ ldd ~/bin/perf | grep tracee libtraceevent.so.1 => /lib64/libtraceevent.so.1 (0x00007f1dcaf8f000) $ # perf trace -e sched:* --max-events 10 0.000 migration/0/17 sched:sched_migrate_task(comm: "", pid: 1603763 (perf), prio: 120, dest_cpu: 1) 0.005 migration/0/17 sched:sched_wake_idle_without_ipi(cpu: 1) 0.011 migration/0/17 sched:sched_switch(prev_comm: "", prev_pid: 17 (migration/0), prev_state: 1, next_comm: "", next_prio: 120) 1.173 :0/0 sched:sched_wakeup(comm: "", pid: 3138 (gnome-terminal-), prio: 120) 1.180 :0/0 sched:sched_switch(prev_comm: "", prev_prio: 120, next_comm: "", next_pid: 3138 (gnome-terminal-), next_prio: 120) 0.156 migration/1/21 sched:sched_migrate_task(comm: "", pid: 1603763 (perf), prio: 120, orig_cpu: 1, dest_cpu: 2) 0.160 migration/1/21 sched:sched_wake_idle_without_ipi(cpu: 2) 0.166 migration/1/21 sched:sched_switch(prev_comm: "", prev_pid: 21 (migration/1), prev_state: 1, next_comm: "", next_prio: 120) 1.183 :0/0 sched:sched_wakeup(comm: "", pid: 1602985 (kworker/u16:0-f), prio: 120, target_cpu: 1) 1.186 :0/0 sched:sched_switch(prev_comm: "", prev_prio: 120, next_comm: "", next_pid: 1602985 (kworker/u16:0-f), next_prio: 120) # Had to tweak tools/perf/util/setup.py to make sure the python binding shared object links with libtraceevent if -DHAVE_LIBTRACEEVENT is present in CFLAGS. Building with NO_LIBTRACEEVENT=1 uncovered some more build failures: - Make building of data-convert-bt.c to CONFIG_LIBTRACEEVENT=y - perf-$(CONFIG_LIBTRACEEVENT) += scripts/ - bpf_kwork.o needs also to be dependent on CONFIG_LIBTRACEEVENT=y - The python binding needed some fixups and util/trace-event.c can't be built and linked with the python binding shared object, so remove it in tools/perf/util/setup.py and exclude it from the list of dependencies in the python/perf.so Makefile.perf target. Building without libtraceevent-devel installed uncovered more build failures: - The python binding tools/perf/util/python.c was assuming that traceevent/parse-events.h was always available, which was the case when we defaulted to using the in-kernel tools/lib/traceevent/ files, now we need to enclose it under ifdef HAVE_LIBTRACEEVENT, just like the other parts of it that deal with tracepoints. - We have to ifdef the rules in the Build files with CONFIG_LIBTRACEEVENT=y to build builtin-trace.c and tools/perf/trace/beauty/ as we only ifdef setting CONFIG_TRACE=y when setting NO_LIBTRACEEVENT=1 in the make command line, not when we don't detect libtraceevent-devel installed in the system. Simplification here to avoid these two ways of disabling builtin-trace.c and not having CONFIG_TRACE=y when libtraceevent-devel isn't installed is the clean way. From Athira: <quote> tools/perf/arch/powerpc/util/Build -perf-y += kvm-stat.o +perf-$(CONFIG_LIBTRACEEVENT) += kvm-stat.o </quote> Then, ditto for arm64 and s390, detected by container cross build tests. - s/390 uses test__checkevent_tracepoint() that is now only available if HAVE_LIBTRACEEVENT is defined, enclose the callsite with ifder HAVE_LIBTRACEEVENT. Also from Athira: <quote> With this change, I could successfully compile in these environment: - Without libtraceevent-devel installed - With libtraceevent-devel installed - With “make NO_LIBTRACEEVENT=1” </quote> Then, finally rename CONFIG_TRACEEVENT to CONFIG_LIBTRACEEVENT for consistency with other libraries detected in tools/perf/. Signed-off-by: Ian Rogers <irogers@google.com> Tested-by: Arnaldo Carvalho de Melo <acme@redhat.com> Tested-by: Athira Rajeev <atrajeev@linux.vnet.ibm.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Nick Desaulniers <ndesaulniers@google.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Stephane Eranian <eranian@google.com> Cc: bpf@vger.kernel.org Link: http://lore.kernel.org/lkml/20221205225940.3079667-3-irogers@google.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
189 lines
4.6 KiB
C
189 lines
4.6 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef __PERF_HEADER_H
|
|
#define __PERF_HEADER_H
|
|
|
|
#include <linux/stddef.h>
|
|
#include <linux/perf_event.h>
|
|
#include <sys/types.h>
|
|
#include <stdio.h> // FILE
|
|
#include <stdbool.h>
|
|
#include <linux/bitmap.h>
|
|
#include <linux/types.h>
|
|
#include "env.h"
|
|
#include "pmu.h"
|
|
|
|
enum {
|
|
HEADER_RESERVED = 0, /* always cleared */
|
|
HEADER_FIRST_FEATURE = 1,
|
|
HEADER_TRACING_DATA = 1,
|
|
HEADER_BUILD_ID,
|
|
|
|
HEADER_HOSTNAME,
|
|
HEADER_OSRELEASE,
|
|
HEADER_VERSION,
|
|
HEADER_ARCH,
|
|
HEADER_NRCPUS,
|
|
HEADER_CPUDESC,
|
|
HEADER_CPUID,
|
|
HEADER_TOTAL_MEM,
|
|
HEADER_CMDLINE,
|
|
HEADER_EVENT_DESC,
|
|
HEADER_CPU_TOPOLOGY,
|
|
HEADER_NUMA_TOPOLOGY,
|
|
HEADER_BRANCH_STACK,
|
|
HEADER_PMU_MAPPINGS,
|
|
HEADER_GROUP_DESC,
|
|
HEADER_AUXTRACE,
|
|
HEADER_STAT,
|
|
HEADER_CACHE,
|
|
HEADER_SAMPLE_TIME,
|
|
HEADER_MEM_TOPOLOGY,
|
|
HEADER_CLOCKID,
|
|
HEADER_DIR_FORMAT,
|
|
HEADER_BPF_PROG_INFO,
|
|
HEADER_BPF_BTF,
|
|
HEADER_COMPRESSED,
|
|
HEADER_CPU_PMU_CAPS,
|
|
HEADER_CLOCK_DATA,
|
|
HEADER_HYBRID_TOPOLOGY,
|
|
HEADER_PMU_CAPS,
|
|
HEADER_LAST_FEATURE,
|
|
HEADER_FEAT_BITS = 256,
|
|
};
|
|
|
|
enum perf_header_version {
|
|
PERF_HEADER_VERSION_1,
|
|
PERF_HEADER_VERSION_2,
|
|
};
|
|
|
|
struct perf_file_section {
|
|
u64 offset;
|
|
u64 size;
|
|
};
|
|
|
|
struct perf_file_header {
|
|
u64 magic;
|
|
u64 size;
|
|
u64 attr_size;
|
|
struct perf_file_section attrs;
|
|
struct perf_file_section data;
|
|
/* event_types is ignored */
|
|
struct perf_file_section event_types;
|
|
DECLARE_BITMAP(adds_features, HEADER_FEAT_BITS);
|
|
};
|
|
|
|
struct perf_pipe_file_header {
|
|
u64 magic;
|
|
u64 size;
|
|
};
|
|
|
|
struct perf_header;
|
|
|
|
int perf_file_header__read(struct perf_file_header *header,
|
|
struct perf_header *ph, int fd);
|
|
|
|
struct perf_header {
|
|
enum perf_header_version version;
|
|
bool needs_swap;
|
|
u64 data_offset;
|
|
u64 data_size;
|
|
u64 feat_offset;
|
|
DECLARE_BITMAP(adds_features, HEADER_FEAT_BITS);
|
|
struct perf_env env;
|
|
};
|
|
|
|
struct feat_fd {
|
|
struct perf_header *ph;
|
|
int fd;
|
|
void *buf; /* Either buf != NULL or fd >= 0 */
|
|
ssize_t offset;
|
|
size_t size;
|
|
struct evsel *events;
|
|
};
|
|
|
|
struct perf_header_feature_ops {
|
|
int (*write)(struct feat_fd *ff, struct evlist *evlist);
|
|
void (*print)(struct feat_fd *ff, FILE *fp);
|
|
int (*process)(struct feat_fd *ff, void *data);
|
|
const char *name;
|
|
bool full_only;
|
|
bool synthesize;
|
|
};
|
|
|
|
struct evlist;
|
|
struct perf_session;
|
|
struct perf_tool;
|
|
union perf_event;
|
|
|
|
int perf_session__read_header(struct perf_session *session, int repipe_fd);
|
|
int perf_session__write_header(struct perf_session *session,
|
|
struct evlist *evlist,
|
|
int fd, bool at_exit);
|
|
int perf_header__write_pipe(int fd);
|
|
|
|
/* feat_writer writes a feature section to output */
|
|
struct feat_writer {
|
|
int (*write)(struct feat_writer *fw, void *buf, size_t sz);
|
|
};
|
|
|
|
/* feat_copier copies a feature section using feat_writer to output */
|
|
struct feat_copier {
|
|
int (*copy)(struct feat_copier *fc, int feat, struct feat_writer *fw);
|
|
};
|
|
|
|
int perf_session__inject_header(struct perf_session *session,
|
|
struct evlist *evlist,
|
|
int fd,
|
|
struct feat_copier *fc);
|
|
|
|
size_t perf_session__data_offset(const struct evlist *evlist);
|
|
|
|
void perf_header__set_feat(struct perf_header *header, int feat);
|
|
void perf_header__clear_feat(struct perf_header *header, int feat);
|
|
bool perf_header__has_feat(const struct perf_header *header, int feat);
|
|
|
|
int perf_header__set_cmdline(int argc, const char **argv);
|
|
|
|
int perf_header__process_sections(struct perf_header *header, int fd,
|
|
void *data,
|
|
int (*process)(struct perf_file_section *section,
|
|
struct perf_header *ph,
|
|
int feat, int fd, void *data));
|
|
|
|
int perf_header__fprintf_info(struct perf_session *s, FILE *fp, bool full);
|
|
|
|
int perf_event__process_feature(struct perf_session *session,
|
|
union perf_event *event);
|
|
int perf_event__process_attr(struct perf_tool *tool, union perf_event *event,
|
|
struct evlist **pevlist);
|
|
int perf_event__process_event_update(struct perf_tool *tool,
|
|
union perf_event *event,
|
|
struct evlist **pevlist);
|
|
size_t perf_event__fprintf_event_update(union perf_event *event, FILE *fp);
|
|
#ifdef HAVE_LIBTRACEEVENT
|
|
int perf_event__process_tracing_data(struct perf_session *session,
|
|
union perf_event *event);
|
|
#endif
|
|
int perf_event__process_build_id(struct perf_session *session,
|
|
union perf_event *event);
|
|
bool is_perf_magic(u64 magic);
|
|
|
|
#define NAME_ALIGN 64
|
|
|
|
struct feat_fd;
|
|
|
|
int do_write(struct feat_fd *fd, const void *buf, size_t size);
|
|
|
|
int write_padded(struct feat_fd *fd, const void *bf,
|
|
size_t count, size_t count_aligned);
|
|
|
|
int is_cpu_online(unsigned int cpu);
|
|
/*
|
|
* arch specific callback
|
|
*/
|
|
int get_cpuid(char *buffer, size_t sz);
|
|
|
|
char *get_cpuid_str(struct perf_pmu *pmu __maybe_unused);
|
|
int strcmp_cpuid_str(const char *s1, const char *s2);
|
|
#endif /* __PERF_HEADER_H */
|