[PATCH v2 5/7] perf tools: add perf_evlist__terminate() for terminate
From: James Clark <hidden>
Date: 2020-01-23 16:08:37
Also in:
linux-perf-users, lkml
Subsystem:
performance events subsystem, the rest · Maintainers:
Peter Zijlstra, Ingo Molnar, Arnaldo Carvalho de Melo, Namhyung Kim, Linus Torvalds
From: Wei Li <redacted> In __cmd_record(), when receiving SIGINT(ctrl + c), a done flag will be set and the event list will be disabled by perf_evlist__disable() once. While in auxtrace_record.read_finish(), the related events will be enabled again, if they are continuous, the recording seems to be endless. Mark the evlist's state as terminated, preparing for the following fix. Signed-off-by: Wei Li <redacted> Tested-by: Qi Liu <redacted> Signed-off-by: James Clark <redacted> Cc: Will Deacon <will@kernel.org> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Ingo Molnar <mingo@redhat.com> Cc: Arnaldo Carvalho de Melo <acme@kernel.org> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Jiri Olsa <redacted> Cc: Tan Xiaojun <redacted> Cc: Al Grant <redacted> Cc: Namhyung Kim <namhyung@kernel.org> --- tools/perf/builtin-record.c | 1 + tools/perf/util/evlist.c | 14 ++++++++++++++ tools/perf/util/evlist.h | 1 + tools/perf/util/evsel.h | 1 + 4 files changed, 17 insertions(+)
diff --git a/tools/perf/builtin-record.c b/tools/perf/builtin-record.c
index 4c301466101b..e7c917f9534d 100644
--- a/tools/perf/builtin-record.c
+++ b/tools/perf/builtin-record.c@@ -1722,6 +1722,7 @@ static int __cmd_record(struct record *rec, int argc, const char **argv) if (done && !disabled && !target__none(&opts->target)) { trigger_off(&auxtrace_snapshot_trigger); evlist__disable(rec->evlist); + evlist__terminate(rec->evlist); disabled = true; } }
diff --git a/tools/perf/util/evlist.c b/tools/perf/util/evlist.c
index b9c7e5271611..b04794cd8586 100644
--- a/tools/perf/util/evlist.c
+++ b/tools/perf/util/evlist.c@@ -377,6 +377,20 @@ bool evsel__cpu_iter_skip(struct evsel *ev, int cpu) return true; } +void evlist__terminate(struct evlist *evlist) +{ + struct evsel *pos; + + evlist__for_each_entry(evlist, pos) { + if (pos->disabled || !perf_evsel__is_group_leader(pos) || !pos->core.fd) + continue; + evsel__disable(pos); + pos->terminated = true; + } + + evlist->enabled = false; +} + void evlist__disable(struct evlist *evlist) { struct evsel *pos;
diff --git a/tools/perf/util/evlist.h b/tools/perf/util/evlist.h
index f5bd5c386df1..9fbd0ce2a1c4 100644
--- a/tools/perf/util/evlist.h
+++ b/tools/perf/util/evlist.h@@ -206,6 +206,7 @@ void evlist__munmap(struct evlist *evlist); size_t evlist__mmap_size(unsigned long pages); +void evlist__terminate(struct evlist *evlist); void evlist__disable(struct evlist *evlist); void evlist__enable(struct evlist *evlist); void perf_evlist__toggle_enable(struct evlist *evlist);
diff --git a/tools/perf/util/evsel.h b/tools/perf/util/evsel.h
index dc14f4a823cd..8e8a2cb41de8 100644
--- a/tools/perf/util/evsel.h
+++ b/tools/perf/util/evsel.h@@ -104,6 +104,7 @@ struct evsel { perf_evsel__sb_cb_t *cb; void *data; } side_band; + bool terminated; }; struct perf_missing_features {
--
2.25.0
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel