Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp4174592ybl; Mon, 13 Jan 2020 09:05:55 -0800 (PST) X-Google-Smtp-Source: APXvYqwD4cf7vEEME5k6pQ9ePDP0uMy0r/ms9bfkiVcUSvZViBNrfWzVf2onZuyK/S447sQWROeJ X-Received: by 2002:a9d:6d8f:: with SMTP id x15mr13808284otp.322.1578935155570; Mon, 13 Jan 2020 09:05:55 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578935155; cv=none; d=google.com; s=arc-20160816; b=p96runexEYNGZsPiX7tsHoa486o+3D7Wp04iawn3kWJWg3rV0Vibxv8QPE2uCZUt08 U9L7orMJAQpfgdpSofI+mzZJIAsbaNH8feR7lGOnWyu6qxvl966I+rDXCUEAJkILdqNm +iv3R+VDPqcrewz5tRhgJnKQZ6V0odkhJcWjKlNIxzB01D6TJOTUq/8e5J9CpAWb1azj 2m0Mfk+NLNE6DVyIV+zApl2F6Moz5XShCD/wc3c15N7yM5xCCh0oW3/2AeZ5UAtuQ8VC X0FLV9d1o08C33HvTRUEalIJwqSAXxGbbkuWhVRwbydU5Ut3N+UfLUIZmENy4ROckn9M qS9w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=vCYLCPHiRWh6ksrtGlcqhC567jMXoyBRG7FIiY46P9k=; b=Zsn3f04kOvrP1E7JdE9PsVHfTMbmLqfyv7kW1mAksgsOa17yKZm5biihLDZJP7s4fw kB4z2fC69faDY+fyA8uOiEHgzFYvhEPXiVEQSzcZ6/K1cZvKi64lBtqxErxTtQ4ViSxP k2YQO/P16k/XtqIEX899sMCJm11h0ye2vOA+i5uDwICHtye3tx7bHtt3D/cLpReuQ2Z3 fypCUgdI/jaTwk8IMS70ztfaYPH2SpyBMH4CA+0RA6H406g6wIZzVGjK0E+6vS2Y+/pg XBvSgEC76y5fDZF1xTOvGVmJvGxK5YpDFmP6KsFd/yFN7+tbC+Pu/4G8E4mnPg5UMyIp 96OA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b="s0GhKBL/"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i65si6519579oif.15.2020.01.13.09.05.42; Mon, 13 Jan 2020 09:05:55 -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; dkim=pass header.i=@linaro.org header.s=google header.b="s0GhKBL/"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728709AbgAMRE1 (ORCPT + 99 others); Mon, 13 Jan 2020 12:04:27 -0500 Received: from mail-qv1-f68.google.com ([209.85.219.68]:45079 "EHLO mail-qv1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728621AbgAMRE1 (ORCPT ); Mon, 13 Jan 2020 12:04:27 -0500 Received: by mail-qv1-f68.google.com with SMTP id l14so4305919qvu.12 for ; Mon, 13 Jan 2020 09:04:26 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=vCYLCPHiRWh6ksrtGlcqhC567jMXoyBRG7FIiY46P9k=; b=s0GhKBL/eF9yyr9CWYHpUMvzHi9fizQhOAARow+yAPqgt8vBE9aOUzsqbT4FQrZuLu imSq2jgq9heHVhbQUxdAaaq8d/P1WdtU2dDO6NTrckuskK3im1fO6VVukIeCmsqBLWbZ t6wuYJGMz3bCNezQKeHS0GBRGz7qg7NVHOiVQmiDVIJF9TVCugOxiFeJ9AFlBRRnZw7a ZQlnS28kS+dA1tlYVKb143Z/vvnhdJex/UFD14xhHzocUcpukUxtebi9L5HQ+vtW5M3D kbxDYbCpFVeo83NLv2dei7UcxCs8n/yZxkFeWetWcS2TijAkSN/kToe0TeQ9CgYL1s1g CWIg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=vCYLCPHiRWh6ksrtGlcqhC567jMXoyBRG7FIiY46P9k=; b=RaU2ngqNo8/LyWjikXFND/NgonL4H5/dj8crNmgdtFYH8laTn33fOH2cFYU8QnXXA5 8CYvaHrfqoK2oNjJztguseZSXqVd4QGfFxEW2Rp2bAIWBWNESrVEkDrcWiFBLELMunDD XrgxxnRJqqrLN5BQL9ZRrhRiwkUp3WukbLIjYuZUXC0uiae+BDw9azX4OWH2LQZorAWA nQc/yiBXdW9JSGj/uHqKwRkbfnDQUVF6f32LS4gsfa/SeLysJ2JWVJaN2+mxIJh6mlu1 1/PPW0PePh13ACbLomCPKhwv7ycgqnvCRaAVW+t3EiIKEmWnaqACCCwqE87k9TGeu68A KIbQ== X-Gm-Message-State: APjAAAVooscQsAI8DEJ81u6yh/T90MNnAc2rCpRcYk6ZRrq2p23Uc6K/ rOMTYTWA74ZbD+iiEVb8zU0HAMUtszJMowdLTKsElw== X-Received: by 2002:ad4:5614:: with SMTP id ca20mr12569770qvb.43.1578935065414; Mon, 13 Jan 2020 09:04:25 -0800 (PST) MIME-Version: 1.0 References: <20200113151806.17854-1-leo.yan@linaro.org> In-Reply-To: <20200113151806.17854-1-leo.yan@linaro.org> From: Mathieu Poirier Date: Mon, 13 Jan 2020 10:04:14 -0700 Message-ID: Subject: Re: [PATCH v5 1/2] perf parse: Refactor struct perf_evsel_config_term To: Leo Yan Cc: Arnaldo Carvalho de Melo , Suzuki K Poulose , Jiri Olsa , Peter Zijlstra , Ingo Molnar , Mark Rutland , Alexander Shishkin , Namhyung Kim , Ian Rogers , Andi Kleen , Adrian Hunter , linux-arm-kernel , Linux Kernel Mailing List Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 13 Jan 2020 at 08:18, Leo Yan wrote: > > The struct perf_evsel_config_term::val is a union which contains > fields 'callgraph', 'drv_cfg' and 'branch' as string pointers. This > leads to the complex code logic for handling every type's string > separately, and it's hard to release string as a general way. > > This patch refactors the structure to add a common field 'str' in the > 'val' union as string pointer and remove the other three fields > 'callgraph', 'drv_cfg' and 'branch'. Without passing field name, the > patch simplifies the string handling with macro ADD_CONFIG_TERM_STR() > for string pointer assignment. > > Signed-off-by: Leo Yan > --- > tools/perf/arch/arm/util/cs-etm.c | 2 +- > tools/perf/util/evsel.c | 6 ++-- > tools/perf/util/evsel_config.h | 4 +-- > tools/perf/util/parse-events.c | 53 ++++++++++++++++++------------- > 4 files changed, 36 insertions(+), 29 deletions(-) > > diff --git a/tools/perf/arch/arm/util/cs-etm.c b/tools/perf/arch/arm/util/cs-etm.c > index ede040cf82ad..2898cfdf8fe1 100644 > --- a/tools/perf/arch/arm/util/cs-etm.c > +++ b/tools/perf/arch/arm/util/cs-etm.c > @@ -226,7 +226,7 @@ static int cs_etm_set_sink_attr(struct perf_pmu *pmu, > if (term->type != PERF_EVSEL__CONFIG_TERM_DRV_CFG) > continue; > > - sink = term->val.drv_cfg; > + sink = term->val.str; > snprintf(path, PATH_MAX, "sinks/%s", sink); > > ret = perf_pmu__scan_file(pmu, path, "%x", &hash); > diff --git a/tools/perf/util/evsel.c b/tools/perf/util/evsel.c > index a69e64236120..549abd43816f 100644 > --- a/tools/perf/util/evsel.c > +++ b/tools/perf/util/evsel.c > @@ -808,12 +808,12 @@ static void apply_config_terms(struct evsel *evsel, > perf_evsel__reset_sample_bit(evsel, TIME); > break; > case PERF_EVSEL__CONFIG_TERM_CALLGRAPH: > - callgraph_buf = term->val.callgraph; > + callgraph_buf = term->val.str; > break; > case PERF_EVSEL__CONFIG_TERM_BRANCH: > - if (term->val.branch && strcmp(term->val.branch, "no")) { > + if (term->val.str && strcmp(term->val.str, "no")) { > perf_evsel__set_sample_bit(evsel, BRANCH_STACK); > - parse_branch_str(term->val.branch, > + parse_branch_str(term->val.str, > &attr->branch_sample_type); > } else > perf_evsel__reset_sample_bit(evsel, BRANCH_STACK); > diff --git a/tools/perf/util/evsel_config.h b/tools/perf/util/evsel_config.h > index 1f8d2fe0b66e..b4a65201e4f7 100644 > --- a/tools/perf/util/evsel_config.h > +++ b/tools/perf/util/evsel_config.h > @@ -36,18 +36,16 @@ struct perf_evsel_config_term { > u64 period; > u64 freq; > bool time; > - char *callgraph; > - char *drv_cfg; > u64 stack_user; > int max_stack; > bool inherit; > bool overwrite; > - char *branch; > unsigned long max_events; > bool percore; > bool aux_output; > u32 aux_sample_size; > u64 cfg_chg; > + char *str; > } val; > bool weak; > }; > diff --git a/tools/perf/util/parse-events.c b/tools/perf/util/parse-events.c > index ed7c008b9c8b..64b394519a4c 100644 > --- a/tools/perf/util/parse-events.c > +++ b/tools/perf/util/parse-events.c > @@ -1219,8 +1219,7 @@ static int config_attr(struct perf_event_attr *attr, > static int get_config_terms(struct list_head *head_config, > struct list_head *head_terms __maybe_unused) > { > -#define ADD_CONFIG_TERM(__type, __name, __val) \ > -do { \ > +#define ADD_CONFIG_TERM(__type) \ > struct perf_evsel_config_term *__t; \ > \ > __t = zalloc(sizeof(*__t)); \ > @@ -1229,9 +1228,19 @@ do { \ > \ > INIT_LIST_HEAD(&__t->list); \ > __t->type = PERF_EVSEL__CONFIG_TERM_ ## __type; \ > - __t->val.__name = __val; \ > __t->weak = term->weak; \ > - list_add_tail(&__t->list, head_terms); \ > + list_add_tail(&__t->list, head_terms) > + > +#define ADD_CONFIG_TERM_VAL(__type, __name, __val) \ > +do { \ > + ADD_CONFIG_TERM(__type); \ > + __t->val.__name = __val; \ > +} while (0) > + > +#define ADD_CONFIG_TERM_STR(__type, __val) \ > +do { \ > + ADD_CONFIG_TERM(__type); \ > + __t->val.str = __val; \ > } while (0) > > struct parse_events_term *term; > @@ -1239,53 +1248,53 @@ do { \ > list_for_each_entry(term, head_config, list) { > switch (term->type_term) { > case PARSE_EVENTS__TERM_TYPE_SAMPLE_PERIOD: > - ADD_CONFIG_TERM(PERIOD, period, term->val.num); > + ADD_CONFIG_TERM_VAL(PERIOD, period, term->val.num); > break; > case PARSE_EVENTS__TERM_TYPE_SAMPLE_FREQ: > - ADD_CONFIG_TERM(FREQ, freq, term->val.num); > + ADD_CONFIG_TERM_VAL(FREQ, freq, term->val.num); > break; > case PARSE_EVENTS__TERM_TYPE_TIME: > - ADD_CONFIG_TERM(TIME, time, term->val.num); > + ADD_CONFIG_TERM_VAL(TIME, time, term->val.num); > break; > case PARSE_EVENTS__TERM_TYPE_CALLGRAPH: > - ADD_CONFIG_TERM(CALLGRAPH, callgraph, term->val.str); > + ADD_CONFIG_TERM_STR(CALLGRAPH, term->val.str); > break; > case PARSE_EVENTS__TERM_TYPE_BRANCH_SAMPLE_TYPE: > - ADD_CONFIG_TERM(BRANCH, branch, term->val.str); > + ADD_CONFIG_TERM_STR(BRANCH, term->val.str); > break; > case PARSE_EVENTS__TERM_TYPE_STACKSIZE: > - ADD_CONFIG_TERM(STACK_USER, stack_user, term->val.num); > + ADD_CONFIG_TERM_VAL(STACK_USER, stack_user, term->val.num); > break; > case PARSE_EVENTS__TERM_TYPE_INHERIT: > - ADD_CONFIG_TERM(INHERIT, inherit, term->val.num ? 1 : 0); > + ADD_CONFIG_TERM_VAL(INHERIT, inherit, term->val.num ? 1 : 0); > break; > case PARSE_EVENTS__TERM_TYPE_NOINHERIT: > - ADD_CONFIG_TERM(INHERIT, inherit, term->val.num ? 0 : 1); > + ADD_CONFIG_TERM_VAL(INHERIT, inherit, term->val.num ? 0 : 1); > break; > case PARSE_EVENTS__TERM_TYPE_MAX_STACK: > - ADD_CONFIG_TERM(MAX_STACK, max_stack, term->val.num); > + ADD_CONFIG_TERM_VAL(MAX_STACK, max_stack, term->val.num); > break; > case PARSE_EVENTS__TERM_TYPE_MAX_EVENTS: > - ADD_CONFIG_TERM(MAX_EVENTS, max_events, term->val.num); > + ADD_CONFIG_TERM_VAL(MAX_EVENTS, max_events, term->val.num); > break; > case PARSE_EVENTS__TERM_TYPE_OVERWRITE: > - ADD_CONFIG_TERM(OVERWRITE, overwrite, term->val.num ? 1 : 0); > + ADD_CONFIG_TERM_VAL(OVERWRITE, overwrite, term->val.num ? 1 : 0); > break; > case PARSE_EVENTS__TERM_TYPE_NOOVERWRITE: > - ADD_CONFIG_TERM(OVERWRITE, overwrite, term->val.num ? 0 : 1); > + ADD_CONFIG_TERM_VAL(OVERWRITE, overwrite, term->val.num ? 0 : 1); > break; > case PARSE_EVENTS__TERM_TYPE_DRV_CFG: > - ADD_CONFIG_TERM(DRV_CFG, drv_cfg, term->val.str); > + ADD_CONFIG_TERM_STR(DRV_CFG, term->val.str); > break; > case PARSE_EVENTS__TERM_TYPE_PERCORE: > - ADD_CONFIG_TERM(PERCORE, percore, > - term->val.num ? true : false); > + ADD_CONFIG_TERM_VAL(PERCORE, percore, > + term->val.num ? true : false); > break; > case PARSE_EVENTS__TERM_TYPE_AUX_OUTPUT: > - ADD_CONFIG_TERM(AUX_OUTPUT, aux_output, term->val.num ? 1 : 0); > + ADD_CONFIG_TERM_VAL(AUX_OUTPUT, aux_output, term->val.num ? 1 : 0); > break; > case PARSE_EVENTS__TERM_TYPE_AUX_SAMPLE_SIZE: > - ADD_CONFIG_TERM(AUX_SAMPLE_SIZE, aux_sample_size, term->val.num); > + ADD_CONFIG_TERM_VAL(AUX_SAMPLE_SIZE, aux_sample_size, term->val.num); > break; > default: > break; > @@ -1322,7 +1331,7 @@ static int get_config_chgs(struct perf_pmu *pmu, struct list_head *head_config, > } > > if (bits) > - ADD_CONFIG_TERM(CFG_CHG, cfg_chg, bits); > + ADD_CONFIG_TERM_VAL(CFG_CHG, cfg_chg, bits); > > #undef ADD_CONFIG_TERM > return 0; There are checkpatch warnings - please address them. Mathieu > -- > 2.17.1 >