Add sparc configure checks for GOTDATA support.
* config.h.in (HAVE_BINUTILS_GOTDATA): New. (HAVE_GCC_GOTDATA): New. * sysdeps/sparc/elf/configure.in: Test for GOTDATA relocation support in both binutils and gcc. * sysdeps/sparc/elf/configure: Regenerate.
This commit is contained in:
parent
3a2545a0f3
commit
c80098a9a0
|
@ -1,5 +1,11 @@
|
||||||
2012-02-20 David S. Miller <davem@davemloft.net>
|
2012-02-20 David S. Miller <davem@davemloft.net>
|
||||||
|
|
||||||
|
* config.h.in (HAVE_BINUTILS_GOTDATA): New.
|
||||||
|
(HAVE_GCC_GOTDATA): New.
|
||||||
|
* sysdeps/sparc/elf/configure.in: Test for GOTDATA
|
||||||
|
relocation support in both binutils and gcc.
|
||||||
|
* sysdeps/sparc/elf/configure: Regenerate.
|
||||||
|
|
||||||
* sysdeps/sparc/sparc32/elf/configure.in: Delete.
|
* sysdeps/sparc/sparc32/elf/configure.in: Delete.
|
||||||
* sysdeps/sparc/sparc32/elf/configure: Delete.
|
* sysdeps/sparc/sparc32/elf/configure: Delete.
|
||||||
* sysdeps/sparc/sparc64/elf/configure.in: Delete.
|
* sysdeps/sparc/sparc64/elf/configure.in: Delete.
|
||||||
|
|
|
@ -87,6 +87,12 @@
|
||||||
certain registers (CR0, MQ, CTR, LR) in asm statements. */
|
certain registers (CR0, MQ, CTR, LR) in asm statements. */
|
||||||
#undef BROKEN_PPC_ASM_CR0
|
#undef BROKEN_PPC_ASM_CR0
|
||||||
|
|
||||||
|
/* Defined on SPARC if as and ld both support GOTDATA relocations. */
|
||||||
|
#undef HAVE_BINUTILS_GOTDATA
|
||||||
|
|
||||||
|
/* Defined on SPARC if GCC emits GOTDATA relocations. */
|
||||||
|
#undef HAVE_GCC_GOTDATA
|
||||||
|
|
||||||
/* Define if the linker supports the -z combreloc option. */
|
/* Define if the linker supports the -z combreloc option. */
|
||||||
#undef HAVE_Z_COMBRELOC
|
#undef HAVE_Z_COMBRELOC
|
||||||
|
|
||||||
|
|
|
@ -136,3 +136,76 @@ $as_echo "$libc_cv_sparc_tls" >&6; }
|
||||||
if test $libc_cv_sparc_tls = no; then
|
if test $libc_cv_sparc_tls = no; then
|
||||||
as_fn_error $? "the assembler must support TLS" "$LINENO" 5
|
as_fn_error $? "the assembler must support TLS" "$LINENO" 5
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Check for GOTDATA relocation support in assembler and linker.
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for sparc binutils GOTDATA reloc support" >&5
|
||||||
|
$as_echo_n "checking for sparc binutils GOTDATA reloc support... " >&6; }
|
||||||
|
if ${libc_cv_sparc_gotdata+:} false; then :
|
||||||
|
$as_echo_n "(cached) " >&6
|
||||||
|
else
|
||||||
|
cat > conftest.S <<\EOF
|
||||||
|
.data
|
||||||
|
.globl data
|
||||||
|
data: .word 0
|
||||||
|
.text
|
||||||
|
.globl foo
|
||||||
|
foo: sethi %gdop_hix22(data), %g1
|
||||||
|
xor %g1, %gdop_lox10(data), %g1
|
||||||
|
#ifdef __arch64__
|
||||||
|
ldx [%l7 + %g1], %g1, %gdop(data)
|
||||||
|
#else
|
||||||
|
ld [%l7 + %g1], %g1, %gdop(data)
|
||||||
|
#endif
|
||||||
|
EOF
|
||||||
|
if { ac_try='${CC-cc} -c $CFLAGS conftest.S 1>&5'
|
||||||
|
{ { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_try\""; } >&5
|
||||||
|
(eval $ac_try) 2>&5
|
||||||
|
ac_status=$?
|
||||||
|
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
|
||||||
|
test $ac_status = 0; }; }; then
|
||||||
|
libc_cv_sparc_gotdata=yes
|
||||||
|
else
|
||||||
|
libc_cv_sparc_gotdata=no
|
||||||
|
fi
|
||||||
|
rm -f conftest*
|
||||||
|
fi
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $libc_cv_sparc_gotdata" >&5
|
||||||
|
$as_echo "$libc_cv_sparc_gotdata" >&6; }
|
||||||
|
if test $libc_cv_sparc_gotdata = yes; then
|
||||||
|
$as_echo "#define HAVE_BINUTILS_GOTDATA 1" >>confdefs.h
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check for a GCC emitting GOTDATA relocations.
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for sparc gcc GOTDATA reloc support" >&5
|
||||||
|
$as_echo_n "checking for sparc gcc GOTDATA reloc support... " >&6; }
|
||||||
|
if ${libc_cv_sparc_gcc_gotdata+:} false; then :
|
||||||
|
$as_echo_n "(cached) " >&6
|
||||||
|
else
|
||||||
|
cat > conftest.c <<\EOF
|
||||||
|
int data;
|
||||||
|
int foo(void)
|
||||||
|
{
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
libc_cv_sparc_gcc_gotdata=no
|
||||||
|
if { ac_try='${CC-cc} -S $CFLAGS -O2 -fPIC conftest.c 1>&5'
|
||||||
|
{ { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_try\""; } >&5
|
||||||
|
(eval $ac_try) 2>&5
|
||||||
|
ac_status=$?
|
||||||
|
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
|
||||||
|
test $ac_status = 0; }; }; then
|
||||||
|
if grep -q 'gdop_hix22' conftest.s \
|
||||||
|
&& grep -q 'gdop_lox10' conftest.s; then
|
||||||
|
libc_cv_sparc_gcc_gotdata=yes
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
rm -f conftest*
|
||||||
|
fi
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $libc_cv_sparc_gcc_gotdata" >&5
|
||||||
|
$as_echo "$libc_cv_sparc_gcc_gotdata" >&6; }
|
||||||
|
if test $libc_cv_sparc_gcc_gotdata = yes; then
|
||||||
|
$as_echo "#define HAVE_GCC_GOTDATA 1" >>confdefs.h
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
|
@ -45,3 +45,56 @@ rm -f conftest*])
|
||||||
if test $libc_cv_sparc_tls = no; then
|
if test $libc_cv_sparc_tls = no; then
|
||||||
AC_MSG_ERROR([the assembler must support TLS])
|
AC_MSG_ERROR([the assembler must support TLS])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Check for GOTDATA relocation support in assembler and linker.
|
||||||
|
AC_CACHE_CHECK(for sparc binutils GOTDATA reloc support, libc_cv_sparc_gotdata, [dnl
|
||||||
|
changequote(,)dnl
|
||||||
|
cat > conftest.S <<\EOF
|
||||||
|
.data
|
||||||
|
.globl data
|
||||||
|
data: .word 0
|
||||||
|
.text
|
||||||
|
.globl foo
|
||||||
|
foo: sethi %gdop_hix22(data), %g1
|
||||||
|
xor %g1, %gdop_lox10(data), %g1
|
||||||
|
#ifdef __arch64__
|
||||||
|
ldx [%l7 + %g1], %g1, %gdop(data)
|
||||||
|
#else
|
||||||
|
ld [%l7 + %g1], %g1, %gdop(data)
|
||||||
|
#endif
|
||||||
|
EOF
|
||||||
|
changequote([,])dnl
|
||||||
|
dnl
|
||||||
|
if AC_TRY_COMMAND(${CC-cc} -c $CFLAGS conftest.S 1>&AS_MESSAGE_LOG_FD); then
|
||||||
|
libc_cv_sparc_gotdata=yes
|
||||||
|
else
|
||||||
|
libc_cv_sparc_gotdata=no
|
||||||
|
fi
|
||||||
|
rm -f conftest*])
|
||||||
|
if test $libc_cv_sparc_gotdata = yes; then
|
||||||
|
AC_DEFINE(HAVE_BINUTILS_GOTDATA)
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check for a GCC emitting GOTDATA relocations.
|
||||||
|
AC_CACHE_CHECK(for sparc gcc GOTDATA reloc support, libc_cv_sparc_gcc_gotdata, [dnl
|
||||||
|
changequote(,)dnl
|
||||||
|
cat > conftest.c <<\EOF
|
||||||
|
int data;
|
||||||
|
int foo(void)
|
||||||
|
{
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
changequote([,])dnl
|
||||||
|
dnl
|
||||||
|
libc_cv_sparc_gcc_gotdata=no
|
||||||
|
if AC_TRY_COMMAND(${CC-cc} -S $CFLAGS -O2 -fPIC conftest.c 1>&AS_MESSAGE_LOG_FD); then
|
||||||
|
if grep -q 'gdop_hix22' conftest.s \
|
||||||
|
&& grep -q 'gdop_lox10' conftest.s; then
|
||||||
|
libc_cv_sparc_gcc_gotdata=yes
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
rm -f conftest*])
|
||||||
|
if test $libc_cv_sparc_gcc_gotdata = yes; then
|
||||||
|
AC_DEFINE(HAVE_GCC_GOTDATA)
|
||||||
|
fi
|
||||||
|
|
Loading…
Reference in New Issue