Fix detection of missing plugin for LTO objects.
authorMartin Liska <mliska@suse.cz>
Fri, 16 Aug 2019 11:14:36 +0000 (13:14 +0200)
committerMartin Liska <mliska@suse.cz>
Fri, 16 Aug 2019 11:14:36 +0000 (13:14 +0200)
2019-08-16  Martin Liska  <mliska@suse.cz>

PR ld/24912
* elflink.c: Report error only for not relocatable.
* linker.c (_bfd_generic_link_add_one_symbol): Do not handle
here lto_slim_object as it's handled in caller.
2019-08-16  Martin Liska  <mliska@suse.cz>

PR ld/24912
* object.cc (big_endian>::do_layout): Do not report error,
but only set a flag.
(big_endian>::do_add_symbols): Report error only for when
relocatable.

bfd/ChangeLog
bfd/elflink.c
bfd/linker.c
gold/ChangeLog
gold/object.cc

index 5c3efb94c887f2f6be208a13912338035471c41e..868796a8c1077e3d1637f398584056df66051347 100644 (file)
@@ -1,3 +1,10 @@
+2019-08-16  Martin Liska  <mliska@suse.cz>
+
+       PR ld/24912
+       * elflink.c: Report error only for not relocatable.
+       * linker.c (_bfd_generic_link_add_one_symbol): Do not handle
+       here lto_slim_object as it's handled in caller.
+
 2019-08-16  Alan Modra  <amodra@gmail.com>
 
        * elf32-ppc.c (ppc_elf_relocate_section): Optimize unaligned relocs.
index c7440d19ff0f82bf14e01a398d010bc1ff22e840..16d83bb7a3035357bb47260800c83085bc039fa6 100644 (file)
@@ -4401,7 +4401,8 @@ error_free_dyn:
       goto error_free_vers;
     }
 
-  if (abfd->lto_slim_object)
+  if (!bfd_link_relocatable (info)
+      && abfd->lto_slim_object)
     {
       _bfd_error_handler
        (_("%pB: plugin needed to handle lto object"), abfd);
index edbd0a7df46901e016f43659ed6b6bdf588c560e..1b71fcf8f0d59f0de0363300394425e7ad7ee676 100644 (file)
@@ -1421,24 +1421,12 @@ _bfd_generic_link_add_one_symbol (struct bfd_link_info *info,
   else if (bfd_is_com_section (section))
     {
       row = COMMON_ROW;
-      static bfd_boolean report_plugin_err = TRUE;
-      if (!bfd_link_relocatable (info) && report_plugin_err)
-       {
-         if (abfd->lto_slim_object)
-           {
-             report_plugin_err = FALSE;
-             _bfd_error_handler
-               (_("%pB: plugin needed to handle lto object"), abfd);
-           }
-         else if (name[0] == '_'
-                  && name[1] == '_'
-                  && strcmp (name + (name[2] == '_'), "__gnu_lto_slim") == 0)
-           {
-             report_plugin_err = FALSE;
-             _bfd_error_handler
-               (_("%pB: plugin needed to handle lto object"), abfd);
-           }
-       }
+      if (!bfd_link_relocatable (info)
+         && name[0] == '_'
+         && name[1] == '_'
+         && strcmp (name + (name[2] == '_'), "__gnu_lto_slim") == 0)
+       _bfd_error_handler
+         (_("%pB: plugin needed to handle lto object"), abfd);
     }
   else
     row = DEF_ROW;
index 85af0a3f873c19095df0fcb53aabce7e5cae8d05..6fe991d80d0c1e8d0669f80b5d73afbbbc1f2f03 100644 (file)
@@ -1,3 +1,11 @@
+2019-08-16  Martin Liska  <mliska@suse.cz>
+
+       PR ld/24912
+       * object.cc (big_endian>::do_layout): Do not report error,
+       but only set a flag.
+       (big_endian>::do_add_symbols): Report error only for when
+       relocatable.
+
 2019-08-02  Alan Modra  <amodra@gmail.com>
 
        * powerpc.cc (Target_powerpc::Scan::get_reference_flags): Set
index 86c519acf72db919ff1f6f2f5540f1514dbf3e10..d505ce4752002b2bb2966f3ec1f94a7df4ec65e1 100644 (file)
@@ -1887,8 +1887,7 @@ Sized_relobj_file<size, big_endian>::do_layout(Symbol_table* symtab,
          const unsigned char* pcontents = this->section_contents(i, &contents_len, false);
          struct lto_section lsection = *(const lto_section*)pcontents;
          if (lsection.slim_object)
-           gold_info(_("%s: plugin needed to handle lto object"),
-                     this->name().c_str());
+           layout->set_lto_slim_object ();
        }
     }
 
@@ -2127,7 +2126,8 @@ Sized_relobj_file<size, big_endian>::do_add_symbols(Symbol_table* symtab,
 
   this->symbols_.resize(symcount);
 
-  if (layout->is_lto_slim_object ())
+  if (!parameters->options().relocatable()
+      && layout->is_lto_slim_object ())
     gold_info(_("%s: plugin needed to handle lto object"),
              this->name().c_str());