[PATCH] [AArch64] Define BE loader name.
pinskia@gmail.com
pinskia@gmail.com
Wed Jan 1 19:31:00 GMT 2014
> On Jan 1, 2014, at 9:37 AM, Marcus Shawcroft <marcus.shawcroft@linaro.org> wrote:
>
> Hi,
>
> This patch defines the BE loader name for aarch64 to be ld-linux-aarch64_be.so.1.
We (Cavium and Montavista) already have a distro out in the wild for big-endian and I think changing this is a bad idea as you won't have both little-endian and big-endian on the same system ever. Also you forgot to change both GCC and binutils.
Thanks,
Andrew
>
> Cheers
> /Marcus
>
> ---
> ports/ChangeLog.aarch64 | 12 ++
> ports/sysdeps/aarch64/configure | 174 +++++++++++++++++++++++
> ports/sysdeps/aarch64/configure.ac | 22 +++
> ports/sysdeps/aarch64/shlib-versions | 5 +
> ports/sysdeps/unix/sysv/linux/aarch64/Makefile | 15 ++
> ports/sysdeps/unix/sysv/linux/aarch64/ldconfig.h | 1 +
> 6 files changed, 229 insertions(+)
> create mode 100644 ports/sysdeps/aarch64/configure
> create mode 100644 ports/sysdeps/aarch64/configure.ac
>
> diff --git a/ports/ChangeLog.aarch64 b/ports/ChangeLog.aarch64
> index bad3b91..c1602ce 100644
> --- a/ports/ChangeLog.aarch64
> +++ b/ports/ChangeLog.aarch64
> @@ -1,5 +1,17 @@
> 2014-01-01 Marcus Shawcroft <marcus.shawcroft@linaro.org>
>
> + * sysdeps/aarch64/configure.ac: New file.
> + * sysdeps/aarch64/configure: New file.
> + * sysdeps/aarch64/shlib-versions: Define ld-linux-aarch64_be.so.1
> + * sysdeps/unix/sysv/linux/aarch64/Makefile (abi-variants)
> + (abi-lp64-options, abi-lp64-condition, abi-lp64-ld-soname)
> + (abi-lp64_be-options, abi-lp64_be-condition)
> + (abi-lp64_be-ld-soname) Define.
> + * sysdeps/unix/sysv/linux/aarch64/ldconfig.h
> + (SYSDEP_KNOWN_INTERPRETER_NAMES): Add ld-linux-aarch64_be.so.1
> +
> +2014-01-01 Marcus Shawcroft <marcus.shawcroft@linaro.org>
> +
> * sysdeps/aarch64/abort-instr.h: New file.
>
> 2013-12-18 Marcus Shawcroft <marcus.shawcroft@linaro.org>
> diff --git a/ports/sysdeps/aarch64/configure b/ports/sysdeps/aarch64/configure
> new file mode 100644
> index 0000000..af870b7
> --- /dev/null
> +++ b/ports/sysdeps/aarch64/configure
> @@ -0,0 +1,174 @@
> +# This file is generated from configure.ac by Autoconf. DO NOT EDIT!
> + # Local configure fragment for sysdeps/aarch64.
> +
> +# We check to see if the compiler and flags are
> +# selecting the big endian ABI and if they are then
> +# we set libc_cv_aarch64_be to yes which causes
> +# HAVE_AARCH64_BE to be defined in config.h and
> +# in include/libc-symbols.h and thus available to
> +# shlib-versions to select the appropriate name for
> +# the dynamic linker via %ifdef.
> +
> +
> +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for grep that handles long lines and -e" >&5
> +$as_echo_n "checking for grep that handles long lines and -e... " >&6; }
> +if ${ac_cv_path_GREP+:} false; then :
> + $as_echo_n "(cached) " >&6
> +else
> + if test -z "$GREP"; then
> + ac_path_GREP_found=false
> + # Loop through the user's path and test for each of PROGNAME-LIST
> + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
> +for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin
> +do
> + IFS=$as_save_IFS
> + test -z "$as_dir" && as_dir=.
> + for ac_prog in grep ggrep; do
> + for ac_exec_ext in '' $ac_executable_extensions; do
> + ac_path_GREP="$as_dir/$ac_prog$ac_exec_ext"
> + { test -f "$ac_path_GREP" && $as_test_x "$ac_path_GREP"; } || continue
> +# Check for GNU ac_path_GREP and select it if it is found.
> + # Check for GNU $ac_path_GREP
> +case `"$ac_path_GREP" --version 2>&1` in
> +*GNU*)
> + ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_found=:;;
> +*)
> + ac_count=0
> + $as_echo_n 0123456789 >"conftest.in"
> + while :
> + do
> + cat "conftest.in" "conftest.in" >"conftest.tmp"
> + mv "conftest.tmp" "conftest.in"
> + cp "conftest.in" "conftest.nl"
> + $as_echo 'GREP' >> "conftest.nl"
> + "$ac_path_GREP" -e 'GREP$' -e '-(cannot match)-' < "conftest.nl" >"conftest.out" 2>/dev/null || break
> + diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break
> + as_fn_arith $ac_count + 1 && ac_count=$as_val
> + if test $ac_count -gt ${ac_path_GREP_max-0}; then
> + # Best one so far, save it but keep looking for a better one
> + ac_cv_path_GREP="$ac_path_GREP"
> + ac_path_GREP_max=$ac_count
> + fi
> + # 10*(2^10) chars as input seems more than enough
> + test $ac_count -gt 10 && break
> + done
> + rm -f conftest.in conftest.tmp conftest.nl conftest.out;;
> +esac
> +
> + $ac_path_GREP_found && break 3
> + done
> + done
> + done
> +IFS=$as_save_IFS
> + if test -z "$ac_cv_path_GREP"; then
> + as_fn_error $? "no acceptable grep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5
> + fi
> +else
> + ac_cv_path_GREP=$GREP
> +fi
> +
> +fi
> +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_GREP" >&5
> +$as_echo "$ac_cv_path_GREP" >&6; }
> + GREP="$ac_cv_path_GREP"
> +
> +
> +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for egrep" >&5
> +$as_echo_n "checking for egrep... " >&6; }
> +if ${ac_cv_path_EGREP+:} false; then :
> + $as_echo_n "(cached) " >&6
> +else
> + if echo a | $GREP -E '(a|b)' >/dev/null 2>&1
> + then ac_cv_path_EGREP="$GREP -E"
> + else
> + if test -z "$EGREP"; then
> + ac_path_EGREP_found=false
> + # Loop through the user's path and test for each of PROGNAME-LIST
> + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
> +for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin
> +do
> + IFS=$as_save_IFS
> + test -z "$as_dir" && as_dir=.
> + for ac_prog in egrep; do
> + for ac_exec_ext in '' $ac_executable_extensions; do
> + ac_path_EGREP="$as_dir/$ac_prog$ac_exec_ext"
> + { test -f "$ac_path_EGREP" && $as_test_x "$ac_path_EGREP"; } || continue
> +# Check for GNU ac_path_EGREP and select it if it is found.
> + # Check for GNU $ac_path_EGREP
> +case `"$ac_path_EGREP" --version 2>&1` in
> +*GNU*)
> + ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_found=:;;
> +*)
> + ac_count=0
> + $as_echo_n 0123456789 >"conftest.in"
> + while :
> + do
> + cat "conftest.in" "conftest.in" >"conftest.tmp"
> + mv "conftest.tmp" "conftest.in"
> + cp "conftest.in" "conftest.nl"
> + $as_echo 'EGREP' >> "conftest.nl"
> + "$ac_path_EGREP" 'EGREP$' < "conftest.nl" >"conftest.out" 2>/dev/null || break
> + diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break
> + as_fn_arith $ac_count + 1 && ac_count=$as_val
> + if test $ac_count -gt ${ac_path_EGREP_max-0}; then
> + # Best one so far, save it but keep looking for a better one
> + ac_cv_path_EGREP="$ac_path_EGREP"
> + ac_path_EGREP_max=$ac_count
> + fi
> + # 10*(2^10) chars as input seems more than enough
> + test $ac_count -gt 10 && break
> + done
> + rm -f conftest.in conftest.tmp conftest.nl conftest.out;;
> +esac
> +
> + $ac_path_EGREP_found && break 3
> + done
> + done
> + done
> +IFS=$as_save_IFS
> + if test -z "$ac_cv_path_EGREP"; then
> + as_fn_error $? "no acceptable egrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5
> + fi
> +else
> + ac_cv_path_EGREP=$EGREP
> +fi
> +
> + fi
> +fi
> +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_EGREP" >&5
> +$as_echo "$ac_cv_path_EGREP" >&6; }
> + EGREP="$ac_cv_path_EGREP"
> +
> +
> +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for big endian" >&5
> +$as_echo_n "checking for big endian... " >&6; }
> +if ${libc_cv_aarch64_be+:} false; then :
> + $as_echo_n "(cached) " >&6
> +else
> + cat confdefs.h - <<_ACEOF >conftest.$ac_ext
> +/* end confdefs.h. */
> +#ifdef __AARCH64EB__
> + yes
> + #endif
> +
> +_ACEOF
> +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 |
> + $EGREP "yes" >/dev/null 2>&1; then :
> + libc_cv_aarch64_be=yes
> +else
> + libc_cv_aarch64_be=no
> +fi
> +rm -f conftest*
> +
> +fi
> +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $libc_cv_aarch64_be" >&5
> +$as_echo "$libc_cv_aarch64_be" >&6; }
> +if test $libc_cv_aarch64_be = yes; then
> + $as_echo "#define HAVE_AARCH64_BE 1" >>confdefs.h
> +
> + config_vars="$config_vars
> +default-abi = lp64_be"
> +else
> + config_vars="$config_vars
> +default-abi = lp64"
> +fi
> diff --git a/ports/sysdeps/aarch64/configure.ac b/ports/sysdeps/aarch64/configure.ac
> new file mode 100644
> index 0000000..7851dd4
> --- /dev/null
> +++ b/ports/sysdeps/aarch64/configure.ac
> @@ -0,0 +1,22 @@
> +GLIBC_PROVIDES dnl See aclocal.m4 in the top level source directory.
> +# Local configure fragment for sysdeps/aarch64.
> +
> +# We check to see if the compiler and flags are
> +# selecting the big endian ABI and if they are then
> +# we set libc_cv_aarch64_be to yes which causes
> +# HAVE_AARCH64_BE to be defined in config.h and
> +# in include/libc-symbols.h and thus available to
> +# shlib-versions to select the appropriate name for
> +# the dynamic linker via %ifdef.
> +AC_CACHE_CHECK([for big endian],
> + [libc_cv_aarch64_be],
> + [AC_EGREP_CPP(yes,[#ifdef __AARCH64EB__
> + yes
> + #endif
> + ], libc_cv_aarch64_be=yes, libc_cv_aarch64_be=no)])
> +if test $libc_cv_aarch64_be = yes; then
> + AC_DEFINE(HAVE_AARCH64_BE)
> + LIBC_CONFIG_VAR([default-abi], [lp64_be])
> +else
> + LIBC_CONFIG_VAR([default-abi], [lp64])
> +fi
> diff --git a/ports/sysdeps/aarch64/shlib-versions b/ports/sysdeps/aarch64/shlib-versions
> index 82b227d..67f1911 100644
> --- a/ports/sysdeps/aarch64/shlib-versions
> +++ b/ports/sysdeps/aarch64/shlib-versions
> @@ -1,2 +1,7 @@
> aarch64.*-.*-linux.* DEFAULT GLIBC_2.17
> +
> +%ifdef HAVE_AARCH64_BE
> +aarch64.*-.*-linux.* ld=ld-linux-aarch64_be.so.1
> +%else
> aarch64.*-.*-linux.* ld=ld-linux-aarch64.so.1
> +%endif
> diff --git a/ports/sysdeps/unix/sysv/linux/aarch64/Makefile b/ports/sysdeps/unix/sysv/linux/aarch64/Makefile
> index 8a3d76b..d3f1603 100644
> --- a/ports/sysdeps/unix/sysv/linux/aarch64/Makefile
> +++ b/ports/sysdeps/unix/sysv/linux/aarch64/Makefile
> @@ -22,3 +22,18 @@ endif
> ifeq ($(subdir),stdlib)
> gen-as-const-headers += ucontext_i.sym
> endif
> +
> +abi-variants := lp64
> +abi-variants += lp64_be
> +
> +ifeq (,$(filter $(default-abi),$(abi-variants)))
> +Unknown ABI, must be one of $(abi-variants)
> +endif
> +
> +abi-lp64-options := -U__AARCH64EB__
> +abi-lp64-condition := !defined __AARCH64EB__
> +abi-lp64-ld-soname := ld-linux-aarch64.so.1
> +
> +abi-lp64_be-options := -D__AARCH6464EB__
> +abi-lp64_be-condition := defined __AARCH64EB__
> +abi-lp64_be-ld-soname := ld-linux-aarch64_be.so.1
> diff --git a/ports/sysdeps/unix/sysv/linux/aarch64/ldconfig.h b/ports/sysdeps/unix/sysv/linux/aarch64/ldconfig.h
> index 10be197..b0e6b6a 100644
> --- a/ports/sysdeps/unix/sysv/linux/aarch64/ldconfig.h
> +++ b/ports/sysdeps/unix/sysv/linux/aarch64/ldconfig.h
> @@ -20,6 +20,7 @@
>
> #define SYSDEP_KNOWN_INTERPRETER_NAMES \
> { "/lib/ld-linux-aarch64.so.1", FLAG_ELF_LIBC6 }, \
> + { "/lib/ld-linux-aarch64_be.so.1", FLAG_ELF_LIBC6 }, \
> { "/lib/ld-linux.so.3", FLAG_ELF_LIBC6 }, \
> { "/lib/ld-linux-armhf.so.3", FLAG_ELF_LIBC6 },
> #define SYSDEP_KNOWN_LIBRARY_NAMES \
> --
> 1.8.3.2
>
More information about the Libc-ports
mailing list