From: wempwer@gmail.com
To: Joachim Protze <joachim.protze@tu-dresden.de>
Cc: gdb@sourceware.org
Subject: Re: Why does gdb stop at a different line than “i b” shows while returning from function?
Date: Sat, 04 Aug 2012 19:09:00 -0000 [thread overview]
Message-ID: <20120804200150.GA2730@a.lan> (raw)
In-Reply-To: <501B96BE.8050604@tu-dresden.de>
On Fri, Aug 03, 2012 at 11:15:42AM +0200, Joachim Protze wrote:
> The behaviour is similar with setting a breakpoint at empty line 7 ("b
> 7") or function header line 13 ("b 13"): "i b" shows try5.c:7 resp.
> try5.c:13, but the program stops at line 8 resp. 15.
>
I would understand this because there are no instructions at line 7 and 13 so breakpoints have no effect on these lines and are automatically moved to the nearest next instruction. Is my understanding correct?
However, my example is a bit different. I moved from 'display' to 'main' frame and set a breakpoint. I don't understand why gdb put the breakpoint on line 8 instead of 9, because this is the actual next instruction that's going to be executed in 'frame 1' and in fact when you resume the execution it stops at line 9 in 'main'. I think the breakpoint should be set at line 9 or if it must be set at line 8 it should not be triggered at line 9. There are no empty instructions such as '{' anywhere along the way in this situation.
> The thing gets even fancier, when you rerun the program after setting
> the breakpoints: Now "i b" lists your breakpoint at line 9, while my
> breakpoints remain at line 7 resp. 13.
>
> - Joachim
>
That's right, I didn't notice that before. Maybe it's a bug? I include the full log:
Reading symbols from /home/ja/gdb/learning/try5...done.
(gdb) b 7
Breakpoint 1 at 0x4004fb: file try5.c, line 7.
(gdb) b 13
Breakpoint 2 at 0x40051e: file try5.c, line 13.
(gdb) b display
Note: breakpoint 2 also set at pc 0x40051e.
Breakpoint 3 at 0x40051e: file try5.c, line 15.
(gdb) r
Starting program: /home/ja/gdb/learning/try5
Breakpoint 1, main () at try5.c:8
(gdb) c
Continuing.
Breakpoint 2, display (x=3) at try5.c:15
(gdb) f 1
#1 0x000000000040050c in main () at try5.c:8
(gdb) b
Breakpoint 4 at 0x40050c: file try5.c, line 8.
(gdb) c
Continuing.
i is 0.
i is 1.
i is 2.
Breakpoint 4, main () at try5.c:9
(gdb) c
Continuing.
[Inferior 1 (process 13038) exited normally]
(gdb) i b
Num Type Disp Enb Address What
1 breakpoint keep y 0x00000000004004fb in main at try5.c:7
breakpoint already hit 1 time
2 breakpoint keep y 0x000000000040051e in display at try5.c:13
breakpoint already hit 1 time
3 breakpoint keep y 0x000000000040051e in display at try5.c:15
breakpoint already hit 1 time
4 breakpoint keep y 0x000000000040050c in main at try5.c:8
breakpoint already hit 1 time
(gdb) r
Starting program: /home/ja/gdb/learning/try5
Breakpoint 1, main () at try5.c:8
(gdb) i b
Num Type Disp Enb Address What
1 breakpoint keep y 0x00000000004004fb in main at try5.c:7
breakpoint already hit 1 time
2 breakpoint keep y 0x000000000040051e in display at try5.c:13
3 breakpoint keep y 0x000000000040051e in display at try5.c:15
4 breakpoint keep y 0x000000000040050c in main at try5.c:9
(gdb)
prev parent reply other threads:[~2012-08-04 19:09 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-07-29 18:02 wempwer
2012-08-03 9:16 ` Joachim Protze
2012-08-04 19:09 ` wempwer [this message]
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=20120804200150.GA2730@a.lan \
--to=wempwer@gmail.com \
--cc=gdb@sourceware.org \
--cc=joachim.protze@tu-dresden.de \
/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;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).