sysdeps_dir=i386
libgcj_flags="${libgcj_flags} -ffloat-store"
libgcj_interpreter=yes
- libgcj_cxxflags="-D__NO_MATH_INLINES"
- libgcj_cflags="-D__NO_MATH_INLINES"
+ libgcj_cxxflags=
+ libgcj_cflags=
DIVIDESPEC=-fno-use-divide-subroutine
enable_hash_synchronization_default=yes
slow_pthread_self=yes
CHECKREFSPEC="%{m32:-fcheck-references}"
sysdeps_dir=x86-64
libgcj_flags="${libgcj_flags} -ffloat-store -fno-omit-frame-pointer"
- libgcj_cxxflags="-D__NO_MATH_INLINES"
- libgcj_cflags="-D__NO_MATH_INLINES"
+ libgcj_cxxflags=
+ libgcj_cflags=
enable_hash_synchronization_default=yes
slow_pthread_self=yes
libgcj_interpreter=yes
IEEESPEC=-mieee
;;
powerpc64*-*)
- # libffi not ported.
- with_libffi_default=no
- libgcj_interpreter=no
+ with_libffi_default=yes
+ libgcj_interpreter=yes
libgcj_flags="${libgcj_flags} -mminimal-toc"
# this may not be correct
sysdeps_dir=powerpc
x86_64*-linux* | \
sh-linux* | sh[34]*-linux*)
can_unwind_signal=yes
+ if test x$slow_pthread_self = xyes \
+ && test x$cross_compiling != xyes; then
+ cat > conftest.c <<EOF
+#define _GNU_SOURCE 1
+#include <pthread.h>
+#include <stdlib.h>
+#include <sys/resource.h>
+#include <limits.h>
+
+void *
+tf (void *arg __attribute__ ((unused)))
+{
+ pthread_attr_t a;
+ size_t s;
+
+ if (pthread_getattr_np (pthread_self (), &a)
+ || pthread_attr_getstacksize (&a, &s)
+ || s > 2 * PTHREAD_STACK_MIN)
+ exit (1);
+ exit (0);
+}
+
+int
+main (int argc, char **argv)
+{
+ pthread_t p;
+ void *ret;
+ struct rlimit r;
+
+ if (argc == 2)
+ {
+ r.rlim_cur = 2 * PTHREAD_STACK_MIN;
+ r.rlim_max = 2 * PTHREAD_STACK_MIN;
+ if (setrlimit (RLIMIT_STACK, &r))
+ exit (1);
+ execl (argv[1], argv[0], NULL);
+ exit (1);
+ }
+
+ if (pthread_create (&p, NULL, tf, NULL)
+ || pthread_join (p, &ret))
+ exit (1);
+ exit (1);
+}
+EOF
+ $CC -o conftest conftest.c -lpthread > /dev/null 2>&1 && \
+ ./conftest ./conftest && slow_pthread_self=
+ rm -f conftest conftest.c
+ fi
;;
*-*-darwin*)
enable_hash_synchronization_default=no
*-*-freebsd*)
slow_pthread_self=
;;
+ *-mingw*)
+ # FIXME: win32_exception_handler( ) in win32.cc does not do the
+ # right stuff yet w.r.t. SEH. Live with the following for now.
+ can_unwind_signal=no
+ CHECKREFSPEC=-fcheck-references
+ DIVIDESPEC=-fuse-divide-subroutine
+ ;;
*-cygwin*)
# The cygwin linker doesn't do 8-byte alignment by default, so
# disable hash synchronization for now.