Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp9182934ybl; Fri, 17 Jan 2020 07:39:04 -0800 (PST) X-Google-Smtp-Source: APXvYqzCu8SqVkCubczEl0Vn7FLAqWhPF/BBVKH33Q4SLsep1LcYRAi++ZhNgthDL2DKsK+t+sou X-Received: by 2002:a9d:6b17:: with SMTP id g23mr6351978otp.265.1579275544092; Fri, 17 Jan 2020 07:39:04 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579275544; cv=none; d=google.com; s=arc-20160816; b=iK3V2TkedSiGIvB3j6vvfML9dyEbgbN2meCn0L8DAkFIJo7JTarVcDR5w0eH/P3rEe QKET3ALbnTVbsDkGrWdXDnlgMltTkMbdckQY5fMIN6JFl73PAxIrvyXRsJJ8Tge2AyM/ BK01IdShbuuo2FDYXTRayYXSwbMuGbyovyTeddkaTyAg/lWrwYYCs5en14WGIG/r4QjW CdM1RNJHaop0amiZXLnOhI244crvkwm0t4VAD7RS2k60EyHyrJxXII1IZC0pHftYa6h3 7f+eFcSLt2RHUN1Qydoj1zqtG96zwSjeRvFJhqcqi+nUp2UuXNA2uyoQShaJppyxfO9s xuOA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=pwBF42N8bOInUjU3mqsM9gMbAa/G/sJJUIKIesRfdeA=; b=qCYj4y7vSAQuA/hjLwlqytXLrufMlDWJt7A5oMwgMFBGvK4ROtAeASDeuMo7A2B3yf t34j3rGXDI+Zmk4tj5uR1vcUyeK2AcrnpI4r4PKbBr7+frbH1QqET9qp6LvYd/Y5tQ/+ dZfCzVrLtB97DOLjoOOt8TzLKinV9niBCbu5Cur7f8MLEyy3zKXJ66Fe4gdQHIXTaItv 2jEqNKF6H+9sgCN3pGKZReIVM+K8mR836w2Yu3bHByFsk+KNRVS1yLQbSefEhlJl/zNt snJe3y7s61LU5EFagaxi0XLfiTYJSSIzxPbALWllSUFW6jYen1cXIkmswzSb/YdA5VGu luvQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=dLz+DeXd; 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 u15si13429479oie.265.2020.01.17.07.38.50; Fri, 17 Jan 2020 07:39:04 -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=dLz+DeXd; 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 S1729014AbgAQPgp (ORCPT + 99 others); Fri, 17 Jan 2020 10:36:45 -0500 Received: from mail-pl1-f193.google.com ([209.85.214.193]:44089 "EHLO mail-pl1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728739AbgAQPgo (ORCPT ); Fri, 17 Jan 2020 10:36:44 -0500 Received: by mail-pl1-f193.google.com with SMTP id az3so9995693plb.11 for ; Fri, 17 Jan 2020 07:36:44 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=pwBF42N8bOInUjU3mqsM9gMbAa/G/sJJUIKIesRfdeA=; b=dLz+DeXdaoeUIACOt7xvx6JZ/KdgW4elO6F4OJiTi95bhZNv5d0fTi8sf2esjEeHve jrYJvTvtuTwk9455w9u6uWdHWVRnE2Jb+jmlZYKTHRxuESeUvLSApCr070QeGHnCUSHQ WMwSgYvTh9T6hzji33cRrFwCpRBljihZmZYy5U11TO1jyUAqzKJ6fCEHy8e3bV4O/wxR OAwCrbd7XqNaPEZBQQMj15F4sfT051R1jES7hQ/M3/UigVmN0OjjBXiLETRdBMmDnRnG nC8arJzl3mRUBtRUIpf67KeJ0HgjqXZk6xkCP6pgJgGauSqz4fetpCLJ3l5+GefWmOyv +nWg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=pwBF42N8bOInUjU3mqsM9gMbAa/G/sJJUIKIesRfdeA=; b=OxAoDB38gogQo/wUWfDX2NN/1/tFncRevQ3lwkzCfN3bV6dqHTccqaMPRKD/JLi49k iPYz4ANbipPQ0ZD4Og1VScZ1PqtKvM9a0A7s+G/WDmcqf8pzHFoCTUkXyhMcNMQK2uDP Yi6lOuGN6k7/mdX+BiIaSve4Zz69AahdScLhjRO9Vn9iua9JwEup4S+7KdhijXdfnqZO xs/bOi3t7zeVt95eLymDTZRSXcLjkbNWAYnzMjmAe7KW0XzJzjz8AR+vvzgMhRcNdAQt CspeciuUrTot+yd7dTnkCmmCy46hx9dF+qOAjYB5D8gKT7eo5HM8KBJ6x/8wKOjF+dxr KE9g== X-Gm-Message-State: APjAAAVkmaMjllFRzH9W2q3Am+d6VvFQZ0mxl3a/NQaG1RSxbctAauNd O0tPKscBWO4cLe84KKGvlbwPPQ== X-Received: by 2002:a17:90a:330c:: with SMTP id m12mr6335610pjb.18.1579275403850; Fri, 17 Jan 2020 07:36:43 -0800 (PST) Received: from leoy-ThinkPad-X240s (li96-55.members.linode.com. [74.207.254.55]) by smtp.gmail.com with ESMTPSA id b15sm29770249pft.58.2020.01.17.07.36.37 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Fri, 17 Jan 2020 07:36:43 -0800 (PST) Date: Fri, 17 Jan 2020 23:36:30 +0800 From: Leo Yan To: Arnaldo Carvalho de Melo Cc: Mathieu Poirier , Suzuki K Poulose , Peter Zijlstra , Ingo Molnar , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Ian Rogers , Andi Kleen , Adrian Hunter , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Mike Leach Subject: Re: [PATCH v6 2/2] perf parse: Copy string to perf_evsel_config_term Message-ID: <20200117153630.GA22019@leoy-ThinkPad-X240s> References: <20200117055251.24058-1-leo.yan@linaro.org> <20200117055251.24058-2-leo.yan@linaro.org> <20200117133409.GB3323@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200117133409.GB3323@redhat.com> User-Agent: Mutt/1.9.4 (2018-02-28) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Jan 17, 2020 at 10:34:09AM -0300, Arnaldo Carvalho de Melo wrote: > Em Fri, Jan 17, 2020 at 01:52:51PM +0800, Leo Yan escreveu: > > perf with CoreSight fails to record trace data with command: > > > > perf record -e cs_etm/@tmc_etr0/u --per-thread ls > > failed to set sink "" on event cs_etm/@tmc_etr0/u with 21 (Is a > > directory)/perf/ > > > > This failure is root caused with the commit 1dc925568f01 ("perf > > parse: Add a deep delete for parse event terms"). > > > > The log shows, cs_etm fails to parse the sink attribution; cs_etm event > > relies on the event configuration to pass sink name, but the event > > specific configuration data cannot be passed properly with flow: > > > > get_config_terms() > > ADD_CONFIG_TERM(DRV_CFG, term->val.str); > > __t->val.str = term->val.str; > > `> __t->val.str is assigned to term->val.str; > > > > parse_events_terms__purge() > > parse_events_term__delete() > > zfree(&term->val.str); > > `> term->val.str is freed and assigned to NULL pointer; > > > > cs_etm_set_sink_attr() > > sink = __t->val.str; > > `> sink string has been freed. > > > > To fix this issue, in the function get_config_terms(), this patch > > changes to use strdup() for allocation a new duplicate string rather > > than directly assignment string pointer. > > > > This patch addes a new field 'free_str' in the data structure > > perf_evsel_config_term; 'free_str' is set to true when the union is used > > as a string pointer; thus it can tell perf_evsel__free_config_terms() to > > free the string. > > > > Fixes: 1dc925568f01 ("perf parse: Add a deep delete for parse event terms") > > Suggested-by: Jiri Olsa > > Signed-off-by: Leo Yan > > Acked-by: Jiri Olsa > > --- > > tools/perf/util/evsel.c | 2 ++ > > tools/perf/util/evsel_config.h | 1 + > > tools/perf/util/parse-events.c | 7 ++++++- > > 3 files changed, 9 insertions(+), 1 deletion(-) > > > > diff --git a/tools/perf/util/evsel.c b/tools/perf/util/evsel.c > > index 549abd43816f..6fe9e28180e5 100644 > > --- a/tools/perf/util/evsel.c > > +++ b/tools/perf/util/evsel.c > > @@ -1265,6 +1265,8 @@ static void perf_evsel__free_config_terms(struct evsel *evsel) > > > > list_for_each_entry_safe(term, h, &evsel->config_terms, list) { > > list_del_init(&term->list); > > + if (term->free_str) > > + free(term->val.str); > > I'm replacing this with zfree, so that we can catch possible bugs where > term gets used after freed, just like you do below, in ADD_CONFIG_TERM_STR() Thanks a lot, Arnaldo. > > free(term); > > } > > } > > diff --git a/tools/perf/util/evsel_config.h b/tools/perf/util/evsel_config.h > > index b4a65201e4f7..e026ab67b008 100644 > > --- a/tools/perf/util/evsel_config.h > > +++ b/tools/perf/util/evsel_config.h > > @@ -32,6 +32,7 @@ enum evsel_term_type { > > struct perf_evsel_config_term { > > struct list_head list; > > enum evsel_term_type type; > > + bool free_str; > > union { > > u64 period; > > u64 freq; > > diff --git a/tools/perf/util/parse-events.c b/tools/perf/util/parse-events.c > > index f59f3c8da473..c01ba6f8fdad 100644 > > --- a/tools/perf/util/parse-events.c > > +++ b/tools/perf/util/parse-events.c > > @@ -1240,7 +1240,12 @@ do { \ > > #define ADD_CONFIG_TERM_STR(__type, __val) \ > > do { \ > > ADD_CONFIG_TERM(__type); \ > > - __t->val.str = __val; \ > > + __t->val.str = strdup(__val); \ > > + if (!__t->val.str) { \ > > + zfree(&__t); \ > > + return -ENOMEM; \ > > + } \ > > + __t->free_str = true; \ > > } while (0) > > > > struct parse_events_term *term; > > -- > > 2.17.1 >