Merge
This commit is contained in:
commit
0d4e0d1ed0
2
.hgtags
2
.hgtags
@ -152,3 +152,5 @@ c51754cddc037b9609e202b9ed38363d8683e7a8 jdk8-b27
|
|||||||
16ba58282d117247f480aae7a79b88141ade52a3 jdk8-b28
|
16ba58282d117247f480aae7a79b88141ade52a3 jdk8-b28
|
||||||
e070119aa56ee4dc5506c19d2c4d2eecab8ad429 jdk8-b29
|
e070119aa56ee4dc5506c19d2c4d2eecab8ad429 jdk8-b29
|
||||||
23da7804aca0c9c4e6e86532a1453125a76d95ee jdk8-b30
|
23da7804aca0c9c4e6e86532a1453125a76d95ee jdk8-b30
|
||||||
|
bac81e9f7d57b75fba5ab31b571f3fe0dc08af69 jdk8-b31
|
||||||
|
2c5208ccb863db936eab523f49450b3fcd230348 jdk8-b32
|
||||||
|
@ -152,3 +152,5 @@ cc771d92284f71765eca14d6d08703c4af254c04 jdk8-b21
|
|||||||
6e2541d60f4e342b5b67140271d7611643929dc3 jdk8-b28
|
6e2541d60f4e342b5b67140271d7611643929dc3 jdk8-b28
|
||||||
41460de042580bc4a4ce3f863779c66f39cb8578 jdk8-b29
|
41460de042580bc4a4ce3f863779c66f39cb8578 jdk8-b29
|
||||||
6cea54809b51db92979c22fd8aa8fcb1cb13d12e jdk8-b30
|
6cea54809b51db92979c22fd8aa8fcb1cb13d12e jdk8-b30
|
||||||
|
0b66f43b89a6c0ac1c15d7ec51992c541cdc9089 jdk8-b31
|
||||||
|
88176171e940f02916a312c265a34c32552a8376 jdk8-b32
|
||||||
|
@ -152,3 +152,5 @@ e45d6b406d5f91ff5256a5c82456ab1e7eb8becd jdk8-b25
|
|||||||
2082eb35d49a9c2aab90b8d4fd31cefb7a23b82e jdk8-b28
|
2082eb35d49a9c2aab90b8d4fd31cefb7a23b82e jdk8-b28
|
||||||
6117395d422682f89d228347e319fcaac7edc729 jdk8-b29
|
6117395d422682f89d228347e319fcaac7edc729 jdk8-b29
|
||||||
4605f8418bf562e78be79b25b6b8a5110281acae jdk8-b30
|
4605f8418bf562e78be79b25b6b8a5110281acae jdk8-b30
|
||||||
|
1954151dfae8f73db24e396380f7c02bdd47c486 jdk8-b31
|
||||||
|
5d820cb6b1afd75b619e7fd69e4f2b0eb1d5d6a1 jdk8-b32
|
||||||
|
@ -232,3 +232,7 @@ b45b5c564098c58ea69e7cff3f7d341f0254dd1d jdk8-b29
|
|||||||
d61761bf305031c94f7f8eca49abd978b7d3c5da jdk8-b30
|
d61761bf305031c94f7f8eca49abd978b7d3c5da jdk8-b30
|
||||||
dfae0140457cfb2c381d7679735fbedbae862c62 hs24-b03
|
dfae0140457cfb2c381d7679735fbedbae862c62 hs24-b03
|
||||||
f4767e53d6e0d5da7e3f1775904076cce54247c1 hs24-b04
|
f4767e53d6e0d5da7e3f1775904076cce54247c1 hs24-b04
|
||||||
|
0cd147eaa673d1642b2f466f5dc257cf192db524 jdk8-b31
|
||||||
|
27863e4586de38be7dd17da4163f542038f4d1d7 hs24-b05
|
||||||
|
25410a347ebb0bef166c4338a90d9dea82463a20 jdk8-b32
|
||||||
|
cd47da9383cd932cb2b659064057feafa2a91134 hs24-b06
|
||||||
|
@ -359,6 +359,12 @@ public class InstanceKlass extends Klass {
|
|||||||
public static final int innerClassNextOffset = 4;
|
public static final int innerClassNextOffset = 4;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
public static interface EnclosingMethodAttributeOffset {
|
||||||
|
public static final int enclosing_method_class_index_offset = 0;
|
||||||
|
public static final int enclosing_method_method_index_offset = 1;
|
||||||
|
public static final int enclosing_method_attribute_size = 2;
|
||||||
|
};
|
||||||
|
|
||||||
// refer to compute_modifier_flags in VM code.
|
// refer to compute_modifier_flags in VM code.
|
||||||
public long computeModifierFlags() {
|
public long computeModifierFlags() {
|
||||||
long access = getAccessFlags();
|
long access = getAccessFlags();
|
||||||
@ -367,9 +373,14 @@ public class InstanceKlass extends Klass {
|
|||||||
int length = ( innerClassList == null)? 0 : (int) innerClassList.getLength();
|
int length = ( innerClassList == null)? 0 : (int) innerClassList.getLength();
|
||||||
if (length > 0) {
|
if (length > 0) {
|
||||||
if (Assert.ASSERTS_ENABLED) {
|
if (Assert.ASSERTS_ENABLED) {
|
||||||
Assert.that(length % InnerClassAttributeOffset.innerClassNextOffset == 0, "just checking");
|
Assert.that(length % InnerClassAttributeOffset.innerClassNextOffset == 0 ||
|
||||||
|
length % InnerClassAttributeOffset.innerClassNextOffset == EnclosingMethodAttributeOffset.enclosing_method_attribute_size,
|
||||||
|
"just checking");
|
||||||
}
|
}
|
||||||
for (int i = 0; i < length; i += InnerClassAttributeOffset.innerClassNextOffset) {
|
for (int i = 0; i < length; i += InnerClassAttributeOffset.innerClassNextOffset) {
|
||||||
|
if (i == length - EnclosingMethodAttributeOffset.enclosing_method_attribute_size) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
int ioff = innerClassList.getShortAt(i +
|
int ioff = innerClassList.getShortAt(i +
|
||||||
InnerClassAttributeOffset.innerClassInnerClassInfoOffset);
|
InnerClassAttributeOffset.innerClassInnerClassInfoOffset);
|
||||||
// 'ioff' can be zero.
|
// 'ioff' can be zero.
|
||||||
@ -419,9 +430,14 @@ public class InstanceKlass extends Klass {
|
|||||||
int length = ( innerClassList == null)? 0 : (int) innerClassList.getLength();
|
int length = ( innerClassList == null)? 0 : (int) innerClassList.getLength();
|
||||||
if (length > 0) {
|
if (length > 0) {
|
||||||
if (Assert.ASSERTS_ENABLED) {
|
if (Assert.ASSERTS_ENABLED) {
|
||||||
Assert.that(length % InnerClassAttributeOffset.innerClassNextOffset == 0, "just checking");
|
Assert.that(length % InnerClassAttributeOffset.innerClassNextOffset == 0 ||
|
||||||
|
length % InnerClassAttributeOffset.innerClassNextOffset == EnclosingMethodAttributeOffset.enclosing_method_attribute_size,
|
||||||
|
"just checking");
|
||||||
}
|
}
|
||||||
for (int i = 0; i < length; i += InnerClassAttributeOffset.innerClassNextOffset) {
|
for (int i = 0; i < length; i += InnerClassAttributeOffset.innerClassNextOffset) {
|
||||||
|
if (i == length - EnclosingMethodAttributeOffset.enclosing_method_attribute_size) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
int ioff = innerClassList.getShortAt(i +
|
int ioff = innerClassList.getShortAt(i +
|
||||||
InnerClassAttributeOffset.innerClassInnerClassInfoOffset);
|
InnerClassAttributeOffset.innerClassInnerClassInfoOffset);
|
||||||
// 'ioff' can be zero.
|
// 'ioff' can be zero.
|
||||||
|
@ -271,23 +271,25 @@ KERNEL_DIR=$(KERNEL_BASE_DIR)/$(VM_SUBDIR)
|
|||||||
ZERO_DIR=$(ZERO_BASE_DIR)/$(VM_SUBDIR)
|
ZERO_DIR=$(ZERO_BASE_DIR)/$(VM_SUBDIR)
|
||||||
SHARK_DIR=$(SHARK_BASE_DIR)/$(VM_SUBDIR)
|
SHARK_DIR=$(SHARK_BASE_DIR)/$(VM_SUBDIR)
|
||||||
|
|
||||||
# Misc files and generated files need to come from C1 or C2 area
|
ifeq ($(JVM_VARIANT_SERVER), true)
|
||||||
ifeq ($(ZERO_BUILD), true)
|
|
||||||
ifeq ($(SHARK_BUILD), true)
|
|
||||||
MISC_DIR=$(SHARK_DIR)
|
|
||||||
GEN_DIR=$(SHARK_BASE_DIR)/generated
|
|
||||||
else
|
|
||||||
MISC_DIR=$(ZERO_DIR)
|
|
||||||
GEN_DIR=$(ZERO_BASE_DIR)/generated
|
|
||||||
endif
|
|
||||||
else
|
|
||||||
ifeq ($(ARCH_DATA_MODEL), 32)
|
|
||||||
MISC_DIR=$(C1_DIR)
|
|
||||||
GEN_DIR=$(C1_BASE_DIR)/generated
|
|
||||||
else
|
|
||||||
MISC_DIR=$(C2_DIR)
|
MISC_DIR=$(C2_DIR)
|
||||||
GEN_DIR=$(C2_BASE_DIR)/generated
|
GEN_DIR=$(C2_BASE_DIR)/generated
|
||||||
endif
|
endif
|
||||||
|
ifeq ($(JVM_VARIANT_CLIENT), true)
|
||||||
|
MISC_DIR=$(C1_DIR)
|
||||||
|
GEN_DIR=$(C1_BASE_DIR)/generated
|
||||||
|
endif
|
||||||
|
ifeq ($(JVM_VARIANT_KERNEL), true)
|
||||||
|
MISC_DIR=$(C2_DIR)
|
||||||
|
GEN_DIR=$(C2_BASE_DIR)/generated
|
||||||
|
endif
|
||||||
|
ifeq ($(JVM_VARIANT_ZEROSHARK), true)
|
||||||
|
MISC_DIR=$(SHARK_DIR)
|
||||||
|
GEN_DIR=$(SHARK_BASE_DIR)/generated
|
||||||
|
endif
|
||||||
|
ifeq ($(JVM_VARIANT_ZERO), true)
|
||||||
|
MISC_DIR=$(ZERO_DIR)
|
||||||
|
GEN_DIR=$(ZERO_BASE_DIR)/generated
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Bin files (windows)
|
# Bin files (windows)
|
||||||
@ -332,44 +334,44 @@ endif
|
|||||||
|
|
||||||
# Shared Library
|
# Shared Library
|
||||||
ifneq ($(OSNAME),windows)
|
ifneq ($(OSNAME),windows)
|
||||||
ifeq ($(ZERO_BUILD), true)
|
ifeq ($(JVM_VARIANT_SERVER), true)
|
||||||
ifeq ($(SHARK_BUILD), true)
|
|
||||||
$(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(SHARK_DIR)/%.$(LIBRARY_SUFFIX)
|
|
||||||
$(install-file)
|
|
||||||
$(EXPORT_SERVER_DIR)/%.$(LIBRARY_SUFFIX): $(SHARK_DIR)/%.$(LIBRARY_SUFFIX)
|
|
||||||
$(install-file)
|
|
||||||
else
|
|
||||||
$(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(ZERO_DIR)/%.$(LIBRARY_SUFFIX)
|
|
||||||
$(install-file)
|
|
||||||
$(EXPORT_SERVER_DIR)/%.$(LIBRARY_SUFFIX): $(ZERO_DIR)/%.$(LIBRARY_SUFFIX)
|
|
||||||
$(install-file)
|
|
||||||
endif
|
|
||||||
else
|
|
||||||
$(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(C1_DIR)/%.$(LIBRARY_SUFFIX)
|
|
||||||
$(install-file)
|
|
||||||
$(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(C2_DIR)/%.$(LIBRARY_SUFFIX)
|
$(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(C2_DIR)/%.$(LIBRARY_SUFFIX)
|
||||||
$(install-file)
|
$(install-file)
|
||||||
$(EXPORT_CLIENT_DIR)/%.$(LIBRARY_SUFFIX): $(C1_DIR)/%.$(LIBRARY_SUFFIX)
|
|
||||||
$(install-file)
|
|
||||||
$(EXPORT_CLIENT_DIR)/64/%.$(LIBRARY_SUFFIX): $(C1_DIR)/%.$(LIBRARY_SUFFIX)
|
|
||||||
$(install-file)
|
|
||||||
$(EXPORT_SERVER_DIR)/%.$(LIBRARY_SUFFIX): $(C2_DIR)/%.$(LIBRARY_SUFFIX)
|
$(EXPORT_SERVER_DIR)/%.$(LIBRARY_SUFFIX): $(C2_DIR)/%.$(LIBRARY_SUFFIX)
|
||||||
$(install-file)
|
$(install-file)
|
||||||
$(EXPORT_SERVER_DIR)/64/%.$(LIBRARY_SUFFIX): $(C2_DIR)/%.$(LIBRARY_SUFFIX)
|
$(EXPORT_SERVER_DIR)/64/%.$(LIBRARY_SUFFIX): $(C2_DIR)/%.$(LIBRARY_SUFFIX)
|
||||||
$(install-file)
|
$(install-file)
|
||||||
|
|
||||||
# Debug info for shared library
|
|
||||||
$(EXPORT_JRE_LIB_ARCH_DIR)/%.debuginfo: $(C1_DIR)/%.debuginfo
|
|
||||||
$(install-file)
|
|
||||||
$(EXPORT_JRE_LIB_ARCH_DIR)/%.debuginfo: $(C2_DIR)/%.debuginfo
|
$(EXPORT_JRE_LIB_ARCH_DIR)/%.debuginfo: $(C2_DIR)/%.debuginfo
|
||||||
$(install-file)
|
$(install-file)
|
||||||
|
$(EXPORT_SERVER_DIR)/%.debuginfo: $(C2_DIR)/%.debuginfo
|
||||||
|
$(install-file)
|
||||||
|
$(EXPORT_SERVER_DIR)/64/%.debuginfo: $(C2_DIR)/%.debuginfo
|
||||||
|
$(install-file)
|
||||||
|
endif
|
||||||
|
ifeq ($(JVM_VARIANT_CLIENT), true)
|
||||||
|
$(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(C1_DIR)/%.$(LIBRARY_SUFFIX)
|
||||||
|
$(install-file)
|
||||||
|
$(EXPORT_CLIENT_DIR)/%.$(LIBRARY_SUFFIX): $(C1_DIR)/%.$(LIBRARY_SUFFIX)
|
||||||
|
$(install-file)
|
||||||
|
$(EXPORT_CLIENT_DIR)/64/%.$(LIBRARY_SUFFIX): $(C1_DIR)/%.$(LIBRARY_SUFFIX)
|
||||||
|
$(install-file)
|
||||||
|
$(EXPORT_JRE_LIB_ARCH_DIR)/%.debuginfo: $(C1_DIR)/%.debuginfo
|
||||||
|
$(install-file)
|
||||||
$(EXPORT_CLIENT_DIR)/%.debuginfo: $(C1_DIR)/%.debuginfo
|
$(EXPORT_CLIENT_DIR)/%.debuginfo: $(C1_DIR)/%.debuginfo
|
||||||
$(install-file)
|
$(install-file)
|
||||||
$(EXPORT_CLIENT_DIR)/64/%.debuginfo: $(C1_DIR)/%.debuginfo
|
$(EXPORT_CLIENT_DIR)/64/%.debuginfo: $(C1_DIR)/%.debuginfo
|
||||||
$(install-file)
|
$(install-file)
|
||||||
$(EXPORT_SERVER_DIR)/%.debuginfo: $(C2_DIR)/%.debuginfo
|
endif
|
||||||
|
ifeq ($(JVM_VARIANT_ZEROSHARK), true)
|
||||||
|
$(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(SHARK_DIR)/%.$(LIBRARY_SUFFIX)
|
||||||
$(install-file)
|
$(install-file)
|
||||||
$(EXPORT_SERVER_DIR)/64/%.debuginfo: $(C2_DIR)/%.debuginfo
|
$(EXPORT_SERVER_DIR)/%.$(LIBRARY_SUFFIX): $(SHARK_DIR)/%.$(LIBRARY_SUFFIX)
|
||||||
|
$(install-file)
|
||||||
|
endif
|
||||||
|
ifeq ($(JVM_VARIANT_ZERO), true)
|
||||||
|
$(EXPORT_JRE_LIB_ARCH_DIR)/%.$(LIBRARY_SUFFIX): $(ZERO_DIR)/%.$(LIBRARY_SUFFIX)
|
||||||
|
$(install-file)
|
||||||
|
$(EXPORT_SERVER_DIR)/%.$(LIBRARY_SUFFIX): $(ZERO_DIR)/%.$(LIBRARY_SUFFIX)
|
||||||
$(install-file)
|
$(install-file)
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
@ -450,17 +452,18 @@ $(JDK_IMAGE_DIR)/jre/lib/rt.jar:
|
|||||||
($(CD) $(JDK_IMAGE_DIR) && $(TAR) -xf -)
|
($(CD) $(JDK_IMAGE_DIR) && $(TAR) -xf -)
|
||||||
|
|
||||||
test_jdk:
|
test_jdk:
|
||||||
ifeq ($(ARCH_DATA_MODEL), 32)
|
ifeq ($(JVM_VARIANT_CLIENT), true)
|
||||||
ifneq ($(ZERO_BUILD), true)
|
$(JDK_IMAGE_DIR)/bin/java -d$(ARCH_DATA_MODEL) -client -Xinternalversion
|
||||||
$(JDK_IMAGE_DIR)/bin/java -d32 -client -Xinternalversion
|
$(JDK_IMAGE_DIR)/bin/java -d$(ARCH_DATA_MODEL) -client -version
|
||||||
$(JDK_IMAGE_DIR)/bin/java -d32 -client -version
|
|
||||||
endif
|
endif
|
||||||
$(JDK_IMAGE_DIR)/bin/java -d32 -server -Xinternalversion
|
ifeq ($(findstring true, $(JVM_VARIANT_SERVER)\
|
||||||
$(JDK_IMAGE_DIR)/bin/java -d32 -server -version
|
$(JVM_VARIANT_ZERO)$(JVM_VARIANT_ZEROSHARK)), true)
|
||||||
|
$(JDK_IMAGE_DIR)/bin/java -d$(ARCH_DATA_MODEL) -server -Xinternalversion
|
||||||
|
$(JDK_IMAGE_DIR)/bin/java -d$(ARCH_DATA_MODEL) -server -version
|
||||||
endif
|
endif
|
||||||
ifeq ($(ARCH_DATA_MODEL), 64)
|
ifeq ($(JVM_VARIANT_KERNEL), true)
|
||||||
$(JDK_IMAGE_DIR)/bin/java -d64 -server -Xinternalversion
|
$(JDK_IMAGE_DIR)/bin/java -d$(ARCH_DATA_MODEL) -kernel -Xinternalversion
|
||||||
$(JDK_IMAGE_DIR)/bin/java -d64 -server -version
|
$(JDK_IMAGE_DIR)/bin/java -d$(ARCH_DATA_MODEL) -kernel -version
|
||||||
endif
|
endif
|
||||||
|
|
||||||
copy_product_jdk::
|
copy_product_jdk::
|
||||||
|
@ -188,7 +188,7 @@ VARIANTARCH = $(subst i386,i486,$(ZERO_LIBARCH))
|
|||||||
# in the build.sh script:
|
# in the build.sh script:
|
||||||
TARGETS = debug jvmg fastdebug optimized profiled product
|
TARGETS = debug jvmg fastdebug optimized profiled product
|
||||||
|
|
||||||
ifeq ($(ZERO_BUILD), true)
|
ifeq ($(findstring true, $(JVM_VARIANT_ZERO) $(JVM_VARIANT_ZEROSHARK)), true)
|
||||||
SUBDIR_DOCS = $(OSNAME)_$(VARIANTARCH)_docs
|
SUBDIR_DOCS = $(OSNAME)_$(VARIANTARCH)_docs
|
||||||
else
|
else
|
||||||
SUBDIR_DOCS = $(OSNAME)_$(BUILDARCH)_docs
|
SUBDIR_DOCS = $(OSNAME)_$(BUILDARCH)_docs
|
||||||
|
@ -69,7 +69,7 @@ QUIETLY$(MAKE_VERBOSE) = @
|
|||||||
# For now, until the compiler is less wobbly:
|
# For now, until the compiler is less wobbly:
|
||||||
TESTFLAGS = -Xbatch -showversion
|
TESTFLAGS = -Xbatch -showversion
|
||||||
|
|
||||||
ifeq ($(ZERO_BUILD), true)
|
ifeq ($(findstring true, $(JVM_VARIANT_ZERO) $(JVM_VARIANT_ZEROSHARK)), true)
|
||||||
PLATFORM_FILE = $(shell dirname $(shell dirname $(shell pwd)))/platform_zero
|
PLATFORM_FILE = $(shell dirname $(shell dirname $(shell pwd)))/platform_zero
|
||||||
else
|
else
|
||||||
ifdef USE_SUNCC
|
ifdef USE_SUNCC
|
||||||
|
@ -38,7 +38,7 @@ else
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
# zero
|
# zero
|
||||||
ifeq ($(ZERO_BUILD), true)
|
ifeq ($(findstring true, $(JVM_VARIANT_ZERO) $(JVM_VARIANT_ZEROSHARK)), true)
|
||||||
ifeq ($(ARCH_DATA_MODEL), 64)
|
ifeq ($(ARCH_DATA_MODEL), 64)
|
||||||
MAKE_ARGS += LP64=1
|
MAKE_ARGS += LP64=1
|
||||||
endif
|
endif
|
||||||
@ -124,6 +124,18 @@ ifeq ($(ARCH), ppc)
|
|||||||
HS_ARCH = ppc
|
HS_ARCH = ppc
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# On 32 bit bsd we build server and client, on 64 bit just server.
|
||||||
|
ifeq ($(JVM_VARIANTS),)
|
||||||
|
ifeq ($(ARCH_DATA_MODEL), 32)
|
||||||
|
JVM_VARIANTS:=client,server
|
||||||
|
JVM_VARIANT_CLIENT:=true
|
||||||
|
JVM_VARIANT_SERVER:=true
|
||||||
|
else
|
||||||
|
JVM_VARIANTS:=server
|
||||||
|
JVM_VARIANT_SERVER:=true
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
JDK_INCLUDE_SUBDIR=bsd
|
JDK_INCLUDE_SUBDIR=bsd
|
||||||
|
|
||||||
# Library suffix
|
# Library suffix
|
||||||
@ -146,17 +158,15 @@ EXPORT_CLIENT_DIR = $(EXPORT_JRE_LIB_ARCH_DIR)/client
|
|||||||
|
|
||||||
EXPORT_LIST += $(EXPORT_JRE_LIB_DIR)/wb.jar
|
EXPORT_LIST += $(EXPORT_JRE_LIB_DIR)/wb.jar
|
||||||
|
|
||||||
ifndef BUILD_CLIENT_ONLY
|
ifeq ($(findstring true, $(JVM_VARIANT_SERVER) $(JVM_VARIANT_ZERO) $(JVM_VARIANT_ZEROSHARK)), true)
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/Xusage.txt
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/Xusage.txt
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm.$(LIBRARY_SUFFIX)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifneq ($(ZERO_BUILD), true)
|
ifeq ($(JVM_VARIANT_CLIENT),true)
|
||||||
ifeq ($(ARCH_DATA_MODEL), 32)
|
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/Xusage.txt
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/Xusage.txt
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm.$(LIBRARY_SUFFIX)
|
||||||
endif
|
endif
|
||||||
endif
|
|
||||||
|
|
||||||
# Serviceability Binaries
|
# Serviceability Binaries
|
||||||
# No SA Support for PPC, IA64, ARM or zero
|
# No SA Support for PPC, IA64, ARM or zero
|
||||||
|
@ -105,10 +105,11 @@ VM_PICFLAG/LIBJVM = $(PICFLAG)
|
|||||||
VM_PICFLAG/AOUT =
|
VM_PICFLAG/AOUT =
|
||||||
VM_PICFLAG = $(VM_PICFLAG/$(LINK_INTO))
|
VM_PICFLAG = $(VM_PICFLAG/$(LINK_INTO))
|
||||||
|
|
||||||
ifeq ($(ZERO_BUILD), true)
|
ifeq ($(JVM_VARIANT_ZERO), true)
|
||||||
CFLAGS += $(LIBFFI_CFLAGS)
|
CFLAGS += $(LIBFFI_CFLAGS)
|
||||||
endif
|
endif
|
||||||
ifeq ($(SHARK_BUILD), true)
|
ifeq ($(JVM_VARIANT_ZEROSHARK), true)
|
||||||
|
CFLAGS += $(LIBFFI_CFLAGS)
|
||||||
CFLAGS += $(LLVM_CFLAGS)
|
CFLAGS += $(LLVM_CFLAGS)
|
||||||
endif
|
endif
|
||||||
CFLAGS += $(VM_PICFLAG)
|
CFLAGS += $(VM_PICFLAG)
|
||||||
|
@ -42,7 +42,7 @@ DEP_DIR = $(GENERATED)/dependencies
|
|||||||
-include $(DEP_DIR)/*.d
|
-include $(DEP_DIR)/*.d
|
||||||
|
|
||||||
# read machine-specific adjustments (%%% should do this via buildtree.make?)
|
# read machine-specific adjustments (%%% should do this via buildtree.make?)
|
||||||
ifeq ($(ZERO_BUILD), true)
|
ifeq ($(findstring true, $(JVM_VARIANT_ZERO) $(JVM_VARIANT_ZEROSHARK)), true)
|
||||||
include $(MAKEFILES_DIR)/zeroshark.make
|
include $(MAKEFILES_DIR)/zeroshark.make
|
||||||
else
|
else
|
||||||
include $(MAKEFILES_DIR)/$(BUILDARCH).make
|
include $(MAKEFILES_DIR)/$(BUILDARCH).make
|
||||||
@ -271,12 +271,12 @@ else
|
|||||||
|
|
||||||
LIBS_VM += $(LIBS)
|
LIBS_VM += $(LIBS)
|
||||||
endif
|
endif
|
||||||
ifeq ($(ZERO_BUILD), true)
|
ifeq ($(JVM_VARIANT_ZERO), true)
|
||||||
LIBS_VM += $(LIBFFI_LIBS)
|
LIBS_VM += $(LIBFFI_LIBS)
|
||||||
endif
|
endif
|
||||||
ifeq ($(SHARK_BUILD), true)
|
ifeq ($(JVM_VARIANT_ZEROSHARK), true)
|
||||||
|
LIBS_VM += $(LIBFFI_LIBS) $(LLVM_LIBS)
|
||||||
LFLAGS_VM += $(LLVM_LDFLAGS)
|
LFLAGS_VM += $(LLVM_LDFLAGS)
|
||||||
LIBS_VM += $(LLVM_LIBS)
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
||||||
|
@ -55,6 +55,27 @@ define prep-target
|
|||||||
@$(RM) $@
|
@$(RM) $@
|
||||||
endef
|
endef
|
||||||
|
|
||||||
|
# Default values for JVM_VARIANT* variables if configure hasn't set
|
||||||
|
# it already.
|
||||||
|
ifeq ($(JVM_VARIANTS),)
|
||||||
|
ifeq ($(ZERO_BUILD), true)
|
||||||
|
ifeq ($(SHARK_BUILD), true)
|
||||||
|
JVM_VARIANTS:=zeroshark
|
||||||
|
JVM_VARIANT_ZEROSHARK:=true
|
||||||
|
else
|
||||||
|
JVM_VARIANTS:=zero
|
||||||
|
JVM_VARIANT_ZERO:=true
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
# A default is needed
|
||||||
|
ifeq ($(BUILD_CLIENT_ONLY), true)
|
||||||
|
JVM_VARIANTS:=client
|
||||||
|
JVM_VARIANT_CLIENT:=true
|
||||||
|
endif
|
||||||
|
# Further defaults are platform and arch specific
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
# Directory paths and user name
|
# Directory paths and user name
|
||||||
# Unless GAMMADIR is set on the command line, search upward from
|
# Unless GAMMADIR is set on the command line, search upward from
|
||||||
# the current directory for a parent directory containing "src/share/vm".
|
# the current directory for a parent directory containing "src/share/vm".
|
||||||
|
@ -35,7 +35,7 @@ HOTSPOT_VM_COPYRIGHT=Copyright 2011
|
|||||||
|
|
||||||
HS_MAJOR_VER=24
|
HS_MAJOR_VER=24
|
||||||
HS_MINOR_VER=0
|
HS_MINOR_VER=0
|
||||||
HS_BUILD_NUMBER=04
|
HS_BUILD_NUMBER=06
|
||||||
|
|
||||||
JDK_MAJOR_VER=1
|
JDK_MAJOR_VER=1
|
||||||
JDK_MINOR_VER=8
|
JDK_MINOR_VER=8
|
||||||
|
@ -446,6 +446,7 @@ jprt.test.targets.embedded= \
|
|||||||
|
|
||||||
jprt.test.targets.jdk8=${jprt.test.targets.standard}
|
jprt.test.targets.jdk8=${jprt.test.targets.standard}
|
||||||
jprt.test.targets.jdk7=${jprt.test.targets.standard}
|
jprt.test.targets.jdk7=${jprt.test.targets.standard}
|
||||||
|
jprt.test.targets.jdk7u4=${jprt.test.targets.jdk7}
|
||||||
jprt.test.targets=${jprt.test.targets.${jprt.tools.default.release}}
|
jprt.test.targets=${jprt.test.targets.${jprt.tools.default.release}}
|
||||||
|
|
||||||
# The default test/Makefile targets that should be run
|
# The default test/Makefile targets that should be run
|
||||||
@ -505,5 +506,6 @@ jprt.make.rule.test.targets.embedded = \
|
|||||||
|
|
||||||
jprt.make.rule.test.targets.jdk8=${jprt.make.rule.test.targets.standard}
|
jprt.make.rule.test.targets.jdk8=${jprt.make.rule.test.targets.standard}
|
||||||
jprt.make.rule.test.targets.jdk7=${jprt.make.rule.test.targets.standard}
|
jprt.make.rule.test.targets.jdk7=${jprt.make.rule.test.targets.standard}
|
||||||
|
jprt.make.rule.test.targets.jdk7u4=${jprt.make.rule.test.targets.jdk7}
|
||||||
jprt.make.rule.test.targets=${jprt.make.rule.test.targets.${jprt.tools.default.release}}
|
jprt.make.rule.test.targets=${jprt.make.rule.test.targets.${jprt.tools.default.release}}
|
||||||
|
|
||||||
|
@ -188,7 +188,7 @@ VARIANTARCH = $(subst i386,i486,$(ZERO_LIBARCH))
|
|||||||
# in the build.sh script:
|
# in the build.sh script:
|
||||||
TARGETS = debug jvmg fastdebug optimized profiled product
|
TARGETS = debug jvmg fastdebug optimized profiled product
|
||||||
|
|
||||||
ifeq ($(ZERO_BUILD), true)
|
ifeq ($(findstring true, $(JVM_VARIANT_ZERO) $(JVM_VARIANT_ZEROSHARK)), true)
|
||||||
SUBDIR_DOCS = $(OSNAME)_$(VARIANTARCH)_docs
|
SUBDIR_DOCS = $(OSNAME)_$(VARIANTARCH)_docs
|
||||||
else
|
else
|
||||||
SUBDIR_DOCS = $(OSNAME)_$(BUILDARCH)_docs
|
SUBDIR_DOCS = $(OSNAME)_$(BUILDARCH)_docs
|
||||||
|
@ -66,7 +66,7 @@ QUIETLY$(MAKE_VERBOSE) = @
|
|||||||
# For now, until the compiler is less wobbly:
|
# For now, until the compiler is less wobbly:
|
||||||
TESTFLAGS = -Xbatch -showversion
|
TESTFLAGS = -Xbatch -showversion
|
||||||
|
|
||||||
ifeq ($(ZERO_BUILD), true)
|
ifeq ($(findstring true, $(JVM_VARIANT_ZERO) $(JVM_VARIANT_ZEROSHARK)), true)
|
||||||
PLATFORM_FILE = $(shell dirname $(shell dirname $(shell pwd)))/platform_zero
|
PLATFORM_FILE = $(shell dirname $(shell dirname $(shell pwd)))/platform_zero
|
||||||
else
|
else
|
||||||
ifdef USE_SUNCC
|
ifdef USE_SUNCC
|
||||||
|
@ -38,7 +38,7 @@ else
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
# zero
|
# zero
|
||||||
ifeq ($(ZERO_BUILD), true)
|
ifeq ($(findstring true, $(JVM_VARIANT_ZERO) $(JVM_VARIANT_ZEROSHARK)), true)
|
||||||
ifeq ($(ARCH_DATA_MODEL), 64)
|
ifeq ($(ARCH_DATA_MODEL), 64)
|
||||||
MAKE_ARGS += LP64=1
|
MAKE_ARGS += LP64=1
|
||||||
endif
|
endif
|
||||||
@ -114,6 +114,18 @@ ifeq ($(ARCH), ppc)
|
|||||||
HS_ARCH = ppc
|
HS_ARCH = ppc
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# On 32 bit linux we build server and client, on 64 bit just server.
|
||||||
|
ifeq ($(JVM_VARIANTS),)
|
||||||
|
ifeq ($(ARCH_DATA_MODEL), 32)
|
||||||
|
JVM_VARIANTS:=client,server
|
||||||
|
JVM_VARIANT_CLIENT:=true
|
||||||
|
JVM_VARIANT_SERVER:=true
|
||||||
|
else
|
||||||
|
JVM_VARIANTS:=server
|
||||||
|
JVM_VARIANT_SERVER:=true
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
# determine if HotSpot is being built in JDK6 or earlier version
|
# determine if HotSpot is being built in JDK6 or earlier version
|
||||||
JDK6_OR_EARLIER=0
|
JDK6_OR_EARLIER=0
|
||||||
ifeq "$(shell expr \( '$(JDK_MAJOR_VERSION)' != '' \& '$(JDK_MINOR_VERSION)' != '' \& '$(JDK_MICRO_VERSION)' != '' \))" "1"
|
ifeq "$(shell expr \( '$(JDK_MAJOR_VERSION)' != '' \& '$(JDK_MINOR_VERSION)' != '' \& '$(JDK_MICRO_VERSION)' != '' \))" "1"
|
||||||
@ -195,7 +207,7 @@ EXPORT_CLIENT_DIR = $(EXPORT_JRE_LIB_ARCH_DIR)/client
|
|||||||
|
|
||||||
EXPORT_LIST += $(EXPORT_JRE_LIB_DIR)/wb.jar
|
EXPORT_LIST += $(EXPORT_JRE_LIB_DIR)/wb.jar
|
||||||
|
|
||||||
ifndef BUILD_CLIENT_ONLY
|
ifeq ($(findstring true, $(JVM_VARIANT_SERVER) $(JVM_VARIANT_ZERO) $(JVM_VARIANT_ZEROSHARK)), true)
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/Xusage.txt
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/Xusage.txt
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm.$(LIBRARY_SUFFIX)
|
||||||
ifneq ($(OBJCOPY),)
|
ifneq ($(OBJCOPY),)
|
||||||
@ -203,15 +215,13 @@ EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm.$(LIBRARY_SUFFIX)
|
|||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifneq ($(ZERO_BUILD), true)
|
ifeq ($(JVM_VARIANT_CLIENT),true)
|
||||||
ifeq ($(ARCH_DATA_MODEL), 32)
|
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/Xusage.txt
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/Xusage.txt
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm.$(LIBRARY_SUFFIX)
|
||||||
ifneq ($(OBJCOPY),)
|
ifneq ($(OBJCOPY),)
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm.debuginfo
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm.debuginfo
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
endif
|
|
||||||
|
|
||||||
# Serviceability Binaries
|
# Serviceability Binaries
|
||||||
# No SA Support for PPC, IA64, ARM or zero
|
# No SA Support for PPC, IA64, ARM or zero
|
||||||
|
@ -72,10 +72,11 @@ VM_PICFLAG/LIBJVM = $(PICFLAG)
|
|||||||
VM_PICFLAG/AOUT =
|
VM_PICFLAG/AOUT =
|
||||||
VM_PICFLAG = $(VM_PICFLAG/$(LINK_INTO))
|
VM_PICFLAG = $(VM_PICFLAG/$(LINK_INTO))
|
||||||
|
|
||||||
ifeq ($(ZERO_BUILD), true)
|
ifeq ($(JVM_VARIANT_ZERO), true)
|
||||||
CFLAGS += $(LIBFFI_CFLAGS)
|
CFLAGS += $(LIBFFI_CFLAGS)
|
||||||
endif
|
endif
|
||||||
ifeq ($(SHARK_BUILD), true)
|
ifeq ($(JVM_VARIANT_ZEROSHARK), true)
|
||||||
|
CFLAGS += $(LIBFFI_CFLAGS)
|
||||||
CFLAGS += $(LLVM_CFLAGS)
|
CFLAGS += $(LLVM_CFLAGS)
|
||||||
endif
|
endif
|
||||||
CFLAGS += $(VM_PICFLAG)
|
CFLAGS += $(VM_PICFLAG)
|
||||||
|
@ -42,7 +42,7 @@ DEP_DIR = $(GENERATED)/dependencies
|
|||||||
-include $(DEP_DIR)/*.d
|
-include $(DEP_DIR)/*.d
|
||||||
|
|
||||||
# read machine-specific adjustments (%%% should do this via buildtree.make?)
|
# read machine-specific adjustments (%%% should do this via buildtree.make?)
|
||||||
ifeq ($(ZERO_BUILD), true)
|
ifeq ($(findstring true, $(JVM_VARIANT_ZERO) $(JVM_VARIANT_ZEROSHARK)), true)
|
||||||
include $(MAKEFILES_DIR)/zeroshark.make
|
include $(MAKEFILES_DIR)/zeroshark.make
|
||||||
else
|
else
|
||||||
include $(MAKEFILES_DIR)/$(BUILDARCH).make
|
include $(MAKEFILES_DIR)/$(BUILDARCH).make
|
||||||
@ -236,7 +236,7 @@ mapfile_reorder : mapfile $(REORDERFILE)
|
|||||||
vm.def: $(Res_Files) $(Obj_Files)
|
vm.def: $(Res_Files) $(Obj_Files)
|
||||||
sh $(GAMMADIR)/make/linux/makefiles/build_vm_def.sh *.o > $@
|
sh $(GAMMADIR)/make/linux/makefiles/build_vm_def.sh *.o > $@
|
||||||
|
|
||||||
ifeq ($(SHARK_BUILD), true)
|
ifeq ($(JVM_VARIANT_ZEROSHARK), true)
|
||||||
STATIC_CXX = false
|
STATIC_CXX = false
|
||||||
else
|
else
|
||||||
ifeq ($(ZERO_LIBARCH), ppc64)
|
ifeq ($(ZERO_LIBARCH), ppc64)
|
||||||
@ -268,12 +268,12 @@ else
|
|||||||
|
|
||||||
LIBS_VM += $(LIBS)
|
LIBS_VM += $(LIBS)
|
||||||
endif
|
endif
|
||||||
ifeq ($(ZERO_BUILD), true)
|
ifeq ($(JVM_VARIANT_ZERO), true)
|
||||||
LIBS_VM += $(LIBFFI_LIBS)
|
LIBS_VM += $(LIBFFI_LIBS)
|
||||||
endif
|
endif
|
||||||
ifeq ($(SHARK_BUILD), true)
|
ifeq ($(JVM_VARIANT_ZEROSHARK), true)
|
||||||
|
LIBS_VM += $(LIBFFI_LIBS) $(LLVM_LIBS)
|
||||||
LFLAGS_VM += $(LLVM_LDFLAGS)
|
LFLAGS_VM += $(LLVM_LDFLAGS)
|
||||||
LIBS_VM += $(LLVM_LIBS)
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
LINK_VM = $(LINK_LIB.CC)
|
LINK_VM = $(LINK_LIB.CC)
|
||||||
|
@ -59,6 +59,18 @@ else
|
|||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# On 32 bit solaris we build server and client, on 64 bit just server.
|
||||||
|
ifeq ($(JVM_VARIANTS),)
|
||||||
|
ifeq ($(ARCH_DATA_MODEL), 32)
|
||||||
|
JVM_VARIANTS:=client,server
|
||||||
|
JVM_VARIANT_CLIENT:=true
|
||||||
|
JVM_VARIANT_SERVER:=true
|
||||||
|
else
|
||||||
|
JVM_VARIANTS:=server
|
||||||
|
JVM_VARIANT_SERVER:=true
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
# determine if HotSpot is being built in JDK6 or earlier version
|
# determine if HotSpot is being built in JDK6 or earlier version
|
||||||
JDK6_OR_EARLIER=0
|
JDK6_OR_EARLIER=0
|
||||||
ifeq "$(shell expr \( '$(JDK_MAJOR_VERSION)' != '' \& '$(JDK_MINOR_VERSION)' != '' \& '$(JDK_MICRO_VERSION)' != '' \))" "1"
|
ifeq "$(shell expr \( '$(JDK_MAJOR_VERSION)' != '' \& '$(JDK_MINOR_VERSION)' != '' \& '$(JDK_MICRO_VERSION)' != '' \))" "1"
|
||||||
@ -153,38 +165,38 @@ EXPORT_LIST += $(EXPORT_JRE_LIB_DIR)/wb.jar
|
|||||||
EXPORT_SERVER_DIR = $(EXPORT_JRE_LIB_ARCH_DIR)/server
|
EXPORT_SERVER_DIR = $(EXPORT_JRE_LIB_ARCH_DIR)/server
|
||||||
EXPORT_CLIENT_DIR = $(EXPORT_JRE_LIB_ARCH_DIR)/client
|
EXPORT_CLIENT_DIR = $(EXPORT_JRE_LIB_ARCH_DIR)/client
|
||||||
|
|
||||||
ifneq ($(BUILD_CLIENT_ONLY),true)
|
ifeq ($(JVM_VARIANT_SERVER),true)
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/Xusage.txt
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/Xusage.txt
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm.$(LIBRARY_SUFFIX)
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm_db.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm_db.$(LIBRARY_SUFFIX)
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm_dtrace.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm_dtrace.$(LIBRARY_SUFFIX)
|
||||||
|
ifeq ($(ARCH_DATA_MODEL),32)
|
||||||
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/64/libjvm_db.$(LIBRARY_SUFFIX)
|
||||||
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/64/libjvm_dtrace.$(LIBRARY_SUFFIX)
|
||||||
|
endif
|
||||||
ifneq ($(OBJCOPY),)
|
ifneq ($(OBJCOPY),)
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm.debuginfo
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm.debuginfo
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm_db.debuginfo
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm_db.debuginfo
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm_dtrace.debuginfo
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/libjvm_dtrace.debuginfo
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
ifeq ($(ARCH_DATA_MODEL), 32)
|
ifeq ($(JVM_VARIANT_CLIENT),true)
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/Xusage.txt
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/Xusage.txt
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm.$(LIBRARY_SUFFIX)
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm_db.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm_db.$(LIBRARY_SUFFIX)
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm_dtrace.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm_dtrace.$(LIBRARY_SUFFIX)
|
||||||
|
ifeq ($(ARCH_DATA_MODEL),32)
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/64/libjvm_db.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/64/libjvm_db.$(LIBRARY_SUFFIX)
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/64/libjvm_dtrace.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/64/libjvm_dtrace.$(LIBRARY_SUFFIX)
|
||||||
|
endif
|
||||||
ifneq ($(OBJCOPY),)
|
ifneq ($(OBJCOPY),)
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm.debuginfo
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm.debuginfo
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm_db.debuginfo
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm_db.debuginfo
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm_dtrace.debuginfo
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/libjvm_dtrace.debuginfo
|
||||||
|
ifeq ($(ARCH_DATA_MODEL),32)
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/64/libjvm_db.debuginfo
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/64/libjvm_db.debuginfo
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/64/libjvm_dtrace.debuginfo
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/64/libjvm_dtrace.debuginfo
|
||||||
endif
|
endif
|
||||||
ifneq ($(BUILD_CLIENT_ONLY), true)
|
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/64/libjvm_db.$(LIBRARY_SUFFIX)
|
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/64/libjvm_dtrace.$(LIBRARY_SUFFIX)
|
|
||||||
ifneq ($(OBJCOPY),)
|
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/64/libjvm_db.debuginfo
|
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/64/libjvm_dtrace.debuginfo
|
|
||||||
endif
|
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -107,6 +107,19 @@ ifneq ($(shell $(ECHO) $(PROCESSOR_IDENTIFIER) | $(GREP) EM64T),)
|
|||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# On 32 bit windows we build server, client and kernel, on 64 bit just server.
|
||||||
|
ifeq ($(JVM_VARIANTS),)
|
||||||
|
ifeq ($(ARCH_DATA_MODEL), 32)
|
||||||
|
JVM_VARIANTS:=client,server,kernel
|
||||||
|
JVM_VARIANT_CLIENT:=true
|
||||||
|
JVM_VARIANT_SERVER:=true
|
||||||
|
JVM_VARIANT_KERNEL:=true
|
||||||
|
else
|
||||||
|
JVM_VARIANTS:=server
|
||||||
|
JVM_VARIANT_SERVER:=true
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
JDK_INCLUDE_SUBDIR=win32
|
JDK_INCLUDE_SUBDIR=win32
|
||||||
|
|
||||||
# Library suffix
|
# Library suffix
|
||||||
@ -177,17 +190,20 @@ EXPORT_SERVER_DIR = $(EXPORT_JRE_BIN_DIR)/server
|
|||||||
EXPORT_CLIENT_DIR = $(EXPORT_JRE_BIN_DIR)/client
|
EXPORT_CLIENT_DIR = $(EXPORT_JRE_BIN_DIR)/client
|
||||||
EXPORT_KERNEL_DIR = $(EXPORT_JRE_BIN_DIR)/kernel
|
EXPORT_KERNEL_DIR = $(EXPORT_JRE_BIN_DIR)/kernel
|
||||||
|
|
||||||
|
ifeq ($(JVM_VARIANT_SERVER),true)
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/Xusage.txt
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/Xusage.txt
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/jvm.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/jvm.$(LIBRARY_SUFFIX)
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/jvm.pdb
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/jvm.pdb
|
||||||
EXPORT_LIST += $(EXPORT_SERVER_DIR)/jvm.map
|
EXPORT_LIST += $(EXPORT_SERVER_DIR)/jvm.map
|
||||||
EXPORT_LIST += $(EXPORT_LIB_DIR)/jvm.lib
|
EXPORT_LIST += $(EXPORT_LIB_DIR)/jvm.lib
|
||||||
ifeq ($(ARCH_DATA_MODEL), 32)
|
endif
|
||||||
|
ifeq ($(JVM_VARIANT_CLIENT),true)
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/Xusage.txt
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/Xusage.txt
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/jvm.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/jvm.$(LIBRARY_SUFFIX)
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/jvm.pdb
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/jvm.pdb
|
||||||
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/jvm.map
|
EXPORT_LIST += $(EXPORT_CLIENT_DIR)/jvm.map
|
||||||
# kernel vm
|
endif
|
||||||
|
ifeq ($(JVM_VARIANT_KERNEL),true)
|
||||||
EXPORT_LIST += $(EXPORT_KERNEL_DIR)/Xusage.txt
|
EXPORT_LIST += $(EXPORT_KERNEL_DIR)/Xusage.txt
|
||||||
EXPORT_LIST += $(EXPORT_KERNEL_DIR)/jvm.$(LIBRARY_SUFFIX)
|
EXPORT_LIST += $(EXPORT_KERNEL_DIR)/jvm.$(LIBRARY_SUFFIX)
|
||||||
EXPORT_LIST += $(EXPORT_KERNEL_DIR)/jvm.pdb
|
EXPORT_LIST += $(EXPORT_KERNEL_DIR)/jvm.pdb
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -207,10 +207,15 @@ int BsdAttachListener::init() {
|
|||||||
res = ::listen(listener, 5);
|
res = ::listen(listener, 5);
|
||||||
if (res == 0) {
|
if (res == 0) {
|
||||||
RESTARTABLE(::chmod(initial_path, S_IREAD|S_IWRITE), res);
|
RESTARTABLE(::chmod(initial_path, S_IREAD|S_IWRITE), res);
|
||||||
|
if (res == 0) {
|
||||||
|
// make sure the file is owned by the effective user and effective group
|
||||||
|
// (this is the default on linux, but not on mac os)
|
||||||
|
RESTARTABLE(::chown(initial_path, geteuid(), getegid()), res);
|
||||||
if (res == 0) {
|
if (res == 0) {
|
||||||
res = ::rename(initial_path, path);
|
res = ::rename(initial_path, path);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (res == -1) {
|
if (res == -1) {
|
||||||
RESTARTABLE(::close(listener), res);
|
RESTARTABLE(::close(listener), res);
|
||||||
::unlink(initial_path);
|
::unlink(initial_path);
|
||||||
|
@ -2315,13 +2315,32 @@ void ClassFileParser::parse_classfile_source_debug_extension_attribute(constantP
|
|||||||
#define RECOGNIZED_INNER_CLASS_MODIFIERS (JVM_RECOGNIZED_CLASS_MODIFIERS | JVM_ACC_PRIVATE | JVM_ACC_PROTECTED | JVM_ACC_STATIC)
|
#define RECOGNIZED_INNER_CLASS_MODIFIERS (JVM_RECOGNIZED_CLASS_MODIFIERS | JVM_ACC_PRIVATE | JVM_ACC_PROTECTED | JVM_ACC_STATIC)
|
||||||
|
|
||||||
// Return number of classes in the inner classes attribute table
|
// Return number of classes in the inner classes attribute table
|
||||||
u2 ClassFileParser::parse_classfile_inner_classes_attribute(constantPoolHandle cp, instanceKlassHandle k, TRAPS) {
|
u2 ClassFileParser::parse_classfile_inner_classes_attribute(u1* inner_classes_attribute_start,
|
||||||
|
bool parsed_enclosingmethod_attribute,
|
||||||
|
u2 enclosing_method_class_index,
|
||||||
|
u2 enclosing_method_method_index,
|
||||||
|
constantPoolHandle cp,
|
||||||
|
instanceKlassHandle k, TRAPS) {
|
||||||
ClassFileStream* cfs = stream();
|
ClassFileStream* cfs = stream();
|
||||||
|
u1* current_mark = cfs->current();
|
||||||
|
u2 length = 0;
|
||||||
|
if (inner_classes_attribute_start != NULL) {
|
||||||
|
cfs->set_current(inner_classes_attribute_start);
|
||||||
cfs->guarantee_more(2, CHECK_0); // length
|
cfs->guarantee_more(2, CHECK_0); // length
|
||||||
u2 length = cfs->get_u2_fast();
|
length = cfs->get_u2_fast();
|
||||||
|
}
|
||||||
|
|
||||||
// 4-tuples of shorts [inner_class_info_index, outer_class_info_index, inner_name_index, inner_class_access_flags]
|
// 4-tuples of shorts of inner classes data and 2 shorts of enclosing
|
||||||
typeArrayOop ic = oopFactory::new_permanent_shortArray(length*4, CHECK_0);
|
// method data:
|
||||||
|
// [inner_class_info_index,
|
||||||
|
// outer_class_info_index,
|
||||||
|
// inner_name_index,
|
||||||
|
// inner_class_access_flags,
|
||||||
|
// ...
|
||||||
|
// enclosing_method_class_index,
|
||||||
|
// enclosing_method_method_index]
|
||||||
|
int size = length * 4 + (parsed_enclosingmethod_attribute ? 2 : 0);
|
||||||
|
typeArrayOop ic = oopFactory::new_permanent_shortArray(size, CHECK_0);
|
||||||
typeArrayHandle inner_classes(THREAD, ic);
|
typeArrayHandle inner_classes(THREAD, ic);
|
||||||
int index = 0;
|
int index = 0;
|
||||||
int cp_size = cp->length();
|
int cp_size = cp->length();
|
||||||
@ -2372,8 +2391,8 @@ u2 ClassFileParser::parse_classfile_inner_classes_attribute(constantPoolHandle c
|
|||||||
|
|
||||||
// 4347400: make sure there's no duplicate entry in the classes array
|
// 4347400: make sure there's no duplicate entry in the classes array
|
||||||
if (_need_verify && _major_version >= JAVA_1_5_VERSION) {
|
if (_need_verify && _major_version >= JAVA_1_5_VERSION) {
|
||||||
for(int i = 0; i < inner_classes->length(); i += 4) {
|
for(int i = 0; i < length * 4; i += 4) {
|
||||||
for(int j = i + 4; j < inner_classes->length(); j += 4) {
|
for(int j = i + 4; j < length * 4; j += 4) {
|
||||||
guarantee_property((inner_classes->ushort_at(i) != inner_classes->ushort_at(j) ||
|
guarantee_property((inner_classes->ushort_at(i) != inner_classes->ushort_at(j) ||
|
||||||
inner_classes->ushort_at(i+1) != inner_classes->ushort_at(j+1) ||
|
inner_classes->ushort_at(i+1) != inner_classes->ushort_at(j+1) ||
|
||||||
inner_classes->ushort_at(i+2) != inner_classes->ushort_at(j+2) ||
|
inner_classes->ushort_at(i+2) != inner_classes->ushort_at(j+2) ||
|
||||||
@ -2384,8 +2403,19 @@ u2 ClassFileParser::parse_classfile_inner_classes_attribute(constantPoolHandle c
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Set EnclosingMethod class and method indexes.
|
||||||
|
if (parsed_enclosingmethod_attribute) {
|
||||||
|
inner_classes->short_at_put(index++, enclosing_method_class_index);
|
||||||
|
inner_classes->short_at_put(index++, enclosing_method_method_index);
|
||||||
|
}
|
||||||
|
assert(index == size, "wrong size");
|
||||||
|
|
||||||
// Update instanceKlass with inner class info.
|
// Update instanceKlass with inner class info.
|
||||||
k->set_inner_classes(inner_classes());
|
k->set_inner_classes(inner_classes());
|
||||||
|
|
||||||
|
// Restore buffer's current position.
|
||||||
|
cfs->set_current(current_mark);
|
||||||
|
|
||||||
return length;
|
return length;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2490,6 +2520,10 @@ void ClassFileParser::parse_classfile_attributes(constantPoolHandle cp, instance
|
|||||||
int runtime_visible_annotations_length = 0;
|
int runtime_visible_annotations_length = 0;
|
||||||
u1* runtime_invisible_annotations = NULL;
|
u1* runtime_invisible_annotations = NULL;
|
||||||
int runtime_invisible_annotations_length = 0;
|
int runtime_invisible_annotations_length = 0;
|
||||||
|
u1* inner_classes_attribute_start = NULL;
|
||||||
|
u4 inner_classes_attribute_length = 0;
|
||||||
|
u2 enclosing_method_class_index = 0;
|
||||||
|
u2 enclosing_method_method_index = 0;
|
||||||
// Iterate over attributes
|
// Iterate over attributes
|
||||||
while (attributes_count--) {
|
while (attributes_count--) {
|
||||||
cfs->guarantee_more(6, CHECK); // attribute_name_index, attribute_length
|
cfs->guarantee_more(6, CHECK); // attribute_name_index, attribute_length
|
||||||
@ -2522,11 +2556,9 @@ void ClassFileParser::parse_classfile_attributes(constantPoolHandle cp, instance
|
|||||||
} else {
|
} else {
|
||||||
parsed_innerclasses_attribute = true;
|
parsed_innerclasses_attribute = true;
|
||||||
}
|
}
|
||||||
u2 num_of_classes = parse_classfile_inner_classes_attribute(cp, k, CHECK);
|
inner_classes_attribute_start = cfs->get_u1_buffer();
|
||||||
if (_need_verify && _major_version >= JAVA_1_5_VERSION) {
|
inner_classes_attribute_length = attribute_length;
|
||||||
guarantee_property(attribute_length == sizeof(num_of_classes) + 4 * sizeof(u2) * num_of_classes,
|
cfs->skip_u1(inner_classes_attribute_length, CHECK);
|
||||||
"Wrong InnerClasses attribute length in class file %s", CHECK);
|
|
||||||
}
|
|
||||||
} else if (tag == vmSymbols::tag_synthetic()) {
|
} else if (tag == vmSymbols::tag_synthetic()) {
|
||||||
// Check for Synthetic tag
|
// Check for Synthetic tag
|
||||||
// Shouldn't we check that the synthetic flags wasn't already set? - not required in spec
|
// Shouldn't we check that the synthetic flags wasn't already set? - not required in spec
|
||||||
@ -2568,22 +2600,21 @@ void ClassFileParser::parse_classfile_attributes(constantPoolHandle cp, instance
|
|||||||
parsed_enclosingmethod_attribute = true;
|
parsed_enclosingmethod_attribute = true;
|
||||||
}
|
}
|
||||||
cfs->guarantee_more(4, CHECK); // class_index, method_index
|
cfs->guarantee_more(4, CHECK); // class_index, method_index
|
||||||
u2 class_index = cfs->get_u2_fast();
|
enclosing_method_class_index = cfs->get_u2_fast();
|
||||||
u2 method_index = cfs->get_u2_fast();
|
enclosing_method_method_index = cfs->get_u2_fast();
|
||||||
if (class_index == 0) {
|
if (enclosing_method_class_index == 0) {
|
||||||
classfile_parse_error("Invalid class index in EnclosingMethod attribute in class file %s", CHECK);
|
classfile_parse_error("Invalid class index in EnclosingMethod attribute in class file %s", CHECK);
|
||||||
}
|
}
|
||||||
// Validate the constant pool indices and types
|
// Validate the constant pool indices and types
|
||||||
if (!cp->is_within_bounds(class_index) ||
|
if (!cp->is_within_bounds(enclosing_method_class_index) ||
|
||||||
!is_klass_reference(cp, class_index)) {
|
!is_klass_reference(cp, enclosing_method_class_index)) {
|
||||||
classfile_parse_error("Invalid or out-of-bounds class index in EnclosingMethod attribute in class file %s", CHECK);
|
classfile_parse_error("Invalid or out-of-bounds class index in EnclosingMethod attribute in class file %s", CHECK);
|
||||||
}
|
}
|
||||||
if (method_index != 0 &&
|
if (enclosing_method_method_index != 0 &&
|
||||||
(!cp->is_within_bounds(method_index) ||
|
(!cp->is_within_bounds(enclosing_method_method_index) ||
|
||||||
!cp->tag_at(method_index).is_name_and_type())) {
|
!cp->tag_at(enclosing_method_method_index).is_name_and_type())) {
|
||||||
classfile_parse_error("Invalid or out-of-bounds method index in EnclosingMethod attribute in class file %s", CHECK);
|
classfile_parse_error("Invalid or out-of-bounds method index in EnclosingMethod attribute in class file %s", CHECK);
|
||||||
}
|
}
|
||||||
k->set_enclosing_method_indices(class_index, method_index);
|
|
||||||
} else if (tag == vmSymbols::tag_bootstrap_methods() &&
|
} else if (tag == vmSymbols::tag_bootstrap_methods() &&
|
||||||
_major_version >= Verifier::INVOKEDYNAMIC_MAJOR_VERSION) {
|
_major_version >= Verifier::INVOKEDYNAMIC_MAJOR_VERSION) {
|
||||||
if (parsed_bootstrap_methods_attribute)
|
if (parsed_bootstrap_methods_attribute)
|
||||||
@ -2606,6 +2637,20 @@ void ClassFileParser::parse_classfile_attributes(constantPoolHandle cp, instance
|
|||||||
CHECK);
|
CHECK);
|
||||||
k->set_class_annotations(annotations());
|
k->set_class_annotations(annotations());
|
||||||
|
|
||||||
|
if (parsed_innerclasses_attribute || parsed_enclosingmethod_attribute) {
|
||||||
|
u2 num_of_classes = parse_classfile_inner_classes_attribute(
|
||||||
|
inner_classes_attribute_start,
|
||||||
|
parsed_innerclasses_attribute,
|
||||||
|
enclosing_method_class_index,
|
||||||
|
enclosing_method_method_index,
|
||||||
|
cp, k, CHECK);
|
||||||
|
if (parsed_innerclasses_attribute &&_need_verify && _major_version >= JAVA_1_5_VERSION) {
|
||||||
|
guarantee_property(
|
||||||
|
inner_classes_attribute_length == sizeof(num_of_classes) + 4 * sizeof(u2) * num_of_classes,
|
||||||
|
"Wrong InnerClasses attribute length in class file %s", CHECK);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (_max_bootstrap_specifier_index >= 0) {
|
if (_max_bootstrap_specifier_index >= 0) {
|
||||||
guarantee_property(parsed_bootstrap_methods_attribute,
|
guarantee_property(parsed_bootstrap_methods_attribute,
|
||||||
"Missing BootstrapMethods attribute in class file %s", CHECK);
|
"Missing BootstrapMethods attribute in class file %s", CHECK);
|
||||||
|
@ -130,7 +130,11 @@ class ClassFileParser VALUE_OBJ_CLASS_SPEC {
|
|||||||
void parse_classfile_sourcefile_attribute(constantPoolHandle cp, instanceKlassHandle k, TRAPS);
|
void parse_classfile_sourcefile_attribute(constantPoolHandle cp, instanceKlassHandle k, TRAPS);
|
||||||
void parse_classfile_source_debug_extension_attribute(constantPoolHandle cp,
|
void parse_classfile_source_debug_extension_attribute(constantPoolHandle cp,
|
||||||
instanceKlassHandle k, int length, TRAPS);
|
instanceKlassHandle k, int length, TRAPS);
|
||||||
u2 parse_classfile_inner_classes_attribute(constantPoolHandle cp,
|
u2 parse_classfile_inner_classes_attribute(u1* inner_classes_attribute_start,
|
||||||
|
bool parsed_enclosingmethod_attribute,
|
||||||
|
u2 enclosing_method_class_index,
|
||||||
|
u2 enclosing_method_method_index,
|
||||||
|
constantPoolHandle cp,
|
||||||
instanceKlassHandle k, TRAPS);
|
instanceKlassHandle k, TRAPS);
|
||||||
void parse_classfile_attributes(constantPoolHandle cp, instanceKlassHandle k, TRAPS);
|
void parse_classfile_attributes(constantPoolHandle cp, instanceKlassHandle k, TRAPS);
|
||||||
void parse_classfile_synthetic_attribute(constantPoolHandle cp, instanceKlassHandle k, TRAPS);
|
void parse_classfile_synthetic_attribute(constantPoolHandle cp, instanceKlassHandle k, TRAPS);
|
||||||
|
@ -285,7 +285,7 @@ size_t CollectionSetChooser::calcMinOldCSetLength() {
|
|||||||
// that the result is the same during all mixed GCs that follow a cycle.
|
// that the result is the same during all mixed GCs that follow a cycle.
|
||||||
|
|
||||||
const size_t region_num = (size_t) _length;
|
const size_t region_num = (size_t) _length;
|
||||||
const size_t gc_num = (size_t) G1MaxMixedGCNum;
|
const size_t gc_num = (size_t) G1MixedGCCountTarget;
|
||||||
size_t result = region_num / gc_num;
|
size_t result = region_num / gc_num;
|
||||||
// emulate ceiling
|
// emulate ceiling
|
||||||
if (result * gc_num < region_num) {
|
if (result * gc_num < region_num) {
|
||||||
|
@ -155,7 +155,7 @@ void ConcurrentMarkThread::run() {
|
|||||||
|
|
||||||
CMCheckpointRootsFinalClosure final_cl(_cm);
|
CMCheckpointRootsFinalClosure final_cl(_cm);
|
||||||
sprintf(verbose_str, "GC remark");
|
sprintf(verbose_str, "GC remark");
|
||||||
VM_CGC_Operation op(&final_cl, verbose_str);
|
VM_CGC_Operation op(&final_cl, verbose_str, true /* needs_pll */);
|
||||||
VMThread::execute(&op);
|
VMThread::execute(&op);
|
||||||
}
|
}
|
||||||
if (cm()->restart_for_overflow() &&
|
if (cm()->restart_for_overflow() &&
|
||||||
@ -189,7 +189,7 @@ void ConcurrentMarkThread::run() {
|
|||||||
|
|
||||||
CMCleanUp cl_cl(_cm);
|
CMCleanUp cl_cl(_cm);
|
||||||
sprintf(verbose_str, "GC cleanup");
|
sprintf(verbose_str, "GC cleanup");
|
||||||
VM_CGC_Operation op(&cl_cl, verbose_str);
|
VM_CGC_Operation op(&cl_cl, verbose_str, false /* needs_pll */);
|
||||||
VMThread::execute(&op);
|
VMThread::execute(&op);
|
||||||
} else {
|
} else {
|
||||||
// We don't want to update the marking status if a GC pause
|
// We don't want to update the marking status if a GC pause
|
||||||
|
@ -2437,20 +2437,22 @@ void G1CollectedHeap::collect(GCCause::Cause cause) {
|
|||||||
true, /* should_initiate_conc_mark */
|
true, /* should_initiate_conc_mark */
|
||||||
g1_policy()->max_pause_time_ms(),
|
g1_policy()->max_pause_time_ms(),
|
||||||
cause);
|
cause);
|
||||||
|
|
||||||
VMThread::execute(&op);
|
VMThread::execute(&op);
|
||||||
if (!op.pause_succeeded()) {
|
if (!op.pause_succeeded()) {
|
||||||
// Another GC got scheduled and prevented us from scheduling
|
|
||||||
// the initial-mark GC. It's unlikely that the GC that
|
|
||||||
// pre-empted us was also an initial-mark GC. So, we'll retry
|
|
||||||
// the initial-mark GC.
|
|
||||||
|
|
||||||
if (full_gc_count_before == total_full_collections()) {
|
if (full_gc_count_before == total_full_collections()) {
|
||||||
retry_gc = true;
|
retry_gc = op.should_retry_gc();
|
||||||
} else {
|
} else {
|
||||||
// A Full GC happened while we were trying to schedule the
|
// A Full GC happened while we were trying to schedule the
|
||||||
// initial-mark GC. No point in starting a new cycle given
|
// initial-mark GC. No point in starting a new cycle given
|
||||||
// that the whole heap was collected anyway.
|
// that the whole heap was collected anyway.
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (retry_gc) {
|
||||||
|
if (GC_locker::is_active_and_needs_gc()) {
|
||||||
|
GC_locker::stall_until_clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (cause == GCCause::_gc_locker
|
if (cause == GCCause::_gc_locker
|
||||||
|
@ -2608,7 +2608,7 @@ bool G1CollectorPolicy::next_gc_should_be_mixed(const char* true_action_str,
|
|||||||
size_t reclaimable_bytes = cset_chooser->remainingReclaimableBytes();
|
size_t reclaimable_bytes = cset_chooser->remainingReclaimableBytes();
|
||||||
size_t capacity_bytes = _g1->capacity();
|
size_t capacity_bytes = _g1->capacity();
|
||||||
double perc = (double) reclaimable_bytes * 100.0 / (double) capacity_bytes;
|
double perc = (double) reclaimable_bytes * 100.0 / (double) capacity_bytes;
|
||||||
double threshold = (double) G1OldReclaimableThresholdPercent;
|
double threshold = (double) G1HeapWastePercent;
|
||||||
if (perc < threshold) {
|
if (perc < threshold) {
|
||||||
ergo_verbose4(ErgoMixedGCs,
|
ergo_verbose4(ErgoMixedGCs,
|
||||||
false_action_str,
|
false_action_str,
|
||||||
|
@ -940,10 +940,9 @@ public:
|
|||||||
return _bytes_copied_during_gc;
|
return _bytes_copied_during_gc;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Determine whether the next GC should be mixed. Called to determine
|
// Determine whether there are candidate regions so that the
|
||||||
// whether to start mixed GCs or whether to carry on doing mixed
|
// next GC should be mixed. The two action strings are used
|
||||||
// GCs. The two action strings are used in the ergo output when the
|
// in the ergo output when the method returns true or false.
|
||||||
// method returns true or false.
|
|
||||||
bool next_gc_should_be_mixed(const char* true_action_str,
|
bool next_gc_should_be_mixed(const char* true_action_str,
|
||||||
const char* false_action_str);
|
const char* false_action_str);
|
||||||
|
|
||||||
|
@ -299,17 +299,16 @@
|
|||||||
"Percentage (0-100) of the heap size to use as maximum " \
|
"Percentage (0-100) of the heap size to use as maximum " \
|
||||||
"young gen size.") \
|
"young gen size.") \
|
||||||
\
|
\
|
||||||
develop(uintx, G1OldCSetRegionLiveThresholdPercent, 95, \
|
develop(uintx, G1OldCSetRegionLiveThresholdPercent, 90, \
|
||||||
"Threshold for regions to be added to the collection set. " \
|
"Threshold for regions to be added to the collection set. " \
|
||||||
"Regions with more live bytes that this will not be collected.") \
|
"Regions with more live bytes that this will not be collected.") \
|
||||||
\
|
\
|
||||||
develop(uintx, G1OldReclaimableThresholdPercent, 1, \
|
product(uintx, G1HeapWastePercent, 5, \
|
||||||
"Threshold for the remaining old reclaimable bytes, expressed " \
|
"Amount of space, expressed as a percentage of the heap size, " \
|
||||||
"as a percentage of the heap size. If the old reclaimable bytes " \
|
"that G1 is willing not to collect to avoid expensive GCs.") \
|
||||||
"are under this we will not collect them with more mixed GCs.") \
|
|
||||||
\
|
\
|
||||||
develop(uintx, G1MaxMixedGCNum, 4, \
|
product(uintx, G1MixedGCCountTarget, 4, \
|
||||||
"The maximum desired number of mixed GCs after a marking cycle.") \
|
"The target number of mixed GCs after a marking cycle.") \
|
||||||
\
|
\
|
||||||
develop(uintx, G1OldCSetRegionThresholdPercent, 10, \
|
develop(uintx, G1OldCSetRegionThresholdPercent, 10, \
|
||||||
"An upper bound for the number of old CSet regions expressed " \
|
"An upper bound for the number of old CSet regions expressed " \
|
||||||
|
@ -34,7 +34,8 @@
|
|||||||
VM_G1CollectForAllocation::VM_G1CollectForAllocation(
|
VM_G1CollectForAllocation::VM_G1CollectForAllocation(
|
||||||
unsigned int gc_count_before,
|
unsigned int gc_count_before,
|
||||||
size_t word_size)
|
size_t word_size)
|
||||||
: VM_G1OperationWithAllocRequest(gc_count_before, word_size) {
|
: VM_G1OperationWithAllocRequest(gc_count_before, word_size,
|
||||||
|
GCCause::_allocation_failure) {
|
||||||
guarantee(word_size > 0, "an allocation should always be requested");
|
guarantee(word_size > 0, "an allocation should always be requested");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -57,9 +58,10 @@ VM_G1IncCollectionPause::VM_G1IncCollectionPause(
|
|||||||
bool should_initiate_conc_mark,
|
bool should_initiate_conc_mark,
|
||||||
double target_pause_time_ms,
|
double target_pause_time_ms,
|
||||||
GCCause::Cause gc_cause)
|
GCCause::Cause gc_cause)
|
||||||
: VM_G1OperationWithAllocRequest(gc_count_before, word_size),
|
: VM_G1OperationWithAllocRequest(gc_count_before, word_size, gc_cause),
|
||||||
_should_initiate_conc_mark(should_initiate_conc_mark),
|
_should_initiate_conc_mark(should_initiate_conc_mark),
|
||||||
_target_pause_time_ms(target_pause_time_ms),
|
_target_pause_time_ms(target_pause_time_ms),
|
||||||
|
_should_retry_gc(false),
|
||||||
_full_collections_completed_before(0) {
|
_full_collections_completed_before(0) {
|
||||||
guarantee(target_pause_time_ms > 0.0,
|
guarantee(target_pause_time_ms > 0.0,
|
||||||
err_msg("target_pause_time_ms = %1.6lf should be positive",
|
err_msg("target_pause_time_ms = %1.6lf should be positive",
|
||||||
@ -70,6 +72,22 @@ VM_G1IncCollectionPause::VM_G1IncCollectionPause(
|
|||||||
_gc_cause = gc_cause;
|
_gc_cause = gc_cause;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool VM_G1IncCollectionPause::doit_prologue() {
|
||||||
|
bool res = VM_GC_Operation::doit_prologue();
|
||||||
|
if (!res) {
|
||||||
|
if (_should_initiate_conc_mark) {
|
||||||
|
// The prologue can fail for a couple of reasons. The first is that another GC
|
||||||
|
// got scheduled and prevented the scheduling of the initial mark GC. The
|
||||||
|
// second is that the GC locker may be active and the heap can't be expanded.
|
||||||
|
// In both cases we want to retry the GC so that the initial mark pause is
|
||||||
|
// actually scheduled. In the second case, however, we should stall until
|
||||||
|
// until the GC locker is no longer active and then retry the initial mark GC.
|
||||||
|
_should_retry_gc = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
void VM_G1IncCollectionPause::doit() {
|
void VM_G1IncCollectionPause::doit() {
|
||||||
G1CollectedHeap* g1h = G1CollectedHeap::heap();
|
G1CollectedHeap* g1h = G1CollectedHeap::heap();
|
||||||
assert(!_should_initiate_conc_mark ||
|
assert(!_should_initiate_conc_mark ||
|
||||||
@ -106,11 +124,25 @@ void VM_G1IncCollectionPause::doit() {
|
|||||||
// next GC pause to be an initial mark; it returns false if a
|
// next GC pause to be an initial mark; it returns false if a
|
||||||
// marking cycle is already in progress.
|
// marking cycle is already in progress.
|
||||||
//
|
//
|
||||||
// If a marking cycle is already in progress just return and skip
|
// If a marking cycle is already in progress just return and skip the
|
||||||
// the pause - the requesting thread should block in doit_epilogue
|
// pause below - if the reason for requesting this initial mark pause
|
||||||
// until the marking cycle is complete.
|
// was due to a System.gc() then the requesting thread should block in
|
||||||
|
// doit_epilogue() until the marking cycle is complete.
|
||||||
|
//
|
||||||
|
// If this initial mark pause was requested as part of a humongous
|
||||||
|
// allocation then we know that the marking cycle must just have
|
||||||
|
// been started by another thread (possibly also allocating a humongous
|
||||||
|
// object) as there was no active marking cycle when the requesting
|
||||||
|
// thread checked before calling collect() in
|
||||||
|
// attempt_allocation_humongous(). Retrying the GC, in this case,
|
||||||
|
// will cause the requesting thread to spin inside collect() until the
|
||||||
|
// just started marking cycle is complete - which may be a while. So
|
||||||
|
// we do NOT retry the GC.
|
||||||
if (!res) {
|
if (!res) {
|
||||||
assert(_word_size == 0, "ExplicitGCInvokesConcurrent shouldn't be allocating");
|
assert(_word_size == 0, "Concurrent Full GC/Humongous Object IM shouldn't be allocating");
|
||||||
|
if (_gc_cause != GCCause::_g1_humongous_allocation) {
|
||||||
|
_should_retry_gc = true;
|
||||||
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -123,6 +155,13 @@ void VM_G1IncCollectionPause::doit() {
|
|||||||
true /* expect_null_cur_alloc_region */);
|
true /* expect_null_cur_alloc_region */);
|
||||||
} else {
|
} else {
|
||||||
assert(_result == NULL, "invariant");
|
assert(_result == NULL, "invariant");
|
||||||
|
if (!_pause_succeeded) {
|
||||||
|
// Another possible reason reason for the pause to not be successful
|
||||||
|
// is that, again, the GC locker is active (and has become active
|
||||||
|
// since the prologue was executed). In this case we should retry
|
||||||
|
// the pause after waiting for the GC locker to become inactive.
|
||||||
|
_should_retry_gc = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -168,6 +207,7 @@ void VM_G1IncCollectionPause::doit_epilogue() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void VM_CGC_Operation::acquire_pending_list_lock() {
|
void VM_CGC_Operation::acquire_pending_list_lock() {
|
||||||
|
assert(_needs_pll, "don't call this otherwise");
|
||||||
// The caller may block while communicating
|
// The caller may block while communicating
|
||||||
// with the SLT thread in order to acquire/release the PLL.
|
// with the SLT thread in order to acquire/release the PLL.
|
||||||
ConcurrentMarkThread::slt()->
|
ConcurrentMarkThread::slt()->
|
||||||
@ -175,6 +215,7 @@ void VM_CGC_Operation::acquire_pending_list_lock() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void VM_CGC_Operation::release_and_notify_pending_list_lock() {
|
void VM_CGC_Operation::release_and_notify_pending_list_lock() {
|
||||||
|
assert(_needs_pll, "don't call this otherwise");
|
||||||
// The caller may block while communicating
|
// The caller may block while communicating
|
||||||
// with the SLT thread in order to acquire/release the PLL.
|
// with the SLT thread in order to acquire/release the PLL.
|
||||||
ConcurrentMarkThread::slt()->
|
ConcurrentMarkThread::slt()->
|
||||||
@ -198,7 +239,9 @@ void VM_CGC_Operation::doit() {
|
|||||||
bool VM_CGC_Operation::doit_prologue() {
|
bool VM_CGC_Operation::doit_prologue() {
|
||||||
// Note the relative order of the locks must match that in
|
// Note the relative order of the locks must match that in
|
||||||
// VM_GC_Operation::doit_prologue() or deadlocks can occur
|
// VM_GC_Operation::doit_prologue() or deadlocks can occur
|
||||||
|
if (_needs_pll) {
|
||||||
acquire_pending_list_lock();
|
acquire_pending_list_lock();
|
||||||
|
}
|
||||||
|
|
||||||
Heap_lock->lock();
|
Heap_lock->lock();
|
||||||
SharedHeap::heap()->_thread_holds_heap_lock_for_gc = true;
|
SharedHeap::heap()->_thread_holds_heap_lock_for_gc = true;
|
||||||
@ -210,5 +253,7 @@ void VM_CGC_Operation::doit_epilogue() {
|
|||||||
// VM_GC_Operation::doit_epilogue()
|
// VM_GC_Operation::doit_epilogue()
|
||||||
SharedHeap::heap()->_thread_holds_heap_lock_for_gc = false;
|
SharedHeap::heap()->_thread_holds_heap_lock_for_gc = false;
|
||||||
Heap_lock->unlock();
|
Heap_lock->unlock();
|
||||||
|
if (_needs_pll) {
|
||||||
release_and_notify_pending_list_lock();
|
release_and_notify_pending_list_lock();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2001, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -43,8 +43,9 @@ protected:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
VM_G1OperationWithAllocRequest(unsigned int gc_count_before,
|
VM_G1OperationWithAllocRequest(unsigned int gc_count_before,
|
||||||
size_t word_size)
|
size_t word_size,
|
||||||
: VM_GC_Operation(gc_count_before, GCCause::_allocation_failure),
|
GCCause::Cause gc_cause)
|
||||||
|
: VM_GC_Operation(gc_count_before, gc_cause),
|
||||||
_word_size(word_size), _result(NULL), _pause_succeeded(false) { }
|
_word_size(word_size), _result(NULL), _pause_succeeded(false) { }
|
||||||
HeapWord* result() { return _result; }
|
HeapWord* result() { return _result; }
|
||||||
bool pause_succeeded() { return _pause_succeeded; }
|
bool pause_succeeded() { return _pause_succeeded; }
|
||||||
@ -77,6 +78,7 @@ public:
|
|||||||
class VM_G1IncCollectionPause: public VM_G1OperationWithAllocRequest {
|
class VM_G1IncCollectionPause: public VM_G1OperationWithAllocRequest {
|
||||||
private:
|
private:
|
||||||
bool _should_initiate_conc_mark;
|
bool _should_initiate_conc_mark;
|
||||||
|
bool _should_retry_gc;
|
||||||
double _target_pause_time_ms;
|
double _target_pause_time_ms;
|
||||||
unsigned int _full_collections_completed_before;
|
unsigned int _full_collections_completed_before;
|
||||||
public:
|
public:
|
||||||
@ -86,11 +88,13 @@ public:
|
|||||||
double target_pause_time_ms,
|
double target_pause_time_ms,
|
||||||
GCCause::Cause gc_cause);
|
GCCause::Cause gc_cause);
|
||||||
virtual VMOp_Type type() const { return VMOp_G1IncCollectionPause; }
|
virtual VMOp_Type type() const { return VMOp_G1IncCollectionPause; }
|
||||||
|
virtual bool doit_prologue();
|
||||||
virtual void doit();
|
virtual void doit();
|
||||||
virtual void doit_epilogue();
|
virtual void doit_epilogue();
|
||||||
virtual const char* name() const {
|
virtual const char* name() const {
|
||||||
return "garbage-first incremental collection pause";
|
return "garbage-first incremental collection pause";
|
||||||
}
|
}
|
||||||
|
bool should_retry_gc() const { return _should_retry_gc; }
|
||||||
};
|
};
|
||||||
|
|
||||||
// Concurrent GC stop-the-world operations such as remark and cleanup;
|
// Concurrent GC stop-the-world operations such as remark and cleanup;
|
||||||
@ -98,6 +102,7 @@ public:
|
|||||||
class VM_CGC_Operation: public VM_Operation {
|
class VM_CGC_Operation: public VM_Operation {
|
||||||
VoidClosure* _cl;
|
VoidClosure* _cl;
|
||||||
const char* _printGCMessage;
|
const char* _printGCMessage;
|
||||||
|
bool _needs_pll;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// java.lang.ref.Reference support
|
// java.lang.ref.Reference support
|
||||||
@ -105,8 +110,8 @@ protected:
|
|||||||
void release_and_notify_pending_list_lock();
|
void release_and_notify_pending_list_lock();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
VM_CGC_Operation(VoidClosure* cl, const char *printGCMsg)
|
VM_CGC_Operation(VoidClosure* cl, const char *printGCMsg, bool needs_pll)
|
||||||
: _cl(cl), _printGCMessage(printGCMsg) { }
|
: _cl(cl), _printGCMessage(printGCMsg), _needs_pll(needs_pll) { }
|
||||||
virtual VMOp_Type type() const { return VMOp_CGC_Operation; }
|
virtual VMOp_Type type() const { return VMOp_CGC_Operation; }
|
||||||
virtual void doit();
|
virtual void doit();
|
||||||
virtual bool doit_prologue();
|
virtual bool doit_prologue();
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
#ifndef SHARE_VM_GC_IMPLEMENTATION_PARALLELSCAVENGE_PSPROMOTIONMANAGER_INLINE_HPP
|
#ifndef SHARE_VM_GC_IMPLEMENTATION_PARALLELSCAVENGE_PSPROMOTIONMANAGER_INLINE_HPP
|
||||||
#define SHARE_VM_GC_IMPLEMENTATION_PARALLELSCAVENGE_PSPROMOTIONMANAGER_INLINE_HPP
|
#define SHARE_VM_GC_IMPLEMENTATION_PARALLELSCAVENGE_PSPROMOTIONMANAGER_INLINE_HPP
|
||||||
|
|
||||||
|
#include "gc_implementation/parallelScavenge/psOldGen.hpp"
|
||||||
#include "gc_implementation/parallelScavenge/psPromotionManager.hpp"
|
#include "gc_implementation/parallelScavenge/psPromotionManager.hpp"
|
||||||
#include "gc_implementation/parallelScavenge/psScavenge.hpp"
|
#include "gc_implementation/parallelScavenge/psScavenge.hpp"
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2006, 2010, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2006, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -91,30 +91,38 @@ void MutableNUMASpace::ensure_parsability() {
|
|||||||
MutableSpace *s = ls->space();
|
MutableSpace *s = ls->space();
|
||||||
if (s->top() < top()) { // For all spaces preceding the one containing top()
|
if (s->top() < top()) { // For all spaces preceding the one containing top()
|
||||||
if (s->free_in_words() > 0) {
|
if (s->free_in_words() > 0) {
|
||||||
size_t area_touched_words = pointer_delta(s->end(), s->top());
|
intptr_t cur_top = (intptr_t)s->top();
|
||||||
CollectedHeap::fill_with_object(s->top(), area_touched_words);
|
size_t words_left_to_fill = pointer_delta(s->end(), s->top());;
|
||||||
|
while (words_left_to_fill > 0) {
|
||||||
|
size_t words_to_fill = MIN2(words_left_to_fill, CollectedHeap::filler_array_max_size());
|
||||||
|
assert(words_to_fill >= CollectedHeap::min_fill_size(),
|
||||||
|
err_msg("Remaining size ("SIZE_FORMAT ") is too small to fill (based on " SIZE_FORMAT " and " SIZE_FORMAT ")",
|
||||||
|
words_to_fill, words_left_to_fill, CollectedHeap::filler_array_max_size()));
|
||||||
|
CollectedHeap::fill_with_object((HeapWord*)cur_top, words_to_fill);
|
||||||
|
if (!os::numa_has_static_binding()) {
|
||||||
|
size_t touched_words = words_to_fill;
|
||||||
#ifndef ASSERT
|
#ifndef ASSERT
|
||||||
if (!ZapUnusedHeapArea) {
|
if (!ZapUnusedHeapArea) {
|
||||||
area_touched_words = MIN2((size_t)align_object_size(typeArrayOopDesc::header_size(T_INT)),
|
touched_words = MIN2((size_t)align_object_size(typeArrayOopDesc::header_size(T_INT)),
|
||||||
area_touched_words);
|
touched_words);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (!os::numa_has_static_binding()) {
|
|
||||||
MemRegion invalid;
|
MemRegion invalid;
|
||||||
HeapWord *crossing_start = (HeapWord*)round_to((intptr_t)s->top(), os::vm_page_size());
|
HeapWord *crossing_start = (HeapWord*)round_to(cur_top, os::vm_page_size());
|
||||||
HeapWord *crossing_end = (HeapWord*)round_to((intptr_t)(s->top() + area_touched_words),
|
HeapWord *crossing_end = (HeapWord*)round_to(cur_top + touched_words, os::vm_page_size());
|
||||||
os::vm_page_size());
|
|
||||||
if (crossing_start != crossing_end) {
|
if (crossing_start != crossing_end) {
|
||||||
// If object header crossed a small page boundary we mark the area
|
// If object header crossed a small page boundary we mark the area
|
||||||
// as invalid rounding it to a page_size().
|
// as invalid rounding it to a page_size().
|
||||||
HeapWord *start = MAX2((HeapWord*)round_down((intptr_t)s->top(), page_size()), s->bottom());
|
HeapWord *start = MAX2((HeapWord*)round_down(cur_top, page_size()), s->bottom());
|
||||||
HeapWord *end = MIN2((HeapWord*)round_to((intptr_t)(s->top() + area_touched_words), page_size()),
|
HeapWord *end = MIN2((HeapWord*)round_to(cur_top + touched_words, page_size()), s->end());
|
||||||
s->end());
|
|
||||||
invalid = MemRegion(start, end);
|
invalid = MemRegion(start, end);
|
||||||
}
|
}
|
||||||
|
|
||||||
ls->add_invalid_region(invalid);
|
ls->add_invalid_region(invalid);
|
||||||
}
|
}
|
||||||
|
cur_top = cur_top + (words_to_fill * HeapWordSize);
|
||||||
|
words_left_to_fill -= words_to_fill;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (!os::numa_has_static_binding()) {
|
if (!os::numa_has_static_binding()) {
|
||||||
|
@ -85,7 +85,7 @@ CollectedHeap::CollectedHeap() : _n_par_threads(0)
|
|||||||
const size_t max_len = size_t(arrayOopDesc::max_array_length(T_INT));
|
const size_t max_len = size_t(arrayOopDesc::max_array_length(T_INT));
|
||||||
const size_t elements_per_word = HeapWordSize / sizeof(jint);
|
const size_t elements_per_word = HeapWordSize / sizeof(jint);
|
||||||
_filler_array_max_size = align_object_size(filler_array_hdr_size() +
|
_filler_array_max_size = align_object_size(filler_array_hdr_size() +
|
||||||
max_len * elements_per_word);
|
max_len / elements_per_word);
|
||||||
|
|
||||||
_barrier_set = NULL;
|
_barrier_set = NULL;
|
||||||
_is_gc_active = false;
|
_is_gc_active = false;
|
||||||
@ -303,10 +303,6 @@ size_t CollectedHeap::filler_array_min_size() {
|
|||||||
return align_object_size(filler_array_hdr_size()); // align to MinObjAlignment
|
return align_object_size(filler_array_hdr_size()); // align to MinObjAlignment
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t CollectedHeap::filler_array_max_size() {
|
|
||||||
return _filler_array_max_size;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
void CollectedHeap::fill_args_check(HeapWord* start, size_t words)
|
void CollectedHeap::fill_args_check(HeapWord* start, size_t words)
|
||||||
{
|
{
|
||||||
@ -333,10 +329,11 @@ CollectedHeap::fill_with_array(HeapWord* start, size_t words, bool zap)
|
|||||||
|
|
||||||
const size_t payload_size = words - filler_array_hdr_size();
|
const size_t payload_size = words - filler_array_hdr_size();
|
||||||
const size_t len = payload_size * HeapWordSize / sizeof(jint);
|
const size_t len = payload_size * HeapWordSize / sizeof(jint);
|
||||||
|
assert((int)len >= 0, err_msg("size too large " SIZE_FORMAT " becomes %d", words, (int)len));
|
||||||
|
|
||||||
// Set the length first for concurrent GC.
|
// Set the length first for concurrent GC.
|
||||||
((arrayOop)start)->set_length((int)len);
|
((arrayOop)start)->set_length((int)len);
|
||||||
post_allocation_setup_common(Universe::intArrayKlassObj(), start, words);
|
post_allocation_setup_common(Universe::intArrayKlassObj(), start);
|
||||||
DEBUG_ONLY(zap_filler_array(start, words, zap);)
|
DEBUG_ONLY(zap_filler_array(start, words, zap);)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -349,8 +346,7 @@ CollectedHeap::fill_with_object_impl(HeapWord* start, size_t words, bool zap)
|
|||||||
fill_with_array(start, words, zap);
|
fill_with_array(start, words, zap);
|
||||||
} else if (words > 0) {
|
} else if (words > 0) {
|
||||||
assert(words == min_fill_size(), "unaligned size");
|
assert(words == min_fill_size(), "unaligned size");
|
||||||
post_allocation_setup_common(SystemDictionary::Object_klass(), start,
|
post_allocation_setup_common(SystemDictionary::Object_klass(), start);
|
||||||
words);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -480,7 +476,7 @@ oop CollectedHeap::Class_obj_allocate(KlassHandle klass, int size, KlassHandle r
|
|||||||
assert(ScavengeRootsInCode > 0, "must be");
|
assert(ScavengeRootsInCode > 0, "must be");
|
||||||
obj = common_mem_allocate_init(size, CHECK_NULL);
|
obj = common_mem_allocate_init(size, CHECK_NULL);
|
||||||
}
|
}
|
||||||
post_allocation_setup_common(klass, obj, size);
|
post_allocation_setup_common(klass, obj);
|
||||||
assert(Universe::is_bootstrapping() ||
|
assert(Universe::is_bootstrapping() ||
|
||||||
!((oop)obj)->blueprint()->oop_is_array(), "must not be an array");
|
!((oop)obj)->blueprint()->oop_is_array(), "must not be an array");
|
||||||
NOT_PRODUCT(Universe::heap()->check_for_bad_heap_word_value(obj, size));
|
NOT_PRODUCT(Universe::heap()->check_for_bad_heap_word_value(obj, size));
|
||||||
|
@ -128,7 +128,6 @@ class CollectedHeap : public CHeapObj {
|
|||||||
// Reinitialize tlabs before resuming mutators.
|
// Reinitialize tlabs before resuming mutators.
|
||||||
virtual void resize_all_tlabs();
|
virtual void resize_all_tlabs();
|
||||||
|
|
||||||
protected:
|
|
||||||
// Allocate from the current thread's TLAB, with broken-out slow path.
|
// Allocate from the current thread's TLAB, with broken-out slow path.
|
||||||
inline static HeapWord* allocate_from_tlab(Thread* thread, size_t size);
|
inline static HeapWord* allocate_from_tlab(Thread* thread, size_t size);
|
||||||
static HeapWord* allocate_from_tlab_slow(Thread* thread, size_t size);
|
static HeapWord* allocate_from_tlab_slow(Thread* thread, size_t size);
|
||||||
@ -150,18 +149,14 @@ class CollectedHeap : public CHeapObj {
|
|||||||
inline static HeapWord* common_permanent_mem_allocate_init(size_t size, TRAPS);
|
inline static HeapWord* common_permanent_mem_allocate_init(size_t size, TRAPS);
|
||||||
|
|
||||||
// Helper functions for (VM) allocation.
|
// Helper functions for (VM) allocation.
|
||||||
inline static void post_allocation_setup_common(KlassHandle klass,
|
inline static void post_allocation_setup_common(KlassHandle klass, HeapWord* obj);
|
||||||
HeapWord* obj, size_t size);
|
|
||||||
inline static void post_allocation_setup_no_klass_install(KlassHandle klass,
|
inline static void post_allocation_setup_no_klass_install(KlassHandle klass,
|
||||||
HeapWord* objPtr,
|
HeapWord* objPtr);
|
||||||
size_t size);
|
|
||||||
|
|
||||||
inline static void post_allocation_setup_obj(KlassHandle klass,
|
inline static void post_allocation_setup_obj(KlassHandle klass, HeapWord* obj);
|
||||||
HeapWord* obj, size_t size);
|
|
||||||
|
|
||||||
inline static void post_allocation_setup_array(KlassHandle klass,
|
inline static void post_allocation_setup_array(KlassHandle klass,
|
||||||
HeapWord* obj, size_t size,
|
HeapWord* obj, int length);
|
||||||
int length);
|
|
||||||
|
|
||||||
// Clears an allocated object.
|
// Clears an allocated object.
|
||||||
inline static void init_obj(HeapWord* obj, size_t size);
|
inline static void init_obj(HeapWord* obj, size_t size);
|
||||||
@ -169,7 +164,6 @@ class CollectedHeap : public CHeapObj {
|
|||||||
// Filler object utilities.
|
// Filler object utilities.
|
||||||
static inline size_t filler_array_hdr_size();
|
static inline size_t filler_array_hdr_size();
|
||||||
static inline size_t filler_array_min_size();
|
static inline size_t filler_array_min_size();
|
||||||
static inline size_t filler_array_max_size();
|
|
||||||
|
|
||||||
DEBUG_ONLY(static void fill_args_check(HeapWord* start, size_t words);)
|
DEBUG_ONLY(static void fill_args_check(HeapWord* start, size_t words);)
|
||||||
DEBUG_ONLY(static void zap_filler_array(HeapWord* start, size_t words, bool zap = true);)
|
DEBUG_ONLY(static void zap_filler_array(HeapWord* start, size_t words, bool zap = true);)
|
||||||
@ -197,6 +191,10 @@ class CollectedHeap : public CHeapObj {
|
|||||||
G1CollectedHeap
|
G1CollectedHeap
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static inline size_t filler_array_max_size() {
|
||||||
|
return _filler_array_max_size;
|
||||||
|
}
|
||||||
|
|
||||||
virtual CollectedHeap::Name kind() const { return CollectedHeap::Abstract; }
|
virtual CollectedHeap::Name kind() const { return CollectedHeap::Abstract; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -366,9 +364,7 @@ class CollectedHeap : public CHeapObj {
|
|||||||
inline static oop permanent_obj_allocate_no_klass_install(KlassHandle klass,
|
inline static oop permanent_obj_allocate_no_klass_install(KlassHandle klass,
|
||||||
int size,
|
int size,
|
||||||
TRAPS);
|
TRAPS);
|
||||||
inline static void post_allocation_install_obj_klass(KlassHandle klass,
|
inline static void post_allocation_install_obj_klass(KlassHandle klass, oop obj);
|
||||||
oop obj,
|
|
||||||
int size);
|
|
||||||
inline static oop permanent_array_allocate(KlassHandle klass, int size, int length, TRAPS);
|
inline static oop permanent_array_allocate(KlassHandle klass, int size, int length, TRAPS);
|
||||||
|
|
||||||
// Raw memory allocation facilities
|
// Raw memory allocation facilities
|
||||||
@ -662,9 +658,6 @@ class CollectedHeap : public CHeapObj {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Allocate GCHeapLog during VM startup
|
|
||||||
static void initialize_heap_log();
|
|
||||||
|
|
||||||
// Heap verification
|
// Heap verification
|
||||||
virtual void verify(bool allow_dirty, bool silent, VerifyOption option) = 0;
|
virtual void verify(bool allow_dirty, bool silent, VerifyOption option) = 0;
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2001, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -50,15 +50,13 @@
|
|||||||
// Inline allocation implementations.
|
// Inline allocation implementations.
|
||||||
|
|
||||||
void CollectedHeap::post_allocation_setup_common(KlassHandle klass,
|
void CollectedHeap::post_allocation_setup_common(KlassHandle klass,
|
||||||
HeapWord* obj,
|
HeapWord* obj) {
|
||||||
size_t size) {
|
post_allocation_setup_no_klass_install(klass, obj);
|
||||||
post_allocation_setup_no_klass_install(klass, obj, size);
|
post_allocation_install_obj_klass(klass, oop(obj));
|
||||||
post_allocation_install_obj_klass(klass, oop(obj), (int) size);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CollectedHeap::post_allocation_setup_no_klass_install(KlassHandle klass,
|
void CollectedHeap::post_allocation_setup_no_klass_install(KlassHandle klass,
|
||||||
HeapWord* objPtr,
|
HeapWord* objPtr) {
|
||||||
size_t size) {
|
|
||||||
oop obj = (oop)objPtr;
|
oop obj = (oop)objPtr;
|
||||||
|
|
||||||
assert(obj != NULL, "NULL object pointer");
|
assert(obj != NULL, "NULL object pointer");
|
||||||
@ -71,8 +69,7 @@ void CollectedHeap::post_allocation_setup_no_klass_install(KlassHandle klass,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void CollectedHeap::post_allocation_install_obj_klass(KlassHandle klass,
|
void CollectedHeap::post_allocation_install_obj_klass(KlassHandle klass,
|
||||||
oop obj,
|
oop obj) {
|
||||||
int size) {
|
|
||||||
// These asserts are kind of complicated because of klassKlass
|
// These asserts are kind of complicated because of klassKlass
|
||||||
// and the beginning of the world.
|
// and the beginning of the world.
|
||||||
assert(klass() != NULL || !Universe::is_fully_initialized(), "NULL klass");
|
assert(klass() != NULL || !Universe::is_fully_initialized(), "NULL klass");
|
||||||
@ -101,9 +98,8 @@ inline void post_allocation_notify(KlassHandle klass, oop obj) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void CollectedHeap::post_allocation_setup_obj(KlassHandle klass,
|
void CollectedHeap::post_allocation_setup_obj(KlassHandle klass,
|
||||||
HeapWord* obj,
|
HeapWord* obj) {
|
||||||
size_t size) {
|
post_allocation_setup_common(klass, obj);
|
||||||
post_allocation_setup_common(klass, obj, size);
|
|
||||||
assert(Universe::is_bootstrapping() ||
|
assert(Universe::is_bootstrapping() ||
|
||||||
!((oop)obj)->blueprint()->oop_is_array(), "must not be an array");
|
!((oop)obj)->blueprint()->oop_is_array(), "must not be an array");
|
||||||
// notify jvmti and dtrace
|
// notify jvmti and dtrace
|
||||||
@ -112,14 +108,13 @@ void CollectedHeap::post_allocation_setup_obj(KlassHandle klass,
|
|||||||
|
|
||||||
void CollectedHeap::post_allocation_setup_array(KlassHandle klass,
|
void CollectedHeap::post_allocation_setup_array(KlassHandle klass,
|
||||||
HeapWord* obj,
|
HeapWord* obj,
|
||||||
size_t size,
|
|
||||||
int length) {
|
int length) {
|
||||||
// Set array length before setting the _klass field
|
// Set array length before setting the _klass field
|
||||||
// in post_allocation_setup_common() because the klass field
|
// in post_allocation_setup_common() because the klass field
|
||||||
// indicates that the object is parsable by concurrent GC.
|
// indicates that the object is parsable by concurrent GC.
|
||||||
assert(length >= 0, "length should be non-negative");
|
assert(length >= 0, "length should be non-negative");
|
||||||
((arrayOop)obj)->set_length(length);
|
((arrayOop)obj)->set_length(length);
|
||||||
post_allocation_setup_common(klass, obj, size);
|
post_allocation_setup_common(klass, obj);
|
||||||
assert(((oop)obj)->blueprint()->oop_is_array(), "must be an array");
|
assert(((oop)obj)->blueprint()->oop_is_array(), "must be an array");
|
||||||
// notify jvmti and dtrace (must be after length is set for dtrace)
|
// notify jvmti and dtrace (must be after length is set for dtrace)
|
||||||
post_allocation_notify(klass, (oop)obj);
|
post_allocation_notify(klass, (oop)obj);
|
||||||
@ -256,7 +251,7 @@ oop CollectedHeap::obj_allocate(KlassHandle klass, int size, TRAPS) {
|
|||||||
assert(!Universe::heap()->is_gc_active(), "Allocation during gc not allowed");
|
assert(!Universe::heap()->is_gc_active(), "Allocation during gc not allowed");
|
||||||
assert(size >= 0, "int won't convert to size_t");
|
assert(size >= 0, "int won't convert to size_t");
|
||||||
HeapWord* obj = common_mem_allocate_init(size, CHECK_NULL);
|
HeapWord* obj = common_mem_allocate_init(size, CHECK_NULL);
|
||||||
post_allocation_setup_obj(klass, obj, size);
|
post_allocation_setup_obj(klass, obj);
|
||||||
NOT_PRODUCT(Universe::heap()->check_for_bad_heap_word_value(obj, size));
|
NOT_PRODUCT(Universe::heap()->check_for_bad_heap_word_value(obj, size));
|
||||||
return (oop)obj;
|
return (oop)obj;
|
||||||
}
|
}
|
||||||
@ -269,7 +264,7 @@ oop CollectedHeap::array_allocate(KlassHandle klass,
|
|||||||
assert(!Universe::heap()->is_gc_active(), "Allocation during gc not allowed");
|
assert(!Universe::heap()->is_gc_active(), "Allocation during gc not allowed");
|
||||||
assert(size >= 0, "int won't convert to size_t");
|
assert(size >= 0, "int won't convert to size_t");
|
||||||
HeapWord* obj = common_mem_allocate_init(size, CHECK_NULL);
|
HeapWord* obj = common_mem_allocate_init(size, CHECK_NULL);
|
||||||
post_allocation_setup_array(klass, obj, size, length);
|
post_allocation_setup_array(klass, obj, length);
|
||||||
NOT_PRODUCT(Universe::heap()->check_for_bad_heap_word_value(obj, size));
|
NOT_PRODUCT(Universe::heap()->check_for_bad_heap_word_value(obj, size));
|
||||||
return (oop)obj;
|
return (oop)obj;
|
||||||
}
|
}
|
||||||
@ -283,7 +278,7 @@ oop CollectedHeap::array_allocate_nozero(KlassHandle klass,
|
|||||||
assert(size >= 0, "int won't convert to size_t");
|
assert(size >= 0, "int won't convert to size_t");
|
||||||
HeapWord* obj = common_mem_allocate_noinit(size, CHECK_NULL);
|
HeapWord* obj = common_mem_allocate_noinit(size, CHECK_NULL);
|
||||||
((oop)obj)->set_klass_gap(0);
|
((oop)obj)->set_klass_gap(0);
|
||||||
post_allocation_setup_array(klass, obj, size, length);
|
post_allocation_setup_array(klass, obj, length);
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
const size_t hs = oopDesc::header_size()+1;
|
const size_t hs = oopDesc::header_size()+1;
|
||||||
Universe::heap()->check_for_non_bad_heap_word_value(obj+hs, size-hs);
|
Universe::heap()->check_for_non_bad_heap_word_value(obj+hs, size-hs);
|
||||||
@ -293,7 +288,7 @@ oop CollectedHeap::array_allocate_nozero(KlassHandle klass,
|
|||||||
|
|
||||||
oop CollectedHeap::permanent_obj_allocate(KlassHandle klass, int size, TRAPS) {
|
oop CollectedHeap::permanent_obj_allocate(KlassHandle klass, int size, TRAPS) {
|
||||||
oop obj = permanent_obj_allocate_no_klass_install(klass, size, CHECK_NULL);
|
oop obj = permanent_obj_allocate_no_klass_install(klass, size, CHECK_NULL);
|
||||||
post_allocation_install_obj_klass(klass, obj, size);
|
post_allocation_install_obj_klass(klass, obj);
|
||||||
NOT_PRODUCT(Universe::heap()->check_for_bad_heap_word_value((HeapWord*) obj,
|
NOT_PRODUCT(Universe::heap()->check_for_bad_heap_word_value((HeapWord*) obj,
|
||||||
size));
|
size));
|
||||||
return obj;
|
return obj;
|
||||||
@ -306,7 +301,7 @@ oop CollectedHeap::permanent_obj_allocate_no_klass_install(KlassHandle klass,
|
|||||||
assert(!Universe::heap()->is_gc_active(), "Allocation during gc not allowed");
|
assert(!Universe::heap()->is_gc_active(), "Allocation during gc not allowed");
|
||||||
assert(size >= 0, "int won't convert to size_t");
|
assert(size >= 0, "int won't convert to size_t");
|
||||||
HeapWord* obj = common_permanent_mem_allocate_init(size, CHECK_NULL);
|
HeapWord* obj = common_permanent_mem_allocate_init(size, CHECK_NULL);
|
||||||
post_allocation_setup_no_klass_install(klass, obj, size);
|
post_allocation_setup_no_klass_install(klass, obj);
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
const size_t hs = oopDesc::header_size();
|
const size_t hs = oopDesc::header_size();
|
||||||
Universe::heap()->check_for_bad_heap_word_value(obj+hs, size-hs);
|
Universe::heap()->check_for_bad_heap_word_value(obj+hs, size-hs);
|
||||||
@ -322,7 +317,7 @@ oop CollectedHeap::permanent_array_allocate(KlassHandle klass,
|
|||||||
assert(!Universe::heap()->is_gc_active(), "Allocation during gc not allowed");
|
assert(!Universe::heap()->is_gc_active(), "Allocation during gc not allowed");
|
||||||
assert(size >= 0, "int won't convert to size_t");
|
assert(size >= 0, "int won't convert to size_t");
|
||||||
HeapWord* obj = common_permanent_mem_allocate_init(size, CHECK_NULL);
|
HeapWord* obj = common_permanent_mem_allocate_init(size, CHECK_NULL);
|
||||||
post_allocation_setup_array(klass, obj, size, length);
|
post_allocation_setup_array(klass, obj, length);
|
||||||
NOT_PRODUCT(Universe::heap()->check_for_bad_heap_word_value(obj, size));
|
NOT_PRODUCT(Universe::heap()->check_for_bad_heap_word_value(obj, size));
|
||||||
return (oop)obj;
|
return (oop)obj;
|
||||||
}
|
}
|
||||||
|
@ -297,20 +297,18 @@ public:
|
|||||||
|
|
||||||
if (obj->blueprint()->oop_is_instanceKlass()) {
|
if (obj->blueprint()->oop_is_instanceKlass()) {
|
||||||
instanceKlass* ik = instanceKlass::cast((klassOop)obj);
|
instanceKlass* ik = instanceKlass::cast((klassOop)obj);
|
||||||
typeArrayOop inner_classes = ik->inner_classes();
|
instanceKlassHandle ik_h((klassOop)obj);
|
||||||
if (inner_classes != NULL) {
|
InnerClassesIterator iter(ik_h);
|
||||||
constantPoolOop constants = ik->constants();
|
constantPoolOop constants = ik->constants();
|
||||||
int n = inner_classes->length();
|
for (; !iter.done(); iter.next()) {
|
||||||
for (int i = 0; i < n; i += instanceKlass::inner_class_next_offset) {
|
int index = iter.inner_name_index();
|
||||||
int ioff = i + instanceKlass::inner_class_inner_name_offset;
|
|
||||||
int index = inner_classes->ushort_at(ioff);
|
|
||||||
if (index != 0) {
|
if (index != 0) {
|
||||||
_closure->do_symbol(constants->symbol_at_addr(index));
|
_closure->do_symbol(constants->symbol_at_addr(index));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// Traverse symbols referenced by other constantpool entries.
|
// Traverse symbols referenced by other constantpool entries.
|
||||||
|
|
||||||
|
@ -1133,6 +1133,36 @@ JNIid* instanceKlass::jni_id_for(int offset) {
|
|||||||
return probe;
|
return probe;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
u2 instanceKlass::enclosing_method_data(int offset) {
|
||||||
|
typeArrayOop inner_class_list = inner_classes();
|
||||||
|
if (inner_class_list == NULL) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
int length = inner_class_list->length();
|
||||||
|
if (length % inner_class_next_offset == 0) {
|
||||||
|
return 0;
|
||||||
|
} else {
|
||||||
|
int index = length - enclosing_method_attribute_size;
|
||||||
|
typeArrayHandle inner_class_list_h(inner_class_list);
|
||||||
|
assert(offset < enclosing_method_attribute_size, "invalid offset");
|
||||||
|
return inner_class_list_h->ushort_at(index + offset);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void instanceKlass::set_enclosing_method_indices(u2 class_index,
|
||||||
|
u2 method_index) {
|
||||||
|
typeArrayOop inner_class_list = inner_classes();
|
||||||
|
assert (inner_class_list != NULL, "_inner_classes list is not set up");
|
||||||
|
int length = inner_class_list->length();
|
||||||
|
if (length % inner_class_next_offset == enclosing_method_attribute_size) {
|
||||||
|
int index = length - enclosing_method_attribute_size;
|
||||||
|
typeArrayHandle inner_class_list_h(inner_class_list);
|
||||||
|
inner_class_list_h->ushort_at_put(
|
||||||
|
index + enclosing_method_class_index_offset, class_index);
|
||||||
|
inner_class_list_h->ushort_at_put(
|
||||||
|
index + enclosing_method_method_index_offset, method_index);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Lookup or create a jmethodID.
|
// Lookup or create a jmethodID.
|
||||||
// This code is called by the VMThread and JavaThreads so the
|
// This code is called by the VMThread and JavaThreads so the
|
||||||
@ -2107,16 +2137,10 @@ jint instanceKlass::compute_modifier_flags(TRAPS) const {
|
|||||||
jint access = access_flags().as_int();
|
jint access = access_flags().as_int();
|
||||||
|
|
||||||
// But check if it happens to be member class.
|
// But check if it happens to be member class.
|
||||||
typeArrayOop inner_class_list = inner_classes();
|
|
||||||
int length = (inner_class_list == NULL) ? 0 : inner_class_list->length();
|
|
||||||
assert (length % instanceKlass::inner_class_next_offset == 0, "just checking");
|
|
||||||
if (length > 0) {
|
|
||||||
typeArrayHandle inner_class_list_h(THREAD, inner_class_list);
|
|
||||||
instanceKlassHandle ik(THREAD, k);
|
instanceKlassHandle ik(THREAD, k);
|
||||||
for (int i = 0; i < length; i += instanceKlass::inner_class_next_offset) {
|
InnerClassesIterator iter(ik);
|
||||||
int ioff = inner_class_list_h->ushort_at(
|
for (; !iter.done(); iter.next()) {
|
||||||
i + instanceKlass::inner_class_inner_class_info_offset);
|
int ioff = iter.inner_class_info_index();
|
||||||
|
|
||||||
// Inner class attribute can be zero, skip it.
|
// Inner class attribute can be zero, skip it.
|
||||||
// Strange but true: JVM spec. allows null inner class refs.
|
// Strange but true: JVM spec. allows null inner class refs.
|
||||||
if (ioff == 0) continue;
|
if (ioff == 0) continue;
|
||||||
@ -2126,11 +2150,10 @@ jint instanceKlass::compute_modifier_flags(TRAPS) const {
|
|||||||
Symbol* inner_name = ik->constants()->klass_name_at(ioff);
|
Symbol* inner_name = ik->constants()->klass_name_at(ioff);
|
||||||
if ((ik->name() == inner_name)) {
|
if ((ik->name() == inner_name)) {
|
||||||
// This is really a member class.
|
// This is really a member class.
|
||||||
access = inner_class_list_h->ushort_at(i + instanceKlass::inner_class_access_flags_offset);
|
access = iter.inner_access_flags();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
// Remember to strip ACC_SUPER bit
|
// Remember to strip ACC_SUPER bit
|
||||||
return (access & (~JVM_ACC_SUPER)) & JVM_ACC_WRITTEN_FLAGS;
|
return (access & (~JVM_ACC_SUPER)) & JVM_ACC_WRITTEN_FLAGS;
|
||||||
}
|
}
|
||||||
|
@ -188,7 +188,17 @@ class instanceKlass: public Klass {
|
|||||||
klassOop _host_klass;
|
klassOop _host_klass;
|
||||||
// Class signers.
|
// Class signers.
|
||||||
objArrayOop _signers;
|
objArrayOop _signers;
|
||||||
// inner_classes attribute.
|
// The InnerClasses attribute and EnclosingMethod attribute. The
|
||||||
|
// _inner_classes is an array of shorts. If the class has InnerClasses
|
||||||
|
// attribute, then the _inner_classes array begins with 4-tuples of shorts
|
||||||
|
// [inner_class_info_index, outer_class_info_index,
|
||||||
|
// inner_name_index, inner_class_access_flags] for the InnerClasses
|
||||||
|
// attribute. If the EnclosingMethod attribute exists, it occupies the
|
||||||
|
// last two shorts [class_index, method_index] of the array. If only
|
||||||
|
// the InnerClasses attribute exists, the _inner_classes array length is
|
||||||
|
// number_of_inner_classes * 4. If the class has both InnerClasses
|
||||||
|
// and EnclosingMethod attributes the _inner_classes array length is
|
||||||
|
// number_of_inner_classes * 4 + enclosing_method_attribute_size.
|
||||||
typeArrayOop _inner_classes;
|
typeArrayOop _inner_classes;
|
||||||
// Implementors of this interface (not valid if it overflows)
|
// Implementors of this interface (not valid if it overflows)
|
||||||
klassOop _implementors[implementors_limit];
|
klassOop _implementors[implementors_limit];
|
||||||
@ -251,8 +261,6 @@ class instanceKlass: public Klass {
|
|||||||
// Array of interesting part(s) of the previous version(s) of this
|
// Array of interesting part(s) of the previous version(s) of this
|
||||||
// instanceKlass. See PreviousVersionWalker below.
|
// instanceKlass. See PreviousVersionWalker below.
|
||||||
GrowableArray<PreviousVersionNode *>* _previous_versions;
|
GrowableArray<PreviousVersionNode *>* _previous_versions;
|
||||||
u2 _enclosing_method_class_index; // Constant pool index for class of enclosing method, or 0 if none
|
|
||||||
u2 _enclosing_method_method_index; // Constant pool index for name and type of enclosing method, or 0 if none
|
|
||||||
// JVMTI fields can be moved to their own structure - see 6315920
|
// JVMTI fields can be moved to their own structure - see 6315920
|
||||||
unsigned char * _cached_class_file_bytes; // JVMTI: cached class file, before retransformable agent modified it in CFLH
|
unsigned char * _cached_class_file_bytes; // JVMTI: cached class file, before retransformable agent modified it in CFLH
|
||||||
jint _cached_class_file_len; // JVMTI: length of above
|
jint _cached_class_file_len; // JVMTI: length of above
|
||||||
@ -351,6 +359,12 @@ class instanceKlass: public Klass {
|
|||||||
inner_class_next_offset = 4
|
inner_class_next_offset = 4
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum EnclosingMethodAttributeOffset {
|
||||||
|
enclosing_method_class_index_offset = 0,
|
||||||
|
enclosing_method_method_index_offset = 1,
|
||||||
|
enclosing_method_attribute_size = 2
|
||||||
|
};
|
||||||
|
|
||||||
// method override check
|
// method override check
|
||||||
bool is_override(methodHandle super_method, Handle targetclassloader, Symbol* targetclassname, TRAPS);
|
bool is_override(methodHandle super_method, Handle targetclassloader, Symbol* targetclassname, TRAPS);
|
||||||
|
|
||||||
@ -533,11 +547,15 @@ class instanceKlass: public Klass {
|
|||||||
Symbol* generic_signature() const { return _generic_signature; }
|
Symbol* generic_signature() const { return _generic_signature; }
|
||||||
void set_generic_signature(Symbol* sig) { _generic_signature = sig; }
|
void set_generic_signature(Symbol* sig) { _generic_signature = sig; }
|
||||||
|
|
||||||
u2 enclosing_method_class_index() const { return _enclosing_method_class_index; }
|
u2 enclosing_method_data(int offset);
|
||||||
u2 enclosing_method_method_index() const { return _enclosing_method_method_index; }
|
u2 enclosing_method_class_index() {
|
||||||
|
return enclosing_method_data(enclosing_method_class_index_offset);
|
||||||
|
}
|
||||||
|
u2 enclosing_method_method_index() {
|
||||||
|
return enclosing_method_data(enclosing_method_method_index_offset);
|
||||||
|
}
|
||||||
void set_enclosing_method_indices(u2 class_index,
|
void set_enclosing_method_indices(u2 class_index,
|
||||||
u2 method_index) { _enclosing_method_class_index = class_index;
|
u2 method_index);
|
||||||
_enclosing_method_method_index = method_index; }
|
|
||||||
|
|
||||||
// jmethodID support
|
// jmethodID support
|
||||||
static jmethodID get_jmethod_id(instanceKlassHandle ik_h,
|
static jmethodID get_jmethod_id(instanceKlassHandle ik_h,
|
||||||
@ -1053,4 +1071,83 @@ class nmethodBucket: public CHeapObj {
|
|||||||
nmethod* get_nmethod() { return _nmethod; }
|
nmethod* get_nmethod() { return _nmethod; }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// An iterator that's used to access the inner classes indices in the
|
||||||
|
// instanceKlass::_inner_classes array.
|
||||||
|
class InnerClassesIterator : public StackObj {
|
||||||
|
private:
|
||||||
|
typeArrayHandle _inner_classes;
|
||||||
|
int _length;
|
||||||
|
int _idx;
|
||||||
|
public:
|
||||||
|
|
||||||
|
InnerClassesIterator(instanceKlassHandle k) {
|
||||||
|
_inner_classes = k->inner_classes();
|
||||||
|
if (k->inner_classes() != NULL) {
|
||||||
|
_length = _inner_classes->length();
|
||||||
|
// The inner class array's length should be the multiple of
|
||||||
|
// inner_class_next_offset if it only contains the InnerClasses
|
||||||
|
// attribute data, or it should be
|
||||||
|
// n*inner_class_next_offset+enclosing_method_attribute_size
|
||||||
|
// if it also contains the EnclosingMethod data.
|
||||||
|
assert((_length % instanceKlass::inner_class_next_offset == 0 ||
|
||||||
|
_length % instanceKlass::inner_class_next_offset == instanceKlass::enclosing_method_attribute_size),
|
||||||
|
"just checking");
|
||||||
|
// Remove the enclosing_method portion if exists.
|
||||||
|
if (_length % instanceKlass::inner_class_next_offset == instanceKlass::enclosing_method_attribute_size) {
|
||||||
|
_length -= instanceKlass::enclosing_method_attribute_size;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
_length = 0;
|
||||||
|
}
|
||||||
|
_idx = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int length() const {
|
||||||
|
return _length;
|
||||||
|
}
|
||||||
|
|
||||||
|
void next() {
|
||||||
|
_idx += instanceKlass::inner_class_next_offset;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool done() const {
|
||||||
|
return (_idx >= _length);
|
||||||
|
}
|
||||||
|
|
||||||
|
u2 inner_class_info_index() const {
|
||||||
|
return _inner_classes->ushort_at(
|
||||||
|
_idx + instanceKlass::inner_class_inner_class_info_offset);
|
||||||
|
}
|
||||||
|
|
||||||
|
void set_inner_class_info_index(u2 index) {
|
||||||
|
_inner_classes->ushort_at_put(
|
||||||
|
_idx + instanceKlass::inner_class_inner_class_info_offset, index);
|
||||||
|
}
|
||||||
|
|
||||||
|
u2 outer_class_info_index() const {
|
||||||
|
return _inner_classes->ushort_at(
|
||||||
|
_idx + instanceKlass::inner_class_outer_class_info_offset);
|
||||||
|
}
|
||||||
|
|
||||||
|
void set_outer_class_info_index(u2 index) {
|
||||||
|
_inner_classes->ushort_at_put(
|
||||||
|
_idx + instanceKlass::inner_class_outer_class_info_offset, index);
|
||||||
|
}
|
||||||
|
|
||||||
|
u2 inner_name_index() const {
|
||||||
|
return _inner_classes->ushort_at(
|
||||||
|
_idx + instanceKlass::inner_class_inner_name_offset);
|
||||||
|
}
|
||||||
|
|
||||||
|
void set_inner_name_index(u2 index) {
|
||||||
|
_inner_classes->ushort_at_put(
|
||||||
|
_idx + instanceKlass::inner_class_inner_name_offset, index);
|
||||||
|
}
|
||||||
|
|
||||||
|
u2 inner_access_flags() const {
|
||||||
|
return _inner_classes->ushort_at(
|
||||||
|
_idx + instanceKlass::inner_class_access_flags_offset);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
#endif // SHARE_VM_OOPS_INSTANCEKLASS_HPP
|
#endif // SHARE_VM_OOPS_INSTANCEKLASS_HPP
|
||||||
|
@ -416,7 +416,6 @@ instanceKlassKlass::allocate_instance_klass(Symbol* name, int vtable_len, int it
|
|||||||
ik->set_methods_annotations(NULL);
|
ik->set_methods_annotations(NULL);
|
||||||
ik->set_methods_parameter_annotations(NULL);
|
ik->set_methods_parameter_annotations(NULL);
|
||||||
ik->set_methods_default_annotations(NULL);
|
ik->set_methods_default_annotations(NULL);
|
||||||
ik->set_enclosing_method_indices(0, 0);
|
|
||||||
ik->set_jvmti_cached_class_field_map(NULL);
|
ik->set_jvmti_cached_class_field_map(NULL);
|
||||||
ik->set_initial_method_idnum(0);
|
ik->set_initial_method_idnum(0);
|
||||||
assert(k()->is_parsable(), "should be parsable here.");
|
assert(k()->is_parsable(), "should be parsable here.");
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -174,10 +174,9 @@ KlassHandle Klass::base_create_klass(KlassHandle& klass, int size,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Klass_vtbl::post_new_init_klass(KlassHandle& klass,
|
void Klass_vtbl::post_new_init_klass(KlassHandle& klass,
|
||||||
klassOop new_klass,
|
klassOop new_klass) const {
|
||||||
int size) const {
|
|
||||||
assert(!new_klass->klass_part()->null_vtbl(), "Not a complete klass");
|
assert(!new_klass->klass_part()->null_vtbl(), "Not a complete klass");
|
||||||
CollectedHeap::post_allocation_install_obj_klass(klass, new_klass, size);
|
CollectedHeap::post_allocation_install_obj_klass(klass, new_klass);
|
||||||
}
|
}
|
||||||
|
|
||||||
void* Klass_vtbl::operator new(size_t ignored, KlassHandle& klass,
|
void* Klass_vtbl::operator new(size_t ignored, KlassHandle& klass,
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -149,7 +149,7 @@ class Klass_vtbl {
|
|||||||
// by the shared "base_create" subroutines.
|
// by the shared "base_create" subroutines.
|
||||||
//
|
//
|
||||||
virtual void* allocate_permanent(KlassHandle& klass, int size, TRAPS) const = 0;
|
virtual void* allocate_permanent(KlassHandle& klass, int size, TRAPS) const = 0;
|
||||||
void post_new_init_klass(KlassHandle& klass, klassOop obj, int size) const;
|
void post_new_init_klass(KlassHandle& klass, klassOop obj) const;
|
||||||
|
|
||||||
// Every subclass on which vtbl_value is called must include this macro.
|
// Every subclass on which vtbl_value is called must include this macro.
|
||||||
// Delay the installation of the klassKlass pointer until after the
|
// Delay the installation of the klassKlass pointer until after the
|
||||||
@ -160,7 +160,7 @@ class Klass_vtbl {
|
|||||||
if (HAS_PENDING_EXCEPTION) return NULL; \
|
if (HAS_PENDING_EXCEPTION) return NULL; \
|
||||||
klassOop new_klass = ((Klass*) result)->as_klassOop(); \
|
klassOop new_klass = ((Klass*) result)->as_klassOop(); \
|
||||||
OrderAccess::storestore(); \
|
OrderAccess::storestore(); \
|
||||||
post_new_init_klass(klass_klass, new_klass, size); \
|
post_new_init_klass(klass_klass, new_klass); \
|
||||||
return result; \
|
return result; \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -257,6 +257,18 @@ const char* InlineTree::should_not_inline(ciMethod *callee_method, ciMethod* cal
|
|||||||
return "exception method";
|
return "exception method";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (callee_method->should_not_inline()) {
|
||||||
|
return "disallowed by CompilerOracle";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (UseStringCache) {
|
||||||
|
// Do not inline StringCache::profile() method used only at the beginning.
|
||||||
|
if (callee_method->name() == ciSymbol::profile_name() &&
|
||||||
|
callee_method->holder()->name() == ciSymbol::java_lang_StringCache()) {
|
||||||
|
return "profiling method";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// use frequency-based objections only for non-trivial methods
|
// use frequency-based objections only for non-trivial methods
|
||||||
if (callee_method->code_size_for_inlining() <= MaxTrivialSize) return NULL;
|
if (callee_method->code_size_for_inlining() <= MaxTrivialSize) return NULL;
|
||||||
|
|
||||||
@ -278,18 +290,6 @@ const char* InlineTree::should_not_inline(ciMethod *callee_method, ciMethod* cal
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (callee_method->should_not_inline()) {
|
|
||||||
return "disallowed by CompilerOracle";
|
|
||||||
}
|
|
||||||
|
|
||||||
if (UseStringCache) {
|
|
||||||
// Do not inline StringCache::profile() method used only at the beginning.
|
|
||||||
if (callee_method->name() == ciSymbol::profile_name() &&
|
|
||||||
callee_method->holder()->name() == ciSymbol::java_lang_StringCache()) {
|
|
||||||
return "profiling method";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -465,6 +465,9 @@
|
|||||||
notproduct(bool, PrintOptimizePtrCompare, false, \
|
notproduct(bool, PrintOptimizePtrCompare, false, \
|
||||||
"Print information about optimized pointers compare") \
|
"Print information about optimized pointers compare") \
|
||||||
\
|
\
|
||||||
|
notproduct(bool, VerifyConnectionGraph , true, \
|
||||||
|
"Verify Connection Graph construction in Escape Analysis") \
|
||||||
|
\
|
||||||
product(bool, UseOptoBiasInlining, true, \
|
product(bool, UseOptoBiasInlining, true, \
|
||||||
"Generate biased locking code in C2 ideal graph") \
|
"Generate biased locking code in C2 ideal graph") \
|
||||||
\
|
\
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2010, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -1538,10 +1538,7 @@ Node *LockNode::Ideal(PhaseGVN *phase, bool can_reshape) {
|
|||||||
// If we are locking an unescaped object, the lock/unlock is unnecessary
|
// If we are locking an unescaped object, the lock/unlock is unnecessary
|
||||||
//
|
//
|
||||||
ConnectionGraph *cgr = phase->C->congraph();
|
ConnectionGraph *cgr = phase->C->congraph();
|
||||||
PointsToNode::EscapeState es = PointsToNode::GlobalEscape;
|
if (cgr != NULL && cgr->not_global_escape(obj_node())) {
|
||||||
if (cgr != NULL)
|
|
||||||
es = cgr->escape_state(obj_node());
|
|
||||||
if (es != PointsToNode::UnknownEscape && es != PointsToNode::GlobalEscape) {
|
|
||||||
assert(!is_eliminated() || is_coarsened(), "sanity");
|
assert(!is_eliminated() || is_coarsened(), "sanity");
|
||||||
// The lock could be marked eliminated by lock coarsening
|
// The lock could be marked eliminated by lock coarsening
|
||||||
// code during first IGVN before EA. Replace coarsened flag
|
// code during first IGVN before EA. Replace coarsened flag
|
||||||
@ -1680,10 +1677,7 @@ Node *UnlockNode::Ideal(PhaseGVN *phase, bool can_reshape) {
|
|||||||
// If we are unlocking an unescaped object, the lock/unlock is unnecessary.
|
// If we are unlocking an unescaped object, the lock/unlock is unnecessary.
|
||||||
//
|
//
|
||||||
ConnectionGraph *cgr = phase->C->congraph();
|
ConnectionGraph *cgr = phase->C->congraph();
|
||||||
PointsToNode::EscapeState es = PointsToNode::GlobalEscape;
|
if (cgr != NULL && cgr->not_global_escape(obj_node())) {
|
||||||
if (cgr != NULL)
|
|
||||||
es = cgr->escape_state(obj_node());
|
|
||||||
if (es != PointsToNode::UnknownEscape && es != PointsToNode::GlobalEscape) {
|
|
||||||
assert(!is_eliminated() || is_coarsened(), "sanity");
|
assert(!is_eliminated() || is_coarsened(), "sanity");
|
||||||
// The lock could be marked eliminated by lock coarsening
|
// The lock could be marked eliminated by lock coarsening
|
||||||
// code during first IGVN before EA. Replace coarsened flag
|
// code during first IGVN before EA. Replace coarsened flag
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -546,6 +546,12 @@ public:
|
|||||||
// or result projection is there are several CheckCastPP
|
// or result projection is there are several CheckCastPP
|
||||||
// or returns NULL if there is no one.
|
// or returns NULL if there is no one.
|
||||||
Node *result_cast();
|
Node *result_cast();
|
||||||
|
// Does this node returns pointer?
|
||||||
|
bool returns_pointer() const {
|
||||||
|
const TypeTuple *r = tf()->range();
|
||||||
|
return (r->cnt() > TypeFunc::Parms &&
|
||||||
|
r->field_at(TypeFunc::Parms)->isa_ptr());
|
||||||
|
}
|
||||||
|
|
||||||
// Collect all the interesting edges from a call for use in
|
// Collect all the interesting edges from a call for use in
|
||||||
// replacing the call by something else. Used by macro expansion
|
// replacing the call by something else. Used by macro expansion
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -1707,7 +1707,6 @@ void Compile::Optimize() {
|
|||||||
if (major_progress()) print_method("PhaseIdealLoop before EA", 2);
|
if (major_progress()) print_method("PhaseIdealLoop before EA", 2);
|
||||||
if (failing()) return;
|
if (failing()) return;
|
||||||
}
|
}
|
||||||
TracePhase t2("escapeAnalysis", &_t_escapeAnalysis, true);
|
|
||||||
ConnectionGraph::do_analysis(this, &igvn);
|
ConnectionGraph::do_analysis(this, &igvn);
|
||||||
|
|
||||||
if (failing()) return;
|
if (failing()) return;
|
||||||
@ -1719,6 +1718,7 @@ void Compile::Optimize() {
|
|||||||
if (failing()) return;
|
if (failing()) return;
|
||||||
|
|
||||||
if (congraph() != NULL && macro_count() > 0) {
|
if (congraph() != NULL && macro_count() > 0) {
|
||||||
|
NOT_PRODUCT( TracePhase t2("macroEliminate", &_t_macroEliminate, TimeCompiler); )
|
||||||
PhaseMacroExpand mexp(igvn);
|
PhaseMacroExpand mexp(igvn);
|
||||||
mexp.eliminate_macro_nodes();
|
mexp.eliminate_macro_nodes();
|
||||||
igvn.set_delay_transform(false);
|
igvn.set_delay_transform(false);
|
||||||
@ -1875,10 +1875,10 @@ void Compile::Code_Gen() {
|
|||||||
|
|
||||||
cfg.Estimate_Block_Frequency();
|
cfg.Estimate_Block_Frequency();
|
||||||
cfg.GlobalCodeMotion(m,unique(),proj_list);
|
cfg.GlobalCodeMotion(m,unique(),proj_list);
|
||||||
|
if (failing()) return;
|
||||||
|
|
||||||
print_method("Global code motion", 2);
|
print_method("Global code motion", 2);
|
||||||
|
|
||||||
if (failing()) return;
|
|
||||||
NOT_PRODUCT( verify_graph_edges(); )
|
NOT_PRODUCT( verify_graph_edges(); )
|
||||||
|
|
||||||
debug_only( cfg.verify(); )
|
debug_only( cfg.verify(); )
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -115,18 +115,36 @@ class Node;
|
|||||||
class CallNode;
|
class CallNode;
|
||||||
class PhiNode;
|
class PhiNode;
|
||||||
class PhaseTransform;
|
class PhaseTransform;
|
||||||
|
class PointsToNode;
|
||||||
class Type;
|
class Type;
|
||||||
class TypePtr;
|
class TypePtr;
|
||||||
class VectorSet;
|
class VectorSet;
|
||||||
|
|
||||||
class PointsToNode {
|
class JavaObjectNode;
|
||||||
friend class ConnectionGraph;
|
class LocalVarNode;
|
||||||
|
class FieldNode;
|
||||||
|
class ArraycopyNode;
|
||||||
|
|
||||||
|
// ConnectionGraph nodes
|
||||||
|
class PointsToNode : public ResourceObj {
|
||||||
|
GrowableArray<PointsToNode*> _edges; // List of nodes this node points to
|
||||||
|
GrowableArray<PointsToNode*> _uses; // List of nodes which point to this node
|
||||||
|
|
||||||
|
const u1 _type; // NodeType
|
||||||
|
u1 _flags; // NodeFlags
|
||||||
|
u1 _escape; // EscapeState of object
|
||||||
|
u1 _fields_escape; // EscapeState of object's fields
|
||||||
|
|
||||||
|
Node* const _node; // Ideal node corresponding to this PointsTo node.
|
||||||
|
const int _idx; // Cached ideal node's _idx
|
||||||
|
|
||||||
public:
|
public:
|
||||||
typedef enum {
|
typedef enum {
|
||||||
UnknownType = 0,
|
UnknownType = 0,
|
||||||
JavaObject = 1,
|
JavaObject = 1,
|
||||||
LocalVar = 2,
|
LocalVar = 2,
|
||||||
Field = 3
|
Field = 3,
|
||||||
|
Arraycopy = 4
|
||||||
} NodeType;
|
} NodeType;
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
@ -140,178 +158,387 @@ public:
|
|||||||
} EscapeState;
|
} EscapeState;
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
UnknownEdge = 0,
|
ScalarReplaceable = 1, // Not escaped object could be replaced with scalar
|
||||||
PointsToEdge = 1,
|
PointsToUnknown = 2, // Has edge to phantom_object
|
||||||
DeferredEdge = 2,
|
ArraycopySrc = 4, // Has edge from Arraycopy node
|
||||||
FieldEdge = 3
|
ArraycopyDst = 8 // Has edge to Arraycopy node
|
||||||
} EdgeType;
|
} NodeFlags;
|
||||||
|
|
||||||
private:
|
|
||||||
enum {
|
|
||||||
EdgeMask = 3,
|
|
||||||
EdgeShift = 2,
|
|
||||||
|
|
||||||
INITIAL_EDGE_COUNT = 4
|
|
||||||
};
|
|
||||||
|
|
||||||
NodeType _type;
|
|
||||||
EscapeState _escape;
|
|
||||||
GrowableArray<uint>* _edges; // outgoing edges
|
|
||||||
Node* _node; // Ideal node corresponding to this PointsTo node.
|
|
||||||
int _offset; // Object fields offsets.
|
|
||||||
bool _scalar_replaceable; // Not escaped object could be replaced with scalar
|
|
||||||
bool _has_unknown_ptr; // Has edge to phantom_object
|
|
||||||
|
|
||||||
public:
|
|
||||||
PointsToNode():
|
|
||||||
_type(UnknownType),
|
|
||||||
_escape(UnknownEscape),
|
|
||||||
_edges(NULL),
|
|
||||||
_node(NULL),
|
|
||||||
_offset(-1),
|
|
||||||
_has_unknown_ptr(false),
|
|
||||||
_scalar_replaceable(true) {}
|
|
||||||
|
|
||||||
|
|
||||||
EscapeState escape_state() const { return _escape; }
|
PointsToNode(Compile *C, Node* n, EscapeState es, NodeType type):
|
||||||
NodeType node_type() const { return _type;}
|
_edges(C->comp_arena(), 2, 0, NULL),
|
||||||
int offset() { return _offset;}
|
_uses (C->comp_arena(), 2, 0, NULL),
|
||||||
bool scalar_replaceable() { return _scalar_replaceable;}
|
_node(n),
|
||||||
bool has_unknown_ptr() { return _has_unknown_ptr;}
|
_idx(n->_idx),
|
||||||
|
_type((u1)type),
|
||||||
void set_offset(int offs) { _offset = offs;}
|
_escape((u1)es),
|
||||||
void set_escape_state(EscapeState state) { _escape = state; }
|
_fields_escape((u1)es),
|
||||||
void set_node_type(NodeType ntype) {
|
_flags(ScalarReplaceable) {
|
||||||
assert(_type == UnknownType || _type == ntype, "Can't change node type");
|
assert(n != NULL && es != UnknownEscape, "sanity");
|
||||||
_type = ntype;
|
|
||||||
}
|
|
||||||
void set_scalar_replaceable(bool v) { _scalar_replaceable = v; }
|
|
||||||
void set_has_unknown_ptr() { _has_unknown_ptr = true; }
|
|
||||||
|
|
||||||
// count of outgoing edges
|
|
||||||
uint edge_count() const { return (_edges == NULL) ? 0 : _edges->length(); }
|
|
||||||
|
|
||||||
// node index of target of outgoing edge "e"
|
|
||||||
uint edge_target(uint e) const {
|
|
||||||
assert(_edges != NULL, "valid edge index");
|
|
||||||
return (_edges->at(e) >> EdgeShift);
|
|
||||||
}
|
|
||||||
// type of outgoing edge "e"
|
|
||||||
EdgeType edge_type(uint e) const {
|
|
||||||
assert(_edges != NULL, "valid edge index");
|
|
||||||
return (EdgeType) (_edges->at(e) & EdgeMask);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// add a edge of the specified type pointing to the specified target
|
Node* ideal_node() const { return _node; }
|
||||||
void add_edge(uint targIdx, EdgeType et);
|
int idx() const { return _idx; }
|
||||||
|
|
||||||
// remove an edge of the specified type pointing to the specified target
|
bool is_JavaObject() const { return _type == (u1)JavaObject; }
|
||||||
void remove_edge(uint targIdx, EdgeType et);
|
bool is_LocalVar() const { return _type == (u1)LocalVar; }
|
||||||
|
bool is_Field() const { return _type == (u1)Field; }
|
||||||
|
bool is_Arraycopy() const { return _type == (u1)Arraycopy; }
|
||||||
|
|
||||||
|
JavaObjectNode* as_JavaObject() { assert(is_JavaObject(),""); return (JavaObjectNode*)this; }
|
||||||
|
LocalVarNode* as_LocalVar() { assert(is_LocalVar(),""); return (LocalVarNode*)this; }
|
||||||
|
FieldNode* as_Field() { assert(is_Field(),""); return (FieldNode*)this; }
|
||||||
|
ArraycopyNode* as_Arraycopy() { assert(is_Arraycopy(),""); return (ArraycopyNode*)this; }
|
||||||
|
|
||||||
|
EscapeState escape_state() const { return (EscapeState)_escape; }
|
||||||
|
void set_escape_state(EscapeState state) { _escape = (u1)state; }
|
||||||
|
|
||||||
|
EscapeState fields_escape_state() const { return (EscapeState)_fields_escape; }
|
||||||
|
void set_fields_escape_state(EscapeState state) { _fields_escape = (u1)state; }
|
||||||
|
|
||||||
|
bool has_unknown_ptr() const { return (_flags & PointsToUnknown) != 0; }
|
||||||
|
void set_has_unknown_ptr() { _flags |= PointsToUnknown; }
|
||||||
|
|
||||||
|
bool arraycopy_src() const { return (_flags & ArraycopySrc) != 0; }
|
||||||
|
void set_arraycopy_src() { _flags |= ArraycopySrc; }
|
||||||
|
bool arraycopy_dst() const { return (_flags & ArraycopyDst) != 0; }
|
||||||
|
void set_arraycopy_dst() { _flags |= ArraycopyDst; }
|
||||||
|
|
||||||
|
bool scalar_replaceable() const { return (_flags & ScalarReplaceable) != 0;}
|
||||||
|
void set_scalar_replaceable(bool v) {
|
||||||
|
if (v)
|
||||||
|
_flags |= ScalarReplaceable;
|
||||||
|
else
|
||||||
|
_flags &= ~ScalarReplaceable;
|
||||||
|
}
|
||||||
|
|
||||||
|
int edge_count() const { return _edges.length(); }
|
||||||
|
PointsToNode* edge(int e) const { return _edges.at(e); }
|
||||||
|
bool add_edge(PointsToNode* edge) { return _edges.append_if_missing(edge); }
|
||||||
|
|
||||||
|
int use_count() const { return _uses.length(); }
|
||||||
|
PointsToNode* use(int e) const { return _uses.at(e); }
|
||||||
|
bool add_use(PointsToNode* use) { return _uses.append_if_missing(use); }
|
||||||
|
|
||||||
|
// Mark base edge use to distinguish from stored value edge.
|
||||||
|
bool add_base_use(FieldNode* use) { return _uses.append_if_missing((PointsToNode*)((intptr_t)use + 1)); }
|
||||||
|
static bool is_base_use(PointsToNode* use) { return (((intptr_t)use) & 1); }
|
||||||
|
static PointsToNode* get_use_node(PointsToNode* use) { return (PointsToNode*)(((intptr_t)use) & ~1); }
|
||||||
|
|
||||||
|
// Return true if this node points to specified node or nodes it points to.
|
||||||
|
bool points_to(JavaObjectNode* ptn) const;
|
||||||
|
|
||||||
|
// Return true if this node points only to non-escaping allocations.
|
||||||
|
bool non_escaping_allocation();
|
||||||
|
|
||||||
|
// Return true if one node points to an other.
|
||||||
|
bool meet(PointsToNode* ptn);
|
||||||
|
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
|
NodeType node_type() const { return (NodeType)_type;}
|
||||||
void dump(bool print_state=true) const;
|
void dump(bool print_state=true) const;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class LocalVarNode: public PointsToNode {
|
||||||
|
public:
|
||||||
|
LocalVarNode(Compile *C, Node* n, EscapeState es):
|
||||||
|
PointsToNode(C, n, es, LocalVar) {}
|
||||||
|
};
|
||||||
|
|
||||||
|
class JavaObjectNode: public PointsToNode {
|
||||||
|
public:
|
||||||
|
JavaObjectNode(Compile *C, Node* n, EscapeState es):
|
||||||
|
PointsToNode(C, n, es, JavaObject) {
|
||||||
|
if (es > NoEscape)
|
||||||
|
set_scalar_replaceable(false);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
class FieldNode: public PointsToNode {
|
||||||
|
GrowableArray<PointsToNode*> _bases; // List of JavaObject nodes which point to this node
|
||||||
|
const int _offset; // Field's offset.
|
||||||
|
const bool _is_oop; // Field points to object
|
||||||
|
bool _has_unknown_base; // Has phantom_object base
|
||||||
|
public:
|
||||||
|
FieldNode(Compile *C, Node* n, EscapeState es, int offs, bool is_oop):
|
||||||
|
PointsToNode(C, n, es, Field),
|
||||||
|
_offset(offs), _is_oop(is_oop),
|
||||||
|
_has_unknown_base(false) {}
|
||||||
|
|
||||||
|
int offset() const { return _offset;}
|
||||||
|
bool is_oop() const { return _is_oop;}
|
||||||
|
bool has_unknown_base() const { return _has_unknown_base; }
|
||||||
|
void set_has_unknown_base() { _has_unknown_base = true; }
|
||||||
|
|
||||||
|
int base_count() const { return _bases.length(); }
|
||||||
|
PointsToNode* base(int e) const { return _bases.at(e); }
|
||||||
|
bool add_base(PointsToNode* base) { return _bases.append_if_missing(base); }
|
||||||
|
#ifdef ASSERT
|
||||||
|
// Return true if bases points to this java object.
|
||||||
|
bool has_base(JavaObjectNode* ptn) const;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
class ArraycopyNode: public PointsToNode {
|
||||||
|
public:
|
||||||
|
ArraycopyNode(Compile *C, Node* n, EscapeState es):
|
||||||
|
PointsToNode(C, n, es, Arraycopy) {}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Iterators for PointsTo node's edges:
|
||||||
|
// for (EdgeIterator i(n); i.has_next(); i.next()) {
|
||||||
|
// PointsToNode* u = i.get();
|
||||||
|
class PointsToIterator: public StackObj {
|
||||||
|
protected:
|
||||||
|
const PointsToNode* node;
|
||||||
|
const int cnt;
|
||||||
|
int i;
|
||||||
|
public:
|
||||||
|
inline PointsToIterator(const PointsToNode* n, int cnt) : node(n), cnt(cnt), i(0) { }
|
||||||
|
inline bool has_next() const { return i < cnt; }
|
||||||
|
inline void next() { i++; }
|
||||||
|
PointsToNode* get() const { ShouldNotCallThis(); return NULL; }
|
||||||
|
};
|
||||||
|
|
||||||
|
class EdgeIterator: public PointsToIterator {
|
||||||
|
public:
|
||||||
|
inline EdgeIterator(const PointsToNode* n) : PointsToIterator(n, n->edge_count()) { }
|
||||||
|
inline PointsToNode* get() const { return node->edge(i); }
|
||||||
|
};
|
||||||
|
|
||||||
|
class UseIterator: public PointsToIterator {
|
||||||
|
public:
|
||||||
|
inline UseIterator(const PointsToNode* n) : PointsToIterator(n, n->use_count()) { }
|
||||||
|
inline PointsToNode* get() const { return node->use(i); }
|
||||||
|
};
|
||||||
|
|
||||||
|
class BaseIterator: public PointsToIterator {
|
||||||
|
public:
|
||||||
|
inline BaseIterator(const FieldNode* n) : PointsToIterator(n, n->base_count()) { }
|
||||||
|
inline PointsToNode* get() const { return ((PointsToNode*)node)->as_Field()->base(i); }
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
class ConnectionGraph: public ResourceObj {
|
class ConnectionGraph: public ResourceObj {
|
||||||
private:
|
private:
|
||||||
GrowableArray<PointsToNode> _nodes; // Connection graph nodes indexed
|
GrowableArray<PointsToNode*> _nodes; // Map from ideal nodes to
|
||||||
// by ideal node index.
|
// ConnectionGraph nodes.
|
||||||
|
|
||||||
Unique_Node_List _delayed_worklist; // Nodes to be processed before
|
GrowableArray<PointsToNode*> _worklist; // Nodes to be processed
|
||||||
// the call build_connection_graph().
|
|
||||||
|
|
||||||
GrowableArray<MergeMemNode *> _mergemem_worklist; // List of all MergeMem nodes
|
|
||||||
|
|
||||||
VectorSet _processed; // Records which nodes have been
|
|
||||||
// processed.
|
|
||||||
|
|
||||||
bool _collecting; // Indicates whether escape information
|
bool _collecting; // Indicates whether escape information
|
||||||
// is still being collected. If false,
|
// is still being collected. If false,
|
||||||
// no new nodes will be processed.
|
// no new nodes will be processed.
|
||||||
|
|
||||||
bool _progress; // Indicates whether new Graph's edges
|
bool _verify; // verify graph
|
||||||
// were created.
|
|
||||||
|
|
||||||
uint _phantom_object; // Index of globally escaping object
|
JavaObjectNode* phantom_obj; // Unknown object
|
||||||
// that pointer values loaded from
|
JavaObjectNode* null_obj;
|
||||||
// a field which has not been set
|
|
||||||
// are assumed to point to.
|
|
||||||
uint _oop_null; // ConP(#NULL)->_idx
|
|
||||||
uint _noop_null; // ConN(#NULL)->_idx
|
|
||||||
Node* _pcmp_neq; // ConI(#CC_GT)
|
Node* _pcmp_neq; // ConI(#CC_GT)
|
||||||
Node* _pcmp_eq; // ConI(#CC_EQ)
|
Node* _pcmp_eq; // ConI(#CC_EQ)
|
||||||
|
|
||||||
Compile* _compile; // Compile object for current compilation
|
Compile* _compile; // Compile object for current compilation
|
||||||
PhaseIterGVN* _igvn; // Value numbering
|
PhaseIterGVN* _igvn; // Value numbering
|
||||||
|
|
||||||
|
Unique_Node_List ideal_nodes; // Used by CG construction and types splitting.
|
||||||
|
|
||||||
// Address of an element in _nodes. Used when the element is to be modified
|
// Address of an element in _nodes. Used when the element is to be modified
|
||||||
PointsToNode *ptnode_adr(uint idx) const {
|
PointsToNode* ptnode_adr(int idx) const {
|
||||||
// There should be no new ideal nodes during ConnectionGraph build,
|
// There should be no new ideal nodes during ConnectionGraph build,
|
||||||
// growableArray::adr_at() will throw assert otherwise.
|
// growableArray::at() will throw assert otherwise.
|
||||||
return _nodes.adr_at(idx);
|
return _nodes.at(idx);
|
||||||
}
|
}
|
||||||
uint nodes_size() const { return _nodes.length(); }
|
uint nodes_size() const { return _nodes.length(); }
|
||||||
|
|
||||||
bool is_null_ptr(uint idx) const { return (idx == _noop_null || idx == _oop_null); }
|
// Add nodes to ConnectionGraph.
|
||||||
|
void add_local_var(Node* n, PointsToNode::EscapeState es);
|
||||||
|
void add_java_object(Node* n, PointsToNode::EscapeState es);
|
||||||
|
void add_field(Node* n, PointsToNode::EscapeState es, int offset);
|
||||||
|
void add_arraycopy(Node* n, PointsToNode::EscapeState es, PointsToNode* src, PointsToNode* dst);
|
||||||
|
|
||||||
// Add node to ConnectionGraph.
|
// Compute the escape state for arguments to a call.
|
||||||
void add_node(Node *n, PointsToNode::NodeType nt, PointsToNode::EscapeState es, bool done);
|
void process_call_arguments(CallNode *call);
|
||||||
|
|
||||||
|
// Add PointsToNode node corresponding to a call
|
||||||
|
void add_call_node(CallNode* call);
|
||||||
|
|
||||||
|
// Map ideal node to existing PointsTo node (usually phantom_object).
|
||||||
|
void map_ideal_node(Node *n, PointsToNode* ptn) {
|
||||||
|
assert(ptn != NULL, "only existing PointsTo node");
|
||||||
|
_nodes.at_put(n->_idx, ptn);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create PointsToNode node and add it to Connection Graph.
|
||||||
|
void add_node_to_connection_graph(Node *n, Unique_Node_List *delayed_worklist);
|
||||||
|
|
||||||
|
// Add final simple edges to graph.
|
||||||
|
void add_final_edges(Node *n);
|
||||||
|
|
||||||
|
// Finish Graph construction.
|
||||||
|
bool complete_connection_graph(GrowableArray<PointsToNode*>& ptnodes_worklist,
|
||||||
|
GrowableArray<JavaObjectNode*>& non_escaped_worklist,
|
||||||
|
GrowableArray<JavaObjectNode*>& java_objects_worklist,
|
||||||
|
GrowableArray<FieldNode*>& oop_fields_worklist);
|
||||||
|
|
||||||
|
#ifdef ASSERT
|
||||||
|
void verify_connection_graph(GrowableArray<PointsToNode*>& ptnodes_worklist,
|
||||||
|
GrowableArray<JavaObjectNode*>& non_escaped_worklist,
|
||||||
|
GrowableArray<JavaObjectNode*>& java_objects_worklist,
|
||||||
|
GrowableArray<Node*>& addp_worklist);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// Add all references to this JavaObject node.
|
||||||
|
int add_java_object_edges(JavaObjectNode* jobj, bool populate_worklist);
|
||||||
|
|
||||||
|
// Put node on worklist if it is (or was) not there.
|
||||||
|
void add_to_worklist(PointsToNode* pt) {
|
||||||
|
_worklist.push(pt);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Put on worklist all uses of this node.
|
||||||
|
void add_uses_to_worklist(PointsToNode* pt) {
|
||||||
|
for (UseIterator i(pt); i.has_next(); i.next())
|
||||||
|
_worklist.push(i.get());
|
||||||
|
}
|
||||||
|
|
||||||
|
// Put on worklist all field's uses and related field nodes.
|
||||||
|
void add_field_uses_to_worklist(FieldNode* field);
|
||||||
|
|
||||||
|
// Put on worklist all related field nodes.
|
||||||
|
void add_fields_to_worklist(FieldNode* field, PointsToNode* base);
|
||||||
|
|
||||||
|
// Find fields which have unknown value.
|
||||||
|
int find_field_value(FieldNode* field);
|
||||||
|
|
||||||
|
// Find fields initializing values for allocations.
|
||||||
|
int find_init_values(JavaObjectNode* ptn, PointsToNode* init_val, PhaseTransform* phase);
|
||||||
|
|
||||||
|
// Set the escape state of an object and its fields.
|
||||||
|
void set_escape_state(PointsToNode* ptn, PointsToNode::EscapeState esc) {
|
||||||
|
// Don't change non-escaping state of NULL pointer.
|
||||||
|
if (ptn != null_obj) {
|
||||||
|
if (ptn->escape_state() < esc)
|
||||||
|
ptn->set_escape_state(esc);
|
||||||
|
if (ptn->fields_escape_state() < esc)
|
||||||
|
ptn->set_fields_escape_state(esc);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void set_fields_escape_state(PointsToNode* ptn, PointsToNode::EscapeState esc) {
|
||||||
|
// Don't change non-escaping state of NULL pointer.
|
||||||
|
if (ptn != null_obj) {
|
||||||
|
if (ptn->fields_escape_state() < esc)
|
||||||
|
ptn->set_fields_escape_state(esc);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Propagate GlobalEscape and ArgEscape escape states to all nodes
|
||||||
|
// and check that we still have non-escaping java objects.
|
||||||
|
bool find_non_escaped_objects(GrowableArray<PointsToNode*>& ptnodes_worklist,
|
||||||
|
GrowableArray<JavaObjectNode*>& non_escaped_worklist);
|
||||||
|
|
||||||
|
// Adjust scalar_replaceable state after Connection Graph is built.
|
||||||
|
void adjust_scalar_replaceable_state(JavaObjectNode* jobj);
|
||||||
|
|
||||||
|
// Optimize ideal graph.
|
||||||
|
void optimize_ideal_graph(GrowableArray<Node*>& ptr_cmp_worklist,
|
||||||
|
GrowableArray<Node*>& storestore_worklist);
|
||||||
|
// Optimize objects compare.
|
||||||
|
Node* optimize_ptr_compare(Node* n);
|
||||||
|
|
||||||
|
// Returns unique corresponding java object or NULL.
|
||||||
|
JavaObjectNode* unique_java_object(Node *n);
|
||||||
|
|
||||||
|
// Add an edge of the specified type pointing to the specified target.
|
||||||
|
bool add_edge(PointsToNode* from, PointsToNode* to) {
|
||||||
|
assert(!from->is_Field() || from->as_Field()->is_oop(), "sanity");
|
||||||
|
|
||||||
|
if (to == phantom_obj) {
|
||||||
|
if (from->has_unknown_ptr()) {
|
||||||
|
return false; // already points to phantom_obj
|
||||||
|
}
|
||||||
|
from->set_has_unknown_ptr();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool is_new = from->add_edge(to);
|
||||||
|
assert(to != phantom_obj || is_new, "sanity");
|
||||||
|
if (is_new) { // New edge?
|
||||||
|
assert(!_verify, "graph is incomplete");
|
||||||
|
is_new = to->add_use(from);
|
||||||
|
assert(is_new, "use should be also new");
|
||||||
|
}
|
||||||
|
return is_new;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add an edge from Field node to its base and back.
|
||||||
|
bool add_base(FieldNode* from, PointsToNode* to) {
|
||||||
|
assert(!to->is_Arraycopy(), "sanity");
|
||||||
|
if (to == phantom_obj) {
|
||||||
|
if (from->has_unknown_base()) {
|
||||||
|
return false; // already has phantom_obj base
|
||||||
|
}
|
||||||
|
from->set_has_unknown_base();
|
||||||
|
}
|
||||||
|
bool is_new = from->add_base(to);
|
||||||
|
assert(to != phantom_obj || is_new, "sanity");
|
||||||
|
if (is_new) { // New edge?
|
||||||
|
assert(!_verify, "graph is incomplete");
|
||||||
|
if (to == null_obj)
|
||||||
|
return is_new; // Don't add fields to NULL pointer.
|
||||||
|
if (to->is_JavaObject()) {
|
||||||
|
is_new = to->add_edge(from);
|
||||||
|
} else {
|
||||||
|
is_new = to->add_base_use(from);
|
||||||
|
}
|
||||||
|
assert(is_new, "use should be also new");
|
||||||
|
}
|
||||||
|
return is_new;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add LocalVar node and edge if possible
|
||||||
|
void add_local_var_and_edge(Node* n, PointsToNode::EscapeState es, Node* to,
|
||||||
|
Unique_Node_List *delayed_worklist) {
|
||||||
|
PointsToNode* ptn = ptnode_adr(to->_idx);
|
||||||
|
if (delayed_worklist != NULL) { // First iteration of CG construction
|
||||||
|
add_local_var(n, es);
|
||||||
|
if (ptn == NULL) {
|
||||||
|
delayed_worklist->push(n);
|
||||||
|
return; // Process it later.
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
assert(ptn != NULL, "node should be registered");
|
||||||
|
}
|
||||||
|
add_edge(ptnode_adr(n->_idx), ptn);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Helper functions
|
||||||
|
bool is_oop_field(Node* n, int offset);
|
||||||
|
static Node* get_addp_base(Node *addp);
|
||||||
|
static Node* find_second_addp(Node* addp, Node* n);
|
||||||
|
|
||||||
// offset of a field reference
|
// offset of a field reference
|
||||||
int address_offset(Node* adr, PhaseTransform *phase);
|
int address_offset(Node* adr, PhaseTransform *phase);
|
||||||
|
|
||||||
// compute the escape state for arguments to a call
|
|
||||||
void process_call_arguments(CallNode *call, PhaseTransform *phase);
|
|
||||||
|
|
||||||
// compute the escape state for the return value of a call
|
// Propagate unique types created for unescaped allocated objects
|
||||||
void process_call_result(ProjNode *resproj, PhaseTransform *phase);
|
// through the graph
|
||||||
|
void split_unique_types(GrowableArray<Node *> &alloc_worklist);
|
||||||
|
|
||||||
// Populate Connection Graph with Ideal nodes.
|
// Helper methods for unique types split.
|
||||||
void record_for_escape_analysis(Node *n, PhaseTransform *phase);
|
bool split_AddP(Node *addp, Node *base);
|
||||||
|
|
||||||
// Build Connection Graph and set nodes escape state.
|
PhiNode *create_split_phi(PhiNode *orig_phi, int alias_idx, GrowableArray<PhiNode *> &orig_phi_worklist, bool &new_created);
|
||||||
void build_connection_graph(Node *n, PhaseTransform *phase);
|
PhiNode *split_memory_phi(PhiNode *orig_phi, int alias_idx, GrowableArray<PhiNode *> &orig_phi_worklist);
|
||||||
|
|
||||||
// walk the connection graph starting at the node corresponding to "n" and
|
void move_inst_mem(Node* n, GrowableArray<PhiNode *> &orig_phis);
|
||||||
// add the index of everything it could point to, to "ptset". This may cause
|
Node* find_inst_mem(Node* mem, int alias_idx,GrowableArray<PhiNode *> &orig_phi_worklist);
|
||||||
// Phi's encountered to get (re)processed (which requires "phase".)
|
Node* step_through_mergemem(MergeMemNode *mmem, int alias_idx, const TypeOopPtr *toop);
|
||||||
VectorSet* PointsTo(Node * n);
|
|
||||||
|
|
||||||
// Reused structures for PointsTo().
|
|
||||||
VectorSet pt_ptset;
|
|
||||||
VectorSet pt_visited;
|
|
||||||
GrowableArray<uint> pt_worklist;
|
|
||||||
|
|
||||||
// Edge manipulation. The "from_i" and "to_i" arguments are the
|
|
||||||
// node indices of the source and destination of the edge
|
|
||||||
void add_pointsto_edge(uint from_i, uint to_i);
|
|
||||||
void add_deferred_edge(uint from_i, uint to_i);
|
|
||||||
void add_field_edge(uint from_i, uint to_i, int offs);
|
|
||||||
|
|
||||||
// Add an edge of the specified type pointing to the specified target.
|
|
||||||
// Set _progress if new edge is added.
|
|
||||||
void add_edge(PointsToNode *f, uint to_i, PointsToNode::EdgeType et) {
|
|
||||||
uint e_cnt = f->edge_count();
|
|
||||||
f->add_edge(to_i, et);
|
|
||||||
_progress |= (f->edge_count() != e_cnt);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add an edge to node given by "to_i" from any field of adr_i whose offset
|
|
||||||
// matches "offset" A deferred edge is added if to_i is a LocalVar, and
|
|
||||||
// a pointsto edge is added if it is a JavaObject
|
|
||||||
void add_edge_from_fields(uint adr, uint to_i, int offs);
|
|
||||||
|
|
||||||
// Add a deferred edge from node given by "from_i" to any field
|
|
||||||
// of adr_i whose offset matches "offset"
|
|
||||||
void add_deferred_edge_to_fields(uint from_i, uint adr, int offs);
|
|
||||||
|
|
||||||
|
|
||||||
// Remove outgoing deferred edges from the node referenced by "ni".
|
GrowableArray<MergeMemNode*> _mergemem_worklist; // List of all MergeMem nodes
|
||||||
// Any outgoing edges from the target of the deferred edge are copied
|
|
||||||
// to "ni".
|
|
||||||
void remove_deferred(uint ni, GrowableArray<uint>* deferred_edges, VectorSet* visited);
|
|
||||||
|
|
||||||
Node_Array _node_map; // used for bookeeping during type splitting
|
Node_Array _node_map; // used for bookeeping during type splitting
|
||||||
// Used for the following purposes:
|
// Used for the following purposes:
|
||||||
@ -320,19 +547,16 @@ private:
|
|||||||
// MemNode - new memory input for this node
|
// MemNode - new memory input for this node
|
||||||
// ChecCastPP - allocation that this is a cast of
|
// ChecCastPP - allocation that this is a cast of
|
||||||
// allocation - CheckCastPP of the allocation
|
// allocation - CheckCastPP of the allocation
|
||||||
bool split_AddP(Node *addp, Node *base, PhaseGVN *igvn);
|
|
||||||
PhiNode *create_split_phi(PhiNode *orig_phi, int alias_idx, GrowableArray<PhiNode *> &orig_phi_worklist, PhaseGVN *igvn, bool &new_created);
|
|
||||||
PhiNode *split_memory_phi(PhiNode *orig_phi, int alias_idx, GrowableArray<PhiNode *> &orig_phi_worklist, PhaseGVN *igvn);
|
|
||||||
void move_inst_mem(Node* n, GrowableArray<PhiNode *> &orig_phis, PhaseGVN *igvn);
|
|
||||||
Node *find_inst_mem(Node *mem, int alias_idx,GrowableArray<PhiNode *> &orig_phi_worklist, PhaseGVN *igvn);
|
|
||||||
|
|
||||||
// Propagate unique types created for unescaped allocated objects
|
|
||||||
// through the graph
|
|
||||||
void split_unique_types(GrowableArray<Node *> &alloc_worklist);
|
|
||||||
|
|
||||||
// manage entries in _node_map
|
// manage entries in _node_map
|
||||||
void set_map(int idx, Node *n) { _node_map.map(idx, n); }
|
|
||||||
|
void set_map(Node* from, Node* to) {
|
||||||
|
ideal_nodes.push(from);
|
||||||
|
_node_map.map(from->_idx, to);
|
||||||
|
}
|
||||||
|
|
||||||
Node* get_map(int idx) { return _node_map[idx]; }
|
Node* get_map(int idx) { return _node_map[idx]; }
|
||||||
|
|
||||||
PhiNode* get_map_phi(int idx) {
|
PhiNode* get_map_phi(int idx) {
|
||||||
Node* phi = _node_map[idx];
|
Node* phi = _node_map[idx];
|
||||||
return (phi == NULL) ? NULL : phi->as_Phi();
|
return (phi == NULL) ? NULL : phi->as_Phi();
|
||||||
@ -344,23 +568,6 @@ private:
|
|||||||
_igvn->add_users_to_worklist(n);
|
_igvn->add_users_to_worklist(n);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set the escape state of a node
|
|
||||||
void set_escape_state(uint ni, PointsToNode::EscapeState es);
|
|
||||||
|
|
||||||
// Find fields initializing values for allocations.
|
|
||||||
void find_init_values(Node* n, VectorSet* visited, PhaseTransform* phase);
|
|
||||||
|
|
||||||
// Adjust escape state after Connection Graph is built.
|
|
||||||
void adjust_escape_state(Node* n);
|
|
||||||
|
|
||||||
// Propagate escape states to referenced nodes.
|
|
||||||
bool propagate_escape_state(GrowableArray<int>* cg_worklist,
|
|
||||||
GrowableArray<uint>* worklist,
|
|
||||||
PointsToNode::EscapeState esc_state);
|
|
||||||
|
|
||||||
// Optimize objects compare.
|
|
||||||
Node* optimize_ptr_compare(Node* n);
|
|
||||||
|
|
||||||
// Compute the escape information
|
// Compute the escape information
|
||||||
bool compute_escape();
|
bool compute_escape();
|
||||||
|
|
||||||
@ -373,11 +580,10 @@ public:
|
|||||||
// Perform escape analysis
|
// Perform escape analysis
|
||||||
static void do_analysis(Compile *C, PhaseIterGVN *igvn);
|
static void do_analysis(Compile *C, PhaseIterGVN *igvn);
|
||||||
|
|
||||||
// escape state of a node
|
bool not_global_escape(Node *n);
|
||||||
PointsToNode::EscapeState escape_state(Node *n);
|
|
||||||
|
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
void dump();
|
void dump(GrowableArray<PointsToNode*>& ptnodes_worklist);
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -39,8 +39,9 @@ elapsedTimer Phase::_t_stubCompilation;
|
|||||||
|
|
||||||
// The next timers used for LogCompilation
|
// The next timers used for LogCompilation
|
||||||
elapsedTimer Phase::_t_parser;
|
elapsedTimer Phase::_t_parser;
|
||||||
elapsedTimer Phase::_t_escapeAnalysis;
|
|
||||||
elapsedTimer Phase::_t_optimizer;
|
elapsedTimer Phase::_t_optimizer;
|
||||||
|
elapsedTimer Phase::_t_escapeAnalysis;
|
||||||
|
elapsedTimer Phase::_t_connectionGraph;
|
||||||
elapsedTimer Phase::_t_idealLoop;
|
elapsedTimer Phase::_t_idealLoop;
|
||||||
elapsedTimer Phase::_t_ccp;
|
elapsedTimer Phase::_t_ccp;
|
||||||
elapsedTimer Phase::_t_matcher;
|
elapsedTimer Phase::_t_matcher;
|
||||||
@ -51,6 +52,7 @@ elapsedTimer Phase::_t_output;
|
|||||||
elapsedTimer Phase::_t_graphReshaping;
|
elapsedTimer Phase::_t_graphReshaping;
|
||||||
elapsedTimer Phase::_t_scheduler;
|
elapsedTimer Phase::_t_scheduler;
|
||||||
elapsedTimer Phase::_t_blockOrdering;
|
elapsedTimer Phase::_t_blockOrdering;
|
||||||
|
elapsedTimer Phase::_t_macroEliminate;
|
||||||
elapsedTimer Phase::_t_macroExpand;
|
elapsedTimer Phase::_t_macroExpand;
|
||||||
elapsedTimer Phase::_t_peephole;
|
elapsedTimer Phase::_t_peephole;
|
||||||
elapsedTimer Phase::_t_codeGeneration;
|
elapsedTimer Phase::_t_codeGeneration;
|
||||||
@ -104,6 +106,8 @@ void Phase::print_timers() {
|
|||||||
if (DoEscapeAnalysis) {
|
if (DoEscapeAnalysis) {
|
||||||
// EA is part of Optimizer.
|
// EA is part of Optimizer.
|
||||||
tty->print_cr (" escape analysis: %3.3f sec", Phase::_t_escapeAnalysis.seconds());
|
tty->print_cr (" escape analysis: %3.3f sec", Phase::_t_escapeAnalysis.seconds());
|
||||||
|
tty->print_cr (" connection graph: %3.3f sec", Phase::_t_connectionGraph.seconds());
|
||||||
|
tty->print_cr (" macroEliminate : %3.3f sec", Phase::_t_macroEliminate.seconds());
|
||||||
}
|
}
|
||||||
tty->print_cr (" iterGVN : %3.3f sec", Phase::_t_iterGVN.seconds());
|
tty->print_cr (" iterGVN : %3.3f sec", Phase::_t_iterGVN.seconds());
|
||||||
tty->print_cr (" idealLoop : %3.3f sec", Phase::_t_idealLoop.seconds());
|
tty->print_cr (" idealLoop : %3.3f sec", Phase::_t_idealLoop.seconds());
|
||||||
@ -112,9 +116,10 @@ void Phase::print_timers() {
|
|||||||
tty->print_cr (" iterGVN2 : %3.3f sec", Phase::_t_iterGVN2.seconds());
|
tty->print_cr (" iterGVN2 : %3.3f sec", Phase::_t_iterGVN2.seconds());
|
||||||
tty->print_cr (" macroExpand : %3.3f sec", Phase::_t_macroExpand.seconds());
|
tty->print_cr (" macroExpand : %3.3f sec", Phase::_t_macroExpand.seconds());
|
||||||
tty->print_cr (" graphReshape : %3.3f sec", Phase::_t_graphReshaping.seconds());
|
tty->print_cr (" graphReshape : %3.3f sec", Phase::_t_graphReshaping.seconds());
|
||||||
double optimizer_subtotal = Phase::_t_iterGVN.seconds() +
|
double optimizer_subtotal = Phase::_t_iterGVN.seconds() + Phase::_t_iterGVN2.seconds() +
|
||||||
|
Phase::_t_escapeAnalysis.seconds() + Phase::_t_macroEliminate.seconds() +
|
||||||
Phase::_t_idealLoop.seconds() + Phase::_t_ccp.seconds() +
|
Phase::_t_idealLoop.seconds() + Phase::_t_ccp.seconds() +
|
||||||
Phase::_t_graphReshaping.seconds();
|
Phase::_t_macroExpand.seconds() + Phase::_t_graphReshaping.seconds();
|
||||||
double percent_of_optimizer = ((optimizer_subtotal == 0.0) ? 0.0 : (optimizer_subtotal / Phase::_t_optimizer.seconds() * 100.0));
|
double percent_of_optimizer = ((optimizer_subtotal == 0.0) ? 0.0 : (optimizer_subtotal / Phase::_t_optimizer.seconds() * 100.0));
|
||||||
tty->print_cr (" subtotal : %3.3f sec, %3.2f %%", optimizer_subtotal, percent_of_optimizer);
|
tty->print_cr (" subtotal : %3.3f sec, %3.2f %%", optimizer_subtotal, percent_of_optimizer);
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2010, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -72,8 +72,12 @@ protected:
|
|||||||
|
|
||||||
// The next timers used for LogCompilation
|
// The next timers used for LogCompilation
|
||||||
static elapsedTimer _t_parser;
|
static elapsedTimer _t_parser;
|
||||||
static elapsedTimer _t_escapeAnalysis;
|
|
||||||
static elapsedTimer _t_optimizer;
|
static elapsedTimer _t_optimizer;
|
||||||
|
public:
|
||||||
|
// ConnectionGraph can't be Phase since it is used after EA done.
|
||||||
|
static elapsedTimer _t_escapeAnalysis;
|
||||||
|
static elapsedTimer _t_connectionGraph;
|
||||||
|
protected:
|
||||||
static elapsedTimer _t_idealLoop;
|
static elapsedTimer _t_idealLoop;
|
||||||
static elapsedTimer _t_ccp;
|
static elapsedTimer _t_ccp;
|
||||||
static elapsedTimer _t_matcher;
|
static elapsedTimer _t_matcher;
|
||||||
@ -84,6 +88,7 @@ protected:
|
|||||||
static elapsedTimer _t_graphReshaping;
|
static elapsedTimer _t_graphReshaping;
|
||||||
static elapsedTimer _t_scheduler;
|
static elapsedTimer _t_scheduler;
|
||||||
static elapsedTimer _t_blockOrdering;
|
static elapsedTimer _t_blockOrdering;
|
||||||
|
static elapsedTimer _t_macroEliminate;
|
||||||
static elapsedTimer _t_macroExpand;
|
static elapsedTimer _t_macroExpand;
|
||||||
static elapsedTimer _t_peephole;
|
static elapsedTimer _t_peephole;
|
||||||
static elapsedTimer _t_codeGeneration;
|
static elapsedTimer _t_codeGeneration;
|
||||||
|
@ -1301,9 +1301,6 @@ JVM_END
|
|||||||
// Inner class reflection ///////////////////////////////////////////////////////////////////////////////
|
// Inner class reflection ///////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
JVM_ENTRY(jobjectArray, JVM_GetDeclaredClasses(JNIEnv *env, jclass ofClass))
|
JVM_ENTRY(jobjectArray, JVM_GetDeclaredClasses(JNIEnv *env, jclass ofClass))
|
||||||
const int inner_class_info_index = 0;
|
|
||||||
const int outer_class_info_index = 1;
|
|
||||||
|
|
||||||
JvmtiVMObjectAllocEventCollector oam;
|
JvmtiVMObjectAllocEventCollector oam;
|
||||||
// ofClass is a reference to a java_lang_Class object. The mirror object
|
// ofClass is a reference to a java_lang_Class object. The mirror object
|
||||||
// of an instanceKlass
|
// of an instanceKlass
|
||||||
@ -1315,26 +1312,26 @@ JVM_ENTRY(jobjectArray, JVM_GetDeclaredClasses(JNIEnv *env, jclass ofClass))
|
|||||||
}
|
}
|
||||||
|
|
||||||
instanceKlassHandle k(thread, java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(ofClass)));
|
instanceKlassHandle k(thread, java_lang_Class::as_klassOop(JNIHandles::resolve_non_null(ofClass)));
|
||||||
|
InnerClassesIterator iter(k);
|
||||||
|
|
||||||
if (k->inner_classes()->length() == 0) {
|
if (iter.length() == 0) {
|
||||||
// Neither an inner nor outer class
|
// Neither an inner nor outer class
|
||||||
oop result = oopFactory::new_objArray(SystemDictionary::Class_klass(), 0, CHECK_NULL);
|
oop result = oopFactory::new_objArray(SystemDictionary::Class_klass(), 0, CHECK_NULL);
|
||||||
return (jobjectArray)JNIHandles::make_local(env, result);
|
return (jobjectArray)JNIHandles::make_local(env, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
// find inner class info
|
// find inner class info
|
||||||
typeArrayHandle icls(thread, k->inner_classes());
|
|
||||||
constantPoolHandle cp(thread, k->constants());
|
constantPoolHandle cp(thread, k->constants());
|
||||||
int length = icls->length();
|
int length = iter.length();
|
||||||
|
|
||||||
// Allocate temp. result array
|
// Allocate temp. result array
|
||||||
objArrayOop r = oopFactory::new_objArray(SystemDictionary::Class_klass(), length/4, CHECK_NULL);
|
objArrayOop r = oopFactory::new_objArray(SystemDictionary::Class_klass(), length/4, CHECK_NULL);
|
||||||
objArrayHandle result (THREAD, r);
|
objArrayHandle result (THREAD, r);
|
||||||
int members = 0;
|
int members = 0;
|
||||||
|
|
||||||
for(int i = 0; i < length; i += 4) {
|
for (; !iter.done(); iter.next()) {
|
||||||
int ioff = icls->ushort_at(i + inner_class_info_index);
|
int ioff = iter.inner_class_info_index();
|
||||||
int ooff = icls->ushort_at(i + outer_class_info_index);
|
int ooff = iter.outer_class_info_index();
|
||||||
|
|
||||||
if (ioff != 0 && ooff != 0) {
|
if (ioff != 0 && ooff != 0) {
|
||||||
// Check to see if the name matches the class we're looking for
|
// Check to see if the name matches the class we're looking for
|
||||||
@ -1392,17 +1389,13 @@ klassOop instanceKlass::compute_enclosing_class_impl(instanceKlassHandle k,
|
|||||||
bool* inner_is_member,
|
bool* inner_is_member,
|
||||||
TRAPS) {
|
TRAPS) {
|
||||||
Thread* thread = THREAD;
|
Thread* thread = THREAD;
|
||||||
const int inner_class_info_index = inner_class_inner_class_info_offset;
|
InnerClassesIterator iter(k);
|
||||||
const int outer_class_info_index = inner_class_outer_class_info_offset;
|
if (iter.length() == 0) {
|
||||||
|
|
||||||
if (k->inner_classes()->length() == 0) {
|
|
||||||
// No inner class info => no declaring class
|
// No inner class info => no declaring class
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
typeArrayHandle i_icls(thread, k->inner_classes());
|
|
||||||
constantPoolHandle i_cp(thread, k->constants());
|
constantPoolHandle i_cp(thread, k->constants());
|
||||||
int i_length = i_icls->length();
|
|
||||||
|
|
||||||
bool found = false;
|
bool found = false;
|
||||||
klassOop ok;
|
klassOop ok;
|
||||||
@ -1410,10 +1403,10 @@ klassOop instanceKlass::compute_enclosing_class_impl(instanceKlassHandle k,
|
|||||||
*inner_is_member = false;
|
*inner_is_member = false;
|
||||||
|
|
||||||
// Find inner_klass attribute
|
// Find inner_klass attribute
|
||||||
for (int i = 0; i < i_length && !found; i += inner_class_next_offset) {
|
for (; !iter.done() && !found; iter.next()) {
|
||||||
int ioff = i_icls->ushort_at(i + inner_class_info_index);
|
int ioff = iter.inner_class_info_index();
|
||||||
int ooff = i_icls->ushort_at(i + outer_class_info_index);
|
int ooff = iter.outer_class_info_index();
|
||||||
int noff = i_icls->ushort_at(i + inner_class_inner_name_offset);
|
int noff = iter.inner_name_index();
|
||||||
if (ioff != 0) {
|
if (ioff != 0) {
|
||||||
// Check to see if the name matches the class we're looking for
|
// Check to see if the name matches the class we're looking for
|
||||||
// before attempting to find the class.
|
// before attempting to find the class.
|
||||||
|
@ -292,8 +292,8 @@ void JvmtiClassFileReconstituter::write_signature_attribute(u2 generic_signature
|
|||||||
|
|
||||||
// Compute the number of entries in the InnerClasses attribute
|
// Compute the number of entries in the InnerClasses attribute
|
||||||
u2 JvmtiClassFileReconstituter::inner_classes_attribute_length() {
|
u2 JvmtiClassFileReconstituter::inner_classes_attribute_length() {
|
||||||
typeArrayOop inner_class_list = ikh()->inner_classes();
|
InnerClassesIterator iter(ikh());
|
||||||
return (inner_class_list == NULL) ? 0 : inner_class_list->length();
|
return iter.length();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Write an annotation attribute. The VM stores them in raw form, so all we need
|
// Write an annotation attribute. The VM stores them in raw form, so all we need
|
||||||
@ -324,26 +324,20 @@ void JvmtiClassFileReconstituter::write_annotations_attribute(const char* attr_n
|
|||||||
// JVMSpec| } classes[number_of_classes];
|
// JVMSpec| } classes[number_of_classes];
|
||||||
// JVMSpec| }
|
// JVMSpec| }
|
||||||
void JvmtiClassFileReconstituter::write_inner_classes_attribute(int length) {
|
void JvmtiClassFileReconstituter::write_inner_classes_attribute(int length) {
|
||||||
typeArrayOop inner_class_list = ikh()->inner_classes();
|
InnerClassesIterator iter(ikh());
|
||||||
guarantee(inner_class_list != NULL && inner_class_list->length() == length,
|
guarantee(iter.length() != 0 && iter.length() == length,
|
||||||
"caller must check");
|
"caller must check");
|
||||||
typeArrayHandle inner_class_list_h(thread(), inner_class_list);
|
|
||||||
assert (length % instanceKlass::inner_class_next_offset == 0, "just checking");
|
|
||||||
u2 entry_count = length / instanceKlass::inner_class_next_offset;
|
u2 entry_count = length / instanceKlass::inner_class_next_offset;
|
||||||
u4 size = 2 + entry_count * (2+2+2+2);
|
u4 size = 2 + entry_count * (2+2+2+2);
|
||||||
|
|
||||||
write_attribute_name_index("InnerClasses");
|
write_attribute_name_index("InnerClasses");
|
||||||
write_u4(size);
|
write_u4(size);
|
||||||
write_u2(entry_count);
|
write_u2(entry_count);
|
||||||
for (int i = 0; i < length; i += instanceKlass::inner_class_next_offset) {
|
for (; !iter.done(); iter.next()) {
|
||||||
write_u2(inner_class_list_h->ushort_at(
|
write_u2(iter.inner_class_info_index());
|
||||||
i + instanceKlass::inner_class_inner_class_info_offset));
|
write_u2(iter.outer_class_info_index());
|
||||||
write_u2(inner_class_list_h->ushort_at(
|
write_u2(iter.inner_name_index());
|
||||||
i + instanceKlass::inner_class_outer_class_info_offset));
|
write_u2(iter.inner_access_flags());
|
||||||
write_u2(inner_class_list_h->ushort_at(
|
|
||||||
i + instanceKlass::inner_class_inner_name_offset));
|
|
||||||
write_u2(inner_class_list_h->ushort_at(
|
|
||||||
i + instanceKlass::inner_class_access_flags_offset));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2400,14 +2400,9 @@ void VM_RedefineClasses::set_new_constant_pool(
|
|||||||
// new constant indices as needed. The inner classes info is a
|
// new constant indices as needed. The inner classes info is a
|
||||||
// quadruple:
|
// quadruple:
|
||||||
// (inner_class_info, outer_class_info, inner_name, inner_access_flags)
|
// (inner_class_info, outer_class_info, inner_name, inner_access_flags)
|
||||||
typeArrayOop inner_class_list = scratch_class->inner_classes();
|
InnerClassesIterator iter(scratch_class);
|
||||||
int icl_length = (inner_class_list == NULL) ? 0 : inner_class_list->length();
|
for (; !iter.done(); iter.next()) {
|
||||||
if (icl_length > 0) {
|
int cur_index = iter.inner_class_info_index();
|
||||||
typeArrayHandle inner_class_list_h(THREAD, inner_class_list);
|
|
||||||
for (int i = 0; i < icl_length;
|
|
||||||
i += instanceKlass::inner_class_next_offset) {
|
|
||||||
int cur_index = inner_class_list_h->ushort_at(i
|
|
||||||
+ instanceKlass::inner_class_inner_class_info_offset);
|
|
||||||
if (cur_index == 0) {
|
if (cur_index == 0) {
|
||||||
continue; // JVM spec. allows null inner class refs so skip it
|
continue; // JVM spec. allows null inner class refs so skip it
|
||||||
}
|
}
|
||||||
@ -2415,29 +2410,23 @@ void VM_RedefineClasses::set_new_constant_pool(
|
|||||||
if (new_index != 0) {
|
if (new_index != 0) {
|
||||||
RC_TRACE_WITH_THREAD(0x00080000, THREAD,
|
RC_TRACE_WITH_THREAD(0x00080000, THREAD,
|
||||||
("inner_class_info change: %d to %d", cur_index, new_index));
|
("inner_class_info change: %d to %d", cur_index, new_index));
|
||||||
inner_class_list_h->ushort_at_put(i
|
iter.set_inner_class_info_index(new_index);
|
||||||
+ instanceKlass::inner_class_inner_class_info_offset, new_index);
|
|
||||||
}
|
}
|
||||||
cur_index = inner_class_list_h->ushort_at(i
|
cur_index = iter.outer_class_info_index();
|
||||||
+ instanceKlass::inner_class_outer_class_info_offset);
|
|
||||||
new_index = find_new_index(cur_index);
|
new_index = find_new_index(cur_index);
|
||||||
if (new_index != 0) {
|
if (new_index != 0) {
|
||||||
RC_TRACE_WITH_THREAD(0x00080000, THREAD,
|
RC_TRACE_WITH_THREAD(0x00080000, THREAD,
|
||||||
("outer_class_info change: %d to %d", cur_index, new_index));
|
("outer_class_info change: %d to %d", cur_index, new_index));
|
||||||
inner_class_list_h->ushort_at_put(i
|
iter.set_outer_class_info_index(new_index);
|
||||||
+ instanceKlass::inner_class_outer_class_info_offset, new_index);
|
|
||||||
}
|
}
|
||||||
cur_index = inner_class_list_h->ushort_at(i
|
cur_index = iter.inner_name_index();
|
||||||
+ instanceKlass::inner_class_inner_name_offset);
|
|
||||||
new_index = find_new_index(cur_index);
|
new_index = find_new_index(cur_index);
|
||||||
if (new_index != 0) {
|
if (new_index != 0) {
|
||||||
RC_TRACE_WITH_THREAD(0x00080000, THREAD,
|
RC_TRACE_WITH_THREAD(0x00080000, THREAD,
|
||||||
("inner_name change: %d to %d", cur_index, new_index));
|
("inner_name change: %d to %d", cur_index, new_index));
|
||||||
inner_class_list_h->ushort_at_put(i
|
iter.set_inner_name_index(new_index);
|
||||||
+ instanceKlass::inner_class_inner_name_offset, new_index);
|
|
||||||
}
|
}
|
||||||
} // end for each inner class
|
} // end for each inner class
|
||||||
} // end if we have inner classes
|
|
||||||
|
|
||||||
// Attach each method in klass to the new constant pool and update
|
// Attach each method in klass to the new constant pool and update
|
||||||
// to use new constant pool indices as needed:
|
// to use new constant pool indices as needed:
|
||||||
|
@ -816,8 +816,21 @@ bool Arguments::process_argument(const char* arg,
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// For locked flags, report a custom error message if available.
|
||||||
|
// Otherwise, report the standard unrecognized VM option.
|
||||||
|
|
||||||
|
Flag* locked_flag = Flag::find_flag((char*)argname, strlen(argname), true);
|
||||||
|
if (locked_flag != NULL) {
|
||||||
|
char locked_message_buf[BUFLEN];
|
||||||
|
locked_flag->get_locked_message(locked_message_buf, BUFLEN);
|
||||||
|
if (strlen(locked_message_buf) == 0) {
|
||||||
jio_fprintf(defaultStream::error_stream(),
|
jio_fprintf(defaultStream::error_stream(),
|
||||||
"Unrecognized VM option '%s'\n", argname);
|
"Unrecognized VM option '%s'\n", argname);
|
||||||
|
} else {
|
||||||
|
jio_fprintf(defaultStream::error_stream(), "%s", locked_message_buf);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// allow for commandline "commenting out" options like -XX:#+Verbose
|
// allow for commandline "commenting out" options like -XX:#+Verbose
|
||||||
return arg[0] == '#';
|
return arg[0] == '#';
|
||||||
}
|
}
|
||||||
@ -2523,15 +2536,6 @@ jint Arguments::parse_each_vm_init_arg(const JavaVMInitArgs* args,
|
|||||||
// was arrived at by experimenting with specjbb.
|
// was arrived at by experimenting with specjbb.
|
||||||
FLAG_SET_CMDLINE(uintx, OldPLABSize, 8*K); // Note: this is in words
|
FLAG_SET_CMDLINE(uintx, OldPLABSize, 8*K); // Note: this is in words
|
||||||
|
|
||||||
// CompilationPolicyChoice=0 causes the server compiler to adopt
|
|
||||||
// a more conservative which-method-do-I-compile policy when one
|
|
||||||
// of the counters maintained by the interpreter trips. The
|
|
||||||
// result is reduced startup time and improved specjbb and
|
|
||||||
// alacrity performance. Zero is the default, but we set it
|
|
||||||
// explicitly here in case the default changes.
|
|
||||||
// See runtime/compilationPolicy.*.
|
|
||||||
FLAG_SET_CMDLINE(intx, CompilationPolicyChoice, 0);
|
|
||||||
|
|
||||||
// Enable parallel GC and adaptive generation sizing
|
// Enable parallel GC and adaptive generation sizing
|
||||||
FLAG_SET_CMDLINE(bool, UseParallelGC, true);
|
FLAG_SET_CMDLINE(bool, UseParallelGC, true);
|
||||||
FLAG_SET_DEFAULT(ParallelGCThreads,
|
FLAG_SET_DEFAULT(ParallelGCThreads,
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -81,6 +81,12 @@ bool Flag::is_unlocked() const {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Get custom message for this locked flag, or return NULL if
|
||||||
|
// none is available.
|
||||||
|
void Flag::get_locked_message(char* buf, int buflen) const {
|
||||||
|
get_locked_message_ext(buf, buflen);
|
||||||
|
}
|
||||||
|
|
||||||
bool Flag::is_writeable() const {
|
bool Flag::is_writeable() const {
|
||||||
return strcmp(kind, "{manageable}") == 0 ||
|
return strcmp(kind, "{manageable}") == 0 ||
|
||||||
strcmp(kind, "{product rw}") == 0 ||
|
strcmp(kind, "{product rw}") == 0 ||
|
||||||
@ -260,17 +266,22 @@ inline bool str_equal(const char* s, char* q, size_t len) {
|
|||||||
return strncmp(s, q, len) == 0;
|
return strncmp(s, q, len) == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
Flag* Flag::find_flag(char* name, size_t length) {
|
// Search the flag table for a named flag
|
||||||
for (Flag* current = &flagTable[0]; current->name; current++) {
|
Flag* Flag::find_flag(char* name, size_t length, bool allow_locked) {
|
||||||
|
for (Flag* current = &flagTable[0]; current->name != NULL; current++) {
|
||||||
if (str_equal(current->name, name, length)) {
|
if (str_equal(current->name, name, length)) {
|
||||||
|
// Found a matching entry. Report locked flags only if allowed.
|
||||||
if (!(current->is_unlocked() || current->is_unlocker())) {
|
if (!(current->is_unlocked() || current->is_unlocker())) {
|
||||||
// disable use of diagnostic or experimental flags until they
|
if (!allow_locked) {
|
||||||
// are explicitly unlocked
|
// disable use of locked flags, e.g. diagnostic, experimental,
|
||||||
|
// commercial... until they are explicitly unlocked
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return current;
|
return current;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// Flag name is not in the flag table
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -222,7 +222,7 @@ struct Flag {
|
|||||||
// number of flags
|
// number of flags
|
||||||
static size_t numFlags;
|
static size_t numFlags;
|
||||||
|
|
||||||
static Flag* find_flag(char* name, size_t length);
|
static Flag* find_flag(char* name, size_t length, bool allow_locked = false);
|
||||||
|
|
||||||
bool is_bool() const { return strcmp(type, "bool") == 0; }
|
bool is_bool() const { return strcmp(type, "bool") == 0; }
|
||||||
bool get_bool() const { return *((bool*) addr); }
|
bool get_bool() const { return *((bool*) addr); }
|
||||||
@ -259,6 +259,9 @@ struct Flag {
|
|||||||
bool is_writeable_ext() const;
|
bool is_writeable_ext() const;
|
||||||
bool is_external_ext() const;
|
bool is_external_ext() const;
|
||||||
|
|
||||||
|
void get_locked_message(char*, int) const;
|
||||||
|
void get_locked_message_ext(char*, int) const;
|
||||||
|
|
||||||
void print_on(outputStream* st, bool withComments = false );
|
void print_on(outputStream* st, bool withComments = false );
|
||||||
void print_as_flag(outputStream* st);
|
void print_as_flag(outputStream* st);
|
||||||
};
|
};
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011 Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -61,4 +61,9 @@ inline bool Flag::is_external_ext() const {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline void Flag::get_locked_message_ext(char* buf, int buflen) const {
|
||||||
|
assert(buf != NULL, "Buffer cannot be NULL");
|
||||||
|
buf[0] = '\0';
|
||||||
|
}
|
||||||
|
|
||||||
#endif // SHARE_VM_RUNTIME_GLOBALS_EXT_HPP
|
#endif // SHARE_VM_RUNTIME_GLOBALS_EXT_HPP
|
||||||
|
@ -591,14 +591,11 @@ bool Reflection::is_same_package_member(klassOop class1, klassOop class2, TRAPS)
|
|||||||
// Caller is responsible for figuring out in advance which case must be true.
|
// Caller is responsible for figuring out in advance which case must be true.
|
||||||
void Reflection::check_for_inner_class(instanceKlassHandle outer, instanceKlassHandle inner,
|
void Reflection::check_for_inner_class(instanceKlassHandle outer, instanceKlassHandle inner,
|
||||||
bool inner_is_member, TRAPS) {
|
bool inner_is_member, TRAPS) {
|
||||||
const int inner_class_info_index = 0;
|
InnerClassesIterator iter(outer);
|
||||||
const int outer_class_info_index = 1;
|
|
||||||
|
|
||||||
typeArrayHandle icls (THREAD, outer->inner_classes());
|
|
||||||
constantPoolHandle cp (THREAD, outer->constants());
|
constantPoolHandle cp (THREAD, outer->constants());
|
||||||
for(int i = 0; i < icls->length(); i += 4) {
|
for (; !iter.done(); iter.next()) {
|
||||||
int ioff = icls->ushort_at(i + inner_class_info_index);
|
int ioff = iter.inner_class_info_index();
|
||||||
int ooff = icls->ushort_at(i + outer_class_info_index);
|
int ooff = iter.outer_class_info_index();
|
||||||
|
|
||||||
if (inner_is_member && ioff != 0 && ooff != 0) {
|
if (inner_is_member && ioff != 0 && ooff != 0) {
|
||||||
klassOop o = cp->klass_at(ooff, CHECK);
|
klassOop o = cp->klass_at(ooff, CHECK);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -198,8 +198,11 @@ template<class E> class GrowableArray : public GenericGrowableArray {
|
|||||||
return idx;
|
return idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
void append_if_missing(const E& elem) {
|
bool append_if_missing(const E& elem) {
|
||||||
if (!contains(elem)) append(elem);
|
// Returns TRUE if elem is added.
|
||||||
|
bool missed = !contains(elem);
|
||||||
|
if (missed) append(elem);
|
||||||
|
return missed;
|
||||||
}
|
}
|
||||||
|
|
||||||
E at(int i) const {
|
E at(int i) const {
|
||||||
@ -292,12 +295,22 @@ template<class E> class GrowableArray : public GenericGrowableArray {
|
|||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// The order is preserved.
|
||||||
void remove_at(int index) {
|
void remove_at(int index) {
|
||||||
assert(0 <= index && index < _len, "illegal index");
|
assert(0 <= index && index < _len, "illegal index");
|
||||||
for (int j = index + 1; j < _len; j++) _data[j-1] = _data[j];
|
for (int j = index + 1; j < _len; j++) _data[j-1] = _data[j];
|
||||||
_len--;
|
_len--;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// The order is changed.
|
||||||
|
void delete_at(int index) {
|
||||||
|
assert(0 <= index && index < _len, "illegal index");
|
||||||
|
if (index < --_len) {
|
||||||
|
// Replace removed element with last one.
|
||||||
|
_data[index] = _data[_len];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// inserts the given element before the element at index i
|
// inserts the given element before the element at index i
|
||||||
void insert_before(const int idx, const E& elem) {
|
void insert_before(const int idx, const E& elem) {
|
||||||
check_nesting();
|
check_nesting();
|
||||||
|
@ -26,6 +26,8 @@
|
|||||||
# Makefile to run various jdk tests
|
# Makefile to run various jdk tests
|
||||||
#
|
#
|
||||||
|
|
||||||
|
GETMIXEDPATH=echo
|
||||||
|
|
||||||
# Get OS/ARCH specifics
|
# Get OS/ARCH specifics
|
||||||
OSNAME = $(shell uname -s)
|
OSNAME = $(shell uname -s)
|
||||||
ifeq ($(OSNAME), SunOS)
|
ifeq ($(OSNAME), SunOS)
|
||||||
@ -60,7 +62,14 @@ ifeq ($(findstring BSD,$(OSNAME)), BSD)
|
|||||||
ARCH = i586
|
ARCH = i586
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
ifeq ($(OSNAME), Windows_NT)
|
ifeq ($(PLATFORM),)
|
||||||
|
# detect wether we're running in MKS or cygwin
|
||||||
|
ifeq ($(OSNAME), Windows_NT) # MKS
|
||||||
|
GETMIXEDPATH=dosname -s
|
||||||
|
endif
|
||||||
|
ifeq ($(findstring CYGWIN,$(OSNAME)), CYGWIN)
|
||||||
|
GETMIXEDPATH=cygpath -m -s
|
||||||
|
endif
|
||||||
PLATFORM = windows
|
PLATFORM = windows
|
||||||
SLASH_JAVA = J:
|
SLASH_JAVA = J:
|
||||||
ifeq ($(word 1, $(PROCESSOR_IDENTIFIER)),ia64)
|
ifeq ($(word 1, $(PROCESSOR_IDENTIFIER)),ia64)
|
||||||
@ -234,11 +243,11 @@ wbapitest: prep $(JT_HOME) $(PRODUCT_HOME) $(JTREG)
|
|||||||
$(JTREG) -a -v:fail,error \
|
$(JTREG) -a -v:fail,error \
|
||||||
$(JTREG_KEY_OPTION) \
|
$(JTREG_KEY_OPTION) \
|
||||||
$(EXTRA_JTREG_OPTIONS) \
|
$(EXTRA_JTREG_OPTIONS) \
|
||||||
-r:$(ABS_TEST_OUTPUT_DIR)/JTreport \
|
-r:$(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)")/JTreport \
|
||||||
-w:$(ABS_TEST_OUTPUT_DIR)/JTwork \
|
-w:$(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)")/JTwork \
|
||||||
-jdk:$(PRODUCT_HOME) \
|
-jdk:$(shell $(GETMIXEDPATH) "$(PRODUCT_HOME)") \
|
||||||
$(JAVA_OPTIONS:%=-vmoption:%) \
|
$(JAVA_OPTIONS:%=-vmoption:%) \
|
||||||
$(TEST_ROOT)/sanity \
|
$(shell $(GETMIXEDPATH) "$(TEST_ROOT)")/sanity \
|
||||||
|| $(BUNDLE_UP_FAILED)
|
|| $(BUNDLE_UP_FAILED)
|
||||||
$(BUNDLE_UP)
|
$(BUNDLE_UP)
|
||||||
|
|
||||||
|
@ -152,3 +152,5 @@ dbb7283c197b27da1fc12ae8a83785c851b68c12 jdk8-b26
|
|||||||
f3244c1f04864d35c41fa8d13669faf4f65b81e2 jdk8-b28
|
f3244c1f04864d35c41fa8d13669faf4f65b81e2 jdk8-b28
|
||||||
25099a745e1a43579b6af86b3e052b2e50958753 jdk8-b29
|
25099a745e1a43579b6af86b3e052b2e50958753 jdk8-b29
|
||||||
3be30c25a8255803652b5c466336055d36e2ba21 jdk8-b30
|
3be30c25a8255803652b5c466336055d36e2ba21 jdk8-b30
|
||||||
|
94aabe098916440ae7911866311c9617d8481a36 jdk8-b31
|
||||||
|
60960fbc75df8be4c1a2504aa69fc1428cc94f93 jdk8-b32
|
||||||
|
@ -152,3 +152,5 @@ b376d901e006cd9e0c59733c84e190aace23eec6 jdk8-b25
|
|||||||
88b85470e72ce48515c802d2158f61cad198b935 jdk8-b28
|
88b85470e72ce48515c802d2158f61cad198b935 jdk8-b28
|
||||||
4897d9d2d04838e3479745efa238a99bacd939c9 jdk8-b29
|
4897d9d2d04838e3479745efa238a99bacd939c9 jdk8-b29
|
||||||
6882b10e85d6f6ba110dbb50926d6fe2222cc7ad jdk8-b30
|
6882b10e85d6f6ba110dbb50926d6fe2222cc7ad jdk8-b30
|
||||||
|
4c41c6d0e15de3b56919a5ba0a0f248a2d07f2b2 jdk8-b31
|
||||||
|
017a7dbfaa92f5a8b144e6c890d1cebdaecaf681 jdk8-b32
|
||||||
|
@ -152,3 +152,5 @@ c68342532e2e7deb3a25fc04ed3e4c142278f747 jdk8-b27
|
|||||||
1e1d41daaded291ab3a370ca6a27f7325701978e jdk8-b28
|
1e1d41daaded291ab3a370ca6a27f7325701978e jdk8-b28
|
||||||
c5b882dce0fe27e05dc64debc92b1fb9ebf880ec jdk8-b29
|
c5b882dce0fe27e05dc64debc92b1fb9ebf880ec jdk8-b29
|
||||||
cdbb33303ea344d5e9013e2dd642e7a6e7768db6 jdk8-b30
|
cdbb33303ea344d5e9013e2dd642e7a6e7768db6 jdk8-b30
|
||||||
|
27f0c08c427c65fcab6917edf646f59058e59524 jdk8-b31
|
||||||
|
ddfe5562f61f54ed2121ac0c73b688b94f3e66b5 jdk8-b32
|
||||||
|
@ -348,7 +348,13 @@ ifneq ($(PLATFORM), windows)
|
|||||||
" Try setting LANG to 'C'. \n" \
|
" Try setting LANG to 'C'. \n" \
|
||||||
"" >> $(WARNING_FILE) ; \
|
"" >> $(WARNING_FILE) ; \
|
||||||
fi
|
fi
|
||||||
|
ifeq ($(PLATFORM), macosx)
|
||||||
|
@if [ "$(LANG)" = "" ]; then \
|
||||||
|
$(ECHO) "ERROR: LANG must be set on Mac OS X. Recommended value is \"C\"" >> $(ERROR_FILE) ; \
|
||||||
|
fi
|
||||||
endif
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
######################################################
|
######################################################
|
||||||
# Check the Windows cygwin version
|
# Check the Windows cygwin version
|
||||||
|
@ -64,7 +64,7 @@ ACTIVE_JSR_PKGS= \
|
|||||||
javax.management.* \
|
javax.management.* \
|
||||||
javax.script \
|
javax.script \
|
||||||
javax.sql.* \
|
javax.sql.* \
|
||||||
javax.tools \
|
javax.tools.* \
|
||||||
javax.xml.* \
|
javax.xml.* \
|
||||||
org.w3c.* \
|
org.w3c.* \
|
||||||
org.xml.sax
|
org.xml.sax
|
||||||
@ -218,6 +218,7 @@ CORE_PKGS = \
|
|||||||
javax.swing.plaf.nimbus \
|
javax.swing.plaf.nimbus \
|
||||||
javax.swing.plaf.synth \
|
javax.swing.plaf.synth \
|
||||||
javax.tools \
|
javax.tools \
|
||||||
|
javax.tools.annotation \
|
||||||
javax.transaction \
|
javax.transaction \
|
||||||
javax.transaction.xa \
|
javax.transaction.xa \
|
||||||
javax.xml.parsers \
|
javax.xml.parsers \
|
||||||
|
@ -159,7 +159,9 @@ ifeq ($(NATIVE_ECC_AVAILABLE), true)
|
|||||||
$(PKGDIR)/ECDSASignature.java \
|
$(PKGDIR)/ECDSASignature.java \
|
||||||
$(PKGDIR)/ECKeyPairGenerator.java
|
$(PKGDIR)/ECKeyPairGenerator.java
|
||||||
|
|
||||||
JAVAHFLAGS += -Xbootclasspath/p:$(CLASSDESTDIR)
|
JAVAHFLAGS = -bootclasspath \
|
||||||
|
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)"
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# C and C++ files
|
# C and C++ files
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 2005, 2011, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -149,7 +149,8 @@ OTHER_INCLUDES += \
|
|||||||
# Rules
|
# Rules
|
||||||
#
|
#
|
||||||
CLASSDESTDIR = $(TEMPDIR)/classes
|
CLASSDESTDIR = $(TEMPDIR)/classes
|
||||||
JAVAHFLAGS += -Xbootclasspath/p:$(CLASSDESTDIR)
|
JAVAHFLAGS = -bootclasspath \
|
||||||
|
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)"
|
||||||
|
|
||||||
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
||||||
|
|
||||||
|
@ -150,7 +150,8 @@ OTHER_INCLUDES += \
|
|||||||
# Rules
|
# Rules
|
||||||
#
|
#
|
||||||
CLASSDESTDIR = $(TEMPDIR)/classes
|
CLASSDESTDIR = $(TEMPDIR)/classes
|
||||||
JAVAHFLAGS = -bootclasspath "$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)"
|
JAVAHFLAGS = -bootclasspath \
|
||||||
|
"$(CLASSDESTDIR)$(CLASSPATH_SEPARATOR)$(CLASSBINDIR)"
|
||||||
|
|
||||||
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
||||||
|
|
||||||
|
@ -522,11 +522,6 @@ public abstract class LWToolkit extends SunToolkit implements Runnable {
|
|||||||
postEvent(targetToAppContext(event.getSource()), event);
|
postEvent(targetToAppContext(event.getSource()), event);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Returns true if the application (one of its windows) owns keyboard focus.
|
|
||||||
*/
|
|
||||||
public abstract boolean isApplicationActive();
|
|
||||||
|
|
||||||
// use peer's back buffer to implement non-opaque windows.
|
// use peer's back buffer to implement non-opaque windows.
|
||||||
@Override
|
@Override
|
||||||
public boolean needUpdateWindow() {
|
public boolean needUpdateWindow() {
|
||||||
|
@ -1067,11 +1067,7 @@ public class LWWindowPeer
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Cross-app activation requests are not allowed.
|
if (platformWindow.rejectFocusRequest(cause)) {
|
||||||
if (cause != CausedFocusEvent.Cause.MOUSE_EVENT &&
|
|
||||||
!((LWToolkit)Toolkit.getDefaultToolkit()).isApplicationActive())
|
|
||||||
{
|
|
||||||
focusLog.fine("the app is inactive, so the request is rejected");
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -27,6 +27,7 @@ package sun.lwawt;
|
|||||||
|
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
|
|
||||||
|
import sun.awt.CausedFocusEvent;
|
||||||
import sun.java2d.SurfaceData;
|
import sun.java2d.SurfaceData;
|
||||||
|
|
||||||
// TODO Is it worth to generify this interface, like that:
|
// TODO Is it worth to generify this interface, like that:
|
||||||
@ -117,6 +118,8 @@ public interface PlatformWindow {
|
|||||||
|
|
||||||
public void updateFocusableWindowState();
|
public void updateFocusableWindowState();
|
||||||
|
|
||||||
|
public boolean rejectFocusRequest(CausedFocusEvent.Cause cause);
|
||||||
|
|
||||||
public boolean requestWindowFocus();
|
public boolean requestWindowFocus();
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -38,6 +38,8 @@ import java.awt.event.*;
|
|||||||
public class CEmbeddedFrame extends EmbeddedFrame {
|
public class CEmbeddedFrame extends EmbeddedFrame {
|
||||||
|
|
||||||
private CPlatformResponder responder;
|
private CPlatformResponder responder;
|
||||||
|
private boolean focused = true;
|
||||||
|
private boolean parentWindowActive = true;
|
||||||
|
|
||||||
public CEmbeddedFrame() {
|
public CEmbeddedFrame() {
|
||||||
show();
|
show();
|
||||||
@ -94,4 +96,31 @@ public class CEmbeddedFrame extends EmbeddedFrame {
|
|||||||
public void handleInputEvent(String text) {
|
public void handleInputEvent(String text) {
|
||||||
new RuntimeException("Not implemented");
|
new RuntimeException("Not implemented");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void handleFocusEvent(boolean focused) {
|
||||||
|
this.focused = focused;
|
||||||
|
updateOverlayWindowActiveState();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void handleWindowFocusEvent(boolean parentWindowActive) {
|
||||||
|
this.parentWindowActive = parentWindowActive;
|
||||||
|
updateOverlayWindowActiveState();
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isParentWindowActive() {
|
||||||
|
return parentWindowActive;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* May change appearance of contents of window, and generate a
|
||||||
|
* WINDOW_ACTIVATED event.
|
||||||
|
*/
|
||||||
|
private void updateOverlayWindowActiveState() {
|
||||||
|
final boolean showAsFocused = parentWindowActive && focused;
|
||||||
|
dispatchEvent(
|
||||||
|
new FocusEvent(this, showAsFocused ?
|
||||||
|
FocusEvent.FOCUS_GAINED :
|
||||||
|
FocusEvent.FOCUS_LOST));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -33,17 +33,23 @@ import sun.java2d.SurfaceData;
|
|||||||
|
|
||||||
import sun.awt.CGraphicsConfig;
|
import sun.awt.CGraphicsConfig;
|
||||||
import sun.awt.CGraphicsDevice;
|
import sun.awt.CGraphicsDevice;
|
||||||
|
import sun.awt.CausedFocusEvent;
|
||||||
|
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.awt.BufferCapabilities.FlipContents;
|
import java.awt.BufferCapabilities.FlipContents;
|
||||||
|
|
||||||
|
import sun.util.logging.PlatformLogger;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Provides a lightweight implementation of the EmbeddedFrame.
|
* Provides a lightweight implementation of the EmbeddedFrame.
|
||||||
*/
|
*/
|
||||||
public class CPlatformEmbeddedFrame implements PlatformWindow {
|
public class CPlatformEmbeddedFrame implements PlatformWindow {
|
||||||
|
|
||||||
|
private static final PlatformLogger focusLogger = PlatformLogger.getLogger("sun.lwawt.macosx.focus.CPlatformEmbeddedFrame");
|
||||||
|
|
||||||
private CGLLayer windowLayer;
|
private CGLLayer windowLayer;
|
||||||
private LWWindowPeer peer;
|
private LWWindowPeer peer;
|
||||||
|
private CEmbeddedFrame target;
|
||||||
|
|
||||||
private volatile int screenX = 0;
|
private volatile int screenX = 0;
|
||||||
private volatile int screenY = 0;
|
private volatile int screenY = 0;
|
||||||
@ -52,6 +58,7 @@ public class CPlatformEmbeddedFrame implements PlatformWindow {
|
|||||||
public void initialize(Window target, final LWWindowPeer peer, PlatformWindow owner) {
|
public void initialize(Window target, final LWWindowPeer peer, PlatformWindow owner) {
|
||||||
this.peer = peer;
|
this.peer = peer;
|
||||||
this.windowLayer = new CGLLayer(peer);
|
this.windowLayer = new CGLLayer(peer);
|
||||||
|
this.target = (CEmbeddedFrame)target;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -148,6 +155,18 @@ public class CPlatformEmbeddedFrame implements PlatformWindow {
|
|||||||
@Override
|
@Override
|
||||||
public void updateFocusableWindowState() {}
|
public void updateFocusableWindowState() {}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean rejectFocusRequest(CausedFocusEvent.Cause cause) {
|
||||||
|
// Cross-app activation requests are not allowed.
|
||||||
|
if (cause != CausedFocusEvent.Cause.MOUSE_EVENT &&
|
||||||
|
!target.isParentWindowActive())
|
||||||
|
{
|
||||||
|
focusLogger.fine("the embedder is inactive, so the request is rejected");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean requestWindowFocus() {
|
public boolean requestWindowFocus() {
|
||||||
return true;
|
return true;
|
||||||
|
@ -65,6 +65,7 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
|
|
||||||
// Loger to report issues happened during execution but that do not affect functionality
|
// Loger to report issues happened during execution but that do not affect functionality
|
||||||
private static final PlatformLogger logger = PlatformLogger.getLogger("sun.lwawt.macosx.CPlatformWindow");
|
private static final PlatformLogger logger = PlatformLogger.getLogger("sun.lwawt.macosx.CPlatformWindow");
|
||||||
|
private static final PlatformLogger focusLogger = PlatformLogger.getLogger("sun.lwawt.macosx.focus.CPlatformWindow");
|
||||||
|
|
||||||
// for client properties
|
// for client properties
|
||||||
public static final String WINDOW_BRUSH_METAL_LOOK = "apple.awt.brushMetalLook";
|
public static final String WINDOW_BRUSH_METAL_LOOK = "apple.awt.brushMetalLook";
|
||||||
@ -112,6 +113,7 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
static final int MINIMIZABLE = 1 << 8;
|
static final int MINIMIZABLE = 1 << 8;
|
||||||
|
|
||||||
static final int RESIZABLE = 1 << 9; // both a style bit and prop bit
|
static final int RESIZABLE = 1 << 9; // both a style bit and prop bit
|
||||||
|
static final int NONACTIVATING = 1 << 24;
|
||||||
|
|
||||||
static final int _STYLE_PROP_BITMASK = DECORATED | TEXTURED | UNIFIED | UTILITY | HUD | SHEET | CLOSEABLE | MINIMIZABLE | RESIZABLE;
|
static final int _STYLE_PROP_BITMASK = DECORATED | TEXTURED | UNIFIED | UTILITY | HUD | SHEET | CLOSEABLE | MINIMIZABLE | RESIZABLE;
|
||||||
|
|
||||||
@ -127,9 +129,6 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
|
|
||||||
static final int _METHOD_PROP_BITMASK = RESIZABLE | HAS_SHADOW | ZOOMABLE | ALWAYS_ON_TOP | HIDES_ON_DEACTIVATE | DRAGGABLE_BACKGROUND | DOCUMENT_MODIFIED | FULLSCREENABLE;
|
static final int _METHOD_PROP_BITMASK = RESIZABLE | HAS_SHADOW | ZOOMABLE | ALWAYS_ON_TOP | HIDES_ON_DEACTIVATE | DRAGGABLE_BACKGROUND | DOCUMENT_MODIFIED | FULLSCREENABLE;
|
||||||
|
|
||||||
// not sure
|
|
||||||
static final int POPUP = 1 << 14;
|
|
||||||
|
|
||||||
// corresponds to callback-based properties
|
// corresponds to callback-based properties
|
||||||
static final int SHOULD_BECOME_KEY = 1 << 12;
|
static final int SHOULD_BECOME_KEY = 1 << 12;
|
||||||
static final int SHOULD_BECOME_MAIN = 1 << 13;
|
static final int SHOULD_BECOME_MAIN = 1 << 13;
|
||||||
@ -264,10 +263,6 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
// defaults style bits
|
// defaults style bits
|
||||||
int styleBits = DECORATED | HAS_SHADOW | CLOSEABLE | MINIMIZABLE | ZOOMABLE | RESIZABLE;
|
int styleBits = DECORATED | HAS_SHADOW | CLOSEABLE | MINIMIZABLE | ZOOMABLE | RESIZABLE;
|
||||||
|
|
||||||
if (target.getName() == "###overrideRedirect###") {
|
|
||||||
styleBits = SET(styleBits, POPUP, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isNativelyFocusableWindow()) {
|
if (isNativelyFocusableWindow()) {
|
||||||
styleBits = SET(styleBits, SHOULD_BECOME_KEY, true);
|
styleBits = SET(styleBits, SHOULD_BECOME_KEY, true);
|
||||||
styleBits = SET(styleBits, SHOULD_BECOME_MAIN, true);
|
styleBits = SET(styleBits, SHOULD_BECOME_MAIN, true);
|
||||||
@ -275,6 +270,7 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
|
|
||||||
final boolean isFrame = (target instanceof Frame);
|
final boolean isFrame = (target instanceof Frame);
|
||||||
final boolean isDialog = (target instanceof Dialog);
|
final boolean isDialog = (target instanceof Dialog);
|
||||||
|
final boolean isPopup = (target.getType() == Window.Type.POPUP);
|
||||||
if (isDialog) {
|
if (isDialog) {
|
||||||
styleBits = SET(styleBits, MINIMIZABLE, false);
|
styleBits = SET(styleBits, MINIMIZABLE, false);
|
||||||
}
|
}
|
||||||
@ -304,8 +300,10 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
}
|
}
|
||||||
|
|
||||||
// If the target is a dialog, popup or tooltip we want it to ignore the brushed metal look.
|
// If the target is a dialog, popup or tooltip we want it to ignore the brushed metal look.
|
||||||
if (!isDialog && IS(styleBits, POPUP)) {
|
if (isPopup) {
|
||||||
styleBits = SET(styleBits, TEXTURED, true);
|
styleBits = SET(styleBits, TEXTURED, true);
|
||||||
|
// Popups in applets don't activate applet's process
|
||||||
|
styleBits = SET(styleBits, NONACTIVATING, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (target instanceof javax.swing.RootPaneContainer) {
|
if (target instanceof javax.swing.RootPaneContainer) {
|
||||||
@ -498,12 +496,19 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
// If it ain't blocked, or is being hidden, go regular way
|
// If it ain't blocked, or is being hidden, go regular way
|
||||||
if (visible) {
|
if (visible) {
|
||||||
CWrapper.NSWindow.makeFirstResponder(nsWindowPtr, contentView.getAWTView());
|
CWrapper.NSWindow.makeFirstResponder(nsWindowPtr, contentView.getAWTView());
|
||||||
boolean isKeyWindow = CWrapper.NSWindow.isKeyWindow(nsWindowPtr);
|
|
||||||
if (!isKeyWindow) {
|
boolean isPopup = (target.getType() == Window.Type.POPUP);
|
||||||
CWrapper.NSWindow.makeKeyAndOrderFront(nsWindowPtr);
|
if (isPopup) {
|
||||||
|
// Popups in applets don't activate applet's process
|
||||||
|
CWrapper.NSWindow.orderFrontRegardless(nsWindowPtr);
|
||||||
} else {
|
} else {
|
||||||
CWrapper.NSWindow.orderFront(nsWindowPtr);
|
CWrapper.NSWindow.orderFront(nsWindowPtr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
boolean isKeyWindow = CWrapper.NSWindow.isKeyWindow(nsWindowPtr);
|
||||||
|
if (!isKeyWindow) {
|
||||||
|
CWrapper.NSWindow.makeKeyWindow(nsWindowPtr);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
CWrapper.NSWindow.orderOut(nsWindowPtr);
|
CWrapper.NSWindow.orderOut(nsWindowPtr);
|
||||||
}
|
}
|
||||||
@ -599,8 +604,21 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
nativeSetNSWindowMinMax(nsWindowPtr, min.getWidth(), min.getHeight(), max.getWidth(), max.getHeight());
|
nativeSetNSWindowMinMax(nsWindowPtr, min.getWidth(), min.getHeight(), max.getWidth(), max.getHeight());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean rejectFocusRequest(CausedFocusEvent.Cause cause) {
|
||||||
|
// Cross-app activation requests are not allowed.
|
||||||
|
if (cause != CausedFocusEvent.Cause.MOUSE_EVENT &&
|
||||||
|
!((LWCToolkit)Toolkit.getDefaultToolkit()).isApplicationActive())
|
||||||
|
{
|
||||||
|
focusLogger.fine("the app is inactive, so the request is rejected");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean requestWindowFocus() {
|
public boolean requestWindowFocus() {
|
||||||
|
|
||||||
long ptr = getNSWindowPtr();
|
long ptr = getNSWindowPtr();
|
||||||
if (CWrapper.NSWindow.canBecomeMainWindow(ptr)) {
|
if (CWrapper.NSWindow.canBecomeMainWindow(ptr)) {
|
||||||
CWrapper.NSWindow.makeMainWindow(ptr);
|
CWrapper.NSWindow.makeMainWindow(ptr);
|
||||||
@ -751,6 +769,11 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
* Callbacks from the AWTWindow and AWTView objc classes.
|
* Callbacks from the AWTWindow and AWTView objc classes.
|
||||||
*************************************************************/
|
*************************************************************/
|
||||||
private void deliverWindowFocusEvent(boolean gained){
|
private void deliverWindowFocusEvent(boolean gained){
|
||||||
|
// Fix for 7150349: ingore "gained" notifications when the app is inactive.
|
||||||
|
if (gained && !((LWCToolkit)Toolkit.getDefaultToolkit()).isApplicationActive()) {
|
||||||
|
focusLogger.fine("the app is inactive, so the notification is ignored");
|
||||||
|
return;
|
||||||
|
}
|
||||||
peer.notifyActivation(gained);
|
peer.notifyActivation(gained);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,6 +47,7 @@ public final class CWrapper {
|
|||||||
public static native void setLevel(long window, int level);
|
public static native void setLevel(long window, int level);
|
||||||
|
|
||||||
public static native void makeKeyAndOrderFront(long window);
|
public static native void makeKeyAndOrderFront(long window);
|
||||||
|
public static native void makeKeyWindow(long window);
|
||||||
public static native void makeMainWindow(long window);
|
public static native void makeMainWindow(long window);
|
||||||
public static native boolean canBecomeMainWindow(long window);
|
public static native boolean canBecomeMainWindow(long window);
|
||||||
public static native boolean isKeyWindow(long window);
|
public static native boolean isKeyWindow(long window);
|
||||||
|
@ -686,7 +686,10 @@ public class LWCToolkit extends LWToolkit {
|
|||||||
return sunAwtDisableCALayers.booleanValue();
|
return sunAwtDisableCALayers.booleanValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
|
/*
|
||||||
|
* Returns true if the application (one of its windows) owns keyboard focus.
|
||||||
|
*/
|
||||||
public native boolean isApplicationActive();
|
public native boolean isApplicationActive();
|
||||||
|
|
||||||
/************************
|
/************************
|
||||||
|
@ -812,7 +812,7 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod");
|
|||||||
// Unicode value.
|
// Unicode value.
|
||||||
NSUInteger utf8Length = [aString lengthOfBytesUsingEncoding:NSUTF8StringEncoding];
|
NSUInteger utf8Length = [aString lengthOfBytesUsingEncoding:NSUTF8StringEncoding];
|
||||||
|
|
||||||
if ([self hasMarkedText] || !fProcessingKeystroke || (utf8Length > 2)) {
|
if ([self hasMarkedText] || !fProcessingKeystroke || (utf8Length > 1)) {
|
||||||
JNIEnv *env = [ThreadUtilities getJNIEnv];
|
JNIEnv *env = [ThreadUtilities getJNIEnv];
|
||||||
|
|
||||||
static JNF_MEMBER_CACHE(jm_selectPreviousGlyph, jc_CInputMethod, "selectPreviousGlyph", "()V");
|
static JNF_MEMBER_CACHE(jm_selectPreviousGlyph, jc_CInputMethod, "selectPreviousGlyph", "()V");
|
||||||
|
@ -107,6 +107,7 @@ static JNF_CLASS_CACHE(jc_CPlatformWindow, "sun/lwawt/macosx/CPlatformWindow");
|
|||||||
if (IS(styleBits, UTILITY)) type |= NSUtilityWindowMask;
|
if (IS(styleBits, UTILITY)) type |= NSUtilityWindowMask;
|
||||||
if (IS(styleBits, HUD)) type |= NSHUDWindowMask;
|
if (IS(styleBits, HUD)) type |= NSHUDWindowMask;
|
||||||
if (IS(styleBits, SHEET)) type |= NSDocModalWindowMask;
|
if (IS(styleBits, SHEET)) type |= NSDocModalWindowMask;
|
||||||
|
if (IS(styleBits, NONACTIVATING)) type |= NSNonactivatingPanelMask;
|
||||||
|
|
||||||
return type;
|
return type;
|
||||||
}
|
}
|
||||||
|
@ -74,6 +74,26 @@ JNF_COCOA_ENTER(env);
|
|||||||
JNF_COCOA_EXIT(env);
|
JNF_COCOA_EXIT(env);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: sun_lwawt_macosx_CWrapper$NSWindow
|
||||||
|
* Method: makeKeyWindow
|
||||||
|
* Signature: (J)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL
|
||||||
|
Java_sun_lwawt_macosx_CWrapper_00024NSWindow_makeKeyWindow
|
||||||
|
(JNIEnv *env, jclass cls, jlong windowPtr)
|
||||||
|
{
|
||||||
|
JNF_COCOA_ENTER(env);
|
||||||
|
|
||||||
|
NSWindow *window = (NSWindow *)jlong_to_ptr(windowPtr);
|
||||||
|
[JNFRunLoop performOnMainThread:@selector(makeKeyWindow)
|
||||||
|
on:window
|
||||||
|
withObject:nil
|
||||||
|
waitUntilDone:NO];
|
||||||
|
|
||||||
|
JNF_COCOA_EXIT(env);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: sun_lwawt_macosx_CWrapper$NSWindow
|
* Class: sun_lwawt_macosx_CWrapper$NSWindow
|
||||||
* Method: makeMainWindow
|
* Method: makeMainWindow
|
||||||
|
@ -403,12 +403,15 @@ JNIEXPORT jboolean JNICALL Java_sun_lwawt_macosx_LWCToolkit_isApplicationActive
|
|||||||
{
|
{
|
||||||
__block jboolean active = JNI_FALSE;
|
__block jboolean active = JNI_FALSE;
|
||||||
|
|
||||||
AWT_ASSERT_NOT_APPKIT_THREAD;
|
|
||||||
JNF_COCOA_ENTER(env);
|
JNF_COCOA_ENTER(env);
|
||||||
|
|
||||||
|
if ([NSThread isMainThread]) {
|
||||||
|
active = (jboolean)[NSRunningApplication currentApplication].active;
|
||||||
|
} else {
|
||||||
[JNFRunLoop performOnMainThreadWaiting:YES withBlock:^() {
|
[JNFRunLoop performOnMainThreadWaiting:YES withBlock:^() {
|
||||||
active = (jboolean)[NSRunningApplication currentApplication].active;
|
active = (jboolean)[NSRunningApplication currentApplication].active;
|
||||||
}];
|
}];
|
||||||
|
}
|
||||||
|
|
||||||
JNF_COCOA_EXIT(env);
|
JNF_COCOA_EXIT(env);
|
||||||
|
|
||||||
|
@ -31,33 +31,31 @@
|
|||||||
#import <JavaRuntimeSupport/JavaRuntimeSupport.h>
|
#import <JavaRuntimeSupport/JavaRuntimeSupport.h>
|
||||||
|
|
||||||
|
|
||||||
// returns 10.7 for Lion, 10.6 for SnowLeopard etc.
|
// returns 107 for Lion, 106 for SnowLeopard etc.
|
||||||
double getOSXMajorVersion() {
|
int getOSXMajorVersion() {
|
||||||
char *version = JRSCopyOSVersion();
|
char *ver = JRSCopyOSVersion();
|
||||||
|
if (ver == NULL) {
|
||||||
if (version == NULL) return 0.0;
|
return 0;
|
||||||
|
|
||||||
char temp[32];
|
|
||||||
strlcpy(temp, version, sizeof(temp));
|
|
||||||
free(version);
|
|
||||||
|
|
||||||
if (strlen(temp) < 3) {
|
|
||||||
return 0.0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (temp[2] != '.') { // Third char must be a '.'
|
int len = strlen(ver);
|
||||||
return 0.0;
|
int v = 0;
|
||||||
|
|
||||||
|
// Third char must be a '.'
|
||||||
|
if (len >= 3 && ver[2] == '.') {
|
||||||
|
int i;
|
||||||
|
|
||||||
|
v = (ver[0] - '0') * 10 + (ver[1] - '0');
|
||||||
|
for (i = 3; i < len && isdigit(ver[i]); ++i) {
|
||||||
|
v = v * 10 + (ver[i] - '0');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
char *ptr = strchr(temp+3, '.'); // remove the second . if one exists.
|
free(ver);
|
||||||
if (ptr != NULL) {
|
|
||||||
*ptr = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return atof(temp);
|
return v;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
BOOL isSnowLeopardOrLower() {
|
BOOL isSnowLeopardOrLower() {
|
||||||
return (getOSXMajorVersion() < 10.7);
|
return (getOSXMajorVersion() < 107);
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2009, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -33,6 +33,7 @@ import java.security.InvalidKeyException;
|
|||||||
import java.security.Key;
|
import java.security.Key;
|
||||||
import java.security.NoSuchAlgorithmException;
|
import java.security.NoSuchAlgorithmException;
|
||||||
import java.security.SecureRandom;
|
import java.security.SecureRandom;
|
||||||
|
import java.security.ProviderException;
|
||||||
import java.security.spec.AlgorithmParameterSpec;
|
import java.security.spec.AlgorithmParameterSpec;
|
||||||
import java.security.spec.InvalidKeySpecException;
|
import java.security.spec.InvalidKeySpecException;
|
||||||
import javax.crypto.KeyAgreementSpi;
|
import javax.crypto.KeyAgreementSpi;
|
||||||
@ -234,31 +235,14 @@ extends KeyAgreementSpi {
|
|||||||
protected byte[] engineGenerateSecret()
|
protected byte[] engineGenerateSecret()
|
||||||
throws IllegalStateException
|
throws IllegalStateException
|
||||||
{
|
{
|
||||||
if (generateSecret == false) {
|
int expectedLen = (init_p.bitLength() + 7) >>> 3;
|
||||||
throw new IllegalStateException
|
byte[] result = new byte[expectedLen];
|
||||||
("Key agreement has not been completed yet");
|
try {
|
||||||
}
|
engineGenerateSecret(result, 0);
|
||||||
|
} catch (ShortBufferException sbe) {
|
||||||
// Reset the key agreement here (in case anything goes wrong)
|
// should never happen since length are identical
|
||||||
generateSecret = false;
|
|
||||||
|
|
||||||
// get the modulus
|
|
||||||
BigInteger modulus = init_p;
|
|
||||||
|
|
||||||
BigInteger tmpResult = y.modPow(x, modulus);
|
|
||||||
byte[] secret = tmpResult.toByteArray();
|
|
||||||
|
|
||||||
/*
|
|
||||||
* BigInteger.toByteArray will sometimes put a sign byte up front, but
|
|
||||||
* we NEVER want one.
|
|
||||||
*/
|
|
||||||
if ((tmpResult.bitLength() % 8) == 0) {
|
|
||||||
byte retval[] = new byte[secret.length - 1];
|
|
||||||
System.arraycopy(secret, 1, retval, 0, retval.length);
|
|
||||||
return retval;
|
|
||||||
} else {
|
|
||||||
return secret;
|
|
||||||
}
|
}
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -301,40 +285,52 @@ extends KeyAgreementSpi {
|
|||||||
}
|
}
|
||||||
|
|
||||||
BigInteger modulus = init_p;
|
BigInteger modulus = init_p;
|
||||||
byte[] secret = this.y.modPow(this.x, modulus).toByteArray();
|
int expectedLen = (modulus.bitLength() + 7) >>> 3;
|
||||||
|
if ((sharedSecret.length - offset) < expectedLen) {
|
||||||
// BigInteger.toByteArray will sometimes put a sign byte up front,
|
|
||||||
// but we NEVER want one.
|
|
||||||
if ((secret.length << 3) != modulus.bitLength()) {
|
|
||||||
if ((sharedSecret.length - offset) < (secret.length - 1)) {
|
|
||||||
throw new ShortBufferException
|
throw new ShortBufferException
|
||||||
("Buffer too short for shared secret");
|
("Buffer too short for shared secret");
|
||||||
}
|
}
|
||||||
System.arraycopy(secret, 1, sharedSecret, offset,
|
|
||||||
secret.length - 1);
|
|
||||||
|
|
||||||
// Reset the key agreement here (not earlier!), so that people
|
// Reset the key agreement after checking for ShortBufferException
|
||||||
// can recover from ShortBufferException above without losing
|
// above, so user can recover w/o losing internal state
|
||||||
// internal state
|
|
||||||
generateSecret = false;
|
generateSecret = false;
|
||||||
|
|
||||||
return secret.length - 1;
|
/*
|
||||||
|
* NOTE: BigInteger.toByteArray() returns a byte array containing
|
||||||
|
* the two's-complement representation of this BigInteger with
|
||||||
|
* the most significant byte is in the zeroth element. This
|
||||||
|
* contains the minimum number of bytes required to represent
|
||||||
|
* this BigInteger, including at least one sign bit whose value
|
||||||
|
* is always 0.
|
||||||
|
*
|
||||||
|
* Keys are always positive, and the above sign bit isn't
|
||||||
|
* actually used when representing keys. (i.e. key = new
|
||||||
|
* BigInteger(1, byteArray)) To obtain an array containing
|
||||||
|
* exactly expectedLen bytes of magnitude, we strip any extra
|
||||||
|
* leading 0's, or pad with 0's in case of a "short" secret.
|
||||||
|
*/
|
||||||
|
byte[] secret = this.y.modPow(this.x, modulus).toByteArray();
|
||||||
|
if (secret.length == expectedLen) {
|
||||||
|
System.arraycopy(secret, 0, sharedSecret, offset,
|
||||||
|
secret.length);
|
||||||
} else {
|
} else {
|
||||||
if ((sharedSecret.length - offset) < secret.length) {
|
// Array too short, pad it w/ leading 0s
|
||||||
throw new ShortBufferException
|
if (secret.length < expectedLen) {
|
||||||
("Buffer too short to hold shared secret");
|
System.arraycopy(secret, 0, sharedSecret,
|
||||||
|
offset + (expectedLen - secret.length),
|
||||||
|
secret.length);
|
||||||
|
} else {
|
||||||
|
// Array too long, check and trim off the excess
|
||||||
|
if ((secret.length == (expectedLen+1)) && secret[0] == 0) {
|
||||||
|
// ignore the leading sign byte
|
||||||
|
System.arraycopy(secret, 1, sharedSecret, offset, expectedLen);
|
||||||
|
} else {
|
||||||
|
throw new ProviderException("Generated secret is out-of-range");
|
||||||
}
|
}
|
||||||
System.arraycopy(secret, 0, sharedSecret, offset, secret.length);
|
|
||||||
|
|
||||||
// Reset the key agreement here (not earlier!), so that people
|
|
||||||
// can recover from ShortBufferException above without losing
|
|
||||||
// internal state
|
|
||||||
generateSecret = false;
|
|
||||||
|
|
||||||
return secret.length;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return expectedLen;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates the shared secret and returns it as a secret key object
|
* Creates the shared secret and returns it as a secret key object
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -42,7 +42,7 @@ import javax.management.StandardMBean;
|
|||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.TreeSet;
|
import java.util.HashSet;
|
||||||
import java.security.AccessController;
|
import java.security.AccessController;
|
||||||
import java.security.Permission;
|
import java.security.Permission;
|
||||||
import java.security.PrivilegedAction;
|
import java.security.PrivilegedAction;
|
||||||
@ -787,7 +787,7 @@ public class ManagementFactory {
|
|||||||
getPlatformManagementInterfaces()
|
getPlatformManagementInterfaces()
|
||||||
{
|
{
|
||||||
Set<Class<? extends PlatformManagedObject>> result =
|
Set<Class<? extends PlatformManagedObject>> result =
|
||||||
new TreeSet<>();
|
new HashSet<>();
|
||||||
for (PlatformComponent component: PlatformComponent.values()) {
|
for (PlatformComponent component: PlatformComponent.values()) {
|
||||||
result.add(component.getMXBeanInterface());
|
result.add(component.getMXBeanInterface());
|
||||||
}
|
}
|
||||||
|
@ -207,6 +207,9 @@ class InMemoryCookieStore implements CookieStore {
|
|||||||
public boolean removeAll() {
|
public boolean removeAll() {
|
||||||
lock.lock();
|
lock.lock();
|
||||||
try {
|
try {
|
||||||
|
if (cookieJar.isEmpty()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
cookieJar.clear();
|
cookieJar.clear();
|
||||||
domainIndex.clear();
|
domainIndex.clear();
|
||||||
uriIndex.clear();
|
uriIndex.clear();
|
||||||
|
@ -34,6 +34,8 @@ import java.io.IOException;
|
|||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.security.AccessController;
|
import java.security.AccessController;
|
||||||
import java.security.PrivilegedAction;
|
import java.security.PrivilegedAction;
|
||||||
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
|
import java.util.concurrent.ConcurrentMap;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
@ -99,7 +101,7 @@ public final class Currency implements Serializable {
|
|||||||
|
|
||||||
// class data: instance map
|
// class data: instance map
|
||||||
|
|
||||||
private static HashMap<String, Currency> instances = new HashMap<String, Currency>(7);
|
private static ConcurrentMap<String, Currency> instances = new ConcurrentHashMap<>(7);
|
||||||
private static HashSet<Currency> available;
|
private static HashSet<Currency> available;
|
||||||
|
|
||||||
|
|
||||||
@ -284,7 +286,6 @@ public final class Currency implements Serializable {
|
|||||||
|
|
||||||
private static Currency getInstance(String currencyCode, int defaultFractionDigits,
|
private static Currency getInstance(String currencyCode, int defaultFractionDigits,
|
||||||
int numericCode) {
|
int numericCode) {
|
||||||
synchronized (instances) {
|
|
||||||
// Try to look up the currency code in the instances table.
|
// Try to look up the currency code in the instances table.
|
||||||
// This does the null pointer check as a side effect.
|
// This does the null pointer check as a side effect.
|
||||||
// Also, if there already is an entry, the currencyCode must be valid.
|
// Also, if there already is an entry, the currencyCode must be valid.
|
||||||
@ -322,10 +323,9 @@ public final class Currency implements Serializable {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
instance = new Currency(currencyCode, defaultFractionDigits, numericCode);
|
instance = instances.putIfAbsent(currencyCode,
|
||||||
instances.put(currencyCode, instance);
|
new Currency(currencyCode, defaultFractionDigits, numericCode));
|
||||||
return instance;
|
return (instance != null ? instance : instances.get(currencyCode));
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -400,6 +400,8 @@ public class Manifest implements Cloneable {
|
|||||||
public byte peek() throws IOException {
|
public byte peek() throws IOException {
|
||||||
if (pos == count)
|
if (pos == count)
|
||||||
fill();
|
fill();
|
||||||
|
if (pos == count)
|
||||||
|
return -1; // nothing left in buffer
|
||||||
return buf[pos];
|
return buf[pos];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -252,6 +252,10 @@ public class DefaultListSelectionModel implements ListSelectionModel, Cloneable,
|
|||||||
|
|
||||||
// Updates first and last change indices
|
// Updates first and last change indices
|
||||||
private void markAsDirty(int r) {
|
private void markAsDirty(int r) {
|
||||||
|
if (r == -1) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
firstAdjustedIndex = Math.min(firstAdjustedIndex, r);
|
firstAdjustedIndex = Math.min(firstAdjustedIndex, r);
|
||||||
lastAdjustedIndex = Math.max(lastAdjustedIndex, r);
|
lastAdjustedIndex = Math.max(lastAdjustedIndex, r);
|
||||||
}
|
}
|
||||||
@ -358,16 +362,12 @@ public class DefaultListSelectionModel implements ListSelectionModel, Cloneable,
|
|||||||
private void updateLeadAnchorIndices(int anchorIndex, int leadIndex) {
|
private void updateLeadAnchorIndices(int anchorIndex, int leadIndex) {
|
||||||
if (leadAnchorNotificationEnabled) {
|
if (leadAnchorNotificationEnabled) {
|
||||||
if (this.anchorIndex != anchorIndex) {
|
if (this.anchorIndex != anchorIndex) {
|
||||||
if (this.anchorIndex != -1) { // The unassigned state.
|
|
||||||
markAsDirty(this.anchorIndex);
|
markAsDirty(this.anchorIndex);
|
||||||
}
|
|
||||||
markAsDirty(anchorIndex);
|
markAsDirty(anchorIndex);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.leadIndex != leadIndex) {
|
if (this.leadIndex != leadIndex) {
|
||||||
if (this.leadIndex != -1) { // The unassigned state.
|
|
||||||
markAsDirty(this.leadIndex);
|
markAsDirty(this.leadIndex);
|
||||||
}
|
|
||||||
markAsDirty(leadIndex);
|
markAsDirty(leadIndex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -160,7 +160,7 @@ public class BatchEnvironment extends sun.tools.javac.BatchEnvironment {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** list of generated source files created in this environment */
|
/** list of generated source files created in this environment */
|
||||||
private Vector generatedFiles = new Vector();
|
private Vector<File> generatedFiles = new Vector<>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Remember a generated source file generated so that it
|
* Remember a generated source file generated so that it
|
||||||
@ -177,9 +177,9 @@ public class BatchEnvironment extends sun.tools.javac.BatchEnvironment {
|
|||||||
*/
|
*/
|
||||||
public void deleteGeneratedFiles() {
|
public void deleteGeneratedFiles() {
|
||||||
synchronized(generatedFiles) {
|
synchronized(generatedFiles) {
|
||||||
Enumeration enumeration = generatedFiles.elements();
|
Enumeration<File> enumeration = generatedFiles.elements();
|
||||||
while (enumeration.hasMoreElements()) {
|
while (enumeration.hasMoreElements()) {
|
||||||
File file = (File) enumeration.nextElement();
|
File file = enumeration.nextElement();
|
||||||
file.delete();
|
file.delete();
|
||||||
}
|
}
|
||||||
generatedFiles.removeAllElements();
|
generatedFiles.removeAllElements();
|
||||||
|
@ -73,14 +73,15 @@ public class Main implements sun.rmi.rmic.Constants {
|
|||||||
File destDir;
|
File destDir;
|
||||||
int flags;
|
int flags;
|
||||||
long tm;
|
long tm;
|
||||||
Vector classes;
|
Vector<String> classes;
|
||||||
boolean nowrite;
|
boolean nowrite;
|
||||||
boolean nocompile;
|
boolean nocompile;
|
||||||
boolean keepGenerated;
|
boolean keepGenerated;
|
||||||
boolean status;
|
boolean status;
|
||||||
String[] generatorArgs;
|
String[] generatorArgs;
|
||||||
Vector generators;
|
Vector<Generator> generators;
|
||||||
Class environmentClass = BatchEnvironment.class;
|
Class<? extends BatchEnvironment> environmentClass =
|
||||||
|
BatchEnvironment.class;
|
||||||
boolean iiopGeneration = false;
|
boolean iiopGeneration = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -183,7 +184,7 @@ public class Main implements sun.rmi.rmic.Constants {
|
|||||||
destDir = null;
|
destDir = null;
|
||||||
flags = F_WARNINGS;
|
flags = F_WARNINGS;
|
||||||
tm = System.currentTimeMillis();
|
tm = System.currentTimeMillis();
|
||||||
classes = new Vector();
|
classes = new Vector<>();
|
||||||
nowrite = false;
|
nowrite = false;
|
||||||
nocompile = false;
|
nocompile = false;
|
||||||
keepGenerated = false;
|
keepGenerated = false;
|
||||||
@ -191,7 +192,7 @@ public class Main implements sun.rmi.rmic.Constants {
|
|||||||
if (generatorArgs == null) {
|
if (generatorArgs == null) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
generators = new Vector();
|
generators = new Vector<>();
|
||||||
|
|
||||||
// Pre-process command line for @file arguments
|
// Pre-process command line for @file arguments
|
||||||
try {
|
try {
|
||||||
@ -411,7 +412,7 @@ public class Main implements sun.rmi.rmic.Constants {
|
|||||||
|
|
||||||
// Get the environment required by this generator...
|
// Get the environment required by this generator...
|
||||||
|
|
||||||
Class envClass = BatchEnvironment.class;
|
Class<?> envClass = BatchEnvironment.class;
|
||||||
String env = getString("generator.env." + arg);
|
String env = getString("generator.env." + arg);
|
||||||
if (env != null) {
|
if (env != null) {
|
||||||
try {
|
try {
|
||||||
@ -423,7 +424,7 @@ public class Main implements sun.rmi.rmic.Constants {
|
|||||||
|
|
||||||
// Yes, so switch to the new one...
|
// Yes, so switch to the new one...
|
||||||
|
|
||||||
environmentClass = envClass;
|
environmentClass = envClass.asSubclass(BatchEnvironment.class);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
@ -495,8 +496,9 @@ public class Main implements sun.rmi.rmic.Constants {
|
|||||||
try {
|
try {
|
||||||
Class[] ctorArgTypes = {OutputStream.class,ClassPath.class,Main.class};
|
Class[] ctorArgTypes = {OutputStream.class,ClassPath.class,Main.class};
|
||||||
Object[] ctorArgs = {out,classPath,this};
|
Object[] ctorArgs = {out,classPath,this};
|
||||||
Constructor constructor = environmentClass.getConstructor(ctorArgTypes);
|
Constructor<? extends BatchEnvironment> constructor =
|
||||||
result = (BatchEnvironment) constructor.newInstance(ctorArgs);
|
environmentClass.getConstructor(ctorArgTypes);
|
||||||
|
result = constructor.newInstance(ctorArgs);
|
||||||
result.reset();
|
result.reset();
|
||||||
}
|
}
|
||||||
catch (Exception e) {
|
catch (Exception e) {
|
||||||
@ -530,7 +532,7 @@ public class Main implements sun.rmi.rmic.Constants {
|
|||||||
*/
|
*/
|
||||||
for (int i = classes.size()-1; i >= 0; i-- ) {
|
for (int i = classes.size()-1; i >= 0; i-- ) {
|
||||||
Identifier implClassName =
|
Identifier implClassName =
|
||||||
Identifier.lookup((String)classes.elementAt(i));
|
Identifier.lookup(classes.elementAt(i));
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Fix bugid 4049354: support using '.' as an inner class
|
* Fix bugid 4049354: support using '.' as an inner class
|
||||||
@ -558,7 +560,7 @@ public class Main implements sun.rmi.rmic.Constants {
|
|||||||
try {
|
try {
|
||||||
ClassDefinition def = decl.getClassDefinition(env);
|
ClassDefinition def = decl.getClassDefinition(env);
|
||||||
for (int j = 0; j < generators.size(); j++) {
|
for (int j = 0; j < generators.size(); j++) {
|
||||||
Generator gen = (Generator)generators.elementAt(j);
|
Generator gen = generators.elementAt(j);
|
||||||
gen.generate(env, def, destDir);
|
gen.generate(env, def, destDir);
|
||||||
}
|
}
|
||||||
} catch (ClassNotFound ex) {
|
} catch (ClassNotFound ex) {
|
||||||
@ -673,7 +675,7 @@ public class Main implements sun.rmi.rmic.Constants {
|
|||||||
|
|
||||||
do {
|
do {
|
||||||
done = true;
|
done = true;
|
||||||
for (Enumeration e = env.getClasses() ; e.hasMoreElements() ; ) {
|
for (Enumeration<?> e = env.getClasses() ; e.hasMoreElements() ; ) {
|
||||||
ClassDeclaration c = (ClassDeclaration)e.nextElement();
|
ClassDeclaration c = (ClassDeclaration)e.nextElement();
|
||||||
done = compileClass(c,buf,env);
|
done = compileClass(c,buf,env);
|
||||||
}
|
}
|
||||||
@ -682,7 +684,9 @@ public class Main implements sun.rmi.rmic.Constants {
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Compile a single class.
|
* Compile a single class.
|
||||||
|
* Fallthrough is intentional
|
||||||
*/
|
*/
|
||||||
|
@SuppressWarnings("fallthrough")
|
||||||
public boolean compileClass (ClassDeclaration c,
|
public boolean compileClass (ClassDeclaration c,
|
||||||
ByteArrayOutputStream buf,
|
ByteArrayOutputStream buf,
|
||||||
BatchEnvironment env)
|
BatchEnvironment env)
|
||||||
@ -879,6 +883,6 @@ public class Main implements sun.rmi.rmic.Constants {
|
|||||||
args[1] = (arg1 != null ? arg1.toString() : "null");
|
args[1] = (arg1 != null ? arg1.toString() : "null");
|
||||||
args[2] = (arg2 != null ? arg2.toString() : "null");
|
args[2] = (arg2 != null ? arg2.toString() : "null");
|
||||||
|
|
||||||
return java.text.MessageFormat.format(format, args);
|
return java.text.MessageFormat.format(format, (Object[]) args);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -61,7 +61,7 @@ import com.sun.corba.se.impl.util.Utility;
|
|||||||
*/
|
*/
|
||||||
public class RMIGenerator implements RMIConstants, Generator {
|
public class RMIGenerator implements RMIConstants, Generator {
|
||||||
|
|
||||||
private static final Hashtable versionOptions = new Hashtable();
|
private static final Hashtable<String, Integer> versionOptions = new Hashtable<>();
|
||||||
static {
|
static {
|
||||||
versionOptions.put("-v1.1", new Integer(STUB_VERSION_1_1));
|
versionOptions.put("-v1.1", new Integer(STUB_VERSION_1_1));
|
||||||
versionOptions.put("-vcompat", new Integer(STUB_VERSION_FAT));
|
versionOptions.put("-vcompat", new Integer(STUB_VERSION_FAT));
|
||||||
@ -96,7 +96,7 @@ public class RMIGenerator implements RMIConstants, Generator {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
explicitVersion = arg;
|
explicitVersion = arg;
|
||||||
version = ((Integer) versionOptions.get(arg)).intValue();
|
version = versionOptions.get(arg);
|
||||||
argv[i] = null;
|
argv[i] = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -519,7 +519,7 @@ public class RMIGenerator implements RMIConstants, Generator {
|
|||||||
* follows a previous catch of it or of one of its superclasses.
|
* follows a previous catch of it or of one of its superclasses.
|
||||||
* The following method invocation takes care of these details.
|
* The following method invocation takes care of these details.
|
||||||
*/
|
*/
|
||||||
Vector catchList = computeUniqueCatchList(exceptions);
|
Vector<ClassDefinition> catchList = computeUniqueCatchList(exceptions);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If we need to catch any particular exceptions (i.e. this method
|
* If we need to catch any particular exceptions (i.e. this method
|
||||||
@ -615,10 +615,10 @@ public class RMIGenerator implements RMIConstants, Generator {
|
|||||||
* UnexpectedException, and end the try block.
|
* UnexpectedException, and end the try block.
|
||||||
*/
|
*/
|
||||||
if (catchList.size() > 0) {
|
if (catchList.size() > 0) {
|
||||||
for (Enumeration enumeration = catchList.elements();
|
for (Enumeration<ClassDefinition> enumeration = catchList.elements();
|
||||||
enumeration.hasMoreElements();)
|
enumeration.hasMoreElements();)
|
||||||
{
|
{
|
||||||
ClassDefinition def = (ClassDefinition) enumeration.nextElement();
|
ClassDefinition def = enumeration.nextElement();
|
||||||
p.pOlnI("} catch (" + def.getName() + " e) {");
|
p.pOlnI("} catch (" + def.getName() + " e) {");
|
||||||
p.pln("throw e;");
|
p.pln("throw e;");
|
||||||
}
|
}
|
||||||
@ -650,8 +650,8 @@ public class RMIGenerator implements RMIConstants, Generator {
|
|||||||
* of its superclasses is in the throws clause of the method, indicating
|
* of its superclasses is in the throws clause of the method, indicating
|
||||||
* that no exceptions need to be caught.
|
* that no exceptions need to be caught.
|
||||||
*/
|
*/
|
||||||
private Vector computeUniqueCatchList(ClassDeclaration[] exceptions) {
|
private Vector<ClassDefinition> computeUniqueCatchList(ClassDeclaration[] exceptions) {
|
||||||
Vector uniqueList = new Vector(); // unique exceptions to catch
|
Vector<ClassDefinition> uniqueList = new Vector<>(); // unique exceptions to catch
|
||||||
|
|
||||||
uniqueList.addElement(defRuntimeException);
|
uniqueList.addElement(defRuntimeException);
|
||||||
uniqueList.addElement(defRemoteException);
|
uniqueList.addElement(defRemoteException);
|
||||||
@ -682,8 +682,7 @@ public class RMIGenerator implements RMIConstants, Generator {
|
|||||||
* exceptions that need to be caught:
|
* exceptions that need to be caught:
|
||||||
*/
|
*/
|
||||||
for (int j = 0; j < uniqueList.size();) {
|
for (int j = 0; j < uniqueList.size();) {
|
||||||
ClassDefinition def =
|
ClassDefinition def = uniqueList.elementAt(j);
|
||||||
(ClassDefinition) uniqueList.elementAt(j);
|
|
||||||
if (def.superClassOf(env, decl)) {
|
if (def.superClassOf(env, decl)) {
|
||||||
/*
|
/*
|
||||||
* If a superclass of this exception is already on
|
* If a superclass of this exception is already on
|
||||||
|
@ -455,7 +455,7 @@ public class Main {
|
|||||||
BatchEnvironment env;
|
BatchEnvironment env;
|
||||||
try {
|
try {
|
||||||
Constructor<? extends BatchEnvironment> cons =
|
Constructor<? extends BatchEnvironment> cons =
|
||||||
batch.envClass.getConstructor(new Class[] { RootDoc.class });
|
batch.envClass.getConstructor(new Class<?>[] { RootDoc.class });
|
||||||
env = cons.newInstance(rootDoc);
|
env = cons.newInstance(rootDoc);
|
||||||
} catch (NoSuchMethodException e) {
|
} catch (NoSuchMethodException e) {
|
||||||
throw new AssertionError(e);
|
throw new AssertionError(e);
|
||||||
|
@ -69,7 +69,7 @@ public final class Resources {
|
|||||||
format = "missing resource key: key = \"" + key + "\", " +
|
format = "missing resource key: key = \"" + key + "\", " +
|
||||||
"arguments = \"{0}\", \"{1}\", \"{2}\"";
|
"arguments = \"{0}\", \"{1}\", \"{2}\"";
|
||||||
}
|
}
|
||||||
return MessageFormat.format(format, args);
|
return MessageFormat.format(format, (Object[]) args);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -198,8 +198,22 @@ final class P11KeyAgreement extends KeyAgreementSpi {
|
|||||||
token.p11.C_GetAttributeValue(session.id(), keyID, attributes);
|
token.p11.C_GetAttributeValue(session.id(), keyID, attributes);
|
||||||
byte[] secret = attributes[0].getByteArray();
|
byte[] secret = attributes[0].getByteArray();
|
||||||
token.p11.C_DestroyObject(session.id(), keyID);
|
token.p11.C_DestroyObject(session.id(), keyID);
|
||||||
// trim leading 0x00 bytes per JCE convention
|
// Some vendors, e.g. NSS, trim off the leading 0x00 byte(s) from
|
||||||
return P11Util.trimZeroes(secret);
|
// the generated secret. Thus, we need to check the secret length
|
||||||
|
// and trim/pad it so the returned value has the same length as
|
||||||
|
// the modulus size
|
||||||
|
if (secret.length == secretLen) {
|
||||||
|
return secret;
|
||||||
|
} else {
|
||||||
|
if (secret.length > secretLen) {
|
||||||
|
// Shouldn't happen; but check just in case
|
||||||
|
throw new ProviderException("generated secret is out-of-range");
|
||||||
|
}
|
||||||
|
byte[] newSecret = new byte[secretLen];
|
||||||
|
System.arraycopy(secret, 0, newSecret, secretLen - secret.length,
|
||||||
|
secret.length);
|
||||||
|
return newSecret;
|
||||||
|
}
|
||||||
} catch (PKCS11Exception e) {
|
} catch (PKCS11Exception e) {
|
||||||
throw new ProviderException("Could not derive key", e);
|
throw new ProviderException("Could not derive key", e);
|
||||||
} finally {
|
} finally {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -96,9 +96,9 @@ getPathName(const char *dir, const char *name) {
|
|||||||
/*
|
/*
|
||||||
* Scans the specified directory and its subdirectories to find a
|
* Scans the specified directory and its subdirectories to find a
|
||||||
* zoneinfo file which has the same content as /etc/localtime on Linux
|
* zoneinfo file which has the same content as /etc/localtime on Linux
|
||||||
* or /usr/share/lib/zoneinfo/localtime (most likely a symbolic link)
|
* or /usr/share/lib/zoneinfo/localtime on Solaris given in 'buf'.
|
||||||
* on Solaris given in 'buf'. Returns a zone ID if found, otherwise,
|
* If file is symbolic link, then the contents it points to are in buf.
|
||||||
* NULL is returned.
|
* Returns a zone ID if found, otherwise, NULL is returned.
|
||||||
*/
|
*/
|
||||||
static char *
|
static char *
|
||||||
findZoneinfoFile(char *buf, size_t size, const char *dir)
|
findZoneinfoFile(char *buf, size_t size, const char *dir)
|
||||||
@ -280,21 +280,27 @@ getPlatformTimeZoneID()
|
|||||||
tz = getZoneName(linkbuf);
|
tz = getZoneName(linkbuf);
|
||||||
if (tz != NULL) {
|
if (tz != NULL) {
|
||||||
tz = strdup(tz);
|
tz = strdup(tz);
|
||||||
}
|
|
||||||
return tz;
|
return tz;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If it's a regular file, we need to find out the same zoneinfo file
|
* If it's a regular file, we need to find out the same zoneinfo file
|
||||||
* that has been copied as /etc/localtime.
|
* that has been copied as /etc/localtime.
|
||||||
|
* If initial symbolic link resolution failed, we should treat target
|
||||||
|
* file as a regular file.
|
||||||
*/
|
*/
|
||||||
|
if ((fd = open(DEFAULT_ZONEINFO_FILE, O_RDONLY)) == -1) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
if (fstat(fd, &statbuf) == -1) {
|
||||||
|
(void) close(fd);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
size = (size_t) statbuf.st_size;
|
size = (size_t) statbuf.st_size;
|
||||||
buf = (char *) malloc(size);
|
buf = (char *) malloc(size);
|
||||||
if (buf == NULL) {
|
if (buf == NULL) {
|
||||||
return NULL;
|
(void) close(fd);
|
||||||
}
|
|
||||||
if ((fd = open(DEFAULT_ZONEINFO_FILE, O_RDONLY)) == -1) {
|
|
||||||
free((void *) buf);
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -541,6 +541,8 @@ XImage* X11SD_CreateSharedImage(X11SDOps *xsdo,
|
|||||||
J2dRlsTraceLn1(J2D_TRACE_ERROR,
|
J2dRlsTraceLn1(J2D_TRACE_ERROR,
|
||||||
"X11SD_SetupSharedSegment shmget has failed: %s",
|
"X11SD_SetupSharedSegment shmget has failed: %s",
|
||||||
strerror(errno));
|
strerror(errno));
|
||||||
|
free((void *)shminfo);
|
||||||
|
XDestroyImage(img);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -550,6 +552,8 @@ XImage* X11SD_CreateSharedImage(X11SDOps *xsdo,
|
|||||||
J2dRlsTraceLn1(J2D_TRACE_ERROR,
|
J2dRlsTraceLn1(J2D_TRACE_ERROR,
|
||||||
"X11SD_SetupSharedSegment shmat has failed: %s",
|
"X11SD_SetupSharedSegment shmat has failed: %s",
|
||||||
strerror(errno));
|
strerror(errno));
|
||||||
|
free((void *)shminfo);
|
||||||
|
XDestroyImage(img);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -570,6 +574,9 @@ XImage* X11SD_CreateSharedImage(X11SDOps *xsdo,
|
|||||||
J2dRlsTraceLn1(J2D_TRACE_ERROR,
|
J2dRlsTraceLn1(J2D_TRACE_ERROR,
|
||||||
"X11SD_SetupSharedSegment XShmAttach has failed: %s",
|
"X11SD_SetupSharedSegment XShmAttach has failed: %s",
|
||||||
strerror(errno));
|
strerror(errno));
|
||||||
|
shmdt(shminfo->shmaddr);
|
||||||
|
free((void *)shminfo);
|
||||||
|
XDestroyImage(img);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1345,13 +1352,10 @@ void X11SD_DisposeXImage(XImage * image) {
|
|||||||
#ifdef MITSHM
|
#ifdef MITSHM
|
||||||
if (image->obdata != NULL) {
|
if (image->obdata != NULL) {
|
||||||
X11SD_DropSharedSegment((XShmSegmentInfo*)image->obdata);
|
X11SD_DropSharedSegment((XShmSegmentInfo*)image->obdata);
|
||||||
} else {
|
image->obdata = NULL;
|
||||||
free(image->data);
|
|
||||||
}
|
}
|
||||||
#else
|
|
||||||
free(image->data);
|
|
||||||
#endif /* MITSHM */
|
#endif /* MITSHM */
|
||||||
XFree(image);
|
XDestroyImage(image);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -36,6 +36,7 @@
|
|||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
|
|
||||||
#include "nio_util.h"
|
#include "nio_util.h"
|
||||||
|
#include <limits.h>
|
||||||
|
|
||||||
JNIEXPORT jint JNICALL
|
JNIEXPORT jint JNICALL
|
||||||
Java_sun_nio_ch_DatagramDispatcher_read0(JNIEnv *env, jclass clazz,
|
Java_sun_nio_ch_DatagramDispatcher_read0(JNIEnv *env, jclass clazz,
|
||||||
@ -60,23 +61,14 @@ Java_sun_nio_ch_DatagramDispatcher_readv0(JNIEnv *env, jclass clazz,
|
|||||||
ssize_t result = 0;
|
ssize_t result = 0;
|
||||||
struct iovec *iov = (struct iovec *)jlong_to_ptr(address);
|
struct iovec *iov = (struct iovec *)jlong_to_ptr(address);
|
||||||
struct msghdr m;
|
struct msghdr m;
|
||||||
if (len > 16) {
|
if (len > IOV_MAX) {
|
||||||
len = 16;
|
len = IOV_MAX;
|
||||||
}
|
}
|
||||||
|
|
||||||
m.msg_name = NULL;
|
// initialize the message
|
||||||
m.msg_namelen = 0;
|
memset(&m, 0, sizeof(m));
|
||||||
m.msg_iov = iov;
|
m.msg_iov = iov;
|
||||||
m.msg_iovlen = len;
|
m.msg_iovlen = len;
|
||||||
#ifdef __solaris__
|
|
||||||
m.msg_accrights = NULL;
|
|
||||||
m.msg_accrightslen = 0;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(__linux__) || defined(_ALLBSD_SOURCE)
|
|
||||||
m.msg_control = NULL;
|
|
||||||
m.msg_controllen = 0;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
result = recvmsg(fd, &m, 0);
|
result = recvmsg(fd, &m, 0);
|
||||||
if (result < 0 && errno == ECONNREFUSED) {
|
if (result < 0 && errno == ECONNREFUSED) {
|
||||||
@ -108,23 +100,14 @@ Java_sun_nio_ch_DatagramDispatcher_writev0(JNIEnv *env, jclass clazz,
|
|||||||
struct iovec *iov = (struct iovec *)jlong_to_ptr(address);
|
struct iovec *iov = (struct iovec *)jlong_to_ptr(address);
|
||||||
struct msghdr m;
|
struct msghdr m;
|
||||||
ssize_t result = 0;
|
ssize_t result = 0;
|
||||||
if (len > 16) {
|
if (len > IOV_MAX) {
|
||||||
len = 16;
|
len = IOV_MAX;
|
||||||
}
|
}
|
||||||
|
|
||||||
m.msg_name = NULL;
|
// initialize the message
|
||||||
m.msg_namelen = 0;
|
memset(&m, 0, sizeof(m));
|
||||||
m.msg_iov = iov;
|
m.msg_iov = iov;
|
||||||
m.msg_iovlen = len;
|
m.msg_iovlen = len;
|
||||||
#ifdef __solaris__
|
|
||||||
m.msg_accrights = NULL;
|
|
||||||
m.msg_accrightslen = 0;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(__linux__) || defined(_ALLBSD_SOURCE)
|
|
||||||
m.msg_control = NULL;
|
|
||||||
m.msg_controllen = 0;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
result = sendmsg(fd, &m, 0);
|
result = sendmsg(fd, &m, 0);
|
||||||
if (result < 0 && errno == ECONNREFUSED) {
|
if (result < 0 && errno == ECONNREFUSED) {
|
||||||
|
@ -30,9 +30,6 @@
|
|||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <dlfcn.h>
|
#include <dlfcn.h>
|
||||||
#ifndef __APPLE__
|
|
||||||
#include <link.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __solaris__
|
#ifdef __solaris__
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
|
@ -26,9 +26,6 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <dlfcn.h>
|
#include <dlfcn.h>
|
||||||
#ifndef __APPLE__
|
|
||||||
#include <link.h>
|
|
||||||
#endif
|
|
||||||
#include "NativeFunc.h"
|
#include "NativeFunc.h"
|
||||||
|
|
||||||
/* standard GSS method names (ordering is from mapfile) */
|
/* standard GSS method names (ordering is from mapfile) */
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user