perf db-export: Export main_thread in db_export__sample()
authorAdrian Hunter <adrian.hunter@intel.com>
Wed, 10 Jul 2019 08:57:53 +0000 (11:57 +0300)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Wed, 10 Jul 2019 15:12:05 +0000 (12:12 -0300)
Export main_thread in db_export__sample() because it makes the code
easier to understand, and prepares db_export__thread() for further
simplification.

Signed-off-by: Adrian Hunter <adrian.hunter@intel.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Link: http://lkml.kernel.org/r/20190710085810.1650-5-adrian.hunter@intel.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/util/db-export.c

index 14501236c0469029dab02a662f64bda5b6f0be2d..63f9edf65eeef6e008be2ac6d3770cc3066db435 100644 (file)
@@ -71,16 +71,10 @@ int db_export__thread(struct db_export *dbe, struct thread *thread,
        thread->db_id = ++dbe->thread_last_db_id;
 
        if (main_thread) {
-               if (main_thread != thread) {
-                       err = db_export__thread(dbe, main_thread, machine,
-                                               comm, main_thread);
+               if (main_thread != thread && comm) {
+                       err = db_export__comm_thread(dbe, comm, thread);
                        if (err)
                                return err;
-                       if (comm) {
-                               err = db_export__comm_thread(dbe, comm, thread);
-                               if (err)
-                                       return err;
-                       }
                }
                main_thread_db_id = main_thread->db_id;
        }
@@ -308,12 +302,24 @@ int db_export__sample(struct db_export *dbe, union perf_event *event,
                return err;
 
        main_thread = thread__main_thread(al->machine, thread);
-       if (main_thread)
+       if (main_thread) {
                comm = machine__thread_exec_comm(al->machine, main_thread);
+               /*
+                * A thread has a reference to the main thread, so export the
+                * main thread first.
+                */
+               err = db_export__thread(dbe, main_thread, al->machine, comm,
+                                       main_thread);
+               if (err)
+                       goto out_put;
+       }
 
-       err = db_export__thread(dbe, thread, al->machine, comm, main_thread);
-       if (err)
-               goto out_put;
+       if (thread != main_thread) {
+               err = db_export__thread(dbe, thread, al->machine, comm,
+                                       main_thread);
+               if (err)
+                       goto out_put;
+       }
 
        if (comm) {
                err = db_export__exec_comm(dbe, comm, main_thread);