|
@@ -305,6 +305,11 @@ int pevent_register_comm(struct pevent *pevent, const char *comm, int pid)
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
+void pevent_register_trace_clock(struct pevent *pevent, char *trace_clock)
|
|
|
+{
|
|
|
+ pevent->trace_clock = trace_clock;
|
|
|
+}
|
|
|
+
|
|
|
struct func_map {
|
|
|
unsigned long long addr;
|
|
|
char *func;
|
|
@@ -4443,8 +4448,21 @@ void pevent_event_info(struct trace_seq *s, struct event_format *event,
|
|
|
trace_seq_terminate(s);
|
|
|
}
|
|
|
|
|
|
+static bool is_timestamp_in_us(char *trace_clock, bool use_trace_clock)
|
|
|
+{
|
|
|
+ if (!use_trace_clock)
|
|
|
+ return true;
|
|
|
+
|
|
|
+ if (!strcmp(trace_clock, "local") || !strcmp(trace_clock, "global")
|
|
|
+ || !strcmp(trace_clock, "uptime") || !strcmp(trace_clock, "perf"))
|
|
|
+ return true;
|
|
|
+
|
|
|
+ /* trace_clock is setting in tsc or counter mode */
|
|
|
+ return false;
|
|
|
+}
|
|
|
+
|
|
|
void pevent_print_event(struct pevent *pevent, struct trace_seq *s,
|
|
|
- struct pevent_record *record)
|
|
|
+ struct pevent_record *record, bool use_trace_clock)
|
|
|
{
|
|
|
static const char *spaces = " "; /* 20 spaces */
|
|
|
struct event_format *event;
|
|
@@ -4457,9 +4475,14 @@ void pevent_print_event(struct pevent *pevent, struct trace_seq *s,
|
|
|
int pid;
|
|
|
int len;
|
|
|
int p;
|
|
|
+ bool use_usec_format;
|
|
|
|
|
|
- secs = record->ts / NSECS_PER_SEC;
|
|
|
- nsecs = record->ts - secs * NSECS_PER_SEC;
|
|
|
+ use_usec_format = is_timestamp_in_us(pevent->trace_clock,
|
|
|
+ use_trace_clock);
|
|
|
+ if (use_usec_format) {
|
|
|
+ secs = record->ts / NSECS_PER_SEC;
|
|
|
+ nsecs = record->ts - secs * NSECS_PER_SEC;
|
|
|
+ }
|
|
|
|
|
|
if (record->size < 0) {
|
|
|
do_warning("ug! negative record size %d", record->size);
|
|
@@ -4484,15 +4507,20 @@ void pevent_print_event(struct pevent *pevent, struct trace_seq *s,
|
|
|
} else
|
|
|
trace_seq_printf(s, "%16s-%-5d [%03d]", comm, pid, record->cpu);
|
|
|
|
|
|
- if (pevent->flags & PEVENT_NSEC_OUTPUT) {
|
|
|
- usecs = nsecs;
|
|
|
- p = 9;
|
|
|
- } else {
|
|
|
- usecs = (nsecs + 500) / NSECS_PER_USEC;
|
|
|
- p = 6;
|
|
|
- }
|
|
|
+ if (use_usec_format) {
|
|
|
+ if (pevent->flags & PEVENT_NSEC_OUTPUT) {
|
|
|
+ usecs = nsecs;
|
|
|
+ p = 9;
|
|
|
+ } else {
|
|
|
+ usecs = (nsecs + 500) / NSECS_PER_USEC;
|
|
|
+ p = 6;
|
|
|
+ }
|
|
|
|
|
|
- trace_seq_printf(s, " %5lu.%0*lu: %s: ", secs, p, usecs, event->name);
|
|
|
+ trace_seq_printf(s, " %5lu.%0*lu: %s: ",
|
|
|
+ secs, p, usecs, event->name);
|
|
|
+ } else
|
|
|
+ trace_seq_printf(s, " %12llu: %s: ",
|
|
|
+ record->ts, event->name);
|
|
|
|
|
|
/* Space out the event names evenly. */
|
|
|
len = strlen(event->name);
|