[PATCH 2/2] new tracepoint downloaded MI notification.
Pedro Alves
palves@redhat.com
Fri Nov 2 15:46:00 GMT 2012
On 11/01/2012 12:34 AM, Yao Qi wrote:
> On 11/01/2012 01:59 AM, Pedro Alves wrote:
>>> From the frontend's point of view, {number, location number} is better, and the schema "number.location_number" has been used in "=breakpoint-modified" notification. However, if we want to use {number, location number} here, we have to guarantee that the location number is an attribute of bp_location, because:
>> This is not a particular issue of tracepoint locations, so, if it was a problem, it
>> would be a problem for the existing notifications and MI commands as well.
>>
>> IOW, this would need to be fixed for all those other cases that expose location
>> numbers, not just come up with an ad hoc solution.
>>
>
> I agree.
>
>> IOW, there's no good justification for deviating this notification from
>> existing practice.
>>
>
> What do you mean by "existing practice"? Is {number, location number} the "existing practise"?
Almost. AFAICS, the existing practice is "bp_number.loc_number" in MI, just like in the CLI.
&"b main\n"
~"Breakpoint 8 at 0x457aab: main. (2 locations)\n"
=breakpoint-created,bkpt={number="8",type="breakpoint",disp="keep",enabled="y",addr="<MULTIPLE>",times="0",original-location="main"},{number="8.1",enabled="y",addr="0x0000000000457aab",func="main",file="../../src/gdb/gdb.c",fullname="/home/pedro/gdb/mygit/src/gdb/gdb.c",line="29"},{number="8.2",enabled="y",addr="0x0000000000457aab",func="main",file="../../src/gdb/gdb.c",fullname="/home/pedro/gdb/mygit/src/gdb/gdb.c",line="29"}
^done
Note 'number="8.1"'.
Or,
(gdb)
-break-disable 9.1
^done
(gdb)
info breakpoint
&"info breakpoint\n"
~"Num Type Disp Enb Address What\n"
~"9 tracepoint keep y <MULTIPLE> \n"
~"9.1 n 0x0000000000457aab in main at ../../src/gdb/gdb.c:29 inf 1\n"
~"9.2 y 0x0000000000457aab in main at ../../src/gdb/gdb.c:29 inf 2\n"
Looks like a =breakpoint-modified notification is missing for this, BTW:
disable 8.1
&"disable 8.1\n"
^done
(gdb)
While this emitted the notification:
disable 8
&"disable 8\n"
=breakpoint-modified,bkpt={number="8",type="breakpoint",disp="keep",enabled="n",addr="<MULTIPLE>",times="0",original-location="main"},{number="8.1",enabled="n",addr="0x0000000000457aab",func="main",file="../../src/gdb/gdb.c",fullname="/home/pedro/gdb/mygit/src/gdb/gdb.c",line="29"},{number="8.2",enabled="y",addr="0x0000000000457aab",func="main",file="../../src/gdb/gdb.c",fullname="/home/pedro/gdb/mygit/src/gdb/gdb.c",line="29"}
^done
(gdb)
>>> >In short, if we can make location number persistent (unchanged for a given bp_location object), then {number, location number} is fine, otherwise, I'd prefer {number, address}.
>> {number, address} may looks stabler, but not even that is completely stable.
>> Change the program's code a little, recompile, reload symbols, and you'll see the
>> address change. Whatever smarts you'd want the frontend to have to track
>> locations, GDB could do instead, once for all frontends, and better, because
> ^^^^^^^^^
> IIUC, "locations" here mean location address instead of location number.
I mean location as the abstract location a bp_location represents. By track, I mean,
recognize that a given location is the same as another location (remember that
catchpoints often don't even have a concept of address!).
>
>> it may use properties other than the address to decided whether a new instance
>> of a location is logically the same as the old one (think of stap probes or static
>> tracepoints, where the address is really a very low target side detail; or just
>> consider line number instead of address). I think all this goes hand in hand with
>> redesigning how GDB handles breakpoint re-setting (or rather, get rid of re-setting as is),
>> which will make this whole stabler locations issue better. Keith will be going to
>> work on that very soon, IIUC.
>
> FAOD, we should continue to use {number, location number}, and it requires improvement of breakpoint re-setting, correct?
Yes. Though AFAICS, current notifications and commands use 'number="N.M"', not '{number, location number}'.
--
Pedro Alves
More information about the Gdb-patches
mailing list