From: Maxim Grigoriev <maxim@tensilica.com>
To: Nick Roberts <nickrob@snap.net.nz>
Cc: Daniel Jacobowitz <drow@false.org>,
Maxim Grigoriev <maxim@tensilica.com>,
gdb@sourceware.org, Pete MacLiesh <pmac@tensilica.com>,
Vinay Pandit <vinayp@tensilica.com>,
Shaiju P <shaijup@tensilica.com>,
Marc Gauthier <marc@tensilica.com>
Subject: Re: Which MI behavior is correct ?
Date: Sat, 19 May 2007 19:36:00 -0000 [thread overview]
Message-ID: <464F51B5.5040802@hq.tensilica.com> (raw)
In-Reply-To: <17998.28300.327133.525945@kahikatea.snap.net.nz>
[-- Attachment #1: Type: text/plain, Size: 2789 bytes --]
Nick, Daniel, thanks much for your comments.
My test case wasn't simple enough. Now, I hope it's more clear:
newtest.c:
---------------------------------------------
int f11(int b)
{
int a;
a = b + 1;
return a; /* <- BP set here. */
}
int main()
{
int a = 1;
a = f11(a);
a = f11(a);
return a;
}
MI commands used (CMD):
----------------------------------------------
100-interpreter-exec console echo
file exe
200-break-insert newtest.c:6
run
300-var-create - * a
301-var-create - * b
302-var-evaluate-expression var1
303-var-evaluate-expression var2
400-exec-continue
500-var-update var1
501-var-update var2
502-var-evaluate-expression var1
503-var-evaluate-expression var2
kill
quit
Debuggers ran with commands:
xt-gdb -q -nw --interpreter=mi <CMD >XTENSA.log
gdb -q -nw --interpreter=mi <CMD >NATIVE.log
The outputs are attached.
> Aren't the variables associated with a particular frame ID? I thought
> we'd decided that it was the right thing to take them out of scope.
This seems to be an answer to my question. The behavior has changed
probably since somewhere around 6.3. Now, variable objects are associated
with the frame, not with the function. As you can see in gdb 6.3 case
( NATIVE.log ), variables "var1" and "var2" were successfully reused,
when new frame was allocated after hitting the breakpoint second time.
In 6.5+ (XTENSA.log), we have to recreate variable objects every time
we have a new frame because the old variables are out of scope.
Correct ?
How about efficiency ? What if we have to create hundreds of variable
objects at every breakpoint hit ?
We kept staying with GNU gdb 5.2.1 for too long. So it looks like
we might have missed this important change, which is already in the
past for the majority of GNU gdb users.
-- Maxim
Nick Roberts wrote:
> > > > - Are we supposed to recreate variables each time we enter the
> > > > function ?
> > > > - Is this efficient ?
> > >
> > > Well the variables themselves are reallocated from the stack, so there's
> > > a chance that they're not the same variables. At the moment, however
> > > GDB assumes that they are the same and you don't have to recreate them.
> >
> > Aren't the variables associated with a particular frame ID? I thought
> > we'd decided that it was the right thing to take them out of scope.
>
> Maxim hadn't posted the test case when I replied. Even now I'm not sure what
> the chain of events are. If the second instance is when f11 is called by f1,
> then I agree it should be out of scope, and I think it always has been. If it
> refers to the second time f11 is called from main (and the transcript seems to
> suggest this, although I've not looked too carefully) then GDB still considers
> this to be in scope.
>
>
>
>
[-- Attachment #2: NATIVE.log --]
[-- Type: text/x-log, Size: 997 bytes --]
(gdb)
100^done
(gdb)
&"file exe\n"
~"Using host libthread_db library \"/lib/libthread_db.so.1\".\n"
^done
(gdb)
200^done,bkpt={number="1",type="breakpoint",disp="keep",enabled="y",addr="0x08048363",func="f11",file="newtest.c",line="6",times="0"}
(gdb)
&"run\n"
^done,reason="breakpoint-hit",bkptno="1",thread-id="0",frame={addr="0x08048363",func="f11",args=[{name="b",value="1"}],file="newtest.c",line="6"}
(gdb)
300^done,name="var1",numchild="0",type="int"
(gdb)
301^done,name="var2",numchild="0",type="int"
(gdb)
302^done,value="2"
(gdb)
303^done,value="1"
(gdb)
400^running
(gdb)
400*stopped,reason="breakpoint-hit",bkptno="1",thread-id="0",frame={addr="0x08048363",func="f11",args=[{name="b",value="2"}],file="newtest.c",line="6"}
(gdb)
500^done,changelist=[{name="var1",in_scope="true",type_changed="false"}]
(gdb)
501^done,changelist=[{name="var2",in_scope="true",type_changed="false"}]
(gdb)
502^done,value="3"
(gdb)
503^done,value="2"
(gdb)
&"kill\n"
^done
(gdb)
&"quit\n"
[-- Attachment #3: XTENSA.log --]
[-- Type: text/x-log, Size: 1024 bytes --]
(gdb)
100^done
(gdb)
&"file exe\n"
~"Reading symbols from /home/maxim/W/BUGS/PMAC_MI/exe..."
~"done.\n"
^done
(gdb)
200^done,bkpt={number="1",type="breakpoint",disp="keep",enabled="y",addr="0x40000465",func="f11",file="newtest.c",fullname="/home/maxim/W/BUGS/PMAC_MI/newtest.c",line="6",times="0"}
(gdb)
&"run\n"
~"Breakpoint 1, f11 (b=1) at newtest.c:6\n"
~"6\t return a; /* <- BP set here. */\n"
^done
(gdb)
300^done,name="var1",numchild="0",value="2",type="int"
(gdb)
301^done,name="var2",numchild="0",value="1",type="int"
(gdb)
302^done,value="2"
(gdb)
303^done,value="1"
(gdb)
400^running
(gdb)
400*stopped,reason="breakpoint-hit",bkptno="1",thread-id="0",frame={addr="0x40000465",func="f11",args=[{name="b",value="2"}],file="newtest.c",fullname="/home/maxim/W/BUGS/PMAC_MI/newtest.c",line="6"}
(gdb)
500^done,changelist=[{name="var1",in_scope="false"}]
(gdb)
501^done,changelist=[{name="var2",in_scope="false"}]
(gdb)
502^done,value=""
(gdb)
503^done,value=""
(gdb)
&"kill\n"
^done
(gdb)
&"quit\n"
next prev parent reply other threads:[~2007-05-19 19:36 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-05-19 1:01 Maxim Grigoriev
2007-05-19 1:58 ` Maxim Grigoriev
2007-05-19 2:20 ` Nick Roberts
2007-05-19 3:03 ` Daniel Jacobowitz
2007-05-19 3:27 ` Nick Roberts
2007-05-19 19:36 ` Maxim Grigoriev [this message]
2007-05-19 23:08 ` Nick Roberts
2007-05-21 3:43 ` Maxim Grigoriev
2007-05-25 20:51 ` Jim Blandy
2007-05-25 21:48 ` Maxim Grigoriev
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=464F51B5.5040802@hq.tensilica.com \
--to=maxim@tensilica.com \
--cc=drow@false.org \
--cc=gdb@sourceware.org \
--cc=marc@tensilica.com \
--cc=nickrob@snap.net.nz \
--cc=pmac@tensilica.com \
--cc=shaijup@tensilica.com \
--cc=vinayp@tensilica.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