From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755197Ab2K2O7E (ORCPT ); Thu, 29 Nov 2012 09:59:04 -0500 Received: from mail-da0-f46.google.com ([209.85.210.46]:53873 "EHLO mail-da0-f46.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754935Ab2K2O7C (ORCPT ); Thu, 29 Nov 2012 09:59:02 -0500 Subject: Re: [PATCH 03/18] perf tools: Keep group information From: Namhyung Kim To: Jiri Olsa Cc: Arnaldo Carvalho de Melo , Peter Zijlstra , Paul Mackerras , Ingo Molnar , LKML , Stephane Eranian , Andi Kleen , Namhyung Kim In-Reply-To: <20121129143303.GJ1096@krava.brq.redhat.com> References: <1354171126-14387-1-git-send-email-namhyung@kernel.org> <1354171126-14387-5-git-send-email-namhyung@kernel.org> <20121129143303.GJ1096@krava.brq.redhat.com> Content-Type: text/plain; charset="UTF-8" Date: Thu, 29 Nov 2012 23:58:54 +0900 Message-ID: <1354201134.1630.41.camel@leonhard> Mime-Version: 1.0 X-Mailer: Evolution 2.28.3 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 2012-11-29 (목), 15:33 +0100, Jiri Olsa: > On Thu, Nov 29, 2012 at 03:38:31PM +0900, Namhyung Kim wrote: > > From: Namhyung Kim > > SNIP > > > --- a/tools/perf/util/evlist.h > > +++ b/tools/perf/util/evlist.h > > @@ -21,6 +21,7 @@ struct perf_evlist { > > struct list_head entries; > > struct hlist_head heads[PERF_EVLIST__HLIST_SIZE]; > > int nr_entries; > > + int nr_groups; > > int nr_fds; > > int nr_mmaps; > > int mmap_len; > > diff --git a/tools/perf/util/evsel.h b/tools/perf/util/evsel.h > > index 46c8004ca56b..887834ed0af1 100644 > > --- a/tools/perf/util/evsel.h > > +++ b/tools/perf/util/evsel.h > > @@ -73,6 +73,7 @@ struct perf_evsel { > > bool needs_swap; > > /* parse modifier helper */ > > int exclude_GH; > > + int nr_members; > > struct perf_evsel *leader; > > char *group_name; > > }; > > we could test both new fields in existing group tests > > > @@ -230,4 +231,9 @@ static inline bool perf_evsel__is_group_leader(const struct perf_evsel *evsel) > > { > > return evsel->leader == evsel; > You mean adding 'evsel->nr_members > 1' to this function? For some reason, I'd like to treat non-group events as group leaders so I dropped that check from the function. > SNIP > > > { > > struct list_head *list = $3; > > + struct parse_events_data__events *data = _data; > > + > > + /* Count groups only have more than 1 members */ > > + if (!list_is_last(list->next, list)) > > + data->nr_groups++; > > > > parse_events__set_leader($1, list); > > $$ = list; > > @@ -130,6 +135,11 @@ PE_NAME '{' events '}' > > '{' events '}' > > { > > struct list_head *list = $2; > > + struct parse_events_data__events *data = _data; > > + > > + /* Count groups only have more than 1 members */ > > + if (!list_is_last(list->next, list)) > > + data->nr_groups++; > > nitpick.. maybe add a function for above 3 lines? > > You could add static function right after ABORT_ON > macro definition. No problem. Will do. Thanks, Namhyung