]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
libperf: Add PERF_RECORD_FORK 'struct fork_event' to perf/event.h
authorJiri Olsa <jolsa@kernel.org>
Sun, 25 Aug 2019 18:17:45 +0000 (20:17 +0200)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Mon, 26 Aug 2019 22:39:09 +0000 (19:39 -0300)
Move the fork_event event definition into libperf's event.h header
include.

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

Perf added 'u*' types mainly to ease up printing __u64 values
as stated in the linux/types.h comment:

  /*
   * We define u64 as uint64_t for every architecture
   * so that we can print it with "%"PRIx64 without getting warnings.
   *
   * typedef __u64 u64;
   * typedef __s64 s64;
   */

Add and use new PRI_lu64 and PRI_lx64 macros for that.  Using extra '_'
to ease up the reading and differentiate them from standard PRI*64
macros.

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/20190825181752.722-6-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/python.c

index b90a8a21e613c8f21e39947e8c7ea19000c3d6e9..c7cae58d25358ee228425cf1fd00b8d0b31f4502 100644 (file)
@@ -43,4 +43,11 @@ struct namespaces_event {
        struct perf_ns_link_info link_info[];
 };
 
+struct fork_event {
+       struct perf_event_header header;
+       __u32                    pid, ppid;
+       __u32                    tid, ptid;
+       __u64                    time;
+};
+
 #endif /* __LIBPERF_EVENT_H */
index 0d3ac4fd3ecf18c2e2760ac03f0de7e29b73c896..38b258cbbd906ea743a0ee7b170428475ced30b5 100644 (file)
 #define PRI_lx64 PRIx64
 #endif
 
-struct fork_event {
-       struct perf_event_header header;
-       u32 pid, ppid;
-       u32 tid, ptid;
-       u64 time;
-};
-
 struct lost_event {
        struct perf_event_header header;
        u64 id;
index 55ff0c3182d6c3069e7b71f15a29bcdba37ec96a..8bdadb24f6ba7ca675ac79da6b9e58e9bffb37e1 100644 (file)
@@ -170,7 +170,7 @@ static PyMemberDef pyrf_task_event__members[] = {
 static PyObject *pyrf_task_event__repr(struct pyrf_event *pevent)
 {
        return _PyUnicode_FromFormat("{ type: %s, pid: %u, ppid: %u, tid: %u, "
-                                  "ptid: %u, time: %" PRIu64 "}",
+                                  "ptid: %u, time: %" PRI_lu64 "}",
                                   pevent->event.header.type == PERF_RECORD_FORK ? "fork" : "exit",
                                   pevent->event.fork.pid,
                                   pevent->event.fork.ppid,