[PATCH] [gas] Fix file 0 dir with -gdwarf-5

H.J. Lu hjl.tools@gmail.com
Fri Nov 26 19:47:48 GMT 2021


On Fri, Nov 26, 2021 at 11:31 AM H.J. Lu <hjl.tools@gmail.com> wrote:
>
> On Thu, Nov 25, 2021 at 11:33 PM Tom de Vries via Binutils
> <binutils@sourceware.org> wrote:
> >
> > In out_dir_and_file_list, if file 0 is copied from file 1, only the filename
> > is copied, and the dir and md5 fields are left to their default values.
> >
> > Fix this by adding the copy of the dir and md5 fields.
> >
> > gas/ChangeLog:
> >
> > 2021-11-26  Tom de Vries  <tdevries@suse.de>
> >
> >         PR 28629
> >         * dwarf2dbg.c (out_dir_and_file_list): When copying file 1 to file 0,
> >         also copy dir and md5 fields.
> >         * testsuite/gas/i386/dwarf5-line-4.d: Adjust expected output.
> > ---
> >  gas/dwarf2dbg.c                        | 10 ++++++++--
> >  gas/testsuite/gas/i386/dwarf5-line-4.d |  2 +-
> >  2 files changed, 9 insertions(+), 3 deletions(-)
> >
> > diff --git a/gas/dwarf2dbg.c b/gas/dwarf2dbg.c
> > index 256412f9c79..7300bfe2648 100644
> > --- a/gas/dwarf2dbg.c
> > +++ b/gas/dwarf2dbg.c
> > @@ -2123,7 +2123,7 @@ out_dir_and_file_list (segT line_seg, int sizeof_offset)
> >    size_t size;
> >    const char *dir;
> >    char *cp;
> > -  unsigned int i;
> > +  unsigned int i, j;
> >    bool emit_md5 = false;
> >    bool emit_timestamps = true;
> >    bool emit_filesize = true;
> > @@ -2275,7 +2275,13 @@ out_dir_and_file_list (segT line_seg, int sizeof_offset)
> >              .file 0 directive.  If that isn't used, but file 1 is,
> >              then use that as main file name.  */
> >           if (DWARF2_LINE_VERSION >= 5 && i == 0 && files_in_use >= 1 && files[0].filename == NULL)
> > -           files[0].filename = files[1].filename;
> > +           {
> > +             files[0].filename = files[1].filename;
> > +             files[0].dir = files[1].dir;
> > +             if (emit_md5)
> > +               for (j = 0; i < NUM_MD5_BYTES; ++j)
>                                   ^^^^ Should it be j?
> > +                 files[0].md5[j] = files[1].md5[j];
> > +           }
> >           else
> >             files[i].filename = "";
> >           if (DWARF2_LINE_VERSION < 5 || i != 0)
> > diff --git a/gas/testsuite/gas/i386/dwarf5-line-4.d b/gas/testsuite/gas/i386/dwarf5-line-4.d
> > index 30e1bb2bb89..a3af48eda8c 100644
> > --- a/gas/testsuite/gas/i386/dwarf5-line-4.d
> > +++ b/gas/testsuite/gas/i386/dwarf5-line-4.d
> > @@ -38,7 +38,7 @@ Raw dump of debug contents of section \.z?debug_line:
> >
> >   The File Name Table \(offset 0x.*, lines 2, columns 2\):
> >    Entry        Dir     Name
> > -  0    0       \(indirect line string, offset: 0x.*\): dwarf5-line-4.s
> > +  0    1       \(indirect line string, offset: 0x.*\): dwarf5-line-4.s
> >    1    1       \(indirect line string, offset: 0x.*\): dwarf5-line-4.s
> >
> >   Line Number Statements:
> >
> > base-commit: c0f9d658279d4d352672e283df53c1072925fc97
> > --
> > 2.31.1
> >

I am checking in this:

diff --git a/gas/dwarf2dbg.c b/gas/dwarf2dbg.c
index 7300bfe2648..8e91bef20ab 100644
--- a/gas/dwarf2dbg.c
+++ b/gas/dwarf2dbg.c
@@ -2279,7 +2279,7 @@ out_dir_and_file_list (segT line_seg, int sizeof_offset)
        files[0].filename = files[1].filename;
        files[0].dir = files[1].dir;
        if (emit_md5)
- for (j = 0; i < NUM_MD5_BYTES; ++j)
+ for (j = 0; j < NUM_MD5_BYTES; ++j)
    files[0].md5[j] = files[1].md5[j];
      }
    else
diff --git a/gas/testsuite/gas/elf/dwarf-5-nop-for-line-table.d
b/gas/testsuite/gas/elf/dwarf-5-nop-for-line-table.d
index 651a1a20707..1a8a5c96d1e 100644
--- a/gas/testsuite/gas/elf/dwarf-5-nop-for-line-table.d
+++ b/gas/testsuite/gas/elf/dwarf-5-nop-for-line-table.d
@@ -5,7 +5,7 @@
 #...
 Contents of the .debug_line section:

-CU: .*
+dwarf-5-nop-for-line-table.s:
 File name.*
 #...
 .*[ ]+[1-8][ ]+0.*

-- 
H.J.


More information about the Binutils mailing list