libperf: Add PERF_RECORD_STAT 'struct stat_event' to perf/event.h
authorJiri Olsa <jolsa@kernel.org>
Wed, 28 Aug 2019 13:57:10 +0000 (15:57 +0200)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Thu, 29 Aug 2019 11:36:12 +0000 (08:36 -0300)
Move the PERF_RECORD_STAT event definition to libperf's event.h.

In order to keep libperf simple, we switch 'u64/u32/u16/u8' types used
events to their generic '__u*' versions.

Signed-off-by: Jiri Olsa <jolsa@kernel.org>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Michael Petlan <mpetlan@redhat.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/20190828135717.7245-17-jolsa@kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/lib/include/perf/event.h
tools/perf/util/event.h
tools/perf/util/stat.c

index ba6ed243a31f2eb31b03046aa61dc3da0f44e5be..7d1834f558d65ce0686cd1af62de86f3fa7f76a2 100644 (file)
@@ -282,4 +282,21 @@ struct stat_config_event {
        struct stat_config_event_entry   data[];
 };
 
+struct stat_event {
+       struct perf_event_header header;
+
+       __u64                    id;
+       __u32                    cpu;
+       __u32                    thread;
+
+       union {
+               struct {
+                       __u64    val;
+                       __u64    ena;
+                       __u64    run;
+               };
+               __u64            values[3];
+       };
+};
+
 #endif /* __LIBPERF_EVENT_H */
index 68531d08dcec38800ddefa9836e0b6501efec8bc..f3a02e01852a92b8ad221d16b8d2300d01582f6e 100644 (file)
@@ -332,23 +332,6 @@ struct events_stats {
        u32 nr_proc_map_timeout;
 };
 
-struct stat_event {
-       struct perf_event_header        header;
-
-       u64     id;
-       u32     cpu;
-       u32     thread;
-
-       union {
-               struct {
-                       u64 val;
-                       u64 ena;
-                       u64 run;
-               };
-               u64 values[3];
-       };
-};
-
 enum {
        PERF_STAT_ROUND_TYPE__INTERVAL  = 0,
        PERF_STAT_ROUND_TYPE__FINAL     = 1,
index f985336b3a228b3d84beb64066de584d1f2ee593..c0cd9f9bb0ea4f50a35243ece479209e0c81ca09 100644 (file)
@@ -405,9 +405,9 @@ size_t perf_event__fprintf_stat(union perf_event *event, FILE *fp)
        struct stat_event *st = (struct stat_event *) event;
        size_t ret;
 
-       ret  = fprintf(fp, "\n... id %" PRIu64 ", cpu %d, thread %d\n",
+       ret  = fprintf(fp, "\n... id %" PRI_lu64 ", cpu %d, thread %d\n",
                       st->id, st->cpu, st->thread);
-       ret += fprintf(fp, "... value %" PRIu64 ", enabled %" PRIu64 ", running %" PRIu64 "\n",
+       ret += fprintf(fp, "... value %" PRI_lu64 ", enabled %" PRI_lu64 ", running %" PRI_lu64 "\n",
                       st->val, st->ena, st->run);
 
        return ret;