perf evsel: Fix order of event list deletion

We need to defer calling perf_evsel_list__delete() till after atexit
registered routines, because we need to traverse the events being
recorded at that time at least on 'perf record'.

This fixes the problem reported by Thomas Renninger where cmd_record
called by cmd_timechart would not write the tracing data to the perf.data
file header because the evsel_list at atexit (control+C on 'perf timechart
record') time would be empty, being already deleted by run_builtin(),
and thus 'perf timechart' when trying to process such perf.data file would
die with:

"no trace data in the file"

Problem introduced in 70d544d.

Reported-by: Thomas Renninger <trenn@suse.de>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Cc: Thomas Renninger <trenn@suse.de>
Cc: Tom Zanussi <tzanussi@gmail.com>
LKML-Reference: <new-submission>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>

+3 -2
+1
tools/perf/builtin-record.c
··· 480 480 process_buildids(); 481 481 perf_header__write(&session->header, output, true); 482 482 perf_session__delete(session); 483 + perf_evsel_list__delete(); 483 484 symbol__exit(); 484 485 } 485 486 }
+1
tools/perf/builtin-stat.c
··· 743 743 out_free_fd: 744 744 list_for_each_entry(pos, &evsel_list, node) 745 745 perf_evsel__free_stat_priv(pos); 746 + perf_evsel_list__delete(); 746 747 out: 747 748 thread_map__delete(threads); 748 749 threads = NULL;
+1
tools/perf/builtin-top.c
··· 1490 1490 out_free_fd: 1491 1491 list_for_each_entry(pos, &evsel_list, node) 1492 1492 perf_evsel__free_mmap(pos); 1493 + perf_evsel_list__delete(); 1493 1494 1494 1495 return status; 1495 1496 }
-2
tools/perf/perf.c
··· 286 286 status = p->fn(argc, argv, prefix); 287 287 exit_browser(status); 288 288 289 - perf_evsel_list__delete(); 290 - 291 289 if (status) 292 290 return status & 0xff; 293 291