[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <8bf65f0c-d4cf-8c69-15b3-961ce4f3cd2f@huawei.com>
Date: Mon, 10 Feb 2020 15:47:08 +0000
From: John Garry <john.garry@...wei.com>
To: Jiri Olsa <jolsa@...hat.com>
CC: <peterz@...radead.org>, <mingo@...hat.com>, <acme@...nel.org>,
<mark.rutland@....com>, <alexander.shishkin@...ux.intel.com>,
<namhyung@...nel.org>, <will@...nel.org>, <ak@...ux.intel.com>,
<linuxarm@...wei.com>, <linux-kernel@...r.kernel.org>,
<linux-arm-kernel@...ts.infradead.org>, <suzuki.poulose@....com>,
<james.clark@....com>, <zhangshaokun@...ilicon.com>,
<robin.murphy@....com>
Subject: Re: [PATCH RFC 1/7] perf jevents: Add support for an extra directory
level
On 10/02/2020 12:07, Jiri Olsa wrote:
> On Fri, Jan 24, 2020 at 10:34:59PM +0800, John Garry wrote:
>> Currently we support upto a level 2 directory, and level 2 would be in the
>> form vendor/platform.
>>
>> Add support for a further level, to hold specific categories of events for
>> when we want to segregate them for matching purposes.
>>
>> Signed-off-by: John Garry <john.garry@...wei.com>
>> ---
>> tools/perf/pmu-events/jevents.c | 11 ++++++++---
>> 1 file changed, 8 insertions(+), 3 deletions(-)
>>
>> diff --git a/tools/perf/pmu-events/jevents.c b/tools/perf/pmu-events/jevents.c
>> index 079c77b6a2fd..8af05b94a37d 100644
>> --- a/tools/perf/pmu-events/jevents.c
>> +++ b/tools/perf/pmu-events/jevents.c
>> @@ -960,15 +960,20 @@ static int process_one_file(const char *fpath, const struct stat *sb,
>> int level = ftwbuf->level;
>> int err = 0;
>>
>> - if (level == 2 && is_dir) {
>> + if (level >= 2 && is_dir) {
>> + int count = 0;
>> /*
>> * For level 2 directory, bname will include parent name,
>> * like vendor/platform. So search back from platform dir
>> * to find this.
>> + * Something similar for level 3 directory, but we're a PMU
>> + * category folder, like vendor/platform/cpu.
>> */
>> bname = (char *) fpath + ftwbuf->base - 2;
>> for (;;) {
>> if (*bname == '/')
>> + count++;
>> + if (count == level - 1)
>> break;
>> bname--;
>
Hi Jirka,
> I was wondering why we just don't use different filename for that,
> but it's true that the code transforms directory chain to the table
> name.. so I guess another directory level is justified ;-)
Yes, and we need to have separate tables for system and CPU/uncore PMU
aliases.
Thanks,
John
>
> jirka
>
>
>> }
>> @@ -981,13 +986,13 @@ static int process_one_file(const char *fpath, const struct stat *sb,
>> level, sb->st_size, bname, fpath);
>>
>> /* base dir or too deep */
>> - if (level == 0 || level > 3)
>> + if (level == 0 || level > 4)
>> return 0;
>>
>>
>> /* model directory, reset topic */
>> if ((level == 1 && is_dir && is_leaf_dir(fpath)) ||
>> - (level == 2 && is_dir)) {
>> + (level >= 2 && is_dir && is_leaf_dir(fpath))) {
>> if (close_table)
>> print_events_table_suffix(eventsfp);
>>
>> --
>> 2.17.1
>>
>
> .
>
Powered by blists - more mailing lists