public inbox for dwz@sourceware.org
 help / color / mirror / Atom feed
From: "vries at gcc dot gnu.org" <sourceware-bugzilla@sourceware.org>
To: dwz@sourceware.org
Subject: [Bug default/24468] dwz -m generates partial unit without import
Date: Tue, 01 Jan 2019 00:00:00 -0000	[thread overview]
Message-ID: <bug-24468-11298-hzytuJ5tyX@http.sourceware.org/bugzilla/> (raw)
In-Reply-To: <bug-24468-11298@http.sourceware.org/bugzilla/>

https://sourceware.org/bugzilla/show_bug.cgi?id=24468

--- Comment #1 from Tom de Vries <vries at gcc dot gnu.org> ---
So, what happens is this: the partial unit at 2b5 in the multifile contains as
first die:
...
 <1><2be>: Abbrev Number: 5 (DW_TAG_const_type)
    <2bf>   DW_AT_type        : <0x4c>
...
which refers to:
...
 <1><4c>: Abbrev Number: 18 (DW_TAG_typedef)
    <4d>   DW_AT_name        : (indirect string, offset: 0x54c): size_t
    <51>   DW_AT_decl_file   : 1
    <52>   DW_AT_decl_line   : 216
    <53>   DW_AT_type        : <0x344>
...
in another partial unit in the multifile.

When matching dies in the input file against the dies in the multifile during
finalize_multifile, we compare 2be to 394:
...
 <1><389>: Abbrev Number: 24 (DW_TAG_typedef)
    <38a>   DW_AT_name        : (indirect string, offset: 0x226): size_t
    <38e>   DW_AT_decl_file   : 2
    <38f>   DW_AT_decl_line   : 216
    <390>   DW_AT_type        : <0x14>
 <1><394>: Abbrev Number: 7 (DW_TAG_const_type)
    <395>   DW_AT_type        : <0x389>
...
which then fails because of a mismatch in DW_FORM (DW_FORM_ref_addr vs
DW_FORM_ref_udata).

OTOH, the long double die in the input file matches the one in the multifile.

Subsequently, we hit this in create_import_tree, and skip generating an import
for the partial unit due to 2be not having a duplicate:
...
      if (unlikely (fi_multifile) && rdie->die_nextdup == NULL)
        {
          pu->u1.cu_icu = NULL;
          continue;
        }
...
OTOH, we need an import for the partial unit due to the long double, which does
have a duplicate.

Tentative patch:
...
@@ -5779,10 +5798,15 @@ create_import_tree (void)
       for (rdie = pu->cu_die->die_child;
           rdie->die_named_namespace; rdie = rdie->die_child)
        ;
-      if (unlikely (fi_multifile) && rdie->die_nextdup == NULL)
+      if (unlikely (fi_multifile))
        {
-         pu->u1.cu_icu = NULL;
-         continue;
+         while (rdie->die_nextdup == NULL && rdie->die_sib)
+           rdie = rdie->die_sib;
+         if (rdie->die_nextdup == NULL)
+           {
+             pu->u1.cu_icu = NULL;
+             continue;
+           }
        }
       npus++;
       if (pu->cu_version > new_pu_version)
...

Using the tentative patch, we get the missing import in CU elf-init.c:
...
 <1><2e4>: Abbrev Number: 15 (DW_TAG_imported_unit)
    <2e5>   DW_AT_import      : <alt 0x2b5>
...
and find again the missing long double with gdb:
...
$ gdb 1 -ex "info types" -batch | egrep "long double|^File"
File /usr/include/bits/types.h:
File /usr/include/libio.h:
File /usr/lib64/gcc/x86_64-suse-linux/7/include/stddef.h:
File <unknown>:
        typedef long double;
...

-- 
You are receiving this mail because:
You are on the CC list for the bug.

      parent reply	other threads:[~2019-04-21  6:29 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-01-01  0:00 [Bug default/24468] New: " vries at gcc dot gnu.org
2019-01-01  0:00 ` [Bug default/24468] " vries at gcc dot gnu.org
2019-01-01  0:00 ` vries at gcc dot gnu.org
2019-01-01  0:00 ` vries at gcc dot gnu.org
2019-01-01  0:00 ` vries at gcc dot gnu.org [this message]

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=bug-24468-11298-hzytuJ5tyX@http.sourceware.org/bugzilla/ \
    --to=sourceware-bugzilla@sourceware.org \
    --cc=dwz@sourceware.org \
    /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;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).