Received: by 10.223.185.116 with SMTP id b49csp4757483wrg; Tue, 27 Feb 2018 02:00:53 -0800 (PST) X-Google-Smtp-Source: AH8x2276z6cKSMrC8LIZ4Yud2DY/p98nznNXiYShtkHW7Ha/8dzEjANewuyBwAqtDW6cJ+Gtqvkn X-Received: by 2002:a17:902:a610:: with SMTP id u16-v6mr13112757plq.293.1519725653172; Tue, 27 Feb 2018 02:00:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519725653; cv=none; d=google.com; s=arc-20160816; b=0LKwstV4jjeThBkAcjb2V7R4jOA6AI1ag3fF+nu/HtXUNonRjSqGGRKYojwKXdC8st 7LnG6iSSZLl0/EWIpPUZkblKqWg0FBkpZl7pcP0zxpmHl11S+9HJQW3TSlFzLz6WuP4v /thKG+P1EcQdkvA/b6z067Z7X43lmrZ162iNHlzoQBQI9OfsxxGmhvZkCihfmheTYC2w 9xWOWGoNWC7DVDejDI/4GQm4Z0KDvGViKJ5mC+YzD/JWCislBYy5Rli4aORU0oOdAI7Y LsdnCQ95tDk8EF2fAecvzCqbRogt0MfSeBReS903hFOy5LT9qrQCQsIq5h+OzZrVRSrv hYmQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:in-reply-to :mime-version:user-agent:date:message-id:from:cc:references:to :subject:arc-authentication-results; bh=10JbEq2wKWH+y6GkavTjTfuzLy/WmeBIHRX/in765NU=; b=qHS80gFirk/RW9a4lRYUSUsKWPPb9/0l7sLhqHLef86vYMV4Jq0TgZ+xEy+di12QmY qitOwmzR1nUCOzPV5vBcFsS8rF+u1RKA9pw3atIraS6mh34yw1x2JUOw4Wp0QsQL0rJZ ir0IrCk/VNY9R3iwAqZteJWekLbdOutBDzFpDAi5yy6U5Whl1YpmmDM0aNVlD8RNjGiV ADbK25fcg+f2ZtR3RE8Jv8KaEzULj0w1fTUUMRAOXPj/ybBxQOUP5b7QzNChv0eT2rQA bjMROXeJ9MN7ilPIBDBIR8Y6ON4s6FUxKNAytBJwSdylgyFJQO7trobmud2NDjiF4JKa pklg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c4si6825286pgn.347.2018.02.27.02.00.38; Tue, 27 Feb 2018 02:00:53 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752599AbeB0J7Y (ORCPT + 99 others); Tue, 27 Feb 2018 04:59:24 -0500 Received: from szxga06-in.huawei.com ([45.249.212.32]:42959 "EHLO huawei.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1752537AbeB0J7P (ORCPT ); Tue, 27 Feb 2018 04:59:15 -0500 Received: from DGGEMS410-HUB.china.huawei.com (unknown [172.30.72.58]) by Forcepoint Email with ESMTP id 39889E7263A73; Tue, 27 Feb 2018 17:59:01 +0800 (CST) Received: from [127.0.0.1] (10.202.227.238) by DGGEMS410-HUB.china.huawei.com (10.3.19.210) with Microsoft SMTP Server id 14.3.361.1; Tue, 27 Feb 2018 17:58:53 +0800 Subject: Re: [PATCH v2 07/11] perf vendor events: add support for arch standard events To: Jiri Olsa References: <1519401932-205051-1-git-send-email-john.garry@huawei.com> <1519401932-205051-8-git-send-email-john.garry@huawei.com> <20180227094848.GF21033@krava> CC: , , , , , , , , , , , , From: John Garry Message-ID: <0dcf5646-2e1d-db10-b15c-2d9439180771@huawei.com> Date: Tue, 27 Feb 2018 09:58:46 +0000 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:45.0) Gecko/20100101 Thunderbird/45.3.0 MIME-Version: 1.0 In-Reply-To: <20180227094848.GF21033@krava> Content-Type: text/plain; charset="windows-1252"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.202.227.238] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 27/02/2018 09:48, Jiri Olsa wrote: > On Sat, Feb 24, 2018 at 12:05:28AM +0800, John Garry wrote: > > SNIP > >> +static int save_arch_std_events(void *data, char *name, char *event, >> + char *desc, char *long_desc, char *pmu, >> + char *unit, char *perpkg, char *metric_expr, >> + char *metric_name, char *metric_group) >> +{ >> + struct event_struct *es; >> + struct stat *sb = data; >> + >> + es = malloc(sizeof(*es)); >> + if (!es) >> + return -ENOMEM; >> + memset(es, 0, sizeof(*es)); >> + FOR_ALL_EVENT_STRUCT_FIELDS(ADD_EVENT_FIELD); >> + list_add_tail(&es->list, &arch_std_events); >> + return 0; >> +out_free: >> + FOR_ALL_EVENT_STRUCT_FIELDS(FREE_EVENT_FIELD); >> + free(es); >> + return -ENOMEM; >> +} >> + >> static void print_events_table_suffix(FILE *outfp) >> { >> fprintf(outfp, "{\n"); >> @@ -391,6 +469,27 @@ static char *real_event(const char *name, char *event) >> return event; >> } >> >> +static int >> +try_fixup(const char *fn, char *arch_std, char **event, char **desc, >> + char **name, char **long_desc, char **pmu, char **filter, >> + char **perpkg, char **unit, char **metric_expr, char **metric_name, >> + char **metric_group) >> +{ >> + /* try to find matching event from arch standard values */ >> + struct event_struct *es; >> + >> + list_for_each_entry(es, &arch_std_events, list) { >> + if (!strcmp(arch_std, es->event+sizeof(EVENT_PREFIX))) { > > I spent some time figuring out how this can work when there's on '=' in EVENT_PREFIX > is this because sizeof returns +1 size for NULL char also? Right, sizeof(EVENT_PREFIX)=6 strlen(EVENT_PREFIX)=5 EVENT_PREFIX is "event" Thank you, John > > thanks, > jirka > > . >