Set dynamic_undefined_weak to zero for static PIEs
authorAlan Modra <amodra@gmail.com>
Thu, 12 Oct 2017 02:49:10 +0000 (13:19 +1030)
committerAlan Modra <amodra@gmail.com>
Thu, 12 Oct 2017 04:07:11 +0000 (14:37 +1030)
I believe we should be warning if ld is given both --no-dynamic-linker
and -z dynamic-undefined-weak.  The two options are contradictory, the
first says an executable has no dynamic interpreter to resolve dynamic
symbols, while the second is asking for dynamic symbols to be emitted.
(And even if a static PIE's relocation code, which is needed to
process R_*_RELATIVE relocs, could process symbols, there are no
DT_NEEDED dynamic objects to define such symbols.)

I also think that dynamic_undefined_weak is the right flag to control
whether undefined weaks are made dynamic, whether in static PIEs or
anywhere else.  So force it to 0 for static PIEs, fixing PR 22269 for
powerpc and any other target where the backend usually defaults to
undefined weaks being made dynamic.

This patch introduces regressions.  I'd normally not do that, but
these are all in very recently added test cases, or expose bugs in the
x86 backend.  The test cases were added after I'd made it known that
this patch or one like it was imminent.

PR 22269
* emultempl/elf32.em (after_parse): Warn on --no-dynamic-linker
-z dynamic-undefined-weak combination.  Set dynamic_undefined_weak
to zero when nointerp.

ld/ChangeLog
ld/emultempl/elf32.em

index 0ae81347213994d71563143147a889c4f3c8aa3f..1331a7bbda2e9d8fa8a62c6be31f355328e8b9c9 100644 (file)
@@ -1,3 +1,10 @@
+2017-10-12  Alan Modra  <amodra@gmail.com>
+
+       PR 22269
+       * emultempl/elf32.em (after_parse): Warn on --no-dynamic-linker
+       -z dynamic-undefined-weak combination.  Set dynamic_undefined_weak
+       to zero when nointerp.
+
 2017-10-12  Alan Modra  <amodra@gmail.com>
 
        * emultempl/elf32.em (before_allocation): Call
index e6cf968544bef63229a20fcb0456e6eb785d7a8e..87373768043b2d268de28e20fc1ee30290869437 100644 (file)
@@ -120,6 +120,13 @@ gld${EMULATION_NAME}_after_parse (void)
   if (bfd_link_pie (&link_info))
     link_info.flags_1 |= (bfd_vma) DF_1_PIE;
 
+  if (bfd_link_executable (&link_info)
+      && link_info.nointerp)
+    {
+      if (link_info.dynamic_undefined_weak > 0)
+       einfo (_("%P: warning: -z dynamic-undefined-weak ignored\n"));
+      link_info.dynamic_undefined_weak = 0;
+    }
   after_parse_default ();
 }