diff options
author | Andrew Haley <aph@cygnus.com> | 1999-04-13 09:18:09 +0000 |
---|---|---|
committer | Andrew Haley <aph@gcc.gnu.org> | 1999-04-13 09:18:09 +0000 |
commit | a4e44caa6d2a951af67aefb76ee22f7735bf293b (patch) | |
tree | cf855e7be72eac99926b727b8a0fd3ad8e4cccde | |
parent | 0e8285f1200b2feb78876c3edfe53637cf2577da (diff) | |
download | gcc-a4e44caa6d2a951af67aefb76ee22f7735bf293b.zip gcc-a4e44caa6d2a951af67aefb76ee22f7735bf293b.tar.gz gcc-a4e44caa6d2a951af67aefb76ee22f7735bf293b.tar.bz2 |
i386-signal.h, [...]: New files.
1999-04-13 Andrew Haley <aph@cygnus.com>
* include/i386-signal.h, include/default-signal.h: New files.
* prims.cc (catch_segv): Call MAKE_THROW_FRAME in exception
handler.
(catch_fpe): New function.
* configure.in: Make link to appropriate include/java-signal.h.
* configure: Rebuilt.
* Makefile.am: include/java-signal.h added to dependency list.
* Makefile.in: Rebuilt.
From-SVN: r26400
-rw-r--r-- | libjava/ChangeLog | 11 | ||||
-rw-r--r-- | libjava/Makefile.am | 2 | ||||
-rw-r--r-- | libjava/Makefile.in | 2 | ||||
-rwxr-xr-x | libjava/configure | 15 | ||||
-rw-r--r-- | libjava/configure.in | 11 | ||||
-rw-r--r-- | libjava/include/default-signal.h | 18 | ||||
-rw-r--r-- | libjava/include/i386-signal.h | 38 | ||||
-rw-r--r-- | libjava/prims.cc | 56 |
8 files changed, 133 insertions, 20 deletions
diff --git a/libjava/ChangeLog b/libjava/ChangeLog index 9b8323a..3314bc4 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,14 @@ +1999-04-13 Andrew Haley <aph@cygnus.com> + + * include/i386-signal.h, include/default-signal.h: New files. + * prims.cc (catch_segv): Call MAKE_THROW_FRAME in exception + handler. + (catch_fpe): New function. + * configure.in: Make link to appropriate include/java-signal.h. + * configure: Rebuilt. + * Makefile.am: include/java-signal.h added to dependency list. + * Makefile.in: Rebuilt. + 1999-04-12 Urban Widmark <urban@svenskatest.se> * java/io/DataInputStream.java (readLine): Corrected handling of diff --git a/libjava/Makefile.am b/libjava/Makefile.am index 615ebd1..3fc6051 100644 --- a/libjava/Makefile.am +++ b/libjava/Makefile.am @@ -135,7 +135,7 @@ $(nat_files): %.o: %.cc $(CXXCOMPILE) -c -o $@ $< $(nat_files) $(GCOBJS) $(THREADOBJS) $(libgcj_a_OBJECTS): \ - include/config.h $(nat_headers) + include/config.h include/java-signal.h $(nat_headers) ## FIXME: GNU make. $(c_files): %.o: %.c diff --git a/libjava/Makefile.in b/libjava/Makefile.in index cd6da4c..25dd187 100644 --- a/libjava/Makefile.in +++ b/libjava/Makefile.in @@ -1191,7 +1191,7 @@ $(nat_files): %.o: %.cc $(CXXCOMPILE) -c -o $@ $< $(nat_files) $(GCOBJS) $(THREADOBJS) $(libgcj_a_OBJECTS): \ - include/config.h $(nat_headers) + include/config.h include/java-signal.h $(nat_headers) $(c_files): %.o: %.c $(COMPILE) -c -o $@ $< diff --git a/libjava/configure b/libjava/configure index 8406708..2ee2021 100755 --- a/libjava/configure +++ b/libjava/configure @@ -3298,6 +3298,17 @@ done test -n "$PERL" || PERL="false" +case "${host}" in + i?86-*-linux*) + SIGNAL_HANDLER=include/i386-signal.h + ;; + *) + SIGNAL_HANDLER=include/default-signal.h + ;; +esac + + + if test "${multilib}" = "yes"; then multilib_arg="--enable-multilib" else @@ -3714,8 +3725,8 @@ fi; done EOF cat >> $CONFIG_STATUS <<EOF -ac_sources="java/io/$FILE_DESCRIPTOR include/$GCHDR include/$THREADH" -ac_dests="java/io/natFileDescriptor.cc include/java-gc.h include/java-threads.h" +ac_sources="java/io/$FILE_DESCRIPTOR include/$GCHDR include/$THREADH $SIGNAL_HANDLER" +ac_dests="java/io/natFileDescriptor.cc include/java-gc.h include/java-threads.h include/java-signal.h" EOF cat >> $CONFIG_STATUS <<\EOF diff --git a/libjava/configure.in b/libjava/configure.in index 98083c9..e2fa12f 100644 --- a/libjava/configure.in +++ b/libjava/configure.in @@ -362,6 +362,17 @@ AC_FUNC_ALLOCA AC_CHECK_PROGS(PERL, perl, false) +case "${host}" in + i?86-*-linux*) + SIGNAL_HANDLER=include/i386-signal.h + ;; + *) + SIGNAL_HANDLER=include/default-signal.h + ;; +esac + +AC_LINK_FILES($SIGNAL_HANDLER, include/java-signal.h) + if test "${multilib}" = "yes"; then multilib_arg="--enable-multilib" else diff --git a/libjava/include/default-signal.h b/libjava/include/default-signal.h new file mode 100644 index 0000000..63ba129 --- /dev/null +++ b/libjava/include/default-signal.h @@ -0,0 +1,18 @@ +// default-signal.h - Catch runtime signals and turn them into exceptions. + +/* Copyright (C) 1998, 1999 Cygnus Solutions + + This file is part of libgcj. + +This software is copyrighted work licensed under the terms of the +Libgcj License. Please consult the file "LIBGCJ_LICENSE" for +details. */ + +#ifndef JAVA_SIGNAL_H +#define JAVA_SIGNAL_H 1 + +#undef HANDLE_SEGV +#undef HANDLE_FPE + +#endif /* JAVA_SIGNAL_H */ + diff --git a/libjava/include/i386-signal.h b/libjava/include/i386-signal.h new file mode 100644 index 0000000..de893af --- /dev/null +++ b/libjava/include/i386-signal.h @@ -0,0 +1,38 @@ +// i386-signal.h - Catch runtime signals and turn them into exceptions. + +/* Copyright (C) 1998, 1999 Cygnus Solutions + + This file is part of libgcj. + +This software is copyrighted work licensed under the terms of the +Libgcj License. Please consult the file "LIBGCJ_LICENSE" for +details. */ + +/* This technique should work for all i386 based Unices which conform + to iBCS2. This includes all versions of Linux more recent than + version 1.3 */ + + +#ifndef JAVA_SIGNAL_H +#define JAVA_SIGNAL_H 1 + +#include <signal.h> + +#define HANDLE_SEGV 1 +#define HANDLE_FPE 1 + + +#define MAKE_THROW_FRAME(_dummy) \ +{ \ + void **_p = (void **)&_dummy; \ + struct sigcontext_struct *_regs = (struct sigcontext_struct *)++_p; \ + \ + register unsigned long _ebp = _regs->ebp; \ + register unsigned long _eip = _regs->eip; \ + \ + asm volatile ("mov %0, (%%ebp); mov %1, 4(%%ebp)" \ + : : "r"(_ebp), "r"(_eip)); \ +} + +#endif /* JAVA_SIGNAL_H */ + diff --git a/libjava/prims.cc b/libjava/prims.cc index 265e281..70dc89c 100644 --- a/libjava/prims.cc +++ b/libjava/prims.cc @@ -14,14 +14,12 @@ details. */ #include <stdarg.h> #include <stdio.h> #include <string.h> -#ifdef HANDLE_SEGV -#include <signal.h> -#endif #pragma implementation "java-array.h" #include <cni.h> #include <jvm.h> +#include <java-signal.h> #include <java/lang/Class.h> #include <java/lang/Runtime.h> @@ -30,6 +28,7 @@ details. */ #include <java/lang/ThreadGroup.h> #include <java/lang/FirstThread.h> #include <java/lang/ArrayIndexOutOfBoundsException.h> +#include <java/lang/ArithmeticException.h> #include <java/lang/ClassFormatError.h> #include <java/lang/ClassCastException.h> #include <java/lang/NegativeArraySizeException.h> @@ -40,6 +39,7 @@ details. */ #include <java/lang/reflect/Modifier.h> #include <java/io/PrintStream.h> + #define ObjectClass _CL_Q34java4lang6Object extern java::lang::Class ObjectClass; @@ -426,19 +426,31 @@ _Jv_NewMultiArray (jclass array_type, jint dimensions, ...) -#ifdef HANDLE_SEGV - +#ifdef HANDLE_SEGV static java::lang::NullPointerException *nullp; static void -catch_segv (int) +catch_segv (int dummy) { + MAKE_THROW_FRAME(dummy); // Don't run `new' in a signal handler, so we always throw the same - // null pointer exception. + // exception. _Jv_Throw (nullp); } +#endif -#endif /* HANDLE_SEGV */ +#ifdef HANDLE_FPE +static java::lang::ArithmeticException *arithexception; + +static void +catch_fpe (int dummy) +{ + MAKE_THROW_FRAME(dummy); + // Don't run `new' in a signal handler, so we always throw the same + // exception. + _Jv_Throw (arithexception); +} +#endif class _Jv_PrimClass : public java::lang::Class { @@ -560,14 +572,26 @@ static java::lang::Thread *main_thread; void JvRunMain (jclass klass, int argc, const char **argv) { -#ifdef HANDLE_SEGV - nullp = new java::lang::NullPointerException (); - - struct sigaction act; - act.sa_handler = catch_segv; - sigemptyset (&act.sa_mask); - act.sa_flags = 0; - sigaction (SIGSEGV, &act, NULL); +#ifdef HANDLE_SEGV + { + nullp = new java::lang::NullPointerException (); + struct sigaction act; + act.sa_handler = catch_segv; + sigemptyset (&act.sa_mask); + act.sa_flags = 0; + sigaction (SIGSEGV, &act, NULL); + } +#endif + +#ifdef HANDLE_FPE + { + arithexception = new java::lang::ArithmeticException (); + struct sigaction act; + act.sa_handler = catch_fpe; + sigemptyset (&act.sa_mask); + act.sa_flags = 0; + sigaction (SIGFPE, &act, NULL); + } #endif no_memory = new java::lang::OutOfMemoryError; |