Kajol Jain <kj...@linux.ibm.com> writes: > hv_24x7 performance monitoring unit creates list of supported events > from the event catalog obtained via HCALL. hv_24x7 catalog could also > contain invalid or dummy events (with names like FREE_ or CPM_FREE_ so > on). These events does not have any hardware counters backing them. > So patch adds a check to string compare the event names to filter > out them. > > Signed-off-by: Kajol Jain <kj...@linux.ibm.com> > --- > arch/powerpc/perf/hv-24x7.c | 8 ++++++++ > 1 file changed, 8 insertions(+) > > diff --git a/arch/powerpc/perf/hv-24x7.c b/arch/powerpc/perf/hv-24x7.c > index 6e7e820508df..c3252d8a7818 100644 > --- a/arch/powerpc/perf/hv-24x7.c > +++ b/arch/powerpc/perf/hv-24x7.c > @@ -894,6 +894,11 @@ static int create_events_from_catalog(struct attribute > ***events_, > > name = event_name(event, &nl); > > + if (strstr(name, "FREE_")) { > + pr_info("invalid event %zu (%.*s)\n", event_idx, nl, > name); > + junk_events++; > + continue;
I don't think we want a print for each event, just one at the end saying "Dropped %d invalid events" would be preferable I think. > + } > if (event->event_group_record_len == 0) { > pr_devel("invalid event %zu (%.*s): group_record_len == > 0, skipping\n", > event_idx, nl, name); > @@ -955,6 +960,9 @@ static int create_events_from_catalog(struct attribute > ***events_, > continue; > > name = event_name(event, &nl); > + if (strstr(name, "FREE_")) > + continue; Would be nice if the string comparison was in a single place, ie. in a helper function. cheers