From: Pedro Alves <palves@redhat.com>
To: Yao Qi <qiyaoltc@gmail.com>
Cc: gdb-patches@sourceware.org
Subject: Re: [PATCH 04/12] Delete reinsert breakpoints from forked child
Date: Mon, 13 Jun 2016 17:29:00 -0000 [thread overview]
Message-ID: <f5c12eca-f7f4-c953-bbb6-469e6b8cc8c5@redhat.com> (raw)
In-Reply-To: <86twgxt4hg.fsf@gmail.com>
On 06/13/2016 05:53 PM, Yao Qi wrote:
> Pedro Alves <palves@redhat.com> writes:
>
>> Hmm, "\$pc - 20" doesn't look right for e.g., x86 with variable
>> length instructions. I think that can well start disassembling
>> in the middle of an instruction, and produce garbage.
>>
>
> I thought 20 is big enough to include the previous instruction in.
> The max instruction length of x86 is 16. If we disassemble in the
> middle of an instruction,
Yes, we do.
> and garbage is printed,
Yes, it does. Easily confirmed:
(gdb) disassemble $pc,+10
Dump of assembler code from 0x7ffff78c55bb to 0x7ffff78c55c5:
=> 0x00007ffff78c55bb <__libc_fork+187>: cmp $0xfffffffffffff000,%rax
0x00007ffff78c55c1 <__libc_fork+193>: ja 0x7ffff78c5716 <__libc_fork+534>
End of assembler dump.
(gdb) disassemble $pc-1,+10
Dump of assembler code from 0x7ffff78c55ba to 0x7ffff78c55c4:
0x00007ffff78c55ba <__libc_fork+186>: add $0xf0003d48,%eax
0x00007ffff78c55bf <__libc_fork+191>: (bad)
0x00007ffff78c55c0 <__libc_fork+192>: decl (%rdi)
0x00007ffff78c55c2 <__libc_fork+194>: xchg %ecx,0x1(%rdi)
End of assembler dump.
(gdb)
> it is a bug, and we should fix in disassembler.
The problem is that with variable length instructions,
there's no way to tell where an instruction starts by going
backwards... All you can do is disassemble forward from some
known instruction boundary. "disassemble" without a closed range
uses the the function's address to know where to start.
> I can't find another way to show the previous instruction.
Now that the negative repeat count for 'x' patch [1] is in,
you can just do "x/-i $pc". Maybe "disassemble" could learn
to find boundaries similarly.
But that x/-i trick only works if the code has line info available,
which you won't for _exit, unless you have debug info for glibc
installed. Maybe better is to just do "disassemble", with no args,
which disassembles the whole function.
Or do it like step-over-syscall.exp does.
[1] https://sourceware.org/ml/gdb-patches/2016-06/msg00021.html
>> I'm thinking that it might be good for these tests to also have
>> a displaced-stepping on/off test axis. Or better still:
>>
>> out-of-line-step-over-bp / in-line-step-over-bp / plain-single-step
>>
>
> What is difference between the second one and third one?
As I mention in the quoted sentence below, the last one
would single-step the instruction with no breakpoint
installed. The second one would have a breakpoint at PC,
which forces a step-over operation. With displaced step
off, that'd be an in-line step over. Thus the second one stops
all threads (and thus requires restarting them), while the
third one doesn't.
> I think
> they've already covered by gdb.base/step-over-syscall.exp.
In that case, shouldn't we be extending that test instead?
>
>> with the single-step variant doing a single-step over the
>> syscall instruction, with no breakpoint at PC at all.
>
Thanks,
Pedro Alves
next prev parent reply other threads:[~2016-06-13 17:29 UTC|newest]
Thread overview: 39+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-06-02 9:31 [PATCH 00/12 V2] Use reinsert breakpoint for vCont;s Yao Qi
2016-06-02 9:31 ` [PATCH 05/12] Handle reinsert breakpoints for vforked child Yao Qi
2016-06-13 15:07 ` Pedro Alves
2016-06-02 9:31 ` [PATCH 10/12] Switch current_thread to lwp's thread in install_software_single_step_breakpoints Yao Qi
2016-06-13 15:26 ` Pedro Alves
2016-06-02 9:31 ` [PATCH 04/12] Delete reinsert breakpoints from forked child Yao Qi
2016-06-13 15:02 ` Pedro Alves
2016-06-13 16:53 ` Yao Qi
2016-06-13 17:29 ` Pedro Alves [this message]
2016-06-14 11:17 ` Yao Qi
2016-06-14 11:40 ` Pedro Alves
2016-06-17 9:53 ` Yao Qi
2016-06-02 9:31 ` [PATCH 02/12] More assert checks on reinsert breakpoint Yao Qi
2016-06-13 14:25 ` Pedro Alves
2016-06-02 9:31 ` [PATCH 12/12] Support vCont s and S actions with software single step Yao Qi
2016-06-13 15:56 ` Pedro Alves
2016-06-02 9:31 ` [PATCH 11/12] Use reinsert_breakpoint for vCont;s Yao Qi
2016-06-13 15:55 ` Pedro Alves
2016-06-14 13:14 ` Yao Qi
2016-06-14 15:48 ` Pedro Alves
2016-06-15 16:41 ` Yao Qi
2016-06-17 15:10 ` Pedro Alves
2016-06-20 18:09 ` Antoine Tremblay
2016-06-02 9:31 ` [PATCH 01/12] Switch to current thread in finish_step_over Yao Qi
2016-06-13 14:25 ` Pedro Alves
2016-06-02 9:31 ` [PATCH 07/12] Create sub classes of 'struct breakpoint' Yao Qi
2016-06-13 15:09 ` Pedro Alves
2016-06-02 9:31 ` [PATCH 09/12] Make reinsert_breakpoint thread specific Yao Qi
[not found] ` <71a5322e-41e3-9e23-df73-e14b14c1d656@redhat.com>
2016-06-14 12:52 ` Yao Qi
2016-06-14 12:57 ` Pedro Alves
2016-06-02 9:31 ` [PATCH 08/12] Refactor clone_all_breakpoints Yao Qi
2016-06-13 15:14 ` Pedro Alves
2016-06-02 9:31 ` [PATCH 03/12] Step over exit with reinsert breakpoints Yao Qi
2016-06-13 14:37 ` Pedro Alves
2016-06-13 14:52 ` Yao Qi
2016-06-13 15:01 ` Pedro Alves
2016-06-17 9:50 ` Yao Qi
2016-06-02 9:31 ` [PATCH 06/12] Pass breakpoint type in set_breakpoint_at Yao Qi
2016-06-13 15:07 ` Pedro Alves
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=f5c12eca-f7f4-c953-bbb6-469e6b8cc8c5@redhat.com \
--to=palves@redhat.com \
--cc=gdb-patches@sourceware.org \
--cc=qiyaoltc@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox