8153286: Move sun.misc.GC to java.rmi ( sun.rmi.transport )

Reviewed-by: alanb, erikj
This commit is contained in:
Chris Hegarty 2016-04-04 17:51:41 +01:00
parent c4831260e1
commit 631346147a
7 changed files with 96 additions and 7 deletions

View File

@ -0,0 +1,53 @@
#
# Copyright (c) 2016, 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. Oracle designates this
# particular file as subject to the "Classpath" exception as provided
# by Oracle in the LICENSE file that accompanied this code.
#
# 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.
#
include LibCommon.gmk
################################################################################
$(eval $(call SetupNativeCompilation,BUILD_LIBRMI, \
LIBRARY := rmi, \
OUTPUT_DIR := $(INSTALL_LIBRARIES_HERE), \
SRC := $(JDK_TOPDIR)/src/java.rmi/share/native/librmi, \
OPTIMIZATION := LOW, \
CFLAGS := $(CFLAGS_JDKLIB) -I$(SUPPORT_OUTPUTDIR)/headers/java.rmi, \
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/librmi/mapfile-vers, \
LDFLAGS := $(LDFLAGS_JDKLIB) \
$(call SET_SHARED_LIBRARY_ORIGIN), \
LIBS_unix := -ljvm, \
LIBS_windows := jvm.lib, \
VERSIONINFO_RESOURCE := $(GLOBAL_VERSION_INFO_RESOURCE), \
RC_FLAGS := $(RC_FLAGS) \
-D "JDK_FNAME=rmi.dll" \
-D "JDK_INTERNAL_NAME=rmi" \
-D "JDK_FTYPE=0x2L", \
OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/librmi, \
))
$(BUILD_LIBRMI): $(call FindLib, java.base, java)
TARGETS += $(BUILD_LIBRMI)
################################################################################

View File

@ -259,7 +259,6 @@ SUNWprivate_1.1 {
Java_java_io_Console_istty; Java_java_io_Console_istty;
Java_java_io_Console_encoding; Java_java_io_Console_encoding;
Java_java_io_Console_echo; Java_java_io_Console_echo;
Java_sun_misc_GC_maxObjectInspectionAge;
Java_sun_reflect_NativeConstructorAccessorImpl_newInstance0; Java_sun_reflect_NativeConstructorAccessorImpl_newInstance0;
Java_sun_reflect_NativeMethodAccessorImpl_invoke0; Java_sun_reflect_NativeMethodAccessorImpl_invoke0;
Java_sun_reflect_Reflection_getCallerClass__; Java_sun_reflect_Reflection_getCallerClass__;

View File

@ -0,0 +1,31 @@
#
# Copyright (c) 2016, 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. Oracle designates this
# particular file as subject to the "Classpath" exception as provided
# by Oracle in the LICENSE file that accompanied this code.
#
# 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.
#
SUNWprivate_1.1 {
global:
Java_sun_rmi_transport_GC_maxObjectInspectionAge;
local:
*;
};

View File

@ -41,7 +41,6 @@ import java.rmi.dgc.DGC;
import java.rmi.dgc.Lease; import java.rmi.dgc.Lease;
import java.rmi.dgc.VMID; import java.rmi.dgc.VMID;
import java.rmi.server.ObjID; import java.rmi.server.ObjID;
import sun.misc.GC;
import sun.rmi.runtime.NewThreadAction; import sun.rmi.runtime.NewThreadAction;
import sun.rmi.server.UnicastRef; import sun.rmi.server.UnicastRef;
import sun.rmi.server.Util; import sun.rmi.server.Util;

View File

@ -23,7 +23,7 @@
* questions. * questions.
*/ */
package sun.misc; package sun.rmi.transport;
import java.security.AccessController; import java.security.AccessController;
import java.security.PrivilegedAction; import java.security.PrivilegedAction;
@ -38,7 +38,7 @@ import java.util.TreeSet;
* @since 1.2 * @since 1.2
*/ */
public class GC { class GC {
private GC() { } /* To prevent instantiation */ private GC() { } /* To prevent instantiation */
@ -82,6 +82,14 @@ public class GC {
*/ */
public static native long maxObjectInspectionAge(); public static native long maxObjectInspectionAge();
static {
AccessController.doPrivileged(new PrivilegedAction<Void>() {
public Void run() {
System.loadLibrary("rmi");
return null;
}});
}
private static class Daemon extends Thread { private static class Daemon extends Thread {
public void run() { public void run() {

View File

@ -34,7 +34,6 @@ import java.security.AccessController;
import java.security.PrivilegedAction; import java.security.PrivilegedAction;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import sun.misc.GC;
import sun.rmi.runtime.Log; import sun.rmi.runtime.Log;
import sun.rmi.runtime.NewThreadAction; import sun.rmi.runtime.NewThreadAction;

View File

@ -25,11 +25,11 @@
#include <jni.h> #include <jni.h>
#include <jvm.h> #include <jvm.h>
#include "sun_misc_GC.h" #include "sun_rmi_transport_GC.h"
JNIEXPORT jlong JNICALL JNIEXPORT jlong JNICALL
Java_sun_misc_GC_maxObjectInspectionAge(JNIEnv *env, jclass cls) Java_sun_rmi_transport_GC_maxObjectInspectionAge(JNIEnv *env, jclass cls)
{ {
return JVM_MaxObjectInspectionAge(); return JVM_MaxObjectInspectionAge();
} }