> On 2017/10/12 20:56, Liang, Kan wrote: > >> On 2017/10/11 21:16, Liang, Kan wrote: > >>>> perf record's --overwrite option doesn't work as we expect. > >>>> For example: > >> [SNIP] > >> > >>>> In the above example we get same records from the backward ring > >>>> buffer all the time. Overwriting is not triggered. > >>>> > >>>> This commit maps backward ring buffers readonly, make it overwritable. > >>>> It is safe because we assume backward ring buffer always overwritable > >>>> in other part of code. > >>>> > >>>> After applying this patch: > >>>> > >>>> $ ~/linux/tools/perf$ sudo ./perf record -m 4 -e raw_syscalls:* > >>>> -g -- overwrite \ > >>>> --switch-output=1s --tail-synthesize dd > >>>> if=/dev/zero of=/dev/null > >> [SNIP] > >> > >>>> > >>>> Signed-off-by: Wang Nan <wangn...@huawei.com> > >>>> Cc: Liang Kan <kan.li...@intel.com> > >>>> Cc: Arnaldo Carvalho de Melo <a...@kernel.org> > >>>> Cc: Peter Zijlstra <pet...@infradead.org> > >>>> Cc: Ingo Molnar <mi...@kernel.org> > >>>> Cc: Jiri Olsa <jo...@kernel.org> > >>>> Cc: Namhyung Kim <namhy...@kernel.org> > >>>> Cc: Alexander Shishkin <alexander.shish...@linux.intel.com> > >>>> Cc: Adrian Hunter <adrian.hun...@intel.com> > >>>> Cc: Andi Kleen <a...@linux.intel.com> > >>>> Cc: Li Zefan <lize...@huawei.com> > >>>> --- > >>>> tools/perf/util/evlist.c | 7 ++++++- > >>>> 1 file changed, 6 insertions(+), 1 deletion(-) > >>>> > >>>> diff --git a/tools/perf/util/evlist.c b/tools/perf/util/evlist.c > >>>> index c6c891e..a86b0d2 100644 > >>>> --- a/tools/perf/util/evlist.c > >>>> +++ b/tools/perf/util/evlist.c > >>>> @@ -799,12 +799,14 @@ perf_evlist__should_poll(struct perf_evlist > >>>> *evlist __maybe_unused, > >>>> } > >>>> > >>>> static int perf_evlist__mmap_per_evsel(struct perf_evlist *evlist, int > idx, > >>>> - struct mmap_params *mp, int > >>>> cpu_idx, > >>>> + struct mmap_params *_mp, int > >>>> cpu_idx, > >>>> int thread, int *_output, int > >>>> *_output_backward) > >>>> { > >>>> struct perf_evsel *evsel; > >>>> int revent; > >>>> int evlist_cpu = cpu_map__cpu(evlist->cpus, cpu_idx); > >>>> + struct mmap_params *mp = _mp; > >>>> + struct mmap_params backward_mp; > >>>> > >>>> evlist__for_each_entry(evlist, evsel) { > >>>> struct perf_mmap *maps = evlist->mmap; @@ -815,6 +817,9 > >> @@ static > >>>> int perf_evlist__mmap_per_evsel(struct > >>>> perf_evlist *evlist, int idx, > >>>> if (evsel->attr.write_backward) { > >>>> output = _output_backward; > >>>> maps = evlist->backward_mmap; > >>>> + backward_mp = *mp; > >>>> + backward_mp.prot &= ~PROT_WRITE; > >>>> + mp = &backward_mp; > >>>> > >>>> if (!maps) { > >>>> maps = perf_evlist__alloc_mmap(evlist); > >>> So it's trying to support per-event overwrite. > >>> How about the global --overwrite option? > >> Not only the per-event overwrite. See the example above. The overall -- > >> overwrite option is also respected. In perf_evsel__config, per-event evsel > >> 'backward' setting is set based on overall '--overwrite' and per-event > >> '/overwrite/' setting. > > But how about evlist->overwrite? I think it still keeps the wrong setting. > > The overwrite is implicitly applied. Some settings are inconsistent. > > > > Is there any drawback if you use opts->overwrite for > perf_evlist__mmap_ex? > > We will always face such inconsistency, because we have > an /no-overwrite/ option which can be set per-evsel. > Setting evlist->overwrite won't make things more consistent, > because in a evlist, different evsel can have different > overwrite setting. A simple solution is making evlist > non-overwrite by default, and watch all overwrite evsels > a special cases. Then we have only 2 cases to consider: > > 1. overwrite evsel in a non-overwrite evlist. > 2. non-overwrite evsel in a non-overwrite evlist. >
If evlist->overwrite is always non-overwrite, why not remove it? > If we reset evlist->overwrite according to --overwrite, we > will have 4 cases to consider: > > 1. overwrite evsel in a overwrite evlist. > 2. non-overwrite evsel in a overwrite evlist. > 3. overwrite evsel in a non-overwrite evlist. > 4. non-overwrite evsel in a non-overwrite evlist. > > The real problem is: there's 'overwrite' and 'backward' > concepts in our code, but these two concepts are neither > independent nor identical. > > Thank you. > > > > Thanks, > > Kan > >>> I think we should use opts->overwrite to replace the hard code 'false' > >>> for perf_evlist__mmap_ex as well. > >>> > >>> Thanks, > >>> Kan >