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
This commit is contained in:
parent
0e8285f120
commit
a4e44caa6d
@ -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>
|
1999-04-12 Urban Widmark <urban@svenskatest.se>
|
||||||
|
|
||||||
* java/io/DataInputStream.java (readLine): Corrected handling of
|
* java/io/DataInputStream.java (readLine): Corrected handling of
|
||||||
|
@ -135,7 +135,7 @@ $(nat_files): %.o: %.cc
|
|||||||
$(CXXCOMPILE) -c -o $@ $<
|
$(CXXCOMPILE) -c -o $@ $<
|
||||||
|
|
||||||
$(nat_files) $(GCOBJS) $(THREADOBJS) $(libgcj_a_OBJECTS): \
|
$(nat_files) $(GCOBJS) $(THREADOBJS) $(libgcj_a_OBJECTS): \
|
||||||
include/config.h $(nat_headers)
|
include/config.h include/java-signal.h $(nat_headers)
|
||||||
|
|
||||||
## FIXME: GNU make.
|
## FIXME: GNU make.
|
||||||
$(c_files): %.o: %.c
|
$(c_files): %.o: %.c
|
||||||
|
@ -1191,7 +1191,7 @@ $(nat_files): %.o: %.cc
|
|||||||
$(CXXCOMPILE) -c -o $@ $<
|
$(CXXCOMPILE) -c -o $@ $<
|
||||||
|
|
||||||
$(nat_files) $(GCOBJS) $(THREADOBJS) $(libgcj_a_OBJECTS): \
|
$(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
|
$(c_files): %.o: %.c
|
||||||
$(COMPILE) -c -o $@ $<
|
$(COMPILE) -c -o $@ $<
|
||||||
|
15
libjava/configure
vendored
15
libjava/configure
vendored
@ -3298,6 +3298,17 @@ done
|
|||||||
test -n "$PERL" || PERL="false"
|
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
|
if test "${multilib}" = "yes"; then
|
||||||
multilib_arg="--enable-multilib"
|
multilib_arg="--enable-multilib"
|
||||||
else
|
else
|
||||||
@ -3714,8 +3725,8 @@ fi; done
|
|||||||
EOF
|
EOF
|
||||||
|
|
||||||
cat >> $CONFIG_STATUS <<EOF
|
cat >> $CONFIG_STATUS <<EOF
|
||||||
ac_sources="java/io/$FILE_DESCRIPTOR include/$GCHDR include/$THREADH"
|
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"
|
ac_dests="java/io/natFileDescriptor.cc include/java-gc.h include/java-threads.h include/java-signal.h"
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
cat >> $CONFIG_STATUS <<\EOF
|
cat >> $CONFIG_STATUS <<\EOF
|
||||||
|
@ -362,6 +362,17 @@ AC_FUNC_ALLOCA
|
|||||||
|
|
||||||
AC_CHECK_PROGS(PERL, perl, false)
|
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
|
if test "${multilib}" = "yes"; then
|
||||||
multilib_arg="--enable-multilib"
|
multilib_arg="--enable-multilib"
|
||||||
else
|
else
|
||||||
|
18
libjava/include/default-signal.h
Normal file
18
libjava/include/default-signal.h
Normal file
@ -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 */
|
||||||
|
|
38
libjava/include/i386-signal.h
Normal file
38
libjava/include/i386-signal.h
Normal file
@ -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 */
|
||||||
|
|
@ -14,14 +14,12 @@ details. */
|
|||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#ifdef HANDLE_SEGV
|
|
||||||
#include <signal.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#pragma implementation "java-array.h"
|
#pragma implementation "java-array.h"
|
||||||
|
|
||||||
#include <cni.h>
|
#include <cni.h>
|
||||||
#include <jvm.h>
|
#include <jvm.h>
|
||||||
|
#include <java-signal.h>
|
||||||
|
|
||||||
#include <java/lang/Class.h>
|
#include <java/lang/Class.h>
|
||||||
#include <java/lang/Runtime.h>
|
#include <java/lang/Runtime.h>
|
||||||
@ -30,6 +28,7 @@ details. */
|
|||||||
#include <java/lang/ThreadGroup.h>
|
#include <java/lang/ThreadGroup.h>
|
||||||
#include <java/lang/FirstThread.h>
|
#include <java/lang/FirstThread.h>
|
||||||
#include <java/lang/ArrayIndexOutOfBoundsException.h>
|
#include <java/lang/ArrayIndexOutOfBoundsException.h>
|
||||||
|
#include <java/lang/ArithmeticException.h>
|
||||||
#include <java/lang/ClassFormatError.h>
|
#include <java/lang/ClassFormatError.h>
|
||||||
#include <java/lang/ClassCastException.h>
|
#include <java/lang/ClassCastException.h>
|
||||||
#include <java/lang/NegativeArraySizeException.h>
|
#include <java/lang/NegativeArraySizeException.h>
|
||||||
@ -40,6 +39,7 @@ details. */
|
|||||||
#include <java/lang/reflect/Modifier.h>
|
#include <java/lang/reflect/Modifier.h>
|
||||||
#include <java/io/PrintStream.h>
|
#include <java/io/PrintStream.h>
|
||||||
|
|
||||||
|
|
||||||
#define ObjectClass _CL_Q34java4lang6Object
|
#define ObjectClass _CL_Q34java4lang6Object
|
||||||
extern java::lang::Class ObjectClass;
|
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 java::lang::NullPointerException *nullp;
|
||||||
|
|
||||||
static void
|
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
|
// Don't run `new' in a signal handler, so we always throw the same
|
||||||
// null pointer exception.
|
// exception.
|
||||||
_Jv_Throw (nullp);
|
_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
|
class _Jv_PrimClass : public java::lang::Class
|
||||||
{
|
{
|
||||||
@ -560,14 +572,26 @@ static java::lang::Thread *main_thread;
|
|||||||
void
|
void
|
||||||
JvRunMain (jclass klass, int argc, const char **argv)
|
JvRunMain (jclass klass, int argc, const char **argv)
|
||||||
{
|
{
|
||||||
#ifdef HANDLE_SEGV
|
#ifdef HANDLE_SEGV
|
||||||
nullp = new java::lang::NullPointerException ();
|
{
|
||||||
|
nullp = new java::lang::NullPointerException ();
|
||||||
struct sigaction act;
|
struct sigaction act;
|
||||||
act.sa_handler = catch_segv;
|
act.sa_handler = catch_segv;
|
||||||
sigemptyset (&act.sa_mask);
|
sigemptyset (&act.sa_mask);
|
||||||
act.sa_flags = 0;
|
act.sa_flags = 0;
|
||||||
sigaction (SIGSEGV, &act, NULL);
|
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
|
#endif
|
||||||
|
|
||||||
no_memory = new java::lang::OutOfMemoryError;
|
no_memory = new java::lang::OutOfMemoryError;
|
||||||
|
Loading…
Reference in New Issue
Block a user