@@ -973,6 +973,8 @@ perf_evlist__channel_for_evsel(struct perf_evsel *evsel)
if (evsel->overwrite)
flag |= PERF_EVLIST__CHANNEL_RDONLY;
+ if (evsel->tailsize)
+ flag |= PERF_EVLIST__CHANNEL_TAILSIZE;
return flag;
}
@@ -24,6 +24,7 @@ struct record_opts;
enum perf_evlist_mmap_flag {
PERF_EVLIST__CHANNEL_ENABLED = 1,
PERF_EVLIST__CHANNEL_RDONLY = 2,
+ PERF_EVLIST__CHANNEL_TAILSIZE = 4,
};
/**
@@ -671,13 +671,33 @@ static void apply_config_terms(struct perf_evsel *evsel,
attr->inherit = term->val.inherit ? 1 : 0;
break;
case PERF_EVSEL__CONFIG_TERM_OVERWRITE:
+ /*
+ * Let tailsize and overwrite controled by /overwrite/
+ * semultaneously because /overwrite/ can only be
+ * passed by user explicitly, in this case user should
+ * be able to read from that event so tailsize must
+ * set.
+ *
+ * (overwrite && !tailsize) can happen only when
+ * perf_evlist__mmap() is called with overwrite == true.
+ * In that case there's no chance to pass /overwrite/.
+ */
evsel->overwrite = term->val.overwrite ? 1 : 0;
+ evsel->tailsize = term->val.overwrite ? 1 : 0;
break;
default:
break;
}
}
+ /*
+ * Set tailsize sample bit after config term processing because
+ * it is possible to set overwrite globally, without config
+ * terms.
+ */
+ if (evsel->tailsize)
+ perf_evsel__set_sample_bit(evsel, TAILSIZE);
+
/* User explicitly set per-event callgraph, clear the old setting and reset. */
if ((callgraph_buf != NULL) || (dump_size > 0)) {
@@ -748,7 +768,15 @@ void perf_evsel__config(struct perf_evsel *evsel, struct record_opts *opts)
attr->sample_id_all = perf_missing_features.sample_id_all ? 0 : 1;
attr->inherit = !opts->no_inherit;
+
+ /*
+ * opts->overwrite can be set by user only.
+ * Always keeps evsel->overwrite == evsel->tailsize.
+ * (evsel->overwrite && !evsel->tailsize) can only happen
+ * when calling perf_evlist__mmap() with overwrite == true.
+ */
evsel->overwrite = opts->overwrite;
+ evsel->tailsize = opts->overwrite;
perf_evsel__set_sample_bit(evsel, IP);
perf_evsel__set_sample_bit(evsel, TID);
@@ -118,6 +118,7 @@ struct perf_evsel {
bool per_pkg;
bool precise_max;
bool overwrite;
+ bool tailsize;
/* parse modifier helper */
int exclude_GH;
int nr_members;