Skip to content
This repository has been archived by the owner on Feb 5, 2022. It is now read-only.

Commit

Permalink
Consolidate alphasort{64} and versionsort{64} implementation
Browse files Browse the repository at this point in the history
This patch consolidates both alphasort{64} and versionsort{64}
implementation on just the default dirent/alphasort{64}c and
dirent/versionsort{64} respectively.  It changes the logic
to follow the conventions used on other code consolidation:

  * the non-LFS variant is only built for _DIRENT_MATCHES_DIRENT64 being 0.

  * the LFS variant is always built and aliased to getdents for ABIs
    that define _DIRENT_MATCHES_DIRENT64 to 1.

Also on Linux the compat symbol for old non-LFS dirent64 definition
requires a platform-specific scandir64.c.  For powerpc32 and sparcv9
it requires to add specific arch-implementation to override the
generic Linux one because neither ABI exports an compat symbol for
non-LFS alphasort64 and versionsort64 variant.  It is most likely a
bug and it is also not one that can be fixed (in that there would be
existing binaries expecting both meanings of that symbol at its single
existing version, with binaries expecting the new meaning probably much
more common than those expecting the original meaning of that symbol at
that version).

Checked on aarch64-linux-gnu, x86_64-linux-gnu, i686-linux-gnu,
sparcv9-linux-gnu, sparc64-linux-gnu, powerpc-linux-gnu, and
powerpc64le-linux-gnu.

	* dirent/alphasort.c (alphasort): Build iff _DIRENT_MATCHES_DIRENT64 is
	defined.
	* dirent/versionsort.c (versionsort): Likewise.
	* dirent/alphasort64.c (alphasort64): Build regardless and alias to
	alphasort if _DIRENT_MATCHES_DIRENT64 is defined.
	* dirent/versionsort64.c (versionsort64): Likewise.
	* sysdeps/unix/sysv/linux/i386/alphasort64.c: Remove file.
	* sysdeps/unix/sysv/linux/arm/alphasort64.c: Likewise.
	* sysdeps/unix/sysv/linux/arm/versionsort64.c: Likewise.
	* sysdeps/unix/sysv/linux/m68k/alphasort64.c: Likewise.
	* sysdeps/unix/sysv/linux/m68k/versionsort64.c: Likewise.
	* sysdeps/unix/sysv/linux/s390/s390-32/alphasort64.c: Likewise.
	* sysdeps/unix/sysv/linux/s390/s390-32/versionsort64.c: Likewise.
	* sysdeps/unix/sysv/linux/i386/versionsort64.c: Likewise.
	* sysdeps/unix/sysv/linux/alphasort64.c: New file.
	* sysdeps/unix/sysv/linux/versionsort64.c: Likewise.
	* sysdeps/unix/sysv/linux/powerpc/powerpc32/alphasort64.c: Likewise.
	* sysdeps/unix/sysv/linux/powerpc/powerpc32/versionsort64.c: Likewise.
	* sysdeps/unix/sysv/linux/sparc/sparc32/alphasort64.c: Likewise.
	* sysdeps/unix/sysv/linux/sparc/sparc32/versionsort64.c: Likewise.
  • Loading branch information
zatrazz committed Apr 23, 2018
1 parent da5e036 commit af7e376
Show file tree
Hide file tree
Showing 17 changed files with 69 additions and 55 deletions.
23 changes: 23 additions & 0 deletions ChangeLog
@@ -1,3 +1,26 @@
2018-04-23 Adhemerval Zanella <adhemerval.zanella@linaro.org>

* dirent/alphasort.c (alphasort): Build iff _DIRENT_MATCHES_DIRENT64 is
defined.
* dirent/versionsort.c (versionsort): Likewise.
* dirent/alphasort64.c (alphasort64): Build regardless and alias to
alphasort if _DIRENT_MATCHES_DIRENT64 is defined.
* dirent/versionsort64.c (versionsort64): Likewise.
* sysdeps/unix/sysv/linux/i386/alphasort64.c: Remove file.
* sysdeps/unix/sysv/linux/arm/alphasort64.c: Likewise.
* sysdeps/unix/sysv/linux/arm/versionsort64.c: Likewise.
* sysdeps/unix/sysv/linux/m68k/alphasort64.c: Likewise.
* sysdeps/unix/sysv/linux/m68k/versionsort64.c: Likewise.
* sysdeps/unix/sysv/linux/s390/s390-32/alphasort64.c: Likewise.
* sysdeps/unix/sysv/linux/s390/s390-32/versionsort64.c: Likewise.
* sysdeps/unix/sysv/linux/i386/versionsort64.c: Likewise.
* sysdeps/unix/sysv/linux/alphasort64.c: New file.
* sysdeps/unix/sysv/linux/versionsort64.c: Likewise.
* sysdeps/unix/sysv/linux/powerpc/powerpc32/alphasort64.c: Likewise.
* sysdeps/unix/sysv/linux/powerpc/powerpc32/versionsort64.c: Likewise.
* sysdeps/unix/sysv/linux/sparc/sparc32/alphasort64.c: Likewise.
* sysdeps/unix/sysv/linux/sparc/sparc32/versionsort64.c: Likewise.

