mirror of
git://sourceware.org/git/glibc.git
synced 2024-12-21 04:31:04 +08:00
a4c75cfd56
This patch saves and restores bound registers in symbol lookup for x86-64: 1. Branches without BND prefix clear bound registers. 2. x86-64 pass bounds in bound registers as specified in MPX psABI extension on hjl/mpx/master branch at https://github.com/hjl-tools/x86-64-psABI https://groups.google.com/forum/#!topic/x86-64-abi/KFsB0XTgWYc Binutils has been updated to create an alternate PLT to add BND prefix when branching to ld.so. * config.h.in (HAVE_MPX_SUPPORT): New #undef. * sysdeps/x86_64/configure.ac: Set HAVE_MPX_SUPPORT. * sysdeps/x86_64/configure: Regenerated. * sysdeps/x86_64/dl-trampoline.S (REGISTER_SAVE_AREA): New macro. (REGISTER_SAVE_RAX): Likewise. (REGISTER_SAVE_RCX): Likewise. (REGISTER_SAVE_RDX): Likewise. (REGISTER_SAVE_RSI): Likewise. (REGISTER_SAVE_RDI): Likewise. (REGISTER_SAVE_R8): Likewise. (REGISTER_SAVE_R9): Likewise. (REGISTER_SAVE_BND0): Likewise. (REGISTER_SAVE_BND1): Likewise. (REGISTER_SAVE_BND2): Likewise. (_dl_runtime_resolve): Use them. Save and restore Intel MPX bound registers when calling _dl_fixup.
97 lines
3.0 KiB
Plaintext
97 lines
3.0 KiB
Plaintext
GLIBC_PROVIDES dnl See aclocal.m4 in the top level source directory.
|
|
# Local configure fragment for sysdeps/x86_64.
|
|
|
|
AC_CHECK_HEADER([cpuid.h], ,
|
|
[AC_MSG_ERROR([gcc must provide the <cpuid.h> header])],
|
|
[/* No default includes. */])
|
|
|
|
dnl Check if -msse4 works.
|
|
AC_CACHE_CHECK(for SSE4 support, libc_cv_cc_sse4, [dnl
|
|
LIBC_TRY_CC_OPTION([-msse4], [libc_cv_cc_sse4=yes], [libc_cv_cc_sse4=no])
|
|
])
|
|
if test $libc_cv_cc_sse4 = yes; then
|
|
AC_DEFINE(HAVE_SSE4_SUPPORT)
|
|
fi
|
|
LIBC_CONFIG_VAR([config-cflags-sse4], [$libc_cv_cc_sse4])
|
|
|
|
dnl Check if -mavx works.
|
|
AC_CACHE_CHECK(for AVX support, libc_cv_cc_avx, [dnl
|
|
LIBC_TRY_CC_OPTION([-mavx], [libc_cv_cc_avx=yes], [libc_cv_cc_avx=no])
|
|
])
|
|
if test $libc_cv_cc_avx = yes; then
|
|
AC_DEFINE(HAVE_AVX_SUPPORT)
|
|
fi
|
|
LIBC_CONFIG_VAR([config-cflags-avx], [$libc_cv_cc_avx])
|
|
|
|
dnl Check if asm supports AVX512.
|
|
AC_CACHE_CHECK(for AVX512 support in assembler, libc_cv_asm_avx512, [dnl
|
|
cat > conftest.s <<\EOF
|
|
vmovdqu64 %zmm0, (%rsp)
|
|
EOF
|
|
if AC_TRY_COMMAND(${CC-cc} -c $ASFLAGS conftest.s 1>&AS_MESSAGE_LOG_FD); then
|
|
libc_cv_asm_avx512=yes
|
|
else
|
|
libc_cv_asm_avx512=no
|
|
fi
|
|
rm -f conftest*])
|
|
if test $libc_cv_asm_avx512 == yes; then
|
|
AC_DEFINE(HAVE_AVX512_ASM_SUPPORT)
|
|
fi
|
|
|
|
dnl Check if -mavx512f works.
|
|
AC_CACHE_CHECK(for AVX512 support, libc_cv_cc_avx512, [dnl
|
|
LIBC_TRY_CC_OPTION([-mavx512f], [libc_cv_cc_avx512=$libc_cv_asm_avx512], [libc_cv_cc_avx512=no])
|
|
])
|
|
if test $libc_cv_cc_avx512 = yes; then
|
|
AC_DEFINE(HAVE_AVX512_SUPPORT)
|
|
fi
|
|
LIBC_CONFIG_VAR([config-cflags-avx512], [$libc_cv_cc_avx512])
|
|
|
|
dnl Check if -msse2avx works.
|
|
AC_CACHE_CHECK(for AVX encoding of SSE instructions, libc_cv_cc_sse2avx, [dnl
|
|
LIBC_TRY_CC_OPTION([-msse2avx],
|
|
[libc_cv_cc_sse2avx=yes],
|
|
[libc_cv_cc_sse2avx=no])
|
|
])
|
|
if test $libc_cv_cc_sse2avx = yes; then
|
|
AC_DEFINE(HAVE_SSE2AVX_SUPPORT)
|
|
fi
|
|
LIBC_CONFIG_VAR([config-cflags-sse2avx], [$libc_cv_cc_sse2avx])
|
|
|
|
dnl Check if -mfma4 works.
|
|
AC_CACHE_CHECK(for FMA4 support, libc_cv_cc_fma4, [dnl
|
|
LIBC_TRY_CC_OPTION([-mfma4], [libc_cv_cc_fma4=yes], [libc_cv_cc_fma4=no])
|
|
])
|
|
if test $libc_cv_cc_fma4 = yes; then
|
|
AC_DEFINE(HAVE_FMA4_SUPPORT)
|
|
fi
|
|
LIBC_CONFIG_VAR([have-mfma4], [$libc_cv_cc_fma4])
|
|
|
|
dnl Check if -mno-vzeroupper works.
|
|
AC_CACHE_CHECK(for -mno-vzeroupper support, libc_cv_cc_novzeroupper, [dnl
|
|
LIBC_TRY_CC_OPTION([-mno-vzeroupper],
|
|
[libc_cv_cc_novzeroupper=yes],
|
|
[libc_cv_cc_novzeroupper=no])
|
|
])
|
|
LIBC_CONFIG_VAR([config-cflags-novzeroupper], [$libc_cv_cc_novzeroupper])
|
|
|
|
dnl Check whether asm supports Intel MPX
|
|
AC_CACHE_CHECK(for Intel MPX support, libc_cv_asm_mpx, [dnl
|
|
cat > conftest.s <<\EOF
|
|
bndmov %bnd0,(%rsp)
|
|
EOF
|
|
if AC_TRY_COMMAND(${CC-cc} -c $ASFLAGS conftest.s 1>&AS_MESSAGE_LOG_FD); then
|
|
libc_cv_asm_mpx=yes
|
|
else
|
|
libc_cv_asm_mpx=no
|
|
fi
|
|
rm -f conftest*])
|
|
if test $libc_cv_asm_mpx == yes; then
|
|
AC_DEFINE(HAVE_MPX_SUPPORT)
|
|
fi
|
|
|
|
dnl It is always possible to access static and hidden symbols in an
|
|
dnl position independent way.
|
|
AC_DEFINE(PI_STATIC_AND_HIDDEN)
|
|
# work around problem with autoconf and empty lines at the end of files
|