]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Fix posix_fadvise64 build on mips64n64
authorAdhemerval Zanella <adhemerval.zanella@linaro.org>
Wed, 12 Oct 2016 16:06:22 +0000 (13:06 -0300)
committerAdhemerval Zanella <adhemerval.zanella@linaro.org>
Wed, 12 Oct 2016 16:21:08 +0000 (13:21 -0300)
Recent binutils versions (at least 2.27) complains about libc.so
when linking sotruss-lib.so with:

  libc.so:(*IND*+0x0): multiple definition of `posix_fadvise64@GLIBC_2.2'
  libc.so::(.text+0xcf940): first defined here
  libc.so:(*IND*+0x0): multiple definition of `posix_fadvise64'
  collect2: error: ld returned 1 exit status

Dynamic symbols for libc.so shows (readelf --dyn-syms):

   262: 000000000010b950    28 FUNC    GLOBAL DEFAULT   12 posix_fadvise64@GLIBC_2.2
   417: 000000000010b950    28 FUNC    WEAK   DEFAULT   12 posix_fadvise64@@GLIBC_2.2
  1505: 000000000010b950    28 FUNC    GLOBAL DEFAULT   12 posix_fadvise64@@GLIBC_2.3.3

That is, two separate definitions at version GLIBC_2.2. The issue is
sysdeps/unix/sysv/linux/posix_fadvise64.c creates posix_fadvise64 weak_alias,
while sysdeps/unix/sysv/linux/mips/mips64/n64/posix_fadvise64.c then adds
compat_symbol / versioned_symbol calls.

The patch remove the weak_alias definition on mips64 specific version so
direct weak_alias is disabled.

Checked on mips64n64 build with binutils 2.27.51.20161012.

* sysdeps/unix/sysv/linux/mips/mips64/n64/posix_fadvise64.c:
Undefine weak_alias.

ChangeLog
sysdeps/unix/sysv/linux/mips/mips64/n64/posix_fadvise64.c

index 81dd89ff27c420a1e1d4f7604b28f51cfdd2eccd..2ca9eb1f87b4df9f30ad652b016aa305325e3deb 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2016-10-12  Adhemerval Zanela  <adhemerval.zanella@linaro.org>
+
+       * sysdeps/unix/sysv/linux/mips/mips64/n64/posix_fadvise64.c:
+       Undefine weak_alias and add a comment why mips64 require
+       versioning.
+
 2016-10-12  H.J. Lu  <hongjiu.lu@intel.com>
 
        [BZ #20647]
index d7aab2545f7e0df2e2b8c84990c7d2a1afca7d19..bc756e9b84d970aa32909a2a8dbdfba620727f88 100644 (file)
    License along with the GNU C Library; if not, see
    <http://www.gnu.org/licenses/>.  */
 
+#undef weak_alias
+#define weak_alias(a, b)
 #undef strong_alias
 #define strong_alias(a, b)
 
 #include <sysdeps/unix/sysv/linux/posix_fadvise64.c>
 
+/* Although both posix_fadvise and posix_fadvise64 has the same semantic
+   on mips64, there were were releases with both symbol versions (BZ#14044).
+   So we need to continue export them.  */
 #if SHLIB_COMPAT(libc, GLIBC_2_2, GLIBC_2_3_3)
 _strong_alias (__posix_fadvise64_l64, __posix_fadvise64_l32);
 compat_symbol (libc, __posix_fadvise64_l32, posix_fadvise64, GLIBC_2_2);