diff options
author | ian <ian@138bc75d-0d04-0410-961f-82ee72b054a4> | 2011-04-01 00:17:10 +0000 |
---|---|---|
committer | ian <ian@138bc75d-0d04-0410-961f-82ee72b054a4> | 2011-04-01 00:17:10 +0000 |
commit | fa5e552e3f86f30019911f7945591ff1075a6ab3 (patch) | |
tree | 1d35f4a468c6955c0b5b5237323b06554d53e500 /libgo | |
parent | 27efa7f88c88ff5a3124e61570673a949a7ec72b (diff) | |
download | gcc-fa5e552e3f86f30019911f7945591ff1075a6ab3.tar.gz |
libgo: Recognize MIPS ABIs.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@171809 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libgo')
-rw-r--r-- | libgo/configure | 125 | ||||
-rw-r--r-- | libgo/configure.ac | 44 |
2 files changed, 134 insertions, 35 deletions
diff --git a/libgo/configure b/libgo/configure index e8f88f3c901..375406d9e95 100644 --- a/libgo/configure +++ b/libgo/configure @@ -629,8 +629,14 @@ LIBGO_IS_PPC64_FALSE LIBGO_IS_PPC64_TRUE LIBGO_IS_PPC_FALSE LIBGO_IS_PPC_TRUE -LIBGO_IS_MIPS64_FALSE -LIBGO_IS_MIPS64_TRUE +LIBGO_IS_MIPSO64_FALSE +LIBGO_IS_MIPSO64_TRUE +LIBGO_IS_MIPSN64_FALSE +LIBGO_IS_MIPSN64_TRUE +LIBGO_IS_MIPSN32_FALSE +LIBGO_IS_MIPSN32_TRUE +LIBGO_IS_MIPSO32_FALSE +LIBGO_IS_MIPSO32_TRUE LIBGO_IS_MIPS_FALSE LIBGO_IS_MIPS_TRUE LIBGO_IS_M68K_FALSE @@ -10904,7 +10910,7 @@ else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF -#line 10907 "configure" +#line 10913 "configure" #include "confdefs.h" #if HAVE_DLFCN_H @@ -11010,7 +11016,7 @@ else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF -#line 11013 "configure" +#line 11019 "configure" #include "confdefs.h" #if HAVE_DLFCN_H @@ -13285,8 +13291,7 @@ fi is_386=no is_arm=no is_m68k=no -is_mips=no -is_mips64=no +mips_abi="" is_ppc=no is_ppc64=no is_sparc=no @@ -13326,21 +13331,59 @@ rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ -#ifdef __mips64 -#error 64-bit +#if _MIPS_SIM != _ABIO32 +#error not o32 +#endif +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + mips_abi="o32" +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +#if _MIPS_SIM != _ABIN32 +#error not n32 #endif _ACEOF if ac_fn_c_try_compile "$LINENO"; then : - is_mips=yes + mips_abi="n32" else - is_mips64=yes + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +#if _MIPS_SIM != _ABI64 +#error not n64 +#endif +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + mips_abi="n64" +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +#if _MIPS_SIM != _ABIO64 +#error not o64 +#endif +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + mips_abi="o64" +else + as_fn_error "unknown MIPS ABI" "$LINENO" 5 +mips_abi="n32" fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - if test "$is_mips" = "yes"; then - GOARCH=mips - else - GOARCH=mips64 - fi +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + case "$mips_abi" in + "o32") GOARCH=mipso32 ;; + "n32") GOARCH=mipsn32 ;; + "n64") GOARCH=mipsn64 ;; + "o64") GOARCH=mipso64 ;; + esac ;; rs6000*-*-* | powerpc*-*-*) cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -13407,7 +13450,7 @@ else LIBGO_IS_M68K_FALSE= fi - if test $is_mips = yes; then + if test $mips_abi != ""; then LIBGO_IS_MIPS_TRUE= LIBGO_IS_MIPS_FALSE='#' else @@ -13415,12 +13458,36 @@ else LIBGO_IS_MIPS_FALSE= fi - if test $is_mips64 = yes; then - LIBGO_IS_MIPS64_TRUE= - LIBGO_IS_MIPS64_FALSE='#' + if test $mips_abi = o32; then + LIBGO_IS_MIPSO32_TRUE= + LIBGO_IS_MIPSO32_FALSE='#' +else + LIBGO_IS_MIPSO32_TRUE='#' + LIBGO_IS_MIPSO32_FALSE= +fi + + if test $mips_abi = n32; then + LIBGO_IS_MIPSN32_TRUE= + LIBGO_IS_MIPSN32_FALSE='#' else - LIBGO_IS_MIPS64_TRUE='#' - LIBGO_IS_MIPS64_FALSE= + LIBGO_IS_MIPSN32_TRUE='#' + LIBGO_IS_MIPSN32_FALSE= +fi + + if test $mips_abi = n64; then + LIBGO_IS_MIPSN64_TRUE= + LIBGO_IS_MIPSN64_FALSE='#' +else + LIBGO_IS_MIPSN64_TRUE='#' + LIBGO_IS_MIPSN64_FALSE= +fi + + if test $mips_abi = o64; then + LIBGO_IS_MIPSO64_TRUE= + LIBGO_IS_MIPSO64_FALSE='#' +else + LIBGO_IS_MIPSO64_TRUE='#' + LIBGO_IS_MIPSO64_FALSE= fi if test $is_ppc = yes; then @@ -14541,8 +14608,20 @@ if test -z "${LIBGO_IS_MIPS_TRUE}" && test -z "${LIBGO_IS_MIPS_FALSE}"; then as_fn_error "conditional \"LIBGO_IS_MIPS\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi -if test -z "${LIBGO_IS_MIPS64_TRUE}" && test -z "${LIBGO_IS_MIPS64_FALSE}"; then - as_fn_error "conditional \"LIBGO_IS_MIPS64\" was never defined. +if test -z "${LIBGO_IS_MIPSO32_TRUE}" && test -z "${LIBGO_IS_MIPSO32_FALSE}"; then + as_fn_error "conditional \"LIBGO_IS_MIPSO32\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${LIBGO_IS_MIPSN32_TRUE}" && test -z "${LIBGO_IS_MIPSN32_FALSE}"; then + as_fn_error "conditional \"LIBGO_IS_MIPSN32\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${LIBGO_IS_MIPSN64_TRUE}" && test -z "${LIBGO_IS_MIPSN64_FALSE}"; then + as_fn_error "conditional \"LIBGO_IS_MIPSN64\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${LIBGO_IS_MIPSO64_TRUE}" && test -z "${LIBGO_IS_MIPSO64_FALSE}"; then + as_fn_error "conditional \"LIBGO_IS_MIPSO64\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${LIBGO_IS_PPC_TRUE}" && test -z "${LIBGO_IS_PPC_FALSE}"; then diff --git a/libgo/configure.ac b/libgo/configure.ac index 5bb5df4c1b9..0a98a1e2e2b 100644 --- a/libgo/configure.ac +++ b/libgo/configure.ac @@ -139,8 +139,7 @@ dnl N.B. Keep in sync with gcc/testsuite/go.test/go-test.exp (go-set-goarch). is_386=no is_arm=no is_m68k=no -is_mips=no -is_mips64=no +mips_abi="" is_ppc=no is_ppc64=no is_sparc=no @@ -172,15 +171,33 @@ changequote([,])dnl ;; mips*-*-*) AC_COMPILE_IFELSE([ -#ifdef __mips64 -#error 64-bit +#if _MIPS_SIM != _ABIO32 +#error not o32 #endif], -[is_mips=yes], [is_mips64=yes]) - if test "$is_mips" = "yes"; then - GOARCH=mips - else - GOARCH=mips64 - fi +[mips_abi="o32"], + [AC_COMPILE_IFELSE([ +#if _MIPS_SIM != _ABIN32 +#error not n32 +#endif], +[mips_abi="n32"], + [AC_COMPILE_IFELSE([ +#if _MIPS_SIM != _ABI64 +#error not n64 +#endif], +[mips_abi="n64"], + [AC_COMPILE_IFELSE([ +#if _MIPS_SIM != _ABIO64 +#error not o64 +#endif], +[mips_abi="o64"], + [AC_MSG_ERROR([unknown MIPS ABI]) +[mips_abi="n32"]])])])]) + case "$mips_abi" in + "o32") GOARCH=mipso32 ;; + "n32") GOARCH=mipsn32 ;; + "n64") GOARCH=mipsn64 ;; + "o64") GOARCH=mipso64 ;; + esac ;; rs6000*-*-* | powerpc*-*-*) AC_COMPILE_IFELSE([ @@ -210,8 +227,11 @@ esac AM_CONDITIONAL(LIBGO_IS_386, test $is_386 = yes) AM_CONDITIONAL(LIBGO_IS_ARM, test $is_arm = yes) AM_CONDITIONAL(LIBGO_IS_M68K, test $is_m68k = yes) -AM_CONDITIONAL(LIBGO_IS_MIPS, test $is_mips = yes) -AM_CONDITIONAL(LIBGO_IS_MIPS64, test $is_mips64 = yes) +AM_CONDITIONAL(LIBGO_IS_MIPS, test $mips_abi != "") +AM_CONDITIONAL(LIBGO_IS_MIPSO32, test $mips_abi = o32) +AM_CONDITIONAL(LIBGO_IS_MIPSN32, test $mips_abi = n32) +AM_CONDITIONAL(LIBGO_IS_MIPSN64, test $mips_abi = n64) +AM_CONDITIONAL(LIBGO_IS_MIPSO64, test $mips_abi = o64) AM_CONDITIONAL(LIBGO_IS_PPC, test $is_ppc = yes) AM_CONDITIONAL(LIBGO_IS_PPC64, test $is_ppc64 = yes) AM_CONDITIONAL(LIBGO_IS_SPARC, test $is_sparc = yes) |