Re: [PATCH] tools/perf/metricgroup: Fix printing event names of metric group with multiple events incase of overlapping events

From: Jiri Olsa
Date: Wed Jan 08 2020 - 11:03:02 EST


On Wed, Jan 08, 2020 at 02:41:35PM +0530, kajoljain wrote:

SNIP

> > > -    int i = 0;
> > > +    int i = 0, j = 0;
> > >       bool leader_found;
> > >         evlist__for_each_entry (perf_evlist, ev) {
> > > +        j++;
> > > +        if (j <= iterator_perf_evlist)
> > > +            continue;
> > >           if (!strcmp(ev->name, ids[i])) {
> > >               if (!metric_events[i])
> > >                   metric_events[i] = ev;
> > > @@ -146,6 +151,7 @@ static struct evsel *find_evsel_group(struct
> > > evlist *perf_evlist,
> > >               }
> > >           }
> > >       }
> > > +    iterator_perf_evlist = j;
> > >         return metric_events[0];
> > >   }
> > >
> >
> > Thanks for reporting and fixing this issue.
> >
> > I just have one question, do we really need a *static variable* to track
> > the matched events? Perhaps using an input parameter?
>
> Hi Jin,
>
> The other way I come up with to solve this issue is, making change in
> perf_evlist itself by adding some flag in event name, to keep track of
> matched events.
>
> As if we change event name itself, next time when we compare it won't
> matched. But in that case we need to remove those flag later. Which will
> increase the
>
> complexity. If you have any suggestions, please let me know.

we already keep evsel::cpu_iter for similar concept

so I guess we could have some iterator_perf_evlist variable in evlist..
that is if we don't find other solution (other than static varable)

thanks,
jirka