Merge
This commit is contained in:
commit
aed9248e0b
@ -835,10 +835,6 @@ endif
|
|||||||
$(BOOT_JAVA_CMD) -jar $(BUILDMETAINDEX_JARFILE) \
|
$(BOOT_JAVA_CMD) -jar $(BUILDMETAINDEX_JARFILE) \
|
||||||
-o meta-index *.jar
|
-o meta-index *.jar
|
||||||
@$(CD) $(JRE_IMAGE_DIR)/lib/ext && $(java-vm-cleanup)
|
@$(CD) $(JRE_IMAGE_DIR)/lib/ext && $(java-vm-cleanup)
|
||||||
ifeq ($(PLATFORM), macosx)
|
|
||||||
@#install jobjc, apple mac only
|
|
||||||
$(CP) $(OUTPUTDIR)/JObjC.build/JObjC.jar $(JRE_IMAGE_DIR)/lib/JObjC.jar
|
|
||||||
endif
|
|
||||||
ifeq ($(PLATFORM), windows)
|
ifeq ($(PLATFORM), windows)
|
||||||
@# Remove certain *.lib files
|
@# Remove certain *.lib files
|
||||||
$(CD) $(JRE_IMAGE_DIR)/lib && \
|
$(CD) $(JRE_IMAGE_DIR)/lib && \
|
||||||
|
@ -57,10 +57,6 @@ ifeq ($(PLATFORM), linux)
|
|||||||
SUBDIRS += jexec
|
SUBDIRS += jexec
|
||||||
endif # PLATFORM
|
endif # PLATFORM
|
||||||
|
|
||||||
ifeq ($(PLATFORM), macosx)
|
|
||||||
SUBDIRS += jobjc
|
|
||||||
endif # PLATFORM
|
|
||||||
|
|
||||||
include $(BUILDDIR)/common/Subdirs.gmk
|
include $(BUILDDIR)/common/Subdirs.gmk
|
||||||
|
|
||||||
all build clean clobber::
|
all build clean clobber::
|
||||||
|
@ -270,11 +270,6 @@ ifeq ($(OPENJDK_TARGET_OS),macosx)
|
|||||||
$(JDK_TOPDIR)/src/solaris/classes/sun/util/locale/provider/HostLocaleProviderAdapterImpl.java \
|
$(JDK_TOPDIR)/src/solaris/classes/sun/util/locale/provider/HostLocaleProviderAdapterImpl.java \
|
||||||
$(JDK_TOPDIR)/src/solaris/classes/sun/nio/fs/GnomeFileTypeDetector.java
|
$(JDK_TOPDIR)/src/solaris/classes/sun/nio/fs/GnomeFileTypeDetector.java
|
||||||
|
|
||||||
# JObjC.jar contains 1.5 byte-code...so skip it here :-(
|
|
||||||
# MACOSX_SRC_DIRS += $(JDK_TOPDIR)/src/macosx/native/jobjc/src
|
|
||||||
# EXCLUDES+= tests/java/com/apple/jobjc
|
|
||||||
|
|
||||||
EXCLUDES+= com/apple/jobjc
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# The exception handling of swing beaninfo
|
# The exception handling of swing beaninfo
|
||||||
@ -326,44 +321,6 @@ $(JDK_OUTPUTDIR)/classes/META-INF/services/com.sun.tools.xjc.Plugin:
|
|||||||
|
|
||||||
##########################################################################################
|
##########################################################################################
|
||||||
|
|
||||||
ifeq ($(OPENJDK_TARGET_OS),macosx)
|
|
||||||
#
|
|
||||||
# JObjC.jar is compiled with BOOT_JAVAC which (may) not support the "-h" flag.
|
|
||||||
# so we first compile classes with BOOT_JAVAC and then with JDK_JAVAC :-(
|
|
||||||
#
|
|
||||||
$(eval $(call SetupJavaCompiler,GENERATE_15BYTECODE,\
|
|
||||||
JAVAC:=$(JAVAC),\
|
|
||||||
FLAGS:=-source 1.5 -target 1.5 -g -bootclasspath $(BOOT_RTJAR) -cp $(JDK_OUTPUTDIR)/../langtools/dist/lib/classes.jar $(DISABLE_WARNINGS),\
|
|
||||||
SERVER_DIR:=$(SJAVAC_SERVER_DIR),\
|
|
||||||
SERVER_JVM:=$(SJAVAC_SERVER_JAVA)))
|
|
||||||
|
|
||||||
$(eval $(call SetupJavaCompilation,BUILD_JOBJC,\
|
|
||||||
SETUP:=GENERATE_15BYTECODE,\
|
|
||||||
DISABLE_SJAVAC:=true,\
|
|
||||||
SRC:=$(JDK_TOPDIR)/src/macosx/native/jobjc/src/core/java \
|
|
||||||
$(JDK_TOPDIR)/src/macosx/native/jobjc/src/runtime-additions/java \
|
|
||||||
$(JDK_OUTPUTDIR)/gensrc_jobjc/src, \
|
|
||||||
INCLUDES := com/apple/jobjc,\
|
|
||||||
EXCLUDES := tests/java/com/apple/jobjc,\
|
|
||||||
BIN:=$(JDK_OUTPUTDIR)/jobjc_classes,\
|
|
||||||
JAR:=$(JDK_OUTPUTDIR)/lib/JObjC.jar, \
|
|
||||||
JARINDEX := true))
|
|
||||||
|
|
||||||
$(BUILD_JOBJC) : $(BUILD_JDK)
|
|
||||||
|
|
||||||
$(eval $(call SetupJavaCompilation,BUILD_JOBJC_HEADERS,\
|
|
||||||
SETUP:=GENERATE_JDKBYTECODE,\
|
|
||||||
SRC:=$(JDK_TOPDIR)/src/macosx/native/jobjc/src/core/java \
|
|
||||||
$(JDK_TOPDIR)/src/macosx/native/jobjc/src/runtime-additions/java \
|
|
||||||
$(JDK_OUTPUTDIR)/gensrc_jobjc/src, \
|
|
||||||
INCLUDES := com/apple/jobjc,\
|
|
||||||
EXCLUDES := tests/java/com/apple/jobjc,\
|
|
||||||
BIN:=$(JDK_OUTPUTDIR)/jobjc_classes_headers,\
|
|
||||||
HEADERS:=$(JDK_OUTPUTDIR)/gensrc_headers_jobjc))
|
|
||||||
|
|
||||||
$(BUILD_JOBJC_HEADERS) : $(BUILD_JDK)
|
|
||||||
|
|
||||||
endif
|
|
||||||
|
|
||||||
##########################################################################################
|
##########################################################################################
|
||||||
|
|
||||||
@ -402,7 +359,7 @@ endif
|
|||||||
|
|
||||||
##########################################################################################
|
##########################################################################################
|
||||||
|
|
||||||
all: $(BUILD_JDK) $(BUILD_ALTCLASSES) $(BUILD_JOBJC) $(BUILD_JOBJC_HEADERS) $(COPY_EXTRA) \
|
all: $(BUILD_JDK) $(BUILD_ALTCLASSES) $(COPY_EXTRA) \
|
||||||
$(JDK_OUTPUTDIR)/classes/META-INF/services/com.sun.tools.xjc.Plugin \
|
$(JDK_OUTPUTDIR)/classes/META-INF/services/com.sun.tools.xjc.Plugin \
|
||||||
$(BUILD_ACCESSBRIDGE_32) $(BUILD_ACCESSBRIDGE_64) \
|
$(BUILD_ACCESSBRIDGE_32) $(BUILD_ACCESSBRIDGE_64) \
|
||||||
$(BUILD_ACCESSBRIDGE_LEGACY)
|
$(BUILD_ACCESSBRIDGE_LEGACY)
|
||||||
|
@ -3297,67 +3297,6 @@ endif
|
|||||||
|
|
||||||
##########################################################################################
|
##########################################################################################
|
||||||
|
|
||||||
ifeq ($(OPENJDK_TARGET_OS), macosx)
|
|
||||||
|
|
||||||
# Ugly hack to mimic behaviour in old build where this is built as an xcode project.
|
|
||||||
SET_SHARED_LIBRARY_NAME=-Xlinker -install_name -Xlinker /usr/local/lib/libJObjC.dylib
|
|
||||||
|
|
||||||
$(eval $(call SetupNativeCompilation,BUILD_LIBJOBJC32,\
|
|
||||||
LIBRARY:=JObjC,\
|
|
||||||
OUTPUT_DIR:=$(JDK_OUTPUTDIR)/objs/libjobjc32,\
|
|
||||||
SRC:=$(JDK_TOPDIR)/src/macosx/native/jobjc/src/core/native \
|
|
||||||
$(JDK_TOPDIR)/src/macosx/native/jobjc/src/runtime-additions/native ,\
|
|
||||||
LANG:=C,\
|
|
||||||
OPTIMIZATION:=LOW, \
|
|
||||||
CFLAGS:=-fpascal-strings \
|
|
||||||
-fobjc-gc \
|
|
||||||
-gdwarf-2 \
|
|
||||||
$(CFLAGS_JDKLIB) -I$(JDK_OUTPUTDIR)/gensrc_headers_jobjc \
|
|
||||||
-F/System/Library/Frameworks/JavaVM.framework/Frameworks \
|
|
||||||
-m32,\
|
|
||||||
LDFLAGS:=$(LDFLAGS_JDKLIB)\
|
|
||||||
-m32, \
|
|
||||||
LDFLAGS_SUFFIX:=-framework Foundation -framework JavaVM \
|
|
||||||
-F/System/Library/Frameworks/JavaVM.framework/Frameworks \
|
|
||||||
-framework JavaNativeFoundation \
|
|
||||||
-lffi, \
|
|
||||||
OBJECT_DIR:=$(JDK_OUTPUTDIR)/objs/libjobjc32,\
|
|
||||||
DEBUG_SYMBOLS:=$(DEBUG_ALL_BINARIES)))
|
|
||||||
|
|
||||||
$(eval $(call SetupNativeCompilation,BUILD_LIBJOBJC64,\
|
|
||||||
LIBRARY:=JObjC,\
|
|
||||||
OUTPUT_DIR:=$(JDK_OUTPUTDIR)/objs/libjobjc64,\
|
|
||||||
SRC:=$(JDK_TOPDIR)/src/macosx/native/jobjc/src/core/native \
|
|
||||||
$(JDK_TOPDIR)/src/macosx/native/jobjc/src/runtime-additions/native ,\
|
|
||||||
LANG:=C,\
|
|
||||||
OPTIMIZATION:=LOW, \
|
|
||||||
CFLAGS:=-fpascal-strings \
|
|
||||||
-fobjc-gc \
|
|
||||||
-gdwarf-2 \
|
|
||||||
$(CFLAGS_JDKLIB) -I$(JDK_OUTPUTDIR)/gensrc_headers_jobjc \
|
|
||||||
-F/System/Library/Frameworks/JavaVM.framework/Frameworks \
|
|
||||||
, \
|
|
||||||
LDFLAGS:=-fpascal-strings \
|
|
||||||
-fobjc-gc \
|
|
||||||
-gdwarf-2 \
|
|
||||||
$(LDFLAGS_JDKLIB)\
|
|
||||||
$(call SET_SHARED_LIBRARY_ORIGIN), \
|
|
||||||
LDFLAGS_SUFFIX:=-framework Foundation -framework JavaVM \
|
|
||||||
-F/System/Library/Frameworks/JavaVM.framework/Frameworks \
|
|
||||||
-framework JavaNativeFoundation \
|
|
||||||
-lffi, \
|
|
||||||
OBJECT_DIR:=$(JDK_OUTPUTDIR)/objs/libjobjc64,\
|
|
||||||
DEBUG_SYMBOLS:=$(DEBUG_ALL_BINARIES)))
|
|
||||||
|
|
||||||
$(INSTALL_LIBRARIES_HERE)/$(LIBRARY_PREFIX)JObjC$(SHARED_LIBRARY_SUFFIX): $(BUILD_LIBJOBJC32) $(BUILD_LIBJOBJC64)
|
|
||||||
$(LIPO) -create -output $@ $(BUILD_LIBJOBJC32) $(BUILD_LIBJOBJC64)
|
|
||||||
|
|
||||||
BUILD_LIBRARIES += $(INSTALL_LIBRARIES_HERE)/$(LIBRARY_PREFIX)JObjC$(SHARED_LIBRARY_SUFFIX)
|
|
||||||
|
|
||||||
endif
|
|
||||||
|
|
||||||
##########################################################################################
|
|
||||||
|
|
||||||
ifndef OPENJDK
|
ifndef OPENJDK
|
||||||
ifeq ($(OPENJDK_TARGET_OS), windows)
|
ifeq ($(OPENJDK_TARGET_OS), windows)
|
||||||
|
|
||||||
|
@ -1028,15 +1028,6 @@ $(IMAGES_OUTPUTDIR)/lib/ext/zipfs.jar : $(JDK_OUTPUTDIR)/demo/nio/zipfs/zipfs.ja
|
|||||||
|
|
||||||
##########################################################################################
|
##########################################################################################
|
||||||
|
|
||||||
ifeq ($(OPENJDK_TARGET_OS),macosx)
|
|
||||||
$(eval $(call SetupArchive,BUILD_JOBJC_JAR,,\
|
|
||||||
SRCS:=$(JDK_OUTPUTDIR)/jobjc_classes,\
|
|
||||||
JAR:=$(IMAGES_OUTPUTDIR)/lib/JObjC.jar, \
|
|
||||||
JARINDEX:=true))
|
|
||||||
endif
|
|
||||||
|
|
||||||
##########################################################################################
|
|
||||||
|
|
||||||
ifndef OPENJDK
|
ifndef OPENJDK
|
||||||
$(eval $(call SetupArchive,BUILD_ALT_RT_JAR,,\
|
$(eval $(call SetupArchive,BUILD_ALT_RT_JAR,,\
|
||||||
SRCS:=$(JDK_OUTPUTDIR)/altclasses_classes,\
|
SRCS:=$(JDK_OUTPUTDIR)/altclasses_classes,\
|
||||||
|
@ -83,11 +83,6 @@ GENSRC += $(GENSRC_CLDR)
|
|||||||
include GensrcSwing.gmk
|
include GensrcSwing.gmk
|
||||||
GENSRC += $(GENSRC_SWING_BEANINFO) $(GENSRC_SWING_NIMBUS)
|
GENSRC += $(GENSRC_SWING_BEANINFO) $(GENSRC_SWING_NIMBUS)
|
||||||
|
|
||||||
ifeq ($(OPENJDK_TARGET_OS), macosx)
|
|
||||||
include GensrcJObjC.gmk
|
|
||||||
GENSRC += $(GENSRC_JOBJC)
|
|
||||||
endif
|
|
||||||
|
|
||||||
$(GENSRC) : $(BUILD_TOOLS)
|
$(GENSRC) : $(BUILD_TOOLS)
|
||||||
|
|
||||||
all: $(GENSRC)
|
all: $(GENSRC)
|
||||||
|
@ -283,14 +283,13 @@ $(JDK_IMAGE_DIR)/jre/lib/applet:
|
|||||||
$(ECHO) $(LOG_INFO) Creating $(patsubst $(OUTPUT_ROOT)/%,%,$@)
|
$(ECHO) $(LOG_INFO) Creating $(patsubst $(OUTPUT_ROOT)/%,%,$@)
|
||||||
$(MKDIR) -p $@
|
$(MKDIR) -p $@
|
||||||
|
|
||||||
# In the old build, JObjC.jar is not part of the meta-index
|
|
||||||
$(JRE_IMAGE_DIR)/lib/meta-index: $(JRE_LIB_TARGETS)
|
$(JRE_IMAGE_DIR)/lib/meta-index: $(JRE_LIB_TARGETS)
|
||||||
$(ECHO) $(LOG_INFO) Generating $(patsubst $(OUTPUT_ROOT)/%,%,$@)
|
$(ECHO) $(LOG_INFO) Generating $(patsubst $(OUTPUT_ROOT)/%,%,$@)
|
||||||
$(CD) $(@D) && $(TOOL_BUILDMETAINDEX) -o meta-index `$(LS) *.jar | $(SED) 's/JObjC\.jar//g'`
|
$(CD) $(@D) && $(TOOL_BUILDMETAINDEX) -o meta-index *.jar
|
||||||
|
|
||||||
$(JDK_IMAGE_DIR)/jre/lib/meta-index: $(JDKJRE_LIB_TARGETS)
|
$(JDK_IMAGE_DIR)/jre/lib/meta-index: $(JDKJRE_LIB_TARGETS)
|
||||||
$(ECHO) $(LOG_INFO) Generating $(patsubst $(OUTPUT_ROOT)/%,%,$@)
|
$(ECHO) $(LOG_INFO) Generating $(patsubst $(OUTPUT_ROOT)/%,%,$@)
|
||||||
$(CD) $(@D) && $(TOOL_BUILDMETAINDEX) -o meta-index `$(LS) *.jar | $(SED) 's/JObjC\.jar//g'`
|
$(CD) $(@D) && $(TOOL_BUILDMETAINDEX) -o meta-index *.jar
|
||||||
|
|
||||||
$(JRE_IMAGE_DIR)/lib/ext/meta-index: $(JRE_LIB_TARGETS)
|
$(JRE_IMAGE_DIR)/lib/ext/meta-index: $(JRE_LIB_TARGETS)
|
||||||
$(ECHO) $(LOG_INFO) Generating $(patsubst $(OUTPUT_ROOT)/%,%,$@)
|
$(ECHO) $(LOG_INFO) Generating $(patsubst $(OUTPUT_ROOT)/%,%,$@)
|
||||||
|
@ -109,10 +109,6 @@ ifeq ($(OPENJDK_TARGET_OS),windows)
|
|||||||
ALL_JARS += $(IMAGES_OUTPUTDIR)/lib/ext/sunmscapi.jar
|
ALL_JARS += $(IMAGES_OUTPUTDIR)/lib/ext/sunmscapi.jar
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(OPENJDK_TARGET_OS),macosx)
|
|
||||||
ALL_JARS += $(IMAGES_OUTPUTDIR)/lib/JObjC.jar
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(PROFILE), profile_1)
|
ifeq ($(PROFILE), profile_1)
|
||||||
PROFILE_JARS := $(PROFILE_1_JARS)
|
PROFILE_JARS := $(PROFILE_1_JARS)
|
||||||
else ifeq ($(PROFILE), profile_2)
|
else ifeq ($(PROFILE), profile_2)
|
||||||
|
@ -29,6 +29,7 @@ import com.sun.beans.finder.ClassFinder;
|
|||||||
import java.beans.ExceptionListener;
|
import java.beans.ExceptionListener;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.io.StringReader;
|
||||||
|
|
||||||
import java.lang.ref.Reference;
|
import java.lang.ref.Reference;
|
||||||
import java.lang.ref.WeakReference;
|
import java.lang.ref.WeakReference;
|
||||||
@ -245,6 +246,14 @@ public final class DocumentHandler extends DefaultHandler {
|
|||||||
this.objects.add(object);
|
this.objects.add(object);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Disables any external entities.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public InputSource resolveEntity(String publicId, String systemId) {
|
||||||
|
return new InputSource(new StringReader(""));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Prepares this handler to read objects from XML document.
|
* Prepares this handler to read objects from XML document.
|
||||||
*/
|
*/
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2013, 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
|
||||||
@ -660,7 +660,7 @@ public class XmlReaderContentHandler extends DefaultHandler {
|
|||||||
//Added the handling for Class tags to take care of maps
|
//Added the handling for Class tags to take care of maps
|
||||||
//Makes an entry into the map upon end of class tag
|
//Makes an entry into the map upon end of class tag
|
||||||
try{
|
try{
|
||||||
typeMap.put(Key_map,Class.forName(Value_map));
|
typeMap.put(Key_map,sun.reflect.misc.ReflectUtil.forName(Value_map));
|
||||||
|
|
||||||
}catch(ClassNotFoundException ex) {
|
}catch(ClassNotFoundException ex) {
|
||||||
throw new SAXException(MessageFormat.format(resBundle.handleGetObject("xmlrch.errmap").toString(), ex.getMessage()));
|
throw new SAXException(MessageFormat.format(resBundle.handleGetObject("xmlrch.errmap").toString(), ex.getMessage()));
|
||||||
|
@ -35,6 +35,8 @@ import java.io.FileInputStream;
|
|||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.FileNotFoundException;
|
import java.io.FileNotFoundException;
|
||||||
|
import java.security.AccessController;
|
||||||
|
import java.security.PrivilegedAction;
|
||||||
|
|
||||||
import javax.naming.*;
|
import javax.naming.*;
|
||||||
|
|
||||||
@ -348,7 +350,17 @@ public class SyncFactory {
|
|||||||
/*
|
/*
|
||||||
* Dependent on application
|
* Dependent on application
|
||||||
*/
|
*/
|
||||||
String strRowsetProperties = System.getProperty("rowset.properties");
|
String strRowsetProperties;
|
||||||
|
try {
|
||||||
|
strRowsetProperties = AccessController.doPrivileged(new PrivilegedAction<String>() {
|
||||||
|
public String run() {
|
||||||
|
return System.getProperty("rowset.properties");
|
||||||
|
}
|
||||||
|
}, null, new PropertyPermission("rowset.properties","read"));
|
||||||
|
} catch (Exception ex) {
|
||||||
|
strRowsetProperties = null;
|
||||||
|
}
|
||||||
|
|
||||||
if (strRowsetProperties != null) {
|
if (strRowsetProperties != null) {
|
||||||
// Load user's implementation of SyncProvider
|
// Load user's implementation of SyncProvider
|
||||||
// here. -Drowset.properties=/abc/def/pqr.txt
|
// here. -Drowset.properties=/abc/def/pqr.txt
|
||||||
@ -393,7 +405,16 @@ public class SyncFactory {
|
|||||||
* load additional properties from -D command line
|
* load additional properties from -D command line
|
||||||
*/
|
*/
|
||||||
properties.clear();
|
properties.clear();
|
||||||
String providerImpls = System.getProperty(ROWSET_SYNC_PROVIDER);
|
String providerImpls;
|
||||||
|
try {
|
||||||
|
providerImpls = AccessController.doPrivileged(new PrivilegedAction<String>() {
|
||||||
|
public String run() {
|
||||||
|
return System.getProperty(ROWSET_SYNC_PROVIDER);
|
||||||
|
}
|
||||||
|
}, null, new PropertyPermission(ROWSET_SYNC_PROVIDER,"read"));
|
||||||
|
} catch (Exception ex) {
|
||||||
|
providerImpls = null;
|
||||||
|
}
|
||||||
|
|
||||||
if (providerImpls != null) {
|
if (providerImpls != null) {
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2006, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2006, 2013, 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,10 +43,8 @@ import sun.misc.Unsafe;
|
|||||||
* These are the only platforms we currently support, but other optimized
|
* These are the only platforms we currently support, but other optimized
|
||||||
* variants could be added as needed.
|
* variants could be added as needed.
|
||||||
*
|
*
|
||||||
* NOTE that because this code performs unchecked direct memory access, it
|
* NOTE that ArrayIndexOutOfBoundsException will be thrown if the bounds checks
|
||||||
* MUST be restricted to trusted code. It is imperative that the caller protects
|
* failed.
|
||||||
* against out of bounds memory access by performing the necessary bounds
|
|
||||||
* checks before calling methods in this class.
|
|
||||||
*
|
*
|
||||||
* This class may also be helpful in improving the performance of the
|
* This class may also be helpful in improving the performance of the
|
||||||
* crypto code in the SunJCE provider. However, for now it is only accessible by
|
* crypto code in the SunJCE provider. However, for now it is only accessible by
|
||||||
@ -103,6 +101,10 @@ final class ByteArrayAccess {
|
|||||||
* byte[] to int[] conversion, little endian byte order.
|
* byte[] to int[] conversion, little endian byte order.
|
||||||
*/
|
*/
|
||||||
static void b2iLittle(byte[] in, int inOfs, int[] out, int outOfs, int len) {
|
static void b2iLittle(byte[] in, int inOfs, int[] out, int outOfs, int len) {
|
||||||
|
if ((inOfs < 0) || ((in.length - inOfs) < len) ||
|
||||||
|
(outOfs < 0) || ((out.length - outOfs) < len/4)) {
|
||||||
|
throw new ArrayIndexOutOfBoundsException();
|
||||||
|
}
|
||||||
if (littleEndianUnaligned) {
|
if (littleEndianUnaligned) {
|
||||||
inOfs += byteArrayOfs;
|
inOfs += byteArrayOfs;
|
||||||
len += inOfs;
|
len += inOfs;
|
||||||
@ -131,6 +133,10 @@ final class ByteArrayAccess {
|
|||||||
|
|
||||||
// Special optimization of b2iLittle(in, inOfs, out, 0, 64)
|
// Special optimization of b2iLittle(in, inOfs, out, 0, 64)
|
||||||
static void b2iLittle64(byte[] in, int inOfs, int[] out) {
|
static void b2iLittle64(byte[] in, int inOfs, int[] out) {
|
||||||
|
if ((inOfs < 0) || ((in.length - inOfs) < 64) ||
|
||||||
|
(out.length < 16)) {
|
||||||
|
throw new ArrayIndexOutOfBoundsException();
|
||||||
|
}
|
||||||
if (littleEndianUnaligned) {
|
if (littleEndianUnaligned) {
|
||||||
inOfs += byteArrayOfs;
|
inOfs += byteArrayOfs;
|
||||||
out[ 0] = unsafe.getInt(in, (long)(inOfs ));
|
out[ 0] = unsafe.getInt(in, (long)(inOfs ));
|
||||||
@ -176,6 +182,10 @@ final class ByteArrayAccess {
|
|||||||
* int[] to byte[] conversion, little endian byte order.
|
* int[] to byte[] conversion, little endian byte order.
|
||||||
*/
|
*/
|
||||||
static void i2bLittle(int[] in, int inOfs, byte[] out, int outOfs, int len) {
|
static void i2bLittle(int[] in, int inOfs, byte[] out, int outOfs, int len) {
|
||||||
|
if ((inOfs < 0) || ((in.length - inOfs) < len/4) ||
|
||||||
|
(outOfs < 0) || ((out.length - outOfs) < len)) {
|
||||||
|
throw new ArrayIndexOutOfBoundsException();
|
||||||
|
}
|
||||||
if (littleEndianUnaligned) {
|
if (littleEndianUnaligned) {
|
||||||
outOfs += byteArrayOfs;
|
outOfs += byteArrayOfs;
|
||||||
len += outOfs;
|
len += outOfs;
|
||||||
@ -204,6 +214,9 @@ final class ByteArrayAccess {
|
|||||||
|
|
||||||
// Store one 32-bit value into out[outOfs..outOfs+3] in little endian order.
|
// Store one 32-bit value into out[outOfs..outOfs+3] in little endian order.
|
||||||
static void i2bLittle4(int val, byte[] out, int outOfs) {
|
static void i2bLittle4(int val, byte[] out, int outOfs) {
|
||||||
|
if ((outOfs < 0) || ((out.length - outOfs) < 4)) {
|
||||||
|
throw new ArrayIndexOutOfBoundsException();
|
||||||
|
}
|
||||||
if (littleEndianUnaligned) {
|
if (littleEndianUnaligned) {
|
||||||
unsafe.putInt(out, (long)(byteArrayOfs + outOfs), val);
|
unsafe.putInt(out, (long)(byteArrayOfs + outOfs), val);
|
||||||
} else if (bigEndian && ((outOfs & 3) == 0)) {
|
} else if (bigEndian && ((outOfs & 3) == 0)) {
|
||||||
@ -220,6 +233,10 @@ final class ByteArrayAccess {
|
|||||||
* byte[] to int[] conversion, big endian byte order.
|
* byte[] to int[] conversion, big endian byte order.
|
||||||
*/
|
*/
|
||||||
static void b2iBig(byte[] in, int inOfs, int[] out, int outOfs, int len) {
|
static void b2iBig(byte[] in, int inOfs, int[] out, int outOfs, int len) {
|
||||||
|
if ((inOfs < 0) || ((in.length - inOfs) < len) ||
|
||||||
|
(outOfs < 0) || ((out.length - outOfs) < len/4)) {
|
||||||
|
throw new ArrayIndexOutOfBoundsException();
|
||||||
|
}
|
||||||
if (littleEndianUnaligned) {
|
if (littleEndianUnaligned) {
|
||||||
inOfs += byteArrayOfs;
|
inOfs += byteArrayOfs;
|
||||||
len += inOfs;
|
len += inOfs;
|
||||||
@ -248,6 +265,10 @@ final class ByteArrayAccess {
|
|||||||
|
|
||||||
// Special optimization of b2iBig(in, inOfs, out, 0, 64)
|
// Special optimization of b2iBig(in, inOfs, out, 0, 64)
|
||||||
static void b2iBig64(byte[] in, int inOfs, int[] out) {
|
static void b2iBig64(byte[] in, int inOfs, int[] out) {
|
||||||
|
if ((inOfs < 0) || ((in.length - inOfs) < 64) ||
|
||||||
|
(out.length < 16)) {
|
||||||
|
throw new ArrayIndexOutOfBoundsException();
|
||||||
|
}
|
||||||
if (littleEndianUnaligned) {
|
if (littleEndianUnaligned) {
|
||||||
inOfs += byteArrayOfs;
|
inOfs += byteArrayOfs;
|
||||||
out[ 0] = reverseBytes(unsafe.getInt(in, (long)(inOfs )));
|
out[ 0] = reverseBytes(unsafe.getInt(in, (long)(inOfs )));
|
||||||
@ -293,6 +314,10 @@ final class ByteArrayAccess {
|
|||||||
* int[] to byte[] conversion, big endian byte order.
|
* int[] to byte[] conversion, big endian byte order.
|
||||||
*/
|
*/
|
||||||
static void i2bBig(int[] in, int inOfs, byte[] out, int outOfs, int len) {
|
static void i2bBig(int[] in, int inOfs, byte[] out, int outOfs, int len) {
|
||||||
|
if ((inOfs < 0) || ((in.length - inOfs) < len/4) ||
|
||||||
|
(outOfs < 0) || ((out.length - outOfs) < len)) {
|
||||||
|
throw new ArrayIndexOutOfBoundsException();
|
||||||
|
}
|
||||||
if (littleEndianUnaligned) {
|
if (littleEndianUnaligned) {
|
||||||
outOfs += byteArrayOfs;
|
outOfs += byteArrayOfs;
|
||||||
len += outOfs;
|
len += outOfs;
|
||||||
@ -321,6 +346,9 @@ final class ByteArrayAccess {
|
|||||||
|
|
||||||
// Store one 32-bit value into out[outOfs..outOfs+3] in big endian order.
|
// Store one 32-bit value into out[outOfs..outOfs+3] in big endian order.
|
||||||
static void i2bBig4(int val, byte[] out, int outOfs) {
|
static void i2bBig4(int val, byte[] out, int outOfs) {
|
||||||
|
if ((outOfs < 0) || ((out.length - outOfs) < 4)) {
|
||||||
|
throw new ArrayIndexOutOfBoundsException();
|
||||||
|
}
|
||||||
if (littleEndianUnaligned) {
|
if (littleEndianUnaligned) {
|
||||||
unsafe.putInt(out, (long)(byteArrayOfs + outOfs), reverseBytes(val));
|
unsafe.putInt(out, (long)(byteArrayOfs + outOfs), reverseBytes(val));
|
||||||
} else if (bigEndian && ((outOfs & 3) == 0)) {
|
} else if (bigEndian && ((outOfs & 3) == 0)) {
|
||||||
@ -337,6 +365,10 @@ final class ByteArrayAccess {
|
|||||||
* byte[] to long[] conversion, big endian byte order.
|
* byte[] to long[] conversion, big endian byte order.
|
||||||
*/
|
*/
|
||||||
static void b2lBig(byte[] in, int inOfs, long[] out, int outOfs, int len) {
|
static void b2lBig(byte[] in, int inOfs, long[] out, int outOfs, int len) {
|
||||||
|
if ((inOfs < 0) || ((in.length - inOfs) < len) ||
|
||||||
|
(outOfs < 0) || ((out.length - outOfs) < len/8)) {
|
||||||
|
throw new ArrayIndexOutOfBoundsException();
|
||||||
|
}
|
||||||
if (littleEndianUnaligned) {
|
if (littleEndianUnaligned) {
|
||||||
inOfs += byteArrayOfs;
|
inOfs += byteArrayOfs;
|
||||||
len += inOfs;
|
len += inOfs;
|
||||||
@ -378,6 +410,10 @@ final class ByteArrayAccess {
|
|||||||
|
|
||||||
// Special optimization of b2lBig(in, inOfs, out, 0, 128)
|
// Special optimization of b2lBig(in, inOfs, out, 0, 128)
|
||||||
static void b2lBig128(byte[] in, int inOfs, long[] out) {
|
static void b2lBig128(byte[] in, int inOfs, long[] out) {
|
||||||
|
if ((inOfs < 0) || ((in.length - inOfs) < 128) ||
|
||||||
|
(out.length < 16)) {
|
||||||
|
throw new ArrayIndexOutOfBoundsException();
|
||||||
|
}
|
||||||
if (littleEndianUnaligned) {
|
if (littleEndianUnaligned) {
|
||||||
inOfs += byteArrayOfs;
|
inOfs += byteArrayOfs;
|
||||||
out[ 0] = reverseBytes(unsafe.getLong(in, (long)(inOfs )));
|
out[ 0] = reverseBytes(unsafe.getLong(in, (long)(inOfs )));
|
||||||
@ -406,6 +442,10 @@ final class ByteArrayAccess {
|
|||||||
* long[] to byte[] conversion, big endian byte order.
|
* long[] to byte[] conversion, big endian byte order.
|
||||||
*/
|
*/
|
||||||
static void l2bBig(long[] in, int inOfs, byte[] out, int outOfs, int len) {
|
static void l2bBig(long[] in, int inOfs, byte[] out, int outOfs, int len) {
|
||||||
|
if ((inOfs < 0) || ((in.length - inOfs) < len/8) ||
|
||||||
|
(outOfs < 0) || ((out.length - outOfs) < len)) {
|
||||||
|
throw new ArrayIndexOutOfBoundsException();
|
||||||
|
}
|
||||||
len += outOfs;
|
len += outOfs;
|
||||||
while (outOfs < len) {
|
while (outOfs < len) {
|
||||||
long i = in[inOfs++];
|
long i = in[inOfs++];
|
||||||
@ -419,5 +459,4 @@ final class ByteArrayAccess {
|
|||||||
out[outOfs++] = (byte)(i );
|
out[outOfs++] = (byte)(i );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -182,6 +182,7 @@ package.access=sun.,\
|
|||||||
com.sun.istack.internal.,\
|
com.sun.istack.internal.,\
|
||||||
com.sun.jmx.,\
|
com.sun.jmx.,\
|
||||||
com.sun.media.sound.,\
|
com.sun.media.sound.,\
|
||||||
|
com.sun.naming.internal.,\
|
||||||
com.sun.proxy.,\
|
com.sun.proxy.,\
|
||||||
com.sun.org.apache.bcel.internal.,\
|
com.sun.org.apache.bcel.internal.,\
|
||||||
com.sun.org.apache.regexp.internal.,\
|
com.sun.org.apache.regexp.internal.,\
|
||||||
@ -227,6 +228,7 @@ package.definition=sun.,\
|
|||||||
com.sun.istack.internal.,\
|
com.sun.istack.internal.,\
|
||||||
com.sun.jmx.,\
|
com.sun.jmx.,\
|
||||||
com.sun.media.sound.,\
|
com.sun.media.sound.,\
|
||||||
|
com.sun.naming.internal.,\
|
||||||
com.sun.proxy.,\
|
com.sun.proxy.,\
|
||||||
com.sun.org.apache.bcel.internal.,\
|
com.sun.org.apache.bcel.internal.,\
|
||||||
com.sun.org.apache.regexp.internal.,\
|
com.sun.org.apache.regexp.internal.,\
|
||||||
|
@ -183,6 +183,7 @@ package.access=sun.,\
|
|||||||
com.sun.istack.internal.,\
|
com.sun.istack.internal.,\
|
||||||
com.sun.jmx.,\
|
com.sun.jmx.,\
|
||||||
com.sun.media.sound.,\
|
com.sun.media.sound.,\
|
||||||
|
com.sun.naming.internal.,\
|
||||||
com.sun.proxy.,\
|
com.sun.proxy.,\
|
||||||
com.sun.org.apache.bcel.internal.,\
|
com.sun.org.apache.bcel.internal.,\
|
||||||
com.sun.org.apache.regexp.internal.,\
|
com.sun.org.apache.regexp.internal.,\
|
||||||
@ -228,6 +229,7 @@ package.definition=sun.,\
|
|||||||
com.sun.istack.internal.,\
|
com.sun.istack.internal.,\
|
||||||
com.sun.jmx.,\
|
com.sun.jmx.,\
|
||||||
com.sun.media.sound.,\
|
com.sun.media.sound.,\
|
||||||
|
com.sun.naming.internal.,\
|
||||||
com.sun.proxy.,\
|
com.sun.proxy.,\
|
||||||
com.sun.org.apache.bcel.internal.,\
|
com.sun.org.apache.bcel.internal.,\
|
||||||
com.sun.org.apache.regexp.internal.,\
|
com.sun.org.apache.regexp.internal.,\
|
||||||
|
@ -184,6 +184,7 @@ package.access=sun.,\
|
|||||||
com.sun.istack.internal.,\
|
com.sun.istack.internal.,\
|
||||||
com.sun.jmx.,\
|
com.sun.jmx.,\
|
||||||
com.sun.media.sound.,\
|
com.sun.media.sound.,\
|
||||||
|
com.sun.naming.internal.,\
|
||||||
com.sun.proxy.,\
|
com.sun.proxy.,\
|
||||||
com.sun.org.apache.bcel.internal.,\
|
com.sun.org.apache.bcel.internal.,\
|
||||||
com.sun.org.apache.regexp.internal.,\
|
com.sun.org.apache.regexp.internal.,\
|
||||||
@ -228,6 +229,7 @@ package.definition=sun.,\
|
|||||||
com.sun.istack.internal.,\
|
com.sun.istack.internal.,\
|
||||||
com.sun.jmx.,\
|
com.sun.jmx.,\
|
||||||
com.sun.media.sound.,\
|
com.sun.media.sound.,\
|
||||||
|
com.sun.naming.internal.,\
|
||||||
com.sun.proxy.,\
|
com.sun.proxy.,\
|
||||||
com.sun.org.apache.bcel.internal.,\
|
com.sun.org.apache.bcel.internal.,\
|
||||||
com.sun.org.apache.regexp.internal.,\
|
com.sun.org.apache.regexp.internal.,\
|
||||||
|
@ -183,6 +183,7 @@ package.access=sun.,\
|
|||||||
com.sun.istack.internal.,\
|
com.sun.istack.internal.,\
|
||||||
com.sun.jmx.,\
|
com.sun.jmx.,\
|
||||||
com.sun.media.sound.,\
|
com.sun.media.sound.,\
|
||||||
|
com.sun.naming.internal.,\
|
||||||
com.sun.proxy.,\
|
com.sun.proxy.,\
|
||||||
com.sun.org.apache.bcel.internal.,\
|
com.sun.org.apache.bcel.internal.,\
|
||||||
com.sun.org.apache.regexp.internal.,\
|
com.sun.org.apache.regexp.internal.,\
|
||||||
@ -228,6 +229,7 @@ package.definition=sun.,\
|
|||||||
com.sun.istack.internal.,\
|
com.sun.istack.internal.,\
|
||||||
com.sun.jmx.,\
|
com.sun.jmx.,\
|
||||||
com.sun.media.sound.,\
|
com.sun.media.sound.,\
|
||||||
|
com.sun.naming.internal.,\
|
||||||
com.sun.proxy.,\
|
com.sun.proxy.,\
|
||||||
com.sun.org.apache.bcel.internal.,\
|
com.sun.org.apache.bcel.internal.,\
|
||||||
com.sun.org.apache.regexp.internal.,\
|
com.sun.org.apache.regexp.internal.,\
|
||||||
|
@ -215,6 +215,11 @@ void LinLerp1D(register const cmsUInt16Number Value[],
|
|||||||
Output[0] = LinearInterp(rest, y0, y1);
|
Output[0] = LinearInterp(rest, y0, y1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// To prevent out of bounds indexing
|
||||||
|
cmsINLINE cmsFloat32Number fclamp(cmsFloat32Number v)
|
||||||
|
{
|
||||||
|
return v < 0.0f ? 0.0f : (v > 1.0f ? 1.0f : v);
|
||||||
|
}
|
||||||
|
|
||||||
// Floating-point version of 1D interpolation
|
// Floating-point version of 1D interpolation
|
||||||
static
|
static
|
||||||
@ -227,13 +232,15 @@ void LinLerp1Dfloat(const cmsFloat32Number Value[],
|
|||||||
int cell0, cell1;
|
int cell0, cell1;
|
||||||
const cmsFloat32Number* LutTable = (cmsFloat32Number*) p ->Table;
|
const cmsFloat32Number* LutTable = (cmsFloat32Number*) p ->Table;
|
||||||
|
|
||||||
|
val2 = fclamp(Value[0]);
|
||||||
|
|
||||||
// if last value...
|
// if last value...
|
||||||
if (Value[0] == 1.0) {
|
if (val2 == 1.0) {
|
||||||
Output[0] = LutTable[p -> Domain[0]];
|
Output[0] = LutTable[p -> Domain[0]];
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
val2 = p -> Domain[0] * Value[0];
|
val2 *= p -> Domain[0];
|
||||||
|
|
||||||
cell0 = (int) floor(val2);
|
cell0 = (int) floor(val2);
|
||||||
cell1 = (int) ceil(val2);
|
cell1 = (int) ceil(val2);
|
||||||
@ -292,13 +299,15 @@ void Eval1InputFloat(const cmsFloat32Number Value[],
|
|||||||
cmsUInt32Number OutChan;
|
cmsUInt32Number OutChan;
|
||||||
const cmsFloat32Number* LutTable = (cmsFloat32Number*) p ->Table;
|
const cmsFloat32Number* LutTable = (cmsFloat32Number*) p ->Table;
|
||||||
|
|
||||||
|
val2 = fclamp(Value[0]);
|
||||||
|
|
||||||
// if last value...
|
// if last value...
|
||||||
if (Value[0] == 1.0) {
|
if (val2 == 1.0) {
|
||||||
Output[0] = LutTable[p -> Domain[0]];
|
Output[0] = LutTable[p -> Domain[0]];
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
val2 = p -> Domain[0] * Value[0];
|
val2 *= p -> Domain[0];
|
||||||
|
|
||||||
cell0 = (int) floor(val2);
|
cell0 = (int) floor(val2);
|
||||||
cell1 = (int) ceil(val2);
|
cell1 = (int) ceil(val2);
|
||||||
@ -339,8 +348,8 @@ void BilinearInterpFloat(const cmsFloat32Number Input[],
|
|||||||
dxy;
|
dxy;
|
||||||
|
|
||||||
TotalOut = p -> nOutputs;
|
TotalOut = p -> nOutputs;
|
||||||
px = Input[0] * p->Domain[0];
|
px = fclamp(Input[0]) * p->Domain[0];
|
||||||
py = Input[1] * p->Domain[1];
|
py = fclamp(Input[1]) * p->Domain[1];
|
||||||
|
|
||||||
x0 = (int) _cmsQuickFloor(px); fx = px - (cmsFloat32Number) x0;
|
x0 = (int) _cmsQuickFloor(px); fx = px - (cmsFloat32Number) x0;
|
||||||
y0 = (int) _cmsQuickFloor(py); fy = py - (cmsFloat32Number) y0;
|
y0 = (int) _cmsQuickFloor(py); fy = py - (cmsFloat32Number) y0;
|
||||||
@ -454,20 +463,9 @@ void TrilinearInterpFloat(const cmsFloat32Number Input[],
|
|||||||
TotalOut = p -> nOutputs;
|
TotalOut = p -> nOutputs;
|
||||||
|
|
||||||
// We need some clipping here
|
// We need some clipping here
|
||||||
px = Input[0];
|
px = fclamp(Input[0]) * p->Domain[0];
|
||||||
py = Input[1];
|
py = fclamp(Input[1]) * p->Domain[1];
|
||||||
pz = Input[2];
|
pz = fclamp(Input[2]) * p->Domain[2];
|
||||||
|
|
||||||
if (px < 0) px = 0;
|
|
||||||
if (px > 1) px = 1;
|
|
||||||
if (py < 0) py = 0;
|
|
||||||
if (py > 1) py = 1;
|
|
||||||
if (pz < 0) pz = 0;
|
|
||||||
if (pz > 1) pz = 1;
|
|
||||||
|
|
||||||
px *= p->Domain[0];
|
|
||||||
py *= p->Domain[1];
|
|
||||||
pz *= p->Domain[2];
|
|
||||||
|
|
||||||
x0 = (int) _cmsQuickFloor(px); fx = px - (cmsFloat32Number) x0;
|
x0 = (int) _cmsQuickFloor(px); fx = px - (cmsFloat32Number) x0;
|
||||||
y0 = (int) _cmsQuickFloor(py); fy = py - (cmsFloat32Number) y0;
|
y0 = (int) _cmsQuickFloor(py); fy = py - (cmsFloat32Number) y0;
|
||||||
@ -609,20 +607,9 @@ void TetrahedralInterpFloat(const cmsFloat32Number Input[],
|
|||||||
TotalOut = p -> nOutputs;
|
TotalOut = p -> nOutputs;
|
||||||
|
|
||||||
// We need some clipping here
|
// We need some clipping here
|
||||||
px = Input[0];
|
px = fclamp(Input[0]) * p->Domain[0];
|
||||||
py = Input[1];
|
py = fclamp(Input[1]) * p->Domain[1];
|
||||||
pz = Input[2];
|
pz = fclamp(Input[2]) * p->Domain[2];
|
||||||
|
|
||||||
if (px < 0) px = 0;
|
|
||||||
if (px > 1) px = 1;
|
|
||||||
if (py < 0) py = 0;
|
|
||||||
if (py > 1) py = 1;
|
|
||||||
if (pz < 0) pz = 0;
|
|
||||||
if (pz > 1) pz = 1;
|
|
||||||
|
|
||||||
px *= p->Domain[0];
|
|
||||||
py *= p->Domain[1];
|
|
||||||
pz *= p->Domain[2];
|
|
||||||
|
|
||||||
x0 = (int) _cmsQuickFloor(px); rx = (px - (cmsFloat32Number) x0);
|
x0 = (int) _cmsQuickFloor(px); rx = (px - (cmsFloat32Number) x0);
|
||||||
y0 = (int) _cmsQuickFloor(py); ry = (py - (cmsFloat32Number) y0);
|
y0 = (int) _cmsQuickFloor(py); ry = (py - (cmsFloat32Number) y0);
|
||||||
@ -1039,8 +1026,7 @@ void Eval4InputsFloat(const cmsFloat32Number Input[],
|
|||||||
cmsFloat32Number Tmp1[MAX_STAGE_CHANNELS], Tmp2[MAX_STAGE_CHANNELS];
|
cmsFloat32Number Tmp1[MAX_STAGE_CHANNELS], Tmp2[MAX_STAGE_CHANNELS];
|
||||||
cmsInterpParams p1;
|
cmsInterpParams p1;
|
||||||
|
|
||||||
|
pk = fclamp(Input[0]) * p->Domain[0];
|
||||||
pk = Input[0] * p->Domain[0];
|
|
||||||
k0 = _cmsQuickFloor(pk);
|
k0 = _cmsQuickFloor(pk);
|
||||||
rest = pk - (cmsFloat32Number) k0;
|
rest = pk - (cmsFloat32Number) k0;
|
||||||
|
|
||||||
@ -1127,7 +1113,7 @@ void Eval5InputsFloat(const cmsFloat32Number Input[],
|
|||||||
cmsFloat32Number Tmp1[MAX_STAGE_CHANNELS], Tmp2[MAX_STAGE_CHANNELS];
|
cmsFloat32Number Tmp1[MAX_STAGE_CHANNELS], Tmp2[MAX_STAGE_CHANNELS];
|
||||||
cmsInterpParams p1;
|
cmsInterpParams p1;
|
||||||
|
|
||||||
pk = Input[0] * p->Domain[0];
|
pk = fclamp(Input[0]) * p->Domain[0];
|
||||||
k0 = _cmsQuickFloor(pk);
|
k0 = _cmsQuickFloor(pk);
|
||||||
rest = pk - (cmsFloat32Number) k0;
|
rest = pk - (cmsFloat32Number) k0;
|
||||||
|
|
||||||
@ -1214,7 +1200,7 @@ void Eval6InputsFloat(const cmsFloat32Number Input[],
|
|||||||
cmsFloat32Number Tmp1[MAX_STAGE_CHANNELS], Tmp2[MAX_STAGE_CHANNELS];
|
cmsFloat32Number Tmp1[MAX_STAGE_CHANNELS], Tmp2[MAX_STAGE_CHANNELS];
|
||||||
cmsInterpParams p1;
|
cmsInterpParams p1;
|
||||||
|
|
||||||
pk = Input[0] * p->Domain[0];
|
pk = fclamp(Input[0]) * p->Domain[0];
|
||||||
k0 = _cmsQuickFloor(pk);
|
k0 = _cmsQuickFloor(pk);
|
||||||
rest = pk - (cmsFloat32Number) k0;
|
rest = pk - (cmsFloat32Number) k0;
|
||||||
|
|
||||||
@ -1299,7 +1285,7 @@ void Eval7InputsFloat(const cmsFloat32Number Input[],
|
|||||||
cmsFloat32Number Tmp1[MAX_STAGE_CHANNELS], Tmp2[MAX_STAGE_CHANNELS];
|
cmsFloat32Number Tmp1[MAX_STAGE_CHANNELS], Tmp2[MAX_STAGE_CHANNELS];
|
||||||
cmsInterpParams p1;
|
cmsInterpParams p1;
|
||||||
|
|
||||||
pk = Input[0] * p->Domain[0];
|
pk = fclamp(Input[0]) * p->Domain[0];
|
||||||
k0 = _cmsQuickFloor(pk);
|
k0 = _cmsQuickFloor(pk);
|
||||||
rest = pk - (cmsFloat32Number) k0;
|
rest = pk - (cmsFloat32Number) k0;
|
||||||
|
|
||||||
@ -1384,7 +1370,7 @@ void Eval8InputsFloat(const cmsFloat32Number Input[],
|
|||||||
cmsFloat32Number Tmp1[MAX_STAGE_CHANNELS], Tmp2[MAX_STAGE_CHANNELS];
|
cmsFloat32Number Tmp1[MAX_STAGE_CHANNELS], Tmp2[MAX_STAGE_CHANNELS];
|
||||||
cmsInterpParams p1;
|
cmsInterpParams p1;
|
||||||
|
|
||||||
pk = Input[0] * p->Domain[0];
|
pk = fclamp(Input[0]) * p->Domain[0];
|
||||||
k0 = _cmsQuickFloor(pk);
|
k0 = _cmsQuickFloor(pk);
|
||||||
rest = pk - (cmsFloat32Number) k0;
|
rest = pk - (cmsFloat32Number) k0;
|
||||||
|
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* @test
|
* @test
|
||||||
* @bug 6741606 7146431 8000450 8019830
|
* @bug 6741606 7146431 8000450 8019830 8022945
|
||||||
* @summary Make sure all restricted packages listed in the package.access
|
* @summary Make sure all restricted packages listed in the package.access
|
||||||
* property in the java.security file are blocked
|
* property in the java.security file are blocked
|
||||||
* @run main/othervm CheckPackageAccess
|
* @run main/othervm CheckPackageAccess
|
||||||
@ -55,6 +55,7 @@ public class CheckPackageAccess {
|
|||||||
"com.sun.istack.internal.",
|
"com.sun.istack.internal.",
|
||||||
"com.sun.jmx.",
|
"com.sun.jmx.",
|
||||||
"com.sun.media.sound.",
|
"com.sun.media.sound.",
|
||||||
|
"com.sun.naming.internal.",
|
||||||
"com.sun.proxy.",
|
"com.sun.proxy.",
|
||||||
"com.sun.org.apache.bcel.internal.",
|
"com.sun.org.apache.bcel.internal.",
|
||||||
"com.sun.org.apache.regexp.internal.",
|
"com.sun.org.apache.regexp.internal.",
|
||||||
|
Loading…
Reference in New Issue
Block a user