From a4e44caa6d2a951af67aefb76ee22f7735bf293b Mon Sep 17 00:00:00 2001 From: Andrew Haley Date: Tue, 13 Apr 1999 09:18:09 +0000 Subject: [PATCH] i386-signal.h, [...]: New files. 1999-04-13 Andrew Haley * 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 --- libjava/ChangeLog | 11 +++++++ libjava/Makefile.am | 2 +- libjava/Makefile.in | 2 +- libjava/configure | 15 +++++++-- libjava/configure.in | 11 +++++++ libjava/include/default-signal.h | 18 ++++++++++ libjava/include/i386-signal.h | 38 ++++++++++++++++++++++ libjava/prims.cc | 56 +++++++++++++++++++++++--------- 8 files changed, 133 insertions(+), 20 deletions(-) create mode 100644 libjava/include/default-signal.h create mode 100644 libjava/include/i386-signal.h diff --git a/libjava/ChangeLog b/libjava/ChangeLog index 9b8323a7c0d..3314bc4373f 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,14 @@ +1999-04-13 Andrew Haley + + * 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 * java/io/DataInputStream.java (readLine): Corrected handling of diff --git a/libjava/Makefile.am b/libjava/Makefile.am index 615ebd1512a..3fc60512caa 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 cd6da4ce4ad..25dd1877a85 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 84067083648..2ee202177c0 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 <> $CONFIG_STATUS <<\EOF diff --git a/libjava/configure.in b/libjava/configure.in index 98083c9d6da..e2fa12fa2f4 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 00000000000..63ba129320c --- /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 00000000000..de893afbbf3 --- /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 + +#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 265e281dcb1..70dc89c1e9b 100644 --- a/libjava/prims.cc +++ b/libjava/prims.cc @@ -14,14 +14,12 @@ details. */ #include #include #include -#ifdef HANDLE_SEGV -#include -#endif #pragma implementation "java-array.h" #include #include +#include #include #include @@ -30,6 +28,7 @@ details. */ #include #include #include +#include #include #include #include @@ -40,6 +39,7 @@ details. */ #include #include + #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;