2018-04-23 Joseph Myers <joseph@codesourcery.com>

* elf/elf.h (NT_PPC_PKEY): New macro.
Expand Down
13 changes: 2 additions & 11 deletions dirent/alphasort.c
Expand Up @@ -15,23 +15,14 @@
License along with the GNU C Library; if not, see
<http://www.gnu.org/licenses/>. */

/* We need to avoid the header declaration of alphasort64, because
the types don't match alphasort and then the compiler will
complain about the mismatch when we do the alias below. */
#define alphasort64 __renamed_alphasort64

#include <dirent.h>

#undef alphasort64

#include <string.h>
#if !_DIRENT_MATCHES_DIRENT64
# include <string.h>

int
alphasort (const struct dirent **a, const struct dirent **b)
{
return strcoll ((*a)->d_name, (*b)->d_name);
}

#if _DIRENT_MATCHES_DIRENT64
weak_alias (alphasort, alphasort64)
#endif
7 changes: 4 additions & 3 deletions dirent/alphasort64.c
Expand Up @@ -15,16 +15,17 @@
License along with the GNU C Library; if not, see
<http://www.gnu.org/licenses/>. */

#define alphasort __no_alphasort_decl
#include <dirent.h>
#undef alphasort
#include <string.h>

/* alphasort.c defines alphasort64 as an alias if _DIRENT_MATCHES_DIRENT64. */
#if !_DIRENT_MATCHES_DIRENT64

int
alphasort64 (const struct dirent64 **a, const struct dirent64 **b)
{
return strcoll ((*a)->d_name, (*b)->d_name);
}

#if _DIRENT_MATCHES_DIRENT64
weak_alias (alphasort64, alphasort)
#endif
12 changes: 2 additions & 10 deletions dirent/versionsort.c
Expand Up @@ -15,23 +15,15 @@
License along with the GNU C Library; if not, see
<http://www.gnu.org/licenses/>. */

/* We need to avoid the header declaration of versionsort64, because
the types don't match versionsort and then the compiler will
complain about the mismatch when we do the alias below. */
#define versionsort64 __renamed_versionsort64

#include <dirent.h>

#undef versionsort64

#include <string.h>
#if !_DIRENT_MATCHES_DIRENT64
# include <string.h>

int
versionsort (const struct dirent **a, const struct dirent **b)
{
return __strverscmp ((*a)->d_name, (*b)->d_name);
}

#if _DIRENT_MATCHES_DIRENT64
weak_alias (versionsort, versionsort64)
#endif
7 changes: 4 additions & 3 deletions dirent/versionsort64.c
Expand Up @@ -15,16 +15,17 @@
License along with the GNU C Library; if not, see
<http://www.gnu.org/licenses/>. */

#define versionsort __no_versionsort_decl
#include <dirent.h>
#undef versionsort
#include <string.h>

/* versionsort.c defines a versionsort64 alias if _DIRENT_MATCHES_DIRENT64. */
#if !_DIRENT_MATCHES_DIRENT64

int
versionsort64 (const struct dirent64 **a, const struct dirent64 **b)
{
return __strverscmp ((*a)->d_name, (*b)->d_name);
}

#if !_DIRENT_MATCHES_DIRENT64
weak_alias (versionsort64, versionsort)
#endif
Expand Up @@ -15,7 +15,9 @@
License along with the GNU C Library; if not, see
<http://www.gnu.org/licenses/>. */

#define alphasort __no_alphasort_decl
#include <dirent.h>
#undef alphasort
#include <string.h>

int
Expand All @@ -24,17 +26,14 @@ __alphasort64 (const struct dirent64 **a, const struct dirent64 **b)
return strcoll ((*a)->d_name, (*b)->d_name);
}

#include <shlib-compat.h>

