From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752134AbdAaMXW (ORCPT ); Tue, 31 Jan 2017 07:23:22 -0500 Received: from mail.kernel.org ([198.145.29.136]:50840 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751929AbdAaMWF (ORCPT ); Tue, 31 Jan 2017 07:22:05 -0500 Date: Tue, 31 Jan 2017 09:21:16 -0300 From: Arnaldo Carvalho de Melo To: Taeung Song Cc: linux-kernel@vger.kernel.org, Jiri Olsa , Namhyung Kim , Ingo Molnar , Peter Zijlstra , Wang Nan , Steven Rostedt , Frederic Weisbecker Subject: Re: [PATCH v2 1/4] perf tools: Create for_each_event macro for tracepoints iteration Message-ID: <20170131122116.GA4491@kernel.org> References: <1485862711-20216-1-git-send-email-treeze.taeung@gmail.com> <1485862711-20216-2-git-send-email-treeze.taeung@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1485862711-20216-2-git-send-email-treeze.taeung@gmail.com> X-Url: http://acmel.wordpress.com User-Agent: Mutt/1.7.1 (2016-10-04) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Em Tue, Jan 31, 2017 at 08:38:28PM +0900, Taeung Song escreveu: > Such as for_each_subsystem and for_each_event in util/parse-events.c, > add new macros 'for_each_event' for easy iteration over the tracepoints > in order to be more compact and readable. Looks ok, applied, but look below for some minor suggestions. - Arnaldo > Cc: Steven Rostedt > Cc: Frederic Weisbecker > Cc: Jiri Olsa > Cc: Namhyung Kim > Signed-off-by: Taeung Song > --- > tools/perf/util/trace-event-info.c | 38 ++++++++++++++++++-------------------- > 1 file changed, 18 insertions(+), 20 deletions(-) > > diff --git a/tools/perf/util/trace-event-info.c b/tools/perf/util/trace-event-info.c > index ceb0e27..fb6d95d 100644 > --- a/tools/perf/util/trace-event-info.c > +++ b/tools/perf/util/trace-event-info.c > @@ -170,6 +170,12 @@ static bool name_in_tp_list(char *sys, struct tracepoint_path *tps) > return false; > } > > +#define for_each_event(dir, dent, tps) \ > + while ((dent = readdir(dir))) \ > + if (dent->d_type == DT_DIR && \ > + (strcmp(dent->d_name, ".")) && \ > + (strcmp(dent->d_name, ".."))) \ > + > static int copy_event_system(const char *sys, struct tracepoint_path *tps) > { > struct dirent *dent; > @@ -186,12 +192,10 @@ static int copy_event_system(const char *sys, struct tracepoint_path *tps) > return -errno; > } > > - while ((dent = readdir(dir))) { > - if (dent->d_type != DT_DIR || > - strcmp(dent->d_name, ".") == 0 || > - strcmp(dent->d_name, "..") == 0 || > - !name_in_tp_list(dent->d_name, tps)) > + for_each_event(dir, dent, tps) { > + if (!name_in_tp_list(dent->d_name, tps)) > continue; > + > if (asprintf(&format, "%s/%s/format", sys, dent->d_name) < 0) { > err = -ENOMEM; > goto out; > @@ -210,12 +214,10 @@ static int copy_event_system(const char *sys, struct tracepoint_path *tps) > } > > rewinddir(dir); > - while ((dent = readdir(dir))) { > - if (dent->d_type != DT_DIR || > - strcmp(dent->d_name, ".") == 0 || > - strcmp(dent->d_name, "..") == 0 || > - !name_in_tp_list(dent->d_name, tps)) > + for_each_event(dir, dent, tps) { > + if (!name_in_tp_list(dent->d_name, tps)) > continue; > + > if (asprintf(&format, "%s/%s/format", sys, dent->d_name) < 0) { > err = -ENOMEM; > goto out; > @@ -290,13 +292,11 @@ static int record_event_files(struct tracepoint_path *tps) > goto out; > } > > - while ((dent = readdir(dir))) { > - if (dent->d_type != DT_DIR || > - strcmp(dent->d_name, ".") == 0 || > - strcmp(dent->d_name, "..") == 0 || > - strcmp(dent->d_name, "ftrace") == 0 || > + for_each_event(dir, dent, tps) { > + if (!strcmp(dent->d_name, "ftrace") || the existing style was == 0, you switched it to !, equivalent, but gratuitous, keeping the existing style would make reviewing slightly faster, as the pattern wouldn't have changed. > !system_in_tp_list(dent->d_name, tps)) > continue; > + > count++; > } > > @@ -307,13 +307,11 @@ static int record_event_files(struct tracepoint_path *tps) > } > > rewinddir(dir); > - while ((dent = readdir(dir))) { > - if (dent->d_type != DT_DIR || > - strcmp(dent->d_name, ".") == 0 || > - strcmp(dent->d_name, "..") == 0 || > - strcmp(dent->d_name, "ftrace") == 0 || > + for_each_event(dir, dent, tps) { > + if (!strcmp(dent->d_name, "ftrace") || Ditto. > !system_in_tp_list(dent->d_name, tps)) > continue; > + > if (asprintf(&sys, "%s/%s", path, dent->d_name) < 0) { > err = -ENOMEM; > goto out; > -- > 2.7.4