gold: Remove the circular IFUNC dependency in ifuncmain6pie
authorH.J. Lu <hjl.tools@gmail.com>
Mon, 18 Jan 2021 00:43:45 +0000 (16:43 -0800)
committerH.J. Lu <hjl.tools@gmail.com>
Mon, 18 Jan 2021 00:43:59 +0000 (16:43 -0800)
On Fedora 33 x86-64 with glibc 2.32-3, ifuncmain6pie failed with:

./ifuncmain6pie: IFUNC symbol 'foo' referenced in './ifuncmod6.so' is defined in the executable and creates an unsatisfiable circular dependency.
FAIL ifuncmain6pie (exit status: 127)

Remove non-JUMP_SLOT relocations against foo in ifuncmod6.so, which
trigger the circular IFUNC dependency.

* testsuite/ifuncmain6pie.c: Remove non-JUMP_SLOT relocations
against foo in ifuncmod6.so.
* testsuite/ifuncmod6.c: Likewise.

gold/ChangeLog
gold/testsuite/ifuncmain6pie.c
gold/testsuite/ifuncmod6.c

index 33d97ddde9cb9963df327cba14ec7d61ff3ab826..a1d3d3004f0bf58a88299bb7c73404203eddff2f 100644 (file)
@@ -1,3 +1,9 @@
+2021-01-17  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * testsuite/ifuncmain6pie.c: Remove non-JUMP_SLOT relocations
+       against foo in ifuncmod6.so.
+       * testsuite/ifuncmod6.c: Likewise.
+
 2021-01-14  Nick Clifton  <nickc@redhat.com>
 
        * po/fr.po: Updated French translation.
index 8478d4c408d16c1dc107245e1040217d02d85ae2..5c3eb60d4e538c9aff90eb64716747799a96de95 100644 (file)
@@ -9,7 +9,6 @@
 #include "ifunc-sel.h"
 
 typedef int (*foo_p) (void);
-extern foo_p foo_ptr;
 
 static int
 one (void)
@@ -27,20 +26,17 @@ foo_ifunc (void)
 }
 
 extern int foo (void);
-extern foo_p get_foo (void);
+extern int call_foo (void);
 extern foo_p get_foo_p (void);
 
-foo_p my_foo_ptr = foo;
+foo_p foo_ptr = foo;
 
 int
 main (void)
 {
   foo_p p;
 
-  p = get_foo ();
-  if (p != foo)
-    abort ();
-  if ((*p) () != -30)
+  if (call_foo () != -30)
     abort ();
 
   p = get_foo_p ();
@@ -51,12 +47,8 @@ main (void)
 
   if (foo_ptr != foo)
     abort ();
-  if (my_foo_ptr != foo)
-    abort ();
   if ((*foo_ptr) () != -30)
     abort ();
-  if ((*my_foo_ptr) () != -30)
-    abort ();
   if (foo () != -30)
     abort ();
 
index 89a50f931b489f9bcfbd4e948c42b3861055c5de..d324a82d5eaac260f260fbe6a20cfcfdc9a4128f 100644 (file)
@@ -5,9 +5,9 @@ extern int foo (void);
 typedef int (*foo_p) (void);
 
 extern foo_p get_foo_p (void);
-extern foo_p get_foo (void);
+extern int call_foo (void);
 
-foo_p foo_ptr = foo;
+extern foo_p foo_ptr;
 
 foo_p
 get_foo_p (void)
@@ -15,8 +15,8 @@ get_foo_p (void)
   return foo_ptr;
 }
 
-foo_p
-get_foo (void)
+int
+call_foo (void)
 {
-  return foo;
+  return foo ();
 }