This is the mail archive of the gdb@sourceware.org mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

Re: Which MI behavior is correct ?


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.




(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"
(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"

Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]