diff --git a/make/lib/Lib-java.base.gmk b/make/lib/Lib-java.base.gmk index 7e00e59784d..714e8d74fc9 100644 --- a/make/lib/Lib-java.base.gmk +++ b/make/lib/Lib-java.base.gmk @@ -159,6 +159,7 @@ ifneq ($(OPENJDK_TARGET_OS), windows) ifeq ($(STATIC_BUILD), false) LIBJSIG_SRC_DIR := $(TOPDIR)/src/java.base/$(OPENJDK_TARGET_OS)/native/libjsig + LIBJSIG_MAPFILE := $(wildcard $(TOPDIR)/make/mapfiles/libjsig/mapfile-vers-$(OPENJDK_TARGET_OS)) ifeq ($(OPENJDK_TARGET_OS), linux) # FIXME: This is probably not what we want to do, but keep it now for compatibility. @@ -174,6 +175,7 @@ ifneq ($(OPENJDK_TARGET_OS), windows) LIBS_linux := $(LIBDL), \ LIBS_solaris := $(LIBDL), \ LIBS_aix := $(LIBDL), \ + MAPFILE := $(LIBJSIG_MAPFILE), \ )) TARGETS += $(BUILD_LIBJSIG) diff --git a/make/mapfiles/libjsig/mapfile-vers-solaris b/make/mapfiles/libjsig/mapfile-vers-solaris new file mode 100644 index 00000000000..ddb46c050ec --- /dev/null +++ b/make/mapfiles/libjsig/mapfile-vers-solaris @@ -0,0 +1,38 @@ +# +# Copyright (c) 2005, 2013, Oracle and/or its affiliates. All rights reserved. +# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. +# +# This code is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License version 2 only, as +# published by the Free Software Foundation. +# +# This code is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +# version 2 for more details (a copy is included in the LICENSE file that +# accompanied this code). +# +# You should have received a copy of the GNU General Public License version +# 2 along with this work; if not, write to the Free Software Foundation, +# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. +# +# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA +# or visit www.oracle.com if you need additional information or have any +# questions. +# +# + +# Define library interface. + +SUNWprivate_1.1 { + global: + JVM_begin_signal_setting; + JVM_end_signal_setting; + JVM_get_libjsig_version; + JVM_get_signal_action; + sigaction; + signal; + sigset; + local: + *; +}; diff --git a/src/java.base/solaris/native/libjsig/jsig.c b/src/java.base/solaris/native/libjsig/jsig.c index 5a9204635ec..ea3b5ab46ab 100644 --- a/src/java.base/solaris/native/libjsig/jsig.c +++ b/src/java.base/solaris/native/libjsig/jsig.c @@ -177,13 +177,11 @@ static sa_handler_t set_signal(int sig, sa_handler_t disp, bool is_sigset) { } } -JNIEXPORT sa_handler_t JNICALL -signal(int sig, sa_handler_t disp) { +sa_handler_t signal(int sig, sa_handler_t disp) { return set_signal(sig, disp, false); } -JNIEXPORT sa_handler_t JNICALL -sigset(int sig, sa_handler_t disp) { +sa_handler_t sigset(int sig, sa_handler_t disp) { return set_signal(sig, disp, true); } @@ -199,8 +197,7 @@ static int call_os_sigaction(int sig, const struct sigaction *act, return (*os_sigaction)(sig, act, oact); } -JNIEXPORT int JNICALL -sigaction(int sig, const struct sigaction *act, struct sigaction *oact) { +int sigaction(int sig, const struct sigaction *act, struct sigaction *oact) { int res; struct sigaction oldAct;