summaryrefslogtreecommitdiffstats
path: root/tools/perf/util/parse-events.c
diff options
context:
space:
mode:
authorArnaldo Carvalho de Melo <acme@redhat.com>2016-02-12 16:43:02 -0300
committerArnaldo Carvalho de Melo <acme@redhat.com>2016-02-12 16:53:19 -0300
commitfc0a2c1d59beac70b8738f4ce14431b798837374 (patch)
treebb829db727497c244ca5eb259478a27a4c6a4b0a /tools/perf/util/parse-events.c
parenta8adfceb389a0045e06af22517fa3326797b160a (diff)
downloadlinux-fc0a2c1d59beac70b8738f4ce14431b798837374.tar.gz
linux-fc0a2c1d59beac70b8738f4ce14431b798837374.tar.bz2
linux-fc0a2c1d59beac70b8738f4ce14431b798837374.zip
perf tools: Introduce parse_events_terms__purge()
Purges 'struct parse_event_term' entries from a list_head. Some users need this because they don't allocate space for the list head, it maybe on the stack or embedded into some other struct. Next patch will convert users that need just purging and then the perf_events__free_terms() routine will free the list head as well, finally being renamed to perf_events_terms__delete(). Acked-by: Jiri Olsa <jolsa@kernel.org> Cc: Alexei Starovoitov <ast@kernel.org> Cc: He Kuang <hekuang@huawei.com> Cc: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Wang Nan <wangnan0@huawei.com> Cc: Zefan Li <lizefan@huawei.com> Cc: pi3orama@163.com Link: http://lkml.kernel.org/n/tip-4w3zl4ifcl0ed0j4bu3tckqp@git.kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util/parse-events.c')
-rw-r--r--tools/perf/util/parse-events.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/tools/perf/util/parse-events.c b/tools/perf/util/parse-events.c
index 133c8d28f36c..668afdccfcca 100644
--- a/tools/perf/util/parse-events.c
+++ b/tools/perf/util/parse-events.c
@@ -2068,7 +2068,7 @@ int parse_events_term__clone(struct parse_events_term **new,
term->err_term, term->err_val);
}
-void parse_events__free_terms(struct list_head *terms)
+void parse_events_terms__purge(struct list_head *terms)
{
struct parse_events_term *term, *h;
@@ -2078,6 +2078,11 @@ void parse_events__free_terms(struct list_head *terms)
}
}
+void parse_events__free_terms(struct list_head *terms)
+{
+ parse_events_terms__purge(terms);
+}
+
void parse_events_evlist_error(struct parse_events_evlist *data,
int idx, const char *str)
{