diff options
author | Tom Tromey <tromey@redhat.com> | 2004-12-21 00:49:45 +0000 |
---|---|---|
committer | Tom Tromey <tromey@gcc.gnu.org> | 2004-12-21 00:49:45 +0000 |
commit | 90d8362105e5fcdbb0e8da463f3315c344e8d2b3 (patch) | |
tree | ebad3395e1e19c088c5c220227ad303db595561a | |
parent | f8c940c55c841f14853e2aba9399f86853a4e19a (diff) | |
download | gcc-90d8362105e5fcdbb0e8da463f3315c344e8d2b3.zip gcc-90d8362105e5fcdbb0e8da463f3315c344e8d2b3.tar.gz gcc-90d8362105e5fcdbb0e8da463f3315c344e8d2b3.tar.bz2 |
re PR libgcj/15001 ([3.4 only] Using JNI with interpreter and interface methods yields SIGSEGV)
PR java/15001
* testsuite/libjava.jni/iface.c: New file.
* testsuite/libjava.jni/iface.out: New file.
* testsuite/libjava.jni/iface.java: New file.
From-SVN: r92445
-rw-r--r-- | libjava/ChangeLog | 7 | ||||
-rw-r--r-- | libjava/testsuite/libjava.jni/iface.c | 40 | ||||
-rw-r--r-- | libjava/testsuite/libjava.jni/iface.java | 27 | ||||
-rw-r--r-- | libjava/testsuite/libjava.jni/iface.out | 2 |
4 files changed, 76 insertions, 0 deletions
diff --git a/libjava/ChangeLog b/libjava/ChangeLog index 05dede3..e307a83 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,10 @@ +2004-12-20 Tom Tromey <tromey@redhat.com> + + PR java/15001 + * testsuite/libjava.jni/iface.c: New file. + * testsuite/libjava.jni/iface.out: New file. + * testsuite/libjava.jni/iface.java: New file. + 2004-12-19 Kelley Cook <kcook@gcc.gnu.org> * include/config.h.in: Regenerate. diff --git a/libjava/testsuite/libjava.jni/iface.c b/libjava/testsuite/libjava.jni/iface.c new file mode 100644 index 0000000..6d33dc0 --- /dev/null +++ b/libjava/testsuite/libjava.jni/iface.c @@ -0,0 +1,40 @@ +#include <stdlib.h> +#include <stdio.h> +#include <iface.h> + +void check (JNIEnv *); + +void check(JNIEnv *env) +{ + if ((*env)->ExceptionCheck(env) != JNI_FALSE) + { + fprintf(stderr, "UNEXPECTED EXCEPTION\n"); + exit(-1); + } +} + +void +Java_iface_doCalls (JNIEnv *env, jobject self, jobject other) +{ + jclass iface_class, comparable_class; + jmethodID iface_meth, comparable_meth; + jvalue args[1]; + + iface_class = (*env)->FindClass(env, "iface"); + check (env); + comparable_class = (*env)->FindClass (env, "mycomp"); + check (env); + + iface_meth = (*env)->GetMethodID (env, iface_class, "compareTo", + "(Ljava/lang/Object;)I"); + check (env); + comparable_meth = (*env)->GetMethodID (env, comparable_class, "compareTo", + "(Ljava/lang/Object;)I"); + check (env); + + args[0].l = other; + (*env)->CallObjectMethodA (env, self, iface_meth, args); + check (env); + (*env)->CallObjectMethodA (env, self, comparable_meth, args); + check (env); +} diff --git a/libjava/testsuite/libjava.jni/iface.java b/libjava/testsuite/libjava.jni/iface.java new file mode 100644 index 0000000..c878ae3 --- /dev/null +++ b/libjava/testsuite/libjava.jni/iface.java @@ -0,0 +1,27 @@ +// JNI calls via an interface method were broken in a couple releases. + +interface mycomp +{ + int compareTo(Object x); +} + +public class iface implements mycomp +{ + static + { + System.loadLibrary("iface"); + } + + public int compareTo (Object x) + { + System.out.println ("hi maude"); + return 3; + } + + public native void doCalls(Object x); + + public static void main (String[] args) + { + new iface().doCalls(args); + } +} diff --git a/libjava/testsuite/libjava.jni/iface.out b/libjava/testsuite/libjava.jni/iface.out new file mode 100644 index 0000000..4eb3a1b --- /dev/null +++ b/libjava/testsuite/libjava.jni/iface.out @@ -0,0 +1,2 @@ +hi maude +hi maude |