annotate test/runtime/jsig/TestJNI.c @ 11147:732af649bc3a

8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20 Summary: Added (sig < MAXSIGNUM) check in jsig.c Reviewed-by: dholmes, acorn
author ccheung
date Wed, 17 Jul 2013 12:22:57 -0700
parents
children 72727c4b6dec
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
11147
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
1 /*
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
2 * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
4 *
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
7 * published by the Free Software Foundation.
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
8 *
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
13 * accompanied this code).
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
14 *
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
18 *
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
21 * questions.
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
22 */
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
23
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
24 #include <stdio.h>
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
25 #include <jni.h>
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
26 #define __USE_GNU
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
27 #include <signal.h>
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
28 #include <sys/ucontext.h>
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
29
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
30 #ifdef __cplusplus
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
31 extern "C" {
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
32 #endif
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
33
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
34 void sig_handler(int sig, siginfo_t *info, ucontext_t *context) {
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
35 int thrNum;
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
36
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
37 printf( " HANDLER (1) " );
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
38 // Move forward RIP to skip failing instruction
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
39 context->uc_mcontext.gregs[REG_RIP] += 6;
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
40 }
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
41
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
42 JNIEXPORT void JNICALL Java_TestJNI_doSomething(JNIEnv *env, jclass klass, jint val) {
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
43 struct sigaction act;
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
44 struct sigaction oact;
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
45 pthread_attr_t attr;
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
46 stack_t stack;
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
47
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
48 act.sa_flags = SA_ONSTACK|SA_RESTART|SA_SIGINFO;
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
49 sigfillset(&act.sa_mask);
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
50 act.sa_handler = SIG_DFL;
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
51 act.sa_sigaction = (void (*)())sig_handler;
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
52 sigaction(0x20+val, &act, &oact);
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
53
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
54 printf( " doSomething(%d) " , val);
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
55 printf( " old handler = %p " , oact.sa_handler);
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
56 }
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
57
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
58 #ifdef __cplusplus
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
59 }
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
60 #endif
732af649bc3a 8017498: JVM crashes when native code calls sigaction(sig) where sig>=0x20
ccheung
parents:
diff changeset
61