Commit 60cb19b4 authored by Namhyung Kim's avatar Namhyung Kim Committed by Arnaldo Carvalho de Melo

perf dwarf-aux: Factor out die_get_typename_from_type()

The die_get_typename_from_type() is to get the name of the given DIE in
C-style type name.

The difference from die_get_typename() is that it does not retrieve the
DW_AT_type and use the given DIE directly.  This will be used when users
know the type DIE already.
Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Ian Rogers <irogers@google.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Masami Hiramatsu <mhiramat@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Cc: linux-toolchains@vger.kernel.org
Cc: linux-trace-devel@vger.kernel.org
Link: https://lore.kernel.org/r/20231213001323.718046-2-namhyung@kernel.orgSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent ac254dfb
...@@ -1051,32 +1051,28 @@ Dwarf_Die *die_find_member(Dwarf_Die *st_die, const char *name, ...@@ -1051,32 +1051,28 @@ Dwarf_Die *die_find_member(Dwarf_Die *st_die, const char *name,
} }
/** /**
* die_get_typename - Get the name of given variable DIE * die_get_typename_from_type - Get the name of given type DIE
* @vr_die: a variable DIE * @type_die: a type DIE
* @buf: a strbuf for result type name * @buf: a strbuf for result type name
* *
* Get the name of @vr_die and stores it to @buf. Return 0 if succeeded. * Get the name of @type_die and stores it to @buf. Return 0 if succeeded.
* and Return -ENOENT if failed to find type name. * and Return -ENOENT if failed to find type name.
* Note that the result will stores typedef name if possible, and stores * Note that the result will stores typedef name if possible, and stores
* "*(function_type)" if the type is a function pointer. * "*(function_type)" if the type is a function pointer.
*/ */
int die_get_typename(Dwarf_Die *vr_die, struct strbuf *buf) int die_get_typename_from_type(Dwarf_Die *type_die, struct strbuf *buf)
{ {
Dwarf_Die type;
int tag, ret; int tag, ret;
const char *tmp = ""; const char *tmp = "";
if (__die_get_real_type(vr_die, &type) == NULL) tag = dwarf_tag(type_die);
return -ENOENT;
tag = dwarf_tag(&type);
if (tag == DW_TAG_array_type || tag == DW_TAG_pointer_type) if (tag == DW_TAG_array_type || tag == DW_TAG_pointer_type)
tmp = "*"; tmp = "*";
else if (tag == DW_TAG_subroutine_type) { else if (tag == DW_TAG_subroutine_type) {
/* Function pointer */ /* Function pointer */
return strbuf_add(buf, "(function_type)", 15); return strbuf_add(buf, "(function_type)", 15);
} else { } else {
const char *name = dwarf_diename(&type); const char *name = dwarf_diename(type_die);
if (tag == DW_TAG_union_type) if (tag == DW_TAG_union_type)
tmp = "union "; tmp = "union ";
...@@ -1089,7 +1085,7 @@ int die_get_typename(Dwarf_Die *vr_die, struct strbuf *buf) ...@@ -1089,7 +1085,7 @@ int die_get_typename(Dwarf_Die *vr_die, struct strbuf *buf)
/* Write a base name */ /* Write a base name */
return strbuf_addf(buf, "%s%s", tmp, name ?: ""); return strbuf_addf(buf, "%s%s", tmp, name ?: "");
} }
ret = die_get_typename(&type, buf); ret = die_get_typename(type_die, buf);
if (ret < 0) { if (ret < 0) {
/* void pointer has no type attribute */ /* void pointer has no type attribute */
if (tag == DW_TAG_pointer_type && ret == -ENOENT) if (tag == DW_TAG_pointer_type && ret == -ENOENT)
...@@ -1100,6 +1096,26 @@ int die_get_typename(Dwarf_Die *vr_die, struct strbuf *buf) ...@@ -1100,6 +1096,26 @@ int die_get_typename(Dwarf_Die *vr_die, struct strbuf *buf)
return strbuf_addstr(buf, tmp); return strbuf_addstr(buf, tmp);
} }
/**
* die_get_typename - Get the name of given variable DIE
* @vr_die: a variable DIE
* @buf: a strbuf for result type name
*
* Get the name of @vr_die and stores it to @buf. Return 0 if succeeded.
* and Return -ENOENT if failed to find type name.
* Note that the result will stores typedef name if possible, and stores
* "*(function_type)" if the type is a function pointer.
*/
int die_get_typename(Dwarf_Die *vr_die, struct strbuf *buf)
{
Dwarf_Die type;
if (__die_get_real_type(vr_die, &type) == NULL)
return -ENOENT;
return die_get_typename_from_type(&type, buf);
}
/** /**
* die_get_varname - Get the name and type of given variable DIE * die_get_varname - Get the name and type of given variable DIE
* @vr_die: a variable DIE * @vr_die: a variable DIE
......
...@@ -116,6 +116,9 @@ Dwarf_Die *die_find_variable_at(Dwarf_Die *sp_die, const char *name, ...@@ -116,6 +116,9 @@ Dwarf_Die *die_find_variable_at(Dwarf_Die *sp_die, const char *name,
Dwarf_Die *die_find_member(Dwarf_Die *st_die, const char *name, Dwarf_Die *die_find_member(Dwarf_Die *st_die, const char *name,
Dwarf_Die *die_mem); Dwarf_Die *die_mem);
/* Get the name of given type DIE */
int die_get_typename_from_type(Dwarf_Die *type_die, struct strbuf *buf);
/* Get the name of given variable DIE */ /* Get the name of given variable DIE */
int die_get_typename(Dwarf_Die *vr_die, struct strbuf *buf); int die_get_typename(Dwarf_Die *vr_die, struct strbuf *buf);
......
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