[PATCH][gdb/breakpoint] Handle setting breakpoint on label without address
Tom de Vries
tdevries@suse.de
Fri Aug 28 10:31:12 GMT 2020
On 8/27/20 3:49 PM, Tom de Vries wrote:
> On 8/27/20 2:41 PM, Pedro Alves wrote:
>> On 8/27/20 12:52 PM, Tom de Vries wrote:
>>> Hi,
>>>
>>> Consider test-case test.c:
>>> ...
>>> $ cat test.c
>>> int main (void) {
>>> return 0;
>>> L1:
>>> (void)0;
>>> }
>>> ...
>>>
>>> Compiled with debug info:
>>> ...
>>> $ gcc test.c -g
>>> ...
>>>
>>> When attempting to set a breakpoint at L1, which is a label without address:
>>> ...
>>> <1><f4>: Abbrev Number: 2 (DW_TAG_subprogram)
>>> <f5> DW_AT_name : main
>>> <2><115>: Abbrev Number: 3 (DW_TAG_label)
>>> <116> DW_AT_name : L1
>>> <119> DW_AT_decl_file : 1
>>> <11a> DW_AT_decl_line : 5
>>> <2><11b>: Abbrev Number: 0
>>
>> Is this a debug info bug,
>
> Strictly speaking, this is a debug info bug. The standard says that:
> ...
> The label entry has a DW_AT_low_pc attribute whose value is the address
> of the first executable instruction for the location identified by the
> label in the source program.
> ...
>
> But I interpret the missing DW_AT_low_pc attribute as: there is a label
> in the source, but the corresponding code has been optimized out.
>
>> or is the debug info telling us that the
>> address of the label is the same as the line number's address?
>>
>> How about looking up the line number address instead of throwing
>> an error?
>>
>
> Well, in this particular case, that wouldn't help.
>
> With L1 at line 3:
> ...
> $ cat -n test.c
> 1 int main (void) {
> 2 return 0;
> 3 L1:
> 4 (void)0;
> 5 }
> 6
> ...
> there's no corresponding address:
> ...
> $ readelf -wL a.out
> CU: test.c:
> File name Line number Starting address
> View Stmt
> test.c 1 0x400497
> x
> test.c 2 0x40049b
> x
> test.c 5 0x4004a0
> x
> test.c - 0x4004a2
> ...
>
> My suspicion is that this won't be useful in general.
>
I've pushed this as attached below, with the test-case updated to work
around PR26546 - "[pie] Setting breakpoint on missing label sets
breakpoint at offset 0 in NULL section" (
https://sourceware.org/bugzilla/show_bug.cgi?id=26546 ).
Thanks,
- Tom
-------------- next part --------------
A non-text attachment was scrubbed...
Name: 0001-gdb-breakpoint-Handle-setting-breakpoint-on-label-without-address.patch
Type: text/x-patch
Size: 14652 bytes
Desc: not available
URL: <https://sourceware.org/pipermail/gdb-patches/attachments/20200828/d41b4f33/attachment-0001.bin>
More information about the Gdb-patches
mailing list