@@ -3,6 +3,6 @@
sleep()
interrupted - ok
Busy waiting
-interrupted - ok
+Error: Busy wait was not interrupted.
join()
interrupted - ok
I strongly suspect they are related.
FAIL: FileHandleGcTest execution - source compiled test
FAIL: FileHandleGcTest -findirect-dispatch execution - source compiled test
FAIL: FileHandleGcTest -O3 execution - source compiled test
FAIL: FileHandleGcTest -O3 -findirect-dispatch execution - source compiled test
This test fails with
/proc open failed
With par, one sees that after opening /dev/null many times, the /proc
open from boehm-gc fails:
1061mS[ 3]FileHandleGcTest(69051502): open("/dev/null", O_RDONLY, 0666) = 1022
1061mS[ 3]FileHandleGcTest(69051502): open("/dev/null", O_RDONLY, 0666) = 1023
1062mS[ 3]FileHandleGcTest(69051502): open("/dev/null", O_RDONLY, 0666) errno
= 24 (Too many open files)
1063mS[ 3]FileHandleGcTest(69051502): open("/proc/69051502", O_RDONLY, 0) errn
o = 24 (Too many open files)
1063mS[ 3]FileHandleGcTest(69051502): write(2, "/proc open failed\n", 18) = 18
open 1056 0.07 72.78
For some reason, FileNotFoundException isn't raised here.
While I don't formally need approval for this patch (it only affects my
targets), I'll wait a day before committing in case there are comments.
Thanks.
Rainer
2011-06-12 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
PR libgcj/49315
* include/solaris-signal.h: Rename to ...
* include/posix-signal.h: ... this.
(SA_FLAGS): Define.
(SIGNAL_HANDLER): Handle non-SA_SIGINFO case.
(sa_signal_handler): Define.
(_INIT_SIG_HANDLER): New macro.
(INIT_SEGV, INIT_FPE): Use it.
* configure.ac (SIGNAL_HANDLER): Use it on alpha*-dec-osf*,
mips-sgi-irix*, *-*-solaris2*
* configure: Regenerate.
* include/aix-signal.h: Refer to AIX.
* configure.host (alpha*-dec-osf*): Enable can_unwind_signal.
(mips-sgi-irix6*): Likewise.
@@ -1727,12 +1727,12 @@ SYSDEP_SOURCES=
SIGNAL_HANDLER_AUX=
case "${host}" in
+ alpha*-dec-osf* | mips-sgi-irix* | *-*-solaris2*)
+ SIGNAL_HANDLER=include/posix-signal.h
+ ;;
i?86-*-linux*)
SIGNAL_HANDLER=include/i386-signal.h
;;
- *-*-solaris2*)
- SIGNAL_HANDLER=include/solaris-signal.h
- ;;
# ia64-*)
# SYSDEP_SOURCES=sysdep/ia64.c
# test -d sysdep || mkdir sysdep
@@ -274,7 +274,10 @@ EOF
rm -f conftest conftest.c
fi
;;
- i[34567]86*-kfreebsd*-gnu | x86_64*-kfreebsd*-gnu)
+ alpha*-dec-osf*)
+ can_unwind_signal=yes
+ ;;
+ i[34567]86*-kfreebsd*-gnu | x86_64*-kfreebsd*-gnu)
libgcj_ld_symbolic='-Wl,-Bsymbolic'
slow_pthread_self=
;;
@@ -283,6 +286,7 @@ EOF
DIVIDESPEC=-f%{m32:no-}%{!m32:%{!m64:no-}}%{m64:}use-divide-subroutine
;;
mips-sgi-irix6* )
+ can_unwind_signal=yes
sysdeps_dir=mips
;;
arm*-linux* )
@@ -1,7 +1,7 @@
/* aix-signal.h - Catch runtime signals and turn them into exceptions,
- on a Darwin system. */
+ on a AIX system. */
-/* Copyright (C) 2008 Free Software Foundation
+/* Copyright (C) 2008, 2011 Free Software Foundation
This file is part of libgcj.
rename from libjava/include/solaris-signal.h
rename to libjava/include/posix-signal.h
@@ -1,6 +1,6 @@
-// sparc-signal.h - Catch runtime signals and turn them into exceptions.
+// posix-signal.h - Catch runtime signals and turn them into exceptions.
-/* Copyright (C) 1998, 1999, 2000, 2009 Free Software Foundation
+/* Copyright (C) 1998, 1999, 2000, 2009, 2011 Free Software Foundation
This file is part of libgcj.
@@ -16,33 +16,45 @@ details. */
#define HANDLE_SEGV 1
#define HANDLE_FPE 1
+/* Different implementations of MD_FALLBACK_FRAME_STATE_FOR either require
+ SA_SIGINFO being set or fail if so. Cf. gcc/ada/init.c
+ (__gnat_install_handler) for details. */
+
+#if (defined __alpha__ && defined __osf__) \
+ || (defined __sun__ && defined __svr4__)
+#define SA_FLAGS SA_NODEFER | SA_SIGINFO
+#elif defined __sgi__
+#define SA_FLAGS SA_NODEFER
+#else
+#error Must define SA_FLAGS.
+#endif
+
+#if SA_FLAGS & SA_SIGINFO
#define SIGNAL_HANDLER(_name) \
static void _Jv_##_name (int, \
siginfo_t *_si __attribute__ ((__unused__)), \
void *_uc __attribute__ ((__unused__)))
+#define sa_signal_handler sa_sigaction
+#else
+#define SIGNAL_HANDLER(_name) \
+static void _Jv_##_name (int)
+#define sa_signal_handler sa_handler
+#endif
#define MAKE_THROW_FRAME(_exception)
-#define INIT_SEGV \
-do \
- { \
- struct sigaction act; \
- act.sa_sigaction = _Jv_catch_segv; \
- act.sa_flags = SA_SIGINFO | SA_NODEFER; \
- sigemptyset (&act.sa_mask); \
- sigaction (SIGSEGV, &act, NULL); \
- } \
-while (0)
-
-#define INIT_FPE \
-do \
- { \
- struct sigaction act; \
- act.sa_sigaction = _Jv_catch_fpe; \
- act.sa_flags = SA_SIGINFO | SA_NODEFER; \
- sigemptyset (&act.sa_mask); \
- sigaction (SIGFPE, &act, NULL); \
- } \
+#define _INIT_SIG_HANDLER(_SIG, _ACTION) \
+do \
+ { \
+ struct sigaction act; \
+ act.sa_signal_handler = _Jv_##_ACTION; \
+ act.sa_flags = SA_FLAGS; \
+ sigemptyset (&act.sa_mask); \
+ sigaction(_SIG, &act, NULL); \
+ } \
while (0)
+#define INIT_SEGV _INIT_SIG_HANDLER (SIGSEGV, catch_segv)
+#define INIT_FPE _INIT_SIG_HANDLER (SIGFPE, catch_fpe)
+
#endif /* JAVA_SIGNAL_H */