]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
perf record: Synthesize unit/scale/... in event update
authorAndi Kleen <ak@linux.intel.com>
Fri, 17 Nov 2017 21:42:58 +0000 (13:42 -0800)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Wed, 29 Nov 2017 21:18:00 +0000 (18:18 -0300)
Move the code to synthesize event updates for scale/unit/cpus to a
common utility file, and use it both from stat and record.

This allows to access scale and other extra qualifiers from perf script.

Signed-off-by: Andi Kleen <ak@linux.intel.com>
Acked-by: Jiri Olsa <jolsa@kernel.org>
Link: http://lkml.kernel.org/r/20171117214300.32746-2-andi@firstfloor.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/builtin-record.c
tools/perf/builtin-stat.c
tools/perf/util/header.c
tools/perf/util/header.h

index 003255910c05df9104eafd2c012267c96523118b..b92d6d67bca8e93a6481308bee8fdf1ee0eeb9a8 100644 (file)
@@ -372,6 +372,8 @@ static int record__open(struct record *rec)
                        ui__error("%s\n", msg);
                        goto out;
                }
+
+               pos->supported = true;
        }
 
        if (perf_evlist__apply_filters(evlist, &pos)) {
@@ -784,6 +786,13 @@ static int record__synthesize(struct record *rec, bool tail)
                                         perf_event__synthesize_guest_os, tool);
        }
 
+       err = perf_event__synthesize_extra_attr(&rec->tool,
+                                               rec->evlist,
+                                               process_synthesized_event,
+                                               data->is_pipe);
+       if (err)
+               goto out;
+
        err = __machine__synthesize_threads(machine, tool, &opts->target, rec->evlist->threads,
                                            process_synthesized_event, opts->sample_address,
                                            opts->proc_map_timeout, 1);
index 59af5a8419e2be2c158753bf9d6a14ebd1089d76..a027b4712e486ae575d01198d6c8a05d8af04aac 100644 (file)
@@ -458,19 +458,8 @@ static void workload_exec_failed_signal(int signo __maybe_unused, siginfo_t *inf
        workload_exec_errno = info->si_value.sival_int;
 }
 
-static bool has_unit(struct perf_evsel *counter)
-{
-       return counter->unit && *counter->unit;
-}
-
-static bool has_scale(struct perf_evsel *counter)
-{
-       return counter->scale != 1;
-}
-
 static int perf_stat_synthesize_config(bool is_pipe)
 {
-       struct perf_evsel *counter;
        int err;
 
        if (is_pipe) {
@@ -482,53 +471,10 @@ static int perf_stat_synthesize_config(bool is_pipe)
                }
        }
 
-       /*
-        * Synthesize other events stuff not carried within
-        * attr event - unit, scale, name
-        */
-       evlist__for_each_entry(evsel_list, counter) {
-               if (!counter->supported)
-                       continue;
-
-               /*
-                * Synthesize unit and scale only if it's defined.
-                */
-               if (has_unit(counter)) {
-                       err = perf_event__synthesize_event_update_unit(NULL, counter, process_synthesized_event);
-                       if (err < 0) {
-                               pr_err("Couldn't synthesize evsel unit.\n");
-                               return err;
-                       }
-               }
-
-               if (has_scale(counter)) {
-                       err = perf_event__synthesize_event_update_scale(NULL, counter, process_synthesized_event);
-                       if (err < 0) {
-                               pr_err("Couldn't synthesize evsel scale.\n");
-                               return err;
-                       }
-               }
-
-               if (counter->own_cpus) {
-                       err = perf_event__synthesize_event_update_cpus(NULL, counter, process_synthesized_event);
-                       if (err < 0) {
-                               pr_err("Couldn't synthesize evsel scale.\n");
-                               return err;
-                       }
-               }
-
-               /*
-                * Name is needed only for pipe output,
-                * perf.data carries event names.
-                */
-               if (is_pipe) {
-                       err = perf_event__synthesize_event_update_name(NULL, counter, process_synthesized_event);
-                       if (err < 0) {
-                               pr_err("Couldn't synthesize evsel name.\n");
-                               return err;
-                       }
-               }
-       }
+       err = perf_event__synthesize_extra_attr(NULL,
+                                               evsel_list,
+                                               process_synthesized_event,
+                                               is_pipe);
 
        err = perf_event__synthesize_thread_map2(NULL, evsel_list->threads,
                                                process_synthesized_event,
index 7c0e9d587bfaf06f1aa74219cb8a01723ea63f20..5890e08e075439182c0471a65fa20994a19446a2 100644 (file)
@@ -3258,6 +3258,74 @@ int perf_event__synthesize_attrs(struct perf_tool *tool,
        return err;
 }
 
+static bool has_unit(struct perf_evsel *counter)
+{
+       return counter->unit && *counter->unit;
+}
+
+static bool has_scale(struct perf_evsel *counter)
+{
+       return counter->scale != 1;
+}
+
+int perf_event__synthesize_extra_attr(struct perf_tool *tool,
+                                     struct perf_evlist *evsel_list,
+                                     perf_event__handler_t process,
+                                     bool is_pipe)
+{
+       struct perf_evsel *counter;
+       int err;
+
+       /*
+        * Synthesize other events stuff not carried within
+        * attr event - unit, scale, name
+        */
+       evlist__for_each_entry(evsel_list, counter) {
+               if (!counter->supported)
+                       continue;
+
+               /*
+                * Synthesize unit and scale only if it's defined.
+                */
+               if (has_unit(counter)) {
+                       err = perf_event__synthesize_event_update_unit(tool, counter, process);
+                       if (err < 0) {
+                               pr_err("Couldn't synthesize evsel unit.\n");
+                               return err;
+                       }
+               }
+
+               if (has_scale(counter)) {
+                       err = perf_event__synthesize_event_update_scale(tool, counter, process);
+                       if (err < 0) {
+                               pr_err("Couldn't synthesize evsel counter.\n");
+                               return err;
+                       }
+               }
+
+               if (counter->own_cpus) {
+                       err = perf_event__synthesize_event_update_cpus(tool, counter, process);
+                       if (err < 0) {
+                               pr_err("Couldn't synthesize evsel cpus.\n");
+                               return err;
+                       }
+               }
+
+               /*
+                * Name is needed only for pipe output,
+                * perf.data carries event names.
+                */
+               if (is_pipe) {
+                       err = perf_event__synthesize_event_update_name(tool, counter, process);
+                       if (err < 0) {
+                               pr_err("Couldn't synthesize evsel name.\n");
+                               return err;
+                       }
+               }
+       }
+       return 0;
+}
+
 int perf_event__process_attr(struct perf_tool *tool __maybe_unused,
                             union perf_event *event,
                             struct perf_evlist **pevlist)
index 29ccbfdf87245136c227da56ca92f8f64650ef71..91befc3b550d825cb9eec0ded2cfc46490a64543 100644 (file)
@@ -107,6 +107,11 @@ int perf_event__synthesize_features(struct perf_tool *tool,
                                    struct perf_evlist *evlist,
                                    perf_event__handler_t process);
 
+int perf_event__synthesize_extra_attr(struct perf_tool *tool,
+                                     struct perf_evlist *evsel_list,
+                                     perf_event__handler_t process,
+                                     bool is_pipe);
+
 int perf_event__process_feature(struct perf_tool *tool,
                                union perf_event *event,
                                struct perf_session *session);