* Re: Question to perf annotate handling mov ...(%rip) instructions
[not found] <f241fe0b-7a3f-cb6a-51ee-4833bce81e70@linux.vnet.ibm.com>
@ 2017-11-28 14:50 ` Arnaldo Carvalho de Melo
2017-11-29 8:29 ` Jiri Olsa
2017-11-29 9:14 ` Thomas-Mich Richter
0 siblings, 2 replies; 3+ messages in thread
From: Arnaldo Carvalho de Melo @ 2017-11-28 14:50 UTC (permalink / raw)
To: Thomas-Mich Richter; +Cc: Jiri Olsa, Linux Kernel Mailing List, linux-perf-use.
Em Tue, Nov 28, 2017 at 11:42:16AM +0100, Thomas-Mich Richter escreveu:
> I am confused by perf annotate internals.
>
> Perf annotate examines a perf.data file and shows disassembler output.
> However the output differs depending on the output option specified:
Well, we started with the --stdio code, and then, for the TUI, went on
improving to be able to navigate, etc.
The --stdio code was then left for us to compare outputs and see if some
regression was being added.
I think that the right thing is to have the --stdio use what is in
--tui, modulo the interactive bits.
The --tui has knobs to disable its beautifications, see H in the tui
annotation browser to see the toggle hotkeys.
> ‑‑stdio: Output to stdout, also selected implicitly when output piped to another
> process or redirected to a file. The function call sequence is
>
> symbol__tty_annotate() –> symbol__annotate_printf() –> disasm_line__print().
>
> This output style does not annotate the branch instructions nor does it use special
> printing functions in the util/annotate.c, for example mov__scnprintf().
>
> ‑‑tui: Default. there are annotations to augment branches, jumps, fct returns
> with arrows for interactive usage. The function call stack starts with
> symbol__tui_annotate().
> There is also special treatment for the Intel mov instructions of the form:
The cases where intel has special treatment are bugs, should be moved to
arch specific callbacks.
> 00000000000060b0 <_init@@Base>:
> ....
> 60b4: 48 8b 05 35 cd 22 00 mov 0x22cd35(%rip),%rax # 232df0 <__gmon_start__>
>
> Commit 6de783b6f50f7f1db18a3fda0aa34b2e84b5771d ("perf annotate: Resolve symbols
> using objdump comment") added this support.
>
> Special code for Intel platform handles the mov at address 60b4:
> This is dynamic linkage against the PLT. Function mov__parse() is always called
> to parse the objdump comment following the '#' character.
> However the function mov__scnprintf() to replace the text '0x22cd35(%rip)' by the
> target function name __gmon_start__ is only called in tui mode and not in stdio mode.
>
> Now to the confusion:
> Function mov__parse() calls comment__symbol() which contains:
>
> static int comment__symbol(char *raw, char *comment, u64 *addrp, char **namep)
> {
> char *endptr, *name, *t;
>
> if (strstr(raw, "(%rip)") == NULL)
> return 0;
>
> This is architecture specific and does not work for non-Intel platforms.
>
> I would like to fix perf annotate for s390x and above move instruction on s390x
> is
>
> 655a: c0 10 00 01 9c eb larl %r1,39f30 <__gmon_start__>
>
> There is a need to handle PLT resolution in an architecture independent way.
>
> Ideas and suggestions?
Some historical background there, busy now, but you seem to be on the
right track and IIRC you already sent a patch for this, right? I'll try
to look at it.
Jiri may as well, since he worked a lot recently in this codebase, to
refactor it some more to make it useful for annotating python code, perl
next, other scripted languages should follow too.
- Arnaldo
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: Question to perf annotate handling mov ...(%rip) instructions
2017-11-28 14:50 ` Question to perf annotate handling mov ...(%rip) instructions Arnaldo Carvalho de Melo
@ 2017-11-29 8:29 ` Jiri Olsa
2017-11-29 9:14 ` Thomas-Mich Richter
1 sibling, 0 replies; 3+ messages in thread
From: Jiri Olsa @ 2017-11-29 8:29 UTC (permalink / raw)
To: Arnaldo Carvalho de Melo
Cc: Thomas-Mich Richter, Jiri Olsa, Linux Kernel Mailing List,
linux-perf-use.
On Tue, Nov 28, 2017 at 11:50:30AM -0300, Arnaldo Carvalho de Melo wrote:
SNIP
> > Function mov__parse() calls comment__symbol() which contains:
> >
> > static int comment__symbol(char *raw, char *comment, u64 *addrp, char **namep)
> > {
> > char *endptr, *name, *t;
> >
> > if (strstr(raw, "(%rip)") == NULL)
> > return 0;
> >
> > This is architecture specific and does not work for non-Intel platforms.
> >
> > I would like to fix perf annotate for s390x and above move instruction on s390x
> > is
> >
> > 655a: c0 10 00 01 9c eb larl %r1,39f30 <__gmon_start__>
> >
> > There is a need to handle PLT resolution in an architecture independent way.
> >
> > Ideas and suggestions?
>
> Some historical background there, busy now, but you seem to be on the
> right track and IIRC you already sent a patch for this, right? I'll try
> to look at it.
>
> Jiri may as well, since he worked a lot recently in this codebase, to
> refactor it some more to make it useful for annotating python code, perl
> next, other scripted languages should follow too.
so we try to parse each line out of objdump using arch specific
ops callbacks, check:
disasm_line__new
disasm_line__init_ins
dl->ins.ops->parse(...
the ops stuff are defined in:
static struct arch architectures[] = {
{
.name = "s390",
.init = s390__annotate_init,
.objdump = {
.comment_char = '#',
},
},
I'd check s390__annotate_init, there's some mechanism
of associating ops for arch and try to fit in ;-)
jirka
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: Question to perf annotate handling mov ...(%rip) instructions
2017-11-28 14:50 ` Question to perf annotate handling mov ...(%rip) instructions Arnaldo Carvalho de Melo
2017-11-29 8:29 ` Jiri Olsa
@ 2017-11-29 9:14 ` Thomas-Mich Richter
1 sibling, 0 replies; 3+ messages in thread
From: Thomas-Mich Richter @ 2017-11-29 9:14 UTC (permalink / raw)
To: Arnaldo Carvalho de Melo
Cc: Jiri Olsa, Linux Kernel Mailing List, linux-perf-use.
On 11/28/2017 03:50 PM, Arnaldo Carvalho de Melo wrote:
.....
>> ....
>> 60b4: 48 8b 05 35 cd 22 00 mov 0x22cd35(%rip),%rax # 232df0 <__gmon_start__>
>>
>> Commit 6de783b6f50f7f1db18a3fda0aa34b2e84b5771d ("perf annotate: Resolve symbols
>> using objdump comment") added this support.
>>
>> Special code for Intel platform handles the mov at address 60b4:
>> This is dynamic linkage against the PLT. Function mov__parse() is always called
>> to parse the objdump comment following the '#' character.
>> However the function mov__scnprintf() to replace the text '0x22cd35(%rip)' by the
>> target function name __gmon_start__ is only called in tui mode and not in stdio mode.
>>
>> Now to the confusion:
>> Function mov__parse() calls comment__symbol() which contains:
>>
>> static int comment__symbol(char *raw, char *comment, u64 *addrp, char **namep)
>> {
>> char *endptr, *name, *t;
>>
>> if (strstr(raw, "(%rip)") == NULL)
>> return 0;
>>
>> This is architecture specific and does not work for non-Intel platforms.
>>
>> I would like to fix perf annotate for s390x and above move instruction on s390x
>> is
>>
>> 655a: c0 10 00 01 9c eb larl %r1,39f30 <__gmon_start__>
>>
>> There is a need to handle PLT resolution in an architecture independent way.
>>
>> Ideas and suggestions?
>
> Some historical background there, busy now, but you seem to be on the
> right track and IIRC you already sent a patch for this, right? I'll try
> to look at it.
The two patches I sent are unrelated to this issue.
> Jiri may as well, since he worked a lot recently in this codebase, to
> refactor it some more to make it useful for annotating python code, perl
> next, other scripted languages should follow too.
--
Thomas Richter, Dept 3303, IBM LTC Boeblingen Germany
--
Vorsitzende des Aufsichtsrats: Martina Koederitz
Geschäftsführung: Dirk Wittkopp
Sitz der Gesellschaft: Böblingen / Registergericht: Amtsgericht Stuttgart, HRB 243294
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2017-11-29 9:14 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <f241fe0b-7a3f-cb6a-51ee-4833bce81e70@linux.vnet.ibm.com>
2017-11-28 14:50 ` Question to perf annotate handling mov ...(%rip) instructions Arnaldo Carvalho de Melo
2017-11-29 8:29 ` Jiri Olsa
2017-11-29 9:14 ` Thomas-Mich Richter
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox