All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] perf: fix core dump
@ 2010-08-24  7:07 jovi zhang
  2010-08-24 12:25 ` Arnaldo Carvalho de Melo
  0 siblings, 1 reply; 2+ messages in thread
From: jovi zhang @ 2010-08-24  7:07 UTC (permalink / raw)
  To: a.p.zijlstra, paulus, mingo, acme; +Cc: linux-kernel

Perf invoke symbol__init function twice when we input command "perf
kmem/sched record ls", then it will core dump when symbol__exit
invoked.
So give a flag to make symbol__init can be invoked once.

Signed-off-by: Jovi Zhang <bookjovi@gmail.com>
tools/perf/util/symbol.c |    9 +++++++++
1 files changed, 9 insertions(+), 0 deletions(-)
diff --git a/tools/perf/util/symbol.c b/tools/perf/util/symbol.c
index 1a36773..aded121 100644
--- a/tools/perf/util/symbol.c
+++ b/tools/perf/util/symbol.c
@@ -43,6 +43,8 @@ struct symbol_conf symbol_conf = {
       .try_vmlinux_path = true,
};

+static bool symbol_initizated;
+
int dso__name_len(const struct dso *self)
{
       if (verbose)
@@ -2268,6 +2270,11 @@ static int setup_list(struct strlist **list,
const char *list_str,

int symbol__init(void)
{
+       if (symbol_initizated == true)
+               return 0;
+       else
+               symbol_initizated = true;
+
       elf_version(EV_CURRENT);
       if (symbol_conf.sort_by_name)
               symbol_conf.priv_size += (sizeof(struct symbol_name_rb_node) -
@@ -2304,6 +2311,8 @@ out_free_comm_list:

void symbol__exit(void)
{
+       if (symbol_initizated == false)
+               return;
       strlist__delete(symbol_conf.sym_list);
       strlist__delete(symbol_conf.dso_list);
       strlist__delete(symbol_conf.comm_list);

^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [PATCH] perf: fix core dump
  2010-08-24  7:07 [PATCH] perf: fix core dump jovi zhang
@ 2010-08-24 12:25 ` Arnaldo Carvalho de Melo
  0 siblings, 0 replies; 2+ messages in thread
From: Arnaldo Carvalho de Melo @ 2010-08-24 12:25 UTC (permalink / raw)
  To: jovi zhang; +Cc: a.p.zijlstra, paulus, mingo, linux-kernel

Em Tue, Aug 24, 2010 at 03:07:33PM +0800, jovi zhang escreveu:
> Perf invoke symbol__init function twice when we input command "perf
> kmem/sched record ls", then it will core dump when symbol__exit
> invoked.
> So give a flag to make symbol__init can be invoked once.

Yeah, this fixes the problem, and I'll apply this patch, but I think
that the elegant solution is to adopt one more kernel construct, i.e.
__init markings :)

Thanks!

- Arnaldo
 
> Signed-off-by: Jovi Zhang <bookjovi@gmail.com>
> tools/perf/util/symbol.c |    9 +++++++++
> 1 files changed, 9 insertions(+), 0 deletions(-)
> diff --git a/tools/perf/util/symbol.c b/tools/perf/util/symbol.c
> index 1a36773..aded121 100644
> --- a/tools/perf/util/symbol.c
> +++ b/tools/perf/util/symbol.c
> @@ -43,6 +43,8 @@ struct symbol_conf symbol_conf = {
>        .try_vmlinux_path = true,
> };
> 
> +static bool symbol_initizated;
> +
> int dso__name_len(const struct dso *self)
> {
>        if (verbose)
> @@ -2268,6 +2270,11 @@ static int setup_list(struct strlist **list,
> const char *list_str,
> 
> int symbol__init(void)
> {
> +       if (symbol_initizated == true)
> +               return 0;
> +       else
> +               symbol_initizated = true;
> +
>        elf_version(EV_CURRENT);
>        if (symbol_conf.sort_by_name)
>                symbol_conf.priv_size += (sizeof(struct symbol_name_rb_node) -
> @@ -2304,6 +2311,8 @@ out_free_comm_list:
> 
> void symbol__exit(void)
> {
> +       if (symbol_initizated == false)
> +               return;
>        strlist__delete(symbol_conf.sym_list);
>        strlist__delete(symbol_conf.dso_list);
>        strlist__delete(symbol_conf.comm_list);

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2010-08-24 12:25 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2010-08-24  7:07 [PATCH] perf: fix core dump jovi zhang
2010-08-24 12:25 ` Arnaldo Carvalho de Melo

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.