提交 1945c3e7 编写于 作者: J Jiri Olsa 提交者: Arnaldo Carvalho de Melo

perf hists: Allocate output sort field

Currently we use static output fields, because we have single global
list of all sort/output fields.

We will add hists specific sort and output lists in following patches,
so we need all format entries to be dynamically allocated. Adding
support to allocate output sort field.
Signed-off-by: NJiri 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-10-git-send-email-jolsa@kernel.orgSigned-off-by: NArnaldo Carvalho de Melo <acme@redhat.com>
上级 3ee60c3b
...@@ -533,11 +533,23 @@ void perf_hpp__column_disable(unsigned col) ...@@ -533,11 +533,23 @@ void perf_hpp__column_disable(unsigned col)
void perf_hpp__cancel_cumulate(void) void perf_hpp__cancel_cumulate(void)
{ {
struct perf_hpp_fmt *fmt, *acc, *ovh, *tmp;
if (is_strict_order(field_order)) if (is_strict_order(field_order))
return; return;
perf_hpp__column_disable(PERF_HPP__OVERHEAD_ACC); ovh = &perf_hpp__format[PERF_HPP__OVERHEAD];
perf_hpp__format[PERF_HPP__OVERHEAD].name = "Overhead"; acc = &perf_hpp__format[PERF_HPP__OVERHEAD_ACC];
perf_hpp__for_each_format_safe(fmt, tmp) {
if (acc->equal(acc, fmt)) {
perf_hpp__column_unregister(fmt);
continue;
}
if (ovh->equal(ovh, fmt))
fmt->name = "Overhead";
}
} }
static bool fmt_equal(struct perf_hpp_fmt *a, struct perf_hpp_fmt *b) static bool fmt_equal(struct perf_hpp_fmt *a, struct perf_hpp_fmt *b)
......
...@@ -1577,6 +1577,19 @@ __sort_dimension__alloc_hpp(struct sort_dimension *sd) ...@@ -1577,6 +1577,19 @@ __sort_dimension__alloc_hpp(struct sort_dimension *sd)
return hse; return hse;
} }
static struct perf_hpp_fmt *__hpp_dimension__alloc_hpp(struct hpp_dimension *hd)
{
struct perf_hpp_fmt *fmt;
fmt = memdup(hd->fmt, sizeof(*fmt));
if (fmt) {
INIT_LIST_HEAD(&fmt->list);
INIT_LIST_HEAD(&fmt->sort_list);
}
return fmt;
}
static int __sort_dimension__add_hpp_sort(struct sort_dimension *sd) static int __sort_dimension__add_hpp_sort(struct sort_dimension *sd)
{ {
struct hpp_sort_entry *hse = __sort_dimension__alloc_hpp(sd); struct hpp_sort_entry *hse = __sort_dimension__alloc_hpp(sd);
...@@ -2066,11 +2079,17 @@ static int __sort_dimension__add(struct sort_dimension *sd) ...@@ -2066,11 +2079,17 @@ static int __sort_dimension__add(struct sort_dimension *sd)
static int __hpp_dimension__add(struct hpp_dimension *hd) static int __hpp_dimension__add(struct hpp_dimension *hd)
{ {
if (!hd->taken) { struct perf_hpp_fmt *fmt;
hd->taken = 1;
perf_hpp__register_sort_field(hd->fmt); if (hd->taken)
} return 0;
fmt = __hpp_dimension__alloc_hpp(hd);
if (!fmt)
return -1;
hd->taken = 1;
perf_hpp__register_sort_field(fmt);
return 0; return 0;
} }
...@@ -2088,11 +2107,17 @@ static int __sort_dimension__add_output(struct sort_dimension *sd) ...@@ -2088,11 +2107,17 @@ static int __sort_dimension__add_output(struct sort_dimension *sd)
static int __hpp_dimension__add_output(struct hpp_dimension *hd) static int __hpp_dimension__add_output(struct hpp_dimension *hd)
{ {
if (!hd->taken) { struct perf_hpp_fmt *fmt;
hd->taken = 1;
perf_hpp__column_register(hd->fmt); if (hd->taken)
} return 0;
fmt = __hpp_dimension__alloc_hpp(hd);
if (!fmt)
return -1;
hd->taken = 1;
perf_hpp__column_register(fmt);
return 0; return 0;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册