#if _DIRENT_MATCHES_DIRENT64
weak_alias (__alphasort64, alphasort64)
weak_alias (__alphasort64, alphasort)
#else
# include <shlib-compat.h>
versioned_symbol (libc, __alphasort64, alphasort64, GLIBC_2_2);

#if SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2)

#include <olddirent.h>

int
__old_alphasort64 (const struct __old_dirent64 **a,
const struct __old_dirent64 **b);
# if SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2)
# include <olddirent.h>

int
attribute_compat_text_section
Expand All @@ -45,4 +44,5 @@ __old_alphasort64 (const struct __old_dirent64 **a,
}

compat_symbol (libc, __old_alphasort64, alphasort64, GLIBC_2_1);
#endif
# endif /* SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2) */
#endif /* _DIRENT_MATCHES_DIRENT64 */
1 change: 0 additions & 1 deletion sysdeps/unix/sysv/linux/arm/alphasort64.c

This file was deleted.

1 change: 0 additions & 1 deletion sysdeps/unix/sysv/linux/arm/versionsort64.c

This file was deleted.

1 change: 0 additions & 1 deletion sysdeps/unix/sysv/linux/m68k/alphasort64.c

This file was deleted.

1 change: 0 additions & 1 deletion sysdeps/unix/sysv/linux/m68k/versionsort64.c

This file was deleted.

3 changes: 3 additions & 0 deletions sysdeps/unix/sysv/linux/powerpc/powerpc32/alphasort64.c
@@ -0,0 +1,3 @@
/* Although powerpc32 define _DIRENT_MATCHES_DIRENT64=0 and have compat
mode for 2.1, it does have a compat symbol for alphasort64. */
#include <dirent/alphasort64.c>
3 changes: 3 additions & 0 deletions sysdeps/unix/sysv/linux/powerpc/powerpc32/versionsort64.c
@@ -0,0 +1,3 @@
/* Although powerpc32 define _DIRENT_MATCHES_DIRENT64=0 and have compat
mode for 2.1, it does have a compat symbol for alphasort64. */
#include <dirent/versionsort64.c>
1 change: 0 additions & 1 deletion sysdeps/unix/sysv/linux/s390/s390-32/alphasort64.c

This file was deleted.

1 change: 0 additions & 1 deletion sysdeps/unix/sysv/linux/s390/s390-32/versionsort64.c

This file was deleted.

3 changes: 3 additions & 0 deletions sysdeps/unix/sysv/linux/sparc/sparc32/alphasort64.c
@@ -0,0 +1,3 @@
/* Although sparc32 define _DIRENT_MATCHES_DIRENT64=0 and have compat
mode for 2.1, it does have a compat symbol for alphasort64. */
#include <dirent/alphasort64.c>
3 changes: 3 additions & 0 deletions sysdeps/unix/sysv/linux/sparc/sparc32/versionsort64.c
@@ -0,0 +1,3 @@
/* Although sparc32 define _DIRENT_MATCHES_DIRENT64=0 and have compat
mode for 2.1, it does have a compat symbol for alphasort64. */
#include <dirent/versionsort64.c>
Expand Up @@ -15,7 +15,9 @@
License along with the GNU C Library; if not, see
<http://www.gnu.org/licenses/>. */

#define versionsort __no_versionsort_decl
#include <dirent.h>
#undef versionsort
#include <string.h>

int
Expand All @@ -24,17 +26,14 @@ __versionsort64 (const struct dirent64 **a, const struct dirent64 **b)
return __strverscmp ((*a)->d_name, (*b)->d_name);
}

#include <shlib-compat.h>

#if _DIRENT_MATCHES_DIRENT64
weak_alias (__versionsort64, versionsort64)
weak_alias (__versionsort64, versionsort)
#else
# include <shlib-compat.h>
versioned_symbol (libc, __versionsort64, versionsort64, GLIBC_2_2);

#if SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2)

#include <olddirent.h>

int
__old_versionsort64 (const struct __old_dirent64 **a,
const struct __old_dirent64 **b);
# if SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2)
# include <olddirent.h>

int
attribute_compat_text_section
Expand All @@ -45,4 +44,5 @@ __old_versionsort64 (const struct __old_dirent64 **a,
}

compat_symbol (libc, __old_versionsort64, versionsort64, GLIBC_2_1);
#endif
# endif /* SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2) */
#endif /* _DIRENT_MATCHES_DIRENT64 */

0 comments on commit af7e376

Please sign in to comment.