diff --git a/tools/perf/util/evsel.c b/tools/perf/util/evsel.c index 40626e5fc1c080c44c03a3bb76a5e975fe4479b2..90f58cdd0fb088ac3e068160c2eb649f3c233263 100644 --- a/tools/perf/util/evsel.c +++ b/tools/perf/util/evsel.c @@ -681,6 +681,11 @@ void perf_evsel__config(struct perf_evsel *evsel, struct record_opts *opts) if (target__none(&opts->target) && perf_evsel__is_group_leader(evsel) && !opts->initial_delay) attr->enable_on_exec = 1; + + if (evsel->immediate) { + attr->disabled = 0; + attr->enable_on_exec = 0; + } } int perf_evsel__alloc_fd(struct perf_evsel *evsel, int ncpus, int nthreads) diff --git a/tools/perf/util/evsel.h b/tools/perf/util/evsel.h index 8dfec05bcec2dcbd70794a19ccf6a7aaaa7d1a40..d7f93ce0ebc12b33f542ec82d9d4f2d52ad9c661 100644 --- a/tools/perf/util/evsel.h +++ b/tools/perf/util/evsel.h @@ -84,6 +84,7 @@ struct perf_evsel { bool supported; bool needs_swap; bool no_aux_samples; + bool immediate; /* parse modifier helper */ int exclude_GH; int nr_members;