Commit 7a1799e0 authored by Jiri Olsa's avatar Jiri Olsa Committed by Arnaldo Carvalho de Melo

perf hists: Introduce perf_hpp_list__for_each_format_safe macro

Introducing perf_hpp_list__for_each_format_safe macro to iterate
perf_hpp_list object's output entries safely.
Signed-off-by: default avatarJiri Olsa <jolsa@kernel.org>
Cc: David Ahern <dsahern@gmail.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Link: http://lkml.kernel.org/r/1453109064-1026-21-git-send-email-jolsa@kernel.orgSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent cf094045
...@@ -532,7 +532,7 @@ void perf_hpp__cancel_cumulate(void) ...@@ -532,7 +532,7 @@ void perf_hpp__cancel_cumulate(void)
ovh = &perf_hpp__format[PERF_HPP__OVERHEAD]; ovh = &perf_hpp__format[PERF_HPP__OVERHEAD];
acc = &perf_hpp__format[PERF_HPP__OVERHEAD_ACC]; acc = &perf_hpp__format[PERF_HPP__OVERHEAD_ACC];
perf_hpp__for_each_format_safe(fmt, tmp) { perf_hpp_list__for_each_format_safe(&perf_hpp_list, fmt, tmp) {
if (acc->equal(acc, fmt)) { if (acc->equal(acc, fmt)) {
perf_hpp__column_unregister(fmt); perf_hpp__column_unregister(fmt);
continue; continue;
...@@ -597,7 +597,7 @@ void perf_hpp__reset_output_field(void) ...@@ -597,7 +597,7 @@ void perf_hpp__reset_output_field(void)
struct perf_hpp_fmt *fmt, *tmp; struct perf_hpp_fmt *fmt, *tmp;
/* reset output fields */ /* reset output fields */
perf_hpp__for_each_format_safe(fmt, tmp) { perf_hpp_list__for_each_format_safe(&perf_hpp_list, fmt, tmp) {
list_del_init(&fmt->list); list_del_init(&fmt->list);
list_del_init(&fmt->sort_list); list_del_init(&fmt->sort_list);
fmt_free(fmt); fmt_free(fmt);
......
...@@ -251,8 +251,8 @@ static inline void perf_hpp__register_sort_field(struct perf_hpp_fmt *format) ...@@ -251,8 +251,8 @@ static inline void perf_hpp__register_sort_field(struct perf_hpp_fmt *format)
#define perf_hpp_list__for_each_format(_list, format) \ #define perf_hpp_list__for_each_format(_list, format) \
list_for_each_entry(format, &(_list)->fields, list) list_for_each_entry(format, &(_list)->fields, list)
#define perf_hpp__for_each_format_safe(format, tmp) \ #define perf_hpp_list__for_each_format_safe(_list, format, tmp) \
list_for_each_entry_safe(format, tmp, &perf_hpp_list.fields, list) list_for_each_entry_safe(format, tmp, &(_list)->fields, list)
#define perf_hpp__for_each_sort_list(format) \ #define perf_hpp__for_each_sort_list(format) \
list_for_each_entry(format, &perf_hpp_list.sorts, sort_list) list_for_each_entry(format, &perf_hpp_list.sorts, sort_list)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment