diff --git a/.hgtags-top-repo b/.hgtags-top-repo index 27eb593b749..783312526e8 100644 --- a/.hgtags-top-repo +++ b/.hgtags-top-repo @@ -368,3 +368,4 @@ cae471d3b87783e0a3deea658e1e1c84b2485b6c jdk-9+121 405d811c0d7b9b48ff718ae6c240b732f098c028 jdk-9+123 f80c841ae2545eaf9acd2724bccc305d98cefbe2 jdk-9+124 9aa7d40f3a453f51e47f4c1b19eff5740a74a9f8 jdk-9+125 +3a58466296d36944454756ef01e7513ac5e14a16 jdk-9+126 diff --git a/common/autoconf/generated-configure.sh b/common/autoconf/generated-configure.sh index 2c98c488849..e8b5461b512 100644 --- a/common/autoconf/generated-configure.sh +++ b/common/autoconf/generated-configure.sh @@ -976,7 +976,6 @@ JVM_VARIANTS DEBUG_LEVEL HOTSPOT_DEBUG_LEVEL JDK_VARIANT -SET_OPENJDK USERNAME CANONICAL_TOPDIR ORIGINAL_TOPDIR @@ -5095,7 +5094,7 @@ VS_SDK_PLATFORM_NAME_2013= #CUSTOM_AUTOCONF_INCLUDE # Do not change or remove the following line, it is needed for consistency checks: -DATE_WHEN_GENERATED=1467223237 +DATE_WHEN_GENERATED=1467960715 ############################################################################### # @@ -16592,41 +16591,17 @@ else fi - { $as_echo "$as_me:${as_lineno-$LINENO}: checking for presence of closed sources" >&5 -$as_echo_n "checking for presence of closed sources... " >&6; } - if test -d "$SRC_ROOT/jdk/src/closed"; then - CLOSED_SOURCE_PRESENT=yes + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if custom source is suppressed (openjdk-only)" >&5 +$as_echo_n "checking if custom source is suppressed (openjdk-only)... " >&6; } + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_openjdk_only" >&5 +$as_echo "$enable_openjdk_only" >&6; } + if test "x$enable_openjdk_only" = "xyes"; then + SUPPRESS_CUSTOM_EXTENSIONS="true" + elif test "x$enable_openjdk_only" = "xno"; then + SUPPRESS_CUSTOM_EXTENSIONS="false" else - CLOSED_SOURCE_PRESENT=no + as_fn_error $? "Invalid value for --enable-openjdk-only: $enable_openjdk_only" "$LINENO" 5 fi - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CLOSED_SOURCE_PRESENT" >&5 -$as_echo "$CLOSED_SOURCE_PRESENT" >&6; } - - { $as_echo "$as_me:${as_lineno-$LINENO}: checking if closed source is suppressed (openjdk-only)" >&5 -$as_echo_n "checking if closed source is suppressed (openjdk-only)... " >&6; } - SUPPRESS_CLOSED_SOURCE="$enable_openjdk_only" - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $SUPPRESS_CLOSED_SOURCE" >&5 -$as_echo "$SUPPRESS_CLOSED_SOURCE" >&6; } - - if test "x$CLOSED_SOURCE_PRESENT" = xno; then - OPENJDK=true - if test "x$SUPPRESS_CLOSED_SOURCE" = "xyes"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: No closed source present, --enable-openjdk-only makes no sense" >&5 -$as_echo "$as_me: WARNING: No closed source present, --enable-openjdk-only makes no sense" >&2;} - fi - else - if test "x$SUPPRESS_CLOSED_SOURCE" = "xyes"; then - OPENJDK=true - else - OPENJDK=false - fi - fi - - if test "x$OPENJDK" = "xtrue"; then - SET_OPENJDK="OPENJDK=true" - fi - - # custom-make-dir is deprecated. Please use your custom-hook.m4 to override # the IncludeCustomExtension macro. @@ -53313,11 +53288,7 @@ $as_echo "yes, forced" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: result: no, forced" >&5 $as_echo "no, forced" >&6; } elif test "x$enable_dtrace" = "xauto" || test "x$enable_dtrace" = "x"; then - if test "x$OPENJDK_TARGET_OS" = "xlinux" && test "x$OPENJDK" != "xtrue"; then - INCLUDE_DTRACE=false - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no, non-open linux build" >&5 -$as_echo "no, non-open linux build" >&6; } - elif test "x$DTRACE_DEP_MISSING" = "xtrue"; then + if test "x$DTRACE_DEP_MISSING" = "xtrue"; then INCLUDE_DTRACE=false { $as_echo "$as_me:${as_lineno-$LINENO}: result: no, missing dependencies" >&5 $as_echo "no, missing dependencies" >&6; } @@ -53596,11 +53567,9 @@ $as_echo "yes" >&6; } NEEDS_LIB_CUPS=true fi - # Check if freetype is needed - if test "x$OPENJDK" = "xtrue"; then + # A custom hook may have set this already + if test "x$NEEDS_LIB_FREETYPE" = "x"; then NEEDS_LIB_FREETYPE=true - else - NEEDS_LIB_FREETYPE=false fi # Check if alsa is needed diff --git a/common/autoconf/hotspot.m4 b/common/autoconf/hotspot.m4 index 3886ea86f65..306e2db5502 100644 --- a/common/autoconf/hotspot.m4 +++ b/common/autoconf/hotspot.m4 @@ -161,10 +161,7 @@ AC_DEFUN_ONCE([HOTSPOT_SETUP_DTRACE], INCLUDE_DTRACE=false AC_MSG_RESULT([no, forced]) elif test "x$enable_dtrace" = "xauto" || test "x$enable_dtrace" = "x"; then - if test "x$OPENJDK_TARGET_OS" = "xlinux" && test "x$OPENJDK" != "xtrue"; then - INCLUDE_DTRACE=false - AC_MSG_RESULT([no, non-open linux build]) - elif test "x$DTRACE_DEP_MISSING" = "xtrue"; then + if test "x$DTRACE_DEP_MISSING" = "xtrue"; then INCLUDE_DTRACE=false AC_MSG_RESULT([no, missing dependencies]) else diff --git a/common/autoconf/jdk-options.m4 b/common/autoconf/jdk-options.m4 index 71e442ae4b4..d6aa389f3ae 100644 --- a/common/autoconf/jdk-options.m4 +++ b/common/autoconf/jdk-options.m4 @@ -117,36 +117,15 @@ AC_DEFUN_ONCE([JDKOPT_SETUP_OPEN_OR_CUSTOM], AC_ARG_ENABLE([openjdk-only], [AS_HELP_STRING([--enable-openjdk-only], [suppress building custom source even if present @<:@disabled@:>@])],,[enable_openjdk_only="no"]) - AC_MSG_CHECKING([for presence of closed sources]) - if test -d "$SRC_ROOT/jdk/src/closed"; then - CLOSED_SOURCE_PRESENT=yes + AC_MSG_CHECKING([if custom source is suppressed (openjdk-only)]) + AC_MSG_RESULT([$enable_openjdk_only]) + if test "x$enable_openjdk_only" = "xyes"; then + SUPPRESS_CUSTOM_EXTENSIONS="true" + elif test "x$enable_openjdk_only" = "xno"; then + SUPPRESS_CUSTOM_EXTENSIONS="false" else - CLOSED_SOURCE_PRESENT=no + AC_MSG_ERROR([Invalid value for --enable-openjdk-only: $enable_openjdk_only]) fi - AC_MSG_RESULT([$CLOSED_SOURCE_PRESENT]) - - AC_MSG_CHECKING([if closed source is suppressed (openjdk-only)]) - SUPPRESS_CLOSED_SOURCE="$enable_openjdk_only" - AC_MSG_RESULT([$SUPPRESS_CLOSED_SOURCE]) - - if test "x$CLOSED_SOURCE_PRESENT" = xno; then - OPENJDK=true - if test "x$SUPPRESS_CLOSED_SOURCE" = "xyes"; then - AC_MSG_WARN([No closed source present, --enable-openjdk-only makes no sense]) - fi - else - if test "x$SUPPRESS_CLOSED_SOURCE" = "xyes"; then - OPENJDK=true - else - OPENJDK=false - fi - fi - - if test "x$OPENJDK" = "xtrue"; then - SET_OPENJDK="OPENJDK=true" - fi - - AC_SUBST(SET_OPENJDK) # custom-make-dir is deprecated. Please use your custom-hook.m4 to override # the IncludeCustomExtension macro. diff --git a/common/autoconf/libraries.m4 b/common/autoconf/libraries.m4 index 88412842bde..1e408ef022b 100644 --- a/common/autoconf/libraries.m4 +++ b/common/autoconf/libraries.m4 @@ -59,11 +59,9 @@ AC_DEFUN_ONCE([LIB_DETERMINE_DEPENDENCIES], NEEDS_LIB_CUPS=true fi - # Check if freetype is needed - if test "x$OPENJDK" = "xtrue"; then + # A custom hook may have set this already + if test "x$NEEDS_LIB_FREETYPE" = "x"; then NEEDS_LIB_FREETYPE=true - else - NEEDS_LIB_FREETYPE=false fi # Check if alsa is needed diff --git a/common/autoconf/spec.gmk.in b/common/autoconf/spec.gmk.in index 8ddc28f53aa..26705337a95 100644 --- a/common/autoconf/spec.gmk.in +++ b/common/autoconf/spec.gmk.in @@ -108,7 +108,6 @@ OPENJDK_BUILD_CPU_ENDIAN:=@OPENJDK_BUILD_CPU_ENDIAN@ REQUIRED_OS_NAME:=@REQUIRED_OS_NAME@ REQUIRED_OS_VERSION:=@REQUIRED_OS_VERSION@ -@SET_OPENJDK@ LIBM:=@LIBM@ LIBDL:=@LIBDL@ diff --git a/common/nb_native/nbproject/configurations.xml b/common/nb_native/nbproject/configurations.xml index 983e6bf47ec..8b23549b276 100644 --- a/common/nb_native/nbproject/configurations.xml +++ b/common/nb_native/nbproject/configurations.xml @@ -1,41 +1,59 @@ - + - + - - - - - - ad_x86_64.cpp - ad_x86_64_clone.cpp - ad_x86_64_expand.cpp - ad_x86_64_format.cpp - ad_x86_64_gen.cpp - ad_x86_64_misc.cpp - ad_x86_64_peephole.cpp - ad_x86_64_pipeline.cpp - dfa_x86_64.cpp - - - bytecodeInterpreterWithChecks.cpp - jvmtiEnter.cpp - jvmtiEnterTrace.cpp - + + + + + ad_x86_64.cpp + ad_x86_64_clone.cpp + ad_x86_64_expand.cpp + ad_x86_64_format.cpp + ad_x86_64_gen.cpp + ad_x86_64_misc.cpp + ad_x86_64_peephole.cpp + ad_x86_64_pipeline.cpp + dfa_x86_64.cpp + + + bytecodeInterpreterWithChecks.cpp + jvmtiEnter.cpp + jvmtiEnterTrace.cpp - - - sizer.64.c + + + + ad_x86_64.cpp + ad_x86_64_clone.cpp + ad_x86_64_expand.cpp + ad_x86_64_format.cpp + ad_x86_64_gen.cpp + ad_x86_64_misc.cpp + ad_x86_64_peephole.cpp + ad_x86_64_pipeline.cpp + dfa_x86_64.cpp + + + bytecodeInterpreterWithChecks.cpp + jvmtiEnter.cpp + jvmtiEnterTrace.cpp + + + + + JvmOffsets.cpp + - - + + ad_x86_64.cpp ad_x86_64_clone.cpp @@ -55,77 +73,24 @@ - - - sizer.64.c - - - - - - - - ad_x86_64.cpp - ad_x86_64_clone.cpp - ad_x86_64_expand.cpp - ad_x86_64_format.cpp - ad_x86_64_gen.cpp - ad_x86_64_misc.cpp - ad_x86_64_peephole.cpp - ad_x86_64_pipeline.cpp - dfa_x86_64.cpp - - - bytecodeInterpreterWithChecks.cpp - jvmtiEnter.cpp - jvmtiEnterTrace.cpp - + + + + + sizer.64.c - - JvmOffsets.cpp - - - - - - sizer.64.c - - - - - LinuxDebuggerLocal.c - libproc_impl.c - ps_core.c - ps_proc.c - salibelf.c - symtab.c - - - - saproc.cpp - - - - - - sadis.c - - - - + abstractInterpreter_x86.cpp assembler_x86.cpp - bytecodeInterpreter_x86.cpp - bytecodes_x86.cpp c1_CodeStubs_x86.cpp c1_FpuStackSim_x86.cpp c1_FrameMap_x86.cpp @@ -135,42 +100,92 @@ c1_MacroAssembler_x86.cpp c1_Runtime1_x86.cpp c2_init_x86.cpp - cppInterpreter_x86.cpp + compiledIC_x86.cpp debug_x86.cpp depChecker_x86.cpp frame_x86.cpp icBuffer_x86.cpp icache_x86.cpp - interp_masm_x86_64.cpp + interp_masm_x86.cpp interpreterRT_x86_64.cpp - interpreter_x86_64.cpp jniFastGetField_x86_64.cpp + jvmciCodeInstaller_x86.cpp + macroAssembler_libm_x86_64.cpp macroAssembler_x86.cpp + macroAssembler_x86_cos.cpp + macroAssembler_x86_exp.cpp + macroAssembler_x86_log.cpp + macroAssembler_x86_log10.cpp + macroAssembler_x86_pow.cpp + macroAssembler_x86_sha.cpp + macroAssembler_x86_sin.cpp + macroAssembler_x86_tan.cpp metaspaceShared_x86_64.cpp methodHandles_x86.cpp nativeInst_x86.cpp + registerMap_x86.cpp register_definitions_x86.cpp register_x86.cpp relocInfo_x86.cpp runtime_x86_64.cpp + sharedRuntime_x86.cpp sharedRuntime_x86_64.cpp stubGenerator_x86_64.cpp + stubRoutines_x86.cpp stubRoutines_x86_64.cpp - templateInterpreter_x86_64.cpp - templateTable_x86_64.cpp + templateInterpreterGenerator_x86.cpp + templateInterpreterGenerator_x86_64.cpp + templateTable_x86.cpp vm_version_x86.cpp vmreg_x86.cpp vtableStubs_x86_64.cpp + + + + + LinuxDebuggerLocal.c + libproc_impl.c + ps_core.c + ps_proc.c + salibelf.c + symtab.c + + + + + + + MacosxDebuggerLocal.m + libproc_impl.c + ps_core.c + symtab.c + + + + + + + sadis.c + + + + + + + saproc.cpp + + + + attachListener_bsd.cpp - chaitin_bsd.cpp decoder_machO.cpp - dtraceJSDT_bsd.cpp + jsig.c jvm_bsd.cpp mutex_bsd.cpp osThread_bsd.cpp @@ -178,15 +193,12 @@ perfMemory_bsd.cpp stubRoutines_bsd.cpp threadCritical_bsd.cpp - vmError_bsd.cpp attachListener_linux.cpp - chaitin_linux.cpp decoder_linux.cpp - dtraceJSDT_linux.cpp jsig.c jvm_linux.cpp mutex_linux.cpp @@ -195,35 +207,25 @@ perfMemory_linux.cpp stubRoutines_linux.cpp threadCritical_linux.cpp - vmError_linux.cpp - - java_md.c - os_posix.cpp + threadLocalStorage_posix.cpp + vmError_posix.cpp - - add_gnu_debuglink.c - generateJvmOffsets.cpp generateJvmOffsetsMain.c jvm_dtrace.c libjvm_db.c - - fix_empty_sec_hdr_flags.c - attachListener_solaris.cpp - chaitin_solaris.cpp decoder_solaris.cpp - dtraceJSDT_solaris.cpp jsig.c jvm_solaris.cpp mutex_solaris.cpp @@ -232,7 +234,6 @@ perfMemory_solaris.cpp stubRoutines_solaris.cpp threadCritical_solaris.cpp - vmError_solaris.cpp @@ -241,7 +242,6 @@ assembler_bsd_x86.cpp os_bsd_x86.cpp - threadLS_bsd_x86.cpp thread_bsd_x86.cpp vm_version_bsd_x86.cpp @@ -250,7 +250,6 @@ assembler_linux_x86.cpp os_linux_x86.cpp - threadLS_linux_x86.cpp thread_linux_x86.cpp vm_version_linux_x86.cpp @@ -259,20 +258,12 @@ assembler_solaris_x86.cpp os_solaris_x86.cpp - threadLS_solaris_x86.cpp thread_solaris_x86.cpp vm_version_solaris_x86.cpp - - - java.c - jli_util.c - wildcard.c - - adlparse.cpp @@ -359,19 +350,28 @@ classFileError.cpp classFileParser.cpp classFileStream.cpp + classListParser.cpp classLoader.cpp classLoaderData.cpp + classLoaderExt.cpp + classLoaderStats.cpp + compactHashtable.cpp defaultMethods.cpp dictionary.cpp - genericSignatures.cpp javaAssertions.cpp javaClasses.cpp + klassFactory.cpp loaderConstraints.cpp metadataOnStackMark.cpp + moduleEntry.cpp + modules.cpp + packageEntry.cpp placeholders.cpp resolutionErrors.cpp + sharedPathsMiscInfo.cpp stackMapFrame.cpp stackMapTable.cpp + stringTable.cpp symbolTable.cpp systemDictionary.cpp verificationType.cpp @@ -382,10 +382,12 @@ codeBlob.cpp codeCache.cpp compiledIC.cpp + compiledMethod.cpp compressedStream.cpp debugInfo.cpp debugInfoRec.cpp dependencies.cpp + dependencyContext.cpp exceptionHandlerTable.cpp icBuffer.cpp location.cpp @@ -402,65 +404,121 @@ abstractCompiler.cpp compileBroker.cpp compileLog.cpp + compileTask.cpp + compilerDirectives.cpp compilerOracle.cpp + directivesParser.cpp disassembler.cpp methodLiveness.cpp + methodMatcher.cpp oopMap.cpp - - + + adaptiveFreeList.cpp - cmsAdaptiveSizePolicy.cpp + allocationStats.cpp cmsCollectorPolicy.cpp - cmsGCAdaptivePolicyCounters.cpp cmsLockVerifier.cpp + cmsOopClosures.cpp compactibleFreeListSpace.cpp concurrentMarkSweepGeneration.cpp concurrentMarkSweepThread.cpp freeChunk.cpp + gSpaceCounters.cpp + parCardTableModRefBS.cpp + parNewGeneration.cpp + parOopClosures.cpp promotionInfo.cpp vmCMSOperations.cpp + yieldingWorkgroup.cpp + bufferingOopClosure.cpp collectionSetChooser.cpp concurrentG1Refine.cpp concurrentG1RefineThread.cpp - concurrentMark.cpp concurrentMarkThread.cpp dirtyCardQueue.cpp g1AllocRegion.cpp + g1Allocator.cpp + g1Allocator_ext.cpp + g1Analytics.cpp + g1BiasedArray.cpp g1BlockOffsetTable.cpp + g1CardCounts.cpp + g1CardLiveData.cpp + g1CodeBlobClosure.cpp + g1CodeCacheRemSet.cpp g1CollectedHeap.cpp + g1CollectedHeap_ext.cpp + g1CollectionSet.cpp g1CollectorPolicy.cpp - g1ErgoVerbose.cpp + g1ConcurrentMark.cpp + g1DefaultPolicy.cpp + g1EvacFailure.cpp + g1EvacStats.cpp + g1FromCardCache.cpp g1GCPhaseTimes.cpp - g1HRPrinter.cpp - g1Log.cpp + g1HeapSizingPolicy.cpp + g1HeapSizingPolicy_ext.cpp + g1HeapTransition.cpp + g1HeapVerifier.cpp + g1HotCardCache.cpp + g1IHOPControl.cpp g1MMUTracker.cpp g1MarkSweep.cpp + g1MarkSweep_ext.cpp g1MonitoringSupport.cpp + g1OopClosures.cpp + g1PageBasedVirtualSpace.cpp + g1ParScanThreadState.cpp + g1ParScanThreadState_ext.cpp + g1Predictions.cpp + g1RegionToSpaceMapper.cpp g1RemSet.cpp + g1RemSetSummary.cpp + g1RootClosures.cpp + g1RootClosures_ext.cpp + g1RootProcessor.cpp g1SATBCardTableModRefBS.cpp + g1StringDedup.cpp + g1StringDedupQueue.cpp + g1StringDedupStat.cpp + g1StringDedupTable.cpp + g1StringDedupThread.cpp + g1SurvivorRegions.cpp + g1YoungGenSizer.cpp + g1YoungRemSetSamplingThread.cpp g1_globals.cpp + hSpaceCounters.cpp heapRegion.cpp + heapRegionManager.cpp heapRegionRemSet.cpp - heapRegionSeq.cpp heapRegionSet.cpp - heapRegionSets.cpp + heapRegionTracer.cpp + heapRegionType.cpp ptrQueue.cpp - satbQueue.cpp + satbMarkQueue.cpp sparsePRT.cpp survRateGroup.cpp + suspendibleThreadSet.cpp vm_operations_g1.cpp + workerDataArray.cpp + youngList.cpp - + adjoiningGenerations.cpp adjoiningVirtualSpaces.cpp asPSOldGen.cpp asPSYoungGen.cpp cardTableExtension.cpp + gcAdaptivePolicyCounters.cpp gcTaskManager.cpp gcTaskThread.cpp + generationSizer.cpp + immutableSpace.cpp + mutableNUMASpace.cpp + mutableSpace.cpp objectStartArray.cpp parMarkBitMap.cpp parallelScavengeHeap.cpp @@ -479,42 +537,64 @@ psTasks.cpp psVirtualspace.cpp psYoungGen.cpp + spaceCounters.cpp vmPSOperations.cpp - - asParNewGeneration.cpp - parCardTableModRefBS.cpp - parNewGeneration.cpp + + cSpaceCounters.cpp + defNewGeneration.cpp + genMarkSweep.cpp + markSweep.cpp + tenuredGeneration.cpp adaptiveSizePolicy.cpp ageTable.cpp - allocationStats.cpp - cSpaceCounters.cpp + ageTableTracer.cpp + allocTracer.cpp + barrierSet.cpp + blockOffsetTable.cpp + cardGeneration.cpp + cardTableModRefBS.cpp + cardTableModRefBSForCTRS.cpp + cardTableRS.cpp + collectedHeap.cpp collectorCounters.cpp + collectorPolicy.cpp concurrentGCThread.cpp - gSpaceCounters.cpp - gcAdaptivePolicyCounters.cpp + gcCause.cpp + gcId.cpp + gcLocker.cpp gcPolicyCounters.cpp gcStats.cpp + gcTimer.cpp + gcTrace.cpp + gcTraceSend.cpp + gcTraceTime.cpp gcUtil.cpp + genCollectedHeap.cpp + genOopClosures.cpp + generation.cpp generationCounters.cpp - hSpaceCounters.cpp - immutableSpace.cpp - markSweep.cpp - mutableNUMASpace.cpp - mutableSpace.cpp - parGCAllocBuffer.cpp - spaceCounters.cpp + generationSpec.cpp + memset_with_concurrent_readers.cpp + objectCountEventSender.cpp + plab.cpp + preservedMarks.cpp + referencePendingListLocker.cpp + referencePolicy.cpp + referenceProcessor.cpp + space.cpp spaceDecorator.cpp + strongRootsScope.cpp + taskqueue.cpp + threadLocalAllocBuffer.cpp vmGCOperations.cpp + workgroup.cpp - - collectedHeap.cpp - gcCause.cpp - + abstractInterpreter.cpp bytecode.cpp bytecodeHistogram.cpp bytecodeInterpreter.cpp @@ -522,6 +602,7 @@ bytecodeTracer.cpp bytecodes.cpp cppInterpreter.cpp + cppInterpreterGenerator.cpp interpreter.cpp interpreterRuntime.cpp invocationCounter.cpp @@ -529,51 +610,65 @@ oopMapCache.cpp rewriter.cpp templateInterpreter.cpp + templateInterpreterGenerator.cpp templateTable.cpp + + commandLineFlagConstraintsJVMCI.cpp + jvmciCodeInstaller.cpp + jvmciCompiler.cpp + jvmciCompilerToVM.cpp + jvmciEnv.cpp + jvmciJavaClasses.cpp + jvmciRuntime.cpp + jvmci_globals.cpp + vmStructs_jvmci.cpp + dict.cpp - port.cpp set.cpp vectset.cpp + + log.cpp + logConfiguration.cpp + logDecorations.cpp + logDecorators.cpp + logDiagnosticCommand.cpp + logFileOutput.cpp + logFileStreamOutput.cpp + logLevel.cpp + logMessageBuffer.cpp + logOutput.cpp + logOutputList.cpp + logStream.cpp + logTag.cpp + logTagLevelExpression.cpp + logTagSet.cpp + logTagSetDescriptions.cpp + allocation.cpp - barrierSet.cpp binaryTreeDictionary.cpp - blockOffsetTable.cpp - cardTableModRefBS.cpp - cardTableRS.cpp - collectorPolicy.cpp - defNewGeneration.cpp filemap.cpp freeBlockDictionary.cpp freeList.cpp - gcLocker.cpp - genCollectedHeap.cpp - genMarkSweep.cpp - genRemSet.cpp - generation.cpp - generationSpec.cpp + guardedMemory.cpp heap.cpp heapInspection.cpp iterator.cpp memRegion.cpp - metablock.cpp metachunk.cpp metaspace.cpp metaspaceCounters.cpp metaspaceShared.cpp + metaspaceTracer.cpp oopFactory.cpp - referencePolicy.cpp - referenceProcessor.cpp + operator_new.cpp resourceArea.cpp - sharedHeap.cpp - space.cpp - specialized_oop_closures.cpp - tenuredGeneration.cpp - threadLocalAllocBuffer.cpp universe.cpp + universe_ext.cpp + virtualspace.cpp annotations.cpp @@ -584,7 +679,6 @@ constantPool.cpp cpCache.cpp generateOopMap.cpp - instanceClassLoaderKlass.cpp instanceKlass.cpp instanceMirrorKlass.cpp instanceOop.cpp @@ -594,6 +688,7 @@ markOop.cpp metadata.cpp method.cpp + methodCounters.cpp methodData.cpp objArrayKlass.cpp objArrayOop.cpp @@ -601,10 +696,10 @@ oopsHierarchy.cpp symbol.cpp typeArrayKlass.cpp - typeArrayOop.cpp addnode.cpp + arraycopynode.cpp block.cpp buildOopMap.cpp bytecodeInfo.cpp @@ -612,12 +707,15 @@ c2compiler.cpp callGenerator.cpp callnode.cpp + castnode.cpp cfgnode.cpp chaitin.cpp classes.cpp coalesce.cpp compile.cpp connode.cpp + convertnode.cpp + countbitsnode.cpp divnode.cpp doCall.cpp domgraph.cpp @@ -630,6 +728,7 @@ ifg.cpp ifnode.cpp indexSet.cpp + intrinsicnode.cpp lcm.cpp library_call.cpp live.cpp @@ -641,11 +740,16 @@ loopopts.cpp machnode.cpp macro.cpp + macroArrayCopy.cpp matcher.cpp + mathexactnode.cpp memnode.cpp + movenode.cpp mulnode.cpp multnode.cpp + narrowptrnode.cpp node.cpp + opaquenode.cpp opcodes.cpp output.cpp parse1.cpp @@ -658,6 +762,7 @@ reg_split.cpp regalloc.cpp regmask.cpp + replacednodes.cpp rootnode.cpp runtime.cpp split_if.cpp @@ -667,9 +772,6 @@ type.cpp vectornode.cpp - - precompiled.hpp - parserTests.cpp @@ -702,19 +804,25 @@ nativeLookup.cpp perf.cpp privilegedStack.cpp + stackwalk.cpp unsafe.cpp whitebox.cpp + whitebox_ext.cpp advancedThresholdPolicy.cpp - aprofiler.cpp arguments.cpp atomic.cpp basicLock.cpp biasedLocking.cpp + commandLineFlagConstraintList.cpp + commandLineFlagConstraintsCompiler.cpp + commandLineFlagConstraintsGC.cpp + commandLineFlagConstraintsRuntime.cpp + commandLineFlagRangeList.cpp + commandLineFlagWriteableList.cpp compilationPolicy.cpp deoptimization.cpp - dtraceJSDT.cpp fieldDescriptor.cpp fieldType.cpp fprofiler.cpp @@ -743,7 +851,9 @@ reflectionUtils.cpp relocator.cpp rframe.cpp + rtmLocking.cpp safepoint.cpp + semaphore.cpp serviceThread.cpp sharedRuntime.cpp sharedRuntimeTrans.cpp @@ -759,13 +869,13 @@ synchronizer.cpp task.cpp thread.cpp - threadLocalStorage.cpp + thread_ext.cpp timer.cpp + timerTrace.cpp unhandledOops.cpp vframe.cpp vframeArray.cpp vframe_hp.cpp - virtualspace.cpp vmStructs.cpp vmThread.cpp vm_operations.cpp @@ -782,32 +892,38 @@ gcNotifier.cpp heapDumper.cpp lowMemoryDetector.cpp + mallocSiteTable.cpp + mallocTracker.cpp management.cpp memBaseline.cpp - memPtr.cpp - memRecorder.cpp memReporter.cpp - memSnapshot.cpp - memTrackWorker.cpp memTracker.cpp memoryManager.cpp memoryPool.cpp memoryService.cpp + nmtCommon.cpp nmtDCmd.cpp psMemoryPool.cpp runtimeService.cpp threadService.cpp + virtualMemoryTracker.cpp + writeableFlags.cpp + + + traceBackend.cpp accessFlags.cpp array.cpp bitMap.cpp + chunkedList.cpp constantTag.cpp copy.cpp debug.cpp decoder.cpp decoder_elf.cpp elfFile.cpp + elfFuncDescTable.cpp elfStringTable.cpp elfSymbolTable.cpp errorReporter.cpp @@ -818,84 +934,56 @@ hashtable.cpp histogram.cpp intHisto.cpp + internalVMTests.cpp + json.cpp + linkedlist.cpp + nativeCallStack.cpp numberSeq.cpp ostream.cpp preserveException.cpp quickSort.cpp + resourceHash.cpp sizes.cpp - taskqueue.cpp + stringUtils.cpp + ticks.cpp utf8.cpp vmError.cpp - workgroup.cpp xmlstream.cpp - yieldingWorkgroup.cpp + + + + test_os.cpp + + + test_quicksort.cpp + + gtestLauncher.cpp + gtestMain.cpp + + - - - add_gnu_debuglink.c - - - fix_empty_sec_hdr_flags.c + + + + + genSocketOptionRegistry.c + + + genUnixConstants.c + + - - - ArrayReferenceImpl.c - ArrayTypeImpl.c - ClassLoaderReferenceImpl.c - ClassObjectReferenceImpl.c - ClassTypeImpl.c - EventRequestImpl.c - FieldImpl.c - FrameID.c - MethodImpl.c - ObjectReferenceImpl.c - ReferenceTypeImpl.c - SDE.c - StackFrameImpl.c - StringReferenceImpl.c - ThreadGroupReferenceImpl.c - ThreadReferenceImpl.c - VirtualMachineImpl.c - bag.c - classTrack.c - commonRef.c - debugDispatch.c - debugInit.c - debugLoop.c - error_messages.c - eventFilter.c - eventHandler.c - eventHelper.c - inStream.c - invoker.c - log_messages.c - outStream.c - standardHandlers.c - stepControl.c - stream.c - threadControl.c - transport.c - util.c - - - java.c - jli_util.c - main.c - parse_manifest.c - splashscreen_stubs.c - version_comp.c - wildcard.c - - + + agent_util.c @@ -912,33 +1000,6 @@ heapViewer.c - - debug_malloc.c - hprof_blocks.c - hprof_check.c - hprof_class.c - hprof_cpu.c - hprof_error.c - hprof_event.c - hprof_frame.c - hprof_init.c - hprof_io.c - hprof_ioname.c - hprof_listener.c - hprof_loader.c - hprof_monitor.c - hprof_object.c - hprof_reference.c - hprof_site.c - hprof_stack.c - hprof_string.c - hprof_table.c - hprof_tag.c - hprof_tls.c - hprof_trace.c - hprof_tracker.c - hprof_util.c - java_crw_demo.c @@ -959,287 +1020,848 @@ - - EncodingSupport.c - InstrumentationImplNativeMethods.c - InvocationAdapter.c - JPLISAgent.c - JPLISAssert.c - JarFacade.c - JavaExceptions.c - PathCharsValidator.c - Reentrancy.c - Utilities.c + + + + Poller.c + + - - - - - - - - bands.cpp - bytes.cpp - coding.cpp - jni.cpp - main.cpp - unpack.cpp - utils.cpp - zip.cpp - - - + + + + + + ProcessHandleImpl_linux.c + + + linux_close.c + + + + EPoll.c + EPollArrayWrapper.c + EPollPort.c - - - DirectAudioDevice.c - DirectAudioDeviceProvider.c - MidiInDevice.c - MidiInDeviceProvider.c - MidiOutDevice.c - MidiOutDeviceProvider.c - Platform.c - PlatformMidi.c - PortMixer.c - PortMixerProvider.c - Utilities.c - + + LinuxNativeDispatcher.c + LinuxWatchService.c + MagicFileTypeDetector.c - - check_code.c - check_format.c - check_version.c - jdk_util.c - jio.c - jni_util.c - verify_stub.c + + + + + HostLocaleProviderAdapter_md.c + ProcessHandleImpl_macosx.c + java_props_macosx.c + + + java_md_macosx.c + + + bsd_close.c + + + + KQueue.c + KQueueArrayWrapper.c + KQueuePort.c + + + BsdNativeDispatcher.c + MacOSXNativeDispatcher.c + UTIFileTypeDetector.c + + + + KeystoreImpl.m + - - + + + + + main.c + + + e_acos.c + e_asin.c + e_atan2.c + e_atanh.c + e_cosh.c + e_exp.c + e_fmod.c + e_log.c + e_log10.c + e_rem_pio2.c + e_remainder.c + e_scalb.c + e_sinh.c + e_sqrt.c + k_cos.c + k_rem_pio2.c + k_sin.c + k_standard.c + k_tan.c + s_atan.c + s_ceil.c + s_copysign.c + s_cos.c + s_expm1.c + s_fabs.c + s_finite.c + s_floor.c + s_frexp.c + s_ilogb.c + s_isnan.c + s_ldexp.c + s_lib_version.c + s_log1p.c + s_logb.c + s_matherr.c + s_modf.c + s_nextafter.c + s_rint.c + s_scalbn.c + s_signgam.c + s_significand.c + s_sin.c + s_tan.c + s_tanh.c + w_acos.c + w_asin.c + w_atan2.c + w_atanh.c + w_cosh.c + w_exp.c + w_fmod.c + w_log.c + w_log10.c + w_remainder.c + w_scalb.c + w_sinh.c + w_sqrt.c + + + AccessController.c + Array.c + AtomicLong.c + BootLoader.c + Class.c + ClassLoader.c + ConstantPool.c + Double.c + Executable.c + Field.c FileInputStream.c + Float.c + GC.c + Module.c + NativeAccessors.c + Object.c ObjectInputStream.c ObjectOutputStream.c ObjectStreamClass.c - RandomAccessFile.c - io_util.c - - - - - e_acos.c - e_asin.c - e_atan2.c - e_atanh.c - e_cosh.c - e_exp.c - e_fmod.c - e_hypot.c - e_log.c - e_log10.c - e_pow.c - e_rem_pio2.c - e_remainder.c - e_scalb.c - e_sinh.c - e_sqrt.c - k_cos.c - k_rem_pio2.c - k_sin.c - k_standard.c - k_tan.c - s_atan.c - s_cbrt.c - s_ceil.c - s_copysign.c - s_cos.c - s_expm1.c - s_fabs.c - s_finite.c - s_floor.c - s_frexp.c - s_ilogb.c - s_isnan.c - s_ldexp.c - s_lib_version.c - s_log1p.c - s_logb.c - s_matherr.c - s_modf.c - s_nextafter.c - s_rint.c - s_scalbn.c - s_signgam.c - s_significand.c - s_sin.c - s_tan.c - s_tanh.c - w_acos.c - w_asin.c - w_atan2.c - w_atanh.c - w_cosh.c - w_exp.c - w_fmod.c - w_hypot.c - w_log.c - w_log10.c - w_pow.c - w_remainder.c - w_scalb.c - w_sinh.c - w_sqrt.c - - - - Finalizer.c - - - Array.c - Executable.c - Proxy.c - - Class.c - ClassLoader.c - Compiler.c - Double.c - Float.c - Object.c Package.c - ResourceBundle.c + Proxy.c + RandomAccessFile.c + Reflection.c Runtime.c SecurityManager.c Shutdown.c + Signal.c + StackFrameInfo.c + StackStreamFactory.c StrictMath.c String.c + StringCoding.c System.c Thread.c Throwable.c + TimeZone.c + VM.c + VMSupport.c + Version.c + check_version.c + io_util.c + jdk_util.c + jio.c + jni_util.c + verify_stub.c - + + ImageNativeSubstrate.cpp + NativeImageBuffer.cpp + endian.cpp + imageDecompressor.cpp + imageFile.cpp + jimage.cpp + + + args.c + java.c + jli_util.c + parse_manifest.c + splashscreen_stubs.c + wildcard.c + + DatagramPacket.c Inet4Address.c Inet6Address.c InetAddress.c net_util.c - - Bits.c + + nio_util.c - - AccessController.c + + check_code.c + check_format.c - - - - AtomicLong.c - + + + compress.c + deflate.c + gzclose.c + gzlib.c + gzread.c + gzwrite.c + infback.c + inffast.c + inflate.c + inftrees.c + trees.c + uncompr.c + zadler32.c + zcrc32.c + zutil.c - - - compress.c - deflate.c - gzclose.c - gzlib.c - gzread.c - gzwrite.c - infback.c - inffast.c - inflate.c - inftrees.c - trees.c - uncompr.c - zadler32.c - zcrc32.c - zutil.c - - Adler32.c - CRC32.c - Deflater.c - Inflater.c - ZipFile.c - zip_util.c - - TimeZone.c + Adler32.c + CRC32.c + Deflater.c + Inflater.c + zip_util.c - - - - debug_assert.c - debug_mem.c - debug_trace.c - debug_util.c + + + + + ProcessHandleImpl_solaris.c + + + solaris_close.c + + + + DevPollArrayWrapper.c + SolarisEventPort.c + + SolarisNativeDispatcher.c + SolarisWatchService.c + + + + + + + + jspawnhelper.c + + + jexec.c + + + Console_md.c + FileDescriptor_md.c + FileInputStream_md.c + FileOutputStream_md.c + ProcessEnvironment_md.c + ProcessHandleImpl_unix.c + ProcessImpl_md.c + RandomAccessFile_md.c + TimeZone_md.c + UnixFileSystem_md.c + VM_md.c + canonicalize_md.c + childproc.c + io_util_md.c + java_props_md.c + jdk_util_md.c + jni_util_md.c + + + osSupport_unix.cpp + + + ergo.c + ergo_i586.c + java_md_common.c + java_md_solinux.c + + + DefaultProxySelector.c + ExtendedOptionsImpl.c + Inet4AddressImpl.c + Inet6AddressImpl.c + InetAddressImplFactory.c + NetworkInterface.c + PlainDatagramSocketImpl.c + PlainSocketImpl.c + ResolverConfigurationImpl.c + SdpSupport.c + SocketImpl.c + SocketInputStream.c + SocketOutputStream.c + net_util_md.c + portconfig.c + + + + DatagramChannelImpl.c + DatagramDispatcher.c + FileChannelImpl.c + FileDispatcherImpl.c + FileKey.c + IOUtil.c + InheritedChannel.c + NativeThread.c + Net.c + PollArrayWrapper.c + ServerSocketChannelImpl.c + SocketChannelImpl.c + SocketDispatcher.c + UnixAsynchronousServerSocketChannelImpl.c + UnixAsynchronousSocketChannelImpl.c + + + GioFileTypeDetector.c + UnixCopyFile.c + UnixNativeDispatcher.c + + MappedByteBuffer.c + + + + + + + + + + AWTEvent.m + AWTSurfaceLayers.m + AWTView.m + AWTWindow.m + ApplicationDelegate.m + CClipboard.m + CCursorManager.m + CDataTransferer.m + CDesktopPeer.m + CDragSource.m + CDragSourceContextPeer.m + CDropTarget.m + CDropTargetContextPeer.m + CFRetainedResource.m + CFileDialog.m + CGraphicsConfig.m + CGraphicsDevice.m + CGraphicsEnv.m + CImage.m + CInputMethod.m + CMenu.m + CMenuBar.m + CMenuComponent.m + CMenuItem.m + CPopupMenu.m + CPrinterJob.m + CRobot.m + CRobotKeyCode.m + CSystemColors.m + CTextPipe.m + CTrayIcon.m + CWrapper.m + DnDUtilities.m + GeomUtilities.m + ImageSurfaceData.m + InitIDs.m + JavaAccessibilityAction.m + JavaAccessibilityUtilities.m + JavaComponentAccessibility.m + JavaTextAccessibility.m + LWCToolkit.m + OSVersion.m + PrintModel.m + PrinterSurfaceData.m + PrinterView.m + QuartzRenderer.m + QuartzSurfaceData.m + awt_DrawingSurface.m + + + AWTFont.m + AWTStrike.m + CCharToGlyphMapper.m + CGGlyphImages.m + CGGlyphOutlines.m + CoreTextSupport.m + + + + CGLGraphicsConfig.m + CGLLayer.m + CGLSurfaceData.m + + + + + jawt.m + + + PLATFORM_API_MacOSX_MidiIn.c + PLATFORM_API_MacOSX_MidiOut.c + PLATFORM_API_MacOSX_MidiUtils.c + PLATFORM_API_MacOSX_PCM.cpp + PLATFORM_API_MacOSX_Ports.cpp + PLATFORM_API_MacOSX_Utils.cpp + + + CFileManager.m + + + AWT_debug.m + NSApplicationAWT.m + PropertiesUtilities.m + QueuingApplicationDelegate.m + ThreadUtilities.m + + + AquaFileView.m + AquaLookAndFeel.m + AquaNativeResources.m + JRSUIConstantSync.m + JRSUIController.m + JRSUIFocus.m + ScreenMenu.m + + + splashscreen_sys.m + + + + + + + + + debug_assert.c + debug_mem.c + debug_trace.c + debug_util.c + + + mlib_ImageCopy_Bit.c + mlib_ImageCreate.c + mlib_sys.c + + + rect.c + + + + AccelGlyphCache.c + + + + OGLBlitLoops.c + OGLBufImgOps.c + OGLContext.c + OGLFuncs.c + OGLMaskBlit.c + OGLMaskFill.c + OGLPaints.c + OGLRenderQueue.c + OGLRenderer.c + OGLSurfaceData.c + OGLTextRenderer.c + OGLVertexCache.c + + + + + + + + img_colors.c + img_globals.c + + + gifdecoder.c + + BufImgSurfaceData.c + DataBufferNative.c + awt_ImageRep.c + awt_parseImage.c + dither.c + imageInitIDs.c + + + awt_ImagingLib.c + + + + + AlphaMacros.c + AlphaMath.c + Any3Byte.c + Any4Byte.c + AnyByte.c + AnyInt.c + AnyShort.c + Blit.c + BlitBg.c + ByteBinary1Bit.c + ByteBinary2Bit.c + ByteBinary4Bit.c + ByteGray.c + ByteIndexed.c + DrawLine.c + DrawParallelogram.c + DrawPath.c + DrawPolygons.c + DrawRect.c + FillParallelogram.c + FillPath.c + FillRect.c + FillSpans.c + FourByteAbgr.c + FourByteAbgrPre.c + GraphicsPrimitiveMgr.c + Index12Gray.c + Index8Gray.c + IntArgb.c + IntArgbBm.c + IntArgbPre.c + IntBgr.c + IntRgb.c + IntRgbx.c + MapAccelFunc.c + MaskBlit.c + MaskFill.c + ProcessPath.c + ScaledBlit.c + ThreeByteBgr.c + TransformHelper.c + Ushort4444Argb.c + Ushort555Rgb.c + Ushort555Rgbx.c + Ushort565Rgb.c + UshortGray.c + UshortIndexed.c + + + BufferedMaskBlit.c + BufferedRenderPipe.c + Region.c + ShapeSpanIterator.c + SpanClipRenderer.c + + Disposer.c + SurfaceData.c + Trace.c + + + + + + ucdn.c + + hb-blob.cc + hb-buffer-serialize.cc + hb-buffer.cc + hb-common.cc + hb-coretext.cc + hb-face.cc + hb-fallback-shape.cc + hb-font.cc + hb-ot-font.cc + hb-ot-layout.cc + hb-ot-map.cc + hb-ot-shape-complex-arabic.cc + hb-ot-shape-complex-default.cc + hb-ot-shape-complex-hangul.cc + hb-ot-shape-complex-hebrew.cc + hb-ot-shape-complex-indic-table.cc + hb-ot-shape-complex-indic.cc + hb-ot-shape-complex-myanmar.cc + hb-ot-shape-complex-thai.cc + hb-ot-shape-complex-tibetan.cc + hb-ot-shape-complex-use-table.cc + hb-ot-shape-complex-use.cc + hb-ot-shape-fallback.cc + hb-ot-shape-normalize.cc + hb-ot-shape.cc + hb-ot-tag.cc + hb-set.cc + hb-shape-plan.cc + hb-shape.cc + hb-shaper.cc + hb-ucdn.cc + hb-unicode.cc + hb-warning.cc + + + AlternateSubstSubtables.cpp + AnchorTables.cpp + ArabicLayoutEngine.cpp + ArabicShaping.cpp + CanonData.cpp + CanonShaping.cpp + ClassDefinitionTables.cpp + ContextualGlyphInsertionProc2.cpp + ContextualGlyphSubstProc.cpp + ContextualGlyphSubstProc2.cpp + ContextualSubstSubtables.cpp + CoverageTables.cpp + CursiveAttachmentSubtables.cpp + DeviceTables.cpp + ExtensionSubtables.cpp + Features.cpp + GDEFMarkFilter.cpp + GXLayoutEngine.cpp + GXLayoutEngine2.cpp + GlyphDefinitionTables.cpp + GlyphIterator.cpp + GlyphLookupTables.cpp + GlyphPositionAdjustments.cpp + GlyphPositioningTables.cpp + GlyphPosnLookupProc.cpp + GlyphSubstLookupProc.cpp + GlyphSubstitutionTables.cpp + HanLayoutEngine.cpp + HangulLayoutEngine.cpp + IndicClassTables.cpp + IndicLayoutEngine.cpp + IndicRearrangementProcessor.cpp + IndicRearrangementProcessor2.cpp + IndicReordering.cpp + KernTable.cpp + KhmerLayoutEngine.cpp + KhmerReordering.cpp + LEFontInstance.cpp + LEGlyphStorage.cpp + LEInsertionList.cpp + LayoutEngine.cpp + LigatureSubstProc.cpp + LigatureSubstProc2.cpp + LigatureSubstSubtables.cpp + LookupProcessor.cpp + LookupTables.cpp + Lookups.cpp + MPreFixups.cpp + MarkArrays.cpp + MarkToBasePosnSubtables.cpp + MarkToLigaturePosnSubtables.cpp + MarkToMarkPosnSubtables.cpp + MirroredCharData.cpp + MorphTables.cpp + MorphTables2.cpp + MultipleSubstSubtables.cpp + NonContextualGlyphSubstProc.cpp + NonContextualGlyphSubstProc2.cpp + OpenTypeLayoutEngine.cpp + OpenTypeUtilities.cpp + PairPositioningSubtables.cpp + ScriptAndLanguage.cpp + ScriptAndLanguageTags.cpp + SegmentArrayProcessor.cpp + SegmentArrayProcessor2.cpp + SegmentSingleProcessor.cpp + SegmentSingleProcessor2.cpp + ShapingTypeData.cpp + SimpleArrayProcessor.cpp + SimpleArrayProcessor2.cpp + SinglePositioningSubtables.cpp + SingleSubstitutionSubtables.cpp + SingleTableProcessor.cpp + SingleTableProcessor2.cpp + StateTableProcessor.cpp + StateTableProcessor2.cpp + SubstitutionLookups.cpp + SubtableProcessor.cpp + SubtableProcessor2.cpp + SunLayoutEngine.cpp + ThaiLayoutEngine.cpp + ThaiShaping.cpp + ThaiStateTables.cpp + TibetanLayoutEngine.cpp + TibetanReordering.cpp + TrimmedArrayProcessor.cpp + TrimmedArrayProcessor2.cpp + ValueRecords.cpp + + DrawGlyphList.c + FontInstanceAdapter.cpp + HBShaper.c + freetypeScaler.c + hb-jdk-font.cc + scriptMapping.c + sunFont.c + + + imageioJPEG.c + jcapimin.c + jcapistd.c + jccoefct.c + jccolor.c + jcdctmgr.c + jchuff.c + jcinit.c + jcmainct.c + jcmarker.c + jcmaster.c + jcomapi.c + jcparam.c + jcphuff.c + jcprepct.c + jcsample.c + jctrans.c + jdapimin.c + jdapistd.c + jdcoefct.c + jdcolor.c + jddctmgr.c + jdhuff.c + jdinput.c + jdmainct.c + jdmarker.c + jdmaster.c + jdmerge.c + jdphuff.c + jdpostct.c + jdsample.c + jdtrans.c + jerror.c + jfdctflt.c + jfdctfst.c + jfdctint.c + jidctflt.c + jidctfst.c + jidctint.c + jidctred.c + jmemmgr.c + jmemnobs.c + jpegdecoder.c + jquant1.c + jquant2.c + jutils.c + + + DirectAudioDevice.c + DirectAudioDeviceProvider.c + MidiInDevice.c + MidiInDeviceProvider.c + MidiOutDevice.c + MidiOutDeviceProvider.c + Platform.c + PlatformMidi.c + PortMixer.c + PortMixerProvider.c + Utilities.c + + + LCMS.c + cmscam02.c + cmscgats.c + cmscnvrt.c + cmserr.c + cmsgamma.c + cmsgmt.c + cmshalf.c + cmsintrp.c + cmsio0.c + cmsio1.c + cmslut.c + cmsmd5.c + cmsmtrx.c + cmsnamed.c + cmsopt.c + cmspack.c + cmspcs.c + cmsplugin.c + cmsps2.c + cmssamp.c + cmssm.c + cmstypes.c + cmsvirt.c + cmswtpnt.c + cmsxform.c + + + mlib_ImageAffine.c + mlib_ImageAffineEdge.c + mlib_ImageAffine_BC_D64.c + mlib_ImageAffine_BC_F32.c + mlib_ImageAffine_BC_S32.c + mlib_ImageAffine_BL_D64.c + mlib_ImageAffine_BL_F32.c + mlib_ImageAffine_BL_S32.c + mlib_ImageAffine_NN.c + mlib_ImageAffine_NN_Bit.c + mlib_ImageClipping.c + mlib_ImageColorTrue2Index.c + mlib_ImageConv2x2_f.c + mlib_ImageConvClearEdge_Bit.c + mlib_ImageConvClearEdge_Fp.c + mlib_ImageConvCopyEdge_Bit.c + mlib_ImageConvKernelConvert.c + mlib_ImageConvMxN.c + mlib_ImageConvMxN_Fp.c + mlib_ImageConvMxN_ext.c + mlib_ImageConv_16ext.c + mlib_ImageConv_16nw.c + mlib_ImageConv_32nw.c + mlib_ImageConv_8ext.c + mlib_ImageConv_8nw.c + mlib_ImageConv_D64nw.c + mlib_ImageConv_F32nw.c + mlib_ImageConv_u16ext.c + mlib_ImageConv_u16nw.c + mlib_ImageDivTables.c + mlib_ImageFilters.c + mlib_ImageLookUp_64.c + mlib_ImageLookUp_Bit.c + mlib_ImageScanPoly.c + mlib_ImageUtils.c + mlib_c_ImageAffineIndex_BC.c + mlib_c_ImageAffineIndex_BL.c + mlib_c_ImageAffine_BC.c + mlib_c_ImageAffine_BC_S16.c + mlib_c_ImageAffine_BC_U16.c + mlib_c_ImageAffine_BL.c + mlib_c_ImageAffine_BL_S16.c + mlib_c_ImageAffine_BL_U16.c + mlib_c_ImageAffine_NN.c + mlib_c_ImageConvClearEdge.c + mlib_c_ImageConvCopyEdge.c + mlib_c_ImageConvVersion.c + mlib_c_ImageConv_f.c + mlib_c_ImageCopy.c + mlib_c_ImageLookUp.c + mlib_c_ImageLookUp_f.c + mlib_c_ImageThresh1_U8.c + + dgif_lib.c gif_err.c gifalloc.c - - - img_colors.c - img_globals.c - - - gifdecoder.c - - - imageioJPEG.c - jcapimin.c - jcapistd.c - jccoefct.c - jccolor.c - jcdctmgr.c - jchuff.c - jcinit.c - jcmainct.c - jcmarker.c - jcmaster.c - jcomapi.c - jcparam.c - jcphuff.c - jcprepct.c - jcsample.c - jctrans.c - jdapimin.c - jdapistd.c - jdcoefct.c - jdcolor.c - jddctmgr.c - jdhuff.c - jdinput.c - jdmainct.c - jdmarker.c - jdmaster.c - jdmerge.c - jdphuff.c - jdpostct.c - jdsample.c - jdtrans.c - jerror.c - jfdctflt.c - jfdctfst.c - jfdctint.c - jidctflt.c - jidctfst.c - jidctint.c - jidctred.c - jmemmgr.c - jmemnobs.c - jpegdecoder.c - jquant1.c - jquant2.c - jutils.c - - BufImgSurfaceData.c - DataBufferNative.c - awt_ImageRep.c - awt_parseImage.c - dither.c - imageInitIDs.c - png.c pngerror.c @@ -1257,270 +1879,148 @@ pngwtran.c pngwutil.c - - awt_ImagingLib.c - mlib_ImageAffine.c - mlib_ImageAffineEdge.c - mlib_ImageAffine_BC_D64.c - mlib_ImageAffine_BC_F32.c - mlib_ImageAffine_BC_S32.c - mlib_ImageAffine_BL_D64.c - mlib_ImageAffine_BL_F32.c - mlib_ImageAffine_BL_S32.c - mlib_ImageAffine_NN.c - mlib_ImageAffine_NN_Bit.c - mlib_ImageClipping.c - mlib_ImageColorTrue2Index.c - mlib_ImageConv2x2_f.c - mlib_ImageConvClearEdge_Bit.c - mlib_ImageConvClearEdge_Fp.c - mlib_ImageConvCopyEdge_Bit.c - mlib_ImageConvKernelConvert.c - mlib_ImageConvMxN.c - mlib_ImageConvMxN_Fp.c - mlib_ImageConvMxN_ext.c - mlib_ImageConv_16ext.c - mlib_ImageConv_16nw.c - mlib_ImageConv_32nw.c - mlib_ImageConv_8ext.c - mlib_ImageConv_8nw.c - mlib_ImageConv_D64nw.c - mlib_ImageConv_F32nw.c - mlib_ImageConv_u16ext.c - mlib_ImageConv_u16nw.c - mlib_ImageCopy_Bit.c - mlib_ImageCreate.c - mlib_ImageDivTables.c - mlib_ImageFilters.c - mlib_ImageLookUp_64.c - mlib_ImageLookUp_Bit.c - mlib_ImageScanPoly.c - mlib_ImageUtils.c - mlib_c_ImageAffineIndex_BC.c - mlib_c_ImageAffineIndex_BL.c - mlib_c_ImageAffine_BC.c - mlib_c_ImageAffine_BC_S16.c - mlib_c_ImageAffine_BC_U16.c - mlib_c_ImageAffine_BL.c - mlib_c_ImageAffine_BL_S16.c - mlib_c_ImageAffine_BL_U16.c - mlib_c_ImageAffine_NN.c - mlib_c_ImageConvClearEdge.c - mlib_c_ImageConvCopyEdge.c - mlib_c_ImageConvVersion.c - mlib_c_ImageConv_f.c - mlib_c_ImageCopy.c - mlib_c_ImageLookUp.c - mlib_c_ImageLookUp_f.c - mlib_c_ImageThresh1_U8.c - mlib_sys.c - - - java_awt_SplashScreen.c - splashscreen_gfx_impl.c - splashscreen_gif.c - splashscreen_impl.c - splashscreen_jpeg.c - splashscreen_png.c - - - rect.c - + java_awt_SplashScreen.c + splashscreen_gfx_impl.c + splashscreen_gif.c + splashscreen_impl.c + splashscreen_jpeg.c + splashscreen_png.c - - - AlternateSubstSubtables.cpp - AnchorTables.cpp - ArabicLayoutEngine.cpp - ArabicShaping.cpp - CanonData.cpp - CanonShaping.cpp - ClassDefinitionTables.cpp - ContextualGlyphSubstProc.cpp - ContextualSubstSubtables.cpp - CoverageTables.cpp - CursiveAttachmentSubtables.cpp - DeviceTables.cpp - ExtensionSubtables.cpp - Features.cpp - GDEFMarkFilter.cpp - GXLayoutEngine.cpp - GlyphDefinitionTables.cpp - GlyphIterator.cpp - GlyphLookupTables.cpp - GlyphPositionAdjustments.cpp - GlyphPositioningTables.cpp - GlyphPosnLookupProc.cpp - GlyphSubstLookupProc.cpp - GlyphSubstitutionTables.cpp - HanLayoutEngine.cpp - HangulLayoutEngine.cpp - IndicClassTables.cpp - IndicLayoutEngine.cpp - IndicRearrangementProcessor.cpp - IndicReordering.cpp - KernTable.cpp - KhmerLayoutEngine.cpp - KhmerReordering.cpp - LEFontInstance.cpp - LEGlyphStorage.cpp - LEInsertionList.cpp - LayoutEngine.cpp - LigatureSubstProc.cpp - LigatureSubstSubtables.cpp - LookupProcessor.cpp - LookupTables.cpp - Lookups.cpp - MPreFixups.cpp - MarkArrays.cpp - MarkToBasePosnSubtables.cpp - MarkToLigaturePosnSubtables.cpp - MarkToMarkPosnSubtables.cpp - MirroredCharData.cpp - MorphTables.cpp - MultipleSubstSubtables.cpp - NonContextualGlyphSubstProc.cpp - OpenTypeLayoutEngine.cpp - OpenTypeUtilities.cpp - PairPositioningSubtables.cpp - ScriptAndLanguage.cpp - ScriptAndLanguageTags.cpp - SegmentArrayProcessor.cpp - SegmentSingleProcessor.cpp - ShapingTypeData.cpp - SimpleArrayProcessor.cpp - SinglePositioningSubtables.cpp - SingleSubstitutionSubtables.cpp - SingleTableProcessor.cpp - StateTableProcessor.cpp - SubstitutionLookups.cpp - SubtableProcessor.cpp - SunLayoutEngine.cpp - ThaiLayoutEngine.cpp - ThaiShaping.cpp - ThaiStateTables.cpp - TibetanLayoutEngine.cpp - TibetanReordering.cpp - TrimmedArrayProcessor.cpp - ValueRecords.cpp + + + + + + + + systemScale.c + + CUPSfuncs.c + X11Color.c + awt_Font.c + fontpath.c - AccelGlyphCache.c - DrawGlyphList.c - FontInstanceAdapter.cpp - freetypeScaler.c - sunFont.c - - - - - LCMS.c - cmscam02.c - cmscgats.c - cmscnvrt.c - cmserr.c - cmsgamma.c - cmsgmt.c - cmshalf.c - cmsintrp.c - cmsio0.c - cmsio1.c - cmslut.c - cmsmd5.c - cmsmtrx.c - cmsnamed.c - cmsopt.c - cmspack.c - cmspcs.c - cmsplugin.c - cmsps2.c - cmssamp.c - cmssm.c - cmstypes.c - cmsvirt.c - cmswtpnt.c - cmsxform.c + + + GLXGraphicsConfig.c + GLXSurfaceData.c + + + X11FontScaler_md.c + X11PMBlitLoops.c + X11Renderer.c + X11SurfaceData.c + X11TextRenderer_md.c - - AlphaMacros.c - AlphaMath.c - Any3Byte.c - Any4Byte.c - AnyByte.c - AnyInt.c - AnyShort.c - Blit.c - BlitBg.c - ByteBinary1Bit.c - ByteBinary2Bit.c - ByteBinary4Bit.c - ByteGray.c - ByteIndexed.c - DrawLine.c - DrawParallelogram.c - DrawPath.c - DrawPolygons.c - DrawRect.c - FillParallelogram.c - FillPath.c - FillRect.c - FillSpans.c - FourByteAbgr.c - FourByteAbgrPre.c - GraphicsPrimitiveMgr.c - Index12Gray.c - Index8Gray.c - IntArgb.c - IntArgbBm.c - IntArgbPre.c - IntBgr.c - IntRgb.c - IntRgbx.c - MapAccelFunc.c - MaskBlit.c - MaskFill.c - ProcessPath.c - ScaledBlit.c - ThreeByteBgr.c - TransformHelper.c - Ushort4444Argb.c - Ushort555Rgb.c - Ushort555Rgbx.c - Ushort565Rgb.c - UshortGray.c - UshortIndexed.c - - - OGLBlitLoops.c - OGLBufImgOps.c - OGLContext.c - OGLFuncs.c - OGLMaskBlit.c - OGLMaskFill.c - OGLPaints.c - OGLRenderQueue.c - OGLRenderer.c - OGLSurfaceData.c - OGLTextRenderer.c - OGLVertexCache.c - - - BufferedMaskBlit.c - BufferedRenderPipe.c - Region.c - ShapeSpanIterator.c - SpanClipRenderer.c - - Disposer.c - SurfaceData.c - Trace.c - + + + awt_LoadLibrary.c + awt_Mlib.c + initIDs.c + + + + + HeadlessToolkit.c + VDrawingArea.c + + + + + awt_AWTEvent.c + awt_DrawingSurface.c + awt_Event.c + awt_GraphicsEnv.c + awt_InputMethod.c + awt_Insets.c + awt_Robot.c + awt_UNIXToolkit.c + awt_util.c + gtk2_interface.c + gtk3_interface.c + gtk_interface.c + list.c + multiVis.c + multi_font.c + robot_common.c + sun_awt_X11_GtkFileDialogPeer.c + swing_GTKEngine.c + swing_GTKStyle.c + + + + XRBackendNative.c + XRSurfaceData.c + + + + XToolkit.c + XWindow.c + XlibWrapper.c + awt_Desktop.c + awt_Taskbar.c + gnome_interface.c + + + + X11FontScaler.c + X11TextRenderer.c + + + jawt.c + + + PLATFORM_API_LinuxOS_ALSA_CommonUtils.c + PLATFORM_API_LinuxOS_ALSA_MidiIn.c + PLATFORM_API_LinuxOS_ALSA_MidiOut.c + PLATFORM_API_LinuxOS_ALSA_MidiUtils.c + PLATFORM_API_LinuxOS_ALSA_PCM.c + PLATFORM_API_LinuxOS_ALSA_PCMUtils.c + PLATFORM_API_LinuxOS_ALSA_Ports.c + PLATFORM_API_SolarisOS_PCM.c + PLATFORM_API_SolarisOS_Ports.c + PLATFORM_API_SolarisOS_Utils.c + + + splashscreen_sys.c + + + + + + + + + EncodingSupport.c + InstrumentationImplNativeMethods.c + InvocationAdapter.c + JPLISAgent.c + JPLISAssert.c + JarFacade.c + JavaExceptions.c + PathCharsValidator.c + Reentrancy.c + Utilities.c + + + + + + + EncodingSupport_md.c + FileSystemSupport_md.c + + + + + + + + ClassLoadingImpl.c - Flag.c GarbageCollectorImpl.c - GcInfoBuilder.c - HotSpotDiagnostic.c HotspotThread.c MemoryImpl.c MemoryManagerImpl.c @@ -1529,362 +2029,351 @@ VMManagementImpl.c management.c - - GC.c - MessageUtils.c - NativeSignalHandler.c - Signal.c - VM.c - VMSupport.c - Version.c - - - - genSocketOptionRegistry.c - - - - ConstantPool.c - NativeAccessors.c - Reflection.c - - - - - ec.c - ec2_163.c - ec2_193.c - ec2_233.c - ec2_aff.c - ec2_mont.c - ec_naf.c - ecdecode.c - ecl.c - ecl_curve.c - ecl_gf.c - ecl_mult.c - ecp_192.c - ecp_224.c - ecp_256.c - ecp_384.c - ecp_521.c - ecp_aff.c - ecp_jac.c - ecp_jm.c - ecp_mont.c - mp_gf2m.c - mpi.c - mplogic.c - mpmontg.c - oid.c - secitem.c - - ECC_JNI.cpp - - - - GSSLibStub.c - NativeUtil.c - - - - - p11_convert.c - p11_crypt.c - p11_digest.c - p11_dual.c - p11_general.c - p11_keymgmt.c - p11_mutex.c - p11_objmgmt.c - p11_sessmgmt.c - p11_sign.c - p11_util.c - - j2secmod.c - - - pcsc.c - - - - - JVM.c - - - - npt.c - utf.c - - - - socketTransport.c + + + + FileSystemImpl.c + - - - exec_md.c - linker_md.c - - - ergo.c - ergo_i586.c - java_md_common.c - java_md_solinux.c - jexec.c - - - - - Poller.c - - - - - hprof_md.c + + + + + MacOSXPreferencesFile.m - - EncodingSupport_md.c - FileSystemSupport_md.c - - - - - - LinuxOperatingSystem.c - SolarisOperatingSystem.c - UnixOperatingSystem_md.c - - - - PLATFORM_API_LinuxOS_ALSA_CommonUtils.c - PLATFORM_API_LinuxOS_ALSA_MidiIn.c - PLATFORM_API_LinuxOS_ALSA_MidiOut.c - PLATFORM_API_LinuxOS_ALSA_MidiUtils.c - PLATFORM_API_LinuxOS_ALSA_PCM.c - PLATFORM_API_LinuxOS_ALSA_PCMUtils.c - PLATFORM_API_LinuxOS_ALSA_Ports.c - PLATFORM_API_SolarisOS_PCM.c - PLATFORM_API_SolarisOS_Ports.c - PLATFORM_API_SolarisOS_Utils.c - - - - - - Solaris.c - Unix.c - - - - - - - jdk_util_md.c - jni_util_md.c - - - - Console_md.c - FileDescriptor_md.c - FileInputStream_md.c - FileOutputStream_md.c - RandomAccessFile_md.c - UnixFileSystem_md.c - canonicalize_md.c - io_util_md.c - - - ProcessEnvironment_md.c - UNIXProcess_md.c - java_props_md.c - - - Inet4AddressImpl.c - Inet6AddressImpl.c - InetAddressImplFactory.c - NetworkInterface.c - PlainDatagramSocketImpl.c - PlainSocketImpl.c - SocketInputStream.c - SocketOutputStream.c - linux_close.c - net_util_md.c - - - MappedByteBuffer.c - - + + + FileSystemPreferences.c - TimeZone_md.c - logging.c - - - - - - splashscreen_sys.c - - CUPSfuncs.c - HeadlessToolkit.c - VDrawingArea.c - X11Color.c - awt_AWTEvent.c - awt_DrawingSurface.c - awt_Event.c - awt_Font.c - awt_GraphicsEnv.c - awt_InputMethod.c - awt_Insets.c - awt_LoadLibrary.c - awt_Mlib.c - awt_Plugin.c - awt_Robot.c - awt_UNIXToolkit.c - awt_util.c - fontpath.c - gtk2_interface.c - initIDs.c - jawt.c - list.c - multiVis.c - multi_font.c - robot_common.c - sun_awt_X11_GtkFileDialogPeer.c - swing_GTKEngine.c - swing_GTKStyle.c - - - X11FontScaler.c - X11TextRenderer.c - - - - GLXGraphicsConfig.c - GLXSurfaceData.c - - - X11FontScaler_md.c - X11PMBlitLoops.c - X11Renderer.c - X11SurfaceData.c - X11TextRenderer_md.c - XRBackendNative.c - XRSurfaceData.c - - - - FileSystemImpl.c - - - - ResolverConfigurationImpl.c - - - SdpSupport.c - - - DefaultProxySelector.c - - - - - - SctpChannelImpl.c - SctpNet.c - SctpServerChannelImpl.c - - DatagramChannelImpl.c - DatagramDispatcher.c - DevPollArrayWrapper.c - EPoll.c - EPollArrayWrapper.c - EPollPort.c - FileChannelImpl.c - FileDispatcherImpl.c - FileKey.c - IOUtil.c - InheritedChannel.c - NativeThread.c - Net.c - PollArrayWrapper.c - ServerSocketChannelImpl.c - SocketChannelImpl.c - SocketDispatcher.c - SolarisEventPort.c - UnixAsynchronousServerSocketChannelImpl.c - UnixAsynchronousSocketChannelImpl.c - - - GnomeFileTypeDetector.c - LinuxNativeDispatcher.c - LinuxWatchService.c - MagicFileTypeDetector.c - SolarisNativeDispatcher.c - SolarisWatchService.c - UnixCopyFile.c - UnixNativeDispatcher.c - genSolarisConstants.c - genUnixConstants.c - - - - - - NativeFunc.c - - - - - p11_md.c - - j2secmod_md.c - - - pcsc_md.c - - - - - LinuxVirtualMachine.c - SolarisVirtualMachine.c - - - - - jvm_symbols_md.c - - - - - - HostLocaleProviderAdapter_md.c - - - - - XToolkit.c - XWindow.c - XlibWrapper.c - awt_Desktop.c - gnome_interface.c - - utf_md.c - - - - socket_md.c + + + + + + GC.c + + + + + + SCDynamicStoreConfig.m + nativeccache.c + + + + + + + GSSLibStub.c + NativeUtil.c + + + + + + + NativeFunc.c + + + + + + + + + pcsc.c + + + + + + + pcsc_md.c + + + + + + + + + VirtualMachineImpl.c + + + + + + + VirtualMachineImpl.c + + + + + + + VirtualMachineImpl.c + + + + + + + + + + ec.c + ec2_163.c + ec2_193.c + ec2_233.c + ec2_aff.c + ec2_mont.c + ec_naf.c + ecdecode.c + ecl.c + ecl_curve.c + ecl_gf.c + ecl_mult.c + ecp_192.c + ecp_224.c + ecp_256.c + ecp_384.c + ecp_521.c + ecp_aff.c + ecp_jac.c + ecp_jm.c + ecp_mont.c + mp_gf2m.c + mpi.c + mplogic.c + mpmontg.c + oid.c + secitem.c + + ECC_JNI.cpp + + + + + + + + + j2secmod.c + p11_convert.c + p11_crypt.c + p11_digest.c + p11_dual.c + p11_general.c + p11_keymgmt.c + p11_mutex.c + p11_objmgmt.c + p11_sessmgmt.c + p11_sign.c + p11_util.c + + + + + + + j2secmod_md.c + p11_md.c + + + + + + + + + nativeCrypto.c + nativeCryptoMD.c + nativeFunc.c + + + + + + + + + socketTransport.c + + + ArrayReferenceImpl.c + ArrayTypeImpl.c + ClassLoaderReferenceImpl.c + ClassObjectReferenceImpl.c + ClassTypeImpl.c + EventRequestImpl.c + FieldImpl.c + FrameID.c + InterfaceTypeImpl.c + MethodImpl.c + ModuleReferenceImpl.c + ObjectReferenceImpl.c + ReferenceTypeImpl.c + SDE.c + StackFrameImpl.c + StringReferenceImpl.c + ThreadGroupReferenceImpl.c + ThreadReferenceImpl.c + VirtualMachineImpl.c + bag.c + classTrack.c + commonRef.c + debugDispatch.c + debugInit.c + debugLoop.c + error_messages.c + eventFilter.c + eventHandler.c + eventHelper.c + inStream.c + invoker.c + log_messages.c + outStream.c + standardHandlers.c + stepControl.c + stream.c + threadControl.c + transport.c + utf_util.c + util.c + + + + + + + socket_md.c + + + exec_md.c + linker_md.c + + + + + + + + + UnixOperatingSystem.c + + + + + + + UnixOperatingSystem.c + + + + + + + DiagnosticCommandImpl.c + Flag.c + GarbageCollectorExtImpl.c + GcInfoBuilder.c + HotSpotDiagnostic.c + management_ext.c + + + + + + + UnixOperatingSystem.c + + + + + + + OperatingSystemImpl.c + + + + + + + + + SolarisSocketOptions.c + + + + + + + + + bands.cpp + bytes.cpp + coding.cpp + unpack.cpp + utils.cpp + zip.cpp + + + jni.cpp + + + main.cpp + + + + + + + + + SctpChannelImpl.c + SctpNet.c + SctpServerChannelImpl.c + + + + + + + + + Solaris.c + + + + + + + Unix.c + + + + + + + + + + + gtest-all.cc + + @@ -1895,7 +2384,7 @@ ../../Makefile - ^(nbproject)$ + ^(nbproject|build)$ ../.. @@ -1903,13 +2392,19 @@ - LOCAL_SOURCES default + false + false + + + + + + + + - - IDE_ALT_BOOTDIR - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" @@ -1919,2283 +2414,15710 @@ ../.. - ${MAKE} -f Makefile LOG=debug images + ${MAKE} -f Makefile images ${MAKE} -f Makefile clean - - - ../../build/macosx-x86_64-normal-server-release/hotspot/bsd_amd64_compiler2/product - ../../hotspot/src/share/vm/prims - ../../hotspot/src/share/vm - ../../hotspot/src/share/vm/precompiled - ../../hotspot/src/cpu/x86/vm - ../../hotspot/src/os_cpu/bsd_x86/vm - ../../hotspot/src/os/bsd/vm - ../../hotspot/src/os/posix/vm - ../../build/macosx-x86_64-normal-server-release/hotspot/bsd_amd64_compiler2/generated - + - AMD64 - COMPILER1 - COMPILER2 - DTRACE_ENABLED - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - MAC_OS_X_VERSION_MAX_ALLOWED=1070 - PRODUCT - TARGET_ARCH_MODEL_x86_64 - TARGET_ARCH_x86 - TARGET_COMPILER_gcc - TARGET_OS_ARCH_MODEL_bsd_x86_64 - TARGET_OS_ARCH_bsd_x86 - TARGET_OS_FAMILY_bsd - VM_LITTLE_ENDIAN - _ALLBSD_SOURCE - _DARWIN_C_SOURCE - _GNU_SOURCE - _LP64=1 - _XOPEN_SOURCE + THIS_FILE="MacosxDebuggerLocal.m" - - __EXCEPTIONS - __GXX_RTTI - - + + + ../.. + sh ../configure --with-debug-level=slowdebug --disable-zip-debug-info + - + + + + + + + THIS_FILE="ad_x86_64_clone.cpp" + + + + + + + THIS_FILE="ad_x86_64_expand.cpp" + + + + + + + THIS_FILE="ad_x86_64_format.cpp" + + + + + + + THIS_FILE="ad_x86_64_gen.cpp" + + + + + + + THIS_FILE="ad_x86_64_misc.cpp" + + + + + + + THIS_FILE="ad_x86_64_peephole.cpp" + + + + + + + THIS_FILE="ad_x86_64_pipeline.cpp" + + + + + + + THIS_FILE="dfa_x86_64.cpp" + + + + + + + + + + + THIS_FILE="jvmtiEnter.cpp" + + + + + + + THIS_FILE="jvmtiEnterTrace.cpp" + + + + + + + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/code + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/adfiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + ../../hotspot/make + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/adfiles + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + - + + + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/code + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/adfiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/adfiles + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/adfiles + ../../hotspot/make + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/adfiles + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/adfiles + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/make + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + - + + + ../../hotspot/make + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/adfiles + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/adfiles + ../../hotspot/make + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + - + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/prims + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/prims + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - - - + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/jvmci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/makefiles + + + AMD64 + ASSERT + COMPILER1 + COMPILER2 + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_gcc + TARGET_OS_ARCH_MODEL_bsd_x86_64 + TARGET_OS_ARCH_bsd_x86 + TARGET_OS_FAMILY_bsd + THIS_FILE="macroAssembler_libm_x86_64.cpp" + VM_LITTLE_ENDIAN + _ALLBSD_SOURCE + _DARWIN_C_SOURCE + _GNU_SOURCE + _LP64=1 + _NMT_NOINLINE_ + _XOPEN_SOURCE + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/opto + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/asm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/asm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/ci + ../../hotspot/make + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/asm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + + + + + THIS_FILE="libproc_impl.c" + + + + + + + THIS_FILE="ps_core.c" + + + + + + + THIS_FILE="symtab.c" + + + + + + - - + + + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/services + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/runtime + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/os/bsd/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/os/bsd/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/os/bsd/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/share/vm/runtime + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/os/bsd/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/os/bsd/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/os/bsd/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - - - - + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/os/bsd/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/os/posix/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/os/posix/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/os_cpu/bsd_x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + - - + + + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/os_cpu/bsd_x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + tool="1" + flavor2="4"> - + tool="1" + flavor2="4"> + + + THIS_FILE="archDesc.cpp" + + - + tool="1" + flavor2="4"> + + + THIS_FILE="arena.cpp" + + + + + + + THIS_FILE="dfa.cpp" + + + + + + + THIS_FILE="dict2.cpp" + + + + + + + THIS_FILE="filebuff.cpp" + + + + + + + THIS_FILE="forms.cpp" + + + + + + + THIS_FILE="formsopt.cpp" + + + + + + + THIS_FILE="formssel.cpp" + + + + + + + THIS_FILE="main.cpp" + + + + + + + THIS_FILE="output_c.cpp" + + + + + + + THIS_FILE="output_h.cpp" + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/asm + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/c1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/c1 + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/c1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/c1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/c1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/c1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/prims + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/c1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/prims + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/ci + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/classfile + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/services + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/classfile + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/classfile + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/classfile + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/classfile + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/logging + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/classfile + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/classfile + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/classfile + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/classfile + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/classfile + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/classfile + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/code + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/code + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/ci + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/code + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/code + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/jvmci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/code + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/asm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/code + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/code + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/interpreter + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/compiler + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/jvmci + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/compiler + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/compiler + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/oops + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/cms + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/cms + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/cms + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/gc/serial + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/cms + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/gc/serial + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/cms + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/serial + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/cms + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/cms + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/cms + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/services + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/gc/serial + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/serial + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/g1 + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/makefiles + + + AMD64 + ASSERT + COMPILER1 + COMPILER2 + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_gcc + TARGET_OS_ARCH_MODEL_bsd_x86_64 + TARGET_OS_ARCH_bsd_x86 + TARGET_OS_FAMILY_bsd + THIS_FILE="youngList.cpp" + VM_LITTLE_ENDIAN + _ALLBSD_SOURCE + _DARWIN_C_SOURCE + _GNU_SOURCE + _LP64=1 + _NMT_NOINLINE_ + _XOPEN_SOURCE + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/serial + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/gc/serial + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/serial + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/parallel + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/serial + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/serial + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/serial + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/gc/serial + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/serial + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/gc/serial + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/serial + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/gc/shared + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/ci + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/interpreter + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/interpreter + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/interpreter + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/interpreter + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/interpreter + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/interpreter + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/interpreter + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/asm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/jvmci + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/asm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/jvmci + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/jvmci + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/trace + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/ci + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/jvmci + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/asm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/jvmci + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/jvmci + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/jvmci + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/jvmci + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/libadt + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - - - - - - - - - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - - - - - - - - - - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - - - - - - - - - - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/oops + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/oops + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/oops + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/oops + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/oops + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/logging + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/trace + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/oops + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/oops + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/oops + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/oops + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/oops + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/ci + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/trace + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/oops + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/oops + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/make + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/logging + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/make + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/opto + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/logging + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/code + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/code + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/make + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/code + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/make + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/opto + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/compiler + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/prims + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/jvmci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/prims + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/logging + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/services + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/prims + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/ci + ../../hotspot/src/cpu/x86/vm + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + flavor2="4"> + + + ../../hotspot/src/share/vm + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/makefiles + + + AMD64 + ASSERT + COMPILER1 + COMPILER2 + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_gcc + TARGET_OS_ARCH_MODEL_bsd_x86_64 + TARGET_OS_ARCH_bsd_x86 + TARGET_OS_FAMILY_bsd + THIS_FILE="atomic.cpp" + VM_LITTLE_ENDIAN + _ALLBSD_SOURCE + _DARWIN_C_SOURCE + _GNU_SOURCE + _LP64=1 + _NMT_NOINLINE_ + _XOPEN_SOURCE + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../hotspot/src/share/vm/utilities + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/jvmci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/jvmci + ../../hotspot/src/share/vm/c1 + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/prims + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/code + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/ci + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/asm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/services + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/ci + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/ci + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - + + + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm/opto + ../../hotspot/src/share/vm/libadt + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/runtime + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../hotspot/make + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/services + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/g1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/memory + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/services + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/ci + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - - - - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm + ../../hotspot/make + + - - - - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/gc/serial + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/gc/serial + ../../hotspot/src/share/vm/gc/cms + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/oops + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/logging + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + flavor2="4"> + + + ../../hotspot/src/share/vm + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/makefiles + + + AMD64 + ASSERT + COMPILER1 + COMPILER2 + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_gcc + TARGET_OS_ARCH_MODEL_bsd_x86_64 + TARGET_OS_ARCH_bsd_x86 + TARGET_OS_FAMILY_bsd + THIS_FILE="array.cpp" + VM_LITTLE_ENDIAN + _ALLBSD_SOURCE + _DARWIN_C_SOURCE + _GNU_SOURCE + _LP64=1 + _NMT_NOINLINE_ + _XOPEN_SOURCE + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + /usr/include/c++/4.2.1 + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/services + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + - + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/make + + - - + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm/compiler + ../../hotspot/src/share/vm/ci + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + + + + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/share/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make + + - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + flavor2="4"> - - + + + + + + + + - /usr/X11/include - ../../build/macosx-x86_64-normal-server-release/jdk/include - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make - - + + + + + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/macosx/native/libjava + ../../make + + + + + + + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/share/native/libfdlibm + ../../build/support/headers/java.base + ../../make + + + ARCH="x86_64" + ARCHPROPNAME="x86_64" + DEBUG + MACOSX + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + THIS_FILE="java_props_macosx.c" + _ALLBSD_SOURCE + _DARWIN_UNLIMITED_SELECT + _LITTLE_ENDIAN + _LP64=1 + x86_64 + + + + + + + + + + + + + + + ../../jdk/src/java.base/macosx/native/libnio/ch + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/macosx/native/libnio/ch + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/macosx/native/libnio/ch + ../../make + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/share/native/libjava + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/share/native/libjava + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/share/native/libjava + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/share/native/libjava + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/share/native/libjava + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libjava + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/share/native/libjimage + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libjimage + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libjimage + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libjimage + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libjimage + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libjli + ../../jdk/src/java.base/share/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libjli + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libjli + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libjli + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/share/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libjli + ../../jdk/src/java.base/share/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libjli + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libnet + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + + + + + ../../jdk/src/java.base/share/native/libverify + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/share/native/libverify + ../../make + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/libjava + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/unix/native/libjava + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/unix/native/libjava + ../../make + + + + + + + ../../jdk/src/java.base/unix/native/libjava + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/share/native/libfdlibm + ../../build/support/headers/java.base + ../../make + + + ARCH="x86_64" + ARCHPROPNAME="x86_64" + DEBUG + MACOSX + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + THIS_FILE="java_props_md.c" + _ALLBSD_SOURCE + _DARWIN_UNLIMITED_SELECT + _LITTLE_ENDIAN + _LP64=1 + x86_64 + + + + + + + ../../jdk/src/java.base/unix/native/libjava + ../../make + + + + + + + ../../jdk/src/java.base/unix/native/libjava + ../../make + + + + + + + + + + + + + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.base + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/macosx/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../make + + + ARCH="x86_64" + DEBUG + MACOSX + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + THIS_FILE="ExtendedOptionsImpl.c" + _ALLBSD_SOURCE + _DARWIN_UNLIMITED_SELECT + _LITTLE_ENDIAN + _LP64=1 + x86_64 + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/libnet + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnio + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/libnio/ch + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/libnio/ch + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/libnio/ch + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/libnio/ch + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/libnio/ch + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libnio + ../../jdk/src/java.base/share/native/libnio/ch + ../../jdk/src/java.base/unix/native/libnio + ../../jdk/src/java.base/macosx/native/libnio/ch + ../../jdk/src/java.base/macosx/native/libnio/fs + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/unix/native/libnio/fs + ../../build/support/headers/java.base + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/macosx/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../make + + + ARCH="x86_64" + DEBUG + MACOSX + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + THIS_FILE="SocketDispatcher.c" + _ALLBSD_SOURCE + _DARWIN_UNLIMITED_SELECT + _LITTLE_ENDIAN + _LP64=1 + x86_64 + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/libnio/fs + ../../make + + + + + + + ../../jdk/src/java.base/unix/native/libnio/fs + ../../jdk/src/java.base/macosx/native/include + ../../make + + + + + + + + + + + THIS_FILE="AWTSurfaceLayers.m" + + + + + + + THIS_FILE="AWTView.m" + + + + + + + THIS_FILE="AWTWindow.m" + + + + + + + THIS_FILE="ApplicationDelegate.m" + + + + + + + THIS_FILE="CClipboard.m" + + + + + + + THIS_FILE="CCursorManager.m" + + + + + + + THIS_FILE="CDataTransferer.m" + + + + + + + THIS_FILE="CDesktopPeer.m" + + + + + + + THIS_FILE="CDragSource.m" + + + + + + + THIS_FILE="CDragSourceContextPeer.m" + + + + + + + THIS_FILE="CDropTarget.m" + + + + + + + THIS_FILE="CDropTargetContextPeer.m" + + + + + + + THIS_FILE="CFRetainedResource.m" + + + + + + + THIS_FILE="CFileDialog.m" + + + + + + + THIS_FILE="CGraphicsConfig.m" + + + + + + + THIS_FILE="CGraphicsDevice.m" + + + + + + + THIS_FILE="CGraphicsEnv.m" + + + + + + + THIS_FILE="CImage.m" + + + + + + + THIS_FILE="CInputMethod.m" + + + + + + + THIS_FILE="CMenu.m" + + + + + + + THIS_FILE="CMenuBar.m" + + + + + + + THIS_FILE="CMenuComponent.m" + + + + + + + THIS_FILE="CMenuItem.m" + + + + + + + THIS_FILE="CPopupMenu.m" + + + + + + + THIS_FILE="CPrinterJob.m" + + + + + + + THIS_FILE="CRobot.m" + + + + + + + THIS_FILE="CRobotKeyCode.m" + + + + + + + THIS_FILE="CSystemColors.m" + + + + + + + THIS_FILE="CTextPipe.m" + + + + + + + THIS_FILE="CTrayIcon.m" + + + + + + + THIS_FILE="CWrapper.m" + + + + + + + THIS_FILE="DnDUtilities.m" + + + + + + + THIS_FILE="GeomUtilities.m" + + + + + + + THIS_FILE="ImageSurfaceData.m" + + + + + + + THIS_FILE="InitIDs.m" + + + + + + + THIS_FILE="JavaAccessibilityAction.m" + + + + + + + THIS_FILE="JavaAccessibilityUtilities.m" + + + + + + + THIS_FILE="JavaComponentAccessibility.m" + + + + + + + THIS_FILE="JavaTextAccessibility.m" + + + + + + + THIS_FILE="LWCToolkit.m" + + + + + + + THIS_FILE="OSVersion.m" + + + + + + + THIS_FILE="PrintModel.m" + + + + + + + THIS_FILE="PrinterSurfaceData.m" + + + + + + + THIS_FILE="PrinterView.m" + + + + + + + THIS_FILE="QuartzRenderer.m" + + + + + + + THIS_FILE="QuartzSurfaceData.m" + + + + + + + THIS_FILE="awt_DrawingSurface.m" + + + + + + + + + + + THIS_FILE="AWTStrike.m" + + + + + + + THIS_FILE="CCharToGlyphMapper.m" + + + + + + + THIS_FILE="CGGlyphImages.m" + + + + + + + THIS_FILE="CGGlyphOutlines.m" + + + + + + + THIS_FILE="CoreTextSupport.m" + + + + + + + + + + + THIS_FILE="CGLLayer.m" + + + + + + + THIS_FILE="CGLSurfaceData.m" + + + + + + + + + + + + + + + THIS_FILE="PLATFORM_API_MacOSX_MidiOut.c" + + + + + + + THIS_FILE="PLATFORM_API_MacOSX_MidiUtils.c" + + + + + + - LINUX - TARGET_OS_ARCH_MODEL_linux_x86_64 - TARGET_OS_ARCH_linux_x86 - TARGET_OS_FAMILY_linux - _REENTRANT + THIS_FILE="PLATFORM_API_MacOSX_Ports.cpp" + + + + + + + THIS_FILE="PLATFORM_API_MacOSX_Utils.cpp" + + + + + + + + + + + + + + + THIS_FILE="NSApplicationAWT.m" + + + + + + + THIS_FILE="PropertiesUtilities.m" + + + + + + + THIS_FILE="QueuingApplicationDelegate.m" + + + + + + + THIS_FILE="ThreadUtilities.m" + + + + + + + + + + + THIS_FILE="AquaLookAndFeel.m" + + + + + + + THIS_FILE="AquaNativeResources.m" + + + + + + + THIS_FILE="JRSUIConstantSync.m" + + + + + + + THIS_FILE="JRSUIController.m" + + + + + + + THIS_FILE="JRSUIFocus.m" + + + + + + + THIS_FILE="ScreenMenu.m" + + + + + + + + + + + + + + + THIS_FILE="debug_mem.c" + + + + + + + THIS_FILE="debug_trace.c" + + + + + + + THIS_FILE="debug_util.c" + + + + + + + + + + + THIS_FILE="mlib_ImageCreate.c" + + + + + + + THIS_FILE="mlib_sys.c" + + + + + + + + + + + + + + + THIS_FILE="OGLBufImgOps.c" + + + + + + + THIS_FILE="OGLContext.c" + + + + + + + THIS_FILE="OGLFuncs.c" + + + + + + + THIS_FILE="OGLMaskBlit.c" + + + + + + + THIS_FILE="OGLMaskFill.c" + + + + + + + THIS_FILE="OGLPaints.c" + + + + + + + THIS_FILE="OGLRenderQueue.c" + + + + + + + THIS_FILE="OGLRenderer.c" + + + + + + + THIS_FILE="OGLSurfaceData.c" + + + + + + + THIS_FILE="OGLTextRenderer.c" + + + + + + + THIS_FILE="OGLVertexCache.c" + + + + + + + THIS_FILE="BufImgSurfaceData.c" + + + + + + + THIS_FILE="DataBufferNative.c" + + + + + + + THIS_FILE="awt_ImageRep.c" + + + + + + + THIS_FILE="awt_parseImage.c" + + + + + + + + + + + THIS_FILE="dither.c" + + + + + + + + + + + THIS_FILE="imageInitIDs.c" + + + + + + + + + + + THIS_FILE="Disposer.c" + + + + + + + THIS_FILE="SurfaceData.c" + + + + + + + THIS_FILE="Trace.c" + + + + + + + + + + + THIS_FILE="AlphaMath.c" + + + + + + + THIS_FILE="Any3Byte.c" + + + + + + + THIS_FILE="Any4Byte.c" + + + + + + + THIS_FILE="AnyByte.c" + + + + + + + THIS_FILE="AnyInt.c" + + + + + + + THIS_FILE="AnyShort.c" + + + + + + + THIS_FILE="Blit.c" + + + + + + + THIS_FILE="BlitBg.c" + + + + + + + THIS_FILE="ByteBinary1Bit.c" + + + + + + + THIS_FILE="ByteBinary2Bit.c" + + + + + + + THIS_FILE="ByteBinary4Bit.c" + + + + + + + THIS_FILE="ByteGray.c" + + + + + + + THIS_FILE="ByteIndexed.c" + + + + + + + THIS_FILE="DrawLine.c" + + + + + + + THIS_FILE="DrawParallelogram.c" + + + + + + + THIS_FILE="DrawPath.c" + + + + + + + THIS_FILE="DrawPolygons.c" + + + + + + + THIS_FILE="DrawRect.c" + + + + + + + THIS_FILE="FillParallelogram.c" + + + + + + + THIS_FILE="FillPath.c" + + + + + + + THIS_FILE="FillRect.c" + + + + + + + THIS_FILE="FillSpans.c" + + + + + + + THIS_FILE="FourByteAbgr.c" + + + + + + + THIS_FILE="FourByteAbgrPre.c" + + + + + + + THIS_FILE="GraphicsPrimitiveMgr.c" + + + + + + + THIS_FILE="Index12Gray.c" + + + + + + + THIS_FILE="Index8Gray.c" + + + + + + + THIS_FILE="IntArgb.c" + + + + + + + THIS_FILE="IntArgbBm.c" + + + + + + + THIS_FILE="IntArgbPre.c" + + + + + + + THIS_FILE="IntBgr.c" + + + + + + + THIS_FILE="IntRgb.c" + + + + + + + THIS_FILE="IntRgbx.c" + + + + + + + THIS_FILE="MapAccelFunc.c" + + + + + + + THIS_FILE="MaskBlit.c" + + + + + + + THIS_FILE="MaskFill.c" + + + + + + + THIS_FILE="ProcessPath.c" + + + + + + + THIS_FILE="ScaledBlit.c" + + + + + + + THIS_FILE="ThreeByteBgr.c" + + + + + + + THIS_FILE="TransformHelper.c" + + + + + + + THIS_FILE="Ushort4444Argb.c" + + + + + + + THIS_FILE="Ushort555Rgb.c" + + + + + + + THIS_FILE="Ushort555Rgbx.c" + + + + + + + THIS_FILE="Ushort565Rgb.c" + + + + + + + THIS_FILE="UshortGray.c" + + + + + + + THIS_FILE="UshortIndexed.c" + + + + + + + + + + + THIS_FILE="BufferedRenderPipe.c" + + + + + + + THIS_FILE="Region.c" + + + + + + + THIS_FILE="ShapeSpanIterator.c" + + + + + + + THIS_FILE="SpanClipRenderer.c" + + + + + + + THIS_FILE="DrawGlyphList.c" + + + + + + + THIS_FILE="FontInstanceAdapter.cpp" + + + + + + + THIS_FILE="HBShaper.c" + + + + + + + THIS_FILE="freetypeScaler.c" + + + + + + + + + THIS_FILE="hb-buffer-serialize.cc" + + + + + + + THIS_FILE="hb-buffer.cc" + + + + + + + THIS_FILE="hb-common.cc" + + + + + + + THIS_FILE="hb-coretext.cc" + + + + + + + THIS_FILE="hb-face.cc" + + + + + + + THIS_FILE="hb-fallback-shape.cc" + + + + + + + THIS_FILE="hb-font.cc" + + + + + + + THIS_FILE="hb-ot-font.cc" + + + + + + + THIS_FILE="hb-ot-layout.cc" + + + + + + + THIS_FILE="hb-ot-map.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-arabic.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-default.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-hangul.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-hebrew.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-indic-table.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-indic.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-myanmar.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-thai.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-tibetan.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-use-table.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-use.cc" + + + + + + + THIS_FILE="hb-ot-shape-fallback.cc" + + + + + + + THIS_FILE="hb-ot-shape-normalize.cc" + + + + + + + THIS_FILE="hb-ot-shape.cc" + + + + + + + THIS_FILE="hb-ot-tag.cc" + + + + + + + THIS_FILE="hb-set.cc" + + + + + + + THIS_FILE="hb-shape-plan.cc" + + + + + + + THIS_FILE="hb-shape.cc" + + + + + + + THIS_FILE="hb-shaper.cc" + + + + + + + THIS_FILE="hb-ucdn.cc" + + + + + + + + + + + THIS_FILE="hb-unicode.cc" + + + + + + + THIS_FILE="hb-warning.cc" + + + + + + + THIS_FILE="hb-jdk-font.cc" + + + + + + + + + THIS_FILE="AnchorTables.cpp" + + + + + + + THIS_FILE="ArabicLayoutEngine.cpp" + + + + + + + THIS_FILE="ArabicShaping.cpp" + + + + + + + THIS_FILE="CanonData.cpp" + + + + + + + THIS_FILE="CanonShaping.cpp" + + + + + + + THIS_FILE="ClassDefinitionTables.cpp" + + + + + + + THIS_FILE="ContextualGlyphInsertionProc2.cpp" + + + + + + + THIS_FILE="ContextualGlyphSubstProc.cpp" + + + + + + + THIS_FILE="ContextualGlyphSubstProc2.cpp" + + + + + + + THIS_FILE="ContextualSubstSubtables.cpp" + + + + + + + THIS_FILE="CoverageTables.cpp" + + + + + + + THIS_FILE="CursiveAttachmentSubtables.cpp" + + + + + + + THIS_FILE="DeviceTables.cpp" + + + + + + + THIS_FILE="ExtensionSubtables.cpp" + + + + + + + THIS_FILE="Features.cpp" + + + + + + + THIS_FILE="GDEFMarkFilter.cpp" + + + + + + + THIS_FILE="GXLayoutEngine.cpp" + + + + + + + THIS_FILE="GXLayoutEngine2.cpp" + + + + + + + THIS_FILE="GlyphDefinitionTables.cpp" + + + + + + + THIS_FILE="GlyphIterator.cpp" + + + + + + + THIS_FILE="GlyphLookupTables.cpp" + + + + + + + THIS_FILE="GlyphPositionAdjustments.cpp" + + + + + + + THIS_FILE="GlyphPositioningTables.cpp" + + + + + + + THIS_FILE="GlyphPosnLookupProc.cpp" + + + + + + + THIS_FILE="GlyphSubstLookupProc.cpp" + + + + + + + THIS_FILE="GlyphSubstitutionTables.cpp" + + + + + + + THIS_FILE="HanLayoutEngine.cpp" + + + + + + + THIS_FILE="HangulLayoutEngine.cpp" + + + + + + + THIS_FILE="IndicClassTables.cpp" + + + + + + + THIS_FILE="IndicLayoutEngine.cpp" + + + + + + + THIS_FILE="IndicRearrangementProcessor.cpp" + + + + + + + THIS_FILE="IndicRearrangementProcessor2.cpp" + + + + + + + THIS_FILE="IndicReordering.cpp" + + + + + + + THIS_FILE="KernTable.cpp" + + + + + + + THIS_FILE="KhmerLayoutEngine.cpp" + + + + + + + THIS_FILE="KhmerReordering.cpp" + + + + + + + THIS_FILE="LEFontInstance.cpp" + + + + + + + THIS_FILE="LEGlyphStorage.cpp" + + + + + + + THIS_FILE="LEInsertionList.cpp" + + + + + + + THIS_FILE="LayoutEngine.cpp" + + + + + + + THIS_FILE="LigatureSubstProc.cpp" + + + + + + + THIS_FILE="LigatureSubstProc2.cpp" + + + + + + + THIS_FILE="LigatureSubstSubtables.cpp" + + + + + + + THIS_FILE="LookupProcessor.cpp" + + + + + + + THIS_FILE="LookupTables.cpp" + + + + + + + THIS_FILE="Lookups.cpp" + + + + + + + THIS_FILE="MPreFixups.cpp" + + + + + + + THIS_FILE="MarkArrays.cpp" + + + + + + + THIS_FILE="MarkToBasePosnSubtables.cpp" + + + + + + + THIS_FILE="MarkToLigaturePosnSubtables.cpp" + + + + + + + THIS_FILE="MarkToMarkPosnSubtables.cpp" + + + + + + + THIS_FILE="MirroredCharData.cpp" + + + + + + + THIS_FILE="MorphTables.cpp" + + + + + + + THIS_FILE="MorphTables2.cpp" + + + + + + + THIS_FILE="MultipleSubstSubtables.cpp" + + + + + + + THIS_FILE="NonContextualGlyphSubstProc.cpp" + + + + + + + THIS_FILE="NonContextualGlyphSubstProc2.cpp" + + + + + + + THIS_FILE="OpenTypeLayoutEngine.cpp" + + + + + + + THIS_FILE="OpenTypeUtilities.cpp" + + + + + + + THIS_FILE="PairPositioningSubtables.cpp" + + + + + + + THIS_FILE="ScriptAndLanguage.cpp" + + + + + + + THIS_FILE="ScriptAndLanguageTags.cpp" + + + + + + + THIS_FILE="SegmentArrayProcessor.cpp" + + + + + + + THIS_FILE="SegmentArrayProcessor2.cpp" + + + + + + + THIS_FILE="SegmentSingleProcessor.cpp" + + + + + + + THIS_FILE="SegmentSingleProcessor2.cpp" + + + + + + + THIS_FILE="ShapingTypeData.cpp" + + + + + + + THIS_FILE="SimpleArrayProcessor.cpp" + + + + + + + THIS_FILE="SimpleArrayProcessor2.cpp" + + + + + + + THIS_FILE="SinglePositioningSubtables.cpp" + + + + + + + THIS_FILE="SingleSubstitutionSubtables.cpp" + + + + + + + THIS_FILE="SingleTableProcessor.cpp" + + + + + + + THIS_FILE="SingleTableProcessor2.cpp" + + + + + + + THIS_FILE="StateTableProcessor.cpp" + + + + + + + THIS_FILE="StateTableProcessor2.cpp" + + + + + + + THIS_FILE="SubstitutionLookups.cpp" + + + + + + + THIS_FILE="SubtableProcessor.cpp" + + + + + + + THIS_FILE="SubtableProcessor2.cpp" + + + + + + + THIS_FILE="SunLayoutEngine.cpp" + + + + + + + THIS_FILE="ThaiLayoutEngine.cpp" + + + + + + + THIS_FILE="ThaiShaping.cpp" + + + + + + + THIS_FILE="ThaiStateTables.cpp" + + + + + + + THIS_FILE="TibetanLayoutEngine.cpp" + + + + + + + THIS_FILE="TibetanReordering.cpp" + + + + + + + THIS_FILE="TrimmedArrayProcessor.cpp" + + + + + + + THIS_FILE="TrimmedArrayProcessor2.cpp" + + + + + + + THIS_FILE="ValueRecords.cpp" + + + + + + + THIS_FILE="scriptMapping.c" + + + + + + + THIS_FILE="sunFont.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.base/macosx/native/libjava + ../../build/support/headers/java.desktop + ../../make + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcapimin.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcapistd.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jccoefct.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jccolor.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcdctmgr.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jchuff.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcinit.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcmainct.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcmarker.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcmaster.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcomapi.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcparam.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcphuff.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcprepct.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcsample.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jctrans.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdapimin.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdapistd.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdcoefct.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdcolor.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jddctmgr.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdhuff.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdinput.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmainct.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmarker.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmaster.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmerge.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdphuff.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdpostct.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdsample.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdtrans.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jerror.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jfdctflt.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jfdctfst.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jfdctint.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctflt.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctfst.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctint.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctred.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jmemmgr.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jmemnobs.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.base/macosx/native/libjava + ../../build/support/headers/java.desktop + ../../make + + + THIS_FILE="jpegdecoder.c" + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jquant1.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jquant2.c" + WITH_MACOSX + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jutils.c" + WITH_MACOSX + + + + + + + + + + + THIS_FILE="DirectAudioDeviceProvider.c" + + + + + + + THIS_FILE="MidiInDevice.c" + + + + + + + THIS_FILE="MidiInDeviceProvider.c" + + + + + + + THIS_FILE="MidiOutDevice.c" + + + + + + + THIS_FILE="MidiOutDeviceProvider.c" + + + + + + + THIS_FILE="Platform.c" + + + + + + + THIS_FILE="PlatformMidi.c" + + + + + + + THIS_FILE="PortMixer.c" + + + + + + + THIS_FILE="PortMixerProvider.c" + + + + + + + THIS_FILE="Utilities.c" + + + + + + + + + + + THIS_FILE="cmscam02.c" + + + + + + + THIS_FILE="cmscgats.c" + + + + + + + THIS_FILE="cmscnvrt.c" + + + + + + + THIS_FILE="cmserr.c" + + + + + + + THIS_FILE="cmsgamma.c" + + + + + + + THIS_FILE="cmsgmt.c" + + + + + + + THIS_FILE="cmshalf.c" + + + + + + + THIS_FILE="cmsintrp.c" + + + + + + + THIS_FILE="cmsio0.c" + + + + + + + THIS_FILE="cmsio1.c" + + + + + + + THIS_FILE="cmslut.c" + + + + + + + THIS_FILE="cmsmd5.c" + + + + + + + THIS_FILE="cmsmtrx.c" + + + + + + + THIS_FILE="cmsnamed.c" + + + + + + + THIS_FILE="cmsopt.c" + + + + + + + THIS_FILE="cmspack.c" + + + + + + + THIS_FILE="cmspcs.c" + + + + + + + THIS_FILE="cmsplugin.c" + + + + + + + THIS_FILE="cmsps2.c" + + + + + + + THIS_FILE="cmssamp.c" + + + + + + + THIS_FILE="cmssm.c" + + + + + + + THIS_FILE="cmstypes.c" + + + + + + + THIS_FILE="cmsvirt.c" + + + + + + + THIS_FILE="cmswtpnt.c" + + + + + + + THIS_FILE="cmsxform.c" + + + + + + + + + + + THIS_FILE="mlib_ImageAffineEdge.c" + + + + + + + THIS_FILE="mlib_ImageAffine_BC_D64.c" + + + + + + + THIS_FILE="mlib_ImageAffine_BC_F32.c" + + + + + + + THIS_FILE="mlib_ImageAffine_BC_S32.c" + + + + + + + THIS_FILE="mlib_ImageAffine_BL_D64.c" + + + + + + + THIS_FILE="mlib_ImageAffine_BL_F32.c" + + + + + + + THIS_FILE="mlib_ImageAffine_BL_S32.c" + + + + + + + THIS_FILE="mlib_ImageAffine_NN.c" + + + + + + + THIS_FILE="mlib_ImageAffine_NN_Bit.c" + + + + + + + THIS_FILE="mlib_ImageClipping.c" + + + + + + + THIS_FILE="mlib_ImageColorTrue2Index.c" + + + + + + + THIS_FILE="mlib_ImageConv2x2_f.c" + + + + + + + THIS_FILE="mlib_ImageConvClearEdge_Bit.c" + + + + + + + THIS_FILE="mlib_ImageConvClearEdge_Fp.c" + + + + + + + THIS_FILE="mlib_ImageConvCopyEdge_Bit.c" + + + + + + + THIS_FILE="mlib_ImageConvKernelConvert.c" + + + + + + + THIS_FILE="mlib_ImageConvMxN.c" + + + + + + + THIS_FILE="mlib_ImageConvMxN_Fp.c" + + + + + + + THIS_FILE="mlib_ImageConvMxN_ext.c" + + + + + + + THIS_FILE="mlib_ImageConv_16ext.c" + + + + + + + THIS_FILE="mlib_ImageConv_16nw.c" + + + + + + + THIS_FILE="mlib_ImageConv_32nw.c" + + + + + + + THIS_FILE="mlib_ImageConv_8ext.c" + + + + + + + THIS_FILE="mlib_ImageConv_8nw.c" + + + + + + + THIS_FILE="mlib_ImageConv_D64nw.c" + + + + + + + THIS_FILE="mlib_ImageConv_F32nw.c" + + + + + + + THIS_FILE="mlib_ImageConv_u16ext.c" + + + + + + + THIS_FILE="mlib_ImageConv_u16nw.c" + + + + + + + THIS_FILE="mlib_ImageDivTables.c" + + + + + + + THIS_FILE="mlib_ImageFilters.c" + + + + + + + THIS_FILE="mlib_ImageLookUp_64.c" + + + + + + + THIS_FILE="mlib_ImageLookUp_Bit.c" + + + + + + + THIS_FILE="mlib_ImageScanPoly.c" + + + + + + + THIS_FILE="mlib_ImageUtils.c" + + + + + + + THIS_FILE="mlib_c_ImageAffineIndex_BC.c" + + + + + + + THIS_FILE="mlib_c_ImageAffineIndex_BL.c" + + + + + + + THIS_FILE="mlib_c_ImageAffine_BC.c" + + + + + + + THIS_FILE="mlib_c_ImageAffine_BC_S16.c" + + + + + + + THIS_FILE="mlib_c_ImageAffine_BC_U16.c" + + + + + + + THIS_FILE="mlib_c_ImageAffine_BL.c" + + + + + + + THIS_FILE="mlib_c_ImageAffine_BL_S16.c" + + + + + + + THIS_FILE="mlib_c_ImageAffine_BL_U16.c" + + + + + + + THIS_FILE="mlib_c_ImageAffine_NN.c" + + + + + + + THIS_FILE="mlib_c_ImageConvClearEdge.c" + + + + + + + THIS_FILE="mlib_c_ImageConvCopyEdge.c" + + + + + + + THIS_FILE="mlib_c_ImageConvVersion.c" + + + + + + + THIS_FILE="mlib_c_ImageConv_f.c" + + + + + + + THIS_FILE="mlib_c_ImageCopy.c" + + + + + + + THIS_FILE="mlib_c_ImageLookUp.c" + + + + + + + THIS_FILE="mlib_c_ImageLookUp_f.c" + + + + + + + THIS_FILE="mlib_c_ImageThresh1_U8.c" + + + + + + + + + + + THIS_FILE="gif_err.c" + + + + + + + THIS_FILE="gifalloc.c" + + + + + + + THIS_FILE="java_awt_SplashScreen.c" + + + + + + + + + + + THIS_FILE="pngerror.c" + + + + + + + THIS_FILE="pngget.c" + + + + + + + THIS_FILE="pngmem.c" + + + + + + + THIS_FILE="pngpread.c" + + + + + + + THIS_FILE="pngread.c" + + + + + + + THIS_FILE="pngrio.c" + + + + + + + THIS_FILE="pngrtran.c" + + + + + + + THIS_FILE="pngrutil.c" + + + + + + + THIS_FILE="pngset.c" + + + + + + + THIS_FILE="pngtrans.c" + + + + + + + THIS_FILE="pngwio.c" + + + + + + + THIS_FILE="pngwrite.c" + + + + + + + THIS_FILE="pngwtran.c" + + + + + + + THIS_FILE="pngwutil.c" + + + + + + + THIS_FILE="splashscreen_gfx_impl.c" + + + + + + + THIS_FILE="splashscreen_gif.c" + + + + + + + THIS_FILE="splashscreen_impl.c" + + + + + + + THIS_FILE="splashscreen_jpeg.c" + + + + + + + THIS_FILE="splashscreen_png.c" + + + + + + + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/macosx/native/include + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt/java2d/opengl + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt/font + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/macosx/native/libjava + ../../make + + + THIS_FILE="CUPSfuncs.c" + + + + + + + + + + + + + + + THIS_FILE="awt_Mlib.c" + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ../../build/support/headers/java.security.jgss + ../../make + + + + + + + /System/Library/Frameworks/Kerberos.framework/Headers + ../../make + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + THIS_FILE="p11_dual.c" + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + THIS_FILE="ArrayTypeImpl.c" + + + + + + + THIS_FILE="ClassLoaderReferenceImpl.c" + + + + + + + THIS_FILE="ClassObjectReferenceImpl.c" + + + + + + + THIS_FILE="ClassTypeImpl.c" + + + + + + + THIS_FILE="EventRequestImpl.c" + + + + + + + THIS_FILE="FieldImpl.c" + + + + + + + THIS_FILE="FrameID.c" + + + + + + + THIS_FILE="InterfaceTypeImpl.c" + + + + + + + THIS_FILE="MethodImpl.c" + + + + + + + THIS_FILE="ModuleReferenceImpl.c" + + + + + + + THIS_FILE="ObjectReferenceImpl.c" + + + + + + + THIS_FILE="ReferenceTypeImpl.c" + + + + + + + THIS_FILE="SDE.c" + + + + + + + THIS_FILE="StackFrameImpl.c" + + + + + + + THIS_FILE="StringReferenceImpl.c" + + + + + + + THIS_FILE="ThreadGroupReferenceImpl.c" + + + + + + + THIS_FILE="ThreadReferenceImpl.c" + + + + + + + THIS_FILE="VirtualMachineImpl.c" + + + + + + + THIS_FILE="bag.c" + + + + + + + THIS_FILE="classTrack.c" + + + + + + + THIS_FILE="commonRef.c" + + + + + + + THIS_FILE="debugDispatch.c" + + + + + + + THIS_FILE="debugInit.c" + + + + + + + THIS_FILE="debugLoop.c" + + + + + + + THIS_FILE="error_messages.c" + + + + + + + THIS_FILE="eventFilter.c" + + + + + + + THIS_FILE="eventHandler.c" + + + + + + + THIS_FILE="eventHelper.c" + + + + + + + THIS_FILE="inStream.c" + + + + + + + THIS_FILE="invoker.c" + + + + + + + THIS_FILE="log_messages.c" + + + + + + + THIS_FILE="outStream.c" + + + + + + + THIS_FILE="standardHandlers.c" + + + + + + + THIS_FILE="stepControl.c" + + + + + + + THIS_FILE="stream.c" + + + + + + + THIS_FILE="threadControl.c" + + + + + + + THIS_FILE="transport.c" + + + + + + + THIS_FILE="utf_util.c" + + + + + + + THIS_FILE="util.c" + + + + + + + + + + + + + + + THIS_FILE="linker_md.c" + + + + + + + + + + + + + + + THIS_FILE="Flag.c" + + + + + + + THIS_FILE="GarbageCollectorExtImpl.c" + + + + + + + THIS_FILE="GcInfoBuilder.c" + + + + + + + THIS_FILE="HotSpotDiagnostic.c" + + + + + + + THIS_FILE="management_ext.c" + + + + + + + + + + + + + THIS_FILE="bytes.cpp" + + + + + + + THIS_FILE="coding.cpp" + + + + + + + THIS_FILE="unpack.cpp" + + + + + + + THIS_FILE="utils.cpp" + + + + + + + THIS_FILE="zip.cpp" + + + + + + + + + + + + + + + + + ../../hotspot/src/share/vm + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/makefiles + + + AMD64 + ASSERT + COMPILER1 + COMPILER2 + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_gcc + TARGET_OS_ARCH_MODEL_bsd_x86_64 + TARGET_OS_ARCH_bsd_x86 + TARGET_OS_FAMILY_bsd + VM_LITTLE_ENDIAN + _ALLBSD_SOURCE + _DARWIN_C_SOURCE + _GNU_SOURCE + _LP64=1 + _NMT_NOINLINE_ + _XOPEN_SOURCE - + + + + THIS_FILE="ad_x86_64.cpp" + + + + + + + THIS_FILE="bytecodeInterpreterWithChecks.cpp" + + + + + + + ../../hotspot/src/share/vm/memory + + + + ../../hotspot/src/os/posix/launcher @@ -4847,45 +30169,139 @@ ../../hotspot/src/os/posix/vm ../../build/macosx-x86_64-normal-server-release/hotspot/bsd_amd64_compiler2/generated + + + + ../../hotspot/src/share/vm + AMD64 - ARCH="amd64" - GAMMA - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" + ASSERT + THIS_FILE="abstractInterpreter_x86.cpp" + + + + + + + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/makefiles + + + COMPILER1 + COMPILER2 + DTRACE_ENABLED HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - LAUNCHER_TYPE="gamma" - LINK_INTO_LIBJVM - PRODUCT + MAC_OS_X_VERSION_MAX_ALLOWED=1070 TARGET_ARCH_MODEL_x86_64 TARGET_ARCH_x86 TARGET_COMPILER_gcc TARGET_OS_ARCH_MODEL_bsd_x86_64 TARGET_OS_ARCH_bsd_x86 TARGET_OS_FAMILY_bsd + VM_LITTLE_ENDIAN _ALLBSD_SOURCE + _DARWIN_C_SOURCE _GNU_SOURCE + _LP64=1 + _NMT_NOINLINE_ + _XOPEN_SOURCE - + - + - ../../hotspot/agent/src/os/linux - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated - ${IDE_ALT_BOOTDIR}include - ${IDE_ALT_BOOTDIR}include/linux - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/jdk.hotspot.agent/share/native/libsaproc + ../../hotspot/src/jdk.hotspot.agent/macosx/native/libsaproc + ../../build/support/headers/jdk.hotspot.agent + ../../hotspot/src/os/macosx + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../make - _FILE_OFFSET_BITS=64 + ARCH="x86_64" + DEBUG + MACOSX + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + _ALLBSD_SOURCE + _DARWIN_UNLIMITED_SELECT + _GNU_SOURCE + _LITTLE_ENDIAN + _LP64=1 amd64 + x86_64 - + + + + THIS_FILE="sadis.c" + + + + + + + ../../hotspot/make + + + THIS_FILE="jsig.c" + + + + + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/makefiles + + + COMPILER1 + COMPILER2 + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_gcc + TARGET_OS_ARCH_MODEL_bsd_x86_64 + TARGET_OS_ARCH_bsd_x86 + TARGET_OS_FAMILY_bsd + THIS_FILE="attachListener_bsd.cpp" + VM_LITTLE_ENDIAN + _ALLBSD_SOURCE + _DARWIN_C_SOURCE + _GNU_SOURCE + _LP64=1 + _NMT_NOINLINE_ + _XOPEN_SOURCE + + + + + + + ../../hotspot/src/share/vm/memory + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product @@ -4907,7 +30323,42 @@ - + + + + THIS_FILE="os_posix.cpp" + + + + + + + ../../hotspot/src/share/vm/memory + + + COMPILER1 + COMPILER2 + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_gcc + TARGET_OS_ARCH_MODEL_bsd_x86_64 + TARGET_OS_ARCH_bsd_x86 + TARGET_OS_FAMILY_bsd + THIS_FILE="assembler_bsd_x86.cpp" + VM_LITTLE_ENDIAN + _ALLBSD_SOURCE + _DARWIN_C_SOURCE + _GNU_SOURCE + _LP64=1 + _NMT_NOINLINE_ + _XOPEN_SOURCE + + + + HOTSPOT_BUILD_TARGET="target" @@ -4921,662 +30372,651 @@ - + - - ../../hotspot/src/os_cpu/linux_x86/vm - ../../hotspot/src/os/linux/vm - ../../hotspot/src/share/vm/adlc - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product - - ASSERT - LINUX - TARGET_OS_ARCH_MODEL_linux_x86_64 - TARGET_OS_ARCH_linux_x86 - TARGET_OS_FAMILY_linux - _REENTRANT + THIS_FILE="adlparse.cpp" - - - - THIS_FILE="ArrayReferenceImpl.c" - - + + + ../../hotspot/makefiles + + + + + + + ../../hotspot/src/os/bsd/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/makefiles + - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="Agent.cpp" - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _REENTRANT - amd64 + COMPILER1 + COMPILER2 + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_gcc + TARGET_OS_ARCH_MODEL_bsd_x86_64 + TARGET_OS_ARCH_bsd_x86 + TARGET_OS_FAMILY_bsd + THIS_FILE="adaptiveFreeList.cpp" + VM_LITTLE_ENDIAN + _ALLBSD_SOURCE + _DARWIN_C_SOURCE + _GNU_SOURCE + _LP64=1 + _NMT_NOINLINE_ + _XOPEN_SOURCE - - + + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/transport/export - ../../jdk/src/share/back/export - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/src/share/back - ../../jdk/src/solaris/back - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_jdwp_headers - ../../jdk/make + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/prims/wbtestmethods + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm/runtime + ../../hotspot/src/share/vm/oops + ../../hotspot/src/share/vm/gc/parallel + ../../hotspot/src/share/vm/gc/shared + ../../hotspot/src/share/vm/classfile + ../../hotspot/src/share/vm/trace + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/tracefiles + ../../hotspot/src/os/bsd/vm + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc/jvmtifiles + ../../hotspot/src/share/vm/code + ../../hotspot/src/share/vm/asm + ../../hotspot/src/share/vm/interpreter + ../../hotspot/src/os/posix/vm + ../../hotspot/src/os_cpu/bsd_x86/vm + ../../hotspot/src/share/vm/services + ../../build/macosx-x86_64-normal-server-release/hotspot/variant-server/gensrc + ../../hotspot/make - - ARCH="amd64" - JDWP_LOGGING - LINUX - NDEBUG - RELEASE="" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - + - - + + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common + ../../hotspot/src/share/vm/memory + ../../hotspot/src/share/vm/logging + ../../hotspot/src/share/vm/utilities + ../../hotspot/src/share/vm/trace + /usr/include/c++/4.2.1 + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/share/vm/prims + ../../hotspot/make - - ARCH="amd64" - LIBARCHNAME="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="java.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - + - + - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" + ARCH="x86_64" + MACOSX + MAC_OS_X_VERSION_MAX_ALLOWED=1070 THIS_FILE="agent_util.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE + _ALLBSD_SOURCE + _DARWIN_UNLIMITED_SELECT _LITTLE_ENDIAN _LP64=1 - _REENTRANT - amd64 - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../jdk/src/share/demo/jvmti/waiters - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/make - - - - - - - ../../jdk/src/share/demo/jvmti/heapTracker - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/src/share/demo/jvmti/java_crw_demo - ../../jdk/make - - - - - - - ../../jdk/src/share/demo/jvmti/compiledMethodLoad - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/make - - - THIS_FILE="compiledMethodLoad.c" - - - - - - - ../../jdk/src/share/demo/jvmti/gctest - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/make - - - THIS_FILE="gctest.c" - - - - - - - ../../jdk/src/share/demo/jvmti/heapTracker - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/src/share/demo/jvmti/java_crw_demo - ../../jdk/make - - - THIS_FILE="heapTracker.c" - - - - - - - ../../jdk/src/share/demo/jvmti/heapViewer - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/make - - - THIS_FILE="heapViewer.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/demo/jvmti/hprof - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/src/share/demo/jvmti/java_crw_demo - ../../jdk/make - - - THIS_FILE="debug_malloc.c" - - - - - - - ../../jdk/src/share/demo/jvmti/hprof - ../../jdk/src/solaris/demo/jvmti/hprof - ../../jdk/src/share/demo/jvmti/java_crw_demo - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/make - - - THIS_FILE="java_crw_demo.c" - - - - - - - ../../jdk/src/share/demo/jvmti/minst - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/src/share/demo/jvmti/java_crw_demo - ../../jdk/make - - - THIS_FILE="minst.c" - - - - - - - ../../jdk/src/share/demo/jvmti/mtrace - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/src/share/demo/jvmti/java_crw_demo - ../../jdk/make - - - THIS_FILE="mtrace.c" - - - - - - - ../../jdk/src/share/demo/jvmti/versionCheck - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/make - - - THIS_FILE="versionCheck.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/instrument - ../../jdk/src/solaris/instrument - ../../jdk/src/share/bin - ../../jdk/make - - - ARCH="amd64" - LINUX - NDEBUG - NO_JPLIS_LOGGING - RELEASE="" - THIS_FILE="EncodingSupport.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - THIS_FILE="DirectAudioDevice.c" + x86_64 - THIS_FILE="bands.cpp" + ARCH="x86_64" + MACOSX + MAC_OS_X_VERSION_MAX_ALLOWED=1070 + THIS_FILE="Agent.cpp" + _ALLBSD_SOURCE + _DARWIN_UNLIMITED_SELECT + _LITTLE_ENDIAN + _LP64=1 + x86_64 - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/com/sun/media/sound - ../../jdk/src/solaris/native/com/sun/media/sound - ../../jdk/make + ../../jdk/make/src/native/genconstants/ch + ../../jdk/make/gensrc + + + + + + ../../jdk/make/src/native/genconstants/fs + ../../jdk/make/gensrc + + + + + - ARCH="amd64" - EXTRA_SOUND_JNI_LIBS=" jsoundalsa" - LINUX - NDEBUG - RELEASE="" - X_ARCH=X_AMD64 - X_PLATFORM=X_LINUX - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 + DEBUG + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/demo/share/jvmti/waiters + ../../jdk/src/java.base/macosx/native/include + ../../jdk/make + - FULL + DEBUG - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="check_code.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="FileInputStream.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - - - THIS_FILE="e_acos.c" - - - - - - - ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/src/java.base/share/native/include + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/java.base/macosx/native/include ../../jdk/make - + - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/src/demo/share/jvmti/compiledMethodLoad + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include ../../jdk/make - - ARCHPROPNAME="amd64" - THIS_FILE="Finalizer.c" - - + - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/demo/share/jvmti/gctest ../../jdk/make - - ARCHPROPNAME="amd64" - THIS_FILE="Array.c" - - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/src/solaris/native/sun/net/dns - ../../jdk/src/solaris/native/sun/net/spi - ../../jdk/src/solaris/native/sun/net/sdp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/demo/share/jvmti/heapTracker ../../jdk/make - - THIS_FILE="DatagramPacket.c" - - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/src/java.base/share/native/include + ../../jdk/src/demo/share/jvmti/heapViewer + ../../jdk/src/java.base/macosx/native/include ../../jdk/make - - ARCHPROPNAME="amd64" - THIS_FILE="Bits.c" - - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/src/demo/share/jvmti/java_crw_demo + ../../jdk/src/java.base/share/native/include ../../jdk/make - - ARCHPROPNAME="amd64" - THIS_FILE="AccessController.c" - - - - - THIS_FILE="AtomicLong.c" - - - - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/demo/share/jvmti/minst ../../jdk/make - - ARCHPROPNAME="amd64" - - - - - THIS_FILE="compress.c" - - - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/demo/share/jvmti/mtrace ../../jdk/make + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/demo/share/jvmti/versionCheck + ../../jdk/src/java.base/macosx/native/include + ../../jdk/make + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + + THIS_FILE="HostLocaleProviderAdapter_md.c" + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjimage + ../../build/support/headers/java.base + ../../make + + + THIS_FILE="NativeImageBuffer.cpp" + + + + + + + DEBUG + + + + + + + ../../jdk/src/java.base/macosx/native/libjli + ../../jdk/src/java.base/unix/native/libjli + ../../jdk/src/java.base/share/native/libjli + ../../make + + + LIBARCHNAME="x86_64" + PACKAGE_PATH="/opt/local" + THIS_FILE="java_md_macosx.c" + + + + + + + ../../jdk/src/java.base/macosx/native/libnet + ../../make + + + + + + + THIS_FILE="KQueue.c" + + + + + + + ../../jdk/src/java.base/macosx/native/libnio/fs + ../../make + + + + + + + ../../jdk/src/java.base/macosx/native/libosxsecurity + ../../jdk/src/java.base/macosx/native/libjava + ../../build/support/headers/java.base + ../../make + + + THIS_FILE="KeystoreImpl.m" + + + + + + + THIS_FILE="main.c" + + + + + + + ../../jdk/src/java.base/share/native/launcher + ../../jdk/src/java.base/share/native/libjli + ../../jdk/src/java.base/unix/native/libjli + ../../jdk/src/java.base/macosx/native/libjli + ../../make + + + DEBUG + ENABLE_ARG_FILES + EXPAND_CLASSPATH_WILDCARDS + JAVA_ARGS={ "-J-ms8m", "-m", "jdk.jlink/jdk.tools.jlink.internal.Main", } + LAUNCHER_NAME="openjdk" + NEVER_ACT_AS_SERVER_CLASS_MACHINE + PACKAGE_PATH="/opt/local" + PROGNAME="jlink" + VERSION_BUILD=0 + VERSION_MAJOR=9 + VERSION_MINOR=0 + VERSION_NUMBER="9" + VERSION_OPT="2016-06-20-162150.devtester.jdktrunk" + VERSION_PATCH=0 + VERSION_PRE="internal" + VERSION_SECURITY=0 + VERSION_SHORT="9-internal" + VERSION_SPECIFICATION="9" + VERSION_STRING="9-internal+0-2016-06-20-162150.devtester.jdktrunk" + + + + + + + ../../jdk/src/java.base/share/native/libfdlibm + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libnio + ../../make + + + + + + + ../../jdk/src/java.base/share/native/libzip + ../../make + + + + + + + DEBUG + THIS_FILE="jspawnhelper.c" + + + + + ../../jdk/src/java.base/unix/native/libjimage + + + THIS_FILE="osSupport_unix.cpp" + + + + + + + ../../make + + + + + + + ../../jdk/src/java.base/unix/native/libjli + ../../jdk/src/java.base/share/native/libjli + ../../make + + + + + + + DEBUG + THIS_FILE="AWTEvent.m" + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + + + DEBUG + THIS_FILE="PLATFORM_API_MacOSX_PCM.cpp" + + + + + + + ../../jdk/src/java.desktop/macosx/native/libjsound + ../../jdk/src/java.desktop/share/native/libjsound + + + + + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + + + EXTRA_SOUND_JNI_LIBS="" + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + X_PLATFORM=X_MACOSX + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/macosx/native/include + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt/java2d/opengl + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt/font + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/macosx/native/libjava + ../../make + + + + + + + THIS_FILE="AWTFont.m" + + + + + + + THIS_FILE="CGLGraphicsConfig.m" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/macosx/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.base/macosx/native/libjava + ../../make + + + THIS_FILE="jawt.m" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + + + EXTRA_SOUND_JNI_LIBS="" + THIS_FILE="PLATFORM_API_MacOSX_MidiIn.c" + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + X_PLATFORM=X_MACOSX + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosx + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/macosx/native/libjava + ../../build/support/headers/java.desktop + ../../make + + + THIS_FILE="CFileManager.m" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../build/support/headers/java.desktop + ../../make + + + THIS_FILE="AWT_debug.m" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxui + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt/awt + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../build/support/headers/java.desktop + ../../make + + + THIS_FILE="AquaFileView.m" + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN - WITH_X11 + THIS_FILE="splashscreen_sys.m" + WITH_MACOSX - + THIS_FILE="debug_assert.c" @@ -5584,1494 +31024,984 @@ - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/java.desktop/share/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz/hb-ucdn + ../../jdk/src/java.desktop/share/native/libfontmanager/layout + ../../jdk/src/java.desktop/unix/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common + ../../jdk/src/java.desktop/share/native/common/awt + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.desktop/unix/native/common/java2d + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/macosx/native/libjava + /opt/local/include/freetype2 + ../../make + + GETPAGESIZE + HAVE_CORETEXT + HAVE_FALLBACK + HAVE_INTEL_ATOMIC_PRIMITIVES + HAVE_MPROTECT + HAVE_OT + HAVE_PTHREAD + HAVE_SYSCONF + HAVE_SYS_MMAN_H + HAVE_UCDN + HAVE_UNISTD_H + HEADLESS + LE_STANDALONE + THIS_FILE="hb-blob.cc" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + + + + + + + MLIB_NO_LIBSUNMATH + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../make + + + + + + + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/libmlib_image + ../../make + + + MLIB_OS64BIT + THIS_FILE="mlib_ImageCopy_Bit.c" + + + + + + + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/macosx/native/include + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt/java2d/opengl + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt/font + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/macosx/native/libjava + ../../make + + + THIS_FILE="AccelGlyphCache.c" + + + + + + + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/macosx/native/include + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt/java2d/opengl + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/macosx/native/libawt_lwawt/font + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/macosx/native/libjava + ../../make + + + THIS_FILE="OGLBlitLoops.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../make + + + MLIB_NO_LIBSUNMATH + THIS_FILE="img_globals.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + THIS_FILE="gifdecoder.c" + + + + + + + THIS_FILE="awt_ImagingLib.c" + + + + + + + THIS_FILE="AlphaMacros.c" + + + + + + + THIS_FILE="BufferedMaskBlit.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz/hb-ucdn + ../../jdk/src/java.desktop/share/native/libfontmanager/layout + ../../jdk/src/java.desktop/unix/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common + ../../jdk/src/java.desktop/share/native/common/awt + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.desktop/unix/native/common/java2d + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/macosx/native/libjava + /opt/local/include/freetype2 + ../../make + + + GETPAGESIZE + HAVE_CORETEXT + HAVE_FALLBACK + HAVE_INTEL_ATOMIC_PRIMITIVES + HAVE_MPROTECT + HAVE_OT + HAVE_PTHREAD + HAVE_SYSCONF + HAVE_SYS_MMAN_H + HAVE_UCDN + HAVE_UNISTD_H + HEADLESS + LE_STANDALONE + THIS_FILE="ucdn.c" + + + + + THIS_FILE="AlternateSubstSubtables.cpp" - - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="dgif_lib.c" - WITH_X11 - - - - - - - THIS_FILE="img_colors.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="gifdecoder.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - + THIS_FILE="imageioJPEG.c" - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="png.c" - WITH_X11 + EXTRA_SOUND_JNI_LIBS="" + THIS_FILE="DirectAudioDevice.c" + USE_DAUDIO=TRUE + USE_PLATFORM_MIDI_IN=TRUE + USE_PLATFORM_MIDI_OUT=TRUE + USE_PORTS=TRUE + X_PLATFORM=X_MACOSX - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.desktop/share/native/liblcms + ../../make - MLIB_NO_LIBSUNMATH - THIS_FILE="awt_ImagingLib.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="java_awt_SplashScreen.c" - WITH_X11 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="rect.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="AccelGlyphCache.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - /usr/include/freetype2 - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/font/layout - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d - ../../jdk/make - - - HEADLESS - LE_STANDALONE - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" + CMS_DONT_USE_FAST_FLOOR THIS_FILE="LCMS.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - + - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/make - - - - - - - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/libmlib_image + ../../make - INTERNAL_BUILD MLIB_NO_LIBSUNMATH - THIS_FILE="AlphaMacros.c" + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine.c" __MEDIALIB_OLD_NAMES __USE_J2D_NAMES - + - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/macosx/native/libsplashscreen + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.desktop/macosx/native/libosxapp + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="OGLBlitLoops.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="dgif_lib.c" + WITH_MACOSX - + + + + THIS_FILE="png.c" + + + + - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + + + THIS_FILE="systemScale.c" + + + + + + + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../make - INTERNAL_BUILD MLIB_NO_LIBSUNMATH - THIS_FILE="BufferedMaskBlit.c" __MEDIALIB_OLD_NAMES __USE_J2D_NAMES - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/management - ../../jdk/make + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.base/macosx/native/libjava + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../make - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" + MLIB_NO_LIBSUNMATH + THIS_FILE="awt_LoadLibrary.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.instrument/share/native/libinstrument + ../../jdk/src/java.instrument/unix/native/libinstrument + ../../build/support/headers/java.instrument + ../../jdk/src/java.base/share/native/libjli + ../../make + + + DEBUG + JPLIS_LOGGING + THIS_FILE="EncodingSupport.c" + + + + + + + THIS_FILE="EncodingSupport_md.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.management/share/native/include + ../../jdk/src/java.management/share/native/libmanagement + ../../jdk/src/java.management/unix/native/libmanagement + ../../build/support/headers/java.management + ../../jdk/src/java.base/macosx/native/libjava + ../../make + + + DEBUG THIS_FILE="ClassLoadingImpl.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - + + + + THIS_FILE="FileSystemImpl.c" + + + + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.prefs/macosx/native/libprefs + ../../jdk/src/java.base/macosx/native/libjava + ../../make - ARCH="amd64" - ARCHPROPNAME="amd64" - LINUX - NDEBUG - RELEASE="" + DEBUG + THIS_FILE="MacOSXPreferencesFile.m" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.rmi/share/native/librmi + ../../jdk/src/java.base/macosx/native/include + ../../make + + + DEBUG THIS_FILE="GC.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - + - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava - THIS_FILE="genSocketOptionRegistry.c" + DEBUG + THIS_FILE="SCDynamicStoreConfig.m" - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make + ../../jdk/src/java.security.jgss/macosx/native/libosxkrb5 - - ARCH="amd64" - ARCHPROPNAME="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="ConstantPool.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="ec.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - ../../jdk/src/share/native/sun/security/ec - ../../jdk/src/share/native/sun/security/ec/impl - ../../jdk/make - - - THIS_FILE="ECC_JNI.cpp" - - - - - - - ../../jdk/src/share/native/sun/security/ec - ../../jdk/src/share/native/sun/security/ec/impl - ../../jdk/make - - - MP_API_COMPATIBLE - NSS_ECC_MORE_THAN_SUITE_B - - - - - - - ../../jdk/src/share/native/sun/security/jgss/wrapper - ../../jdk/src/solaris/native/sun/security/jgss/wrapper - ../../jdk/make + ../../jdk/src/java.security.jgss/share/native/libj2gss + ../../jdk/src/java.security.jgss/unix/native/libj2gss + ../../make THIS_FILE="GSSLibStub.c" - + - ../../jdk/src/share/native/sun/security/pkcs11 - ../../jdk/src/solaris/native/sun/security/pkcs11 - ../../jdk/src/share/native/sun/security/pkcs11/wrapper - ../../jdk/src/solaris/native/sun/security/pkcs11/wrapper - ../../jdk/make - - - THIS_FILE="p11_convert.c" - - - - - - - ../../jdk/src/share/native/sun/security/smartcardio - ../../jdk/src/solaris/native/sun/security/smartcardio - ../../jdk/src/solaris/native/sun/security/smartcardio/MUSCLE - ../../jdk/make - - - THIS_FILE="pcsc.c" - __sun_jdk - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/tracing/dtrace - ../../jdk/make - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="JVM.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/make - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="npt.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/transport/socket - ../../jdk/src/solaris/transport/socket - ../../jdk/src/share/back/export - ../../jdk/src/share/back - ../../jdk/make - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="socketTransport.c" - USE_MMAP - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="exec_md.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/transport/export - ../../jdk/src/share/back/export - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/src/share/back - ../../jdk/src/solaris/back - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_jdwp_headers - ../../jdk/make - - - JDWP_LOGGING - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - - - THIS_FILE="ergo.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/demo/jvmti/hprof - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/src/share/demo/jvmti/java_crw_demo - ../../jdk/make - - - THIS_FILE="hprof_md.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/instrument - ../../jdk/src/solaris/instrument - ../../jdk/src/share/bin - ../../jdk/make - - - NO_JPLIS_LOGGING - THIS_FILE="EncodingSupport_md.c" - - - - - - - THIS_FILE="LinuxOperatingSystem.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - - - - - - - ../../jdk/src/share/native/sun/management - ../../jdk/make - - - - - - - ../../jdk/src/share/native/com/sun/media/sound - ../../jdk/src/solaris/native/com/sun/media/sound - ../../jdk/make - - - EXTRA_SOUND_JNI_LIBS=" jsoundalsa" - THIS_FILE="PLATFORM_API_LinuxOS_ALSA_CommonUtils.c" - USE_DAUDIO=TRUE - USE_PLATFORM_MIDI_IN=TRUE - USE_PLATFORM_MIDI_OUT=TRUE - USE_PORTS=TRUE - X_ARCH=X_AMD64 - X_PLATFORM=X_LINUX - - - - - - - ../../jdk/make - - - THIS_FILE="Unix.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="jdk_util_md.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - - - THIS_FILE="Console_md.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="ProcessEnvironment_md.c" - - - - - - - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/src/solaris/native/sun/net/dns - ../../jdk/src/solaris/native/sun/net/spi - ../../jdk/src/solaris/native/sun/net/sdp - ../../jdk/make - - - THIS_FILE="Inet4AddressImpl.c" - - - - - - - ../../jdk/src/share/native/sun/nio/ch - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="MappedByteBuffer.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="FileSystemPreferences.c" - - - - - - - THIS_FILE="splashscreen_sys.c" - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - WITH_X11 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - /usr/include/freetype2 - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/font/layout - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d - ../../jdk/make - - - HEADLESS - LE_STANDALONE - THIS_FILE="X11FontScaler.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="GLXGraphicsConfig.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - THIS_FILE="X11FontScaler_md.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/management - ../../jdk/make - - - THIS_FILE="FileSystemImpl.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/src/solaris/native/sun/net/dns - ../../jdk/src/solaris/native/sun/net/spi - ../../jdk/src/solaris/native/sun/net/sdp - ../../jdk/make - - - THIS_FILE="ResolverConfigurationImpl.c" - - - - - - - THIS_FILE="SdpSupport.c" - - - - - - - THIS_FILE="DefaultProxySelector.c" - - - - - - - THIS_FILE="SctpChannelImpl.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/nio/ch - - - - - - - ../../jdk/src/share/native/sun/nio/ch/sctp - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/sun/nio/ch - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - - - - - THIS_FILE="GnomeFileTypeDetector.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/java.security.jgss/share/native/libj2gss + ../../jdk/src/java.security.jgss/unix/native/libj2gss + ../../make THIS_FILE="NativeFunc.c" - + - ../../jdk/src/share/native/sun/security/jgss/wrapper - ../../jdk/src/solaris/native/sun/security/jgss/wrapper - ../../jdk/make - - - - - - - ../../jdk/src/share/native/sun/security/pkcs11 - ../../jdk/src/solaris/native/sun/security/pkcs11 - ../../jdk/src/share/native/sun/security/pkcs11/wrapper - ../../jdk/src/solaris/native/sun/security/pkcs11/wrapper - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.smartcardio/share/native/libj2pcsc + ../../jdk/src/java.smartcardio/unix/native/libj2pcsc + ../../jdk/src/java.smartcardio/unix/native/libj2pcsc/MUSCLE + ../../build/support/headers/java.smartcardio + ../../make - THIS_FILE="p11_md.c" - - - - - - - ../../jdk/src/share/native/sun/security/smartcardio - ../../jdk/src/solaris/native/sun/security/smartcardio - ../../jdk/src/solaris/native/sun/security/smartcardio/MUSCLE - ../../jdk/make - - - THIS_FILE="pcsc_md.c" + DEBUG + THIS_FILE="pcsc.c" __sun_jdk - + - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - THIS_FILE="LinuxVirtualMachine.c" + THIS_FILE="pcsc_md.c" - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/tracing/dtrace - ../../jdk/make + ../../jdk/src/jdk.attach/macosx/native/libattach + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../make - THIS_FILE="jvm_symbols_md.c" + DEBUG + THIS_FILE="VirtualMachineImpl.c" - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make + ../../jdk/src/jdk.crypto.ec/share/native/libsunec/impl + ../../make - ARCHPROPNAME="amd64" - THIS_FILE="HostLocaleProviderAdapter_md.c" + DEBUG + MP_API_COMPATIBLE + NSS_ECC_MORE_THAN_SUITE_B + THIS_FILE="ec.c" + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/jdk.crypto.ec/share/native/libsunec/impl + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/jdk.crypto.ec/share/native/libsunec + ../../make + + + DEBUG + THIS_FILE="ECC_JNI.cpp" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/jdk.crypto.pkcs11/share/native/libj2pkcs11 + ../../jdk/src/jdk.crypto.pkcs11/unix/native/libj2pkcs11 + ../../jdk/src/java.base/macosx/native/libjava + ../../build/support/headers/jdk.crypto.pkcs11 + ../../make + + + DEBUG + THIS_FILE="j2secmod.c" - + - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="XToolkit.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK + THIS_FILE="j2secmod_md.c" - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava - THIS_FILE="utf_md.c" + DEBUG + THIS_FILE="socketTransport.c" - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/transport/socket - ../../jdk/src/solaris/transport/socket - ../../jdk/src/share/back/export - ../../jdk/src/share/back - ../../jdk/make + ../../jdk/src/jdk.jdwp.agent/share/native/libdt_socket + ../../jdk/src/jdk.jdwp.agent/unix/native/libdt_socket + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp/export + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp + ../../jdk/src/jdk.jdwp.agent/share/native/include + ../../make + + USE_MMAP + + + + + + + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp/export + ../../jdk/src/jdk.jdwp.agent/share/native/include + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp + ../../jdk/src/jdk.jdwp.agent/unix/native/libjdwp + ../../build/support/headers/jdk.jdwp.agent + ../../make + + + JDWP_LOGGING + THIS_FILE="ArrayReferenceImpl.c" + + + + + THIS_FILE="socket_md.c" + + + + + + + ../../jdk/src/jdk.jdwp.agent/share/native/libdt_socket + ../../jdk/src/jdk.jdwp.agent/unix/native/libdt_socket + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp/export + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp + ../../jdk/src/jdk.jdwp.agent/share/native/include + ../../make + + USE_MMAP + + + + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp/export + ../../jdk/src/jdk.jdwp.agent/share/native/include + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp + ../../jdk/src/jdk.jdwp.agent/unix/native/libjdwp + ../../build/support/headers/jdk.jdwp.agent + ../../make + + + JDWP_LOGGING + THIS_FILE="exec_md.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.management/share/native/include + ../../jdk/src/jdk.management/share/native/libmanagement_ext + ../../jdk/src/jdk.management/unix/native/libmanagement_ext + ../../jdk/src/jdk.management/macosx/native/libmanagement_ext + ../../build/support/headers/jdk.management + ../../jdk/src/java.base/macosx/native/libjava + ../../make + + + DEBUG + THIS_FILE="UnixOperatingSystem.c" + + + + + + + THIS_FILE="DiagnosticCommandImpl.c" + + + + + + + THIS_FILE="OperatingSystemImpl.c" + + + + + + + DEBUG + FULL + THIS_FILE="bands.cpp" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.base + ../../jdk/src/jdk.pack200/share/native/common-unpack + ../../jdk/src/java.base/macosx/native/libjava + ../../make + + + NO_ZLIB + UNPACK_JNI + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.base + ../../jdk/src/jdk.pack200/share/native/common-unpack + ../../jdk/src/java.base/macosx/native/libjava + ../../make + + + NO_ZLIB + THIS_FILE="jni.cpp" + UNPACK_JNI + + + + + + + ../../jdk/src/jdk.pack200/share/native/common-unpack + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + SYSTEM_ZLIB + THIS_FILE="main.cpp" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/macosx/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/jdk.security.auth + ../../make + + + DEBUG + THIS_FILE="Unix.c" + + + - LOCAL_SOURCES default + false + false + + + + + + + + + + + - - IDE_ALT_BOOTDIR - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" @@ -7092,2668 +32022,4436 @@ + + ../.. + sh ../configure --with-debug-level=slowdebug --disable-zip-debug-info + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - - - - - - - - - - - - - + + - - - - + + + + + + + + + + + + + + + + + + + + - + + + + + + + + + + + + - + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + + - + + + + + + + + + + + + + + + + + + + + + THIS_FILE="libproc_impl.c" + + + + + + + THIS_FILE="ps_core.c" + + + + + + + THIS_FILE="ps_proc.c" + + + + + + + THIS_FILE="salibelf.c" + + + + + + + THIS_FILE="symtab.c" + + + + + + - - + + - - + + + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + + + - - + + + + - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + - - - - - - - - - - + + + + + + + + - - - - - - - - - - - + + + + + + + + - - + + + + + + + + + + + + + + - - - - + + - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + + + + + + + - - + + + + + + + + - + + DEBUG_LEVEL="slowdebug" + HOTSPOT_VERSION_STRING="9-internal+0-2016-06-20-224455.vkvashin.jdktrunk" + VERSION_BUILD=0 + VERSION_MAJOR=9 + VERSION_MINOR=0 + VERSION_PATCH=0 + VERSION_SECURITY=0 + VERSION_STRING="9-internal+0-2016-06-20-224455.vkvashin.jdktrunk" @@ -9761,1330 +36459,6049 @@ ex="false" tool="1" flavor2="0"> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - + + - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + _FILE_OFFSET_BITS=64 + + + + + + + + + + + + - + + + + + + + + - - + + + + - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - - - THIS_FILE="ArrayTypeImpl.c" - - - - - - - THIS_FILE="ClassLoaderReferenceImpl.c" - - - - - - - THIS_FILE="ClassObjectReferenceImpl.c" - - - - - - - THIS_FILE="ClassTypeImpl.c" - - - - - - - THIS_FILE="EventRequestImpl.c" - - - - - - - THIS_FILE="FieldImpl.c" - - - - - - - THIS_FILE="FrameID.c" - - - - - - - THIS_FILE="MethodImpl.c" - - - - - - - THIS_FILE="ObjectReferenceImpl.c" - - - - - - - THIS_FILE="ReferenceTypeImpl.c" - - - - - - - THIS_FILE="SDE.c" - - - - - - - THIS_FILE="StackFrameImpl.c" - - - - - - - THIS_FILE="StringReferenceImpl.c" - - - - - - - THIS_FILE="ThreadGroupReferenceImpl.c" - - - - - - - THIS_FILE="ThreadReferenceImpl.c" - - - - - - - THIS_FILE="VirtualMachineImpl.c" - - - - - - - THIS_FILE="bag.c" - - - - - - - THIS_FILE="classTrack.c" - - - - - - - THIS_FILE="commonRef.c" - - - - - - - THIS_FILE="debugDispatch.c" - - - - - - - THIS_FILE="debugInit.c" - - - - - - - THIS_FILE="debugLoop.c" - - - - - - - THIS_FILE="error_messages.c" - - - - - - - THIS_FILE="eventFilter.c" - - - - - - - THIS_FILE="eventHandler.c" - - - - - - - THIS_FILE="eventHelper.c" - - - - - - - THIS_FILE="inStream.c" - - - - - - - THIS_FILE="invoker.c" - - - - - - - THIS_FILE="log_messages.c" - - - - - - - THIS_FILE="outStream.c" - - - - - - - THIS_FILE="standardHandlers.c" - - - - - - - THIS_FILE="stepControl.c" - - - - - - - THIS_FILE="stream.c" - - - - - - - THIS_FILE="threadControl.c" - - - - - - - THIS_FILE="transport.c" - - - - - - - THIS_FILE="util.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - - - THIS_FILE="jli_util.c" - - - - - - - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/linux/bin - ../../jdk/make - - - EXPAND_CLASSPATH_WILDCARDS - JAVA_ARGS={ "-J-ms8m", "com.sun.tools.javac.Main", } - LAUNCHER_NAME="openjdk" - NEVER_ACT_AS_SERVER_CLASS_MACHINE - PROGNAME="javac" - THIS_FILE="main.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - - - THIS_FILE="parse_manifest.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - - - THIS_FILE="splashscreen_stubs.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - - - THIS_FILE="version_comp.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - - - THIS_FILE="wildcard.c" - - - - - - - - - - - - - - - - - - - THIS_FILE="hprof_blocks.c" - - - - - - - THIS_FILE="hprof_check.c" - - - - - - - THIS_FILE="hprof_class.c" - - - - - - - THIS_FILE="hprof_cpu.c" - - - - - - - THIS_FILE="hprof_error.c" - - - - - - - THIS_FILE="hprof_event.c" - - - - - - - THIS_FILE="hprof_frame.c" - - - - - - - THIS_FILE="hprof_init.c" - - - - - - - THIS_FILE="hprof_io.c" - - - - - - - THIS_FILE="hprof_ioname.c" - - - - - - - THIS_FILE="hprof_listener.c" - - - - - - - THIS_FILE="hprof_loader.c" - - - - - - - THIS_FILE="hprof_monitor.c" - - - - - - - THIS_FILE="hprof_object.c" - - - - - - - THIS_FILE="hprof_reference.c" - - - - - - - THIS_FILE="hprof_site.c" - - - - - - - THIS_FILE="hprof_stack.c" - - - - - - - THIS_FILE="hprof_string.c" - - - - - - - THIS_FILE="hprof_table.c" - - - - - - - THIS_FILE="hprof_tag.c" - - - - - - - THIS_FILE="hprof_tls.c" - - - - - - - THIS_FILE="hprof_trace.c" - - - - - - - THIS_FILE="hprof_tracker.c" - - - - - - - THIS_FILE="hprof_util.c" - - - - - - - - - - - - - - - + THIS_FILE="Monitor.cpp" - - + THIS_FILE="Thread.cpp" - - + THIS_FILE="waiters.cpp" - + + - - + + + + + + + + + - THIS_FILE="InstrumentationImplNativeMethods.c" + THIS_FILE="EPollArrayWrapper.c" - - + - THIS_FILE="InvocationAdapter.c" + THIS_FILE="EPollPort.c" - - - - THIS_FILE="JPLISAgent.c" - + - - + - THIS_FILE="JPLISAssert.c" + THIS_FILE="LinuxWatchService.c" - - + - THIS_FILE="JarFacade.c" + THIS_FILE="MagicFileTypeDetector.c" - - - - THIS_FILE="JavaExceptions.c" - + - - - - THIS_FILE="PathCharsValidator.c" - + - - + - THIS_FILE="Reentrancy.c" + THIS_FILE="e_asin.c" - - + - THIS_FILE="Utilities.c" + THIS_FILE="e_atan2.c" - + + + THIS_FILE="e_atanh.c" + + + + + + + THIS_FILE="e_cosh.c" + + + + + + + THIS_FILE="e_exp.c" + + + + + + + THIS_FILE="e_fmod.c" + + + + + + + THIS_FILE="e_log.c" + + + + + + + THIS_FILE="e_log10.c" + + + + + + + THIS_FILE="e_rem_pio2.c" + + + + + + + THIS_FILE="e_remainder.c" + + + + + + + THIS_FILE="e_scalb.c" + + + + + + + THIS_FILE="e_sinh.c" + + + + + + + THIS_FILE="e_sqrt.c" + + + + + + + THIS_FILE="k_cos.c" + + + + + + + THIS_FILE="k_rem_pio2.c" + + + + + + + THIS_FILE="k_sin.c" + + + + + + + THIS_FILE="k_standard.c" + + + + + + + THIS_FILE="k_tan.c" + + + + + + + THIS_FILE="s_atan.c" + + + + + + + THIS_FILE="s_ceil.c" + + + + + + + THIS_FILE="s_copysign.c" + + + + + + + THIS_FILE="s_cos.c" + + + + + + + THIS_FILE="s_expm1.c" + + + + + + + THIS_FILE="s_fabs.c" + + + + + + + THIS_FILE="s_finite.c" + + + + + + + THIS_FILE="s_floor.c" + + + + + + + THIS_FILE="s_frexp.c" + + + + + + + THIS_FILE="s_ilogb.c" + + + + + + + THIS_FILE="s_isnan.c" + + + + + + + THIS_FILE="s_ldexp.c" + + + + + + + THIS_FILE="s_lib_version.c" + + + + + + + THIS_FILE="s_log1p.c" + + + + + + + THIS_FILE="s_logb.c" + + + + + + + THIS_FILE="s_matherr.c" + + + + + + + THIS_FILE="s_modf.c" + + + + + + + THIS_FILE="s_nextafter.c" + + + + + + + THIS_FILE="s_rint.c" + + + + + + + THIS_FILE="s_scalbn.c" + + + + + + + THIS_FILE="s_signgam.c" + + + + + + + THIS_FILE="s_significand.c" + + + + + + + THIS_FILE="s_sin.c" + + + + + + + THIS_FILE="s_tan.c" + + + + + + + THIS_FILE="s_tanh.c" + + + + + + + THIS_FILE="w_acos.c" + + + + + + + THIS_FILE="w_asin.c" + + + + + + + THIS_FILE="w_atan2.c" + + + + + + + THIS_FILE="w_atanh.c" + + + + + + + THIS_FILE="w_cosh.c" + + + + + + + THIS_FILE="w_exp.c" + + + + + + + THIS_FILE="w_fmod.c" + + + + + + + THIS_FILE="w_log.c" + + + + + + + THIS_FILE="w_log10.c" + + + + + + + THIS_FILE="w_remainder.c" + + + + + + + THIS_FILE="w_scalb.c" + + + + + + + THIS_FILE="w_sinh.c" + + + + + + + THIS_FILE="w_sqrt.c" + + + + + + + + + + + THIS_FILE="Array.c" + + + + + + + THIS_FILE="AtomicLong.c" + + + + + + + THIS_FILE="Class.c" + + + + + + + THIS_FILE="ClassLoader.c" + + + + + + + THIS_FILE="ConstantPool.c" + + + + + + + THIS_FILE="Double.c" + + + + + + + THIS_FILE="Executable.c" + + + + + + + THIS_FILE="Field.c" + + + + + + + THIS_FILE="FileInputStream.c" + + + + + + + THIS_FILE="Float.c" + + + + + + + THIS_FILE="GC.c" + + + + + + + THIS_FILE="NativeAccessors.c" + + + + + + + THIS_FILE="Object.c" + + + + + + + THIS_FILE="ObjectInputStream.c" + + + + + + + THIS_FILE="ObjectOutputStream.c" + + + + + + + THIS_FILE="ObjectStreamClass.c" + + + + + + + THIS_FILE="Package.c" + + + + + + + THIS_FILE="Proxy.c" + + + + + + + THIS_FILE="RandomAccessFile.c" + + + + + + + THIS_FILE="Reflection.c" + + + + + + + THIS_FILE="Runtime.c" + + + + + + + THIS_FILE="SecurityManager.c" + + + + + + + THIS_FILE="Shutdown.c" + + + + + + + THIS_FILE="Signal.c" + + + + + + + THIS_FILE="StackFrameInfo.c" + + + + + + + THIS_FILE="StackStreamFactory.c" + + + + + + + THIS_FILE="StrictMath.c" + + + + + + + THIS_FILE="String.c" + + + + + + + THIS_FILE="StringCoding.c" + + + + + + + THIS_FILE="System.c" + VERSION_BUILD=0 + VERSION_MAJOR=9 + VERSION_MINOR=0 + VERSION_NUMBER="9" + VERSION_OPT="2016-06-20-224455.vkvashin.jdktrunk" + VERSION_PATCH=0 + VERSION_PRE="internal" + VERSION_SECURITY=0 + VERSION_SHORT="9-internal" + VERSION_SPECIFICATION="9" + VERSION_STRING="9-internal+0-2016-06-20-224455.vkvashin.jdktrunk" + + + + + + + THIS_FILE="Thread.c" + + + + + + + THIS_FILE="Throwable.c" + + + + + + + THIS_FILE="TimeZone.c" + + + + + + + THIS_FILE="VM.c" + + + + + + + THIS_FILE="VMSupport.c" + + + + + + + THIS_FILE="Version.c" + + + + + + + THIS_FILE="check_version.c" + + + + + + + THIS_FILE="io_util.c" + + + + + + + THIS_FILE="jdk_util.c" + VERSION_BUILD=0 + VERSION_MAJOR=9 + VERSION_MINOR=0 + VERSION_NUMBER="9" + VERSION_OPT="2016-06-20-224455.vkvashin.jdktrunk" + VERSION_PATCH=0 + VERSION_PRE="internal" + VERSION_SECURITY=0 + VERSION_SHORT="9-internal" + VERSION_SPECIFICATION="9" + VERSION_STRING="9-internal+0-2016-06-20-224455.vkvashin.jdktrunk" + + + + + + + THIS_FILE="jio.c" + + + + + + + THIS_FILE="jni_util.c" + + + + + + + THIS_FILE="verify_stub.c" + + + + - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - NO_ZLIB - UNPACK_JNI - + - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - + - NO_ZLIB - THIS_FILE="bytes.cpp" - UNPACK_JNI + THIS_FILE="endian.cpp" - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - + - NO_ZLIB - THIS_FILE="coding.cpp" - UNPACK_JNI + THIS_FILE="imageDecompressor.cpp" - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - + - NO_ZLIB - THIS_FILE="jni.cpp" - UNPACK_JNI + THIS_FILE="imageFile.cpp" - - - - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../jdk/make - + - THIS_FILE="main.cpp" + THIS_FILE="jimage.cpp" - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - NO_ZLIB - THIS_FILE="unpack.cpp" - UNPACK_JNI - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - NO_ZLIB - THIS_FILE="utils.cpp" - UNPACK_JNI - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - NO_ZLIB - THIS_FILE="zip.cpp" - UNPACK_JNI - - - - - + + + + + + + THIS_FILE="java.c" + + + + + + + THIS_FILE="jli_util.c" + + + + + + + THIS_FILE="parse_manifest.c" + + + + + + + THIS_FILE="splashscreen_stubs.c" + + + + + + + THIS_FILE="wildcard.c" + + + + + + + + + + + THIS_FILE="Inet4Address.c" + + + + + + + THIS_FILE="Inet6Address.c" + + + + + + + THIS_FILE="InetAddress.c" + + + + + + + THIS_FILE="net_util.c" + + + + + + + + + + + + + + + THIS_FILE="check_format.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../build/support/headers/java.base + ../../make + + + THIS_FILE="Adler32.c" + USE_MMAP + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../build/support/headers/java.base + ../../make + + + THIS_FILE="CRC32.c" + USE_MMAP + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../build/support/headers/java.base + ../../make + + + THIS_FILE="Deflater.c" + USE_MMAP + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../build/support/headers/java.base + ../../make + + + THIS_FILE="Inflater.c" + USE_MMAP + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../build/support/headers/java.base + ../../make + + + THIS_FILE="zip_util.c" + USE_MMAP + + + + + + + + + + + THIS_FILE="deflate.c" + + + + + + + THIS_FILE="gzclose.c" + + + + + + + THIS_FILE="gzlib.c" + + + + + + + THIS_FILE="gzread.c" + + + + + + + THIS_FILE="gzwrite.c" + + + + + + + THIS_FILE="infback.c" + + + + + + + THIS_FILE="inffast.c" + + + + + + + THIS_FILE="inflate.c" + + + + + + + THIS_FILE="inftrees.c" + + + + + + + THIS_FILE="trees.c" + + + + + + + THIS_FILE="uncompr.c" + + + + + + + THIS_FILE="zadler32.c" + + + + + + + THIS_FILE="zcrc32.c" + + + + + + + THIS_FILE="zutil.c" + + + + + + + + + + + + + + + THIS_FILE="FileDescriptor_md.c" + + + + + + + THIS_FILE="FileInputStream_md.c" + + + + + + + THIS_FILE="FileOutputStream_md.c" + + + + + + + THIS_FILE="ProcessEnvironment_md.c" + + + + + + + THIS_FILE="ProcessHandleImpl_unix.c" + + + + + + + THIS_FILE="ProcessImpl_md.c" + + + + + + + THIS_FILE="RandomAccessFile_md.c" + + + + + + + THIS_FILE="TimeZone_md.c" + + + + + + + THIS_FILE="UnixFileSystem_md.c" + + + + + + + THIS_FILE="VM_md.c" + + + + + + + THIS_FILE="canonicalize_md.c" + + + + + + + THIS_FILE="childproc.c" + + + + + + + THIS_FILE="io_util_md.c" + + + + + + + THIS_FILE="java_props_md.c" + + + + + + + THIS_FILE="jdk_util_md.c" + + + + + + + THIS_FILE="jni_util_md.c" + + + + + + + + + + + + + + + THIS_FILE="ergo_i586.c" + + + + + + + THIS_FILE="java_md_common.c" + + + + + + + THIS_FILE="java_md_solinux.c" + + + + + + + + + + + THIS_FILE="ExtendedOptionsImpl.c" + + + + + + + THIS_FILE="Inet4AddressImpl.c" + + + + + + + THIS_FILE="Inet6AddressImpl.c" + + + + + + + THIS_FILE="InetAddressImplFactory.c" + + + + + + + THIS_FILE="NetworkInterface.c" + + + + + + + THIS_FILE="PlainDatagramSocketImpl.c" + + + + + + + THIS_FILE="PlainSocketImpl.c" + + + + + + + THIS_FILE="ResolverConfigurationImpl.c" + + + + + + + THIS_FILE="SdpSupport.c" + + + + + + + THIS_FILE="SocketImpl.c" + + + + + + + THIS_FILE="SocketInputStream.c" + + + + + + + THIS_FILE="SocketOutputStream.c" + + + + + + + THIS_FILE="net_util_md.c" + + + + + + + THIS_FILE="portconfig.c" + + + + + + + THIS_FILE="MappedByteBuffer.c" + + + + + + + + + + + THIS_FILE="DatagramDispatcher.c" + + + + + + + THIS_FILE="FileChannelImpl.c" + + + + + + + THIS_FILE="FileDispatcherImpl.c" + + + + + + + THIS_FILE="FileKey.c" + + + + + + + THIS_FILE="IOUtil.c" + + + + + + + THIS_FILE="InheritedChannel.c" + + + + + + + THIS_FILE="NativeThread.c" + + + + + + + THIS_FILE="Net.c" + + + + + + + THIS_FILE="PollArrayWrapper.c" + + + + + + + THIS_FILE="ServerSocketChannelImpl.c" + + + + + + + THIS_FILE="SocketChannelImpl.c" + + + + + + + THIS_FILE="SocketDispatcher.c" + + + + + + + THIS_FILE="UnixAsynchronousServerSocketChannelImpl.c" + + + + + + + THIS_FILE="UnixAsynchronousSocketChannelImpl.c" + + + + + + + + + + + THIS_FILE="UnixCopyFile.c" + + + + + + + THIS_FILE="UnixNativeDispatcher.c" + + + + + + + + + + + THIS_FILE="debug_mem.c" + + + + + + + THIS_FILE="debug_trace.c" + + + + + + + THIS_FILE="debug_util.c" + + + + + + + + + + + THIS_FILE="mlib_ImageCreate.c" + + + + + + + THIS_FILE="mlib_sys.c" + + + + + + + + + + + + + + + + + + + THIS_FILE="OGLBufImgOps.c" + + + + + + + THIS_FILE="OGLContext.c" + + + + + + + THIS_FILE="OGLFuncs.c" + + + + + + + THIS_FILE="OGLMaskBlit.c" + + + + + + + THIS_FILE="OGLMaskFill.c" + + + + + + + THIS_FILE="OGLPaints.c" + + + + + + + THIS_FILE="OGLRenderQueue.c" + + + + + + + THIS_FILE="OGLRenderer.c" + + + + + + + THIS_FILE="OGLSurfaceData.c" + + + + + + + THIS_FILE="OGLTextRenderer.c" + + + + + + + THIS_FILE="OGLVertexCache.c" + + + + + + + THIS_FILE="BufImgSurfaceData.c" + + + + + + + THIS_FILE="DataBufferNative.c" + + + + + + + THIS_FILE="awt_ImageRep.c" + + + + + + + THIS_FILE="awt_parseImage.c" + + + + + + + + + + + THIS_FILE="img_globals.c" + + + + + + + THIS_FILE="dither.c" + + + + + + + + + + + THIS_FILE="imageInitIDs.c" + + + + + + + + + + + THIS_FILE="Disposer.c" + + + + + + + THIS_FILE="SurfaceData.c" + + + + + + + THIS_FILE="Trace.c" + + + + + + + + + + + THIS_FILE="AlphaMath.c" + + + + + + + THIS_FILE="Any3Byte.c" + + + + + + + THIS_FILE="Any4Byte.c" + + + + + + + THIS_FILE="AnyByte.c" + + + + + + + THIS_FILE="AnyInt.c" + + + + + + + THIS_FILE="AnyShort.c" + + + + + + + THIS_FILE="Blit.c" + + + + + + + THIS_FILE="BlitBg.c" + + + + + + + THIS_FILE="ByteBinary1Bit.c" + + + + + + + THIS_FILE="ByteBinary2Bit.c" + + + + + + + THIS_FILE="ByteBinary4Bit.c" + + + + + + + THIS_FILE="ByteGray.c" + + + + + + + THIS_FILE="ByteIndexed.c" + + + + + + + THIS_FILE="DrawLine.c" + + + + + + + THIS_FILE="DrawParallelogram.c" + + + + + + + THIS_FILE="DrawPath.c" + + + + + + + THIS_FILE="DrawPolygons.c" + + + + + + + THIS_FILE="DrawRect.c" + + + + + + + THIS_FILE="FillParallelogram.c" + + + + + + + THIS_FILE="FillPath.c" + + + + + + + THIS_FILE="FillRect.c" + + + + + + + THIS_FILE="FillSpans.c" + + + + + + + THIS_FILE="FourByteAbgr.c" + + + + + + + THIS_FILE="FourByteAbgrPre.c" + + + + + + + THIS_FILE="GraphicsPrimitiveMgr.c" + + + + + + + THIS_FILE="Index12Gray.c" + + + + + + + THIS_FILE="Index8Gray.c" + + + + + + + THIS_FILE="IntArgb.c" + + + + + + + THIS_FILE="IntArgbBm.c" + + + + + + + THIS_FILE="IntArgbPre.c" + + + + + + + THIS_FILE="IntBgr.c" + + + + + + + THIS_FILE="IntRgb.c" + + + + + + + THIS_FILE="IntRgbx.c" + + + + + + + THIS_FILE="MapAccelFunc.c" + + + + + + + THIS_FILE="MaskBlit.c" + + + + + + + THIS_FILE="MaskFill.c" + + + + + + + THIS_FILE="ProcessPath.c" + + + + + + + THIS_FILE="ScaledBlit.c" + + + + + + + THIS_FILE="ThreeByteBgr.c" + + + + + + + THIS_FILE="TransformHelper.c" + + + + + + + THIS_FILE="Ushort4444Argb.c" + + + + + + + THIS_FILE="Ushort555Rgb.c" + + + + + + + THIS_FILE="Ushort555Rgbx.c" + + + + + + + THIS_FILE="Ushort565Rgb.c" + + + + + + + THIS_FILE="UshortGray.c" + + + + + + + THIS_FILE="UshortIndexed.c" + + + + + + + + + + + THIS_FILE="BufferedRenderPipe.c" + + + + + + + THIS_FILE="Region.c" + + + + + + + THIS_FILE="ShapeSpanIterator.c" + + + + + + + THIS_FILE="SpanClipRenderer.c" + + + + + + + THIS_FILE="DrawGlyphList.c" + + + + + + + THIS_FILE="FontInstanceAdapter.cpp" + + + + + + + THIS_FILE="HBShaper.c" + + + + + + + THIS_FILE="freetypeScaler.c" + + + + + + + + + + + THIS_FILE="hb-buffer-serialize.cc" + + + + + + + THIS_FILE="hb-buffer.cc" + + + + + + + THIS_FILE="hb-common.cc" + + + + + + + THIS_FILE="hb-face.cc" + + + + + + + THIS_FILE="hb-fallback-shape.cc" + + + + + + + THIS_FILE="hb-font.cc" + + + + + + + THIS_FILE="hb-ot-font.cc" + + + + + + + THIS_FILE="hb-ot-layout.cc" + + + + + + + THIS_FILE="hb-ot-map.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-arabic.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-default.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-hangul.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-hebrew.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-indic-table.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-indic.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-myanmar.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-thai.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-tibetan.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-use-table.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-use.cc" + + + + + + + THIS_FILE="hb-ot-shape-fallback.cc" + + + + + + + THIS_FILE="hb-ot-shape-normalize.cc" + + + + + + + THIS_FILE="hb-ot-shape.cc" + + + + + + + THIS_FILE="hb-ot-tag.cc" + + + + + + + THIS_FILE="hb-set.cc" + + + + + + + THIS_FILE="hb-shape-plan.cc" + + + + + + + THIS_FILE="hb-shape.cc" + + + + + + + THIS_FILE="hb-shaper.cc" + + + + + + + THIS_FILE="hb-ucdn.cc" + + + + + + + + + + + THIS_FILE="hb-unicode.cc" + + + + + + + THIS_FILE="hb-warning.cc" + + + + + + + THIS_FILE="hb-jdk-font.cc" + + + + + + + + + + + THIS_FILE="AnchorTables.cpp" + + + + + + + THIS_FILE="ArabicLayoutEngine.cpp" + + + + + + + THIS_FILE="ArabicShaping.cpp" + + + + + + + THIS_FILE="CanonData.cpp" + + + + + + + THIS_FILE="CanonShaping.cpp" + + + + + + + THIS_FILE="ClassDefinitionTables.cpp" + + + + + + + THIS_FILE="ContextualGlyphInsertionProc2.cpp" + + + + + + + THIS_FILE="ContextualGlyphSubstProc.cpp" + + + + + + + THIS_FILE="ContextualGlyphSubstProc2.cpp" + + + + + + + THIS_FILE="ContextualSubstSubtables.cpp" + + + + + + + THIS_FILE="CoverageTables.cpp" + + + + + + + THIS_FILE="CursiveAttachmentSubtables.cpp" + + + + + + + THIS_FILE="DeviceTables.cpp" + + + + + + + THIS_FILE="ExtensionSubtables.cpp" + + + + + + + THIS_FILE="Features.cpp" + + + + + + + THIS_FILE="GDEFMarkFilter.cpp" + + + + + + + THIS_FILE="GXLayoutEngine.cpp" + + + + + + + THIS_FILE="GXLayoutEngine2.cpp" + + + + + + + THIS_FILE="GlyphDefinitionTables.cpp" + + + + + + + THIS_FILE="GlyphIterator.cpp" + + + + + + + THIS_FILE="GlyphLookupTables.cpp" + + + + + + + THIS_FILE="GlyphPositionAdjustments.cpp" + + + + + + + THIS_FILE="GlyphPositioningTables.cpp" + + + + + + + THIS_FILE="GlyphPosnLookupProc.cpp" + + + + + + + THIS_FILE="GlyphSubstLookupProc.cpp" + + + + + + + THIS_FILE="GlyphSubstitutionTables.cpp" + + + + + + + THIS_FILE="HanLayoutEngine.cpp" + + + + + + + THIS_FILE="HangulLayoutEngine.cpp" + + + + + + + THIS_FILE="IndicClassTables.cpp" + + + + + + + THIS_FILE="IndicLayoutEngine.cpp" + + + + + + + THIS_FILE="IndicRearrangementProcessor.cpp" + + + + + + + THIS_FILE="IndicRearrangementProcessor2.cpp" + + + + + + + THIS_FILE="IndicReordering.cpp" + + + + + + + THIS_FILE="KernTable.cpp" + + + + + + + THIS_FILE="KhmerLayoutEngine.cpp" + + + + + + + THIS_FILE="KhmerReordering.cpp" + + + + + + + THIS_FILE="LEFontInstance.cpp" + + + + + + + THIS_FILE="LEGlyphStorage.cpp" + + + + + + + THIS_FILE="LEInsertionList.cpp" + + + + + + + THIS_FILE="LayoutEngine.cpp" + + + + + + + THIS_FILE="LigatureSubstProc.cpp" + + + + + + + THIS_FILE="LigatureSubstProc2.cpp" + + + + + + + THIS_FILE="LigatureSubstSubtables.cpp" + + + + + + + THIS_FILE="LookupProcessor.cpp" + + + + + + + THIS_FILE="LookupTables.cpp" + + + + + + + THIS_FILE="Lookups.cpp" + + + + + + + THIS_FILE="MPreFixups.cpp" + + + + + + + THIS_FILE="MarkArrays.cpp" + + + + + + + THIS_FILE="MarkToBasePosnSubtables.cpp" + + + + + + + THIS_FILE="MarkToLigaturePosnSubtables.cpp" + + + + + + + THIS_FILE="MarkToMarkPosnSubtables.cpp" + + + + + + + THIS_FILE="MirroredCharData.cpp" + + + + + + + THIS_FILE="MorphTables.cpp" + + + + + + + THIS_FILE="MorphTables2.cpp" + + + + + + + THIS_FILE="MultipleSubstSubtables.cpp" + + + + + + + THIS_FILE="NonContextualGlyphSubstProc.cpp" + + + + + + + THIS_FILE="NonContextualGlyphSubstProc2.cpp" + + + + + + + THIS_FILE="OpenTypeLayoutEngine.cpp" + + + + + + + THIS_FILE="OpenTypeUtilities.cpp" + + + + + + + THIS_FILE="PairPositioningSubtables.cpp" + + + + + + + THIS_FILE="ScriptAndLanguage.cpp" + + + + + + + THIS_FILE="ScriptAndLanguageTags.cpp" + + + + + + + THIS_FILE="SegmentArrayProcessor.cpp" + + + + + + + THIS_FILE="SegmentArrayProcessor2.cpp" + + + + + + + THIS_FILE="SegmentSingleProcessor.cpp" + + + + + + + THIS_FILE="SegmentSingleProcessor2.cpp" + + + + + + + THIS_FILE="ShapingTypeData.cpp" + + + + + + + THIS_FILE="SimpleArrayProcessor.cpp" + + + + + + + THIS_FILE="SimpleArrayProcessor2.cpp" + + + + + + + THIS_FILE="SinglePositioningSubtables.cpp" + + + + + + + THIS_FILE="SingleSubstitutionSubtables.cpp" + + + + + + + THIS_FILE="SingleTableProcessor.cpp" + + + + + + + THIS_FILE="SingleTableProcessor2.cpp" + + + + + + + THIS_FILE="StateTableProcessor.cpp" + + + + + + + THIS_FILE="StateTableProcessor2.cpp" + + + + + + + THIS_FILE="SubstitutionLookups.cpp" + + + + + + + THIS_FILE="SubtableProcessor.cpp" + + + + + + + THIS_FILE="SubtableProcessor2.cpp" + + + + + + + THIS_FILE="SunLayoutEngine.cpp" + + + + + + + THIS_FILE="ThaiLayoutEngine.cpp" + + + + + + + THIS_FILE="ThaiShaping.cpp" + + + + + + + THIS_FILE="ThaiStateTables.cpp" + + + + + + + THIS_FILE="TibetanLayoutEngine.cpp" + + + + + + + THIS_FILE="TibetanReordering.cpp" + + + + + + + THIS_FILE="TrimmedArrayProcessor.cpp" + + + + + + + THIS_FILE="TrimmedArrayProcessor2.cpp" + + + + + + + THIS_FILE="ValueRecords.cpp" + + + + + + + THIS_FILE="scriptMapping.c" + + + + + + + THIS_FILE="sunFont.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.base/linux/native/libjava + ../../build/support/headers/java.desktop + ../../make + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcapimin.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcapistd.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jccoefct.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jccolor.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcdctmgr.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jchuff.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcinit.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcmainct.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcmarker.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcmaster.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcomapi.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcparam.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcphuff.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcprepct.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jcsample.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jctrans.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdapimin.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdapistd.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdcoefct.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdcolor.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jddctmgr.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdhuff.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdinput.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmainct.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmarker.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmaster.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdmerge.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdphuff.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdpostct.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdsample.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jdtrans.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jerror.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jfdctflt.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jfdctfst.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jfdctint.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctflt.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctfst.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctint.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jidctred.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jmemmgr.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jmemnobs.c" + WITH_X11 + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.base/linux/native/libjava + ../../build/support/headers/java.desktop + ../../make + + + THIS_FILE="jpegdecoder.c" + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jquant1.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jquant2.c" + WITH_X11 + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="jutils.c" + WITH_X11 + + + + + + + /usr/include/alsa + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + USE_DAUDIO=TRUE USE_PLATFORM_MIDI_IN=TRUE @@ -11093,11 +42510,19 @@ - - + + + /usr/include/alsa + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + THIS_FILE="DirectAudioDeviceProvider.c" USE_DAUDIO=TRUE @@ -11107,11 +42532,19 @@ - - + + + /usr/include/alsa + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + THIS_FILE="MidiInDevice.c" USE_DAUDIO=TRUE @@ -11121,11 +42554,19 @@ - - + + + /usr/include/alsa + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + THIS_FILE="MidiInDeviceProvider.c" USE_DAUDIO=TRUE @@ -11135,11 +42576,19 @@ - - + + + /usr/include/alsa + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + THIS_FILE="MidiOutDevice.c" USE_DAUDIO=TRUE @@ -11149,11 +42598,19 @@ - - + + + /usr/include/alsa + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + THIS_FILE="MidiOutDeviceProvider.c" USE_DAUDIO=TRUE @@ -11163,21 +42620,36 @@ - - + + + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + THIS_FILE="Platform.c" - - + + + /usr/include/alsa + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + THIS_FILE="PlatformMidi.c" USE_DAUDIO=TRUE @@ -11187,11 +42659,19 @@ - - + + + /usr/include/alsa + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + THIS_FILE="PortMixer.c" USE_DAUDIO=TRUE @@ -11201,11 +42681,19 @@ - - + + + /usr/include/alsa + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + THIS_FILE="PortMixerProvider.c" USE_DAUDIO=TRUE @@ -11215,11 +42703,19 @@ - - + + + /usr/include/alsa + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + THIS_FILE="Utilities.c" USE_DAUDIO=TRUE @@ -11229,9316 +42725,2765 @@ - - - - ../../jdk/make - + - - - - ../../jdk/make - - - THIS_FILE="check_format.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="check_version.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="jdk_util.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="jio.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="jni_util.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="verify_stub.c" - - - - - - - - - THIS_FILE="ObjectInputStream.c" - - - - - - - THIS_FILE="ObjectOutputStream.c" - - - - - - - THIS_FILE="ObjectStreamClass.c" - - - - - - - THIS_FILE="RandomAccessFile.c" - - - - - - - THIS_FILE="io_util.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Class.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="ClassLoader.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Compiler.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Double.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Float.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Object.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Package.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="ResourceBundle.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Runtime.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="SecurityManager.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Shutdown.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="StrictMath.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="String.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="System.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Thread.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Throwable.c" - - - - - - - - - THIS_FILE="e_asin.c" - - - - - - - THIS_FILE="e_atan2.c" - - - - - - - THIS_FILE="e_atanh.c" - - - - - - - THIS_FILE="e_cosh.c" - - - - - - - THIS_FILE="e_exp.c" - - - - - - - THIS_FILE="e_fmod.c" - - - - - - - THIS_FILE="e_hypot.c" - - - - - - - THIS_FILE="e_log.c" - - - - - - - THIS_FILE="e_log10.c" - - - - - - - THIS_FILE="e_pow.c" - - - - - - - THIS_FILE="e_rem_pio2.c" - - - - - - - THIS_FILE="e_remainder.c" - - - - - - - THIS_FILE="e_scalb.c" - - - - - - - THIS_FILE="e_sinh.c" - - - - - - - THIS_FILE="e_sqrt.c" - - - - - - - THIS_FILE="k_cos.c" - - - - - - - THIS_FILE="k_rem_pio2.c" - - - - - - - THIS_FILE="k_sin.c" - - - - - - - THIS_FILE="k_standard.c" - - - - - - - THIS_FILE="k_tan.c" - - - - - - - THIS_FILE="s_atan.c" - - - - - - - THIS_FILE="s_cbrt.c" - - - - - - - THIS_FILE="s_ceil.c" - - - - - - - THIS_FILE="s_copysign.c" - - - - - - - THIS_FILE="s_cos.c" - - - - - - - THIS_FILE="s_expm1.c" - - - - - - - THIS_FILE="s_fabs.c" - - - - - - - THIS_FILE="s_finite.c" - - - - - - - THIS_FILE="s_floor.c" - - - - - - - THIS_FILE="s_frexp.c" - - - - - - - THIS_FILE="s_ilogb.c" - - - - - - - THIS_FILE="s_isnan.c" - - - - - - - THIS_FILE="s_ldexp.c" - - - - - - - THIS_FILE="s_lib_version.c" - - - - - - - THIS_FILE="s_log1p.c" - - - - - - - THIS_FILE="s_logb.c" - - - - - - - THIS_FILE="s_matherr.c" - - - - - - - THIS_FILE="s_modf.c" - - - - - - - THIS_FILE="s_nextafter.c" - - - - - - - THIS_FILE="s_rint.c" - - - - - - - THIS_FILE="s_scalbn.c" - - - - - - - THIS_FILE="s_signgam.c" - - - - - - - THIS_FILE="s_significand.c" - - - - - - - THIS_FILE="s_sin.c" - - - - - - - THIS_FILE="s_tan.c" - - - - - - - THIS_FILE="s_tanh.c" - - - - - - - THIS_FILE="w_acos.c" - - - - - - - THIS_FILE="w_asin.c" - - - - - - - THIS_FILE="w_atan2.c" - - - - - - - THIS_FILE="w_atanh.c" - - - - - - - THIS_FILE="w_cosh.c" - - - - - - - THIS_FILE="w_exp.c" - - - - - - - THIS_FILE="w_fmod.c" - - - - - - - THIS_FILE="w_hypot.c" - - - - - - - THIS_FILE="w_log.c" - - - - - - - THIS_FILE="w_log10.c" - - - - - - - THIS_FILE="w_pow.c" - - - - - - - THIS_FILE="w_remainder.c" - - - - - - - THIS_FILE="w_scalb.c" - - - - - - - THIS_FILE="w_sinh.c" - - - - - - - THIS_FILE="w_sqrt.c" - - - - - - - - - - - THIS_FILE="Executable.c" - - - - - - - THIS_FILE="Proxy.c" - - - - - - - - - THIS_FILE="Inet4Address.c" - - - - - - - THIS_FILE="Inet6Address.c" - - - - - - - THIS_FILE="InetAddress.c" - - - - - - - THIS_FILE="net_util.c" - - - - - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="TimeZone.c" - - - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/make - - - THIS_FILE="Adler32.c" - USE_MMAP - - - DEBUG - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/make - - - THIS_FILE="CRC32.c" - USE_MMAP - - - DEBUG - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/make - - - THIS_FILE="Deflater.c" - USE_MMAP - - - DEBUG - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/make - - - THIS_FILE="Inflater.c" - USE_MMAP - - - DEBUG - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/make - - - THIS_FILE="ZipFile.c" - USE_MMAP - - - DEBUG - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/make - - - THIS_FILE="zip_util.c" - USE_MMAP - - - DEBUG - - - - - - - - - THIS_FILE="deflate.c" - - - - - - - THIS_FILE="gzclose.c" - - - - - - - THIS_FILE="gzlib.c" - - - - - - - THIS_FILE="gzread.c" - - - - - - - THIS_FILE="gzwrite.c" - - - - - - - THIS_FILE="infback.c" - - - - - - - THIS_FILE="inffast.c" - - - - - - - THIS_FILE="inflate.c" - - - - - - - THIS_FILE="inftrees.c" - - - - - - - THIS_FILE="trees.c" - - - - - - - THIS_FILE="uncompr.c" - - - - - - - THIS_FILE="zadler32.c" - - - - - - - THIS_FILE="zcrc32.c" - - - - - - - THIS_FILE="zutil.c" - - - - - - - - - THIS_FILE="debug_mem.c" - - - - - - - THIS_FILE="debug_trace.c" - - - - - - - THIS_FILE="debug_util.c" - - - - - - - - - THIS_FILE="gif_err.c" - - - - - - - THIS_FILE="gifalloc.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="BufImgSurfaceData.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="DataBufferNative.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="awt_ImageRep.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="awt_parseImage.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - - - THIS_FILE="img_globals.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="dither.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="imageInitIDs.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/make - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jcapimin.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jcapistd.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jccoefct.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jccolor.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jcdctmgr.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jchuff.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jcinit.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jcmainct.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jcmarker.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jcmaster.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jcomapi.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jcparam.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jcphuff.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jcprepct.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jcsample.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jctrans.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jdapimin.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jdapistd.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jdcoefct.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jdcolor.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jddctmgr.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jdhuff.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jdinput.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jdmainct.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jdmarker.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jdmaster.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jdmerge.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jdphuff.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jdpostct.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jdsample.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jdtrans.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jerror.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jfdctflt.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jfdctfst.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jfdctint.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jidctflt.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jidctfst.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jidctint.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jidctred.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jmemmgr.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jmemnobs.c" - WITH_X11 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/make - - - THIS_FILE="jpegdecoder.c" - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jquant1.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jquant2.c" - WITH_X11 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="jutils.c" - WITH_X11 - - - - - - - - - THIS_FILE="pngerror.c" - - - - - - - THIS_FILE="pngget.c" - - - - - - - THIS_FILE="pngmem.c" - - - - - - - THIS_FILE="pngpread.c" - - - - - - - THIS_FILE="pngread.c" - - - - - - - THIS_FILE="pngrio.c" - - - - - - - THIS_FILE="pngrtran.c" - - - - - - - THIS_FILE="pngrutil.c" - - - - - - - THIS_FILE="pngset.c" - - - - - - - THIS_FILE="pngtrans.c" - - - - - - - THIS_FILE="pngwio.c" - - - - - - - THIS_FILE="pngwrite.c" - - - - - - - THIS_FILE="pngwtran.c" - - - - - - - THIS_FILE="pngwutil.c" - - - - - - - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffineEdge.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_BC_D64.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_BC_F32.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_BC_S32.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_BL_D64.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_BL_F32.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_BL_S32.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_NN.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_NN_Bit.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageClipping.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageColorTrue2Index.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv2x2_f.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConvClearEdge_Bit.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConvClearEdge_Fp.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConvCopyEdge_Bit.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConvKernelConvert.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConvMxN.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConvMxN_Fp.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConvMxN_ext.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_16ext.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_16nw.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_32nw.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_8ext.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_8nw.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_D64nw.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_F32nw.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_u16ext.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_u16nw.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageCopy_Bit.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageCreate.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageDivTables.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageFilters.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageLookUp_64.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageLookUp_Bit.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageScanPoly.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_ImageUtils.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffineIndex_BC.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffineIndex_BL.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffine_BC.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffine_BC_S16.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffine_BC_U16.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffine_BL.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffine_BL_S16.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffine_BL_U16.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffine_NN.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageConvClearEdge.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageConvCopyEdge.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageConvVersion.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageConv_f.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageCopy.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageLookUp.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageLookUp_f.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageThresh1_U8.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_OS64BIT - THIS_FILE="mlib_sys.c" - - - - - - - - - THIS_FILE="splashscreen_gfx_impl.c" - - - - - - - THIS_FILE="splashscreen_gif.c" - - - - - - - THIS_FILE="splashscreen_impl.c" - - - - - - - THIS_FILE="splashscreen_jpeg.c" - - - - - - - THIS_FILE="splashscreen_png.c" - - - - - - - - - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - /usr/include/freetype2 - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/font/layout - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d - ../../jdk/make - - - HEADLESS - LE_STANDALONE - THIS_FILE="DrawGlyphList.c" - - - - - - - THIS_FILE="FontInstanceAdapter.cpp" - - - - - - - /usr/include/freetype2 - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/font/layout - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d - ../../jdk/make - - - HEADLESS - LE_STANDALONE - THIS_FILE="freetypeScaler.c" - - - - - - - - - THIS_FILE="AnchorTables.cpp" - - - - - - - THIS_FILE="ArabicLayoutEngine.cpp" - - - - - - - THIS_FILE="ArabicShaping.cpp" - - - - - - - THIS_FILE="CanonData.cpp" - - - - - - - THIS_FILE="CanonShaping.cpp" - - - - - - - THIS_FILE="ClassDefinitionTables.cpp" - - - - - - - THIS_FILE="ContextualGlyphSubstProc.cpp" - - - - - - - THIS_FILE="ContextualSubstSubtables.cpp" - - - - - - - THIS_FILE="CoverageTables.cpp" - - - - - - - THIS_FILE="CursiveAttachmentSubtables.cpp" - - - - - - - THIS_FILE="DeviceTables.cpp" - - - - - - - THIS_FILE="ExtensionSubtables.cpp" - - - - - - - THIS_FILE="Features.cpp" - - - - - - - THIS_FILE="GDEFMarkFilter.cpp" - - - - - - - THIS_FILE="GXLayoutEngine.cpp" - - - - - - - THIS_FILE="GlyphDefinitionTables.cpp" - - - - - - - THIS_FILE="GlyphIterator.cpp" - - - - - - - THIS_FILE="GlyphLookupTables.cpp" - - - - - - - THIS_FILE="GlyphPositionAdjustments.cpp" - - - - - - - THIS_FILE="GlyphPositioningTables.cpp" - - - - - - - THIS_FILE="GlyphPosnLookupProc.cpp" - - - - - - - THIS_FILE="GlyphSubstLookupProc.cpp" - - - - - - - THIS_FILE="GlyphSubstitutionTables.cpp" - - - - - - - THIS_FILE="HanLayoutEngine.cpp" - - - - - - - THIS_FILE="HangulLayoutEngine.cpp" - - - - - - - THIS_FILE="IndicClassTables.cpp" - - - - - - - THIS_FILE="IndicLayoutEngine.cpp" - - - - - - - THIS_FILE="IndicRearrangementProcessor.cpp" - - - - - - - THIS_FILE="IndicReordering.cpp" - - - - - - - THIS_FILE="KernTable.cpp" - - - - - - - THIS_FILE="KhmerLayoutEngine.cpp" - - - - - - - THIS_FILE="KhmerReordering.cpp" - - - - - - - THIS_FILE="LEFontInstance.cpp" - - - - - - - THIS_FILE="LEGlyphStorage.cpp" - - - - - - - THIS_FILE="LEInsertionList.cpp" - - - - - - - THIS_FILE="LayoutEngine.cpp" - - - - - - - THIS_FILE="LigatureSubstProc.cpp" - - - - - - - THIS_FILE="LigatureSubstSubtables.cpp" - - - - - - - THIS_FILE="LookupProcessor.cpp" - - - - - - - THIS_FILE="LookupTables.cpp" - - - - - - - THIS_FILE="Lookups.cpp" - - - - - - - THIS_FILE="MPreFixups.cpp" - - - - - - - THIS_FILE="MarkArrays.cpp" - - - - - - - THIS_FILE="MarkToBasePosnSubtables.cpp" - - - - - - - THIS_FILE="MarkToLigaturePosnSubtables.cpp" - - - - - - - THIS_FILE="MarkToMarkPosnSubtables.cpp" - - - - - - - THIS_FILE="MirroredCharData.cpp" - - - - - - - THIS_FILE="MorphTables.cpp" - - - - - - - THIS_FILE="MultipleSubstSubtables.cpp" - - - - - - - THIS_FILE="NonContextualGlyphSubstProc.cpp" - - - - - - - THIS_FILE="OpenTypeLayoutEngine.cpp" - - - - - - - THIS_FILE="OpenTypeUtilities.cpp" - - - - - - - THIS_FILE="PairPositioningSubtables.cpp" - - - - - - - THIS_FILE="ScriptAndLanguage.cpp" - - - - - - - THIS_FILE="ScriptAndLanguageTags.cpp" - - - - - - - THIS_FILE="SegmentArrayProcessor.cpp" - - - - - - - THIS_FILE="SegmentSingleProcessor.cpp" - - - - - - - THIS_FILE="ShapingTypeData.cpp" - - - - - - - THIS_FILE="SimpleArrayProcessor.cpp" - - - - - - - THIS_FILE="SinglePositioningSubtables.cpp" - - - - - - - THIS_FILE="SingleSubstitutionSubtables.cpp" - - - - - - - THIS_FILE="SingleTableProcessor.cpp" - - - - - - - THIS_FILE="StateTableProcessor.cpp" - - - - - - - THIS_FILE="SubstitutionLookups.cpp" - - - - - - - THIS_FILE="SubtableProcessor.cpp" - - - - - - - THIS_FILE="SunLayoutEngine.cpp" - - - - - - - THIS_FILE="ThaiLayoutEngine.cpp" - - - - - - - THIS_FILE="ThaiShaping.cpp" - - - - - - - THIS_FILE="ThaiStateTables.cpp" - - - - - - - THIS_FILE="TibetanLayoutEngine.cpp" - - - - - - - THIS_FILE="TibetanReordering.cpp" - - - - - - - THIS_FILE="TrimmedArrayProcessor.cpp" - - - - - - - THIS_FILE="ValueRecords.cpp" - - - - - - - /usr/include/freetype2 - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/font/layout - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d - ../../jdk/make - - - HEADLESS - LE_STANDALONE - THIS_FILE="sunFont.c" - - - - - - - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="Disposer.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="SurfaceData.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="Trace.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - + THIS_FILE="cmscam02.c" - - + THIS_FILE="cmscgats.c" - - + THIS_FILE="cmscnvrt.c" - - + THIS_FILE="cmserr.c" - - + THIS_FILE="cmsgamma.c" - - + THIS_FILE="cmsgmt.c" - - + THIS_FILE="cmshalf.c" - - + THIS_FILE="cmsintrp.c" - - + THIS_FILE="cmsio0.c" - - + THIS_FILE="cmsio1.c" - - + THIS_FILE="cmslut.c" - - + THIS_FILE="cmsmd5.c" - - + THIS_FILE="cmsmtrx.c" - - + THIS_FILE="cmsnamed.c" - - + THIS_FILE="cmsopt.c" - - + THIS_FILE="cmspack.c" - - + THIS_FILE="cmspcs.c" - - + THIS_FILE="cmsplugin.c" - - + THIS_FILE="cmsps2.c" - - + THIS_FILE="cmssamp.c" - - + THIS_FILE="cmssm.c" - - + THIS_FILE="cmstypes.c" - - + THIS_FILE="cmsvirt.c" - - + THIS_FILE="cmswtpnt.c" - - + THIS_FILE="cmsxform.c" - - - - - - THIS_FILE="AlphaMath.c" - - - - - - - THIS_FILE="Any3Byte.c" - - - - - - - THIS_FILE="Any4Byte.c" - - - - - - - THIS_FILE="AnyByte.c" - - - - - - - THIS_FILE="AnyInt.c" - - - - - - - THIS_FILE="AnyShort.c" - - - - - - - THIS_FILE="Blit.c" - - - - - - - THIS_FILE="BlitBg.c" - - - - - - - THIS_FILE="ByteBinary1Bit.c" - - - - - - - THIS_FILE="ByteBinary2Bit.c" - - - - - - - THIS_FILE="ByteBinary4Bit.c" - - - - - - - THIS_FILE="ByteGray.c" - - - - - - - THIS_FILE="ByteIndexed.c" - - - - - - - THIS_FILE="DrawLine.c" - - - - - - - THIS_FILE="DrawParallelogram.c" - - - - - - - THIS_FILE="DrawPath.c" - - - - - - - THIS_FILE="DrawPolygons.c" - - - - - - - THIS_FILE="DrawRect.c" - - - - - - - THIS_FILE="FillParallelogram.c" - - - - - - - THIS_FILE="FillPath.c" - - - - - - - THIS_FILE="FillRect.c" - - - - - - - THIS_FILE="FillSpans.c" - - - - - - - THIS_FILE="FourByteAbgr.c" - - - - - - - THIS_FILE="FourByteAbgrPre.c" - - - - - - - THIS_FILE="GraphicsPrimitiveMgr.c" - - - - - - - THIS_FILE="Index12Gray.c" - - - - - - - THIS_FILE="Index8Gray.c" - - - - - - - THIS_FILE="IntArgb.c" - - - - - - - THIS_FILE="IntArgbBm.c" - - - - - - - THIS_FILE="IntArgbPre.c" - - - - - - - THIS_FILE="IntBgr.c" - - - - - - - THIS_FILE="IntRgb.c" - - - - - - - THIS_FILE="IntRgbx.c" - - - - - - - THIS_FILE="MapAccelFunc.c" - - - - - - - THIS_FILE="MaskBlit.c" - - - - - - - THIS_FILE="MaskFill.c" - - - - - - - THIS_FILE="ProcessPath.c" - - - - - - - THIS_FILE="ScaledBlit.c" - - - - - - - THIS_FILE="ThreeByteBgr.c" - - - - - - - THIS_FILE="TransformHelper.c" - - - - - - - THIS_FILE="Ushort4444Argb.c" - - - - - - - THIS_FILE="Ushort555Rgb.c" - - - - - - - THIS_FILE="Ushort555Rgbx.c" - - - - - - - THIS_FILE="Ushort565Rgb.c" - - - - - - - THIS_FILE="UshortGray.c" - - - - - - - THIS_FILE="UshortIndexed.c" - - - - - - - - - THIS_FILE="OGLBufImgOps.c" - - - - - - - THIS_FILE="OGLContext.c" - - - - - - - THIS_FILE="OGLFuncs.c" - - - - - - - THIS_FILE="OGLMaskBlit.c" - - - - - - - THIS_FILE="OGLMaskFill.c" - - - - - - - THIS_FILE="OGLPaints.c" - - - - - - - THIS_FILE="OGLRenderQueue.c" - - - - - - - THIS_FILE="OGLRenderer.c" - - - - - - - THIS_FILE="OGLSurfaceData.c" - - - - - - - THIS_FILE="OGLTextRenderer.c" - + - - + - THIS_FILE="OGLVertexCache.c" + THIS_FILE="mlib_ImageAffineEdge.c" - - - - - - THIS_FILE="BufferedRenderPipe.c" - - - - - - - THIS_FILE="Region.c" - - - - - - - THIS_FILE="ShapeSpanIterator.c" - - - - - - - THIS_FILE="SpanClipRenderer.c" - - - - - - - - - THIS_FILE="Flag.c" - - - - - - - THIS_FILE="GarbageCollectorImpl.c" - - - - - - - THIS_FILE="GcInfoBuilder.c" - - - - - - - THIS_FILE="HotSpotDiagnostic.c" - - - - - - - THIS_FILE="HotspotThread.c" - - - - - - - THIS_FILE="MemoryImpl.c" - - - - - - - THIS_FILE="MemoryManagerImpl.c" - - - - - - - THIS_FILE="MemoryPoolImpl.c" - - - - - - - THIS_FILE="ThreadImpl.c" - - - - - - - THIS_FILE="VMManagementImpl.c" - - - - - - - THIS_FILE="management.c" - - - - - - - - - THIS_FILE="MessageUtils.c" - - - - - - - THIS_FILE="NativeSignalHandler.c" - - - - - - - THIS_FILE="Signal.c" - - - - - - - THIS_FILE="VM.c" - - - - - - - THIS_FILE="VMSupport.c" - - - - - - - THIS_FILE="Version.c" - - - - - - - - - + - THIS_FILE="NativeAccessors.c" + THIS_FILE="mlib_ImageAffine_BC_D64.c" - - + - THIS_FILE="Reflection.c" + THIS_FILE="mlib_ImageAffine_BC_F32.c" - - - - - - + - THIS_FILE="ec2_163.c" + THIS_FILE="mlib_ImageAffine_BC_S32.c" - - + - THIS_FILE="ec2_193.c" + THIS_FILE="mlib_ImageAffine_BL_D64.c" - - + - THIS_FILE="ec2_233.c" + THIS_FILE="mlib_ImageAffine_BL_F32.c" - - + - THIS_FILE="ec2_aff.c" + THIS_FILE="mlib_ImageAffine_BL_S32.c" - - + - THIS_FILE="ec2_mont.c" + THIS_FILE="mlib_ImageAffine_NN.c" - - + - THIS_FILE="ec_naf.c" + THIS_FILE="mlib_ImageAffine_NN_Bit.c" - - + - THIS_FILE="ecdecode.c" + THIS_FILE="mlib_ImageClipping.c" - - + - THIS_FILE="ecl.c" + THIS_FILE="mlib_ImageColorTrue2Index.c" - - + - THIS_FILE="ecl_curve.c" + THIS_FILE="mlib_ImageConv2x2_f.c" - - + - THIS_FILE="ecl_gf.c" + THIS_FILE="mlib_ImageConvClearEdge_Bit.c" - - + - THIS_FILE="ecl_mult.c" + THIS_FILE="mlib_ImageConvClearEdge_Fp.c" - - + - THIS_FILE="ecp_192.c" + THIS_FILE="mlib_ImageConvCopyEdge_Bit.c" - - + - THIS_FILE="ecp_224.c" + THIS_FILE="mlib_ImageConvKernelConvert.c" - - + - THIS_FILE="ecp_256.c" + THIS_FILE="mlib_ImageConvMxN.c" - - + - THIS_FILE="ecp_384.c" + THIS_FILE="mlib_ImageConvMxN_Fp.c" - - + - THIS_FILE="ecp_521.c" + THIS_FILE="mlib_ImageConvMxN_ext.c" - - + - THIS_FILE="ecp_aff.c" + THIS_FILE="mlib_ImageConv_16ext.c" - - + - THIS_FILE="ecp_jac.c" + THIS_FILE="mlib_ImageConv_16nw.c" - - + - THIS_FILE="ecp_jm.c" + THIS_FILE="mlib_ImageConv_32nw.c" - - + - THIS_FILE="ecp_mont.c" + THIS_FILE="mlib_ImageConv_8ext.c" - - + - THIS_FILE="mp_gf2m.c" + THIS_FILE="mlib_ImageConv_8nw.c" - - + - THIS_FILE="mpi.c" + THIS_FILE="mlib_ImageConv_D64nw.c" - - + - THIS_FILE="mplogic.c" + THIS_FILE="mlib_ImageConv_F32nw.c" - - + - THIS_FILE="mpmontg.c" + THIS_FILE="mlib_ImageConv_u16ext.c" - - + - THIS_FILE="oid.c" + THIS_FILE="mlib_ImageConv_u16nw.c" - - + - THIS_FILE="secitem.c" + THIS_FILE="mlib_ImageDivTables.c" - - - - + - THIS_FILE="NativeUtil.c" + THIS_FILE="mlib_ImageFilters.c" - - + - THIS_FILE="j2secmod.c" + THIS_FILE="mlib_ImageLookUp_64.c" - - - - + - THIS_FILE="p11_crypt.c" + THIS_FILE="mlib_ImageLookUp_Bit.c" - - + - THIS_FILE="p11_digest.c" + THIS_FILE="mlib_ImageScanPoly.c" - - + - THIS_FILE="p11_dual.c" + THIS_FILE="mlib_ImageUtils.c" - - + - THIS_FILE="p11_general.c" + THIS_FILE="mlib_c_ImageAffineIndex_BC.c" - - + - THIS_FILE="p11_keymgmt.c" + THIS_FILE="mlib_c_ImageAffineIndex_BL.c" - - + - THIS_FILE="p11_mutex.c" + THIS_FILE="mlib_c_ImageAffine_BC.c" - - + - THIS_FILE="p11_objmgmt.c" + THIS_FILE="mlib_c_ImageAffine_BC_S16.c" - - + - THIS_FILE="p11_sessmgmt.c" + THIS_FILE="mlib_c_ImageAffine_BC_U16.c" - - + - THIS_FILE="p11_sign.c" + THIS_FILE="mlib_c_ImageAffine_BL.c" - - + - THIS_FILE="p11_util.c" + THIS_FILE="mlib_c_ImageAffine_BL_S16.c" - - - - - - - - + - THIS_FILE="utf.c" + THIS_FILE="mlib_c_ImageAffine_BL_U16.c" - - - - - - - - THIS_FILE="linker_md.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - + - LIBARCHNAME="amd64" + THIS_FILE="mlib_c_ImageAffine_NN.c" - - - - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - + - LIBARCHNAME="amd64" - THIS_FILE="ergo_i586.c" + THIS_FILE="mlib_c_ImageConvClearEdge.c" - - - - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - + - LIBARCHNAME="amd64" - THIS_FILE="java_md_common.c" + THIS_FILE="mlib_c_ImageConvCopyEdge.c" - - - - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - + - LIBARCHNAME="amd64" - THIS_FILE="java_md_solinux.c" + THIS_FILE="mlib_c_ImageConvVersion.c" - - - - ../../jdk/src/share/bin - ../../jdk/make - - - THIS_FILE="jexec.c" - - - - - - - - - + - THIS_FILE="FileSystemSupport_md.c" + THIS_FILE="mlib_c_ImageConv_f.c" - - - - + - THIS_FILE="UnixOperatingSystem_md.c" + THIS_FILE="mlib_c_ImageCopy.c" - - - - + - THIS_FILE="PLATFORM_API_LinuxOS_ALSA_MidiIn.c" + THIS_FILE="mlib_c_ImageLookUp.c" - - + - THIS_FILE="PLATFORM_API_LinuxOS_ALSA_MidiOut.c" + THIS_FILE="mlib_c_ImageLookUp_f.c" - - + - THIS_FILE="PLATFORM_API_LinuxOS_ALSA_MidiUtils.c" + THIS_FILE="mlib_c_ImageThresh1_U8.c" - - - - THIS_FILE="PLATFORM_API_LinuxOS_ALSA_PCM.c" - + - - + - THIS_FILE="PLATFORM_API_LinuxOS_ALSA_PCMUtils.c" + THIS_FILE="gif_err.c" - - + - THIS_FILE="PLATFORM_API_LinuxOS_ALSA_Ports.c" + THIS_FILE="gifalloc.c" - - - - - - + - THIS_FILE="jni_util_md.c" + THIS_FILE="java_awt_SplashScreen.c" - - - - - - THIS_FILE="FileDescriptor_md.c" - + - - + - THIS_FILE="FileInputStream_md.c" + THIS_FILE="pngerror.c" - - + - THIS_FILE="FileOutputStream_md.c" + THIS_FILE="pngget.c" - - + - THIS_FILE="RandomAccessFile_md.c" + THIS_FILE="pngmem.c" - - + - THIS_FILE="UnixFileSystem_md.c" + THIS_FILE="pngpread.c" - - + - THIS_FILE="canonicalize_md.c" + THIS_FILE="pngread.c" - - + - THIS_FILE="io_util_md.c" + THIS_FILE="pngrio.c" - - - - + - THIS_FILE="UNIXProcess_md.c" + THIS_FILE="pngrtran.c" - - + - THIS_FILE="java_props_md.c" + THIS_FILE="pngrutil.c" - - - - + - THIS_FILE="Inet6AddressImpl.c" + THIS_FILE="pngset.c" - - + - THIS_FILE="InetAddressImplFactory.c" + THIS_FILE="pngtrans.c" - - + - THIS_FILE="NetworkInterface.c" + THIS_FILE="pngwio.c" - - + - THIS_FILE="PlainDatagramSocketImpl.c" + THIS_FILE="pngwrite.c" - - + - THIS_FILE="PlainSocketImpl.c" + THIS_FILE="pngwtran.c" - - + - THIS_FILE="SocketInputStream.c" + THIS_FILE="pngwutil.c" - - + - THIS_FILE="SocketOutputStream.c" + THIS_FILE="splashscreen_gfx_impl.c" - - + - THIS_FILE="linux_close.c" + THIS_FILE="splashscreen_gif.c" - - + - THIS_FILE="net_util_md.c" + THIS_FILE="splashscreen_impl.c" - - - - - - + - THIS_FILE="TimeZone_md.c" + THIS_FILE="splashscreen_jpeg.c" - - + - THIS_FILE="logging.c" + THIS_FILE="splashscreen_png.c" - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="CUPSfuncs.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - + - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - + - HEADLESS=true - PACKAGE_PATH="/opt/local" - THIS_FILE="HeadlessToolkit.c" - X11_PATH="/usr/X11R6" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - HEADLESS=true - PACKAGE_PATH="/opt/local" - THIS_FILE="VDrawingArea.c" - X11_PATH="/usr/X11R6" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" THIS_FILE="X11Color.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - + - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_AWTEvent.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_DrawingSurface.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_Event.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" THIS_FILE="awt_Font.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - + - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_GraphicsEnv.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_InputMethod.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_Insets.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="awt_LoadLibrary.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="awt_Mlib.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_Plugin.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_Robot.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_UNIXToolkit.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_util.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" THIS_FILE="fontpath.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="gtk2_interface.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - + - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="initIDs.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="jawt.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="list.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="multiVis.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="multi_font.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="robot_common.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="sun_awt_X11_GtkFileDialogPeer.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="swing_GTKEngine.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="swing_GTKStyle.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - - - THIS_FILE="X11TextRenderer.c" - - - - - - - + THIS_FILE="GLXSurfaceData.c" - + + - - + THIS_FILE="X11PMBlitLoops.c" - - + THIS_FILE="X11Renderer.c" - - + THIS_FILE="X11SurfaceData.c" - - + THIS_FILE="X11TextRenderer_md.c" - - + + + + + - THIS_FILE="XRBackendNative.c" + THIS_FILE="awt_Mlib.c" - - + + + THIS_FILE="initIDs.c" + + + + + + + + + + + THIS_FILE="VDrawingArea.c" + + + + + + + + + + + THIS_FILE="awt_DrawingSurface.c" + + + + + + + THIS_FILE="awt_Event.c" + + + + + + + THIS_FILE="awt_GraphicsEnv.c" + + + + + + + THIS_FILE="awt_InputMethod.c" + + + + + + + THIS_FILE="awt_Insets.c" + + + + + + + THIS_FILE="awt_Robot.c" + + + + + + + THIS_FILE="awt_UNIXToolkit.c" + + + + + + + THIS_FILE="awt_util.c" + + + + + + + THIS_FILE="gtk2_interface.c" + + + + + + + THIS_FILE="list.c" + + + + + + + THIS_FILE="multiVis.c" + + + + + + + THIS_FILE="multi_font.c" + + + + + + + THIS_FILE="robot_common.c" + + + + + + + THIS_FILE="sun_awt_X11_GtkFileDialogPeer.c" + + + + + + + THIS_FILE="swing_GTKEngine.c" + + + + + + + THIS_FILE="swing_GTKStyle.c" + + + + + + + + + THIS_FILE="XRSurfaceData.c" - - - - - - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="DatagramChannelImpl.c" - + - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="DatagramDispatcher.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="EPoll.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="EPollArrayWrapper.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="EPollPort.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="FileChannelImpl.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="FileDispatcherImpl.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="FileKey.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="IOUtil.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="InheritedChannel.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="NativeThread.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="Net.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="PollArrayWrapper.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="ServerSocketChannelImpl.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="SocketChannelImpl.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="SocketDispatcher.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="UnixAsynchronousServerSocketChannelImpl.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="UnixAsynchronousSocketChannelImpl.c" - - - - - - - - - THIS_FILE="SctpNet.c" - - - - - - - THIS_FILE="SctpServerChannelImpl.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/nio/ch - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/nio/ch - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="LinuxNativeDispatcher.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/nio/ch - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="LinuxWatchService.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/nio/ch - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="MagicFileTypeDetector.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/nio/ch - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="UnixCopyFile.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/nio/ch - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="UnixNativeDispatcher.c" - - - - - - - ../../jdk/make - - - THIS_FILE="genUnixConstants.c" - - - - - - - - - THIS_FILE="j2secmod_md.c" - - - - - - - - - - - - - - - - - + THIS_FILE="XWindow.c" - - + THIS_FILE="XlibWrapper.c" - - + THIS_FILE="awt_Desktop.c" - - + THIS_FILE="gnome_interface.c" - - - + + - + + + + THIS_FILE="X11TextRenderer.c" + + + + + + + + + + + + + + + THIS_FILE="PLATFORM_API_LinuxOS_ALSA_MidiIn.c" + + + + + + + THIS_FILE="PLATFORM_API_LinuxOS_ALSA_MidiOut.c" + + + + + + + THIS_FILE="PLATFORM_API_LinuxOS_ALSA_MidiUtils.c" + + + + + + + THIS_FILE="PLATFORM_API_LinuxOS_ALSA_PCM.c" + + + + + + + THIS_FILE="PLATFORM_API_LinuxOS_ALSA_PCMUtils.c" + + + + + + + THIS_FILE="PLATFORM_API_LinuxOS_ALSA_Ports.c" + + + + + + + + + + + + + + + THIS_FILE="InstrumentationImplNativeMethods.c" + + + + + + + THIS_FILE="InvocationAdapter.c" + + + + + + + THIS_FILE="JPLISAgent.c" + + + + + + + THIS_FILE="JPLISAssert.c" + + + + + + + THIS_FILE="JarFacade.c" + + + + + + + THIS_FILE="JavaExceptions.c" + + + + + + + THIS_FILE="PathCharsValidator.c" + + + + + + + THIS_FILE="Reentrancy.c" + + + + + + + THIS_FILE="Utilities.c" + + + + + + + + + + + THIS_FILE="FileSystemSupport_md.c" + + + + + + + + + + + THIS_FILE="GarbageCollectorImpl.c" + + + + + + + THIS_FILE="HotspotThread.c" + + + + + + + THIS_FILE="MemoryImpl.c" + + + + + + + THIS_FILE="MemoryManagerImpl.c" + + + + + + + THIS_FILE="MemoryPoolImpl.c" + + + + + + + THIS_FILE="ThreadImpl.c" + + + + + + + THIS_FILE="VMManagementImpl.c" + + + + + + + THIS_FILE="management.c" + + + + + + + + + + + + + + + + + + + THIS_FILE="NativeUtil.c" + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + THIS_FILE="ec2_163.c" + + + + + + + THIS_FILE="ec2_193.c" + + + + + + + THIS_FILE="ec2_233.c" + + + + + + + THIS_FILE="ec2_aff.c" + + + + + + + THIS_FILE="ec2_mont.c" + + + + + + + THIS_FILE="ec_naf.c" + + + + + + + THIS_FILE="ecdecode.c" + + + + + + + THIS_FILE="ecl.c" + + + + + + + THIS_FILE="ecl_curve.c" + + + + + + + THIS_FILE="ecl_gf.c" + + + + + + + THIS_FILE="ecl_mult.c" + + + + + + + THIS_FILE="ecp_192.c" + + + + + + + THIS_FILE="ecp_224.c" + + + + + + + THIS_FILE="ecp_256.c" + + + + + + + THIS_FILE="ecp_384.c" + + + + + + + THIS_FILE="ecp_521.c" + + + + + + + THIS_FILE="ecp_aff.c" + + + + + + + THIS_FILE="ecp_jac.c" + + + + + + + THIS_FILE="ecp_jm.c" + + + + + + + THIS_FILE="ecp_mont.c" + + + + + + + THIS_FILE="mp_gf2m.c" + + + + + + + THIS_FILE="mpi.c" + + + + + + + THIS_FILE="mplogic.c" + + + + + + + THIS_FILE="mpmontg.c" + + + + + + + THIS_FILE="oid.c" + + + + + + + THIS_FILE="secitem.c" + + + + + + + + + + + THIS_FILE="p11_convert.c" + + + + + + + THIS_FILE="p11_crypt.c" + + + + + + + THIS_FILE="p11_digest.c" + + + + + + + THIS_FILE="p11_dual.c" + + + + + + + THIS_FILE="p11_general.c" + + + + + + + THIS_FILE="p11_keymgmt.c" + + + + + + + THIS_FILE="p11_mutex.c" + + + + + + + THIS_FILE="p11_objmgmt.c" + + + + + + + THIS_FILE="p11_sessmgmt.c" + + + + + + + THIS_FILE="p11_sign.c" + + + + + + + THIS_FILE="p11_util.c" + + + + + + + + + + + THIS_FILE="p11_md.c" + + + + + + + + + + + + + + + THIS_FILE="ArrayTypeImpl.c" + + + + + + + THIS_FILE="ClassLoaderReferenceImpl.c" + + + + + + + THIS_FILE="ClassObjectReferenceImpl.c" + + + + + + + THIS_FILE="ClassTypeImpl.c" + + + + + + + THIS_FILE="EventRequestImpl.c" + + + + + + + THIS_FILE="FieldImpl.c" + + + + + + + THIS_FILE="FrameID.c" + + + + + + + THIS_FILE="InterfaceTypeImpl.c" + + + + + + + THIS_FILE="MethodImpl.c" + + + + + + + THIS_FILE="ObjectReferenceImpl.c" + + + + + + + THIS_FILE="ReferenceTypeImpl.c" + + + + + + + THIS_FILE="SDE.c" + + + + + + + THIS_FILE="StackFrameImpl.c" + + + + + + + THIS_FILE="StringReferenceImpl.c" + + + + + + + THIS_FILE="ThreadGroupReferenceImpl.c" + + + + + + + THIS_FILE="ThreadReferenceImpl.c" + + + + + + + THIS_FILE="VirtualMachineImpl.c" + + + + + + + THIS_FILE="bag.c" + + + + + + + THIS_FILE="classTrack.c" + + + + + + + THIS_FILE="commonRef.c" + + + + + + + THIS_FILE="debugDispatch.c" + + + + + + + THIS_FILE="debugInit.c" + + + + + + + THIS_FILE="debugLoop.c" + + + + + + + THIS_FILE="error_messages.c" + + + + + + + THIS_FILE="eventFilter.c" + + + + + + + THIS_FILE="eventHandler.c" + + + + + + + THIS_FILE="eventHelper.c" + + + + + + + THIS_FILE="inStream.c" + + + + + + + THIS_FILE="invoker.c" + + + + + + + THIS_FILE="log_messages.c" + + + + + + + THIS_FILE="outStream.c" + + + + + + + THIS_FILE="standardHandlers.c" + + + + + + + THIS_FILE="stepControl.c" + + + + + + + THIS_FILE="stream.c" + + + + + + + THIS_FILE="threadControl.c" + + + + + + + THIS_FILE="transport.c" + + + + + + + THIS_FILE="utf_util.c" + + + + + + + THIS_FILE="util.c" + + + + + + + + + + + + + + + THIS_FILE="linker_md.c" + + + + + + + + + + + + + + + THIS_FILE="Flag.c" + + + + + + + THIS_FILE="GarbageCollectorExtImpl.c" + + + + + + + THIS_FILE="GcInfoBuilder.c" + + + + + + + THIS_FILE="HotSpotDiagnostic.c" + + + + + + + THIS_FILE="management_ext.c" + + + + + + + + + + + + + + + THIS_FILE="bytes.cpp" + + + + + + + THIS_FILE="coding.cpp" + + + + + + + THIS_FILE="unpack.cpp" + + + + + + + THIS_FILE="utils.cpp" + + + + + + + THIS_FILE="zip.cpp" + + + + + + + + + + + + + + + + + + + THIS_FILE="SctpNet.c" + + + + + + + THIS_FILE="SctpServerChannelImpl.c" + + + + + + + + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/image/cvutils + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -20546,19 +45491,16 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated AMD64 + ASSERT COMPILER1 COMPILER2 - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT TARGET_ARCH_MODEL_x86_64 TARGET_ARCH_x86 TARGET_COMPILER_gcc @@ -20567,22 +45509,21 @@ TARGET_OS_FAMILY_linux VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - - __EXCEPTIONS - __GXX_RTTI - - + _GNU_SOURCE + _REENTRANT AMD64 + ASSERT COMPILER1 COMPILER2 TARGET_ARCH_MODEL_x86_64 @@ -20598,84 +45539,92 @@ - - + + - ../../hotspot/agent/src/os/linux - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated - ${IDE_ALT_BOOTDIR}/include - ${IDE_ALT_BOOTDIR}/include/linux - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/hotspot/linux_amd64_compiler2/generated + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_VM_DISTRO="OpenJDK" + VM_LITTLE_ENDIAN + _LP64=1 + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/jdk.hotspot.agent/share/native/libsaproc + ../../hotspot/src/jdk.hotspot.agent/linux/native/libsaproc + ../../build/support/headers/jdk.hotspot.agent + ../../hotspot/src/os/linux + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../make + + + ARCH="amd64" + DEBUG + LINUX + THIS_FILE="LinuxDebuggerLocal.c" _FILE_OFFSET_BITS=64 + _LARGEFILE64_SOURCE + _LITTLE_ENDIAN + _LP64=1 amd64 - - - - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product - ../../hotspot/src/share/vm/prims - ../../hotspot/src/share/vm - ../../hotspot/src/share/vm/precompiled - ../../hotspot/src/cpu/x86/vm - ../../hotspot/src/os_cpu/linux_x86/vm - ../../hotspot/src/os/linux/vm - ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated - - - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN - _LP64=1 - - - - - - - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product - ../../hotspot/src/share/vm/prims - ../../hotspot/src/share/vm - ../../hotspot/src/share/vm/precompiled - ../../hotspot/src/cpu/x86/vm - ../../hotspot/src/os_cpu/linux_x86/vm - ../../hotspot/src/os/linux/vm - ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated - - - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN - _LP64=1 - - - - + - - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product - - _REENTRANT + THIS_FILE="sadis.c" - + + + + ../../build/hotspot/linux_amd64_compiler2/debug + + + + + ../../build/hotspot/linux_amd64_compiler2/debug + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/linux_x86/vm + ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm + ../../build/hotspot/linux_amd64_compiler2/generated + + + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_VM_DISTRO="OpenJDK" + VM_LITTLE_ENDIAN + _LP64=1 + _NMT_NOINLINE_ + + + + ../../hotspot/src/os/posix/launcher @@ -20712,10 +45661,10 @@ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -20723,22 +45672,19 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + ../../hotspot/src/os/posix/launcher @@ -20775,7 +45721,7 @@ - + ../../hotspot/src/share/vm/prims @@ -20786,18 +45732,15 @@ ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm ../../hotspot/src/share/vm/adlc - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/debug - - ASSERT - - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -20805,25 +45748,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -20831,25 +45771,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -20857,25 +45794,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -20883,25 +45817,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -20909,25 +45840,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -20935,25 +45863,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -20961,25 +45886,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -20987,25 +45909,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -21013,25 +45932,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -21039,25 +45955,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -21065,25 +45978,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -21091,25 +46001,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -21117,25 +46024,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -21143,25 +46047,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -21169,25 +46070,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -21195,25 +46093,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -21221,25 +46116,22 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../build/hotspot/linux_amd64_compiler2/debug ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm ../../hotspot/src/share/vm/precompiled @@ -21247,32 +46139,27 @@ ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + ../../build/hotspot/linux_amd64_compiler2/generated - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT VM_LITTLE_ENDIAN _LP64=1 + _NMT_NOINLINE_ - + - THIS_FILE="ArrayReferenceImpl.c" + THIS_FILE="genSocketOptionRegistry.c" ARCH="amd64" - NDEBUG - RELEASE="" THIS_FILE="Agent.cpp" _LARGEFILE64_SOURCE _LITTLE_ENDIAN @@ -21281,81 +46168,25 @@ - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/transport/export - ../../jdk/src/share/back/export - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/src/share/back - ../../jdk/src/solaris/back - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_jdwp_headers - ../../jdk/make + ../../jdk/make/gensrc + + + + - ARCH="amd64" - JDWP_LOGGING - LINUX - NDEBUG - RELEASE="" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 + THIS_FILE="genUnixConstants.c" - + - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - - - ARCH="amd64" - LIBARCHNAME="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="java.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ARCH="amd64" LINUX - NDEBUG - RELEASE="" THIS_FILE="agent_util.c" _GNU_SOURCE _LARGEFILE64_SOURCE @@ -21365,35 +46196,54 @@ amd64 + + + + + DEBUG + + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../jdk/src/share/demo/jvmti/waiters - ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/waiters + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make + + DEBUG + - + - ../../jdk/src/share/demo/jvmti/heapTracker - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/src/demo/share/jvmti/heapTracker + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/java_crw_demo + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make - + - ../../jdk/src/share/demo/jvmti/compiledMethodLoad - ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/compiledMethodLoad + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -21401,11 +46251,16 @@ - + - ../../jdk/src/share/demo/jvmti/gctest - ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/gctest + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -21413,12 +46268,17 @@ - + - ../../jdk/src/share/demo/jvmti/heapTracker - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/src/demo/share/jvmti/heapTracker + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/java_crw_demo + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -21426,11 +46286,16 @@ - + - ../../jdk/src/share/demo/jvmti/heapViewer - ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/heapViewer + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -21438,29 +46303,17 @@ - + - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/demo/jvmti/hprof - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/src/share/demo/jvmti/java_crw_demo - ../../jdk/make - - - THIS_FILE="debug_malloc.c" - - - - - - - ../../jdk/src/share/demo/jvmti/hprof - ../../jdk/src/solaris/demo/jvmti/hprof - ../../jdk/src/share/demo/jvmti/java_crw_demo - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt + ../../jdk/src/demo/share/jvmti/heapTracker + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/java_crw_demo + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -21468,12 +46321,17 @@ - + - ../../jdk/src/share/demo/jvmti/minst - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/src/demo/share/jvmti/minst + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/java_crw_demo + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -21481,12 +46339,17 @@ - + - ../../jdk/src/share/demo/jvmti/mtrace - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/src/demo/share/jvmti/mtrace + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/java_crw_demo + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -21494,11 +46357,16 @@ - + - ../../jdk/src/share/demo/jvmti/versionCheck - ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/versionCheck + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -21506,493 +46374,893 @@ - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/instrument - ../../jdk/src/solaris/instrument - ../../jdk/src/share/bin - ../../jdk/make - - - ARCH="amd64" - LINUX - NDEBUG - NO_JPLIS_LOGGING - RELEASE="" - THIS_FILE="EncodingSupport.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - + - THIS_FILE="DirectAudioDevice.c" + THIS_FILE="ProcessHandleImpl_linux.c" + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjimage + ../../build/support/headers/java.base + ../../make + - THIS_FILE="bands.cpp" + THIS_FILE="ImageNativeSubstrate.cpp" - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/com/sun/media/sound - ../../jdk/src/solaris/native/com/sun/media/sound - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava - ARCH="amd64" - EXTRA_SOUND_JNI_LIBS=" jsoundalsa" - LINUX - NDEBUG - RELEASE="" - X_ARCH=X_AMD64 - X_PLATFORM=X_LINUX - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 + DEBUG - - - FULL - PRODUCT - - - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="check_code.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="FileInputStream.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/share/native/libfdlibm + ../../build/support/headers/java.base + ../../make ARCHPROPNAME="amd64" - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../build/support/headers/java.base + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/linux/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../make + THIS_FILE="linux_close.c" + + + + + + + ../../jdk/src/java.base/share/native/libnio + ../../jdk/src/java.base/share/native/libnio/ch + ../../jdk/src/java.base/unix/native/libnio + ../../jdk/src/java.base/linux/native/libnio/ch + ../../jdk/src/java.base/linux/native/libnio/fs + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/unix/native/libnio/fs + ../../build/support/headers/java.base + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/linux/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../make + + + THIS_FILE="EPoll.c" + + + + + + + THIS_FILE="LinuxNativeDispatcher.c" + + + + + + + THIS_FILE="main.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/launcher + ../../jdk/src/java.base/share/native/libjli + ../../jdk/src/java.base/unix/native/libjli + ../../jdk/src/java.base/linux/native/libjli + ../../make + + + DEBUG + EXPAND_CLASSPATH_WILDCARDS + JAVA_ARGS={ "-J-ms8m", "com.sun.tools.javac.Main", } + LAUNCHER_NAME="openjdk" + NEVER_ACT_AS_SERVER_CLASS_MACHINE + PROGNAME="javac" + VERSION_BUILD=0 + VERSION_MAJOR=9 + VERSION_MINOR=0 + VERSION_NUMBER="9" + VERSION_OPT="2016-06-20-224455.vkvashin.jdktrunk" + VERSION_PATCH=0 + VERSION_PRE="internal" + VERSION_SECURITY=0 + VERSION_SHORT="9-internal" + VERSION_SPECIFICATION="9" + VERSION_STRING="9-internal+0-2016-06-20-224455.vkvashin.jdktrunk" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libfdlibm + ../../make + + + DEBUG + LIBRARY_NAME=fdlibm THIS_FILE="e_acos.c" - + - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Finalizer.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Array.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/src/solaris/native/sun/net/dns - ../../jdk/src/solaris/native/sun/net/spi - ../../jdk/src/solaris/native/sun/net/sdp - ../../jdk/make - - - THIS_FILE="DatagramPacket.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Bits.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/share/native/libfdlibm + ../../build/support/headers/java.base + ../../make ARCHPROPNAME="amd64" + DEBUG THIS_FILE="AccessController.c" - - - - THIS_FILE="AtomicLong.c" - - - - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/unix/native/libjli + ../../jdk/src/java.base/share/native/libjli + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../make - ARCHPROPNAME="amd64" + DEBUG + LIBARCHNAME="amd64" + THIS_FILE="args.c" - + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.base + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/linux/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../make + + + DEBUG + THIS_FILE="DatagramPacket.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libnio + ../../jdk/src/java.base/share/native/libnio/ch + ../../jdk/src/java.base/unix/native/libnio + ../../jdk/src/java.base/linux/native/libnio/ch + ../../jdk/src/java.base/linux/native/libnio/fs + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/unix/native/libnio/fs + ../../build/support/headers/java.base + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/linux/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../make + + + DEBUG + THIS_FILE="nio_util.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../make + + + DEBUG + THIS_FILE="check_code.c" + + + + THIS_FILE="compress.c" - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + DEBUG + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN WITH_X11 - + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + + + DEBUG + THIS_FILE="jexec.c" + + + + + THIS_FILE="osSupport_unix.cpp" + + + + + + + ../../jdk/src/java.base/share/native/libjli + ../../make + + + + + + + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/share/native/libfdlibm + ../../build/support/headers/java.base + ../../make + + + ARCHPROPNAME="amd64" + THIS_FILE="Console_md.c" + + + + + + + ../../jdk/src/java.base/unix/native/libjli + ../../jdk/src/java.base/share/native/libjli + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../make + + + LIBARCHNAME="amd64" + THIS_FILE="ergo.c" + + + + + + + ../../build/support/headers/java.base + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/linux/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../make + + + THIS_FILE="DefaultProxySelector.c" + + + + + + + ../../jdk/src/java.base/share/native/libnio + ../../jdk/src/java.base/share/native/libnio/ch + ../../jdk/src/java.base/unix/native/libnio + ../../jdk/src/java.base/linux/native/libnio/ch + ../../jdk/src/java.base/linux/native/libnio/fs + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/unix/native/libnio/fs + ../../build/support/headers/java.base + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/linux/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../make + + + THIS_FILE="DatagramChannelImpl.c" + + + + + THIS_FILE="GioFileTypeDetector.c" + + + + + + + DEBUG THIS_FILE="debug_assert.c" - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz/hb-ucdn + ../../jdk/src/java.desktop/share/native/libfontmanager/layout + ../../jdk/src/java.desktop/unix/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/awt + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/java2d + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/java2d + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + /usr/include/freetype2 + ../../make - THIS_FILE="AlternateSubstSubtables.cpp" + DEBUG + GETPAGESIZE + HAVE_FALLBACK + HAVE_INTEL_ATOMIC_PRIMITIVES + HAVE_MPROTECT + HAVE_OT + HAVE_PTHREAD + HAVE_SYSCONF + HAVE_SYS_MMAN_H + HAVE_UCDN + HAVE_UNISTD_H + HEADLESS + LE_STANDALONE + THIS_FILE="hb-blob.cc" - - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + + + + + + + ../../jdk/src/java.desktop/unix/native/libawt_xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d/x11 + ../../jdk/src/java.desktop/unix/native/libawt_xawt/xawt + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/linux/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/unix/native/libsunwjdga + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.base/linux/native/libjava + ../../make - INTERNAL_BUILD PACKAGE_PATH="/opt/local" - X11_PATH="/usr/X11R6" XAWT XAWT_HACK - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/libmlib_image + ../../make + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageCopy_Bit.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/java.desktop/unix/native/libawt_xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d/x11 + ../../jdk/src/java.desktop/unix/native/libawt_xawt/xawt + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/linux/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/unix/native/libsunwjdga + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.base/linux/native/libjava + ../../make + + + PACKAGE_PATH="/opt/local" + THIS_FILE="rect.c" + XAWT + XAWT_HACK + + + + + + + ../../jdk/src/java.desktop/unix/native/libawt_xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d/x11 + ../../jdk/src/java.desktop/unix/native/libawt_xawt/xawt + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/linux/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/unix/native/libsunwjdga + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.base/linux/native/libjava + ../../make + + + PACKAGE_PATH="/opt/local" + THIS_FILE="AccelGlyphCache.c" + XAWT + XAWT_HACK + + + + + + + ../../jdk/src/java.desktop/unix/native/libawt_xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d/x11 + ../../jdk/src/java.desktop/unix/native/libawt_xawt/xawt + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/linux/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/unix/native/libsunwjdga + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.base/linux/native/libjava + ../../make + + + PACKAGE_PATH="/opt/local" + THIS_FILE="OGLBlitLoops.c" + XAWT + XAWT_HACK + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../make + + + MLIB_NO_LIBSUNMATH + THIS_FILE="img_colors.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + THIS_FILE="gifdecoder.c" + + + + + + + THIS_FILE="awt_ImagingLib.c" + + + + + + + THIS_FILE="AlphaMacros.c" + + + + + + + THIS_FILE="BufferedMaskBlit.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz/hb-ucdn + ../../jdk/src/java.desktop/share/native/libfontmanager/layout + ../../jdk/src/java.desktop/unix/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/awt + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/java2d + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/java2d + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + /usr/include/freetype2 + ../../make + + + GETPAGESIZE + HAVE_FALLBACK + HAVE_INTEL_ATOMIC_PRIMITIVES + HAVE_MPROTECT + HAVE_OT + HAVE_PTHREAD + HAVE_SYSCONF + HAVE_SYS_MMAN_H + HAVE_UCDN + HAVE_UNISTD_H + HEADLESS + LE_STANDALONE + THIS_FILE="ucdn.c" + + + + + + + THIS_FILE="AlternateSubstSubtables.cpp" + + + + + + + THIS_FILE="imageioJPEG.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + + + EXTRA_SOUND_JNI_LIBS=" jsoundalsa" + THIS_FILE="DirectAudioDevice.c" + X_PLATFORM=X_LINUX + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/liblcms + ../../make + + + CMS_DONT_USE_FAST_FLOOR + THIS_FILE="LCMS.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/libmlib_image + ../../make + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="dgif_lib.c" @@ -22000,811 +47268,316 @@ - + - THIS_FILE="img_colors.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="gifdecoder.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - THIS_FILE="imageioJPEG.c" - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN THIS_FILE="png.c" - WITH_X11 - + - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - - MLIB_NO_LIBSUNMATH - THIS_FILE="awt_ImagingLib.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES + THIS_FILE="CUPSfuncs.c" - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/unix/native/libawt_xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d/x11 + ../../jdk/src/java.desktop/unix/native/libawt_xawt/xawt + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/linux/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/unix/native/libsunwjdga + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.base/linux/native/libjava + ../../make - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="java_awt_SplashScreen.c" - WITH_X11 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD PACKAGE_PATH="/opt/local" - THIS_FILE="rect.c" - X11_PATH="/usr/X11R6" XAWT XAWT_HACK - + - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="AccelGlyphCache.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 + THIS_FILE="GLXGraphicsConfig.c" - + + + + + THIS_FILE="X11FontScaler_md.c" + + + + + - /usr/include/freetype2 - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/font/layout - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../make + MLIB_NO_LIBSUNMATH + THIS_FILE="awt_LoadLibrary.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/unix/native/libawt_headless/awt + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.desktop/unix/native/libsunwjdga + ../../jdk/src/java.base/linux/native/libjava + ../../make + + + HEADLESS=true + PACKAGE_PATH="/opt/local" + THIS_FILE="HeadlessToolkit.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/unix/native/libawt_xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d/x11 + ../../jdk/src/java.desktop/unix/native/libawt_xawt/xawt + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/linux/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/unix/native/libsunwjdga + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.base/linux/native/libjava + ../../make + + + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_AWTEvent.c" + XAWT + XAWT_HACK + + + + + + + THIS_FILE="XRBackendNative.c" + + + + + + + THIS_FILE="XToolkit.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz/hb-ucdn + ../../jdk/src/java.desktop/share/native/libfontmanager/layout + ../../jdk/src/java.desktop/unix/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/awt + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/java2d + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/java2d + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + /usr/include/freetype2 + ../../make + + + GETPAGESIZE + HAVE_FALLBACK + HAVE_INTEL_ATOMIC_PRIMITIVES + HAVE_MPROTECT + HAVE_OT + HAVE_PTHREAD + HAVE_SYSCONF + HAVE_SYS_MMAN_H + HAVE_UCDN + HAVE_UNISTD_H HEADLESS LE_STANDALONE + THIS_FILE="X11FontScaler.c" - + - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/linux/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.base/linux/native/libjava + ../../make - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="LCMS.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 + THIS_FILE="jawt.c" - + - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/make - - - - - - - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="AlphaMacros.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="OGLBlitLoops.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - MLIB_NO_LIBSUNMATH - THIS_FILE="BufferedMaskBlit.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/management - ../../jdk/make - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="ClassLoadingImpl.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCH="amd64" - ARCHPROPNAME="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="GC.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ../../jdk/make - - - THIS_FILE="genSocketOptionRegistry.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCH="amd64" - ARCHPROPNAME="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="ConstantPool.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="ec.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - ../../jdk/src/share/native/sun/security/ec - ../../jdk/src/share/native/sun/security/ec/impl - ../../jdk/make - - - THIS_FILE="ECC_JNI.cpp" - - - - - - - ../../jdk/src/share/native/sun/security/ec - ../../jdk/src/share/native/sun/security/ec/impl - ../../jdk/make - - - MP_API_COMPATIBLE - NSS_ECC_MORE_THAN_SUITE_B - - - - - - - ../../jdk/src/share/native/sun/security/jgss/wrapper - ../../jdk/src/solaris/native/sun/security/jgss/wrapper - ../../jdk/make - - - THIS_FILE="GSSLibStub.c" - - - - - - - ../../jdk/src/share/native/sun/security/pkcs11 - ../../jdk/src/solaris/native/sun/security/pkcs11 - ../../jdk/src/share/native/sun/security/pkcs11/wrapper - ../../jdk/src/solaris/native/sun/security/pkcs11/wrapper - ../../jdk/make - - - THIS_FILE="p11_convert.c" - - - - - - - ../../jdk/src/share/native/sun/security/smartcardio - ../../jdk/src/solaris/native/sun/security/smartcardio - ../../jdk/src/solaris/native/sun/security/smartcardio/MUSCLE - ../../jdk/make - - - THIS_FILE="pcsc.c" - __sun_jdk - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/tracing/dtrace - ../../jdk/make - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="JVM.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/make - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="npt.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/transport/socket - ../../jdk/src/solaris/transport/socket - ../../jdk/src/share/back/export - ../../jdk/src/share/back - ../../jdk/make - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="socketTransport.c" - USE_MMAP - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ARCH="amd64" - LINUX - NDEBUG - RELEASE="" - THIS_FILE="exec_md.c" - _GNU_SOURCE - _LARGEFILE64_SOURCE - _LITTLE_ENDIAN - _LP64=1 - _REENTRANT - amd64 - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/transport/export - ../../jdk/src/share/back/export - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/src/share/back - ../../jdk/src/solaris/back - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_jdwp_headers - ../../jdk/make - - - JDWP_LOGGING - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - - - THIS_FILE="ergo.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/demo/jvmti/hprof - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/src/share/demo/jvmti/java_crw_demo - ../../jdk/make - - - THIS_FILE="hprof_md.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/instrument - ../../jdk/src/solaris/instrument - ../../jdk/src/share/bin - ../../jdk/make - - - NO_JPLIS_LOGGING - THIS_FILE="EncodingSupport_md.c" - - - - - - - THIS_FILE="LinuxOperatingSystem.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - - - - - - - ../../jdk/src/share/native/sun/management - ../../jdk/make - - - - - - - ../../jdk/src/share/native/com/sun/media/sound - ../../jdk/src/solaris/native/com/sun/media/sound - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + /usr/include/alsa + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make EXTRA_SOUND_JNI_LIBS=" jsoundalsa" @@ -22813,587 +47586,483 @@ USE_PLATFORM_MIDI_IN=TRUE USE_PLATFORM_MIDI_OUT=TRUE USE_PORTS=TRUE - X_ARCH=X_AMD64 X_PLATFORM=X_LINUX - + - ../../jdk/make - - - THIS_FILE="Unix.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="jdk_util_md.c" - - - - - - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - - - THIS_FILE="Console_md.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="ProcessEnvironment_md.c" - - - - - - - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/src/solaris/native/sun/net/dns - ../../jdk/src/solaris/native/sun/net/spi - ../../jdk/src/solaris/native/sun/net/sdp - ../../jdk/make - - - THIS_FILE="Inet4AddressImpl.c" - - - - - - - ../../jdk/src/share/native/sun/nio/ch - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="MappedByteBuffer.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="FileSystemPreferences.c" - - - - - - - THIS_FILE="splashscreen_sys.c" - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/include - /usr/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/linux/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN + THIS_FILE="splashscreen_sys.c" WITH_X11 - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - /usr/include/freetype2 - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/font/layout - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.instrument/share/native/libinstrument + ../../jdk/src/java.instrument/unix/native/libinstrument + ../../build/support/headers/java.instrument + ../../jdk/src/java.base/share/native/libjli + ../../make - HEADLESS - LE_STANDALONE - THIS_FILE="X11FontScaler.c" + DEBUG + JPLIS_LOGGING + THIS_FILE="EncodingSupport.c" - + - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="GLXGraphicsConfig.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK + THIS_FILE="EncodingSupport_md.c" - + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.management/share/native/include + ../../jdk/src/java.management/share/native/libmanagement + ../../jdk/src/java.management/unix/native/libmanagement + ../../build/support/headers/java.management + ../../jdk/src/java.base/linux/native/libjava + ../../make + - THIS_FILE="X11FontScaler_md.c" + DEBUG + THIS_FILE="ClassLoadingImpl.c" - + - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/management - ../../jdk/make - THIS_FILE="FileSystemImpl.c" - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/src/solaris/native/sun/net/dns - ../../jdk/src/solaris/native/sun/net/spi - ../../jdk/src/solaris/native/sun/net/sdp - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.prefs/unix/native/libprefs + ../../jdk/src/java.base/linux/native/libjava + ../../make - THIS_FILE="ResolverConfigurationImpl.c" + DEBUG + THIS_FILE="FileSystemPreferences.c" - - - - THIS_FILE="SdpSupport.c" - - - - - - - THIS_FILE="DefaultProxySelector.c" - - - - - - - THIS_FILE="SctpChannelImpl.c" - - - - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.security.jgss/share/native/libj2gss + ../../jdk/src/java.security.jgss/unix/native/libj2gss + ../../jdk/src/java.base/linux/native/libjava + ../../build/support/headers/java.security.jgss + ../../make - - - - - - ../../jdk/src/share/native/sun/nio/ch/sctp - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/sun/nio/ch - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - - - - THIS_FILE="GnomeFileTypeDetector.c" + DEBUG + THIS_FILE="GSSLibStub.c" - + - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - THIS_FILE="NativeFunc.c" - + - ../../jdk/src/share/native/sun/security/jgss/wrapper - ../../jdk/src/solaris/native/sun/security/jgss/wrapper - ../../jdk/make - - - - - - - ../../jdk/src/share/native/sun/security/pkcs11 - ../../jdk/src/solaris/native/sun/security/pkcs11 - ../../jdk/src/share/native/sun/security/pkcs11/wrapper - ../../jdk/src/solaris/native/sun/security/pkcs11/wrapper - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.smartcardio/share/native/libj2pcsc + ../../jdk/src/java.smartcardio/unix/native/libj2pcsc + ../../jdk/src/java.smartcardio/unix/native/libj2pcsc/MUSCLE + ../../build/support/headers/java.smartcardio + ../../make - THIS_FILE="p11_md.c" - - - - - - - ../../jdk/src/share/native/sun/security/smartcardio - ../../jdk/src/solaris/native/sun/security/smartcardio - ../../jdk/src/solaris/native/sun/security/smartcardio/MUSCLE - ../../jdk/make - - - THIS_FILE="pcsc_md.c" + DEBUG + THIS_FILE="pcsc.c" __sun_jdk - + - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - THIS_FILE="LinuxVirtualMachine.c" + THIS_FILE="pcsc_md.c" - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/tracing/dtrace - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/jdk.attach + ../../jdk/src/java.base/linux/native/libjava + ../../make - THIS_FILE="jvm_symbols_md.c" + DEBUG + THIS_FILE="VirtualMachineImpl.c" - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../make - ARCHPROPNAME="amd64" - THIS_FILE="HostLocaleProviderAdapter_md.c" + DEBUG + MP_API_COMPATIBLE + NSS_ECC_MORE_THAN_SUITE_B + THIS_FILE="ec.c" + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../make + + + DEBUG + THIS_FILE="ECC_JNI.cpp" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/jdk.crypto.pkcs11/share/native/libj2pkcs11 + ../../jdk/src/jdk.crypto.pkcs11/unix/native/libj2pkcs11 + ../../jdk/src/java.base/linux/native/libjava + ../../build/support/headers/jdk.crypto.pkcs11 + ../../make + + + DEBUG + THIS_FILE="j2secmod.c" - + - - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="XToolkit.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK + THIS_FILE="j2secmod_md.c" - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava - THIS_FILE="utf_md.c" + DEBUG + THIS_FILE="socketTransport.c" - + - ../../build/linux-x86_64-normal-server-release/jdk/include - ../../build/linux-x86_64-normal-server-release/jdk/include/linux - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/linux-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/transport/socket - ../../jdk/src/solaris/transport/socket - ../../jdk/src/share/back/export - ../../jdk/src/share/back - ../../jdk/make + ../../jdk/src/jdk.jdwp.agent/share/native/libdt_socket + ../../jdk/src/jdk.jdwp.agent/unix/native/libdt_socket + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp/export + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp + ../../jdk/src/jdk.jdwp.agent/share/native/include + ../../make + + USE_MMAP + + + + + + + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp/export + ../../jdk/src/jdk.jdwp.agent/share/native/include + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp + ../../jdk/src/jdk.jdwp.agent/unix/native/libjdwp + ../../build/support/headers/jdk.jdwp.agent + ../../make + + + JDWP_LOGGING + THIS_FILE="ArrayReferenceImpl.c" + + + + + THIS_FILE="socket_md.c" + + + + + + + ../../jdk/src/jdk.jdwp.agent/share/native/libdt_socket + ../../jdk/src/jdk.jdwp.agent/unix/native/libdt_socket + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp/export + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp + ../../jdk/src/jdk.jdwp.agent/share/native/include + ../../make + + USE_MMAP + + + + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp/export + ../../jdk/src/jdk.jdwp.agent/share/native/include + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp + ../../jdk/src/jdk.jdwp.agent/unix/native/libjdwp + ../../build/support/headers/jdk.jdwp.agent + ../../make + + + JDWP_LOGGING + THIS_FILE="exec_md.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.management/share/native/include + ../../jdk/src/jdk.management/share/native/libmanagement_ext + ../../jdk/src/jdk.management/unix/native/libmanagement_ext + ../../jdk/src/jdk.management/linux/native/libmanagement_ext + ../../build/support/headers/jdk.management + ../../jdk/src/java.base/linux/native/libjava + ../../make + + + DEBUG + THIS_FILE="UnixOperatingSystem.c" + + + + + + + THIS_FILE="DiagnosticCommandImpl.c" + + + + + + + THIS_FILE="OperatingSystemImpl.c" + + + + + + + DEBUG + FULL + THIS_FILE="bands.cpp" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.base + ../../jdk/src/jdk.pack200/share/native/common-unpack + ../../jdk/src/java.base/linux/native/libjava + ../../make + + + NO_ZLIB + UNPACK_JNI + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.base + ../../jdk/src/jdk.pack200/share/native/common-unpack + ../../jdk/src/java.base/linux/native/libjava + ../../make + + + NO_ZLIB + THIS_FILE="jni.cpp" + UNPACK_JNI + + + + + + + ../../jdk/src/jdk.pack200/share/native/common-unpack + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libzip/zlib-1.2.8 + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + THIS_FILE="main.cpp" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/share/native/libnio/ch + ../../jdk/src/java.base/linux/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../jdk/src/java.base/linux/native/libjava + ../../build/support/headers/jdk.sctp + ../../build/support/headers/java.base + ../../make + + + DEBUG + THIS_FILE="SctpChannelImpl.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/linux/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/jdk.security.auth + ../../make + + + DEBUG + THIS_FILE="Unix.c" + + + - LOCAL_SOURCES default + false + false + + + + + + + - - IDE_ALT_BOOTDIR - HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" @@ -23406,323 +48075,697 @@ gmake -f Makefile images gmake -f Makefile clean + + + THIS_FILE="ad_x86_64.cpp" + + + + ../.. + sh ../configure --with-debug-level=slowdebug --disable-zip-debug-info + - + + - + + + THIS_FILE="ad_x86_64_clone.cpp" + + - + + + THIS_FILE="ad_x86_64_expand.cpp" + + - + + + THIS_FILE="ad_x86_64_format.cpp" + + - + + + THIS_FILE="ad_x86_64_gen.cpp" + + - + + + THIS_FILE="ad_x86_64_misc.cpp" + + - + + + THIS_FILE="ad_x86_64_peephole.cpp" + + - + + + THIS_FILE="ad_x86_64_pipeline.cpp" + + - + + + THIS_FILE="dfa_x86_64.cpp" + + - + + - + + + THIS_FILE="jvmtiEnter.cpp" + + - + + + THIS_FILE="jvmtiEnterTrace.cpp" + + - + + - + + - - - + + - - - - + + + THIS_FILE="assembler_x86.cpp" + + + + + THIS_FILE="c1_CodeStubs_x86.cpp" + + + + + THIS_FILE="c1_FpuStackSim_x86.cpp" + + + + + THIS_FILE="c1_FrameMap_x86.cpp" + + + + + THIS_FILE="c1_LIRAssembler_x86.cpp" + + + + + THIS_FILE="c1_LIRGenerator_x86.cpp" + + + + + THIS_FILE="c1_LinearScan_x86.cpp" + + + + + THIS_FILE="c1_MacroAssembler_x86.cpp" + + + + + THIS_FILE="c1_Runtime1_x86.cpp" + + + + + THIS_FILE="c2_init_x86.cpp" + + - + + + THIS_FILE="compiledIC_x86.cpp" + + + + + THIS_FILE="debug_x86.cpp" + + + + + THIS_FILE="depChecker_x86.cpp" + + + + + THIS_FILE="frame_x86.cpp" + + + + + THIS_FILE="icBuffer_x86.cpp" + + + + + THIS_FILE="icache_x86.cpp" + + - + + + THIS_FILE="interp_masm_x86.cpp" + + - - + + + THIS_FILE="interpreterRT_x86_64.cpp" + + + + + THIS_FILE="jniFastGetField_x86_64.cpp" + + + + + + + THIS_FILE="jvmciCodeInstaller_x86.cpp" + + + + + THIS_FILE="macroAssembler_x86.cpp" + + + + + + + THIS_FILE="macroAssembler_x86_cos.cpp" + + + + + + + THIS_FILE="macroAssembler_x86_exp.cpp" + + + + + + + THIS_FILE="macroAssembler_x86_log.cpp" + + + + + + + THIS_FILE="macroAssembler_x86_log10.cpp" + + + + + + + THIS_FILE="macroAssembler_x86_pow.cpp" + + + + + + + THIS_FILE="macroAssembler_x86_sha.cpp" + + + + + + + THIS_FILE="macroAssembler_x86_sin.cpp" + + + + + + + THIS_FILE="macroAssembler_x86_tan.cpp" + + + + + THIS_FILE="metaspaceShared_x86_64.cpp" + + + + + THIS_FILE="methodHandles_x86.cpp" + + + + + THIS_FILE="nativeInst_x86.cpp" + + + + + + + THIS_FILE="registerMap_x86.cpp" + + + + + THIS_FILE="register_definitions_x86.cpp" + + + + + THIS_FILE="register_x86.cpp" + + + + + THIS_FILE="relocInfo_x86.cpp" + + + + + THIS_FILE="runtime_x86_64.cpp" + + + + + + + THIS_FILE="sharedRuntime_x86.cpp" + + + + + THIS_FILE="sharedRuntime_x86_64.cpp" + + + + + THIS_FILE="stubGenerator_x86_64.cpp" + + + + + + + THIS_FILE="stubRoutines_x86.cpp" + + + + + THIS_FILE="stubRoutines_x86_64.cpp" + + - + + + THIS_FILE="templateInterpreterGenerator_x86.cpp" + + - + + + THIS_FILE="templateInterpreterGenerator_x86_64.cpp" + + + + + + + THIS_FILE="templateTable_x86.cpp" + + + + + THIS_FILE="vm_version_x86.cpp" + + + + + THIS_FILE="vmreg_x86.cpp" + + + + + THIS_FILE="vtableStubs_x86_64.cpp" + + - + + + + + + + + - + + + THIS_FILE="threadLocalStorage_posix.cpp" + + + + + + + THIS_FILE="vmError_posix.cpp" + + - + - ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm - ../../hotspot/src/share/vm/precompiled - ../../hotspot/src/cpu/x86/vm - ../../hotspot/src/os_cpu/solaris_x86/vm ../../hotspot/src/os/solaris/vm ../../hotspot/src/os/posix/vm - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make AMD64 + ASSERT COMPILER1 COMPILER2 DONT_USE_PRECOMPILED_HEADER DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT SOLARIS SPARC_WORKS TARGET_ARCH_MODEL_x86_64 @@ -23733,6 +48776,7 @@ TARGET_OS_FAMILY_solaris VM_LITTLE_ENDIAN _Crun_inline_placement + _NMT_NOINLINE_ @@ -23740,1622 +48784,4051 @@ ex="false" tool="1" flavor2="0"> - + - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + ../../hotspot/make + + THIS_FILE="generateJvmOffsetsMain.c" + + + + ../../hotspot/make + + - + - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/hotspot/variant-server/gensrc + ../../build/hotspot/variant-server/support/dtrace + ../../hotspot/make + + THIS_FILE="libjvm_db.c" + - - - - + + - - + + + THIS_FILE="decoder_solaris.cpp" + + + + + + + THIS_FILE="jvm_solaris.cpp" + + + + + THIS_FILE="mutex_solaris.cpp" + + + + + THIS_FILE="osThread_solaris.cpp" + + + + + THIS_FILE="os_solaris.cpp" + + + + + THIS_FILE="perfMemory_solaris.cpp" + + + + + THIS_FILE="stubRoutines_solaris.cpp" + + - - + + + THIS_FILE="threadCritical_solaris.cpp" + + + + - - + + + THIS_FILE="os_solaris_x86.cpp" + + + + + THIS_FILE="thread_solaris_x86.cpp" + + - - - - - - + + + THIS_FILE="vm_version_solaris_x86.cpp" + + + + + + + THIS_FILE="archDesc.cpp" + + + + + THIS_FILE="arena.cpp" + + + + + THIS_FILE="dfa.cpp" + + + + + THIS_FILE="dict2.cpp" + + + + + THIS_FILE="filebuff.cpp" + + + + + THIS_FILE="forms.cpp" + + + + + THIS_FILE="formsopt.cpp" + + + + + THIS_FILE="formssel.cpp" + + + + + THIS_FILE="main.cpp" + + + + + THIS_FILE="output_c.cpp" + + + + + THIS_FILE="output_h.cpp" + + + + + + + THIS_FILE="codeBuffer.cpp" + + + + + THIS_FILE="register.cpp" + + + + + + + THIS_FILE="c1_Canonicalizer.cpp" + + + + + THIS_FILE="c1_Compilation.cpp" + + + + + THIS_FILE="c1_Compiler.cpp" + + + + + THIS_FILE="c1_Defs.cpp" + + + + + THIS_FILE="c1_FrameMap.cpp" + + + + + THIS_FILE="c1_GraphBuilder.cpp" + + + + + THIS_FILE="c1_IR.cpp" + + + + + THIS_FILE="c1_Instruction.cpp" + + + + + THIS_FILE="c1_InstructionPrinter.cpp" + + + + + THIS_FILE="c1_LIR.cpp" + + + + + THIS_FILE="c1_LIRAssembler.cpp" + + + + + THIS_FILE="c1_LIRGenerator.cpp" + + + + + THIS_FILE="c1_LinearScan.cpp" + + + + + THIS_FILE="c1_Optimizer.cpp" + + + + + THIS_FILE="c1_RangeCheckElimination.cpp" + + + + + THIS_FILE="c1_Runtime1.cpp" + + + + + THIS_FILE="c1_ValueMap.cpp" + + + + + THIS_FILE="c1_ValueSet.cpp" + + + + + THIS_FILE="c1_ValueStack.cpp" + + + + + THIS_FILE="c1_ValueType.cpp" + + + + + THIS_FILE="c1_globals.cpp" + + + + + + + THIS_FILE="ciArray.cpp" + + + + + THIS_FILE="ciArrayKlass.cpp" + + + + + THIS_FILE="ciBaseObject.cpp" + + + + + THIS_FILE="ciCallSite.cpp" + + + + + THIS_FILE="ciConstant.cpp" + + + + + THIS_FILE="ciConstantPoolCache.cpp" + + + + + THIS_FILE="ciEnv.cpp" + + + + + THIS_FILE="ciExceptionHandler.cpp" + + + + + THIS_FILE="ciField.cpp" + + + + + THIS_FILE="ciFlags.cpp" + + + + + THIS_FILE="ciInstance.cpp" + + + + + THIS_FILE="ciInstanceKlass.cpp" + + + + + THIS_FILE="ciKlass.cpp" + + + + + THIS_FILE="ciMemberName.cpp" + + + + + THIS_FILE="ciMetadata.cpp" + + + + + THIS_FILE="ciMethod.cpp" + + + + + THIS_FILE="ciMethodBlocks.cpp" + + + + + THIS_FILE="ciMethodData.cpp" + + + + + THIS_FILE="ciMethodHandle.cpp" + + + + + THIS_FILE="ciNullObject.cpp" + + + + + THIS_FILE="ciObjArray.cpp" + + + + + THIS_FILE="ciObjArrayKlass.cpp" + + + + + THIS_FILE="ciObject.cpp" + + + + + THIS_FILE="ciObjectFactory.cpp" + + + + + THIS_FILE="ciReplay.cpp" + + + + + THIS_FILE="ciSignature.cpp" + + + + + THIS_FILE="ciStreams.cpp" + + + + + THIS_FILE="ciSymbol.cpp" + + + + + THIS_FILE="ciType.cpp" + + + + + THIS_FILE="ciTypeArray.cpp" + + + + + THIS_FILE="ciTypeArrayKlass.cpp" + + + + + THIS_FILE="ciTypeFlow.cpp" + + + + + THIS_FILE="ciUtilities.cpp" + + + + + + + THIS_FILE="bytecodeAssembler.cpp" + + + + + THIS_FILE="classFileError.cpp" + + + + + THIS_FILE="classFileParser.cpp" + + + + + THIS_FILE="classFileStream.cpp" + + + + + + + THIS_FILE="classListParser.cpp" + + + + + THIS_FILE="classLoader.cpp" + + + + + THIS_FILE="classLoaderData.cpp" + + + + + + + THIS_FILE="classLoaderExt.cpp" + + + + + + + THIS_FILE="classLoaderStats.cpp" + + + + + + + THIS_FILE="compactHashtable.cpp" + + + + + THIS_FILE="defaultMethods.cpp" + + - - + + + THIS_FILE="dictionary.cpp" + + + + + THIS_FILE="javaAssertions.cpp" + + + + + THIS_FILE="javaClasses.cpp" + + + + + + + THIS_FILE="klassFactory.cpp" + + + + + THIS_FILE="loaderConstraints.cpp" + + + + + THIS_FILE="metadataOnStackMark.cpp" + + + + + + + THIS_FILE="moduleEntry.cpp" + + + + + + + THIS_FILE="modules.cpp" + + + + + + + THIS_FILE="packageEntry.cpp" + + + + + THIS_FILE="placeholders.cpp" + + + + + THIS_FILE="resolutionErrors.cpp" + + + + + + + THIS_FILE="sharedPathsMiscInfo.cpp" + + + + + THIS_FILE="stackMapFrame.cpp" + + + + + THIS_FILE="stackMapTable.cpp" + + + + + + + THIS_FILE="stringTable.cpp" + + + + + THIS_FILE="symbolTable.cpp" + + + + + THIS_FILE="systemDictionary.cpp" + + + + + THIS_FILE="verificationType.cpp" + + + + + THIS_FILE="verifier.cpp" + + + + + THIS_FILE="vmSymbols.cpp" + + + + + + + THIS_FILE="codeCache.cpp" + + + + + THIS_FILE="compiledIC.cpp" + + + + + + + THIS_FILE="compiledMethod.cpp" + + + + + THIS_FILE="compressedStream.cpp" + + + + + THIS_FILE="debugInfo.cpp" + + + + + THIS_FILE="debugInfoRec.cpp" + + + + + THIS_FILE="dependencies.cpp" + + + + + + + THIS_FILE="dependencyContext.cpp" + + + + + THIS_FILE="exceptionHandlerTable.cpp" + + + + + THIS_FILE="icBuffer.cpp" + + + + + THIS_FILE="location.cpp" + + + + + THIS_FILE="nmethod.cpp" + + + + + THIS_FILE="oopRecorder.cpp" + + + + + THIS_FILE="pcDesc.cpp" + + + + + THIS_FILE="relocInfo.cpp" + + + + + THIS_FILE="scopeDesc.cpp" + + + + + THIS_FILE="stubs.cpp" + + + + + THIS_FILE="vmreg.cpp" + + + + + THIS_FILE="vtableStubs.cpp" + + + + + + + THIS_FILE="compileBroker.cpp" + + + + + THIS_FILE="compileLog.cpp" + + + + + + + THIS_FILE="compileTask.cpp" + + + + + + + THIS_FILE="compilerDirectives.cpp" + + + + + THIS_FILE="compilerOracle.cpp" + + + + + + + THIS_FILE="directivesParser.cpp" + + + + + THIS_FILE="disassembler.cpp" + + + + + THIS_FILE="methodLiveness.cpp" + + + + + + + THIS_FILE="methodMatcher.cpp" + + + + + THIS_FILE="oopMap.cpp" + + - + + - + + + THIS_FILE="allocationStats.cpp" + + - + + + THIS_FILE="cmsCollectorPolicy.cpp" + + - + + + THIS_FILE="cmsLockVerifier.cpp" + + - + + + THIS_FILE="cmsOopClosures.cpp" + + - + + + THIS_FILE="compactibleFreeListSpace.cpp" + + - + + + THIS_FILE="concurrentMarkSweepGeneration.cpp" + + - + + + THIS_FILE="concurrentMarkSweepThread.cpp" + + - + + + THIS_FILE="freeChunk.cpp" + + - + + + THIS_FILE="gSpaceCounters.cpp" + + - + + + THIS_FILE="parCardTableModRefBS.cpp" + + - + + + THIS_FILE="parNewGeneration.cpp" + + - + + + THIS_FILE="parOopClosures.cpp" + + - + + + THIS_FILE="promotionInfo.cpp" + + - + + + THIS_FILE="vmCMSOperations.cpp" + + - + + + THIS_FILE="yieldingWorkgroup.cpp" + + - + + - + + + THIS_FILE="collectionSetChooser.cpp" + + - + + + THIS_FILE="concurrentG1Refine.cpp" + + - + + + THIS_FILE="concurrentG1RefineThread.cpp" + + - + + + THIS_FILE="concurrentMarkThread.cpp" + + - + + + THIS_FILE="dirtyCardQueue.cpp" + + - + + + THIS_FILE="g1AllocRegion.cpp" + + - + + + THIS_FILE="g1Allocator.cpp" + + - + + + THIS_FILE="g1Allocator_ext.cpp" + + - + + + THIS_FILE="g1Analytics.cpp" + + - + + + THIS_FILE="g1BiasedArray.cpp" + + - + + + THIS_FILE="g1BlockOffsetTable.cpp" + + - + + + THIS_FILE="g1CardCounts.cpp" + + - + + + THIS_FILE="g1CardLiveData.cpp" + + - + + + THIS_FILE="g1CodeBlobClosure.cpp" + + - + + + THIS_FILE="g1CodeCacheRemSet.cpp" + + - + + + THIS_FILE="g1CollectedHeap.cpp" + + - + + + THIS_FILE="g1CollectedHeap_ext.cpp" + + - + + + THIS_FILE="g1CollectionSet.cpp" + + - + + + THIS_FILE="g1CollectorPolicy.cpp" + + - + + + THIS_FILE="g1ConcurrentMark.cpp" + + - + + + THIS_FILE="g1DefaultPolicy.cpp" + + - + + + THIS_FILE="g1EvacFailure.cpp" + + - + + + THIS_FILE="g1EvacStats.cpp" + + - + + + THIS_FILE="g1FromCardCache.cpp" + + - + + + THIS_FILE="g1GCPhaseTimes.cpp" + + - + + + THIS_FILE="g1HeapSizingPolicy.cpp" + + - + + + THIS_FILE="g1HeapSizingPolicy_ext.cpp" + + - + + + THIS_FILE="g1HeapTransition.cpp" + + - + + + THIS_FILE="g1HeapVerifier.cpp" + + - + + + THIS_FILE="g1HotCardCache.cpp" + + - + + + THIS_FILE="g1IHOPControl.cpp" + + - + + + THIS_FILE="g1MMUTracker.cpp" + + - + + + THIS_FILE="g1MarkSweep.cpp" + + - + + + THIS_FILE="g1MarkSweep_ext.cpp" + + - + + + THIS_FILE="g1MonitoringSupport.cpp" + + - + + + THIS_FILE="g1OopClosures.cpp" + + - + + + THIS_FILE="g1PageBasedVirtualSpace.cpp" + + - + + + THIS_FILE="g1ParScanThreadState.cpp" + + - + + + THIS_FILE="g1ParScanThreadState_ext.cpp" + + - + + + THIS_FILE="g1Predictions.cpp" + + - + + + THIS_FILE="g1RegionToSpaceMapper.cpp" + + - + + + THIS_FILE="g1RemSet.cpp" + + - + + + THIS_FILE="g1RemSetSummary.cpp" + + - + + + THIS_FILE="g1RootClosures.cpp" + + - + + + THIS_FILE="g1RootClosures_ext.cpp" + + - + + + THIS_FILE="g1RootProcessor.cpp" + + - + + + THIS_FILE="g1SATBCardTableModRefBS.cpp" + + - + + + THIS_FILE="g1StringDedup.cpp" + + - + + + THIS_FILE="g1StringDedupQueue.cpp" + + - + + + THIS_FILE="g1StringDedupStat.cpp" + + - + + + THIS_FILE="g1StringDedupTable.cpp" + + - + + + THIS_FILE="g1StringDedupThread.cpp" + + - + + + THIS_FILE="g1SurvivorRegions.cpp" + + - + + + THIS_FILE="g1YoungGenSizer.cpp" + + - + + + THIS_FILE="g1YoungRemSetSamplingThread.cpp" + + - + + + THIS_FILE="g1_globals.cpp" + + - + + + THIS_FILE="hSpaceCounters.cpp" + + - + + + THIS_FILE="heapRegion.cpp" + + - + + + THIS_FILE="heapRegionManager.cpp" + + - + + + THIS_FILE="heapRegionRemSet.cpp" + + - + + + THIS_FILE="heapRegionSet.cpp" + + - + + + THIS_FILE="heapRegionTracer.cpp" + + - + + + THIS_FILE="heapRegionType.cpp" + + - + + + THIS_FILE="ptrQueue.cpp" + + - + + + THIS_FILE="satbMarkQueue.cpp" + + - + + + THIS_FILE="sparsePRT.cpp" + + - + + + THIS_FILE="survRateGroup.cpp" + + - + + + THIS_FILE="suspendibleThreadSet.cpp" + + - + + + THIS_FILE="vm_operations_g1.cpp" + + - + + + THIS_FILE="workerDataArray.cpp" + + - + + - + + + THIS_FILE="adjoiningVirtualSpaces.cpp" + + - + + + THIS_FILE="asPSOldGen.cpp" + + - + + + THIS_FILE="asPSYoungGen.cpp" + + - + + + THIS_FILE="cardTableExtension.cpp" + + - + + + THIS_FILE="gcAdaptivePolicyCounters.cpp" + + + + + + + THIS_FILE="gcTaskManager.cpp" + + + + + + + THIS_FILE="gcTaskThread.cpp" + + + + + + + THIS_FILE="generationSizer.cpp" + + + + + + + THIS_FILE="immutableSpace.cpp" + + + + + + + THIS_FILE="mutableNUMASpace.cpp" + + + + + + + THIS_FILE="mutableSpace.cpp" + + + + + + + THIS_FILE="objectStartArray.cpp" + + + + + + + THIS_FILE="parMarkBitMap.cpp" + + + + + + + THIS_FILE="parallelScavengeHeap.cpp" + + + + + + + THIS_FILE="pcTasks.cpp" + + + + + + + THIS_FILE="psAdaptiveSizePolicy.cpp" + + + + + + + THIS_FILE="psCompactionManager.cpp" + + + + + + + THIS_FILE="psGCAdaptivePolicyCounters.cpp" + + + + + + + THIS_FILE="psGenerationCounters.cpp" + + + + + + + THIS_FILE="psMarkSweep.cpp" + + + + + + + THIS_FILE="psMarkSweepDecorator.cpp" + + + + + + + THIS_FILE="psOldGen.cpp" + + + + + + + THIS_FILE="psParallelCompact.cpp" + + + + + + + THIS_FILE="psPromotionLAB.cpp" + + + + + + + THIS_FILE="psPromotionManager.cpp" + + + + + + + THIS_FILE="psScavenge.cpp" + + + + + + + THIS_FILE="psTasks.cpp" + + + + + + + THIS_FILE="psVirtualspace.cpp" + + + + + + + THIS_FILE="psYoungGen.cpp" + + + + + + + THIS_FILE="spaceCounters.cpp" + + + + + + + THIS_FILE="vmPSOperations.cpp" + + + + + + + + + + + THIS_FILE="defNewGeneration.cpp" + + + + + + + THIS_FILE="genMarkSweep.cpp" + + + + + + + THIS_FILE="markSweep.cpp" + + + + + + + THIS_FILE="tenuredGeneration.cpp" + + + + + + + + + + + THIS_FILE="ageTable.cpp" + + + + + + + THIS_FILE="ageTableTracer.cpp" + + + + + + + THIS_FILE="allocTracer.cpp" + + + + + + + THIS_FILE="barrierSet.cpp" + + + + + + + THIS_FILE="blockOffsetTable.cpp" + + + + + + + THIS_FILE="cardGeneration.cpp" + + + + + + + THIS_FILE="cardTableModRefBS.cpp" + + + + + + + THIS_FILE="cardTableModRefBSForCTRS.cpp" + + + + + + + THIS_FILE="cardTableRS.cpp" + + + + + + + THIS_FILE="collectedHeap.cpp" + + + + + + + THIS_FILE="collectorCounters.cpp" + + + + + + + THIS_FILE="collectorPolicy.cpp" + + + + + + + THIS_FILE="concurrentGCThread.cpp" + + + + + + + THIS_FILE="gcCause.cpp" + + + + + + + THIS_FILE="gcId.cpp" + + + + + + + THIS_FILE="gcLocker.cpp" + + + + + + + THIS_FILE="gcPolicyCounters.cpp" + + + + + + + THIS_FILE="gcStats.cpp" + + + + + + + THIS_FILE="gcTimer.cpp" + + + + + + + THIS_FILE="gcTrace.cpp" + + + + + + + THIS_FILE="gcTraceSend.cpp" + + + + + + + THIS_FILE="gcTraceTime.cpp" + + + + + + + THIS_FILE="gcUtil.cpp" + + + + + + + THIS_FILE="genCollectedHeap.cpp" + + + + + + + THIS_FILE="genOopClosures.cpp" + + + + + + + THIS_FILE="generation.cpp" + + + + + + + THIS_FILE="generationCounters.cpp" + + + + + + + THIS_FILE="generationSpec.cpp" + + + + + + + THIS_FILE="memset_with_concurrent_readers.cpp" + + + + + + + THIS_FILE="objectCountEventSender.cpp" + + + + + + + THIS_FILE="plab.cpp" + + + + + + + THIS_FILE="preservedMarks.cpp" + + + + + + + THIS_FILE="referencePendingListLocker.cpp" + + + + + + + THIS_FILE="referencePolicy.cpp" + + + + + + + THIS_FILE="referenceProcessor.cpp" + + + + + + + THIS_FILE="space.cpp" + + + + + + + THIS_FILE="spaceDecorator.cpp" + + + + + + + THIS_FILE="strongRootsScope.cpp" + + + + + + + THIS_FILE="taskqueue.cpp" + + + + + + + THIS_FILE="threadLocalAllocBuffer.cpp" + + + + + + + THIS_FILE="vmGCOperations.cpp" + + + + + + + THIS_FILE="workgroup.cpp" + + + + + + + + + THIS_FILE="bytecode.cpp" + + + + + THIS_FILE="bytecodeHistogram.cpp" + + + + + THIS_FILE="bytecodeInterpreter.cpp" + + + + + THIS_FILE="bytecodeStream.cpp" + + + + + THIS_FILE="bytecodeTracer.cpp" + + + + + THIS_FILE="bytecodes.cpp" + + + + + THIS_FILE="cppInterpreter.cpp" + + + + + + + THIS_FILE="cppInterpreterGenerator.cpp" + + + + + THIS_FILE="interpreter.cpp" + + + + + THIS_FILE="interpreterRuntime.cpp" + + + + + THIS_FILE="invocationCounter.cpp" + + + + + THIS_FILE="linkResolver.cpp" + + + + + THIS_FILE="oopMapCache.cpp" + + + + + THIS_FILE="rewriter.cpp" + + + + + THIS_FILE="templateInterpreter.cpp" + + + + + + + THIS_FILE="templateInterpreterGenerator.cpp" + + + + + THIS_FILE="templateTable.cpp" + + + + + + + + + + + THIS_FILE="jvmciCompiler.cpp" + + + + + + + THIS_FILE="jvmciCompilerToVM.cpp" + + + + + + + THIS_FILE="jvmciEnv.cpp" + + + + + + + THIS_FILE="jvmciJavaClasses.cpp" + + + + + + + THIS_FILE="jvmciRuntime.cpp" + + + + + + + THIS_FILE="jvmci_globals.cpp" + + + + + + + THIS_FILE="vmStructs_jvmci.cpp" + + - - + + + + + THIS_FILE="set.cpp" + + + + + THIS_FILE="vectset.cpp" + + + + + + + + + + + THIS_FILE="logConfiguration.cpp" + + + + + + + THIS_FILE="logDecorations.cpp" + + + + + + + THIS_FILE="logDecorators.cpp" + + + + + + + THIS_FILE="logDiagnosticCommand.cpp" + + + + + + + THIS_FILE="logFileOutput.cpp" + + + + + + + THIS_FILE="logFileStreamOutput.cpp" + + + + + + + THIS_FILE="logLevel.cpp" + + + + + + + THIS_FILE="logMessageBuffer.cpp" + + + + + + + THIS_FILE="logOutput.cpp" + + + + + + + THIS_FILE="logOutputList.cpp" + + + + + + + THIS_FILE="logStream.cpp" + + + + + + + THIS_FILE="logTag.cpp" + + + + + + + THIS_FILE="logTagLevelExpression.cpp" + + + + + + + THIS_FILE="logTagSet.cpp" + + + + + + + THIS_FILE="logTagSetDescriptions.cpp" + + - - + + - - - - - - - - - - + + + THIS_FILE="binaryTreeDictionary.cpp" + + + + + THIS_FILE="filemap.cpp" + + + + + THIS_FILE="freeBlockDictionary.cpp" + + + + + THIS_FILE="freeList.cpp" + + - - - - - - - - - - - + + + THIS_FILE="guardedMemory.cpp" + + + + + THIS_FILE="heap.cpp" + + + + + THIS_FILE="heapInspection.cpp" + + + + + THIS_FILE="iterator.cpp" + + - - + + + THIS_FILE="memRegion.cpp" + + + + + THIS_FILE="metachunk.cpp" + + + + + THIS_FILE="metaspace.cpp" + + + + + THIS_FILE="metaspaceCounters.cpp" + + + + + THIS_FILE="metaspaceShared.cpp" + + + + + + + THIS_FILE="metaspaceTracer.cpp" + + + + + THIS_FILE="oopFactory.cpp" + + - - - + + + THIS_FILE="operator_new.cpp" + + - - - - - - - - - - + + + THIS_FILE="resourceArea.cpp" + + + + + THIS_FILE="universe.cpp" + + + + + + + THIS_FILE="universe_ext.cpp" + + + + + + + THIS_FILE="virtualspace.cpp" + + + + + + + THIS_FILE="arrayKlass.cpp" + + + + + THIS_FILE="arrayOop.cpp" + + + + + THIS_FILE="compiledICHolder.cpp" + + + + + THIS_FILE="constMethod.cpp" + + + + + THIS_FILE="constantPool.cpp" + + + + + THIS_FILE="cpCache.cpp" + + - - + + + THIS_FILE="generateOopMap.cpp" + + + + + THIS_FILE="instanceKlass.cpp" + + + + + THIS_FILE="instanceMirrorKlass.cpp" + + + + + THIS_FILE="instanceOop.cpp" + + + + + THIS_FILE="instanceRefKlass.cpp" + + + + + THIS_FILE="klass.cpp" + + + + + THIS_FILE="klassVtable.cpp" + + + + + THIS_FILE="markOop.cpp" + + + + + THIS_FILE="metadata.cpp" + + + + + THIS_FILE="method.cpp" + + + + + + + THIS_FILE="methodCounters.cpp" + + + + + THIS_FILE="methodData.cpp" + + + + + THIS_FILE="objArrayKlass.cpp" + + + + + THIS_FILE="objArrayOop.cpp" + + + + + THIS_FILE="oop.cpp" + + + + + THIS_FILE="oopsHierarchy.cpp" + + + + + THIS_FILE="symbol.cpp" + + - - + + + THIS_FILE="typeArrayKlass.cpp" + + - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + + + + + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="arraycopynode.cpp" @@ -25363,22 +52836,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="block.cpp" @@ -25386,22 +52846,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="buildOopMap.cpp" @@ -25409,22 +52856,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="bytecodeInfo.cpp" @@ -25432,22 +52866,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="c2_globals.cpp" @@ -25455,22 +52876,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="c2compiler.cpp" @@ -25478,22 +52886,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="callGenerator.cpp" @@ -25501,22 +52896,19 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="callnode.cpp" + + + + + + + THIS_FILE="castnode.cpp" @@ -25524,22 +52916,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="cfgnode.cpp" @@ -25547,22 +52926,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="chaitin.cpp" @@ -25570,22 +52936,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="classes.cpp" @@ -25593,22 +52946,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="coalesce.cpp" @@ -25616,22 +52956,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="compile.cpp" @@ -25639,22 +52966,29 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="connode.cpp" + + + + + + + THIS_FILE="convertnode.cpp" + + + + + + + THIS_FILE="countbitsnode.cpp" @@ -25662,22 +52996,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="divnode.cpp" @@ -25685,22 +53006,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="doCall.cpp" @@ -25708,22 +53016,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="domgraph.cpp" @@ -25731,22 +53026,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="escape.cpp" @@ -25754,22 +53036,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="gcm.cpp" @@ -25777,22 +53046,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="generateOptoStub.cpp" @@ -25800,22 +53056,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="graphKit.cpp" @@ -25823,22 +53066,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="idealGraphPrinter.cpp" @@ -25846,22 +53076,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="idealKit.cpp" @@ -25869,22 +53086,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="ifg.cpp" @@ -25892,22 +53096,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="ifnode.cpp" @@ -25915,22 +53106,19 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="indexSet.cpp" + + + + + + + THIS_FILE="intrinsicnode.cpp" @@ -25938,22 +53126,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="lcm.cpp" @@ -25961,22 +53136,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="library_call.cpp" @@ -25984,22 +53146,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="live.cpp" @@ -26007,22 +53156,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="locknode.cpp" @@ -26030,22 +53166,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="loopPredicate.cpp" @@ -26053,22 +53176,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="loopTransform.cpp" @@ -26076,22 +53186,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="loopUnswitch.cpp" @@ -26099,22 +53196,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="loopnode.cpp" @@ -26122,22 +53206,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="loopopts.cpp" @@ -26145,22 +53216,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="machnode.cpp" @@ -26168,22 +53226,19 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="macro.cpp" + + + + + + + THIS_FILE="macroArrayCopy.cpp" @@ -26191,22 +53246,19 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="matcher.cpp" + + + + + + + THIS_FILE="mathexactnode.cpp" @@ -26214,22 +53266,19 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="memnode.cpp" + + + + + + + THIS_FILE="movenode.cpp" @@ -26237,22 +53286,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="mulnode.cpp" @@ -26260,22 +53296,19 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="multnode.cpp" + + + + + + + THIS_FILE="narrowptrnode.cpp" @@ -26283,22 +53316,19 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="node.cpp" + + + + + + + THIS_FILE="opaquenode.cpp" @@ -26306,14 +53336,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../hotspot/src/share/vm/adlc - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - ASSERT + THIS_FILE="opcodes.cpp" @@ -26321,22 +53346,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="output.cpp" @@ -26344,22 +53356,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="parse1.cpp" @@ -26367,22 +53366,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="parse2.cpp" @@ -26390,22 +53376,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="parse3.cpp" @@ -26413,22 +53386,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="parseHelper.cpp" @@ -26436,22 +53396,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="phase.cpp" @@ -26459,22 +53406,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="phaseX.cpp" @@ -26482,22 +53416,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="postaloc.cpp" @@ -26505,22 +53426,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="reg_split.cpp" @@ -26528,22 +53436,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="regalloc.cpp" @@ -26551,22 +53446,19 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="regmask.cpp" + + + + + + + THIS_FILE="replacednodes.cpp" @@ -26574,22 +53466,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="rootnode.cpp" @@ -26597,22 +53476,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="runtime.cpp" @@ -26620,22 +53486,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="split_if.cpp" @@ -26643,22 +53496,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="stringopts.cpp" @@ -26666,22 +53506,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="subnode.cpp" @@ -26689,22 +53516,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="superword.cpp" @@ -26712,22 +53526,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="type.cpp" @@ -26735,22 +53536,9 @@ ex="false" tool="1" flavor2="0"> - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="vectornode.cpp" @@ -26758,478 +53546,1039 @@ ex="false" tool="1" flavor2="0"> + + + THIS_FILE="evmCompat.cpp" + + + + + THIS_FILE="forte.cpp" + + + + + THIS_FILE="jni.cpp" + + + + + THIS_FILE="jniCheck.cpp" + + + + + THIS_FILE="jniFastGetField.cpp" + + + + + THIS_FILE="jvm.cpp" + + + + + THIS_FILE="jvmtiClassFileReconstituter.cpp" + + + + + THIS_FILE="jvmtiCodeBlobEvents.cpp" + + + + + THIS_FILE="jvmtiEnv.cpp" + + + + + THIS_FILE="jvmtiEnvBase.cpp" + + + + + THIS_FILE="jvmtiEnvThreadState.cpp" + + + + + THIS_FILE="jvmtiEventController.cpp" + + + + + THIS_FILE="jvmtiExport.cpp" + + + + + THIS_FILE="jvmtiExtensions.cpp" + + + + + THIS_FILE="jvmtiGetLoadedClasses.cpp" + + + + + THIS_FILE="jvmtiImpl.cpp" + + + + + THIS_FILE="jvmtiManageCapabilities.cpp" + + + + + THIS_FILE="jvmtiRawMonitor.cpp" + + + + + THIS_FILE="jvmtiRedefineClasses.cpp" + + + + + THIS_FILE="jvmtiTagMap.cpp" + + + + + THIS_FILE="jvmtiThreadState.cpp" + + + + + THIS_FILE="jvmtiTrace.cpp" + + + + + THIS_FILE="jvmtiUtil.cpp" + + + + + THIS_FILE="methodComparator.cpp" + + + + + THIS_FILE="methodHandles.cpp" + + + + + THIS_FILE="nativeLookup.cpp" + + + + + THIS_FILE="perf.cpp" + + + + + THIS_FILE="privilegedStack.cpp" + + + + + + + THIS_FILE="stackwalk.cpp" + + + + + THIS_FILE="unsafe.cpp" + + + + + + + THIS_FILE="whitebox.cpp" + + + + + + + THIS_FILE="whitebox_ext.cpp" + + - - + + + + + THIS_FILE="arguments.cpp" + + + + + THIS_FILE="atomic.cpp" + + + + + THIS_FILE="basicLock.cpp" + + + + + THIS_FILE="biasedLocking.cpp" + + + + + + + THIS_FILE="commandLineFlagConstraintList.cpp" + + + + + + + THIS_FILE="commandLineFlagConstraintsCompiler.cpp" + + + + + + + THIS_FILE="commandLineFlagConstraintsGC.cpp" + + + + + + + THIS_FILE="commandLineFlagConstraintsRuntime.cpp" + + + + + + + THIS_FILE="commandLineFlagRangeList.cpp" + + + + + + + THIS_FILE="commandLineFlagWriteableList.cpp" + + + + + THIS_FILE="compilationPolicy.cpp" + + - - + + + THIS_FILE="deoptimization.cpp" + + + + + THIS_FILE="fieldDescriptor.cpp" + + + + + THIS_FILE="fieldType.cpp" + + + + + THIS_FILE="fprofiler.cpp" + + + + + THIS_FILE="frame.cpp" + + + + + THIS_FILE="globals.cpp" + + + + + THIS_FILE="handles.cpp" + + + + + THIS_FILE="icache.cpp" + + + + + THIS_FILE="init.cpp" + + + + + THIS_FILE="interfaceSupport.cpp" + + + + + THIS_FILE="java.cpp" + + + + + THIS_FILE="javaCalls.cpp" + + + + + THIS_FILE="jniHandles.cpp" + + + + + THIS_FILE="jniPeriodicChecker.cpp" + + + + + THIS_FILE="memprofiler.cpp" + + + + + THIS_FILE="monitorChunk.cpp" + + + + + THIS_FILE="mutex.cpp" + + + + + THIS_FILE="mutexLocker.cpp" + + + + + THIS_FILE="objectMonitor.cpp" + + + + + THIS_FILE="orderAccess.cpp" + + + + + THIS_FILE="os.cpp" + + + + + THIS_FILE="osThread.cpp" + + + + + THIS_FILE="park.cpp" + + + + + THIS_FILE="perfData.cpp" + + + + + THIS_FILE="perfMemory.cpp" + + + + + THIS_FILE="reflection.cpp" + + + + + THIS_FILE="reflectionUtils.cpp" + + + + + THIS_FILE="relocator.cpp" + + + + + THIS_FILE="rframe.cpp" + + + + + + + THIS_FILE="rtmLocking.cpp" + + + + + THIS_FILE="safepoint.cpp" + + + + + + + THIS_FILE="semaphore.cpp" + + + + + THIS_FILE="serviceThread.cpp" + + + + + THIS_FILE="sharedRuntime.cpp" + + + + + THIS_FILE="sharedRuntimeTrans.cpp" + + + + + THIS_FILE="sharedRuntimeTrig.cpp" + + + + + THIS_FILE="signature.cpp" + + + + + THIS_FILE="simpleThresholdPolicy.cpp" + + + + + THIS_FILE="stackValue.cpp" + + + + + THIS_FILE="stackValueCollection.cpp" + + + + + THIS_FILE="statSampler.cpp" + + + + + THIS_FILE="stubCodeGenerator.cpp" + + + + + THIS_FILE="stubRoutines.cpp" + + + + + THIS_FILE="sweeper.cpp" + + + + + THIS_FILE="synchronizer.cpp" + + + + + THIS_FILE="task.cpp" + + + + + THIS_FILE="thread.cpp" + + - + + + THIS_FILE="thread_ext.cpp" + + + + + THIS_FILE="timer.cpp" + + + + + + + THIS_FILE="timerTrace.cpp" + + + + + THIS_FILE="unhandledOops.cpp" + + + + + THIS_FILE="vframe.cpp" + + + + + THIS_FILE="vframeArray.cpp" + + - - + + + THIS_FILE="vframe_hp.cpp" + + + + + THIS_FILE="vmStructs.cpp" + + + + + THIS_FILE="vmThread.cpp" + + + + + THIS_FILE="vm_operations.cpp" + + - + + CPU="amd64" + DEBUG_LEVEL="slowdebug" + HOTSPOT_BUILD_USER="user" + HOTSPOT_VERSION_STRING="9-internal+0-2016-06-21-161756.vkvashin.jdktrunk" + HOTSPOT_VM_DISTRO="OpenJDK" + THIS_FILE="vm_version.cpp" + VERSION_BUILD=0 + VERSION_MAJOR=9 + VERSION_MINOR=0 + VERSION_NUMBER="9" + VERSION_OPT="2016-06-21-161756.vkvashin.jdktrunk" + VERSION_PATCH=0 + VERSION_PRE="internal" + VERSION_SECURITY=0 + VERSION_SHORT="9-internal" + VERSION_SPECIFICATION="9" + VERSION_STRING="9-internal+0-2016-06-21-161756.vkvashin.jdktrunk" @@ -27237,3545 +54586,4717 @@ ex="false" tool="1" flavor2="0"> + + + + + THIS_FILE="classLoadingService.cpp" + + + + + THIS_FILE="diagnosticArgument.cpp" + + + + + THIS_FILE="diagnosticCommand.cpp" + + + + + THIS_FILE="diagnosticFramework.cpp" + + + + + THIS_FILE="dtraceAttacher.cpp" + + + + + THIS_FILE="g1MemoryPool.cpp" + + + + + THIS_FILE="gcNotifier.cpp" + + + + + THIS_FILE="heapDumper.cpp" + + + + + THIS_FILE="lowMemoryDetector.cpp" + + + + + + + THIS_FILE="mallocSiteTable.cpp" + + + + + + + THIS_FILE="mallocTracker.cpp" + + + + + THIS_FILE="management.cpp" + + - - - - + + + THIS_FILE="memBaseline.cpp" + + - - - - + + + THIS_FILE="memReporter.cpp" + + + + + THIS_FILE="memTracker.cpp" + + + + + THIS_FILE="memoryManager.cpp" + + + + + THIS_FILE="memoryPool.cpp" + + + + + THIS_FILE="memoryService.cpp" + + + + + + + THIS_FILE="nmtCommon.cpp" + + + + + THIS_FILE="nmtDCmd.cpp" + + + + + THIS_FILE="psMemoryPool.cpp" + + + + + THIS_FILE="runtimeService.cpp" + + + + + THIS_FILE="threadService.cpp" + + + + + + + THIS_FILE="virtualMemoryTracker.cpp" + + + + + + + THIS_FILE="writeableFlags.cpp" + + + + + + - - + + + + + THIS_FILE="bitMap.cpp" + + + + + + + THIS_FILE="chunkedList.cpp" + + + + + THIS_FILE="constantTag.cpp" + + + + + THIS_FILE="copy.cpp" + + + + + THIS_FILE="debug.cpp" + + + + + THIS_FILE="decoder.cpp" + + + + + THIS_FILE="decoder_elf.cpp" + + + + + THIS_FILE="elfFile.cpp" + + + + + + + THIS_FILE="elfFuncDescTable.cpp" + + + + + THIS_FILE="elfStringTable.cpp" + + + + + THIS_FILE="elfSymbolTable.cpp" + + + + + THIS_FILE="errorReporter.cpp" + + + + + THIS_FILE="events.cpp" + + + + + THIS_FILE="exceptions.cpp" + + + + + THIS_FILE="globalDefinitions.cpp" + + + + + THIS_FILE="growableArray.cpp" + + + + + THIS_FILE="hashtable.cpp" + + + + + THIS_FILE="histogram.cpp" + + + + + THIS_FILE="intHisto.cpp" + + + + + + + THIS_FILE="internalVMTests.cpp" + + + + + + + THIS_FILE="json.cpp" + + + + + + + THIS_FILE="linkedlist.cpp" + + + + + + + THIS_FILE="nativeCallStack.cpp" + + + + + THIS_FILE="numberSeq.cpp" + + + + + THIS_FILE="ostream.cpp" + + + + + THIS_FILE="preserveException.cpp" + + + + + THIS_FILE="quickSort.cpp" + + + + + + + THIS_FILE="resourceHash.cpp" + + + + + THIS_FILE="sizes.cpp" + + - + + + THIS_FILE="stringUtils.cpp" + + + + + + + THIS_FILE="ticks.cpp" + + + + + THIS_FILE="utf8.cpp" + + - - + + + THIS_FILE="vmError.cpp" + + + + + THIS_FILE="xmlstream.cpp" + + - - - - - - - - - - - - THIS_FILE="ArrayTypeImpl.c" - - - - - - - THIS_FILE="ClassLoaderReferenceImpl.c" - - - - - - - THIS_FILE="ClassObjectReferenceImpl.c" - - - - - - - THIS_FILE="ClassTypeImpl.c" - - - - - - - THIS_FILE="EventRequestImpl.c" - - - - - - - THIS_FILE="FieldImpl.c" - - - - - - - THIS_FILE="FrameID.c" - - - - - - - THIS_FILE="MethodImpl.c" - - - - - - - THIS_FILE="ObjectReferenceImpl.c" - - - - - - - THIS_FILE="ReferenceTypeImpl.c" - - - - - - - THIS_FILE="SDE.c" - - - - - - - THIS_FILE="StackFrameImpl.c" - - - - - - - THIS_FILE="StringReferenceImpl.c" - - - - - - - THIS_FILE="ThreadGroupReferenceImpl.c" - - - - - - - THIS_FILE="ThreadReferenceImpl.c" - - - - - - - THIS_FILE="VirtualMachineImpl.c" - - - - - - - THIS_FILE="bag.c" - - - - - - - THIS_FILE="classTrack.c" - - - - - - - THIS_FILE="commonRef.c" - - - - - - - THIS_FILE="debugDispatch.c" - - - - - - - THIS_FILE="debugInit.c" - - - - - - - THIS_FILE="debugLoop.c" - - - - - - - THIS_FILE="error_messages.c" - - - - - - - THIS_FILE="eventFilter.c" - - - - - - - THIS_FILE="eventHandler.c" - - - - - - - THIS_FILE="eventHelper.c" - - - - - - - THIS_FILE="inStream.c" - - - - - - - THIS_FILE="invoker.c" - - - - - - - THIS_FILE="log_messages.c" - - - - - - - THIS_FILE="outStream.c" - - - - - - - THIS_FILE="standardHandlers.c" - - - - - - - THIS_FILE="stepControl.c" - - - - - - - THIS_FILE="stream.c" - - - - - - - THIS_FILE="threadControl.c" - - - - - - - THIS_FILE="transport.c" - - - - - - - THIS_FILE="util.c" - - - - - + - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make + ../../hotspot/make - LIBARCH32NAME="i386" - LIBARCH64NAME="amd64" + THIS_FILE="gtestLauncher.cpp" - + - - - - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - - - LIBARCH32NAME="i386" - LIBARCH64NAME="amd64" - THIS_FILE="jli_util.c" - - - - - - - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/make - - - EXPAND_CLASSPATH_WILDCARDS - HAVE_GETHRTIME - JAVA_ARGS={ "-J-ms8m", "com.sun.tools.javac.Main", } - LAUNCHER_NAME="openjdk" - NEVER_ACT_AS_SERVER_CLASS_MACHINE - PROGNAME="javac" - THIS_FILE="main.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - - - LIBARCH32NAME="i386" - LIBARCH64NAME="amd64" - THIS_FILE="parse_manifest.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - - - LIBARCH32NAME="i386" - LIBARCH64NAME="amd64" - THIS_FILE="splashscreen_stubs.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - - - LIBARCH32NAME="i386" - LIBARCH64NAME="amd64" - THIS_FILE="version_comp.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - - - LIBARCH32NAME="i386" - LIBARCH64NAME="amd64" - THIS_FILE="wildcard.c" - - - - - - - - - - - - - - - - - - - THIS_FILE="hprof_blocks.c" - - - - - - - THIS_FILE="hprof_check.c" - - - - - - - THIS_FILE="hprof_class.c" - - - - - - - THIS_FILE="hprof_cpu.c" - - - - - - - THIS_FILE="hprof_error.c" - - - - - - - THIS_FILE="hprof_event.c" - - - - - - - THIS_FILE="hprof_frame.c" - - - - - - - THIS_FILE="hprof_init.c" - - - - - - - THIS_FILE="hprof_io.c" - - - - - - - THIS_FILE="hprof_ioname.c" - - - - - - - THIS_FILE="hprof_listener.c" - - - - - - - THIS_FILE="hprof_loader.c" - - - - - - - THIS_FILE="hprof_monitor.c" - - - - - - - THIS_FILE="hprof_object.c" - - - - - - - THIS_FILE="hprof_reference.c" - - - - - - - THIS_FILE="hprof_site.c" - - - - - - - THIS_FILE="hprof_stack.c" - - - - - - - THIS_FILE="hprof_string.c" - - - - - - - THIS_FILE="hprof_table.c" - - - - - - - THIS_FILE="hprof_tag.c" - - - - - - - THIS_FILE="hprof_tls.c" - - - - - - - THIS_FILE="hprof_trace.c" - - - - - - - THIS_FILE="hprof_tracker.c" - - - - - - - THIS_FILE="hprof_util.c" - - - - - - - - - - - - + + + ../../hotspot/test/native + ../../hotspot/make + + + GTEST_HAS_EXCEPTIONS=0 + THIS_FILE="gtestMain.cpp" + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + THIS_FILE="Monitor.cpp" - - + THIS_FILE="Thread.cpp" - - + THIS_FILE="waiters.cpp" - - - - - - THIS_FILE="InstrumentationImplNativeMethods.c" - + - - - - THIS_FILE="InvocationAdapter.c" - + - - - - THIS_FILE="JPLISAgent.c" - + - - - - THIS_FILE="JPLISAssert.c" - - - - - - - THIS_FILE="JarFacade.c" - - - - - - - THIS_FILE="JavaExceptions.c" - - - - - - - THIS_FILE="PathCharsValidator.c" - - - - - - - THIS_FILE="Reentrancy.c" - - - - - - - THIS_FILE="Utilities.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - NO_ZLIB - UNPACK_JNI - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - NO_ZLIB - THIS_FILE="bytes.cpp" - UNPACK_JNI - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - NO_ZLIB - THIS_FILE="coding.cpp" - UNPACK_JNI - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - NO_ZLIB - THIS_FILE="jni.cpp" - UNPACK_JNI - - - - - - - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../jdk/make - - - THIS_FILE="main.cpp" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - NO_ZLIB - THIS_FILE="unpack.cpp" - UNPACK_JNI - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - NO_ZLIB - THIS_FILE="utils.cpp" - UNPACK_JNI - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - NO_ZLIB - THIS_FILE="zip.cpp" - UNPACK_JNI - - - - - - - - - THIS_FILE="DirectAudioDeviceProvider.c" - - - - - - - THIS_FILE="MidiInDevice.c" - - - - - - - THIS_FILE="MidiInDeviceProvider.c" - - - - - - - THIS_FILE="MidiOutDevice.c" - - - - - - - THIS_FILE="MidiOutDeviceProvider.c" - - - - - - - THIS_FILE="Platform.c" - - - - - - - THIS_FILE="PlatformMidi.c" - - - - - - - THIS_FILE="PortMixer.c" - - - - - - - THIS_FILE="PortMixerProvider.c" - - - - - - - THIS_FILE="Utilities.c" - - - - - - - ../../jdk/make - - - - - - - ../../jdk/make - - - THIS_FILE="check_format.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="check_version.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="jdk_util.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="jio.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="jni_util.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="verify_stub.c" - - - - - - - - - THIS_FILE="ObjectInputStream.c" - - - - - - - THIS_FILE="ObjectOutputStream.c" - - - - - - - THIS_FILE="ObjectStreamClass.c" - - - - - - - THIS_FILE="RandomAccessFile.c" - - - - - - - THIS_FILE="io_util.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Class.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="ClassLoader.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Compiler.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Double.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Float.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Object.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Package.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="ResourceBundle.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Runtime.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="SecurityManager.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Shutdown.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="StrictMath.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="String.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="System.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Thread.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Throwable.c" - - - - - - - + THIS_FILE="e_asin.c" - - + THIS_FILE="e_atan2.c" - - + THIS_FILE="e_atanh.c" - - + THIS_FILE="e_cosh.c" - - + THIS_FILE="e_exp.c" - - + THIS_FILE="e_fmod.c" - - - - THIS_FILE="e_hypot.c" - - - - - + THIS_FILE="e_log.c" - - + THIS_FILE="e_log10.c" - - - - THIS_FILE="e_pow.c" - - - - - + THIS_FILE="e_rem_pio2.c" - - + THIS_FILE="e_remainder.c" - - + THIS_FILE="e_scalb.c" - - + THIS_FILE="e_sinh.c" - - + THIS_FILE="e_sqrt.c" - - + THIS_FILE="k_cos.c" - - + THIS_FILE="k_rem_pio2.c" - - + THIS_FILE="k_sin.c" - - + THIS_FILE="k_standard.c" - - + THIS_FILE="k_tan.c" - - + THIS_FILE="s_atan.c" - - - - THIS_FILE="s_cbrt.c" - - - - - + THIS_FILE="s_ceil.c" - - + THIS_FILE="s_copysign.c" - - + THIS_FILE="s_cos.c" - - + THIS_FILE="s_expm1.c" - - + THIS_FILE="s_fabs.c" - - + THIS_FILE="s_finite.c" - - + THIS_FILE="s_floor.c" - - + THIS_FILE="s_frexp.c" - - + THIS_FILE="s_ilogb.c" - - + THIS_FILE="s_isnan.c" - - + THIS_FILE="s_ldexp.c" - - + THIS_FILE="s_lib_version.c" - - + THIS_FILE="s_log1p.c" - - + THIS_FILE="s_logb.c" - - + THIS_FILE="s_matherr.c" - - + THIS_FILE="s_modf.c" - - + THIS_FILE="s_nextafter.c" - - + THIS_FILE="s_rint.c" - - + THIS_FILE="s_scalbn.c" - - + THIS_FILE="s_signgam.c" - - + THIS_FILE="s_significand.c" - - + THIS_FILE="s_sin.c" - - + THIS_FILE="s_tan.c" - - + THIS_FILE="s_tanh.c" - - + THIS_FILE="w_acos.c" - - + THIS_FILE="w_asin.c" - - + THIS_FILE="w_atan2.c" - - + THIS_FILE="w_atanh.c" - - + THIS_FILE="w_cosh.c" - - + THIS_FILE="w_exp.c" - - + THIS_FILE="w_fmod.c" - - - - THIS_FILE="w_hypot.c" - - - - - + THIS_FILE="w_log.c" - - + THIS_FILE="w_log10.c" - - - - THIS_FILE="w_pow.c" - - - - - + THIS_FILE="w_remainder.c" - - + THIS_FILE="w_scalb.c" - - + THIS_FILE="w_sinh.c" - - + THIS_FILE="w_sqrt.c" - + + - + + + THIS_FILE="Array.c" + + - - + + + THIS_FILE="AtomicLong.c" + + + + + + + THIS_FILE="BootLoader.c" + + + + + + + THIS_FILE="Class.c" + + + + + + + THIS_FILE="ClassLoader.c" + + + + + + + THIS_FILE="ConstantPool.c" + + + + + + + THIS_FILE="Double.c" + + + + + THIS_FILE="Executable.c" - - + - THIS_FILE="Proxy.c" + THIS_FILE="Field.c" - + + + THIS_FILE="FileInputStream.c" + + - - + + + THIS_FILE="Float.c" + + + + + + + THIS_FILE="Module.c" + + + + + + + THIS_FILE="NativeAccessors.c" + + + + + + + THIS_FILE="Object.c" + + + + + + + THIS_FILE="ObjectInputStream.c" + + + + + + + THIS_FILE="ObjectOutputStream.c" + + + + + + + THIS_FILE="ObjectStreamClass.c" + + + + + + + THIS_FILE="RandomAccessFile.c" + + + + + + + THIS_FILE="Reflection.c" + + + + + + + THIS_FILE="Runtime.c" + + + + + + + THIS_FILE="SecurityManager.c" + + + + + + + THIS_FILE="Shutdown.c" + + + + + + + THIS_FILE="Signal.c" + + + + + + + THIS_FILE="StackFrameInfo.c" + + + + + + + THIS_FILE="StackStreamFactory.c" + + + + + + + THIS_FILE="StrictMath.c" + + + + + + + THIS_FILE="String.c" + + + + + + + THIS_FILE="StringCoding.c" + + + + + + + THIS_FILE="System.c" + VERSION_BUILD=0 + VERSION_MAJOR=9 + VERSION_MINOR=0 + VERSION_NUMBER="9" + VERSION_OPT="2016-06-21-161756.vkvashin.jdktrunk" + VERSION_PATCH=0 + VERSION_PRE="internal" + VERSION_SECURITY=0 + VERSION_SHORT="9-internal" + VERSION_SPECIFICATION="9" + VERSION_STRING="9-internal+0-2016-06-21-161756.vkvashin.jdktrunk" + + + + + + + THIS_FILE="Thread.c" + + + + + + + THIS_FILE="Throwable.c" + + + + + + + THIS_FILE="TimeZone.c" + + + + + + + THIS_FILE="VM.c" + + + + + + + THIS_FILE="VMSupport.c" + + + + + + + THIS_FILE="check_version.c" + + + + + + + THIS_FILE="io_util.c" + + + + + + + THIS_FILE="jdk_util.c" + VERSION_BUILD=0 + VERSION_MAJOR=9 + VERSION_MINOR=0 + VERSION_NUMBER="9" + VERSION_OPT="2016-06-21-161756.vkvashin.jdktrunk" + VERSION_PATCH=0 + VERSION_PRE="internal" + VERSION_SECURITY=0 + VERSION_SHORT="9-internal" + VERSION_SPECIFICATION="9" + VERSION_STRING="9-internal+0-2016-06-21-161756.vkvashin.jdktrunk" + + + + + + + THIS_FILE="jio.c" + + + + + + + THIS_FILE="jni_util.c" + + + + + + + THIS_FILE="verify_stub.c" + + + + + + + + + + + THIS_FILE="endian.cpp" + + + + + + + THIS_FILE="imageDecompressor.cpp" + + + + + + + THIS_FILE="imageFile.cpp" + + + + + + + THIS_FILE="jimage.cpp" + + + + + + + + + + + THIS_FILE="java.c" + + + + + + + THIS_FILE="jli_util.c" + + + + + + + THIS_FILE="parse_manifest.c" + + + + + + + THIS_FILE="splashscreen_stubs.c" + + + + + + + THIS_FILE="wildcard.c" + + + + + + + + + THIS_FILE="Inet4Address.c" - - + THIS_FILE="Inet6Address.c" - - + THIS_FILE="InetAddress.c" - - + THIS_FILE="net_util.c" - + + - + + - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - + - ARCHPROPNAME="amd64" - THIS_FILE="TimeZone.c" + THIS_FILE="check_format.c" - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/make - - - THIS_FILE="Adler32.c" - USE_MMAP - - - DEBUG - + - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/make - + THIS_FILE="CRC32.c" - USE_MMAP - - DEBUG - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/make - + THIS_FILE="Deflater.c" - USE_MMAP - - DEBUG - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/make - + THIS_FILE="Inflater.c" - USE_MMAP - - DEBUG - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/make - - - THIS_FILE="ZipFile.c" - USE_MMAP - - - DEBUG - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/make - + THIS_FILE="zip_util.c" - USE_MMAP - - DEBUG - - + + - - + + + + + + + + + - THIS_FILE="deflate.c" + THIS_FILE="SolarisEventPort.c" - - + + + + + - THIS_FILE="gzclose.c" + THIS_FILE="SolarisWatchService.c" - - + + + + + + + + + - THIS_FILE="gzlib.c" + THIS_FILE="FileDescriptor_md.c" - - + - THIS_FILE="gzread.c" + THIS_FILE="FileInputStream_md.c" - - + - THIS_FILE="gzwrite.c" + THIS_FILE="FileOutputStream_md.c" - - + - THIS_FILE="infback.c" + THIS_FILE="ProcessEnvironment_md.c" - - + - THIS_FILE="inffast.c" + THIS_FILE="ProcessHandleImpl_unix.c" - - + - THIS_FILE="inflate.c" + THIS_FILE="ProcessImpl_md.c" - - + - THIS_FILE="inftrees.c" + THIS_FILE="RandomAccessFile_md.c" - - + - THIS_FILE="trees.c" + THIS_FILE="TimeZone_md.c" - - + - THIS_FILE="uncompr.c" + THIS_FILE="UnixFileSystem_md.c" - - + - THIS_FILE="zadler32.c" + THIS_FILE="VM_md.c" - - + - THIS_FILE="zcrc32.c" + THIS_FILE="canonicalize_md.c" - - + - THIS_FILE="zutil.c" + THIS_FILE="childproc.c" - + + + THIS_FILE="io_util_md.c" + + - - + + + THIS_FILE="java_props_md.c" + + + + + + + THIS_FILE="jdk_util_md.c" + + + + + + + THIS_FILE="jni_util_md.c" + + + + + + + + + + + + + + + THIS_FILE="ergo_i586.c" + + + + + + + THIS_FILE="java_md_common.c" + + + + + + + THIS_FILE="java_md_solinux.c" + + + + + + + + + + + THIS_FILE="Inet4AddressImpl.c" + + + + + + + THIS_FILE="Inet6AddressImpl.c" + + + + + + + THIS_FILE="InetAddressImplFactory.c" + + + + + + + THIS_FILE="NetworkInterface.c" + + + + + + + THIS_FILE="PlainDatagramSocketImpl.c" + + + + + + + THIS_FILE="PlainSocketImpl.c" + + + + + + + THIS_FILE="ResolverConfigurationImpl.c" + + + + + + + THIS_FILE="SdpSupport.c" + + + + + + + THIS_FILE="SocketImpl.c" + + + + + + + THIS_FILE="SocketInputStream.c" + + + + + + + THIS_FILE="SocketOutputStream.c" + + + + + + + THIS_FILE="net_util_md.c" + + + + + + + THIS_FILE="portconfig.c" + + + + + + + THIS_FILE="MappedByteBuffer.c" + + + + + + + + + + + THIS_FILE="DatagramDispatcher.c" + + + + + + + THIS_FILE="FileChannelImpl.c" + + + + + + + THIS_FILE="FileDispatcherImpl.c" + + + + + + + THIS_FILE="FileKey.c" + + + + + + + THIS_FILE="IOUtil.c" + + + + + + + THIS_FILE="InheritedChannel.c" + + + + + + + THIS_FILE="NativeThread.c" + + + + + + + THIS_FILE="Net.c" + + + + + + + THIS_FILE="PollArrayWrapper.c" + + + + + + + THIS_FILE="ServerSocketChannelImpl.c" + + + + + + + THIS_FILE="SocketChannelImpl.c" + + + + + + + THIS_FILE="SocketDispatcher.c" + + + + + + + THIS_FILE="UnixAsynchronousServerSocketChannelImpl.c" + + + + + + + THIS_FILE="UnixAsynchronousSocketChannelImpl.c" + + + + + + + + + + + THIS_FILE="UnixCopyFile.c" + + + + + + + THIS_FILE="UnixNativeDispatcher.c" + + + + + + + + + THIS_FILE="debug_mem.c" - - + THIS_FILE="debug_trace.c" - - + THIS_FILE="debug_util.c" - + + - - + - THIS_FILE="gif_err.c" + THIS_FILE="mlib_ImageCreate.c" - - + - THIS_FILE="gifalloc.c" + THIS_FILE="mlib_sys.c" - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - + + + + + + + + + + + + + + + THIS_FILE="OGLBufImgOps.c" + + + + + + + THIS_FILE="OGLContext.c" + + + + + + + THIS_FILE="OGLFuncs.c" + + + + + + + THIS_FILE="OGLMaskBlit.c" + + + + + + + THIS_FILE="OGLMaskFill.c" + + + + + + + THIS_FILE="OGLPaints.c" + + + + + + + THIS_FILE="OGLRenderQueue.c" + + + + + + + THIS_FILE="OGLRenderer.c" + + + + + + + THIS_FILE="OGLSurfaceData.c" + + + + + + + THIS_FILE="OGLTextRenderer.c" + + + + + + + THIS_FILE="OGLVertexCache.c" + + + + + - INTERNAL_BUILD THIS_FILE="BufImgSurfaceData.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - + - INTERNAL_BUILD THIS_FILE="DataBufferNative.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - + - INTERNAL_BUILD THIS_FILE="awt_ImageRep.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - + - INTERNAL_BUILD THIS_FILE="awt_parseImage.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - + + - - + THIS_FILE="img_globals.c" - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - + - INTERNAL_BUILD THIS_FILE="dither.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - + + - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - + - INTERNAL_BUILD THIS_FILE="imageInitIDs.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - + + + + + + + THIS_FILE="Disposer.c" + + + + + + + THIS_FILE="SurfaceData.c" + + + + + + + THIS_FILE="Trace.c" + + + + + + + + + + + THIS_FILE="AlphaMath.c" + + + + + + + THIS_FILE="Any3Byte.c" + + + + + + + THIS_FILE="Any4Byte.c" + + + + + + + THIS_FILE="AnyByte.c" + + + + + + + THIS_FILE="AnyInt.c" + + + + + + + THIS_FILE="AnyShort.c" + + + + + + + THIS_FILE="Blit.c" + + + + + + + THIS_FILE="BlitBg.c" + + + + + + + THIS_FILE="ByteBinary1Bit.c" + + + + + + + THIS_FILE="ByteBinary2Bit.c" + + + + + + + THIS_FILE="ByteBinary4Bit.c" + + + + + + + THIS_FILE="ByteGray.c" + + + + + + + THIS_FILE="ByteIndexed.c" + + + + + + + THIS_FILE="DrawLine.c" + + + + + + + THIS_FILE="DrawParallelogram.c" + + + + + + + THIS_FILE="DrawPath.c" + + + + + + + THIS_FILE="DrawPolygons.c" + + + + + + + THIS_FILE="DrawRect.c" + + + + + + + THIS_FILE="FillParallelogram.c" + + + + + + + THIS_FILE="FillPath.c" + + + + + + + THIS_FILE="FillRect.c" + + + + + + + THIS_FILE="FillSpans.c" + + + + + + + THIS_FILE="FourByteAbgr.c" + + + + + + + THIS_FILE="FourByteAbgrPre.c" + + + + + + + THIS_FILE="GraphicsPrimitiveMgr.c" + + + + + + + THIS_FILE="Index12Gray.c" + + + + + + + THIS_FILE="Index8Gray.c" + + + + + + + THIS_FILE="IntArgb.c" + + + + + + + THIS_FILE="IntArgbBm.c" + + + + + + + THIS_FILE="IntArgbPre.c" + + + + + + + THIS_FILE="IntBgr.c" + + + + + + + THIS_FILE="IntRgb.c" + + + + + + + THIS_FILE="IntRgbx.c" + + + + + + + THIS_FILE="MapAccelFunc.c" + + + + + + + THIS_FILE="MaskBlit.c" + + + + + + + THIS_FILE="MaskFill.c" + + + + + + + THIS_FILE="ProcessPath.c" + + + + + + + THIS_FILE="ScaledBlit.c" + + + + + + + THIS_FILE="ThreeByteBgr.c" + + + + + + + THIS_FILE="TransformHelper.c" + + + + + + + THIS_FILE="Ushort4444Argb.c" + + + + + + + THIS_FILE="Ushort555Rgb.c" + + + + + + + THIS_FILE="Ushort555Rgbx.c" + + + + + + + THIS_FILE="Ushort565Rgb.c" + + + + + + + THIS_FILE="UshortGray.c" + + + + + + + THIS_FILE="UshortIndexed.c" + + + + + + + + + + + THIS_FILE="BufferedRenderPipe.c" + + + + + + + THIS_FILE="Region.c" + + + + + + + THIS_FILE="ShapeSpanIterator.c" + + + + + + + THIS_FILE="SpanClipRenderer.c" + + + + + + + THIS_FILE="DrawGlyphList.c" + + + + + + + THIS_FILE="FontInstanceAdapter.cpp" + + + + + + + THIS_FILE="HBShaper.c" + + + + + + + THIS_FILE="freetypeScaler.c" + + + + + + + + + + + THIS_FILE="hb-buffer-serialize.cc" + + + + + + + THIS_FILE="hb-buffer.cc" + + + + + + + THIS_FILE="hb-common.cc" + + + + + + + THIS_FILE="hb-face.cc" + + + + + + + THIS_FILE="hb-fallback-shape.cc" + + + + + + + THIS_FILE="hb-font.cc" + + + + + + + THIS_FILE="hb-ot-font.cc" + + + + + + + THIS_FILE="hb-ot-layout.cc" + + + + + + + THIS_FILE="hb-ot-map.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-arabic.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-default.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-hangul.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-hebrew.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-indic-table.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-indic.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-myanmar.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-thai.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-tibetan.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-use-table.cc" + + + + + + + THIS_FILE="hb-ot-shape-complex-use.cc" + + + + + + + THIS_FILE="hb-ot-shape-fallback.cc" + + + + + + + THIS_FILE="hb-ot-shape-normalize.cc" + + + + + + + THIS_FILE="hb-ot-shape.cc" + + + + + + + THIS_FILE="hb-ot-tag.cc" + + + + + + + THIS_FILE="hb-set.cc" + + + + + + + THIS_FILE="hb-shape-plan.cc" + + + + + + + THIS_FILE="hb-shape.cc" + + + + + + + THIS_FILE="hb-shaper.cc" + + + + + + + THIS_FILE="hb-ucdn.cc" + + + + + + + + + + + THIS_FILE="hb-unicode.cc" + + + + + + + THIS_FILE="hb-warning.cc" + + + + + + + THIS_FILE="hb-jdk-font.cc" + + + + + + + + + + + THIS_FILE="AnchorTables.cpp" + + + + + + + THIS_FILE="ArabicLayoutEngine.cpp" + + + + + + + THIS_FILE="ArabicShaping.cpp" + + + + + + + THIS_FILE="CanonData.cpp" + + + + + + + THIS_FILE="CanonShaping.cpp" + + + + + + + THIS_FILE="ClassDefinitionTables.cpp" + + + + + + + THIS_FILE="ContextualGlyphInsertionProc2.cpp" + + + + + + + THIS_FILE="ContextualGlyphSubstProc.cpp" + + + + + + + THIS_FILE="ContextualGlyphSubstProc2.cpp" + + + + + + + THIS_FILE="ContextualSubstSubtables.cpp" + + + + + + + THIS_FILE="CoverageTables.cpp" + + + + + + + THIS_FILE="CursiveAttachmentSubtables.cpp" + + + + + + + THIS_FILE="DeviceTables.cpp" + + + + + + + THIS_FILE="ExtensionSubtables.cpp" + + + + + + + THIS_FILE="Features.cpp" + + + + + + + THIS_FILE="GDEFMarkFilter.cpp" + + + + + + + THIS_FILE="GXLayoutEngine.cpp" + + + + + + + THIS_FILE="GXLayoutEngine2.cpp" + + + + + + + THIS_FILE="GlyphDefinitionTables.cpp" + + + + + + + THIS_FILE="GlyphIterator.cpp" + + + + + + + THIS_FILE="GlyphLookupTables.cpp" + + + + + + + THIS_FILE="GlyphPositionAdjustments.cpp" + + + + + + + THIS_FILE="GlyphPositioningTables.cpp" + + + + + + + THIS_FILE="GlyphPosnLookupProc.cpp" + + + + + + + THIS_FILE="GlyphSubstLookupProc.cpp" + + + + + + + THIS_FILE="GlyphSubstitutionTables.cpp" + + + + + + + THIS_FILE="HanLayoutEngine.cpp" + + + + + + + THIS_FILE="HangulLayoutEngine.cpp" + + + + + + + THIS_FILE="IndicClassTables.cpp" + + + + + + + THIS_FILE="IndicLayoutEngine.cpp" + + + + + + + THIS_FILE="IndicRearrangementProcessor.cpp" + + + + + + + THIS_FILE="IndicRearrangementProcessor2.cpp" + + + + + + + THIS_FILE="IndicReordering.cpp" + + + + + + + THIS_FILE="KernTable.cpp" + + + + + + + THIS_FILE="KhmerLayoutEngine.cpp" + + + + + + + THIS_FILE="KhmerReordering.cpp" + + + + + + + THIS_FILE="LEFontInstance.cpp" + + + + + + + THIS_FILE="LEGlyphStorage.cpp" + + + + + + + THIS_FILE="LEInsertionList.cpp" + + + + + + + THIS_FILE="LayoutEngine.cpp" + + + + + + + THIS_FILE="LigatureSubstProc.cpp" + + + + + + + THIS_FILE="LigatureSubstProc2.cpp" + + + + + + + THIS_FILE="LigatureSubstSubtables.cpp" + + + + + + + THIS_FILE="LookupProcessor.cpp" + + + + + + + THIS_FILE="LookupTables.cpp" + + + + + + + THIS_FILE="Lookups.cpp" + + + + + + + THIS_FILE="MPreFixups.cpp" + + + + + + + THIS_FILE="MarkArrays.cpp" + + + + + + + THIS_FILE="MarkToBasePosnSubtables.cpp" + + + + + + + THIS_FILE="MarkToLigaturePosnSubtables.cpp" + + + + + + + THIS_FILE="MarkToMarkPosnSubtables.cpp" + + + + + + + THIS_FILE="MirroredCharData.cpp" + + + + + + + THIS_FILE="MorphTables.cpp" + + + + + + + THIS_FILE="MorphTables2.cpp" + + + + + + + THIS_FILE="MultipleSubstSubtables.cpp" + + + + + + + THIS_FILE="NonContextualGlyphSubstProc.cpp" + + + + + + + THIS_FILE="NonContextualGlyphSubstProc2.cpp" + + + + + + + THIS_FILE="OpenTypeLayoutEngine.cpp" + + + + + + + THIS_FILE="OpenTypeUtilities.cpp" + + + + + + + THIS_FILE="PairPositioningSubtables.cpp" + + + + + + + THIS_FILE="ScriptAndLanguage.cpp" + + + + + + + THIS_FILE="ScriptAndLanguageTags.cpp" + + + + + + + THIS_FILE="SegmentArrayProcessor.cpp" + + + + + + + THIS_FILE="SegmentArrayProcessor2.cpp" + + + + + + + THIS_FILE="SegmentSingleProcessor.cpp" + + + + + + + THIS_FILE="SegmentSingleProcessor2.cpp" + + + + + + + THIS_FILE="ShapingTypeData.cpp" + + + + + + + THIS_FILE="SimpleArrayProcessor.cpp" + + + + + + + THIS_FILE="SimpleArrayProcessor2.cpp" + + + + + + + THIS_FILE="SinglePositioningSubtables.cpp" + + + + + + + THIS_FILE="SingleSubstitutionSubtables.cpp" + + + + + + + THIS_FILE="SingleTableProcessor.cpp" + + + + + + + THIS_FILE="SingleTableProcessor2.cpp" + + + + + + + THIS_FILE="StateTableProcessor.cpp" + + + + + + + THIS_FILE="StateTableProcessor2.cpp" + + + + + + + THIS_FILE="SubstitutionLookups.cpp" + + + + + + + THIS_FILE="SubtableProcessor.cpp" + + + + + + + THIS_FILE="SubtableProcessor2.cpp" + + + + + + + THIS_FILE="SunLayoutEngine.cpp" + + + + + + + THIS_FILE="ThaiLayoutEngine.cpp" + + + + + + + THIS_FILE="ThaiShaping.cpp" + + + + + + + THIS_FILE="ThaiStateTables.cpp" + + + + + + + THIS_FILE="TibetanLayoutEngine.cpp" + + + + + + + THIS_FILE="TibetanReordering.cpp" + + + + + + + THIS_FILE="TrimmedArrayProcessor.cpp" + + + + + + + THIS_FILE="TrimmedArrayProcessor2.cpp" + + + + + + + THIS_FILE="ValueRecords.cpp" + + + + + + + THIS_FILE="scriptMapping.c" + + + + + + + THIS_FILE="sunFont.c" + + + + + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.base/solaris/native/libjava + ../../build/support/headers/java.desktop + ../../make - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jcapimin.c" @@ -30783,30 +59304,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jcapistd.c" @@ -30814,30 +59335,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jccoefct.c" @@ -30845,30 +59366,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jccolor.c" @@ -30876,30 +59397,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jcdctmgr.c" @@ -30907,30 +59428,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jchuff.c" @@ -30938,30 +59459,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jcinit.c" @@ -30969,30 +59490,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jcmainct.c" @@ -31000,30 +59521,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jcmarker.c" @@ -31031,30 +59552,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jcmaster.c" @@ -31062,30 +59583,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jcomapi.c" @@ -31093,30 +59614,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jcparam.c" @@ -31124,30 +59645,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jcphuff.c" @@ -31155,30 +59676,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jcprepct.c" @@ -31186,30 +59707,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jcsample.c" @@ -31217,30 +59738,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jctrans.c" @@ -31248,30 +59769,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jdapimin.c" @@ -31279,30 +59800,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jdapistd.c" @@ -31310,30 +59831,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jdcoefct.c" @@ -31341,30 +59862,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jdcolor.c" @@ -31372,30 +59893,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jddctmgr.c" @@ -31403,30 +59924,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jdhuff.c" @@ -31434,30 +59955,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jdinput.c" @@ -31465,30 +59986,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jdmainct.c" @@ -31496,30 +60017,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jdmarker.c" @@ -31527,30 +60048,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jdmaster.c" @@ -31558,30 +60079,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jdmerge.c" @@ -31589,30 +60110,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jdphuff.c" @@ -31620,30 +60141,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jdpostct.c" @@ -31651,30 +60172,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jdsample.c" @@ -31682,30 +60203,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jdtrans.c" @@ -31713,30 +60234,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jerror.c" @@ -31744,30 +60265,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jfdctflt.c" @@ -31775,30 +60296,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jfdctfst.c" @@ -31806,30 +60327,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jfdctint.c" @@ -31837,30 +60358,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jidctflt.c" @@ -31868,30 +60389,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jidctfst.c" @@ -31899,30 +60420,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jidctint.c" @@ -31930,30 +60451,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jidctred.c" @@ -31961,30 +60482,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jmemmgr.c" @@ -31992,30 +60513,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jmemnobs.c" @@ -32023,51 +60544,51 @@ - - + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.base/solaris/native/libjava + ../../build/support/headers/java.desktop + ../../make THIS_FILE="jpegdecoder.c" - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jquant1.c" @@ -32075,30 +60596,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jquant2.c" @@ -32106,30 +60627,30 @@ - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="jutils.c" @@ -32137,6693 +60658,4039 @@ - - - - - - THIS_FILE="pngerror.c" - - - - - - - THIS_FILE="pngget.c" - - - - - - - THIS_FILE="pngmem.c" - - - - - - - THIS_FILE="pngpread.c" - - - - - - - THIS_FILE="pngread.c" - - - - - - - THIS_FILE="pngrio.c" - - - - - - - THIS_FILE="pngrtran.c" - - - - - - - THIS_FILE="pngrutil.c" - - - - - - - THIS_FILE="pngset.c" - - - - - - - THIS_FILE="pngtrans.c" - - - - - - - THIS_FILE="pngwio.c" - - - - - - - THIS_FILE="pngwrite.c" - - - - - - - THIS_FILE="pngwtran.c" - - - - - - - THIS_FILE="pngwutil.c" - - - - - - - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffineEdge.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_BC_D64.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_BC_F32.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_BC_S32.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_BL_D64.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_BL_F32.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_BL_S32.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_NN.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageAffine_NN_Bit.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageClipping.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageColorTrue2Index.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv2x2_f.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConvClearEdge_Bit.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConvClearEdge_Fp.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConvCopyEdge_Bit.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConvKernelConvert.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConvMxN.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConvMxN_Fp.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConvMxN_ext.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_16ext.c" - + - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - + - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_16nw.c" + THIS_FILE="DirectAudioDeviceProvider.c" - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - + - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_32nw.c" + THIS_FILE="MidiInDevice.c" - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - + - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_8ext.c" + THIS_FILE="MidiInDeviceProvider.c" - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - + - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_8nw.c" + THIS_FILE="MidiOutDevice.c" - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - + - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_D64nw.c" + THIS_FILE="MidiOutDeviceProvider.c" - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - + - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_F32nw.c" + THIS_FILE="Platform.c" - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - + - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_u16ext.c" + THIS_FILE="PlatformMidi.c" - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - + - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageConv_u16nw.c" + THIS_FILE="PortMixer.c" - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - + - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageCopy_Bit.c" + THIS_FILE="PortMixerProvider.c" - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - + - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageCreate.c" + THIS_FILE="Utilities.c" - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageDivTables.c" - + - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageFilters.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageLookUp_64.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageLookUp_Bit.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageScanPoly.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_ImageUtils.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffineIndex_BC.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffineIndex_BL.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffine_BC.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffine_BC_S16.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffine_BC_U16.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffine_BL.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffine_BL_S16.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffine_BL_U16.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageAffine_NN.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageConvClearEdge.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageConvCopyEdge.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageConvVersion.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageConv_f.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageCopy.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageLookUp.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageLookUp_f.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_c_ImageThresh1_U8.c" - - - - - - - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/solaris/native/sun/awt/medialib - ../../jdk/make - - - MLIB_NO_LIBSUNMATH - MLIB_OS64BIT - THIS_FILE="mlib_sys.c" - - - - - - - - - THIS_FILE="splashscreen_gfx_impl.c" - - - - - - - THIS_FILE="splashscreen_gif.c" - - - - - - - THIS_FILE="splashscreen_impl.c" - - - - - - - THIS_FILE="splashscreen_jpeg.c" - - - - - - - THIS_FILE="splashscreen_png.c" - - - - - - - - - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - /usr/include/freetype2 - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/font/layout - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d - ../../jdk/make - - - HEADLESS - LE_STANDALONE - THIS_FILE="DrawGlyphList.c" - - - - - - - THIS_FILE="FontInstanceAdapter.cpp" - - - - - - - /usr/include/freetype2 - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/font/layout - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d - ../../jdk/make - - - HEADLESS - LE_STANDALONE - THIS_FILE="freetypeScaler.c" - - - - - - - - - THIS_FILE="AnchorTables.cpp" - - - - - - - THIS_FILE="ArabicLayoutEngine.cpp" - - - - - - - THIS_FILE="ArabicShaping.cpp" - - - - - - - THIS_FILE="CanonData.cpp" - - - - - - - THIS_FILE="CanonShaping.cpp" - - - - - - - THIS_FILE="ClassDefinitionTables.cpp" - - - - - - - THIS_FILE="ContextualGlyphSubstProc.cpp" - - - - - - - THIS_FILE="ContextualSubstSubtables.cpp" - - - - - - - THIS_FILE="CoverageTables.cpp" - - - - - - - THIS_FILE="CursiveAttachmentSubtables.cpp" - - - - - - - THIS_FILE="DeviceTables.cpp" - - - - - - - THIS_FILE="ExtensionSubtables.cpp" - - - - - - - THIS_FILE="Features.cpp" - - - - - - - THIS_FILE="GDEFMarkFilter.cpp" - - - - - - - THIS_FILE="GXLayoutEngine.cpp" - - - - - - - THIS_FILE="GlyphDefinitionTables.cpp" - - - - - - - THIS_FILE="GlyphIterator.cpp" - - - - - - - THIS_FILE="GlyphLookupTables.cpp" - - - - - - - THIS_FILE="GlyphPositionAdjustments.cpp" - - - - - - - THIS_FILE="GlyphPositioningTables.cpp" - - - - - - - THIS_FILE="GlyphPosnLookupProc.cpp" - - - - - - - THIS_FILE="GlyphSubstLookupProc.cpp" - - - - - - - THIS_FILE="GlyphSubstitutionTables.cpp" - - - - - - - THIS_FILE="HanLayoutEngine.cpp" - - - - - - - THIS_FILE="HangulLayoutEngine.cpp" - - - - - - - THIS_FILE="IndicClassTables.cpp" - - - - - - - THIS_FILE="IndicLayoutEngine.cpp" - - - - - - - THIS_FILE="IndicRearrangementProcessor.cpp" - - - - - - - THIS_FILE="IndicReordering.cpp" - - - - - - - THIS_FILE="KernTable.cpp" - - - - - - - THIS_FILE="KhmerLayoutEngine.cpp" - - - - - - - THIS_FILE="KhmerReordering.cpp" - - - - - - - THIS_FILE="LEFontInstance.cpp" - - - - - - - THIS_FILE="LEGlyphStorage.cpp" - - - - - - - THIS_FILE="LEInsertionList.cpp" - - - - - - - THIS_FILE="LayoutEngine.cpp" - - - - - - - THIS_FILE="LigatureSubstProc.cpp" - - - - - - - THIS_FILE="LigatureSubstSubtables.cpp" - - - - - - - THIS_FILE="LookupProcessor.cpp" - - - - - - - THIS_FILE="LookupTables.cpp" - - - - - - - THIS_FILE="Lookups.cpp" - - - - - - - THIS_FILE="MPreFixups.cpp" - - - - - - - THIS_FILE="MarkArrays.cpp" - - - - - - - THIS_FILE="MarkToBasePosnSubtables.cpp" - - - - - - - THIS_FILE="MarkToLigaturePosnSubtables.cpp" - - - - - - - THIS_FILE="MarkToMarkPosnSubtables.cpp" - - - - - - - THIS_FILE="MirroredCharData.cpp" - - - - - - - THIS_FILE="MorphTables.cpp" - - - - - - - THIS_FILE="MultipleSubstSubtables.cpp" - - - - - - - THIS_FILE="NonContextualGlyphSubstProc.cpp" - - - - - - - THIS_FILE="OpenTypeLayoutEngine.cpp" - - - - - - - THIS_FILE="OpenTypeUtilities.cpp" - - - - - - - THIS_FILE="PairPositioningSubtables.cpp" - - - - - - - THIS_FILE="ScriptAndLanguage.cpp" - - - - - - - THIS_FILE="ScriptAndLanguageTags.cpp" - - - - - - - THIS_FILE="SegmentArrayProcessor.cpp" - - - - - - - THIS_FILE="SegmentSingleProcessor.cpp" - - - - - - - THIS_FILE="ShapingTypeData.cpp" - - - - - - - THIS_FILE="SimpleArrayProcessor.cpp" - - - - - - - THIS_FILE="SinglePositioningSubtables.cpp" - - - - - - - THIS_FILE="SingleSubstitutionSubtables.cpp" - - - - - - - THIS_FILE="SingleTableProcessor.cpp" - - - - - - - THIS_FILE="StateTableProcessor.cpp" - - - - - - - THIS_FILE="SubstitutionLookups.cpp" - - - - - - - THIS_FILE="SubtableProcessor.cpp" - - - - - - - THIS_FILE="SunLayoutEngine.cpp" - - - - - - - THIS_FILE="ThaiLayoutEngine.cpp" - - - - - - - THIS_FILE="ThaiShaping.cpp" - - - - - - - THIS_FILE="ThaiStateTables.cpp" - - - - - - - THIS_FILE="TibetanLayoutEngine.cpp" - - - - - - - THIS_FILE="TibetanReordering.cpp" - - - - - - - THIS_FILE="TrimmedArrayProcessor.cpp" - - - - - - - THIS_FILE="ValueRecords.cpp" - - - - - - - /usr/include/freetype2 - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/font/layout - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d - ../../jdk/make - - - HEADLESS - LE_STANDALONE - THIS_FILE="sunFont.c" - - - - - - - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - THIS_FILE="Disposer.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - THIS_FILE="SurfaceData.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - THIS_FILE="Trace.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - + THIS_FILE="cmscam02.c" - - + THIS_FILE="cmscgats.c" - - + THIS_FILE="cmscnvrt.c" - - + THIS_FILE="cmserr.c" - - + THIS_FILE="cmsgamma.c" - - + THIS_FILE="cmsgmt.c" - - + THIS_FILE="cmshalf.c" - - + THIS_FILE="cmsintrp.c" - - + THIS_FILE="cmsio0.c" - - + THIS_FILE="cmsio1.c" - - + THIS_FILE="cmslut.c" - - + THIS_FILE="cmsmd5.c" - - + THIS_FILE="cmsmtrx.c" - - + THIS_FILE="cmsnamed.c" - - + THIS_FILE="cmsopt.c" - - + THIS_FILE="cmspack.c" - - + THIS_FILE="cmspcs.c" - - + THIS_FILE="cmsplugin.c" - - + THIS_FILE="cmsps2.c" - - + THIS_FILE="cmssamp.c" - - + THIS_FILE="cmssm.c" - - + THIS_FILE="cmstypes.c" - - + THIS_FILE="cmsvirt.c" - - + THIS_FILE="cmswtpnt.c" - - + THIS_FILE="cmsxform.c" - - - - - - THIS_FILE="AlphaMath.c" - - - - - - - THIS_FILE="Any3Byte.c" - - - - - - - THIS_FILE="Any4Byte.c" - - - - - - - THIS_FILE="AnyByte.c" - - - - - - - THIS_FILE="AnyInt.c" - - - - - - - THIS_FILE="AnyShort.c" - - - - - - - THIS_FILE="Blit.c" - - - - - - - THIS_FILE="BlitBg.c" - - - - - - - THIS_FILE="ByteBinary1Bit.c" - - - - - - - THIS_FILE="ByteBinary2Bit.c" - - - - - - - THIS_FILE="ByteBinary4Bit.c" - - - - - - - THIS_FILE="ByteGray.c" - - - - - - - THIS_FILE="ByteIndexed.c" - - - - - - - THIS_FILE="DrawLine.c" - - - - - - - THIS_FILE="DrawParallelogram.c" - - - - - - - THIS_FILE="DrawPath.c" - - - - - - - THIS_FILE="DrawPolygons.c" - - - - - - - THIS_FILE="DrawRect.c" - - - - - - - THIS_FILE="FillParallelogram.c" - - - - - - - THIS_FILE="FillPath.c" - - - - - - - THIS_FILE="FillRect.c" - - - - - - - THIS_FILE="FillSpans.c" - - - - - - - THIS_FILE="FourByteAbgr.c" - - - - - - - THIS_FILE="FourByteAbgrPre.c" - - - - - - - THIS_FILE="GraphicsPrimitiveMgr.c" - - - - - - - THIS_FILE="Index12Gray.c" - - - - - - - THIS_FILE="Index8Gray.c" - - - - - - - THIS_FILE="IntArgb.c" - - - - - - - THIS_FILE="IntArgbBm.c" - - - - - - - THIS_FILE="IntArgbPre.c" - - - - - - - THIS_FILE="IntBgr.c" - - - - - - - THIS_FILE="IntRgb.c" - - - - - - - THIS_FILE="IntRgbx.c" - - - - - - - THIS_FILE="MapAccelFunc.c" - - - - - - - THIS_FILE="MaskBlit.c" - - - - - - - THIS_FILE="MaskFill.c" - - - - - - - THIS_FILE="ProcessPath.c" - - - - - - - THIS_FILE="ScaledBlit.c" - - - - - - - THIS_FILE="ThreeByteBgr.c" - - - - - - - THIS_FILE="TransformHelper.c" - - - - - - - THIS_FILE="Ushort4444Argb.c" - - - - - - - THIS_FILE="Ushort555Rgb.c" - - - - - - - THIS_FILE="Ushort555Rgbx.c" - - - - - - - THIS_FILE="Ushort565Rgb.c" - - - - - - - THIS_FILE="UshortGray.c" - - - - - - - THIS_FILE="UshortIndexed.c" - - - - - - - - - THIS_FILE="OGLBufImgOps.c" - - - - - - - THIS_FILE="OGLContext.c" - - - - - - - THIS_FILE="OGLFuncs.c" - - - - - - - THIS_FILE="OGLMaskBlit.c" - - - - - - - THIS_FILE="OGLMaskFill.c" - - - - - - - THIS_FILE="OGLPaints.c" - - - - - - - THIS_FILE="OGLRenderQueue.c" - - - - - - - THIS_FILE="OGLRenderer.c" - - - - - - - THIS_FILE="OGLSurfaceData.c" - - - - - - - THIS_FILE="OGLTextRenderer.c" - + - - + - THIS_FILE="OGLVertexCache.c" + THIS_FILE="mlib_ImageAffineEdge.c" - - - - - - THIS_FILE="BufferedRenderPipe.c" - - - - - - - THIS_FILE="Region.c" - - - - - - - THIS_FILE="ShapeSpanIterator.c" - - - - - - - THIS_FILE="SpanClipRenderer.c" - - - - - - - - - THIS_FILE="Flag.c" - - - - - - - THIS_FILE="GarbageCollectorImpl.c" - - - - - - - THIS_FILE="GcInfoBuilder.c" - - - - - - - THIS_FILE="HotSpotDiagnostic.c" - - - - - - - THIS_FILE="HotspotThread.c" - - - - - - - THIS_FILE="MemoryImpl.c" - - - - - - - THIS_FILE="MemoryManagerImpl.c" - - - - - - - THIS_FILE="MemoryPoolImpl.c" - - - - - - - THIS_FILE="ThreadImpl.c" - - - - - - - THIS_FILE="VMManagementImpl.c" - - - - - - - THIS_FILE="management.c" - - - - - - - - - THIS_FILE="MessageUtils.c" - - - - - - - THIS_FILE="NativeSignalHandler.c" - - - - - - - THIS_FILE="Signal.c" - - - - - - - THIS_FILE="VM.c" - - - - - - - THIS_FILE="VMSupport.c" - - - - - - - THIS_FILE="Version.c" - - - - - - - - - - - THIS_FILE="NativeAccessors.c" - - - - - + - THIS_FILE="Reflection.c" + THIS_FILE="mlib_ImageAffine_BC_D64.c" - - - - - - + - THIS_FILE="ec2_163.c" + THIS_FILE="mlib_ImageAffine_BC_F32.c" - - + - THIS_FILE="ec2_193.c" + THIS_FILE="mlib_ImageAffine_BC_S32.c" - - + - THIS_FILE="ec2_233.c" + THIS_FILE="mlib_ImageAffine_BL_D64.c" - - + - THIS_FILE="ec2_aff.c" + THIS_FILE="mlib_ImageAffine_BL_F32.c" - - + - THIS_FILE="ec2_mont.c" + THIS_FILE="mlib_ImageAffine_BL_S32.c" - - + - THIS_FILE="ec_naf.c" + THIS_FILE="mlib_ImageAffine_NN.c" - - + - THIS_FILE="ecdecode.c" + THIS_FILE="mlib_ImageAffine_NN_Bit.c" - - + - THIS_FILE="ecl.c" + THIS_FILE="mlib_ImageClipping.c" - - + - THIS_FILE="ecl_curve.c" + THIS_FILE="mlib_ImageConvClearEdge_Bit.c" - - + - THIS_FILE="ecl_gf.c" + THIS_FILE="mlib_ImageConvClearEdge_Fp.c" - - + - THIS_FILE="ecl_mult.c" + THIS_FILE="mlib_ImageConvCopyEdge_Bit.c" - - + - THIS_FILE="ecp_192.c" + THIS_FILE="mlib_ImageConvKernelConvert.c" - - + - THIS_FILE="ecp_224.c" + THIS_FILE="mlib_ImageConvMxN.c" - - + - THIS_FILE="ecp_256.c" + THIS_FILE="mlib_ImageConvMxN_Fp.c" - - + - THIS_FILE="ecp_384.c" + THIS_FILE="mlib_ImageConvMxN_ext.c" - - + - THIS_FILE="ecp_521.c" + THIS_FILE="mlib_ImageConv_16ext.c" - - + - THIS_FILE="ecp_aff.c" + THIS_FILE="mlib_ImageConv_16nw.c" - - + - THIS_FILE="ecp_jac.c" + THIS_FILE="mlib_ImageConv_32nw.c" - - + - THIS_FILE="ecp_jm.c" + THIS_FILE="mlib_ImageConv_8ext.c" - - + - THIS_FILE="ecp_mont.c" + THIS_FILE="mlib_ImageConv_8nw.c" - - + - THIS_FILE="mp_gf2m.c" + THIS_FILE="mlib_ImageConv_D64nw.c" - - + - THIS_FILE="mpi.c" + THIS_FILE="mlib_ImageConv_F32nw.c" - - + - THIS_FILE="mplogic.c" + THIS_FILE="mlib_ImageConv_u16ext.c" - - + - THIS_FILE="mpmontg.c" + THIS_FILE="mlib_ImageConv_u16nw.c" - - + - THIS_FILE="oid.c" + THIS_FILE="mlib_ImageDivTables.c" - - + - THIS_FILE="secitem.c" + THIS_FILE="mlib_ImageFilters.c" - - - - + - THIS_FILE="NativeUtil.c" + THIS_FILE="mlib_ImageLookUp_64.c" - - + - THIS_FILE="j2secmod.c" + THIS_FILE="mlib_ImageLookUp_Bit.c" - - - - + - THIS_FILE="p11_crypt.c" + THIS_FILE="mlib_ImageScanPoly.c" - - + - THIS_FILE="p11_digest.c" + THIS_FILE="mlib_ImageUtils.c" - - + - THIS_FILE="p11_dual.c" + THIS_FILE="mlib_c_ImageAffine_BC.c" - - + - THIS_FILE="p11_general.c" + THIS_FILE="mlib_c_ImageAffine_BC_S16.c" - - + - THIS_FILE="p11_keymgmt.c" + THIS_FILE="mlib_c_ImageAffine_BC_U16.c" - - + - THIS_FILE="p11_mutex.c" + THIS_FILE="mlib_c_ImageAffine_BL.c" - - + - THIS_FILE="p11_objmgmt.c" + THIS_FILE="mlib_c_ImageAffine_BL_S16.c" - - + - THIS_FILE="p11_sessmgmt.c" + THIS_FILE="mlib_c_ImageAffine_BL_U16.c" - - + - THIS_FILE="p11_sign.c" + THIS_FILE="mlib_c_ImageAffine_NN.c" - - + - THIS_FILE="p11_util.c" + THIS_FILE="mlib_c_ImageConvClearEdge.c" - - - - - - - - + - THIS_FILE="utf.c" + THIS_FILE="mlib_c_ImageConvCopyEdge.c" - - - - - - + - THIS_FILE="linker_md.c" + THIS_FILE="mlib_c_ImageConvVersion.c" - - - - + - THIS_FILE="ergo_i586.c" + THIS_FILE="mlib_c_ImageConv_f.c" - - + - THIS_FILE="java_md_common.c" + THIS_FILE="mlib_c_ImageCopy.c" - - + - THIS_FILE="java_md_solinux.c" + THIS_FILE="mlib_c_ImageLookUp.c" - - - - - - - - + - THIS_FILE="FileSystemSupport_md.c" + THIS_FILE="mlib_c_ImageLookUp_f.c" - - - - - - THIS_FILE="UnixOperatingSystem_md.c" - + - - - - + - THIS_FILE="PLATFORM_API_SolarisOS_Ports.c" + THIS_FILE="gif_err.c" - - + - THIS_FILE="PLATFORM_API_SolarisOS_Utils.c" + THIS_FILE="gifalloc.c" - - - - + - THIS_FILE="Unix.c" + THIS_FILE="java_awt_SplashScreen.c" - - - - - - THIS_FILE="jni_util_md.c" - + - - - - + - THIS_FILE="FileDescriptor_md.c" + THIS_FILE="pngerror.c" - - + - THIS_FILE="FileInputStream_md.c" + THIS_FILE="pngget.c" - - + - THIS_FILE="FileOutputStream_md.c" + THIS_FILE="pngmem.c" - - + - THIS_FILE="RandomAccessFile_md.c" + THIS_FILE="pngpread.c" - - + - THIS_FILE="UnixFileSystem_md.c" + THIS_FILE="pngread.c" - - + - THIS_FILE="canonicalize_md.c" + THIS_FILE="pngrio.c" - - + - THIS_FILE="io_util_md.c" + THIS_FILE="pngrtran.c" - - - - + - THIS_FILE="UNIXProcess_md.c" + THIS_FILE="pngrutil.c" - - + - THIS_FILE="java_props_md.c" + THIS_FILE="pngset.c" - - - - + - THIS_FILE="Inet6AddressImpl.c" + THIS_FILE="pngtrans.c" - - + - THIS_FILE="InetAddressImplFactory.c" + THIS_FILE="pngwio.c" - - + - THIS_FILE="NetworkInterface.c" + THIS_FILE="pngwrite.c" - - + - THIS_FILE="PlainDatagramSocketImpl.c" + THIS_FILE="pngwtran.c" - - + - THIS_FILE="PlainSocketImpl.c" + THIS_FILE="pngwutil.c" - - + - THIS_FILE="SocketInputStream.c" + THIS_FILE="splashscreen_gfx_impl.c" - - + - THIS_FILE="SocketOutputStream.c" + THIS_FILE="splashscreen_gif.c" - - + - THIS_FILE="net_util_md.c" + THIS_FILE="splashscreen_impl.c" - - - - - - + - THIS_FILE="TimeZone_md.c" + THIS_FILE="splashscreen_jpeg.c" - - + - THIS_FILE="logging.c" + THIS_FILE="splashscreen_png.c" - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - + - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" THIS_FILE="CUPSfuncs.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - + - HEADLESS=true - PACKAGE_PATH="/opt/local" - THIS_FILE="HeadlessToolkit.c" - X11_PATH="/usr/X11R6" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - HEADLESS=true - PACKAGE_PATH="/opt/local" - THIS_FILE="VDrawingArea.c" - X11_PATH="/usr/X11R6" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" THIS_FILE="X11Color.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - + - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_AWTEvent.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_DrawingSurface.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_Event.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" THIS_FILE="awt_Font.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - + - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_GraphicsEnv.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_InputMethod.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_Insets.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - THIS_FILE="awt_LoadLibrary.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - THIS_FILE="awt_Mlib.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_Plugin.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_Robot.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_UNIXToolkit.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="awt_util.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" THIS_FILE="fontpath.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="gtk2_interface.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - + - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="initIDs.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - + - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="jawt.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="list.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="multiVis.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="multi_font.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="robot_common.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="sun_awt_X11_GtkFileDialogPeer.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="swing_GTKEngine.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="swing_GTKStyle.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - - - THIS_FILE="X11TextRenderer.c" - - - - - - - + THIS_FILE="GLXSurfaceData.c" - + + - - + THIS_FILE="X11PMBlitLoops.c" - - + THIS_FILE="X11Renderer.c" - - + THIS_FILE="X11SurfaceData.c" - - + THIS_FILE="X11TextRenderer_md.c" - - + + + + + - THIS_FILE="XRBackendNative.c" + THIS_FILE="awt_Mlib.c" - - + + + THIS_FILE="initIDs.c" + + + + + + + + + + + + + + + THIS_FILE="awt_DrawingSurface.c" + + + + + + + THIS_FILE="awt_Event.c" + + + + + + + THIS_FILE="awt_GraphicsEnv.c" + + + + + + + THIS_FILE="awt_InputMethod.c" + + + + + + + THIS_FILE="awt_Insets.c" + + + + + + + THIS_FILE="awt_Robot.c" + + + + + + + THIS_FILE="awt_UNIXToolkit.c" + + + + + + + THIS_FILE="awt_util.c" + + + + + + + THIS_FILE="gtk2_interface.c" + + + + + + + THIS_FILE="gtk3_interface.c" + + + + + + + THIS_FILE="gtk_interface.c" + + + + + + + THIS_FILE="list.c" + + + + + + + THIS_FILE="multiVis.c" + + + + + + + THIS_FILE="multi_font.c" + + + + + + + THIS_FILE="robot_common.c" + + + + + + + THIS_FILE="sun_awt_X11_GtkFileDialogPeer.c" + + + + + + + THIS_FILE="swing_GTKEngine.c" + + + + + + + THIS_FILE="swing_GTKStyle.c" + + + + + + + + + THIS_FILE="XRSurfaceData.c" - - - - - - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="DatagramChannelImpl.c" - + - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="DatagramDispatcher.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="DevPollArrayWrapper.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="FileChannelImpl.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="FileDispatcherImpl.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="FileKey.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="IOUtil.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="InheritedChannel.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="NativeThread.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="Net.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="PollArrayWrapper.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="ServerSocketChannelImpl.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="SocketChannelImpl.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="SocketDispatcher.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="SolarisEventPort.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="UnixAsynchronousServerSocketChannelImpl.c" - - - - - - - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="UnixAsynchronousSocketChannelImpl.c" - - - - - - - - - THIS_FILE="SctpNet.c" - - - - - - - THIS_FILE="SctpServerChannelImpl.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/nio/ch - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/nio/ch - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="SolarisNativeDispatcher.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/nio/ch - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="SolarisWatchService.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/nio/ch - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="UnixCopyFile.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/nio/ch - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="UnixNativeDispatcher.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../jdk/make - - - THIS_FILE="genSolarisConstants.c" - - - - - - - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="genUnixConstants.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - - - THIS_FILE="j2secmod_md.c" - - - - - - - - - - - - - - - - - + THIS_FILE="XWindow.c" - - + THIS_FILE="XlibWrapper.c" - - + THIS_FILE="awt_Desktop.c" - - + + + THIS_FILE="awt_Taskbar.c" + + + + + THIS_FILE="gnome_interface.c" - - - + + - + + + + THIS_FILE="X11TextRenderer.c" + + + + + + + + + + + + + + + THIS_FILE="PLATFORM_API_SolarisOS_Ports.c" + + + + + + + THIS_FILE="PLATFORM_API_SolarisOS_Utils.c" + + + + + + + + + + + + + + + THIS_FILE="InstrumentationImplNativeMethods.c" + + + + + + + THIS_FILE="InvocationAdapter.c" + + + + + + + THIS_FILE="JPLISAgent.c" + + + + + + + THIS_FILE="JPLISAssert.c" + + + + + + + THIS_FILE="JarFacade.c" + + + + + + + THIS_FILE="JavaExceptions.c" + + + + + + + THIS_FILE="PathCharsValidator.c" + + + + + + + THIS_FILE="Reentrancy.c" + + + + + + + THIS_FILE="Utilities.c" + + + + + + + + + + + THIS_FILE="FileSystemSupport_md.c" + + + + + + + + + + + THIS_FILE="GarbageCollectorImpl.c" + + + + + + + THIS_FILE="HotspotThread.c" + + + + + + + THIS_FILE="MemoryImpl.c" + + + + + + + THIS_FILE="MemoryManagerImpl.c" + + + + + + + THIS_FILE="MemoryPoolImpl.c" + + + + + + + THIS_FILE="ThreadImpl.c" + + + + + + + THIS_FILE="VMManagementImpl.c" + + + + + + + THIS_FILE="management.c" + + + + + + + + + + + + + + + + + + + + + + + THIS_FILE="NativeUtil.c" + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + THIS_FILE="ec2_163.c" + + + + + + + THIS_FILE="ec2_193.c" + + + + + + + THIS_FILE="ec2_233.c" + + + + + + + THIS_FILE="ec2_aff.c" + + + + + + + THIS_FILE="ec2_mont.c" + + + + + + + THIS_FILE="ec_naf.c" + + + + + + + THIS_FILE="ecdecode.c" + + + + + + + THIS_FILE="ecl.c" + + + + + + + THIS_FILE="ecl_curve.c" + + + + + + + THIS_FILE="ecl_gf.c" + + + + + + + THIS_FILE="ecl_mult.c" + + + + + + + THIS_FILE="ecp_192.c" + + + + + + + THIS_FILE="ecp_224.c" + + + + + + + THIS_FILE="ecp_256.c" + + + + + + + THIS_FILE="ecp_384.c" + + + + + + + THIS_FILE="ecp_521.c" + + + + + + + THIS_FILE="ecp_aff.c" + + + + + + + THIS_FILE="ecp_jac.c" + + + + + + + THIS_FILE="ecp_jm.c" + + + + + + + THIS_FILE="ecp_mont.c" + + + + + + + THIS_FILE="mp_gf2m.c" + + + + + + + THIS_FILE="mpi.c" + + + + + + + THIS_FILE="mplogic.c" + + + + + + + THIS_FILE="mpmontg.c" + + + + + + + THIS_FILE="oid.c" + + + + + + + THIS_FILE="secitem.c" + + + + + + + + + + + THIS_FILE="p11_convert.c" + + + + + + + THIS_FILE="p11_crypt.c" + + + + + + + THIS_FILE="p11_digest.c" + + + + + + + THIS_FILE="p11_dual.c" + + + + + + + THIS_FILE="p11_general.c" + + + + + + + THIS_FILE="p11_keymgmt.c" + + + + + + + THIS_FILE="p11_mutex.c" + + + + + + + THIS_FILE="p11_objmgmt.c" + + + + + + + THIS_FILE="p11_sessmgmt.c" + + + + + + + THIS_FILE="p11_sign.c" + + + + + + + THIS_FILE="p11_util.c" + + + + + + + + + + + THIS_FILE="p11_md.c" + + + + + + + + + + + THIS_FILE="nativeCryptoMD.c" + + + + + + + THIS_FILE="nativeFunc.c" + + + + + + + + + + + + + + + THIS_FILE="ArrayTypeImpl.c" + + + + + + + THIS_FILE="ClassLoaderReferenceImpl.c" + + + + + + + THIS_FILE="ClassObjectReferenceImpl.c" + + + + + + + THIS_FILE="ClassTypeImpl.c" + + + + + + + THIS_FILE="EventRequestImpl.c" + + + + + + + THIS_FILE="FieldImpl.c" + + + + + + + THIS_FILE="FrameID.c" + + + + + + + THIS_FILE="InterfaceTypeImpl.c" + + + + + + + THIS_FILE="MethodImpl.c" + + + + + + + THIS_FILE="ModuleReferenceImpl.c" + + + + + + + THIS_FILE="ObjectReferenceImpl.c" + + + + + + + THIS_FILE="ReferenceTypeImpl.c" + + + + + + + THIS_FILE="SDE.c" + + + + + + + THIS_FILE="StackFrameImpl.c" + + + + + + + THIS_FILE="StringReferenceImpl.c" + + + + + + + THIS_FILE="ThreadGroupReferenceImpl.c" + + + + + + + THIS_FILE="ThreadReferenceImpl.c" + + + + + + + THIS_FILE="VirtualMachineImpl.c" + + + + + + + THIS_FILE="bag.c" + + + + + + + THIS_FILE="classTrack.c" + + + + + + + THIS_FILE="commonRef.c" + + + + + + + THIS_FILE="debugDispatch.c" + + + + + + + THIS_FILE="debugInit.c" + + + + + + + THIS_FILE="debugLoop.c" + + + + + + + THIS_FILE="error_messages.c" + + + + + + + THIS_FILE="eventFilter.c" + + + + + + + THIS_FILE="eventHandler.c" + + + + + + + THIS_FILE="eventHelper.c" + + + + + + + THIS_FILE="inStream.c" + + + + + + + THIS_FILE="invoker.c" + + + + + + + THIS_FILE="log_messages.c" + + + + + + + THIS_FILE="outStream.c" + + + + + + + THIS_FILE="standardHandlers.c" + + + + + + + THIS_FILE="stepControl.c" + + + + + + + THIS_FILE="stream.c" + + + + + + + THIS_FILE="threadControl.c" + + + + + + + THIS_FILE="transport.c" + + + + + + + THIS_FILE="utf_util.c" + + + + + + + THIS_FILE="util.c" + + + + + + + + + + + + + + + THIS_FILE="linker_md.c" + + + + + + + + + + + THIS_FILE="Flag.c" + + + + + + + THIS_FILE="GarbageCollectorExtImpl.c" + + + + + + + THIS_FILE="GcInfoBuilder.c" + + + + + + + THIS_FILE="HotSpotDiagnostic.c" + + + + + + + THIS_FILE="management_ext.c" + + + + + + + + + + + + + + + + + + + + + + + THIS_FILE="bytes.cpp" + + + + + + + THIS_FILE="coding.cpp" + + + + + + + THIS_FILE="unpack.cpp" + + + + + + + THIS_FILE="utils.cpp" + + + + + + + THIS_FILE="zip.cpp" + + + + + + + + + + + + + + + + + + + THIS_FILE="SctpNet.c" + + + + + + + THIS_FILE="SctpServerChannelImpl.c" + + + + + + + + + + + + + + + + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/image/cvutils + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils - - __sparcv9 - - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product - ../../hotspot/src/share/vm/prims ../../hotspot/src/share/vm - ../../hotspot/src/share/vm/precompiled - ../../hotspot/src/cpu/x86/vm - ../../hotspot/src/os_cpu/linux_x86/vm - ../../hotspot/src/os/linux/vm - ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated - - - __EXCEPTIONS - __GXX_RTTI - - - - - - - ../../hotspot/src/os_cpu/solaris_x86/vm - ../../hotspot/src/os/solaris/vm - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - AMD64 - COMPILER1 - COMPILER2 - DONT_USE_PRECOMPILED_HEADER - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - SOLARIS - SPARC_WORKS - TARGET_ARCH_MODEL_x86_64 - TARGET_ARCH_x86 - TARGET_COMPILER_sparcWorks - TARGET_OS_ARCH_MODEL_solaris_x86_64 - TARGET_OS_ARCH_solaris_x86 - TARGET_OS_FAMILY_solaris - VM_LITTLE_ENDIAN - _Crun_inline_placement - - - - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - TIERED - - - - - - - _GNU_SOURCE - - - - - __EXCEPTIONS - __GXX_RTTI - - - - - - - ../../hotspot/agent/src/os/solaris/proc - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ${IDE_ALT_BOOTDIR}/include - ${IDE_ALT_BOOTDIR}/include/solaris - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - SOLARIS_11_B159_OR_LATER - - - - - ../../hotspot/agent/src/os/solaris/proc - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ${IDE_ALT_BOOTDIR}/include - ${IDE_ALT_BOOTDIR}/include/solaris - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - SOLARIS_11_B159_OR_LATER - - - - - - - ${IDE_ALT_BOOTDIR}/include/linux - - - - - - - ../../hotspot/src/share/vm/prims - ../../hotspot/src/share/vm - ../../hotspot/src/share/vm/precompiled - ../../hotspot/src/cpu/x86/vm - ../../hotspot/src/os_cpu/solaris_x86/vm ../../hotspot/src/os/solaris/vm ../../hotspot/src/os/posix/vm - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - AMD64 - COMPILER1 - COMPILER2 - DONT_USE_PRECOMPILED_HEADER - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - SOLARIS - SPARC_WORKS - TARGET_ARCH_MODEL_x86_64 - TARGET_ARCH_x86 - TARGET_COMPILER_sparcWorks - TARGET_OS_ARCH_MODEL_solaris_x86_64 - TARGET_OS_ARCH_solaris_x86 - TARGET_OS_FAMILY_solaris - VM_LITTLE_ENDIAN - _Crun_inline_placement - - - - - - - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product - ../../hotspot/src/share/vm/prims - ../../hotspot/src/share/vm - ../../hotspot/src/share/vm/precompiled - ../../hotspot/src/cpu/x86/vm - ../../hotspot/src/os_cpu/linux_x86/vm - ../../hotspot/src/os/linux/vm - ../../hotspot/src/os/posix/vm - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated - - - - - - - ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product - - - _REENTRANT - - - - - LINUX - _GNU_SOURCE - _REENTRANT - - - - - - - ../../hotspot/src/os/posix/launcher - ../../hotspot/src/share/vm/prims - ../../hotspot/src/share/tools/launcher - ../../hotspot/src/share/vm - ../../hotspot/src/share/vm/precompiled ../../hotspot/src/cpu/x86/vm ../../hotspot/src/os_cpu/solaris_x86/vm - ../../hotspot/src/os/solaris/vm - ../../hotspot/src/os/posix/vm - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - AMD64 - ARCH="amd64" - GAMMA - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - LAUNCHER_TYPE="gamma" - LINK_INTO_LIBJVM - PRODUCT - SOLARIS - SPARC_WORKS - TARGET_ARCH_MODEL_x86_64 - TARGET_ARCH_x86 - TARGET_COMPILER_sparcWorks - TARGET_OS_ARCH_MODEL_solaris_x86_64 - TARGET_OS_ARCH_solaris_x86 - TARGET_OS_FAMILY_solaris - - - - - ../../hotspot/src/os_cpu/solaris_x86/vm - ../../hotspot/src/os/solaris/vm - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - AMD64 - COMPILER1 - COMPILER2 - DONT_USE_PRECOMPILED_HEADER - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - SOLARIS - SPARC_WORKS - TARGET_ARCH_MODEL_x86_64 - TARGET_ARCH_x86 - TARGET_COMPILER_sparcWorks - TARGET_OS_ARCH_MODEL_solaris_x86_64 - TARGET_OS_ARCH_solaris_x86 - TARGET_OS_FAMILY_solaris - VM_LITTLE_ENDIAN - _Crun_inline_placement - - - - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - - - - - TIERED - - - - - - - ../../hotspot/src/os_cpu/solaris_x86/vm - ../../hotspot/src/os/solaris/vm - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - AMD64 - COMPILER1 - COMPILER2 - DONT_USE_PRECOMPILED_HEADER - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - SOLARIS - SPARC_WORKS - TARGET_ARCH_MODEL_x86_64 - TARGET_ARCH_x86 - TARGET_COMPILER_sparcWorks - TARGET_OS_ARCH_MODEL_solaris_x86_64 - TARGET_OS_ARCH_solaris_x86 - TARGET_OS_FAMILY_solaris - VM_LITTLE_ENDIAN - _Crun_inline_placement - - - - - - - ../../hotspot/src/share/vm/prims - ../../hotspot/src/share/vm + ../../build/hotspot/variant-server/gensrc ../../hotspot/src/share/vm/precompiled - ../../hotspot/src/cpu/x86/vm - ../../hotspot/src/os_cpu/solaris_x86/vm - ../../hotspot/src/os/solaris/vm - ../../hotspot/src/os/posix/vm - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - AMD64 - COMPILER1 - COMPILER2 - DONT_USE_PRECOMPILED_HEADER - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - SOLARIS - SPARC_WORKS - TARGET_ARCH_MODEL_x86_64 - TARGET_ARCH_x86 - TARGET_COMPILER_sparcWorks - TARGET_OS_ARCH_MODEL_solaris_x86_64 - TARGET_OS_ARCH_solaris_x86 - TARGET_OS_FAMILY_solaris - VM_LITTLE_ENDIAN - _Crun_inline_placement - - - - - - - LINUX - _GNU_SOURCE - _LP64=1 - _REENTRANT - - - - - - - ../../hotspot/src/os/posix/launcher ../../hotspot/src/share/vm/prims - ../../hotspot/src/share/tools/launcher - ../../hotspot/src/share/vm - ../../hotspot/src/share/vm/precompiled - ../../hotspot/src/cpu/x86/vm - ../../hotspot/src/os_cpu/solaris_x86/vm - ../../hotspot/src/os/solaris/vm - ../../hotspot/src/os/posix/vm - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + ../../hotspot/make AMD64 - ARCH="amd64" - GAMMA - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - LAUNCHER_TYPE="gamma" - LINK_INTO_LIBJVM - PRODUCT - SOLARIS - SPARC_WORKS - TARGET_ARCH_MODEL_x86_64 - TARGET_ARCH_x86 - TARGET_COMPILER_sparcWorks - TARGET_OS_ARCH_MODEL_solaris_x86_64 - TARGET_OS_ARCH_solaris_x86 - TARGET_OS_FAMILY_solaris - - - - - ../../hotspot/src/share/vm/prims - ../../hotspot/src/share/vm - ../../hotspot/src/share/vm/precompiled - ../../hotspot/src/cpu/x86/vm - ../../hotspot/src/os_cpu/solaris_x86/vm - ../../hotspot/src/os/solaris/vm - ../../hotspot/src/os/posix/vm - - - AMD64 - COMPILER1 - COMPILER2 - DONT_USE_PRECOMPILED_HEADER - SOLARIS - SPARC_WORKS - TARGET_ARCH_MODEL_x86_64 - TARGET_ARCH_x86 - TARGET_COMPILER_sparcWorks - TARGET_OS_ARCH_MODEL_solaris_x86_64 - TARGET_OS_ARCH_solaris_x86 - TARGET_OS_FAMILY_solaris - _Crun_inline_placement - - - - - - - ../../hotspot/src/share/vm/adlc - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - ASSERT + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ - + + + + THIS_FILE="bytecodeInterpreterWithChecks.cpp" + + + + - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + ../../build/hotspot/variant-server/support/dtrace + + + + + + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="sadis.c" + + + + THIS_FILE="abstractInterpreter_x86.cpp" + + + __EXCEPTIONS + __GXX_RTTI + - + - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + ../../hotspot/src/share/vm + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + AMD64 + ASSERT + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ - + + + + ../../hotspot/src/jdk.hotspot.agent/share/native/libsaproc + ../../hotspot/src/jdk.hotspot.agent/solaris/native/libsaproc + ../../build/support/headers/jdk.hotspot.agent + ../../hotspot/src/os/solaris + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../make + + + ARCH="amd64" + BREAKPTS + DEBUG + MACRO_MEMSYS_OPS + SOLARIS + SOLARIS_11_B159_OR_LATER + TRACING + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product + ../../hotspot/src/jdk.hotspot.agent/share/native/libsaproc + ../../hotspot/src/jdk.hotspot.agent/solaris/native/libsaproc + ../../build/support/headers/jdk.hotspot.agent + ../../hotspot/src/os/solaris + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../make - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + ARCH="amd64" + BREAKPTS + CC_NOEX + DEBUG + MACRO_MEMSYS_OPS + SOLARIS + SOLARIS_11_B159_OR_LATER + THIS_FILE="saproc.cpp" + TRACING + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - + + - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN + THIS_FILE="jvm_dtrace.c" - - - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN - - - - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN - - - - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN - - - - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN - - - - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN - - - - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN - - - - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN - - - - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN - - - - + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm ../../hotspot/src/os_cpu/linux_x86/vm ../../hotspot/src/os/linux/vm + ../../hotspot/src/os/posix/vm ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/generated + THIS_FILE="os_posix.cpp" + + + + + + + ../../build/linux-x86_64-normal-server-release/hotspot/linux_amd64_compiler2/product + + + _REENTRANT + + + + + LINUX + _GNU_SOURCE + _REENTRANT + + + + + + + ../../hotspot/src/os/posix/launcher + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/tools/launcher + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + + + AMD64 + ARCH="amd64" + GAMMA HOTSPOT_BUILD_TARGET="target" HOTSPOT_BUILD_USER="user" HOTSPOT_LIB_ARCH="amd64" HOTSPOT_RELEASE_VERSION="version" HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - LINUX + LAUNCHER_TYPE="gamma" + LINK_INTO_LIBJVM PRODUCT + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/make + + + AMD64 + ASSERT + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + THIS_FILE="generateJvmOffsets.cpp" + + + + + + + ../../hotspot/make + + + THIS_FILE="jsig.c" + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/make + + + AMD64 + ASSERT + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="attachListener_solaris.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/share/vm + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + AMD64 + ASSERT + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="assembler_solaris_x86.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + LINUX _GNU_SOURCE _LP64=1 _REENTRANT - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN - - - - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN - - - - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN - - - - - - - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated - ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/product - - - DTRACE_ENABLED - HAVE_DTRACE_H - HOTSPOT_BUILD_TARGET="target" - HOTSPOT_BUILD_USER="user" - HOTSPOT_LIB_ARCH="amd64" - HOTSPOT_RELEASE_VERSION="version" - HOTSPOT_VM_DISTRO="OpenJDK" - INCLUDE_TRACE - PRODUCT - VM_LITTLE_ENDIAN - - - - + + + ../../hotspot/src/os/posix/launcher + ../../hotspot/src/share/vm/prims + ../../hotspot/src/share/tools/launcher + ../../hotspot/src/share/vm + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../build/solaris-x86_64-normal-server-release/hotspot/solaris_amd64_compiler2/generated + - THIS_FILE="add_gnu_debuglink.c" + AMD64 + ARCH="amd64" + GAMMA + HOTSPOT_BUILD_TARGET="target" + HOTSPOT_BUILD_USER="user" + HOTSPOT_LIB_ARCH="amd64" + HOTSPOT_RELEASE_VERSION="version" + HOTSPOT_VM_DISTRO="OpenJDK" + LAUNCHER_TYPE="gamma" + LINK_INTO_LIBJVM + PRODUCT + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + + ../../hotspot/src/share/vm + + + AMD64 + ASSERT + THIS_FILE="adlparse.cpp" + + + + + + + ../../hotspot/make + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="assembler.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="c1_CFGPrinter.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="bcEscapeAnalyzer.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="altHashing.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="codeBlob.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="abstractCompiler.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="adaptiveFreeList.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + THIS_FILE="bufferingOopClosure.cpp" + + + + + + + THIS_FILE="adjoiningGenerations.cpp" + + + + + + + THIS_FILE="cSpaceCounters.cpp" + + + + + + + THIS_FILE="adaptiveSizePolicy.cpp" + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="abstractInterpreter.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="jvmciCodeInstaller.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="dict.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="log.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="allocation.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="annotations.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="addnode.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="parserTests.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="advancedThresholdPolicy.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="attachListener.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="traceBackend.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../hotspot/make + + + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="accessFlags.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/src/share/vm + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../test/fmw/gtest + ../../test/fmw/gtest/include + + + AMD64 + ASSERT + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="test_os.cpp" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + + + + + ../../hotspot/test/native + ../../hotspot/make + + + GTEST_HAS_EXCEPTIONS=0 + + + + + + + ../../hotspot/test/native + ../../hotspot/make + + + GTEST_HAS_EXCEPTIONS=0 + THIS_FILE="test_quicksort.cpp" + + + + + + + ARCH="amd64" + BREAKPTS + MACRO_MEMSYS_OPS + SOLARIS + THIS_FILE="agent_util.c" + TRACING + _LITTLE_ENDIAN= + __solaris__ + amd64 + cpuIntel + i586 + + + + + ../../jdk/src/demo/share/jvmti/waiters + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/make + ARCH="amd64" BREAKPTS CC_NOEX MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" SOLARIS THIS_FILE="Agent.cpp" TRACING - TRIMMED _LITTLE_ENDIAN= __solaris__ amd64 @@ -38832,149 +64699,43 @@ - - - - ../../jdk/make - - - - + - THIS_FILE="fix_empty_sec_hdr_flags.c" - - - - - - - THIS_FILE="ArrayReferenceImpl.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/transport/export - ../../jdk/src/share/back/export - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/src/share/back - ../../jdk/src/solaris/back - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_jdwp_headers - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - JDWP_LOGGING - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - - - ARCH="amd64" - BREAKPTS - LIBARCHNAME="amd64" - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="java.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="agent_util.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 + DEBUG - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../jdk/src/share/demo/jvmti/waiters - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/make - + + DEBUG + - + - ../../jdk/src/share/demo/jvmti/heapTracker - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/src/demo/share/jvmti/heapTracker + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/java_crw_demo + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make - + - ../../jdk/src/share/demo/jvmti/compiledMethodLoad - ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/compiledMethodLoad + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -38982,11 +64743,16 @@ - + - ../../jdk/src/share/demo/jvmti/gctest - ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/gctest + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -38994,12 +64760,17 @@ - + - ../../jdk/src/share/demo/jvmti/heapTracker - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/src/demo/share/jvmti/heapTracker + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/java_crw_demo + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -39007,11 +64778,16 @@ - + - ../../jdk/src/share/demo/jvmti/heapViewer - ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/heapViewer + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -39019,29 +64795,17 @@ - + - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/demo/jvmti/hprof - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/src/share/demo/jvmti/java_crw_demo - ../../jdk/make - - - THIS_FILE="debug_malloc.c" - - - - - - - ../../jdk/src/share/demo/jvmti/hprof - ../../jdk/src/solaris/demo/jvmti/hprof - ../../jdk/src/share/demo/jvmti/java_crw_demo - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt + ../../jdk/src/demo/share/jvmti/heapTracker + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/java_crw_demo + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -39049,12 +64813,17 @@ - + - ../../jdk/src/share/demo/jvmti/minst - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/src/demo/share/jvmti/minst + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/java_crw_demo + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -39062,12 +64831,17 @@ - + - ../../jdk/src/share/demo/jvmti/mtrace - ../../jdk/src/share/demo/jvmti/agent_util - ../../jdk/src/share/demo/jvmti/java_crw_demo + ../../jdk/src/demo/share/jvmti/mtrace + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/java_crw_demo + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -39075,11 +64849,16 @@ - + - ../../jdk/src/share/demo/jvmti/versionCheck - ../../jdk/src/share/demo/jvmti/agent_util + ../../jdk/src/demo/share/jvmti/versionCheck + ../../jdk/src/demo/share/jvmti/agent_util + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava ../../jdk/make @@ -39087,511 +64866,863 @@ - + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/instrument - ../../jdk/src/solaris/instrument - ../../jdk/src/share/bin + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/demos/classes/jni/Poller ../../jdk/make - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - NO_JPLIS_LOGGING - RELEASE="" - SOLARIS - THIS_FILE="EncodingSupport.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 + THIS_FILE="Poller.c" - + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + - THIS_FILE="DirectAudioDevice.c" + THIS_FILE="main.c" + + ../../jdk/src/java.base/share/native/libjimage + ../../build/support/headers/java.base + ../../make + - THIS_FILE="bands.cpp" + THIS_FILE="NativeImageBuffer.cpp" - + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/com/sun/media/sound - ../../jdk/src/solaris/native/com/sun/media/sound - ../../jdk/make + ../../jdk/src/java.base/share/native/launcher + ../../jdk/src/java.base/share/native/libjli + ../../jdk/src/java.base/unix/native/libjli + ../../jdk/src/java.base/solaris/native/libjli + ../../make - ARCH="amd64" - BREAKPTS - EXTRA_SOUND_JNI_LIBS="" - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - TRACING - TRIMMED - USE_DAUDIO=TRUE - USE_PORTS=TRUE - X_ARCH=X_AMD64 - X_PLATFORM=X_SOLARIS - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - FULL - PRODUCT - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="check_code.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 + DEBUG + ENABLE_ARG_FILES + EXPAND_CLASSPATH_WILDCARDS + HAVE_GETHRTIME + JAVA_ARGS={ "-J-addmods", "-JALL-DEFAULT", "-J-ms8m", "-m", "jdk.jlink/jdk.tools.jlink.internal.Main", } + LAUNCHER_NAME="openjdk" + NEVER_ACT_AS_SERVER_CLASS_MACHINE + PROGNAME="jlink" + VERSION_BUILD=0 + VERSION_MAJOR=9 + VERSION_MINOR=0 + VERSION_NUMBER="9" + VERSION_OPT="2016-06-21-161756.vkvashin.jdktrunk" + VERSION_PATCH=0 + VERSION_PRE="internal" + VERSION_SECURITY=0 + VERSION_SHORT="9-internal" + VERSION_SPECIFICATION="9" + VERSION_STRING="9-internal+0-2016-06-21-161756.vkvashin.jdktrunk" - - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="FileInputStream.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/java.base/share/native/libfdlibm + ../../make + DEBUG + LIBRARY_NAME=fdlibm THIS_FILE="e_acos.c" - + - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Finalizer.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Array.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/src/solaris/native/sun/net/dns - ../../jdk/src/solaris/native/sun/net/spi - ../../jdk/src/solaris/native/sun/net/sdp - ../../jdk/make - - - THIS_FILE="DatagramPacket.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="Bits.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/share/native/libfdlibm + ../../build/support/headers/java.base + ../../make ARCHPROPNAME="amd64" + DEBUG THIS_FILE="AccessController.c" - + + + ../../jdk/src/java.base/unix/native/libjli + ../../jdk/src/java.base/share/native/libjli + ../../make + - THIS_FILE="AtomicLong.c" + DEBUG + LIBARCH32NAME="i386" + LIBARCH64NAME="amd64" + LIBARCHNAME="amd64" + THIS_FILE="args.c" - + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make + ../../build/support/headers/java.base + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/solaris/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../make + + + DEBUG + THIS_FILE="DatagramPacket.c" + + + + + + + ../../jdk/src/java.base/share/native/libnio + ../../jdk/src/java.base/share/native/libnio/ch + ../../jdk/src/java.base/unix/native/libnio + ../../jdk/src/java.base/solaris/native/libnio/ch + ../../jdk/src/java.base/solaris/native/libnio/fs + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/unix/native/libnio/fs + ../../build/support/headers/java.base + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/solaris/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../make + + + DEBUG + THIS_FILE="nio_util.c" + + + + + + + ../../make + + + DEBUG + THIS_FILE="check_code.c" + + + + + + + ../../build/support/headers/java.base + ../../make + + + THIS_FILE="Adler32.c" + USE_MMAP + + + + + + + DEBUG + THIS_FILE="ProcessHandleImpl_solaris.c" + + + + + + + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/share/native/libfdlibm + ../../build/support/headers/java.base + ../../make ARCHPROPNAME="amd64" - - - - THIS_FILE="compress.c" - - - - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/openwin/include - /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../build/support/headers/java.base + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/solaris/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../make - PNG_NO_MMX_CODE - SPLASHSCREEN - WITH_X11 + THIS_FILE="solaris_close.c" - + + + + ../../jdk/src/java.base/share/native/libnio + ../../jdk/src/java.base/share/native/libnio/ch + ../../jdk/src/java.base/unix/native/libnio + ../../jdk/src/java.base/solaris/native/libnio/ch + ../../jdk/src/java.base/solaris/native/libnio/fs + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/unix/native/libnio/fs + ../../build/support/headers/java.base + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/solaris/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../make + + + THIS_FILE="DevPollArrayWrapper.c" + + + + + THIS_FILE="SolarisNativeDispatcher.c" + + + + + + + DEBUG + THIS_FILE="jspawnhelper.c" + + + + + THIS_FILE="osSupport_unix.cpp" + + + + + + + ../../make + + + + + + + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/share/native/libfdlibm + ../../build/support/headers/java.base + ../../make + + + ARCHPROPNAME="amd64" + THIS_FILE="Console_md.c" + + + + + + + ../../jdk/src/java.base/unix/native/libjli + ../../jdk/src/java.base/share/native/libjli + ../../make + + + LIBARCH32NAME="i386" + LIBARCH64NAME="amd64" + LIBARCHNAME="amd64" + THIS_FILE="ergo.c" + + + + + + + ../../build/support/headers/java.base + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/solaris/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../make + + + THIS_FILE="DefaultProxySelector.c" + + + + + + + ../../jdk/src/java.base/share/native/libnio + ../../jdk/src/java.base/share/native/libnio/ch + ../../jdk/src/java.base/unix/native/libnio + ../../jdk/src/java.base/solaris/native/libnio/ch + ../../jdk/src/java.base/solaris/native/libnio/fs + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/unix/native/libnio/fs + ../../build/support/headers/java.base + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/solaris/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../make + + + THIS_FILE="DatagramChannelImpl.c" + + + + + + + THIS_FILE="GioFileTypeDetector.c" + + + + + + + DEBUG THIS_FILE="debug_assert.c" - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers + ../../jdk/src/java.desktop/share/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz/hb-ucdn + ../../jdk/src/java.desktop/share/native/libfontmanager/layout + ../../jdk/src/java.desktop/unix/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common + ../../jdk/src/java.desktop/share/native/common/awt + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/java2d + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/unix/native/common + ../../jdk/src/java.desktop/unix/native/common/java2d + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/solaris/native/libjava + /usr/include/freetype2 + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../make - THIS_FILE="AlternateSubstSubtables.cpp" + DEBUG + GETPAGESIZE + HAVE_FALLBACK + HAVE_MPROTECT + HAVE_OT + HAVE_PTHREAD + HAVE_SOLARIS_ATOMIC_OPS + HAVE_SYSCONF + HAVE_SYS_MMAN_H + HAVE_UCDN + HAVE_UNISTD_H + HEADLESS + LE_STANDALONE + THIS_FILE="hb-blob.cc" - - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + + + + + + + ../../jdk/src/java.desktop/unix/native/libawt_xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d/x11 + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/solaris/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/unix/native/libsunwjdga + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.base/solaris/native/libjava + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../make FUNCPROTO=15 - INTERNAL_BUILD PACKAGE_PATH="/opt/local" - X11_PATH="/usr/X11R6" XAWT XAWT_HACK - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/openwin/include - /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/libmlib_image + ../../make + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageCopy_Bit.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/java.desktop/unix/native/libawt_xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d/x11 + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/solaris/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/unix/native/libsunwjdga + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.base/solaris/native/libjava + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../make + + + FUNCPROTO=15 + PACKAGE_PATH="/opt/local" + THIS_FILE="rect.c" + XAWT + XAWT_HACK + + + + + + + ../../jdk/src/java.desktop/unix/native/libawt_xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d/x11 + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/solaris/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/unix/native/libsunwjdga + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.base/solaris/native/libjava + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../make + + + FUNCPROTO=15 + PACKAGE_PATH="/opt/local" + THIS_FILE="AccelGlyphCache.c" + XAWT + XAWT_HACK + + + + + + + ../../jdk/src/java.desktop/unix/native/libawt_xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d/x11 + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/solaris/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/unix/native/libsunwjdga + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.base/solaris/native/libjava + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../make + + + FUNCPROTO=15 + PACKAGE_PATH="/opt/local" + THIS_FILE="OGLBlitLoops.c" + XAWT + XAWT_HACK + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/common/awt/medialib + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../make + + + THIS_FILE="img_colors.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + THIS_FILE="gifdecoder.c" + + + + + + + THIS_FILE="awt_ImagingLib.c" + + + + + + + THIS_FILE="AlphaMacros.c" + + + + + + + THIS_FILE="BufferedMaskBlit.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz/hb-ucdn + ../../jdk/src/java.desktop/share/native/libfontmanager/layout + ../../jdk/src/java.desktop/unix/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common + ../../jdk/src/java.desktop/share/native/common/awt + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/java2d + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/unix/native/common + ../../jdk/src/java.desktop/unix/native/common/java2d + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/solaris/native/libjava + /usr/include/freetype2 + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../make + + + GETPAGESIZE + HAVE_FALLBACK + HAVE_MPROTECT + HAVE_OT + HAVE_PTHREAD + HAVE_SOLARIS_ATOMIC_OPS + HAVE_SYSCONF + HAVE_SYS_MMAN_H + HAVE_UCDN + HAVE_UNISTD_H + HEADLESS + LE_STANDALONE + THIS_FILE="ucdn.c" + + + + + + + THIS_FILE="AlternateSubstSubtables.cpp" + + + + + + + THIS_FILE="imageioJPEG.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + + + EXTRA_SOUND_JNI_LIBS="" + THIS_FILE="DirectAudioDevice.c" + USE_DAUDIO=TRUE + USE_PORTS=TRUE + X_PLATFORM=X_SOLARIS + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.desktop/share/native/liblcms + ../../make + + + CMS_DONT_USE_FAST_FLOOR + THIS_FILE="LCMS.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/libmlib_image + ../../make + + + MLIB_NO_LIBSUNMATH + MLIB_OS64BIT + THIS_FILE="mlib_ImageAffine.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 PNG_NO_MMX_CODE SPLASHSCREEN THIS_FILE="dgif_lib.c" @@ -39599,1699 +65730,876 @@ - + - THIS_FILE="img_colors.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - THIS_FILE="gifdecoder.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - THIS_FILE="imageioJPEG.c" - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/openwin/include - /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN THIS_FILE="png.c" - WITH_X11 - + - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - - THIS_FILE="awt_ImagingLib.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES + THIS_FILE="systemScale.c" - + - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/unix/native/libawt_xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d/x11 + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/solaris/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/unix/native/libsunwjdga + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.base/solaris/native/libjava /usr/openwin/include /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - THIS_FILE="java_awt_SplashScreen.c" - WITH_X11 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make + ../../make FUNCPROTO=15 - INTERNAL_BUILD PACKAGE_PATH="/opt/local" - THIS_FILE="rect.c" - X11_PATH="/usr/X11R6" XAWT XAWT_HACK - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="AccelGlyphCache.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - /usr/include/freetype2 - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/font/layout - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d - ../../jdk/make - - - HEADLESS - LE_STANDALONE - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="LCMS.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/make - - - - - - - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - THIS_FILE="AlphaMacros.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - FUNCPROTO=15 - INTERNAL_BUILD - PACKAGE_PATH="/opt/local" - THIS_FILE="OGLBlitLoops.c" - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - - - - - - - ../../jdk/src/share/native/sun/awt - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/gif - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/share/native/sun/awt/medialib - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/make - - - INTERNAL_BUILD - THIS_FILE="BufferedMaskBlit.c" - __MEDIALIB_OLD_NAMES - __USE_J2D_NAMES - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/management - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="ClassLoadingImpl.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCH="amd64" - ARCHPROPNAME="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="GC.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../jdk/make - - - THIS_FILE="genSocketOptionRegistry.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCH="amd64" - ARCHPROPNAME="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="ConstantPool.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="ec.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - ../../jdk/src/share/native/sun/security/ec - ../../jdk/src/share/native/sun/security/ec/impl - ../../jdk/make - - - THIS_FILE="ECC_JNI.cpp" - - - - - - - ../../jdk/src/share/native/sun/security/ec - ../../jdk/src/share/native/sun/security/ec/impl - ../../jdk/make - - - MP_API_COMPATIBLE - NSS_ECC_MORE_THAN_SUITE_B - - - - - - - ../../jdk/src/share/native/sun/security/jgss/wrapper - ../../jdk/src/solaris/native/sun/security/jgss/wrapper - ../../jdk/make - - - THIS_FILE="GSSLibStub.c" - - - - - - - ../../jdk/src/share/native/sun/security/pkcs11 - ../../jdk/src/solaris/native/sun/security/pkcs11 - ../../jdk/src/share/native/sun/security/pkcs11/wrapper - ../../jdk/src/solaris/native/sun/security/pkcs11/wrapper - ../../jdk/make - - - THIS_FILE="p11_convert.c" - - - - - - - ../../jdk/src/share/native/sun/security/smartcardio - ../../jdk/src/solaris/native/sun/security/smartcardio - ../../jdk/src/solaris/native/sun/security/smartcardio/MUSCLE - ../../jdk/make - - - THIS_FILE="pcsc.c" - __sun_jdk - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/tracing/dtrace - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="JVM.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="npt.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/transport/socket - ../../jdk/src/solaris/transport/socket - ../../jdk/src/share/back/export - ../../jdk/src/share/back - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="socketTransport.c" - TRACING - TRIMMED - USE_MMAP - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - + - THIS_FILE="exec_md.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/transport/export - ../../jdk/src/share/back/export - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/src/share/back - ../../jdk/src/solaris/back - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_jdwp_headers - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - JDWP_LOGGING - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/bin - ../../jdk/src/solaris/bin - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - LIBARCH32NAME="i386" - LIBARCH64NAME="amd64" - LIBARCHNAME="amd64" - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="ergo.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="Poller.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/democlasses/jni/Poller - ../../jdk/make - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/demo/jvmti/hprof - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/src/share/demo/jvmti/java_crw_demo - ../../jdk/make - - - THIS_FILE="hprof_md.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/instrument - ../../jdk/src/solaris/instrument - ../../jdk/src/share/bin - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - NO_JPLIS_LOGGING - RELEASE="" - SOLARIS - THIS_FILE="EncodingSupport_md.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - THIS_FILE="SolarisOperatingSystem.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../jdk/src/share/native/sun/management - ../../jdk/make - - - - - - - ../../jdk/src/share/native/com/sun/media/sound - ../../jdk/src/solaris/native/com/sun/media/sound - ../../jdk/make - - - EXTRA_SOUND_JNI_LIBS="" - THIS_FILE="PLATFORM_API_SolarisOS_PCM.c" - USE_DAUDIO=TRUE - USE_PORTS=TRUE - X_ARCH=X_AMD64 - X_PLATFORM=X_SOLARIS - - - - - - - ../../jdk/make - - - THIS_FILE="Solaris.c" - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCH="amd64" - ARCHPROPNAME="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="jdk_util_md.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="Console_md.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="ProcessEnvironment_md.c" - - - - - - - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/src/solaris/native/sun/net/dns - ../../jdk/src/solaris/native/sun/net/spi - ../../jdk/src/solaris/native/sun/net/sdp - ../../jdk/make - - - THIS_FILE="Inet4AddressImpl.c" - - - - - - - ../../jdk/src/share/native/sun/nio/ch - ../../jdk/src/share/native/java/io - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/make - - - THIS_FILE="MappedByteBuffer.c" - - - - - - - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make - - - ARCHPROPNAME="amd64" - THIS_FILE="FileSystemPreferences.c" - - - - - - - THIS_FILE="splashscreen_sys.c" - - - - - - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../jdk/src/share/native/sun/awt/image/jpeg - ../../jdk/src/share/native/sun/awt/libpng - ../../jdk/src/share/native/sun/awt/splashscreen - ../../jdk/src/share/native/sun/awt/giflib - ../../jdk/src/solaris/native/sun/awt/splashscreen - /usr/openwin/include - /usr/openwin/include/X11/extensions - ../../jdk/src/share/native/java/util/zip/zlib-1.2.5 - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - - PNG_NO_MMX_CODE - SPLASHSCREEN - WITH_X11 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - /usr/include/freetype2 - ../../jdk/src/share/native/sun/font - ../../jdk/src/share/native/sun/font/layout - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - HEADLESS - LE_STANDALONE - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="X11FontScaler.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - - - - - - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - - ARCH="amd64" - BREAKPTS - FUNCPROTO=15 - INTERNAL_BUILD - MACRO_MEMSYS_OPS - NDEBUG - PACKAGE_PATH="/opt/local" - RELEASE="" - SOLARIS THIS_FILE="GLXGraphicsConfig.c" - TRACING - TRIMMED - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - + THIS_FILE="X11FontScaler_md.c" - + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/management - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.desktop/share/native/libmlib_image + ../../jdk/src/java.desktop/share/native/common/awt/medialib + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../make - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS + THIS_FILE="awt_LoadLibrary.c" + __MEDIALIB_OLD_NAMES + __USE_J2D_NAMES + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/unix/native/libawt_headless/awt + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.desktop/unix/native/libsunwjdga + ../../jdk/src/java.base/solaris/native/libjava + ../../make + + + HEADLESS=true + PACKAGE_PATH="/opt/local" + THIS_FILE="HeadlessToolkit.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/unix/native/libawt_xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/awt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/xawt + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt_xawt/java2d/x11 + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../build/support/headers/java.desktop + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.desktop/solaris/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/unix/native/libsunwjdga + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.base/solaris/native/libjava + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../make + + + FUNCPROTO=15 + PACKAGE_PATH="/opt/local" + THIS_FILE="awt_AWTEvent.c" + XAWT + XAWT_HACK + + + + + + + THIS_FILE="XRBackendNative.c" + + + + + + + THIS_FILE="XToolkit.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/share/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz + ../../jdk/src/java.desktop/share/native/libfontmanager/harfbuzz/hb-ucdn + ../../jdk/src/java.desktop/share/native/libfontmanager/layout + ../../jdk/src/java.desktop/unix/native/libfontmanager + ../../jdk/src/java.desktop/share/native/libawt + ../../jdk/src/java.desktop/share/native/libawt/java2d + ../../jdk/src/java.desktop/share/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/libawt/java2d/pipe + ../../jdk/src/java.desktop/share/native/libawt/awt + ../../jdk/src/java.desktop/share/native/libawt/awt/image + ../../jdk/src/java.desktop/share/native/libawt/awt/image/gif + ../../jdk/src/java.desktop/share/native/libawt/awt/image/cvutils + ../../jdk/src/java.desktop/share/native/libawt/awt/medialib + ../../jdk/src/java.desktop/unix/native/libawt + ../../jdk/src/java.desktop/unix/native/libawt/awt + ../../jdk/src/java.desktop/unix/native/libawt/java2d + ../../jdk/src/java.desktop/unix/native/libawt/java2d/loops + ../../jdk/src/java.desktop/share/native/common + ../../jdk/src/java.desktop/share/native/common/awt + ../../jdk/src/java.desktop/share/native/common/awt/medialib + ../../jdk/src/java.desktop/share/native/common/awt/utility + ../../jdk/src/java.desktop/share/native/common/awt/debug + ../../jdk/src/java.desktop/share/native/common/java2d + ../../jdk/src/java.desktop/share/native/common/java2d/opengl + ../../jdk/src/java.desktop/share/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/share/native/common/font + ../../jdk/src/java.desktop/unix/native/common + ../../jdk/src/java.desktop/unix/native/common/java2d + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl + ../../jdk/src/java.desktop/unix/native/common/java2d/opengl/J2D_GL + ../../jdk/src/java.desktop/unix/native/common/java2d/x11 + ../../jdk/src/java.desktop/unix/native/common/font + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.desktop/unix/native/common/awt/medialib + ../../jdk/src/java.desktop/unix/native/common/awt/utility + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/solaris/native/libjava + /usr/include/freetype2 + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../make + + + GETPAGESIZE + HAVE_FALLBACK + HAVE_MPROTECT + HAVE_OT + HAVE_PTHREAD + HAVE_SOLARIS_ATOMIC_OPS + HAVE_SYSCONF + HAVE_SYS_MMAN_H + HAVE_UCDN + HAVE_UNISTD_H + HEADLESS + LE_STANDALONE + THIS_FILE="X11FontScaler.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.desktop/unix/native/common/awt + ../../jdk/src/java.desktop/solaris/native/include + ../../jdk/src/java.desktop/unix/native/include + ../../jdk/src/java.desktop/share/native/include + ../../jdk/src/java.base/solaris/native/libjava + ../../make + + + THIS_FILE="jawt.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.desktop + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.desktop/share/native/libjsound + ../../jdk/src/java.desktop/unix/native/libjsound + ../../make + + + EXTRA_SOUND_JNI_LIBS="" + THIS_FILE="PLATFORM_API_SolarisOS_PCM.c" + USE_DAUDIO=TRUE + USE_PORTS=TRUE + X_PLATFORM=X_SOLARIS + + + + + + + ../../jdk/src/java.desktop/share/native/libsplashscreen/giflib + ../../jdk/src/java.desktop/share/native/libjavajpeg + ../../jdk/src/java.desktop/share/native/libsplashscreen + ../../jdk/src/java.desktop/share/native/libsplashscreen/libpng + ../../jdk/src/java.desktop/unix/native/libsplashscreen + ../../jdk/src/java.desktop/unix/native/common/awt/systemscale + ../../jdk/src/java.base/solaris/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/share/native/libjava + /usr/openwin/include + /usr/openwin/include/X11/extensions + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../make + + + PNG_ARM_NEON_OPT=0 + PNG_NO_MMX_CODE + SPLASHSCREEN + THIS_FILE="splashscreen_sys.c" + WITH_X11 + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.instrument/share/native/libinstrument + ../../jdk/src/java.instrument/unix/native/libinstrument + ../../build/support/headers/java.instrument + ../../jdk/src/java.base/share/native/libjli + ../../make + + + DEBUG + JPLIS_LOGGING + THIS_FILE="EncodingSupport.c" + + + + + + + THIS_FILE="EncodingSupport_md.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.management/share/native/include + ../../jdk/src/java.management/share/native/libmanagement + ../../jdk/src/java.management/unix/native/libmanagement + ../../build/support/headers/java.management + ../../jdk/src/java.base/solaris/native/libjava + ../../make + + + DEBUG + THIS_FILE="ClassLoadingImpl.c" + + + + + + THIS_FILE="FileSystemImpl.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/java/net - ../../jdk/src/solaris/native/sun/net/dns - ../../jdk/src/solaris/native/sun/net/spi - ../../jdk/src/solaris/native/sun/net/sdp - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.prefs/unix/native/libprefs + ../../jdk/src/java.base/solaris/native/libjava + ../../make - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="ResolverConfigurationImpl.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 + DEBUG + THIS_FILE="FileSystemPreferences.c" - - - - THIS_FILE="SdpSupport.c" - - - - - - - THIS_FILE="DefaultProxySelector.c" - - - - - - - THIS_FILE="SctpChannelImpl.c" - - - - + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/nio/ch + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/java.rmi + ../../make - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 + DEBUG + THIS_FILE="GC.c" - + - ../../jdk/src/share/native/sun/nio/ch/sctp - ../../jdk/src/share/native/java/net - ../../jdk/src/solaris/native/sun/nio/ch - ../../jdk/src/solaris/native/java/net - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.security.jgss/share/native/libj2gss + ../../jdk/src/java.security.jgss/unix/native/libj2gss + ../../jdk/src/java.base/solaris/native/libjava + ../../build/support/headers/java.security.jgss + ../../make - - - - - THIS_FILE="GnomeFileTypeDetector.c" + DEBUG + THIS_FILE="GSSLibStub.c" - + - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS THIS_FILE="NativeFunc.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 - + - ../../jdk/src/share/native/sun/security/jgss/wrapper - ../../jdk/src/solaris/native/sun/security/jgss/wrapper - ../../jdk/make - - - - - - - ../../jdk/src/share/native/sun/security/pkcs11 - ../../jdk/src/solaris/native/sun/security/pkcs11 - ../../jdk/src/share/native/sun/security/pkcs11/wrapper - ../../jdk/src/solaris/native/sun/security/pkcs11/wrapper - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.smartcardio/share/native/libj2pcsc + ../../jdk/src/java.smartcardio/unix/native/libj2pcsc + ../../jdk/src/java.smartcardio/unix/native/libj2pcsc/MUSCLE + ../../build/support/headers/java.smartcardio + ../../make - THIS_FILE="p11_md.c" - - - - - - - ../../jdk/src/share/native/sun/security/smartcardio - ../../jdk/src/solaris/native/sun/security/smartcardio - ../../jdk/src/solaris/native/sun/security/smartcardio/MUSCLE - ../../jdk/make - - - THIS_FILE="pcsc_md.c" + DEBUG + THIS_FILE="pcsc.c" __sun_jdk - + - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/make - - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="SolarisVirtualMachine.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 + THIS_FILE="pcsc_md.c" - + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/tracing/dtrace - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/jdk.attach + ../../jdk/src/java.base/solaris/native/libjava + ../../make - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="jvm_symbols_md.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 + DEBUG + THIS_FILE="VirtualMachineImpl.c" - + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/solaris/native/java/lang - ../../jdk/src/share/native/java/lang - ../../jdk/src/share/native/java/lang/ref - ../../jdk/src/share/native/java/lang/reflect - ../../jdk/src/share/native/java/io - ../../jdk/src/solaris/native/java/io - ../../jdk/src/share/native/java/nio - ../../jdk/src/share/native/java/security - ../../jdk/src/share/native/sun/misc - ../../jdk/src/share/native/sun/reflect - ../../jdk/src/share/native/java/util - ../../jdk/src/share/native/java/util/concurrent/atomic - ../../jdk/src/solaris/native/java/util - ../../jdk/src/solaris/native/sun/util/locale/provider - ../../jdk/src/share/native/java/lang/fdlibm/include - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../make - ARCH="amd64" - ARCHPROPNAME="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="HostLocaleProviderAdapter_md.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 + DEBUG + MP_API_COMPATIBLE + NSS_ECC_MORE_THAN_SUITE_B + THIS_FILE="ec.c" + + + + + ../../make + + + DEBUG + THIS_FILE="ECC_JNI.cpp" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/jdk.crypto.pkcs11/share/native/libj2pkcs11 + ../../jdk/src/jdk.crypto.pkcs11/unix/native/libj2pkcs11 + ../../jdk/src/java.base/solaris/native/libjava + ../../build/support/headers/jdk.crypto.pkcs11 + ../../make + + + DEBUG + THIS_FILE="j2secmod.c" - + - - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/native/sun/awt/debug - ../../jdk/src/share/native/sun/awt/utility - ../../jdk/src/share/native/sun/font - ../../jdk/src/solaris/native/sun/font - ../../jdk/src/share/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/awt - ../../jdk/src/solaris/native/sun/java2d/opengl - ../../jdk/src/solaris/native/sun/java2d/x11 - ../../jdk/src/solaris/native/sun/xawt - ../../jdk/src/share/native/sun/java2d - ../../jdk/src/solaris/native/sun/java2d - ../../jdk/src/share/native/sun/java2d/loops - ../../jdk/src/share/native/sun/java2d/pipe - ../../jdk/src/share/native/sun/awt/image - ../../jdk/src/share/native/sun/awt/image/cvutils - ../../jdk/src/solaris/native/sun/jdga - ../../jdk/make - - ARCH="amd64" - BREAKPTS - FUNCPROTO=15 - INTERNAL_BUILD - MACRO_MEMSYS_OPS - NDEBUG - PACKAGE_PATH="/opt/local" - RELEASE="" - SOLARIS - THIS_FILE="XToolkit.c" - TRACING - TRIMMED - X11_PATH="/usr/X11R6" - XAWT - XAWT_HACK - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 + THIS_FILE="j2secmod_md.c" - + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/npt - ../../jdk/src/solaris/npt - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/jdk.crypto.ucrypto/solaris/native/libj2ucrypto + ../../make - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="utf_md.c" - TRACING - TRIMMED - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 + DEBUG + THIS_FILE="nativeCrypto.c" - + - ../../build/solaris-x86_64-normal-server-release/jdk/include - ../../build/solaris-x86_64-normal-server-release/jdk/include/solaris - ../../jdk/src/share/javavm/export - ../../jdk/src/solaris/javavm/export - ../../jdk/src/share/native/common - ../../jdk/src/solaris/native/common - ../../build/solaris-x86_64-normal-server-release/jdk/gensrc_headers - ../../jdk/src/share/transport/socket - ../../jdk/src/solaris/transport/socket - ../../jdk/src/share/back/export - ../../jdk/src/share/back - ../../jdk/make + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + + + DEBUG + THIS_FILE="socketTransport.c" + + + + + + + ../../jdk/src/jdk.jdwp.agent/share/native/libdt_socket + ../../jdk/src/jdk.jdwp.agent/unix/native/libdt_socket + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp/export + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp + ../../jdk/src/jdk.jdwp.agent/share/native/include + ../../make - ARCH="amd64" - BREAKPTS - MACRO_MEMSYS_OPS - NDEBUG - RELEASE="" - SOLARIS - THIS_FILE="socket_md.c" - TRACING - TRIMMED USE_MMAP - _LITTLE_ENDIAN= - __solaris__ - amd64 - cpuIntel - i586 + + + + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp/export + ../../jdk/src/jdk.jdwp.agent/share/native/include + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp + ../../jdk/src/jdk.jdwp.agent/unix/native/libjdwp + ../../build/support/headers/jdk.jdwp.agent + ../../make + + + JDWP_LOGGING + THIS_FILE="ArrayReferenceImpl.c" + + + + + + + THIS_FILE="socket_md.c" + + + + + + + ../../jdk/src/jdk.jdwp.agent/share/native/libdt_socket + ../../jdk/src/jdk.jdwp.agent/unix/native/libdt_socket + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp/export + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp + ../../jdk/src/jdk.jdwp.agent/share/native/include + ../../make + + + USE_MMAP + + + + + + + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp/export + ../../jdk/src/jdk.jdwp.agent/share/native/include + ../../jdk/src/jdk.jdwp.agent/share/native/libjdwp + ../../jdk/src/jdk.jdwp.agent/unix/native/libjdwp + ../../build/support/headers/jdk.jdwp.agent + ../../make + + + JDWP_LOGGING + THIS_FILE="exec_md.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.management/share/native/include + ../../jdk/src/jdk.management/share/native/libmanagement_ext + ../../jdk/src/jdk.management/unix/native/libmanagement_ext + ../../jdk/src/jdk.management/solaris/native/libmanagement_ext + ../../build/support/headers/jdk.management + ../../jdk/src/java.base/solaris/native/libjava + ../../make + + + DEBUG + THIS_FILE="DiagnosticCommandImpl.c" + + + + + + + THIS_FILE="UnixOperatingSystem.c" + + + + + + + THIS_FILE="OperatingSystemImpl.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/jdk.net + ../../make + + + DEBUG + THIS_FILE="SolarisSocketOptions.c" + + + + + + + DEBUG + FULL + THIS_FILE="bands.cpp" + + + + + + + ../../build/support/headers/java.base + ../../jdk/src/jdk.pack200/share/native/common-unpack + ../../jdk/src/java.base/solaris/native/libjava + ../../make + + + NO_ZLIB + UNPACK_JNI + + + + + + + ../../build/support/headers/java.base + ../../jdk/src/jdk.pack200/share/native/common-unpack + ../../jdk/src/java.base/solaris/native/libjava + ../../make + + + NO_ZLIB + THIS_FILE="jni.cpp" + UNPACK_JNI + + + + + + + ../../jdk/src/jdk.pack200/share/native/common-unpack + ../../make + + + SYSTEM_ZLIB + THIS_FILE="main.cpp" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../jdk/src/java.base/unix/native/libnio/ch + ../../jdk/src/java.base/share/native/libnio/ch + ../../jdk/src/java.base/solaris/native/libnet + ../../jdk/src/java.base/unix/native/libnet + ../../jdk/src/java.base/share/native/libnet + ../../jdk/src/java.base/solaris/native/libjava + ../../build/support/headers/jdk.sctp + ../../build/support/headers/java.base + ../../make + + + DEBUG + THIS_FILE="SctpChannelImpl.c" + + + + + + + ../../jdk/src/java.base/share/native/include + ../../jdk/src/java.base/solaris/native/include + ../../jdk/src/java.base/unix/native/include + ../../jdk/src/java.base/share/native/libjava + ../../jdk/src/java.base/unix/native/libjava + ../../build/support/headers/jdk.security.auth + ../../make + + + DEBUG + THIS_FILE="Solaris.c" + + + + + + + THIS_FILE="Unix.c" + + + + + + + ../../hotspot/src/share/vm + ../../hotspot/src/os/solaris/vm + ../../hotspot/src/os/posix/vm + ../../hotspot/src/cpu/x86/vm + ../../hotspot/src/os_cpu/solaris_x86/vm + ../../build/hotspot/variant-server/gensrc + ../../hotspot/src/share/vm/precompiled + ../../hotspot/src/share/vm/prims + ../../test/fmw/gtest + ../../test/fmw/gtest/include + ../../hotspot/test/native + ../../hotspot/make + + + AMD64 + ASSERT + COMPILER1 + COMPILER2 + DONT_USE_PRECOMPILED_HEADER + DTRACE_ENABLED + GTEST_HAS_EXCEPTIONS=0 + HOTSPOT_LIB_ARCH="amd64" + SOLARIS + SPARC_WORKS + TARGET_ARCH_MODEL_x86_64 + TARGET_ARCH_x86 + TARGET_COMPILER_sparcWorks + TARGET_OS_ARCH_MODEL_solaris_x86_64 + TARGET_OS_ARCH_solaris_x86 + TARGET_OS_FAMILY_solaris + THIS_FILE="gtest-all.cc" + VM_LITTLE_ENDIAN + _Crun_inline_placement + _NMT_NOINLINE_ + + + diff --git a/common/nb_native/nbproject/project.xml b/common/nb_native/nbproject/project.xml index 0f248c751ed..37ac590e95d 100644 --- a/common/nb_native/nbproject/project.xml +++ b/common/nb_native/nbproject/project.xml @@ -6,7 +6,7 @@ OpenJDK (Native) c,m cc,cpp - ad,h,hpp,in_out + ad,h,hh,hpp,in_out,map,txt UTF-8 @@ -26,6 +26,9 @@ 0 + + false + diff --git a/hotspot/.hgtags b/hotspot/.hgtags index 91141129553..393252486a7 100644 --- a/hotspot/.hgtags +++ b/hotspot/.hgtags @@ -528,3 +528,4 @@ af6b4ad908e732d23021f12e8322b204433d5cf6 jdk-9+122 75f81e1fecfb444f34f357295fe06af60e2762d9 jdk-9+123 479631362b4930be985245ea063d87d821a472eb jdk-9+124 bb640b49741af3f57f9994129934c46fc173219f jdk-9+125 +adc8c84b7cf8c540d920182f78a2bc982366432a jdk-9+126 diff --git a/hotspot/.mx.jvmci/mx_jvmci.py b/hotspot/.mx.jvmci/mx_jvmci.py index b359dcf7f95..ede9029a5ba 100644 --- a/hotspot/.mx.jvmci/mx_jvmci.py +++ b/hotspot/.mx.jvmci/mx_jvmci.py @@ -186,7 +186,8 @@ To build hotspot and import it into the JDK: "mx make hotspot import-hotspot" # Might be building with JDK8 which has cacerts under jre/ srcCerts = join(mx.get_jdk(tag='default').home, 'jre', 'lib', 'security', 'cacerts') dstCerts = join(jdkImageDir, 'lib', 'security', 'cacerts') - shutil.copyfile(srcCerts, dstCerts) + if srcCerts != dstCerts: + shutil.copyfile(srcCerts, dstCerts) _create_jdk_bundle(jdkBuildDir, _vm.debugLevel, jdkImageDir) diff --git a/hotspot/.mx.jvmci/suite.py b/hotspot/.mx.jvmci/suite.py index 9ca4c8cb77e..359c2b2ae3a 100644 --- a/hotspot/.mx.jvmci/suite.py +++ b/hotspot/.mx.jvmci/suite.py @@ -149,7 +149,6 @@ suite = { "subDir" : "src/jdk.vm.ci/share/classes", "sourceDirs" : ["src"], "dependencies" : [ - "jdk.vm.ci.hotspotvmconfig", "jdk.vm.ci.common", "jdk.vm.ci.runtime", "jdk.vm.ci.services", @@ -175,14 +174,6 @@ suite = { "workingSets" : "API,JVMCI", }, - "jdk.vm.ci.hotspotvmconfig" : { - "subDir" : "src/jdk.vm.ci/share/classes", - "sourceDirs" : ["src"], - "checkstyle" : "jdk.vm.ci.services", - "javaCompliance" : "9", - "workingSets" : "JVMCI,HotSpot", - }, - "jdk.vm.ci.hotspot.aarch64" : { "subDir" : "src/jdk.vm.ci/share/classes", "sourceDirs" : ["src"], @@ -248,13 +239,6 @@ suite = { ], }, - "JVMCI_HOTSPOTVMCONFIG" : { - "subDir" : "src/jdk.vm.ci/share/classes", - "dependencies" : [ - "jdk.vm.ci.hotspotvmconfig", - ], - }, - "JVMCI_HOTSPOT" : { "subDir" : "src/jdk.vm.ci/share/classes", "dependencies" : [ @@ -263,7 +247,6 @@ suite = { "jdk.vm.ci.hotspot.sparc", ], "distDependencies" : [ - "JVMCI_HOTSPOTVMCONFIG", "JVMCI_SERVICES", "JVMCI_API", ], diff --git a/hotspot/make/lib/CompileGtest.gmk b/hotspot/make/lib/CompileGtest.gmk index 2fd3f966704..2a052a10743 100644 --- a/hotspot/make/lib/CompileGtest.gmk +++ b/hotspot/make/lib/CompileGtest.gmk @@ -23,7 +23,10 @@ # questions. # -GTEST_TEST_SRC := $(HOTSPOT_TOPDIR)/test/native +$(eval $(call IncludeCustomExtension, hotspot, lib/CompileGtest.gmk)) + +GTEST_TEST_SRC += $(HOTSPOT_TOPDIR)/test/native +GTEST_LAUNCHER_SRC := $(HOTSPOT_TOPDIR)/test/native/gtestLauncher.cpp GTEST_FRAMEWORK_SRC := $(SRC_ROOT)/test/fmw/gtest # On Windows, there are no internal debug symbols so must set copying to true @@ -65,7 +68,7 @@ $(eval $(call SetupNativeCompilation, BUILD_GTEST_LIBJVM, \ $(BUILD_LIBJVM_ALL_OBJS)), \ CFLAGS := $(JVM_CFLAGS) -I$(GTEST_FRAMEWORK_SRC) \ -I$(GTEST_FRAMEWORK_SRC)/include \ - -I$(GTEST_TEST_SRC), \ + $(addprefix -I,$(GTEST_TEST_SRC)), \ CFLAGS_windows := /EHsc, \ CFLAGS_solaris := -DGTEST_HAS_EXCEPTIONS=0 -library=stlport4, \ CFLAGS_macosx := -DGTEST_OS_MAC=1, \ @@ -73,7 +76,7 @@ $(eval $(call SetupNativeCompilation, BUILD_GTEST_LIBJVM, \ CXXFLAGS_DEBUG_SYMBOLS := $(JVM_CFLAGS_SYMBOLS), \ DISABLED_WARNINGS_gcc := undef, \ DISABLED_WARNINGS_clang := undef switch format-nonliteral \ - tautological-undefined-compare, \ + tautological-undefined-compare $(BUILD_LIBJVM_DISABLED_WARNINGS_clang), \ DISABLED_WARNINGS_solstudio := identexpected, \ LDFLAGS := $(JVM_LDFLAGS), \ LDFLAGS_solaris := -library=stlport4 $(call SET_SHARED_LIBRARY_ORIGIN), \ @@ -83,6 +86,8 @@ $(eval $(call SetupNativeCompilation, BUILD_GTEST_LIBJVM, \ USE_MAPFILE_FOR_SYMBOLS := true, \ COPY_DEBUG_SYMBOLS := $(GTEST_COPY_DEBUG_SYMBOLS), \ ZIP_EXTERNAL_DEBUG_SYMBOLS := false, \ + PRECOMPILED_HEADER := $(JVM_PRECOMPILED_HEADER), \ + PRECOMPILED_HEADER_EXCLUDE := gtest-all.cc gtestMain.cpp, \ )) TARGETS += $(BUILD_GTEST_LIBJVM) @@ -93,7 +98,7 @@ $(eval $(call SetupNativeCompilation, BUILD_GTEST_LAUNCHER, \ TOOLCHAIN := $(JVM_TOOLCHAIN), \ PROGRAM := gtestLauncher, \ OUTPUT_DIR := $(JVM_OUTPUTDIR)/gtest, \ - EXTRA_FILES := $(GTEST_TEST_SRC)/gtestLauncher.cpp, \ + EXTRA_FILES := $(GTEST_LAUNCHER_SRC), \ OBJECT_DIR := $(JVM_OUTPUTDIR)/gtest/launcher-objs, \ CFLAGS := $(JVM_CFLAGS) -I$(GTEST_FRAMEWORK_SRC) \ -I$(GTEST_FRAMEWORK_SRC)/include, \ diff --git a/hotspot/make/lib/JvmOverrideFiles.gmk b/hotspot/make/lib/JvmOverrideFiles.gmk index 78a007cc39d..f7827ef5c40 100644 --- a/hotspot/make/lib/JvmOverrideFiles.gmk +++ b/hotspot/make/lib/JvmOverrideFiles.gmk @@ -35,6 +35,7 @@ endif ifeq ($(OPENJDK_TARGET_OS), linux) BUILD_LIBJVM_ostream.cpp_CXXFLAGS := -D_FILE_OFFSET_BITS=64 + BUILD_LIBJVM_logFileOutput.cpp_CXXFLAGS := -D_FILE_OFFSET_BITS=64 ifeq ($(OPENJDK_TARGET_CPU_ARCH), x86) BUILD_LIBJVM_sharedRuntimeTrig.cpp_CXXFLAGS := -DNO_PCH $(CXX_O_FLAG_NONE) diff --git a/hotspot/src/cpu/aarch64/vm/aarch64.ad b/hotspot/src/cpu/aarch64/vm/aarch64.ad index 1aeae0bf38f..89fac8fa208 100644 --- a/hotspot/src/cpu/aarch64/vm/aarch64.ad +++ b/hotspot/src/cpu/aarch64/vm/aarch64.ad @@ -6629,6 +6629,82 @@ operand cmpOpU() %} %} +// used for certain integral comparisons which can be +// converted to cbxx or tbxx instructions + +operand cmpOpEqNe() +%{ + match(Bool); + match(CmpOp); + op_cost(0); + predicate(n->as_Bool()->_test._test == BoolTest::ne + || n->as_Bool()->_test._test == BoolTest::eq); + + format %{ "" %} + interface(COND_INTER) %{ + equal(0x0, "eq"); + not_equal(0x1, "ne"); + less(0xb, "lt"); + greater_equal(0xa, "ge"); + less_equal(0xd, "le"); + greater(0xc, "gt"); + overflow(0x6, "vs"); + no_overflow(0x7, "vc"); + %} +%} + +// used for certain integral comparisons which can be +// converted to cbxx or tbxx instructions + +operand cmpOpLtGe() +%{ + match(Bool); + match(CmpOp); + op_cost(0); + + predicate(n->as_Bool()->_test._test == BoolTest::lt + || n->as_Bool()->_test._test == BoolTest::ge); + + format %{ "" %} + interface(COND_INTER) %{ + equal(0x0, "eq"); + not_equal(0x1, "ne"); + less(0xb, "lt"); + greater_equal(0xa, "ge"); + less_equal(0xd, "le"); + greater(0xc, "gt"); + overflow(0x6, "vs"); + no_overflow(0x7, "vc"); + %} +%} + +// used for certain unsigned integral comparisons which can be +// converted to cbxx or tbxx instructions + +operand cmpOpUEqNeLtGe() +%{ + match(Bool); + match(CmpOp); + op_cost(0); + + predicate(n->as_Bool()->_test._test == BoolTest::eq + || n->as_Bool()->_test._test == BoolTest::ne + || n->as_Bool()->_test._test == BoolTest::lt + || n->as_Bool()->_test._test == BoolTest::ge); + + format %{ "" %} + interface(COND_INTER) %{ + equal(0x0, "eq"); + not_equal(0x1, "ne"); + less(0xb, "lt"); + greater_equal(0xa, "ge"); + less_equal(0xd, "le"); + greater(0xc, "gt"); + overflow(0x6, "vs"); + no_overflow(0x7, "vc"); + %} +%} + // Special operand allowing long args to int ops to be truncated for free operand iRegL2I(iRegL reg) %{ @@ -14286,10 +14362,8 @@ instruct branchConU(cmpOpU cmp, rFlagsRegU cr, label lbl) // shorter than (cmp; branch), have the additional benefit of not // killing the flags. -instruct cmpI_imm0_branch(cmpOp cmp, iRegIorL2I op1, immI0 op2, label labl, rFlagsReg cr) %{ +instruct cmpI_imm0_branch(cmpOpEqNe cmp, iRegIorL2I op1, immI0 op2, label labl, rFlagsReg cr) %{ match(If cmp (CmpI op1 op2)); - predicate(n->in(1)->as_Bool()->_test._test == BoolTest::ne - || n->in(1)->as_Bool()->_test._test == BoolTest::eq); effect(USE labl); ins_cost(BRANCH_COST); @@ -14305,10 +14379,8 @@ instruct cmpI_imm0_branch(cmpOp cmp, iRegIorL2I op1, immI0 op2, label labl, rFla ins_pipe(pipe_cmp_branch); %} -instruct cmpL_imm0_branch(cmpOp cmp, iRegL op1, immL0 op2, label labl, rFlagsReg cr) %{ +instruct cmpL_imm0_branch(cmpOpEqNe cmp, iRegL op1, immL0 op2, label labl, rFlagsReg cr) %{ match(If cmp (CmpL op1 op2)); - predicate(n->in(1)->as_Bool()->_test._test == BoolTest::ne - || n->in(1)->as_Bool()->_test._test == BoolTest::eq); effect(USE labl); ins_cost(BRANCH_COST); @@ -14324,10 +14396,8 @@ instruct cmpL_imm0_branch(cmpOp cmp, iRegL op1, immL0 op2, label labl, rFlagsReg ins_pipe(pipe_cmp_branch); %} -instruct cmpP_imm0_branch(cmpOp cmp, iRegP op1, immP0 op2, label labl, rFlagsReg cr) %{ +instruct cmpP_imm0_branch(cmpOpEqNe cmp, iRegP op1, immP0 op2, label labl, rFlagsReg cr) %{ match(If cmp (CmpP op1 op2)); - predicate(n->in(1)->as_Bool()->_test._test == BoolTest::ne - || n->in(1)->as_Bool()->_test._test == BoolTest::eq); effect(USE labl); ins_cost(BRANCH_COST); @@ -14343,10 +14413,8 @@ instruct cmpP_imm0_branch(cmpOp cmp, iRegP op1, immP0 op2, label labl, rFlagsReg ins_pipe(pipe_cmp_branch); %} -instruct cmpN_imm0_branch(cmpOp cmp, iRegN op1, immN0 op2, label labl, rFlagsReg cr) %{ +instruct cmpN_imm0_branch(cmpOpEqNe cmp, iRegN op1, immN0 op2, label labl, rFlagsReg cr) %{ match(If cmp (CmpN op1 op2)); - predicate(n->in(1)->as_Bool()->_test._test == BoolTest::ne - || n->in(1)->as_Bool()->_test._test == BoolTest::eq); effect(USE labl); ins_cost(BRANCH_COST); @@ -14362,10 +14430,8 @@ instruct cmpN_imm0_branch(cmpOp cmp, iRegN op1, immN0 op2, label labl, rFlagsReg ins_pipe(pipe_cmp_branch); %} -instruct cmpP_narrowOop_imm0_branch(cmpOp cmp, iRegN oop, immP0 zero, label labl, rFlagsReg cr) %{ +instruct cmpP_narrowOop_imm0_branch(cmpOpEqNe cmp, iRegN oop, immP0 zero, label labl, rFlagsReg cr) %{ match(If cmp (CmpP (DecodeN oop) zero)); - predicate(n->in(1)->as_Bool()->_test._test == BoolTest::ne - || n->in(1)->as_Bool()->_test._test == BoolTest::eq); effect(USE labl); ins_cost(BRANCH_COST); @@ -14381,12 +14447,8 @@ instruct cmpP_narrowOop_imm0_branch(cmpOp cmp, iRegN oop, immP0 zero, label labl ins_pipe(pipe_cmp_branch); %} -instruct cmpUI_imm0_branch(cmpOpU cmp, iRegIorL2I op1, immI0 op2, label labl, rFlagsRegU cr) %{ +instruct cmpUI_imm0_branch(cmpOpUEqNeLtGe cmp, iRegIorL2I op1, immI0 op2, label labl, rFlagsRegU cr) %{ match(If cmp (CmpU op1 op2)); - predicate(n->in(1)->as_Bool()->_test._test == BoolTest::ne - || n->in(1)->as_Bool()->_test._test == BoolTest::eq - || n->in(1)->as_Bool()->_test._test == BoolTest::gt - || n->in(1)->as_Bool()->_test._test == BoolTest::le); effect(USE labl); ins_cost(BRANCH_COST); @@ -14402,12 +14464,8 @@ instruct cmpUI_imm0_branch(cmpOpU cmp, iRegIorL2I op1, immI0 op2, label labl, rF ins_pipe(pipe_cmp_branch); %} -instruct cmpUL_imm0_branch(cmpOpU cmp, iRegL op1, immL0 op2, label labl, rFlagsRegU cr) %{ +instruct cmpUL_imm0_branch(cmpOpUEqNeLtGe cmp, iRegL op1, immL0 op2, label labl, rFlagsRegU cr) %{ match(If cmp (CmpU op1 op2)); - predicate(n->in(1)->as_Bool()->_test._test == BoolTest::ne - || n->in(1)->as_Bool()->_test._test == BoolTest::eq - || n->in(1)->as_Bool()->_test._test == BoolTest::gt - || n->in(1)->as_Bool()->_test._test == BoolTest::le); effect(USE labl); ins_cost(BRANCH_COST); @@ -14426,10 +14484,8 @@ instruct cmpUL_imm0_branch(cmpOpU cmp, iRegL op1, immL0 op2, label labl, rFlagsR // Test bit and Branch // Patterns for short (< 32KiB) variants -instruct cmpL_branch_sign(cmpOp cmp, iRegL op1, immL0 op2, label labl) %{ +instruct cmpL_branch_sign(cmpOpLtGe cmp, iRegL op1, immL0 op2, label labl) %{ match(If cmp (CmpL op1 op2)); - predicate(n->in(1)->as_Bool()->_test._test == BoolTest::lt - || n->in(1)->as_Bool()->_test._test == BoolTest::ge); effect(USE labl); ins_cost(BRANCH_COST); @@ -14444,10 +14500,8 @@ instruct cmpL_branch_sign(cmpOp cmp, iRegL op1, immL0 op2, label labl) %{ ins_short_branch(1); %} -instruct cmpI_branch_sign(cmpOp cmp, iRegIorL2I op1, immI0 op2, label labl) %{ +instruct cmpI_branch_sign(cmpOpLtGe cmp, iRegIorL2I op1, immI0 op2, label labl) %{ match(If cmp (CmpI op1 op2)); - predicate(n->in(1)->as_Bool()->_test._test == BoolTest::lt - || n->in(1)->as_Bool()->_test._test == BoolTest::ge); effect(USE labl); ins_cost(BRANCH_COST); @@ -14462,11 +14516,9 @@ instruct cmpI_branch_sign(cmpOp cmp, iRegIorL2I op1, immI0 op2, label labl) %{ ins_short_branch(1); %} -instruct cmpL_branch_bit(cmpOp cmp, iRegL op1, immL op2, immL0 op3, label labl) %{ +instruct cmpL_branch_bit(cmpOpEqNe cmp, iRegL op1, immL op2, immL0 op3, label labl) %{ match(If cmp (CmpL (AndL op1 op2) op3)); - predicate((n->in(1)->as_Bool()->_test._test == BoolTest::ne - || n->in(1)->as_Bool()->_test._test == BoolTest::eq) - && is_power_of_2(n->in(2)->in(1)->in(2)->get_long())); + predicate(is_power_of_2(n->in(2)->in(1)->in(2)->get_long())); effect(USE labl); ins_cost(BRANCH_COST); @@ -14481,11 +14533,9 @@ instruct cmpL_branch_bit(cmpOp cmp, iRegL op1, immL op2, immL0 op3, label labl) ins_short_branch(1); %} -instruct cmpI_branch_bit(cmpOp cmp, iRegIorL2I op1, immI op2, immI0 op3, label labl) %{ +instruct cmpI_branch_bit(cmpOpEqNe cmp, iRegIorL2I op1, immI op2, immI0 op3, label labl) %{ match(If cmp (CmpI (AndI op1 op2) op3)); - predicate((n->in(1)->as_Bool()->_test._test == BoolTest::ne - || n->in(1)->as_Bool()->_test._test == BoolTest::eq) - && is_power_of_2(n->in(2)->in(1)->in(2)->get_int())); + predicate(is_power_of_2(n->in(2)->in(1)->in(2)->get_int())); effect(USE labl); ins_cost(BRANCH_COST); @@ -14501,10 +14551,8 @@ instruct cmpI_branch_bit(cmpOp cmp, iRegIorL2I op1, immI op2, immI0 op3, label l %} // And far variants -instruct far_cmpL_branch_sign(cmpOp cmp, iRegL op1, immL0 op2, label labl) %{ +instruct far_cmpL_branch_sign(cmpOpLtGe cmp, iRegL op1, immL0 op2, label labl) %{ match(If cmp (CmpL op1 op2)); - predicate(n->in(1)->as_Bool()->_test._test == BoolTest::lt - || n->in(1)->as_Bool()->_test._test == BoolTest::ge); effect(USE labl); ins_cost(BRANCH_COST); @@ -14518,10 +14566,8 @@ instruct far_cmpL_branch_sign(cmpOp cmp, iRegL op1, immL0 op2, label labl) %{ ins_pipe(pipe_cmp_branch); %} -instruct far_cmpI_branch_sign(cmpOp cmp, iRegIorL2I op1, immI0 op2, label labl) %{ +instruct far_cmpI_branch_sign(cmpOpLtGe cmp, iRegIorL2I op1, immI0 op2, label labl) %{ match(If cmp (CmpI op1 op2)); - predicate(n->in(1)->as_Bool()->_test._test == BoolTest::lt - || n->in(1)->as_Bool()->_test._test == BoolTest::ge); effect(USE labl); ins_cost(BRANCH_COST); @@ -14535,11 +14581,9 @@ instruct far_cmpI_branch_sign(cmpOp cmp, iRegIorL2I op1, immI0 op2, label labl) ins_pipe(pipe_cmp_branch); %} -instruct far_cmpL_branch_bit(cmpOp cmp, iRegL op1, immL op2, immL0 op3, label labl) %{ +instruct far_cmpL_branch_bit(cmpOpEqNe cmp, iRegL op1, immL op2, immL0 op3, label labl) %{ match(If cmp (CmpL (AndL op1 op2) op3)); - predicate((n->in(1)->as_Bool()->_test._test == BoolTest::ne - || n->in(1)->as_Bool()->_test._test == BoolTest::eq) - && is_power_of_2(n->in(2)->in(1)->in(2)->get_long())); + predicate(is_power_of_2(n->in(2)->in(1)->in(2)->get_long())); effect(USE labl); ins_cost(BRANCH_COST); @@ -14553,11 +14597,9 @@ instruct far_cmpL_branch_bit(cmpOp cmp, iRegL op1, immL op2, immL0 op3, label la ins_pipe(pipe_cmp_branch); %} -instruct far_cmpI_branch_bit(cmpOp cmp, iRegIorL2I op1, immI op2, immI0 op3, label labl) %{ +instruct far_cmpI_branch_bit(cmpOpEqNe cmp, iRegIorL2I op1, immI op2, immI0 op3, label labl) %{ match(If cmp (CmpI (AndI op1 op2) op3)); - predicate((n->in(1)->as_Bool()->_test._test == BoolTest::ne - || n->in(1)->as_Bool()->_test._test == BoolTest::eq) - && is_power_of_2(n->in(2)->in(1)->in(2)->get_int())); + predicate(is_power_of_2(n->in(2)->in(1)->in(2)->get_int())); effect(USE labl); ins_cost(BRANCH_COST); diff --git a/hotspot/src/cpu/aarch64/vm/templateInterpreterGenerator_aarch64.cpp b/hotspot/src/cpu/aarch64/vm/templateInterpreterGenerator_aarch64.cpp index f24536daf75..4c54f8e357e 100644 --- a/hotspot/src/cpu/aarch64/vm/templateInterpreterGenerator_aarch64.cpp +++ b/hotspot/src/cpu/aarch64/vm/templateInterpreterGenerator_aarch64.cpp @@ -630,7 +630,11 @@ void TemplateInterpreterGenerator::generate_counter_overflow(Label& do_continue) __ b(do_continue); } -// See if we've got enough room on the stack for locals plus overhead. +// See if we've got enough room on the stack for locals plus overhead +// below JavaThread::stack_overflow_limit(). If not, throw a StackOverflowError +// without going through the signal handler, i.e., reserved and yellow zones +// will not be made usable. The shadow zone must suffice to handle the +// overflow. // The expression stack grows down incrementally, so the normal guard // page mechanism will work for that. // @@ -674,40 +678,25 @@ void TemplateInterpreterGenerator::generate_stack_overflow_check(void) { // compute rsp as if this were going to be the last frame on // the stack before the red zone - const Address stack_base(rthread, Thread::stack_base_offset()); - const Address stack_size(rthread, Thread::stack_size_offset()); - // locals + overhead, in bytes __ mov(r0, overhead_size); __ add(r0, r0, r3, Assembler::LSL, Interpreter::logStackElementSize); // 2 slots per parameter. - __ ldr(rscratch1, stack_base); - __ ldr(rscratch2, stack_size); + const Address stack_limit(rthread, JavaThread::stack_overflow_limit_offset()); + __ ldr(rscratch1, stack_limit); #ifdef ASSERT - Label stack_base_okay, stack_size_okay; - // verify that thread stack base is non-zero - __ cbnz(rscratch1, stack_base_okay); - __ stop("stack base is zero"); - __ bind(stack_base_okay); - // verify that thread stack size is non-zero - __ cbnz(rscratch2, stack_size_okay); - __ stop("stack size is zero"); - __ bind(stack_size_okay); + Label limit_okay; + // Verify that thread stack limit is non-zero. + __ cbnz(rscratch1, limit_okay); + __ stop("stack overflow limit is zero"); + __ bind(limit_okay); #endif - // Add stack base to locals and subtract stack size - __ sub(rscratch1, rscratch1, rscratch2); // Stack limit + // Add stack limit to locals. __ add(r0, r0, rscratch1); - // Use the bigger size for banging. - const int max_bang_size = MAX2(JavaThread::stack_shadow_zone_size(), - JavaThread::stack_red_zone_size() + JavaThread::stack_yellow_zone_size()); - - // add in the red and yellow zone sizes - __ add(r0, r0, max_bang_size * 2); - - // check against the current stack bottom + // Check against the current stack bottom. __ cmp(sp, r0); __ br(Assembler::HI, after_frame_check); @@ -1088,9 +1077,9 @@ address TemplateInterpreterGenerator::generate_native_entry(bool synchronized) { __ ldr(r2, constMethod); __ load_unsigned_short(r2, size_of_parameters); - // native calls don't need the stack size check since they have no + // Native calls don't need the stack size check since they have no // expression stack and the arguments are already on the stack and - // we only add a handful of words to the stack + // we only add a handful of words to the stack. // rmethod: Method* // r2: size of parameters diff --git a/hotspot/src/cpu/ppc/vm/assembler_ppc.hpp b/hotspot/src/cpu/ppc/vm/assembler_ppc.hpp index 813580542e1..e81d08e848a 100644 --- a/hotspot/src/cpu/ppc/vm/assembler_ppc.hpp +++ b/hotspot/src/cpu/ppc/vm/assembler_ppc.hpp @@ -706,9 +706,13 @@ class Assembler : public AbstractAssembler { TW_OPCODE = (31u << OPCODE_SHIFT | 4u << 1), // Atomics. + LBARX_OPCODE = (31u << OPCODE_SHIFT | 52u << 1), + LHARX_OPCODE = (31u << OPCODE_SHIFT | 116u << 1), LWARX_OPCODE = (31u << OPCODE_SHIFT | 20u << 1), LDARX_OPCODE = (31u << OPCODE_SHIFT | 84u << 1), LQARX_OPCODE = (31u << OPCODE_SHIFT | 276u << 1), + STBCX_OPCODE = (31u << OPCODE_SHIFT | 694u << 1), + STHCX_OPCODE = (31u << OPCODE_SHIFT | 726u << 1), STWCX_OPCODE = (31u << OPCODE_SHIFT | 150u << 1), STDCX_OPCODE = (31u << OPCODE_SHIFT | 214u << 1), STQCX_OPCODE = (31u << OPCODE_SHIFT | 182u << 1) @@ -1796,13 +1800,19 @@ class Assembler : public AbstractAssembler { inline void waitrsv(); // >=Power7 // atomics + inline void lbarx_unchecked(Register d, Register a, Register b, int eh1 = 0); // >=Power 8 + inline void lharx_unchecked(Register d, Register a, Register b, int eh1 = 0); // >=Power 8 inline void lwarx_unchecked(Register d, Register a, Register b, int eh1 = 0); inline void ldarx_unchecked(Register d, Register a, Register b, int eh1 = 0); - inline void lqarx_unchecked(Register d, Register a, Register b, int eh1 = 0); + inline void lqarx_unchecked(Register d, Register a, Register b, int eh1 = 0); // >=Power 8 inline bool lxarx_hint_exclusive_access(); + inline void lbarx( Register d, Register a, Register b, bool hint_exclusive_access = false); + inline void lharx( Register d, Register a, Register b, bool hint_exclusive_access = false); inline void lwarx( Register d, Register a, Register b, bool hint_exclusive_access = false); inline void ldarx( Register d, Register a, Register b, bool hint_exclusive_access = false); inline void lqarx( Register d, Register a, Register b, bool hint_exclusive_access = false); + inline void stbcx_( Register s, Register a, Register b); + inline void sthcx_( Register s, Register a, Register b); inline void stwcx_( Register s, Register a, Register b); inline void stdcx_( Register s, Register a, Register b); inline void stqcx_( Register s, Register a, Register b); @@ -2169,12 +2179,18 @@ class Assembler : public AbstractAssembler { inline void dcbtstct(Register s2, int ct); // Atomics: use ra0mem to disallow R0 as base. + inline void lbarx_unchecked(Register d, Register b, int eh1); + inline void lharx_unchecked(Register d, Register b, int eh1); inline void lwarx_unchecked(Register d, Register b, int eh1); inline void ldarx_unchecked(Register d, Register b, int eh1); inline void lqarx_unchecked(Register d, Register b, int eh1); + inline void lbarx( Register d, Register b, bool hint_exclusive_access); + inline void lharx( Register d, Register b, bool hint_exclusive_access); inline void lwarx( Register d, Register b, bool hint_exclusive_access); inline void ldarx( Register d, Register b, bool hint_exclusive_access); inline void lqarx( Register d, Register b, bool hint_exclusive_access); + inline void stbcx_(Register s, Register b); + inline void sthcx_(Register s, Register b); inline void stwcx_(Register s, Register b); inline void stdcx_(Register s, Register b); inline void stqcx_(Register s, Register b); diff --git a/hotspot/src/cpu/ppc/vm/assembler_ppc.inline.hpp b/hotspot/src/cpu/ppc/vm/assembler_ppc.inline.hpp index ca126170157..14f25e4eea8 100644 --- a/hotspot/src/cpu/ppc/vm/assembler_ppc.inline.hpp +++ b/hotspot/src/cpu/ppc/vm/assembler_ppc.inline.hpp @@ -594,13 +594,19 @@ inline void Assembler::waitrsv() { emit_int32( WAIT_OPCODE | 1<<(31-10)); } // W // atomics // Use ra0mem to disallow R0 as base. +inline void Assembler::lbarx_unchecked(Register d, Register a, Register b, int eh1) { emit_int32( LBARX_OPCODE | rt(d) | ra0mem(a) | rb(b) | eh(eh1)); } +inline void Assembler::lharx_unchecked(Register d, Register a, Register b, int eh1) { emit_int32( LHARX_OPCODE | rt(d) | ra0mem(a) | rb(b) | eh(eh1)); } inline void Assembler::lwarx_unchecked(Register d, Register a, Register b, int eh1) { emit_int32( LWARX_OPCODE | rt(d) | ra0mem(a) | rb(b) | eh(eh1)); } inline void Assembler::ldarx_unchecked(Register d, Register a, Register b, int eh1) { emit_int32( LDARX_OPCODE | rt(d) | ra0mem(a) | rb(b) | eh(eh1)); } inline void Assembler::lqarx_unchecked(Register d, Register a, Register b, int eh1) { emit_int32( LQARX_OPCODE | rt(d) | ra0mem(a) | rb(b) | eh(eh1)); } inline bool Assembler::lxarx_hint_exclusive_access() { return VM_Version::has_lxarxeh(); } +inline void Assembler::lbarx( Register d, Register a, Register b, bool hint_exclusive_access) { lbarx_unchecked(d, a, b, (hint_exclusive_access && lxarx_hint_exclusive_access() && UseExtendedLoadAndReserveInstructionsPPC64) ? 1 : 0); } +inline void Assembler::lharx( Register d, Register a, Register b, bool hint_exclusive_access) { lharx_unchecked(d, a, b, (hint_exclusive_access && lxarx_hint_exclusive_access() && UseExtendedLoadAndReserveInstructionsPPC64) ? 1 : 0); } inline void Assembler::lwarx( Register d, Register a, Register b, bool hint_exclusive_access) { lwarx_unchecked(d, a, b, (hint_exclusive_access && lxarx_hint_exclusive_access() && UseExtendedLoadAndReserveInstructionsPPC64) ? 1 : 0); } inline void Assembler::ldarx( Register d, Register a, Register b, bool hint_exclusive_access) { ldarx_unchecked(d, a, b, (hint_exclusive_access && lxarx_hint_exclusive_access() && UseExtendedLoadAndReserveInstructionsPPC64) ? 1 : 0); } inline void Assembler::lqarx( Register d, Register a, Register b, bool hint_exclusive_access) { lqarx_unchecked(d, a, b, (hint_exclusive_access && lxarx_hint_exclusive_access() && UseExtendedLoadAndReserveInstructionsPPC64) ? 1 : 0); } +inline void Assembler::stbcx_(Register s, Register a, Register b) { emit_int32( STBCX_OPCODE | rs(s) | ra0mem(a) | rb(b) | rc(1)); } +inline void Assembler::sthcx_(Register s, Register a, Register b) { emit_int32( STHCX_OPCODE | rs(s) | ra0mem(a) | rb(b) | rc(1)); } inline void Assembler::stwcx_(Register s, Register a, Register b) { emit_int32( STWCX_OPCODE | rs(s) | ra0mem(a) | rb(b) | rc(1)); } inline void Assembler::stdcx_(Register s, Register a, Register b) { emit_int32( STDCX_OPCODE | rs(s) | ra0mem(a) | rb(b) | rc(1)); } inline void Assembler::stqcx_(Register s, Register a, Register b) { emit_int32( STQCX_OPCODE | rs(s) | ra0mem(a) | rb(b) | rc(1)); } @@ -933,12 +939,18 @@ inline void Assembler::dcbtst( Register s2) { emit_int32( DCBTST_OPCOD inline void Assembler::dcbtstct(Register s2, int ct) { emit_int32( DCBTST_OPCODE | rb(s2) | thct(ct)); } // ra0 version +inline void Assembler::lbarx_unchecked(Register d, Register b, int eh1) { emit_int32( LBARX_OPCODE | rt(d) | rb(b) | eh(eh1)); } +inline void Assembler::lharx_unchecked(Register d, Register b, int eh1) { emit_int32( LHARX_OPCODE | rt(d) | rb(b) | eh(eh1)); } inline void Assembler::lwarx_unchecked(Register d, Register b, int eh1) { emit_int32( LWARX_OPCODE | rt(d) | rb(b) | eh(eh1)); } inline void Assembler::ldarx_unchecked(Register d, Register b, int eh1) { emit_int32( LDARX_OPCODE | rt(d) | rb(b) | eh(eh1)); } inline void Assembler::lqarx_unchecked(Register d, Register b, int eh1) { emit_int32( LQARX_OPCODE | rt(d) | rb(b) | eh(eh1)); } +inline void Assembler::lbarx( Register d, Register b, bool hint_exclusive_access){ lbarx_unchecked(d, b, (hint_exclusive_access && lxarx_hint_exclusive_access() && UseExtendedLoadAndReserveInstructionsPPC64) ? 1 : 0); } +inline void Assembler::lharx( Register d, Register b, bool hint_exclusive_access){ lharx_unchecked(d, b, (hint_exclusive_access && lxarx_hint_exclusive_access() && UseExtendedLoadAndReserveInstructionsPPC64) ? 1 : 0); } inline void Assembler::lwarx( Register d, Register b, bool hint_exclusive_access){ lwarx_unchecked(d, b, (hint_exclusive_access && lxarx_hint_exclusive_access() && UseExtendedLoadAndReserveInstructionsPPC64) ? 1 : 0); } inline void Assembler::ldarx( Register d, Register b, bool hint_exclusive_access){ ldarx_unchecked(d, b, (hint_exclusive_access && lxarx_hint_exclusive_access() && UseExtendedLoadAndReserveInstructionsPPC64) ? 1 : 0); } inline void Assembler::lqarx( Register d, Register b, bool hint_exclusive_access){ lqarx_unchecked(d, b, (hint_exclusive_access && lxarx_hint_exclusive_access() && UseExtendedLoadAndReserveInstructionsPPC64) ? 1 : 0); } +inline void Assembler::stbcx_(Register s, Register b) { emit_int32( STBCX_OPCODE | rs(s) | rb(b) | rc(1)); } +inline void Assembler::sthcx_(Register s, Register b) { emit_int32( STHCX_OPCODE | rs(s) | rb(b) | rc(1)); } inline void Assembler::stwcx_(Register s, Register b) { emit_int32( STWCX_OPCODE | rs(s) | rb(b) | rc(1)); } inline void Assembler::stdcx_(Register s, Register b) { emit_int32( STDCX_OPCODE | rs(s) | rb(b) | rc(1)); } inline void Assembler::stqcx_(Register s, Register b) { emit_int32( STQCX_OPCODE | rs(s) | rb(b) | rc(1)); } diff --git a/hotspot/src/cpu/ppc/vm/globals_ppc.hpp b/hotspot/src/cpu/ppc/vm/globals_ppc.hpp index a442f17f4b8..662dc3c6bf1 100644 --- a/hotspot/src/cpu/ppc/vm/globals_ppc.hpp +++ b/hotspot/src/cpu/ppc/vm/globals_ppc.hpp @@ -40,9 +40,9 @@ define_pd_global(bool, ImplicitNullChecks, true); // Generate code for impli define_pd_global(bool, TrapBasedNullChecks, true); define_pd_global(bool, UncommonNullCast, true); // Uncommon-trap NULLs passed to check cast. -#define DEFAULT_STACK_YELLOW_PAGES (6) +#define DEFAULT_STACK_YELLOW_PAGES (2) #define DEFAULT_STACK_RED_PAGES (1) -#define DEFAULT_STACK_SHADOW_PAGES (6 DEBUG_ONLY(+2)) +#define DEFAULT_STACK_SHADOW_PAGES (20 DEBUG_ONLY(+2)) #define DEFAULT_STACK_RESERVED_PAGES (1) #define MIN_STACK_YELLOW_PAGES DEFAULT_STACK_YELLOW_PAGES diff --git a/hotspot/src/cpu/ppc/vm/interp_masm_ppc_64.cpp b/hotspot/src/cpu/ppc/vm/interp_masm_ppc_64.cpp index d3c60b74944..2a8eddf18ad 100644 --- a/hotspot/src/cpu/ppc/vm/interp_masm_ppc_64.cpp +++ b/hotspot/src/cpu/ppc/vm/interp_masm_ppc_64.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2016, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2012, 2016 SAP SE. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * @@ -478,33 +478,6 @@ void InterpreterMacroAssembler::gen_subtype_check(Register Rsub_klass, Register profile_typecheck_failed(Rtmp1, Rtmp2); } -void InterpreterMacroAssembler::generate_stack_overflow_check_with_compare_and_throw(Register Rmem_frame_size, Register Rscratch1) { - Label done; - BLOCK_COMMENT("stack_overflow_check_with_compare_and_throw {"); - sub(Rmem_frame_size, R1_SP, Rmem_frame_size); - ld(Rscratch1, thread_(stack_overflow_limit)); - cmpld(CCR0/*is_stack_overflow*/, Rmem_frame_size, Rscratch1); - bgt(CCR0/*is_stack_overflow*/, done); - - // Load target address of the runtime stub. - assert(StubRoutines::throw_StackOverflowError_entry() != NULL, "generated in wrong order"); - load_const_optimized(Rscratch1, (StubRoutines::throw_StackOverflowError_entry()), R0); - mtctr(Rscratch1); - // Restore caller_sp. -#ifdef ASSERT - ld(Rscratch1, 0, R1_SP); - ld(R0, 0, R21_sender_SP); - cmpd(CCR0, R0, Rscratch1); - asm_assert_eq("backlink", 0x547); -#endif // ASSERT - mr(R1_SP, R21_sender_SP); - bctr(); - - align(32, 12); - bind(done); - BLOCK_COMMENT("} stack_overflow_check_with_compare_and_throw"); -} - // Separate these two to allow for delay slot in middle. // These are used to do a test and full jump to exception-throwing code. diff --git a/hotspot/src/cpu/ppc/vm/interp_masm_ppc_64.hpp b/hotspot/src/cpu/ppc/vm/interp_masm_ppc_64.hpp index 05bd3aa0bdd..3da602dd93e 100644 --- a/hotspot/src/cpu/ppc/vm/interp_masm_ppc_64.hpp +++ b/hotspot/src/cpu/ppc/vm/interp_masm_ppc_64.hpp @@ -1,6 +1,6 @@ /* - * Copyright (c) 2002, 2015, Oracle and/or its affiliates. All rights reserved. - * Copyright (c) 2012, 2015 SAP SE. All rights reserved. + * Copyright (c) 2002, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2016 SAP SE. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -79,7 +79,6 @@ class InterpreterMacroAssembler: public MacroAssembler { // Load object from cpool->resolved_references(index). void load_resolved_reference_at_index(Register result, Register index, Label *is_null = NULL); - void generate_stack_overflow_check_with_compare_and_throw(Register Rmem_frame_size, Register Rscratch1); void load_receiver(Register Rparam_count, Register Rrecv_dst); // helpers for expression stack diff --git a/hotspot/src/cpu/ppc/vm/macroAssembler_ppc.cpp b/hotspot/src/cpu/ppc/vm/macroAssembler_ppc.cpp index d0b0fa8dbda..5d58dab4995 100644 --- a/hotspot/src/cpu/ppc/vm/macroAssembler_ppc.cpp +++ b/hotspot/src/cpu/ppc/vm/macroAssembler_ppc.cpp @@ -1422,42 +1422,168 @@ void MacroAssembler::reserved_stack_check(Register return_pc) { bind(no_reserved_zone_enabling); } -// CmpxchgX sets condition register to cmpX(current, compare). -void MacroAssembler::cmpxchgw(ConditionRegister flag, Register dest_current_value, - Register compare_value, Register exchange_value, - Register addr_base, int semantics, bool cmpxchgx_hint, - Register int_flag_success, bool contention_hint, bool weak) { +void MacroAssembler::getandsetd(Register dest_current_value, Register exchange_value, Register addr_base, + bool cmpxchgx_hint) { Label retry; - Label failed; - Label done; - - // Save one branch if result is returned via register and - // result register is different from the other ones. - bool use_result_reg = (int_flag_success != noreg); - bool preset_result_reg = (int_flag_success != dest_current_value && int_flag_success != compare_value && - int_flag_success != exchange_value && int_flag_success != addr_base); - assert(!weak || flag == CCR0, "weak only supported with CCR0"); - - if (use_result_reg && preset_result_reg) { - li(int_flag_success, 0); // preset (assume cas failed) + bind(retry); + ldarx(dest_current_value, addr_base, cmpxchgx_hint); + stdcx_(exchange_value, addr_base); + if (UseStaticBranchPredictionInCompareAndSwapPPC64) { + bne_predict_not_taken(CCR0, retry); // StXcx_ sets CCR0. + } else { + bne( CCR0, retry); // StXcx_ sets CCR0. } +} - // Add simple guard in order to reduce risk of starving under high contention (recommended by IBM). - if (contention_hint) { // Don't try to reserve if cmp fails. - lwz(dest_current_value, 0, addr_base); - cmpw(flag, dest_current_value, compare_value); - bne(flag, failed); +void MacroAssembler::getandaddd(Register dest_current_value, Register inc_value, Register addr_base, + Register tmp, bool cmpxchgx_hint) { + Label retry; + bind(retry); + ldarx(dest_current_value, addr_base, cmpxchgx_hint); + add(tmp, dest_current_value, inc_value); + stdcx_(tmp, addr_base); + if (UseStaticBranchPredictionInCompareAndSwapPPC64) { + bne_predict_not_taken(CCR0, retry); // StXcx_ sets CCR0. + } else { + bne( CCR0, retry); // StXcx_ sets CCR0. } +} - // release/fence semantics - if (semantics & MemBarRel) { - release(); +// Word/sub-word atomic helper functions + +// Temps and addr_base are killed if size < 4 and processor does not support respective instructions. +// Only signed types are supported with size < 4. +// Atomic add always kills tmp1. +void MacroAssembler::atomic_get_and_modify_generic(Register dest_current_value, Register exchange_value, + Register addr_base, Register tmp1, Register tmp2, Register tmp3, + bool cmpxchgx_hint, bool is_add, int size) { + // Sub-word instructions are available since Power 8. + // For older processors, instruction_type != size holds, and we + // emulate the sub-word instructions by constructing a 4-byte value + // that leaves the other bytes unchanged. + const int instruction_type = VM_Version::has_lqarx() ? size : 4; + + Label retry; + Register shift_amount = noreg, + val32 = dest_current_value, + modval = is_add ? tmp1 : exchange_value; + + if (instruction_type != size) { + assert_different_registers(tmp1, tmp2, tmp3, dest_current_value, exchange_value, addr_base); + modval = tmp1; + shift_amount = tmp2; + val32 = tmp3; + // Need some preperation: Compute shift amount, align address. Note: shorts must be 2 byte aligned. +#ifdef VM_LITTLE_ENDIAN + rldic(shift_amount, addr_base, 3, 64-5); // (dest & 3) * 8; + clrrdi(addr_base, addr_base, 2); +#else + xori(shift_amount, addr_base, (size == 1) ? 3 : 2); + clrrdi(addr_base, addr_base, 2); + rldic(shift_amount, shift_amount, 3, 64-5); // byte: ((3-dest) & 3) * 8; short: ((1-dest/2) & 1) * 16; +#endif } // atomic emulation loop bind(retry); - lwarx(dest_current_value, addr_base, cmpxchgx_hint); + switch (instruction_type) { + case 4: lwarx(val32, addr_base, cmpxchgx_hint); break; + case 2: lharx(val32, addr_base, cmpxchgx_hint); break; + case 1: lbarx(val32, addr_base, cmpxchgx_hint); break; + default: ShouldNotReachHere(); + } + + if (instruction_type != size) { + srw(dest_current_value, val32, shift_amount); + } + + if (is_add) { add(modval, dest_current_value, exchange_value); } + + if (instruction_type != size) { + // Transform exchange value such that the replacement can be done by one xor instruction. + xorr(modval, dest_current_value, is_add ? modval : exchange_value); + clrldi(modval, modval, (size == 1) ? 56 : 48); + slw(modval, modval, shift_amount); + xorr(modval, val32, modval); + } + + switch (instruction_type) { + case 4: stwcx_(modval, addr_base); break; + case 2: sthcx_(modval, addr_base); break; + case 1: stbcx_(modval, addr_base); break; + default: ShouldNotReachHere(); + } + + if (UseStaticBranchPredictionInCompareAndSwapPPC64) { + bne_predict_not_taken(CCR0, retry); // StXcx_ sets CCR0. + } else { + bne( CCR0, retry); // StXcx_ sets CCR0. + } + + // l?arx zero-extends, but Java wants byte/short values sign-extended. + if (size == 1) { + extsb(dest_current_value, dest_current_value); + } else if (size == 2) { + extsh(dest_current_value, dest_current_value); + }; +} + +// Temps, addr_base and exchange_value are killed if size < 4 and processor does not support respective instructions. +// Only signed types are supported with size < 4. +void MacroAssembler::cmpxchg_loop_body(ConditionRegister flag, Register dest_current_value, + Register compare_value, Register exchange_value, + Register addr_base, Register tmp1, Register tmp2, + Label &retry, Label &failed, bool cmpxchgx_hint, int size) { + // Sub-word instructions are available since Power 8. + // For older processors, instruction_type != size holds, and we + // emulate the sub-word instructions by constructing a 4-byte value + // that leaves the other bytes unchanged. + const int instruction_type = VM_Version::has_lqarx() ? size : 4; + + Register shift_amount = noreg, + val32 = dest_current_value, + modval = exchange_value; + + if (instruction_type != size) { + assert_different_registers(tmp1, tmp2, dest_current_value, compare_value, exchange_value, addr_base); + shift_amount = tmp1; + val32 = tmp2; + modval = tmp2; + // Need some preperation: Compute shift amount, align address. Note: shorts must be 2 byte aligned. +#ifdef VM_LITTLE_ENDIAN + rldic(shift_amount, addr_base, 3, 64-5); // (dest & 3) * 8; + clrrdi(addr_base, addr_base, 2); +#else + xori(shift_amount, addr_base, (size == 1) ? 3 : 2); + clrrdi(addr_base, addr_base, 2); + rldic(shift_amount, shift_amount, 3, 64-5); // byte: ((3-dest) & 3) * 8; short: ((1-dest/2) & 1) * 16; +#endif + // Transform exchange value such that the replacement can be done by one xor instruction. + xorr(exchange_value, compare_value, exchange_value); + clrldi(exchange_value, exchange_value, (size == 1) ? 56 : 48); + slw(exchange_value, exchange_value, shift_amount); + } + + // atomic emulation loop + bind(retry); + + switch (instruction_type) { + case 4: lwarx(val32, addr_base, cmpxchgx_hint); break; + case 2: lharx(val32, addr_base, cmpxchgx_hint); break; + case 1: lbarx(val32, addr_base, cmpxchgx_hint); break; + default: ShouldNotReachHere(); + } + + if (instruction_type != size) { + srw(dest_current_value, val32, shift_amount); + } + if (size == 1) { + extsb(dest_current_value, dest_current_value); + } else if (size == 2) { + extsh(dest_current_value, dest_current_value); + }; + cmpw(flag, dest_current_value, compare_value); if (UseStaticBranchPredictionInCompareAndSwapPPC64) { bne_predict_not_taken(flag, failed); @@ -1467,7 +1593,60 @@ void MacroAssembler::cmpxchgw(ConditionRegister flag, Register dest_current_valu // branch to done => (flag == ne), (dest_current_value != compare_value) // fall through => (flag == eq), (dest_current_value == compare_value) - stwcx_(exchange_value, addr_base); + if (instruction_type != size) { + xorr(modval, val32, exchange_value); + } + + switch (instruction_type) { + case 4: stwcx_(modval, addr_base); break; + case 2: sthcx_(modval, addr_base); break; + case 1: stbcx_(modval, addr_base); break; + default: ShouldNotReachHere(); + } +} + +// CmpxchgX sets condition register to cmpX(current, compare). +void MacroAssembler::cmpxchg_generic(ConditionRegister flag, Register dest_current_value, + Register compare_value, Register exchange_value, + Register addr_base, Register tmp1, Register tmp2, + int semantics, bool cmpxchgx_hint, + Register int_flag_success, bool contention_hint, bool weak, int size) { + Label retry; + Label failed; + Label done; + + // Save one branch if result is returned via register and + // result register is different from the other ones. + bool use_result_reg = (int_flag_success != noreg); + bool preset_result_reg = (int_flag_success != dest_current_value && int_flag_success != compare_value && + int_flag_success != exchange_value && int_flag_success != addr_base && + int_flag_success != tmp1 && int_flag_success != tmp2); + assert(!weak || flag == CCR0, "weak only supported with CCR0"); + assert(size == 1 || size == 2 || size == 4, "unsupported"); + + if (use_result_reg && preset_result_reg) { + li(int_flag_success, 0); // preset (assume cas failed) + } + + // Add simple guard in order to reduce risk of starving under high contention (recommended by IBM). + if (contention_hint) { // Don't try to reserve if cmp fails. + switch (size) { + case 1: lbz(dest_current_value, 0, addr_base); extsb(dest_current_value, dest_current_value); break; + case 2: lha(dest_current_value, 0, addr_base); break; + case 4: lwz(dest_current_value, 0, addr_base); break; + default: ShouldNotReachHere(); + } + cmpw(flag, dest_current_value, compare_value); + bne(flag, failed); + } + + // release/fence semantics + if (semantics & MemBarRel) { + release(); + } + + cmpxchg_loop_body(flag, dest_current_value, compare_value, exchange_value, addr_base, tmp1, tmp2, + retry, failed, cmpxchgx_hint, size); if (!weak || use_result_reg) { if (UseStaticBranchPredictionInCompareAndSwapPPC64) { bne_predict_not_taken(CCR0, weak ? failed : retry); // StXcx_ sets CCR0. @@ -3751,454 +3930,6 @@ void MacroAssembler::has_negatives(Register src, Register cnt, Register result, bind(Ldone); } - -// Intrinsics for non-CompactStrings - -// Search for a single jchar in an jchar[]. -// -// Assumes that result differs from all other registers. -// -// 'haystack' is the addresses of a jchar-array. -// 'needle' is either the character to search for or R0. -// 'needleChar' is the character to search for if 'needle' == R0.. -// 'haycnt' is the length of the haystack. We assume 'haycnt' >=1. -// -// Preserves haystack, haycnt, needle and kills all other registers. -// -// If needle == R0, we search for the constant needleChar. -void MacroAssembler::string_indexof_1(Register result, Register haystack, Register haycnt, - Register needle, jchar needleChar, - Register tmp1, Register tmp2) { - - assert_different_registers(result, haystack, haycnt, needle, tmp1, tmp2); - - Label L_InnerLoop, L_FinalCheck, L_Found1, L_Found2, L_Found3, L_NotFound, L_End; - Register addr = tmp1, - ch1 = tmp2, - ch2 = R0; - -//3: - dcbtct(haystack, 0x00); // Indicate R/O access to haystack. - - srwi_(tmp2, haycnt, 1); // Shift right by exact_log2(UNROLL_FACTOR). - mr(addr, haystack); - beq(CCR0, L_FinalCheck); - mtctr(tmp2); // Move to count register. -//8: - bind(L_InnerLoop); // Main work horse (2x unrolled search loop). - lhz(ch1, 0, addr); // Load characters from haystack. - lhz(ch2, 2, addr); - (needle != R0) ? cmpw(CCR0, ch1, needle) : cmplwi(CCR0, ch1, needleChar); - (needle != R0) ? cmpw(CCR1, ch2, needle) : cmplwi(CCR1, ch2, needleChar); - beq(CCR0, L_Found1); // Did we find the needle? - beq(CCR1, L_Found2); - addi(addr, addr, 4); - bdnz(L_InnerLoop); -//16: - bind(L_FinalCheck); - andi_(R0, haycnt, 1); - beq(CCR0, L_NotFound); - lhz(ch1, 0, addr); // One position left at which we have to compare. - (needle != R0) ? cmpw(CCR1, ch1, needle) : cmplwi(CCR1, ch1, needleChar); - beq(CCR1, L_Found3); -//21: - bind(L_NotFound); - li(result, -1); // Not found. - b(L_End); - - bind(L_Found2); - addi(addr, addr, 2); -//24: - bind(L_Found1); - bind(L_Found3); // Return index ... - subf(addr, haystack, addr); // relative to haystack, - srdi(result, addr, 1); // in characters. - bind(L_End); -} - - -// Implementation of IndexOf for jchar arrays. -// -// The length of haystack and needle are not constant, i.e. passed in a register. -// -// Preserves registers haystack, needle. -// Kills registers haycnt, needlecnt. -// Assumes that result differs from all other registers. -// Haystack, needle are the addresses of jchar-arrays. -// Haycnt, needlecnt are the lengths of them, respectively. -// -// Needlecntval must be zero or 15-bit unsigned immediate and > 1. -void MacroAssembler::string_indexof(Register result, Register haystack, Register haycnt, - Register needle, ciTypeArray* needle_values, Register needlecnt, int needlecntval, - Register tmp1, Register tmp2, Register tmp3, Register tmp4) { - - // Ensure 0=2, bail out otherwise. - // ************************************************************************************************** - -//1 (variable) or 3 (const): - dcbtct(needle, 0x00); // Indicate R/O access to str1. - dcbtct(haystack, 0x00); // Indicate R/O access to str2. - - // Compute last haystack addr to use if no match gets found. - if (needlecntval == 0) { // variable needlecnt -//3: - subf(ch1, needlecnt, haycnt); // Last character index to compare is haycnt-needlecnt. - addi(addr, haystack, -2); // Accesses use pre-increment. - cmpwi(CCR6, needlecnt, 2); - blt(CCR6, L_TooShort); // Variable needlecnt: handle short needle separately. - slwi(ch1, ch1, 1); // Scale to number of bytes. - lwz(n_start, 0, needle); // Load first 2 characters of needle. - add(last_addr, haystack, ch1); // Point to last address to compare (haystack+2*(haycnt-needlecnt)). - addi(needlecnt, needlecnt, -2); // Rest of needle. - } else { // constant needlecnt - guarantee(needlecntval != 1, "IndexOf with single-character needle must be handled separately"); - assert((needlecntval & 0x7fff) == needlecntval, "wrong immediate"); -//5: - addi(ch1, haycnt, -needlecntval); // Last character index to compare is haycnt-needlecnt. - lwz(n_start, 0, needle); // Load first 2 characters of needle. - addi(addr, haystack, -2); // Accesses use pre-increment. - slwi(ch1, ch1, 1); // Scale to number of bytes. - add(last_addr, haystack, ch1); // Point to last address to compare (haystack+2*(haycnt-needlecnt)). - li(needlecnt, needlecntval-2); // Rest of needle. - } - - // Main Loop (now we have at least 3 characters). -//11: - Label L_OuterLoop, L_InnerLoop, L_FinalCheck, L_Comp1, L_Comp2, L_Comp3; - bind(L_OuterLoop); // Search for 1st 2 characters. - Register addr_diff = tmp4; - subf(addr_diff, addr, last_addr); // Difference between already checked address and last address to check. - addi(addr, addr, 2); // This is the new address we want to use for comparing. - srdi_(ch2, addr_diff, 2); - beq(CCR0, L_FinalCheck); // 2 characters left? - mtctr(ch2); // addr_diff/4 -//16: - bind(L_InnerLoop); // Main work horse (2x unrolled search loop) - lwz(ch1, 0, addr); // Load 2 characters of haystack (ignore alignment). - lwz(ch2, 2, addr); - cmpw(CCR0, ch1, n_start); // Compare 2 characters (1 would be sufficient but try to reduce branches to CompLoop). - cmpw(CCR1, ch2, n_start); - beq(CCR0, L_Comp1); // Did we find the needle start? - beq(CCR1, L_Comp2); - addi(addr, addr, 4); - bdnz(L_InnerLoop); -//24: - bind(L_FinalCheck); - rldicl_(addr_diff, addr_diff, 64-1, 63); // Remaining characters not covered by InnerLoop: (addr_diff>>1)&1. - beq(CCR0, L_NotFound); - lwz(ch1, 0, addr); // One position left at which we have to compare. - cmpw(CCR1, ch1, n_start); - beq(CCR1, L_Comp3); -//29: - bind(L_NotFound); - li(result, -1); // not found - b(L_End); - - - // ************************************************************************************************** - // Special Case: unfortunately, the variable needle case can be called with needlecnt<2 - // ************************************************************************************************** -//31: - if ((needlecntval>>1) !=1 ) { // Const needlecnt is 2 or 3? Reduce code size. - int nopcnt = 5; - if (needlecntval !=0 ) ++nopcnt; // Balance alignment (other case: see below). - if (needlecntval == 0) { // We have to handle these cases separately. - Label L_OneCharLoop; - bind(L_TooShort); - mtctr(haycnt); - lhz(n_start, 0, needle); // First character of needle - bind(L_OneCharLoop); - lhzu(ch1, 2, addr); - cmpw(CCR1, ch1, n_start); - beq(CCR1, L_Found); // Did we find the one character needle? - bdnz(L_OneCharLoop); - li(result, -1); // Not found. - b(L_End); - } // 8 instructions, so no impact on alignment. - for (int x = 0; x < nopcnt; ++x) nop(); - } - - // ************************************************************************************************** - // Regular Case Part II: compare rest of needle (first 2 characters have been compared already) - // ************************************************************************************************** - - // Compare the rest -//36 if needlecntval==0, else 37: - bind(L_Comp2); - addi(addr, addr, 2); // First comparison has failed, 2nd one hit. - bind(L_Comp1); // Addr points to possible needle start. - bind(L_Comp3); // Could have created a copy and use a different return address but saving code size here. - if (needlecntval != 2) { // Const needlecnt==2? - if (needlecntval != 3) { - if (needlecntval == 0) beq(CCR6, L_Found); // Variable needlecnt==2? - Register ind_reg = tmp4; - li(ind_reg, 2*2); // First 2 characters are already compared, use index 2. - mtctr(needlecnt); // Decremented by 2, still > 0. -//40: - Label L_CompLoop; - bind(L_CompLoop); - lhzx(ch2, needle, ind_reg); - lhzx(ch1, addr, ind_reg); - cmpw(CCR1, ch1, ch2); - bne(CCR1, L_OuterLoop); - addi(ind_reg, ind_reg, 2); - bdnz(L_CompLoop); - } else { // No loop required if there's only one needle character left. - lhz(ch2, 2*2, needle); - lhz(ch1, 2*2, addr); - cmpw(CCR1, ch1, ch2); - bne(CCR1, L_OuterLoop); - } - } - // Return index ... -//46: - bind(L_Found); - subf(addr, haystack, addr); // relative to haystack, ... - srdi(result, addr, 1); // in characters. -//48: - bind(L_End); -} - -// Implementation of Compare for jchar arrays. -// -// Kills the registers str1, str2, cnt1, cnt2. -// Kills cr0, ctr. -// Assumes that result differes from the input registers. -void MacroAssembler::string_compare(Register str1_reg, Register str2_reg, Register cnt1_reg, Register cnt2_reg, - Register result_reg, Register tmp_reg) { - assert_different_registers(result_reg, str1_reg, str2_reg, cnt1_reg, cnt2_reg, tmp_reg); - - Label Ldone, Lslow_case, Lslow_loop, Lfast_loop; - Register cnt_diff = R0, - limit_reg = cnt1_reg, - chr1_reg = result_reg, - chr2_reg = cnt2_reg, - addr_diff = str2_reg; - - // 'cnt_reg' contains the number of characters in the string's character array for the - // pre-CompactStrings strings implementation and the number of bytes in the string's - // byte array for the CompactStrings strings implementation. - const int HAS_COMPACT_STRING = java_lang_String::has_coder_field() ? 1 : 0; // '1' = byte array, '0' = char array - - // Offset 0 should be 32 byte aligned. -//-6: - srawi(cnt1_reg, cnt1_reg, HAS_COMPACT_STRING); - srawi(cnt2_reg, cnt2_reg, HAS_COMPACT_STRING); -//-4: - dcbtct(str1_reg, 0x00); // Indicate R/O access to str1. - dcbtct(str2_reg, 0x00); // Indicate R/O access to str2. -//-2: - // Compute min(cnt1, cnt2) and check if 0 (bail out if we don't need to compare characters). - subf(result_reg, cnt2_reg, cnt1_reg); // difference between cnt1/2 - subf_(addr_diff, str1_reg, str2_reg); // alias? - beq(CCR0, Ldone); // return cnt difference if both ones are identical - srawi(limit_reg, result_reg, 31); // generate signmask (cnt1/2 must be non-negative so cnt_diff can't overflow) - mr(cnt_diff, result_reg); - andr(limit_reg, result_reg, limit_reg); // difference or zero (negative): cnt14 characters for fast loop - andi(limit_reg, tmp_reg, 4-1); // remaining characters - - // Adapt str1_reg str2_reg for the first loop iteration - mtctr(chr2_reg); // (min(cnt1, cnt2)-1)/4 - addi(limit_reg, limit_reg, 4+1); // compare last 5-8 characters in slow_case if mismatch found in fast_loop -//16: - // Compare the rest of the characters - bind(Lfast_loop); - ld(chr1_reg, 0, str1_reg); - ldx(chr2_reg, str1_reg, addr_diff); - cmpd(CCR0, chr2_reg, chr1_reg); - bne(CCR0, Lslow_case); // return chr1_reg - addi(str1_reg, str1_reg, 4*2); - bdnz(Lfast_loop); - addi(limit_reg, limit_reg, -4); // no mismatch found in fast_loop, only 1-4 characters missing -//23: - bind(Lslow_case); - mtctr(limit_reg); -//24: - bind(Lslow_loop); - lhz(chr1_reg, 0, str1_reg); - lhzx(chr2_reg, str1_reg, addr_diff); - subf_(result_reg, chr2_reg, chr1_reg); - bne(CCR0, Ldone); // return chr1_reg - addi(str1_reg, str1_reg, 1*2); - bdnz(Lslow_loop); -//30: - // If strings are equal up to min length, return the length difference. - mr(result_reg, cnt_diff); - nop(); // alignment -//32: - // Otherwise, return the difference between the first mismatched chars. - bind(Ldone); -} - - -// Compare char[] arrays. -// -// str1_reg USE only -// str2_reg USE only -// cnt_reg USE_DEF, due to tmp reg shortage -// result_reg DEF only, might compromise USE only registers -void MacroAssembler::char_arrays_equals(Register str1_reg, Register str2_reg, Register cnt_reg, Register result_reg, - Register tmp1_reg, Register tmp2_reg, Register tmp3_reg, Register tmp4_reg, - Register tmp5_reg) { - - // Str1 may be the same register as str2 which can occur e.g. after scalar replacement. - assert_different_registers(result_reg, str1_reg, cnt_reg, tmp1_reg, tmp2_reg, tmp3_reg, tmp4_reg, tmp5_reg); - assert_different_registers(result_reg, str2_reg, cnt_reg, tmp1_reg, tmp2_reg, tmp3_reg, tmp4_reg, tmp5_reg); - - // Offset 0 should be 32 byte aligned. - Label Linit_cbc, Lcbc, Lloop, Ldone_true, Ldone_false; - Register index_reg = tmp5_reg; - Register cbc_iter = tmp4_reg; - - // 'cnt_reg' contains the number of characters in the string's character array for the - // pre-CompactStrings strings implementation and the number of bytes in the string's - // byte array for the CompactStrings strings implementation. - const int HAS_COMPACT_STRING = java_lang_String::has_coder_field() ? 1 : 0; // '1' = byte array, '0' = char array - -//-1: - dcbtct(str1_reg, 0x00); // Indicate R/O access to str1. - dcbtct(str2_reg, 0x00); // Indicate R/O access to str2. -//1: - // cbc_iter: remaining characters after the '4 java characters per iteration' loop. - rlwinm(cbc_iter, cnt_reg, 32 - HAS_COMPACT_STRING, 30, 31); // (cnt_reg % (HAS_COMPACT_STRING ? 8 : 4)) >> HAS_COMPACT_STRING - li(index_reg, 0); // init - li(result_reg, 0); // assume false - // tmp2_reg: units of 4 java characters (i.e. 8 bytes) per iteration (main loop). - srwi_(tmp2_reg, cnt_reg, exact_log2(4 << HAS_COMPACT_STRING)); // cnt_reg / (HAS_COMPACT_STRING ? 8 : 4) - - cmpwi(CCR1, cbc_iter, 0); // CCR1 = (cbc_iter==0) - beq(CCR0, Linit_cbc); // too short - mtctr(tmp2_reg); -//8: - bind(Lloop); - ldx(tmp1_reg, str1_reg, index_reg); - ldx(tmp2_reg, str2_reg, index_reg); - cmpd(CCR0, tmp1_reg, tmp2_reg); - bne(CCR0, Ldone_false); // Unequal char pair found -> done. - addi(index_reg, index_reg, 4*sizeof(jchar)); - bdnz(Lloop); -//14: - bind(Linit_cbc); - beq(CCR1, Ldone_true); - mtctr(cbc_iter); -//16: - bind(Lcbc); - lhzx(tmp1_reg, str1_reg, index_reg); - lhzx(tmp2_reg, str2_reg, index_reg); - cmpw(CCR0, tmp1_reg, tmp2_reg); - bne(CCR0, Ldone_false); // Unequal char pair found -> done. - addi(index_reg, index_reg, 1*sizeof(jchar)); - bdnz(Lcbc); - nop(); - bind(Ldone_true); - li(result_reg, 1); -//24: - bind(Ldone_false); -} - - -void MacroAssembler::char_arrays_equalsImm(Register str1_reg, Register str2_reg, int cntval, Register result_reg, - Register tmp1_reg, Register tmp2_reg) { - // Str1 may be the same register as str2 which can occur e.g. after scalar replacement. - assert_different_registers(result_reg, str1_reg, tmp1_reg, tmp2_reg); - assert_different_registers(result_reg, str2_reg, tmp1_reg, tmp2_reg); - assert(sizeof(jchar) == 2, "must be"); - assert(cntval >= 0 && ((cntval & 0x7fff) == cntval), "wrong immediate"); - - // 'cntval' contains the number of characters in the string's character array for the - // pre-CompactStrings strings implementation and the number of bytes in the string's - // byte array for the CompactStrings strings implementation. - cntval >>= (java_lang_String::has_coder_field() ? 1 : 0); // '1' = byte array strings, '0' = char array strings - - Label Ldone_false; - - if (cntval < 16) { // short case - if (cntval != 0) li(result_reg, 0); // assume false - - const int num_bytes = cntval*sizeof(jchar); - int index = 0; - for (int next_index; (next_index = index + 8) <= num_bytes; index = next_index) { - ld(tmp1_reg, index, str1_reg); - ld(tmp2_reg, index, str2_reg); - cmpd(CCR0, tmp1_reg, tmp2_reg); - bne(CCR0, Ldone_false); - } - if (cntval & 2) { - lwz(tmp1_reg, index, str1_reg); - lwz(tmp2_reg, index, str2_reg); - cmpw(CCR0, tmp1_reg, tmp2_reg); - bne(CCR0, Ldone_false); - index += 4; - } - if (cntval & 1) { - lhz(tmp1_reg, index, str1_reg); - lhz(tmp2_reg, index, str2_reg); - cmpw(CCR0, tmp1_reg, tmp2_reg); - bne(CCR0, Ldone_false); - } - // fallthrough: true - } else { - Label Lloop; - Register index_reg = tmp1_reg; - const int loopcnt = cntval/4; - assert(loopcnt > 0, "must be"); - // Offset 0 should be 32 byte aligned. - //2: - dcbtct(str1_reg, 0x00); // Indicate R/O access to str1. - dcbtct(str2_reg, 0x00); // Indicate R/O access to str2. - li(tmp2_reg, loopcnt); - li(index_reg, 0); // init - li(result_reg, 0); // assume false - mtctr(tmp2_reg); - //8: - bind(Lloop); - ldx(R0, str1_reg, index_reg); - ldx(tmp2_reg, str2_reg, index_reg); - cmpd(CCR0, R0, tmp2_reg); - bne(CCR0, Ldone_false); // Unequal char pair found -> done. - addi(index_reg, index_reg, 4*sizeof(jchar)); - bdnz(Lloop); - //14: - if (cntval & 2) { - lwzx(R0, str1_reg, index_reg); - lwzx(tmp2_reg, str2_reg, index_reg); - cmpw(CCR0, R0, tmp2_reg); - bne(CCR0, Ldone_false); - if (cntval & 1) addi(index_reg, index_reg, 2*sizeof(jchar)); - } - if (cntval & 1) { - lhzx(R0, str1_reg, index_reg); - lhzx(tmp2_reg, str2_reg, index_reg); - cmpw(CCR0, R0, tmp2_reg); - bne(CCR0, Ldone_false); - } - // fallthru: true - } - li(result_reg, 1); - bind(Ldone_false); -} - #endif // Compiler2 // Helpers for Intrinsic Emitters diff --git a/hotspot/src/cpu/ppc/vm/macroAssembler_ppc.hpp b/hotspot/src/cpu/ppc/vm/macroAssembler_ppc.hpp index 003c27b4333..ed846efb580 100644 --- a/hotspot/src/cpu/ppc/vm/macroAssembler_ppc.hpp +++ b/hotspot/src/cpu/ppc/vm/macroAssembler_ppc.hpp @@ -431,10 +431,81 @@ class MacroAssembler: public Assembler { MemBarAcq = 2, MemBarFenceAfter = 4 // use powers of 2 }; + private: + // Helper functions for word/sub-word atomics. + void atomic_get_and_modify_generic(Register dest_current_value, Register exchange_value, + Register addr_base, Register tmp1, Register tmp2, Register tmp3, + bool cmpxchgx_hint, bool is_add, int size); + void cmpxchg_loop_body(ConditionRegister flag, Register dest_current_value, + Register compare_value, Register exchange_value, + Register addr_base, Register tmp1, Register tmp2, + Label &retry, Label &failed, bool cmpxchgx_hint, int size); + void cmpxchg_generic(ConditionRegister flag, + Register dest_current_value, Register compare_value, Register exchange_value, Register addr_base, + Register tmp1, Register tmp2, + int semantics, bool cmpxchgx_hint, Register int_flag_success, bool contention_hint, bool weak, int size); + public: + // Temps and addr_base are killed if processor does not support Power 8 instructions. + // Result will be sign extended. + void getandsetb(Register dest_current_value, Register exchange_value, Register addr_base, + Register tmp1, Register tmp2, Register tmp3, bool cmpxchgx_hint) { + atomic_get_and_modify_generic(dest_current_value, exchange_value, addr_base, tmp1, tmp2, tmp3, cmpxchgx_hint, false, 1); + } + // Temps and addr_base are killed if processor does not support Power 8 instructions. + // Result will be sign extended. + void getandseth(Register dest_current_value, Register exchange_value, Register addr_base, + Register tmp1, Register tmp2, Register tmp3, bool cmpxchgx_hint) { + atomic_get_and_modify_generic(dest_current_value, exchange_value, addr_base, tmp1, tmp2, tmp3, cmpxchgx_hint, false, 2); + } + void getandsetw(Register dest_current_value, Register exchange_value, Register addr_base, + bool cmpxchgx_hint) { + atomic_get_and_modify_generic(dest_current_value, exchange_value, addr_base, noreg, noreg, noreg, cmpxchgx_hint, false, 4); + } + void getandsetd(Register dest_current_value, Register exchange_value, Register addr_base, + bool cmpxchgx_hint); + // tmp2/3 and addr_base are killed if processor does not support Power 8 instructions (tmp1 is always needed). + // Result will be sign extended. + void getandaddb(Register dest_current_value, Register inc_value, Register addr_base, + Register tmp1, Register tmp2, Register tmp3, bool cmpxchgx_hint) { + atomic_get_and_modify_generic(dest_current_value, inc_value, addr_base, tmp1, tmp2, tmp3, cmpxchgx_hint, true, 1); + } + // tmp2/3 and addr_base are killed if processor does not support Power 8 instructions (tmp1 is always needed). + // Result will be sign extended. + void getandaddh(Register dest_current_value, Register inc_value, Register addr_base, + Register tmp1, Register tmp2, Register tmp3, bool cmpxchgx_hint) { + atomic_get_and_modify_generic(dest_current_value, inc_value, addr_base, tmp1, tmp2, tmp3, cmpxchgx_hint, true, 2); + } + void getandaddw(Register dest_current_value, Register inc_value, Register addr_base, + Register tmp1, bool cmpxchgx_hint) { + atomic_get_and_modify_generic(dest_current_value, inc_value, addr_base, tmp1, noreg, noreg, cmpxchgx_hint, true, 4); + } + void getandaddd(Register dest_current_value, Register exchange_value, Register addr_base, + Register tmp, bool cmpxchgx_hint); + // Temps, addr_base and exchange_value are killed if processor does not support Power 8 instructions. + // compare_value must be at least 32 bit sign extended. Result will be sign extended. + void cmpxchgb(ConditionRegister flag, + Register dest_current_value, Register compare_value, Register exchange_value, Register addr_base, + Register tmp1, Register tmp2, int semantics, bool cmpxchgx_hint = false, + Register int_flag_success = noreg, bool contention_hint = false, bool weak = false) { + cmpxchg_generic(flag, dest_current_value, compare_value, exchange_value, addr_base, tmp1, tmp2, + semantics, cmpxchgx_hint, int_flag_success, contention_hint, weak, 1); + } + // Temps, addr_base and exchange_value are killed if processor does not support Power 8 instructions. + // compare_value must be at least 32 bit sign extended. Result will be sign extended. + void cmpxchgh(ConditionRegister flag, + Register dest_current_value, Register compare_value, Register exchange_value, Register addr_base, + Register tmp1, Register tmp2, int semantics, bool cmpxchgx_hint = false, + Register int_flag_success = noreg, bool contention_hint = false, bool weak = false) { + cmpxchg_generic(flag, dest_current_value, compare_value, exchange_value, addr_base, tmp1, tmp2, + semantics, cmpxchgx_hint, int_flag_success, contention_hint, weak, 2); + } void cmpxchgw(ConditionRegister flag, Register dest_current_value, Register compare_value, Register exchange_value, Register addr_base, int semantics, bool cmpxchgx_hint = false, - Register int_flag_success = noreg, bool contention_hint = false, bool weak = false); + Register int_flag_success = noreg, bool contention_hint = false, bool weak = false) { + cmpxchg_generic(flag, dest_current_value, compare_value, exchange_value, addr_base, noreg, noreg, + semantics, cmpxchgx_hint, int_flag_success, contention_hint, weak, 4); + } void cmpxchgd(ConditionRegister flag, Register dest_current_value, RegisterOrConstant compare_value, Register exchange_value, Register addr_base, int semantics, bool cmpxchgx_hint = false, @@ -717,23 +788,6 @@ class MacroAssembler: public Assembler { Register needle, jchar needleChar, Register tmp1, Register tmp2, bool is_byte); void has_negatives(Register src, Register cnt, Register result, Register tmp1, Register tmp2); - - // Intrinsics for non-CompactStrings - // Needle of length 1. - void string_indexof_1(Register result, Register haystack, Register haycnt, - Register needle, jchar needleChar, - Register tmp1, Register tmp2); - // General indexof, eventually with constant needle length. - void string_indexof(Register result, Register haystack, Register haycnt, - Register needle, ciTypeArray* needle_values, Register needlecnt, int needlecntval, - Register tmp1, Register tmp2, Register tmp3, Register tmp4); - void string_compare(Register str1_reg, Register str2_reg, Register cnt1_reg, Register cnt2_reg, - Register result_reg, Register tmp_reg); - void char_arrays_equals(Register str1_reg, Register str2_reg, Register cnt_reg, Register result_reg, - Register tmp1_reg, Register tmp2_reg, Register tmp3_reg, Register tmp4_reg, - Register tmp5_reg); - void char_arrays_equalsImm(Register str1_reg, Register str2_reg, int cntval, Register result_reg, - Register tmp1_reg, Register tmp2_reg); #endif // Emitters for BigInteger.multiplyToLen intrinsic. diff --git a/hotspot/src/cpu/ppc/vm/ppc.ad b/hotspot/src/cpu/ppc/vm/ppc.ad index a62eef493b4..2f4939fb9b9 100644 --- a/hotspot/src/cpu/ppc/vm/ppc.ad +++ b/hotspot/src/cpu/ppc/vm/ppc.ad @@ -965,41 +965,9 @@ static int cc_to_biint(int cc, int flags_reg) { // is the number of bytes (not instructions) which will be inserted before // the instruction. The padding must match the size of a NOP instruction. -int string_indexOf_imm1_charNode::compute_padding(int current_offset) const { - return (3*4-current_offset)&31; // see MacroAssembler::string_indexof_1 -} - -int string_indexOf_imm1Node::compute_padding(int current_offset) const { - return (3*4-current_offset)&31; // see MacroAssembler::string_indexof_1 -} - -int string_indexOfCharNode::compute_padding(int current_offset) const { - return (3*4-current_offset)&31; // see MacroAssembler::string_indexof_1 -} - -int string_indexOf_immNode::compute_padding(int current_offset) const { - return (3*4-current_offset)&31; // see MacroAssembler::string_indexof(constant needlecount) -} - -int string_indexOfNode::compute_padding(int current_offset) const { - return (1*4-current_offset)&31; // see MacroAssembler::string_indexof(variable needlecount) -} - -int string_compareNode::compute_padding(int current_offset) const { - return (2*4-current_offset)&31; // see MacroAssembler::string_compare -} - -int string_equals_immNode::compute_padding(int current_offset) const { - if (opnd_array(3)->constant() < 16) return 0; // For strlen < 16 no nops because loop completely unrolled - return (2*4-current_offset)&31; // Genral case - see MacroAssembler::char_arrays_equalsImm -} - -int string_equalsNode::compute_padding(int current_offset) const { - return (7*4-current_offset)&31; // see MacroAssembler::char_arrays_equals -} - int inlineCallClearArrayNode::compute_padding(int current_offset) const { - return (2*4-current_offset)&31; // see MacroAssembler::clear_memory_doubleword + int desired_padding = (2*4-current_offset)&31; // see MacroAssembler::clear_memory_doubleword + return (desired_padding <= 3*4) ? desired_padding : 0; } //============================================================================= @@ -3064,121 +3032,6 @@ encode %{ __ bind(done); %} - // New atomics. - enc_class enc_GetAndAddI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src) %{ - // TODO: PPC port $archOpcode(ppc64Opcode_compound); - - MacroAssembler _masm(&cbuf); - Register Rtmp = R0; - Register Rres = $res$$Register; - Register Rsrc = $src$$Register; - Register Rptr = $mem_ptr$$Register; - bool RegCollision = (Rres == Rsrc) || (Rres == Rptr); - Register Rold = RegCollision ? Rtmp : Rres; - - Label Lretry; - __ bind(Lretry); - __ lwarx(Rold, Rptr, MacroAssembler::cmpxchgx_hint_atomic_update()); - __ add(Rtmp, Rsrc, Rold); - __ stwcx_(Rtmp, Rptr); - if (UseStaticBranchPredictionInCompareAndSwapPPC64) { - __ bne_predict_not_taken(CCR0, Lretry); - } else { - __ bne( CCR0, Lretry); - } - if (RegCollision) __ subf(Rres, Rsrc, Rtmp); - if (support_IRIW_for_not_multiple_copy_atomic_cpu) { - __ isync(); - } else { - __ sync(); - } - %} - - enc_class enc_GetAndAddL(iRegLdst res, iRegPdst mem_ptr, iRegLsrc src) %{ - // TODO: PPC port $archOpcode(ppc64Opcode_compound); - - MacroAssembler _masm(&cbuf); - Register Rtmp = R0; - Register Rres = $res$$Register; - Register Rsrc = $src$$Register; - Register Rptr = $mem_ptr$$Register; - bool RegCollision = (Rres == Rsrc) || (Rres == Rptr); - Register Rold = RegCollision ? Rtmp : Rres; - - Label Lretry; - __ bind(Lretry); - __ ldarx(Rold, Rptr, MacroAssembler::cmpxchgx_hint_atomic_update()); - __ add(Rtmp, Rsrc, Rold); - __ stdcx_(Rtmp, Rptr); - if (UseStaticBranchPredictionInCompareAndSwapPPC64) { - __ bne_predict_not_taken(CCR0, Lretry); - } else { - __ bne( CCR0, Lretry); - } - if (RegCollision) __ subf(Rres, Rsrc, Rtmp); - if (support_IRIW_for_not_multiple_copy_atomic_cpu) { - __ isync(); - } else { - __ sync(); - } - %} - - enc_class enc_GetAndSetI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src) %{ - // TODO: PPC port $archOpcode(ppc64Opcode_compound); - - MacroAssembler _masm(&cbuf); - Register Rtmp = R0; - Register Rres = $res$$Register; - Register Rsrc = $src$$Register; - Register Rptr = $mem_ptr$$Register; - bool RegCollision = (Rres == Rsrc) || (Rres == Rptr); - Register Rold = RegCollision ? Rtmp : Rres; - - Label Lretry; - __ bind(Lretry); - __ lwarx(Rold, Rptr, MacroAssembler::cmpxchgx_hint_atomic_update()); - __ stwcx_(Rsrc, Rptr); - if (UseStaticBranchPredictionInCompareAndSwapPPC64) { - __ bne_predict_not_taken(CCR0, Lretry); - } else { - __ bne( CCR0, Lretry); - } - if (RegCollision) __ mr(Rres, Rtmp); - if (support_IRIW_for_not_multiple_copy_atomic_cpu) { - __ isync(); - } else { - __ sync(); - } - %} - - enc_class enc_GetAndSetL(iRegLdst res, iRegPdst mem_ptr, iRegLsrc src) %{ - // TODO: PPC port $archOpcode(ppc64Opcode_compound); - - MacroAssembler _masm(&cbuf); - Register Rtmp = R0; - Register Rres = $res$$Register; - Register Rsrc = $src$$Register; - Register Rptr = $mem_ptr$$Register; - bool RegCollision = (Rres == Rsrc) || (Rres == Rptr); - Register Rold = RegCollision ? Rtmp : Rres; - - Label Lretry; - __ bind(Lretry); - __ ldarx(Rold, Rptr, MacroAssembler::cmpxchgx_hint_atomic_update()); - __ stdcx_(Rsrc, Rptr); - if (UseStaticBranchPredictionInCompareAndSwapPPC64) { - __ bne_predict_not_taken(CCR0, Lretry); - } else { - __ bne( CCR0, Lretry); - } - if (RegCollision) __ mr(Rres, Rtmp); - if (support_IRIW_for_not_multiple_copy_atomic_cpu) { - __ isync(); - } else { - __ sync(); - } - %} - // This enc_class is needed so that scheduler gets proper // input mapping for latency computation. enc_class enc_andc(iRegIdst dst, iRegIsrc src1, iRegIsrc src2) %{ @@ -5416,7 +5269,7 @@ instruct loadUI2L(iRegLdst dst, memory mem, immL_32bits mask) %{ %} // Match loading integer and casting it to long. -instruct loadI2L(iRegLdst dst, memory mem) %{ +instruct loadI2L(iRegLdst dst, memoryAlg4 mem) %{ match(Set dst (ConvI2L (LoadI mem))); predicate(_kids[0]->_leaf->as_Load()->is_unordered()); ins_cost(MEMORY_REF_COST); @@ -5432,7 +5285,7 @@ instruct loadI2L(iRegLdst dst, memory mem) %{ %} // Match loading integer and casting it to long - acquire. -instruct loadI2L_ac(iRegLdst dst, memory mem) %{ +instruct loadI2L_ac(iRegLdst dst, memoryAlg4 mem) %{ match(Set dst (ConvI2L (LoadI mem))); ins_cost(3*MEMORY_REF_COST); @@ -7575,11 +7428,90 @@ instruct loadPLocked(iRegPdst dst, memory mem) %{ // Strong versions: +instruct compareAndSwapB_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src1, iRegIsrc src2, flagsRegCR0 cr0) %{ + match(Set res (CompareAndSwapB mem_ptr (Binary src1 src2))); + predicate(VM_Version::has_lqarx()); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump + format %{ "CMPXCHGB $res, $mem_ptr, $src1, $src2; as bool" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgb(CCR0, R0, $src1$$Register, $src2$$Register, $mem_ptr$$Register, noreg, noreg, + MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), + $res$$Register, true); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + +instruct compareAndSwapB4_regP_regI_regI(iRegIdst res, rarg3RegP mem_ptr, iRegIsrc src1, rarg4RegI src2, iRegIdst tmp1, iRegIdst tmp2, flagsRegCR0 cr0) %{ + match(Set res (CompareAndSwapB mem_ptr (Binary src1 src2))); + predicate(!VM_Version::has_lqarx()); + effect(TEMP_DEF res, USE_KILL src2, USE_KILL mem_ptr, TEMP tmp1, TEMP tmp2, TEMP cr0); // TEMP_DEF to avoid jump + format %{ "CMPXCHGB $res, $mem_ptr, $src1, $src2; as bool" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgb(CCR0, R0, $src1$$Register, $src2$$Register, $mem_ptr$$Register, $tmp1$$Register, $tmp2$$Register, + MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), + $res$$Register, true); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + +instruct compareAndSwapS_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src1, iRegIsrc src2, flagsRegCR0 cr0) %{ + match(Set res (CompareAndSwapS mem_ptr (Binary src1 src2))); + predicate(VM_Version::has_lqarx()); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump + format %{ "CMPXCHGH $res, $mem_ptr, $src1, $src2; as bool" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgh(CCR0, R0, $src1$$Register, $src2$$Register, $mem_ptr$$Register, noreg, noreg, + MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), + $res$$Register, true); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + +instruct compareAndSwapS4_regP_regI_regI(iRegIdst res, rarg3RegP mem_ptr, iRegIsrc src1, rarg4RegI src2, iRegIdst tmp1, iRegIdst tmp2, flagsRegCR0 cr0) %{ + match(Set res (CompareAndSwapS mem_ptr (Binary src1 src2))); + predicate(!VM_Version::has_lqarx()); + effect(TEMP_DEF res, USE_KILL src2, USE_KILL mem_ptr, TEMP tmp1, TEMP tmp2, TEMP cr0); // TEMP_DEF to avoid jump + format %{ "CMPXCHGH $res, $mem_ptr, $src1, $src2; as bool" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgh(CCR0, R0, $src1$$Register, $src2$$Register, $mem_ptr$$Register, $tmp1$$Register, $tmp2$$Register, + MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), + $res$$Register, true); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + instruct compareAndSwapI_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src1, iRegIsrc src2, flagsRegCR0 cr0) %{ match(Set res (CompareAndSwapI mem_ptr (Binary src1 src2))); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump format %{ "CMPXCHGW $res, $mem_ptr, $src1, $src2; as bool" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7597,9 +7529,8 @@ instruct compareAndSwapI_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc instruct compareAndSwapN_regP_regN_regN(iRegIdst res, iRegPdst mem_ptr, iRegNsrc src1, iRegNsrc src2, flagsRegCR0 cr0) %{ match(Set res (CompareAndSwapN mem_ptr (Binary src1 src2))); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump format %{ "CMPXCHGW $res, $mem_ptr, $src1, $src2; as bool" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7617,9 +7548,8 @@ instruct compareAndSwapN_regP_regN_regN(iRegIdst res, iRegPdst mem_ptr, iRegNsrc instruct compareAndSwapL_regP_regL_regL(iRegIdst res, iRegPdst mem_ptr, iRegLsrc src1, iRegLsrc src2, flagsRegCR0 cr0) %{ match(Set res (CompareAndSwapL mem_ptr (Binary src1 src2))); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump format %{ "CMPXCHGD $res, $mem_ptr, $src1, $src2; as bool" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7637,9 +7567,8 @@ instruct compareAndSwapL_regP_regL_regL(iRegIdst res, iRegPdst mem_ptr, iRegLsrc instruct compareAndSwapP_regP_regP_regP(iRegIdst res, iRegPdst mem_ptr, iRegPsrc src1, iRegPsrc src2, flagsRegCR0 cr0) %{ match(Set res (CompareAndSwapP mem_ptr (Binary src1 src2))); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump format %{ "CMPXCHGD $res, $mem_ptr, $src1, $src2; as bool; ptr" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7657,12 +7586,131 @@ instruct compareAndSwapP_regP_regP_regP(iRegIdst res, iRegPdst mem_ptr, iRegPsrc // Weak versions: +instruct weakCompareAndSwapB_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src1, iRegIsrc src2, flagsRegCR0 cr0) %{ + match(Set res (WeakCompareAndSwapB mem_ptr (Binary src1 src2))); + predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst && VM_Version::has_lqarx()); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump + format %{ "weak CMPXCHGB $res, $mem_ptr, $src1, $src2; as bool" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgb(CCR0, R0, $src1$$Register, $src2$$Register, $mem_ptr$$Register, noreg, noreg, + MacroAssembler::MemBarNone, + MacroAssembler::cmpxchgx_hint_atomic_update(), $res$$Register, true, /*weak*/ true); + %} + ins_pipe(pipe_class_default); +%} + +instruct weakCompareAndSwapB4_regP_regI_regI(iRegIdst res, rarg3RegP mem_ptr, iRegIsrc src1, rarg4RegI src2, iRegIdst tmp1, iRegIdst tmp2, flagsRegCR0 cr0) %{ + match(Set res (WeakCompareAndSwapB mem_ptr (Binary src1 src2))); + predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst && !VM_Version::has_lqarx()); + effect(TEMP_DEF res, USE_KILL src2, USE_KILL mem_ptr, TEMP tmp1, TEMP tmp2, TEMP cr0); // TEMP_DEF to avoid jump + format %{ "weak CMPXCHGB $res, $mem_ptr, $src1, $src2; as bool" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgb(CCR0, R0, $src1$$Register, $src2$$Register, $mem_ptr$$Register, $tmp1$$Register, $tmp2$$Register, + MacroAssembler::MemBarNone, + MacroAssembler::cmpxchgx_hint_atomic_update(), $res$$Register, true, /*weak*/ true); + %} + ins_pipe(pipe_class_default); +%} + +instruct weakCompareAndSwapB_acq_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src1, iRegIsrc src2, flagsRegCR0 cr0) %{ + match(Set res (WeakCompareAndSwapB mem_ptr (Binary src1 src2))); + predicate((((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst) && VM_Version::has_lqarx()); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump + format %{ "weak CMPXCHGB acq $res, $mem_ptr, $src1, $src2; as bool" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgb(CCR0, R0, $src1$$Register, $src2$$Register, $mem_ptr$$Register, noreg, noreg, + support_IRIW_for_not_multiple_copy_atomic_cpu ? MacroAssembler::MemBarAcq : MacroAssembler::MemBarFenceAfter, + MacroAssembler::cmpxchgx_hint_atomic_update(), $res$$Register, true, /*weak*/ true); + %} + ins_pipe(pipe_class_default); +%} + +instruct weakCompareAndSwapB4_acq_regP_regI_regI(iRegIdst res, rarg3RegP mem_ptr, iRegIsrc src1, rarg4RegI src2, iRegIdst tmp1, iRegIdst tmp2, flagsRegCR0 cr0) %{ + match(Set res (WeakCompareAndSwapB mem_ptr (Binary src1 src2))); + predicate((((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst) && !VM_Version::has_lqarx()); + effect(TEMP_DEF res, USE_KILL src2, USE_KILL mem_ptr, TEMP tmp1, TEMP tmp2, TEMP cr0); // TEMP_DEF to avoid jump + format %{ "weak CMPXCHGB acq $res, $mem_ptr, $src1, $src2; as bool" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgb(CCR0, R0, $src1$$Register, $src2$$Register, $mem_ptr$$Register, $tmp1$$Register, $tmp2$$Register, + support_IRIW_for_not_multiple_copy_atomic_cpu ? MacroAssembler::MemBarAcq : MacroAssembler::MemBarFenceAfter, + MacroAssembler::cmpxchgx_hint_atomic_update(), $res$$Register, true, /*weak*/ true); + %} + ins_pipe(pipe_class_default); +%} + +instruct weakCompareAndSwapS_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src1, iRegIsrc src2, flagsRegCR0 cr0) %{ + match(Set res (WeakCompareAndSwapS mem_ptr (Binary src1 src2))); + predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst && VM_Version::has_lqarx()); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump + format %{ "weak CMPXCHGH $res, $mem_ptr, $src1, $src2; as bool" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgh(CCR0, R0, $src1$$Register, $src2$$Register, $mem_ptr$$Register, noreg, noreg, + MacroAssembler::MemBarNone, + MacroAssembler::cmpxchgx_hint_atomic_update(), $res$$Register, true, /*weak*/ true); + %} + ins_pipe(pipe_class_default); +%} + +instruct weakCompareAndSwapS4_regP_regI_regI(iRegIdst res, rarg3RegP mem_ptr, iRegIsrc src1, rarg4RegI src2, iRegIdst tmp1, iRegIdst tmp2, flagsRegCR0 cr0) %{ + match(Set res (WeakCompareAndSwapS mem_ptr (Binary src1 src2))); + predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst && !VM_Version::has_lqarx()); + effect(TEMP_DEF res, USE_KILL src2, USE_KILL mem_ptr, TEMP tmp1, TEMP tmp2, TEMP cr0); // TEMP_DEF to avoid jump + format %{ "weak CMPXCHGH $res, $mem_ptr, $src1, $src2; as bool" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgh(CCR0, R0, $src1$$Register, $src2$$Register, $mem_ptr$$Register, $tmp1$$Register, $tmp2$$Register, + MacroAssembler::MemBarNone, + MacroAssembler::cmpxchgx_hint_atomic_update(), $res$$Register, true, /*weak*/ true); + %} + ins_pipe(pipe_class_default); +%} + +instruct weakCompareAndSwapS_acq_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src1, iRegIsrc src2, flagsRegCR0 cr0) %{ + match(Set res (WeakCompareAndSwapS mem_ptr (Binary src1 src2))); + predicate((((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst) && VM_Version::has_lqarx()); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump + format %{ "weak CMPXCHGH acq $res, $mem_ptr, $src1, $src2; as bool" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgh(CCR0, R0, $src1$$Register, $src2$$Register, $mem_ptr$$Register, noreg, noreg, + support_IRIW_for_not_multiple_copy_atomic_cpu ? MacroAssembler::MemBarAcq : MacroAssembler::MemBarFenceAfter, + MacroAssembler::cmpxchgx_hint_atomic_update(), $res$$Register, true, /*weak*/ true); + %} + ins_pipe(pipe_class_default); +%} + +instruct weakCompareAndSwapS4_acq_regP_regI_regI(iRegIdst res, rarg3RegP mem_ptr, iRegIsrc src1, rarg4RegI src2, iRegIdst tmp1, iRegIdst tmp2, flagsRegCR0 cr0) %{ + match(Set res (WeakCompareAndSwapS mem_ptr (Binary src1 src2))); + predicate((((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst) && !VM_Version::has_lqarx()); + effect(TEMP_DEF res, USE_KILL src2, USE_KILL mem_ptr, TEMP tmp1, TEMP tmp2, TEMP cr0); // TEMP_DEF to avoid jump + format %{ "weak CMPXCHGH acq $res, $mem_ptr, $src1, $src2; as bool" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgh(CCR0, R0, $src1$$Register, $src2$$Register, $mem_ptr$$Register, $tmp1$$Register, $tmp2$$Register, + support_IRIW_for_not_multiple_copy_atomic_cpu ? MacroAssembler::MemBarAcq : MacroAssembler::MemBarFenceAfter, + MacroAssembler::cmpxchgx_hint_atomic_update(), $res$$Register, true, /*weak*/ true); + %} + ins_pipe(pipe_class_default); +%} + instruct weakCompareAndSwapI_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src1, iRegIsrc src2, flagsRegCR0 cr0) %{ match(Set res (WeakCompareAndSwapI mem_ptr (Binary src1 src2))); predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump format %{ "weak CMPXCHGW $res, $mem_ptr, $src1, $src2; as bool" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7676,9 +7724,8 @@ instruct weakCompareAndSwapI_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iReg instruct weakCompareAndSwapI_acq_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src1, iRegIsrc src2, flagsRegCR0 cr0) %{ match(Set res (WeakCompareAndSwapI mem_ptr (Binary src1 src2))); predicate(((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump format %{ "weak CMPXCHGW acq $res, $mem_ptr, $src1, $src2; as bool" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7694,9 +7741,8 @@ instruct weakCompareAndSwapI_acq_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, instruct weakCompareAndSwapN_regP_regN_regN(iRegIdst res, iRegPdst mem_ptr, iRegNsrc src1, iRegNsrc src2, flagsRegCR0 cr0) %{ match(Set res (WeakCompareAndSwapN mem_ptr (Binary src1 src2))); predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump format %{ "weak CMPXCHGW $res, $mem_ptr, $src1, $src2; as bool" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7710,9 +7756,8 @@ instruct weakCompareAndSwapN_regP_regN_regN(iRegIdst res, iRegPdst mem_ptr, iReg instruct weakCompareAndSwapN_acq_regP_regN_regN(iRegIdst res, iRegPdst mem_ptr, iRegNsrc src1, iRegNsrc src2, flagsRegCR0 cr0) %{ match(Set res (WeakCompareAndSwapN mem_ptr (Binary src1 src2))); predicate(((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump format %{ "weak CMPXCHGW acq $res, $mem_ptr, $src1, $src2; as bool" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7728,9 +7773,8 @@ instruct weakCompareAndSwapN_acq_regP_regN_regN(iRegIdst res, iRegPdst mem_ptr, instruct weakCompareAndSwapL_regP_regL_regL(iRegIdst res, iRegPdst mem_ptr, iRegLsrc src1, iRegLsrc src2, flagsRegCR0 cr0) %{ match(Set res (WeakCompareAndSwapL mem_ptr (Binary src1 src2))); predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump format %{ "weak CMPXCHGD $res, $mem_ptr, $src1, $src2; as bool" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7745,9 +7789,8 @@ instruct weakCompareAndSwapL_regP_regL_regL(iRegIdst res, iRegPdst mem_ptr, iReg instruct weakCompareAndSwapL_acq_regP_regL_regL(iRegIdst res, iRegPdst mem_ptr, iRegLsrc src1, iRegLsrc src2, flagsRegCR0 cr0) %{ match(Set res (WeakCompareAndSwapL mem_ptr (Binary src1 src2))); predicate(((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump format %{ "weak CMPXCHGD acq $res, $mem_ptr, $src1, $src2; as bool" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7763,9 +7806,8 @@ instruct weakCompareAndSwapL_acq_regP_regL_regL(iRegIdst res, iRegPdst mem_ptr, instruct weakCompareAndSwapP_regP_regP_regP(iRegIdst res, iRegPdst mem_ptr, iRegPsrc src1, iRegPsrc src2, flagsRegCR0 cr0) %{ match(Set res (WeakCompareAndSwapP mem_ptr (Binary src1 src2))); predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump format %{ "weak CMPXCHGD $res, $mem_ptr, $src1, $src2; as bool; ptr" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7779,9 +7821,8 @@ instruct weakCompareAndSwapP_regP_regP_regP(iRegIdst res, iRegPdst mem_ptr, iReg instruct weakCompareAndSwapP_acq_regP_regP_regP(iRegIdst res, iRegPdst mem_ptr, iRegPsrc src1, iRegPsrc src2, flagsRegCR0 cr0) %{ match(Set res (WeakCompareAndSwapP mem_ptr (Binary src1 src2))); predicate(((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); // TEMP_DEF to avoid jump format %{ "weak CMPXCHGD acq $res, $mem_ptr, $src1, $src2; as bool; ptr" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7796,12 +7837,155 @@ instruct weakCompareAndSwapP_acq_regP_regP_regP(iRegIdst res, iRegPdst mem_ptr, // CompareAndExchange +instruct compareAndExchangeB_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src1, iRegIsrc src2, flagsRegCR0 cr0) %{ + match(Set res (CompareAndExchangeB mem_ptr (Binary src1 src2))); + predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst && VM_Version::has_lqarx()); + effect(TEMP_DEF res, TEMP cr0); + format %{ "CMPXCHGB $res, $mem_ptr, $src1, $src2; as int" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgb(CCR0, $res$$Register, $src1$$Register, $src2$$Register, $mem_ptr$$Register, noreg, noreg, + MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), + noreg, true); + %} + ins_pipe(pipe_class_default); +%} + +instruct compareAndExchangeB4_regP_regI_regI(iRegIdst res, rarg3RegP mem_ptr, iRegIsrc src1, rarg4RegI src2, iRegIdst tmp1, flagsRegCR0 cr0) %{ + match(Set res (CompareAndExchangeB mem_ptr (Binary src1 src2))); + predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst && !VM_Version::has_lqarx()); + effect(TEMP_DEF res, USE_KILL src2, USE_KILL mem_ptr, TEMP tmp1, TEMP cr0); + format %{ "CMPXCHGB $res, $mem_ptr, $src1, $src2; as int" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgb(CCR0, $res$$Register, $src1$$Register, $src2$$Register, $mem_ptr$$Register, $tmp1$$Register, R0, + MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), + noreg, true); + %} + ins_pipe(pipe_class_default); +%} + +instruct compareAndExchangeB_acq_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src1, iRegIsrc src2, flagsRegCR0 cr0) %{ + match(Set res (CompareAndExchangeB mem_ptr (Binary src1 src2))); + predicate((((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst) && VM_Version::has_lqarx()); + effect(TEMP_DEF res, TEMP cr0); + format %{ "CMPXCHGB acq $res, $mem_ptr, $src1, $src2; as int" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgb(CCR0, $res$$Register, $src1$$Register, $src2$$Register, $mem_ptr$$Register, noreg, noreg, + MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), + noreg, true); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + // isync would be sufficient in case of CompareAndExchangeAcquire, but we currently don't optimize for that. + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + +instruct compareAndExchangeB4_acq_regP_regI_regI(iRegIdst res, rarg3RegP mem_ptr, iRegIsrc src1, rarg4RegI src2, iRegIdst tmp1, flagsRegCR0 cr0) %{ + match(Set res (CompareAndExchangeB mem_ptr (Binary src1 src2))); + predicate((((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst) && !VM_Version::has_lqarx()); + effect(TEMP_DEF res, USE_KILL src2, USE_KILL mem_ptr, TEMP tmp1, TEMP cr0); + format %{ "CMPXCHGB acq $res, $mem_ptr, $src1, $src2; as int" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgb(CCR0, $res$$Register, $src1$$Register, $src2$$Register, $mem_ptr$$Register, $tmp1$$Register, R0, + MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), + noreg, true); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + // isync would be sufficient in case of CompareAndExchangeAcquire, but we currently don't optimize for that. + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + +instruct compareAndExchangeS_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src1, iRegIsrc src2, flagsRegCR0 cr0) %{ + match(Set res (CompareAndExchangeS mem_ptr (Binary src1 src2))); + predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst && VM_Version::has_lqarx()); + effect(TEMP_DEF res, TEMP cr0); + format %{ "CMPXCHGH $res, $mem_ptr, $src1, $src2; as int" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgh(CCR0, $res$$Register, $src1$$Register, $src2$$Register, $mem_ptr$$Register, noreg, noreg, + MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), + noreg, true); + %} + ins_pipe(pipe_class_default); +%} + +instruct compareAndExchangeS4_regP_regI_regI(iRegIdst res, rarg3RegP mem_ptr, iRegIsrc src1, rarg4RegI src2, iRegIdst tmp1, flagsRegCR0 cr0) %{ + match(Set res (CompareAndExchangeS mem_ptr (Binary src1 src2))); + predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst && !VM_Version::has_lqarx()); + effect(TEMP_DEF res, USE_KILL src2, USE_KILL mem_ptr, TEMP tmp1, TEMP cr0); + format %{ "CMPXCHGH $res, $mem_ptr, $src1, $src2; as int" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgh(CCR0, $res$$Register, $src1$$Register, $src2$$Register, $mem_ptr$$Register, $tmp1$$Register, R0, + MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), + noreg, true); + %} + ins_pipe(pipe_class_default); +%} + +instruct compareAndExchangeS_acq_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src1, iRegIsrc src2, flagsRegCR0 cr0) %{ + match(Set res (CompareAndExchangeS mem_ptr (Binary src1 src2))); + predicate((((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst) && VM_Version::has_lqarx()); + effect(TEMP_DEF res, TEMP cr0); + format %{ "CMPXCHGH acq $res, $mem_ptr, $src1, $src2; as int" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgh(CCR0, $res$$Register, $src1$$Register, $src2$$Register, $mem_ptr$$Register, noreg, noreg, + MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), + noreg, true); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + // isync would be sufficient in case of CompareAndExchangeAcquire, but we currently don't optimize for that. + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + +instruct compareAndExchangeS4_acq_regP_regI_regI(iRegIdst res, rarg3RegP mem_ptr, iRegIsrc src1, rarg4RegI src2, iRegIdst tmp1, flagsRegCR0 cr0) %{ + match(Set res (CompareAndExchangeS mem_ptr (Binary src1 src2))); + predicate((((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst) && !VM_Version::has_lqarx()); + effect(TEMP_DEF res, USE_KILL src2, USE_KILL mem_ptr, TEMP tmp1, TEMP cr0); + format %{ "CMPXCHGH acq $res, $mem_ptr, $src1, $src2; as int" %} + ins_encode %{ + // TODO: PPC port $archOpcode(ppc64Opcode_compound); + // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. + __ cmpxchgh(CCR0, $res$$Register, $src1$$Register, $src2$$Register, $mem_ptr$$Register, $tmp1$$Register, R0, + MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), + noreg, true); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + // isync would be sufficient in case of CompareAndExchangeAcquire, but we currently don't optimize for that. + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + instruct compareAndExchangeI_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src1, iRegIsrc src2, flagsRegCR0 cr0) %{ match(Set res (CompareAndExchangeI mem_ptr (Binary src1 src2))); predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst); effect(TEMP_DEF res, TEMP cr0); format %{ "CMPXCHGW $res, $mem_ptr, $src1, $src2; as int" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7817,7 +8001,6 @@ instruct compareAndExchangeI_acq_regP_regI_regI(iRegIdst res, iRegPdst mem_ptr, predicate(((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst); effect(TEMP_DEF res, TEMP cr0); format %{ "CMPXCHGW acq $res, $mem_ptr, $src1, $src2; as int" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7839,7 +8022,6 @@ instruct compareAndExchangeN_regP_regN_regN(iRegNdst res, iRegPdst mem_ptr, iReg predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst); effect(TEMP_DEF res, TEMP cr0); format %{ "CMPXCHGW $res, $mem_ptr, $src1, $src2; as narrow oop" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7855,7 +8037,6 @@ instruct compareAndExchangeN_acq_regP_regN_regN(iRegNdst res, iRegPdst mem_ptr, predicate(((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst); effect(TEMP_DEF res, TEMP cr0); format %{ "CMPXCHGW acq $res, $mem_ptr, $src1, $src2; as narrow oop" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7877,7 +8058,6 @@ instruct compareAndExchangeL_regP_regL_regL(iRegLdst res, iRegPdst mem_ptr, iReg predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst); effect(TEMP_DEF res, TEMP cr0); format %{ "CMPXCHGD $res, $mem_ptr, $src1, $src2; as long" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7893,7 +8073,6 @@ instruct compareAndExchangeL_acq_regP_regL_regL(iRegLdst res, iRegPdst mem_ptr, predicate(((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst); effect(TEMP_DEF res, TEMP cr0); format %{ "CMPXCHGD acq $res, $mem_ptr, $src1, $src2; as long" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7915,7 +8094,6 @@ instruct compareAndExchangeP_regP_regP_regP(iRegPdst res, iRegPdst mem_ptr, iReg predicate(((CompareAndSwapNode*)n)->order() != MemNode::acquire && ((CompareAndSwapNode*)n)->order() != MemNode::seqcst); effect(TEMP_DEF res, TEMP cr0); format %{ "CMPXCHGD $res, $mem_ptr, $src1, $src2; as ptr; ptr" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7931,7 +8109,6 @@ instruct compareAndExchangeP_acq_regP_regP_regP(iRegPdst res, iRegPdst mem_ptr, predicate(((CompareAndSwapNode*)n)->order() == MemNode::acquire || ((CompareAndSwapNode*)n)->order() == MemNode::seqcst); effect(TEMP_DEF res, TEMP cr0); format %{ "CMPXCHGD acq $res, $mem_ptr, $src1, $src2; as ptr; ptr" %} - // Variable size: instruction count smaller if regs are disjoint. ins_encode %{ // TODO: PPC port $archOpcode(ppc64Opcode_compound); // CmpxchgX sets CCR0 to cmpX(src1, src2) and Rres to 'true'/'false'. @@ -7950,57 +8127,235 @@ instruct compareAndExchangeP_acq_regP_regP_regP(iRegPdst res, iRegPdst mem_ptr, // Special RMW +instruct getAndAddB(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src, flagsRegCR0 cr0) %{ + match(Set res (GetAndAddB mem_ptr src)); + predicate(VM_Version::has_lqarx()); + effect(TEMP_DEF res, TEMP cr0); + format %{ "GetAndAddB $res, $mem_ptr, $src" %} + ins_encode %{ + __ getandaddb($res$$Register, $src$$Register, $mem_ptr$$Register, + R0, noreg, noreg, MacroAssembler::cmpxchgx_hint_atomic_update()); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + +instruct getAndAddB4(iRegIdst res, rarg3RegP mem_ptr, iRegIsrc src, iRegIsrc tmp1, iRegIsrc tmp2, flagsRegCR0 cr0) %{ + match(Set res (GetAndAddB mem_ptr src)); + predicate(!VM_Version::has_lqarx()); + effect(TEMP_DEF res, USE_KILL mem_ptr, TEMP tmp1, TEMP tmp2, TEMP cr0); + format %{ "GetAndAddB $res, $mem_ptr, $src" %} + ins_encode %{ + __ getandaddb($res$$Register, $src$$Register, $mem_ptr$$Register, + R0, $tmp1$$Register, $tmp2$$Register, MacroAssembler::cmpxchgx_hint_atomic_update()); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + +instruct getAndAddS(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src, flagsRegCR0 cr0) %{ + match(Set res (GetAndAddS mem_ptr src)); + predicate(VM_Version::has_lqarx()); + effect(TEMP_DEF res, TEMP cr0); + format %{ "GetAndAddS $res, $mem_ptr, $src" %} + ins_encode %{ + __ getandaddh($res$$Register, $src$$Register, $mem_ptr$$Register, + R0, noreg, noreg, MacroAssembler::cmpxchgx_hint_atomic_update()); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + +instruct getAndAddS4(iRegIdst res, rarg3RegP mem_ptr, iRegIsrc src, iRegIsrc tmp1, iRegIsrc tmp2, flagsRegCR0 cr0) %{ + match(Set res (GetAndAddS mem_ptr src)); + predicate(!VM_Version::has_lqarx()); + effect(TEMP_DEF res, USE_KILL mem_ptr, TEMP tmp1, TEMP tmp2, TEMP cr0); + format %{ "GetAndAddS $res, $mem_ptr, $src" %} + ins_encode %{ + __ getandaddh($res$$Register, $src$$Register, $mem_ptr$$Register, + R0, $tmp1$$Register, $tmp2$$Register, MacroAssembler::cmpxchgx_hint_atomic_update()); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + instruct getAndAddI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src, flagsRegCR0 cr0) %{ match(Set res (GetAndAddI mem_ptr src)); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); format %{ "GetAndAddI $res, $mem_ptr, $src" %} - // Variable size: instruction count smaller if regs are disjoint. - ins_encode( enc_GetAndAddI(res, mem_ptr, src) ); + ins_encode %{ + __ getandaddw($res$$Register, $src$$Register, $mem_ptr$$Register, + R0, MacroAssembler::cmpxchgx_hint_atomic_update()); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} ins_pipe(pipe_class_default); %} instruct getAndAddL(iRegLdst res, iRegPdst mem_ptr, iRegLsrc src, flagsRegCR0 cr0) %{ match(Set res (GetAndAddL mem_ptr src)); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); format %{ "GetAndAddL $res, $mem_ptr, $src" %} - // Variable size: instruction count smaller if regs are disjoint. - ins_encode( enc_GetAndAddL(res, mem_ptr, src) ); + ins_encode %{ + __ getandaddd($res$$Register, $src$$Register, $mem_ptr$$Register, + R0, MacroAssembler::cmpxchgx_hint_atomic_update()); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + +instruct getAndSetB(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src, flagsRegCR0 cr0) %{ + match(Set res (GetAndSetB mem_ptr src)); + predicate(VM_Version::has_lqarx()); + effect(TEMP_DEF res, TEMP cr0); + format %{ "GetAndSetB $res, $mem_ptr, $src" %} + ins_encode %{ + __ getandsetb($res$$Register, $src$$Register, $mem_ptr$$Register, + noreg, noreg, noreg, MacroAssembler::cmpxchgx_hint_atomic_update()); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + +instruct getAndSetB4(iRegIdst res, rarg3RegP mem_ptr, iRegIsrc src, iRegIsrc tmp1, iRegIsrc tmp2, flagsRegCR0 cr0) %{ + match(Set res (GetAndSetB mem_ptr src)); + predicate(!VM_Version::has_lqarx()); + effect(TEMP_DEF res, USE_KILL mem_ptr, TEMP tmp1, TEMP tmp2, TEMP cr0); + format %{ "GetAndSetB $res, $mem_ptr, $src" %} + ins_encode %{ + __ getandsetb($res$$Register, $src$$Register, $mem_ptr$$Register, + R0, $tmp1$$Register, $tmp2$$Register, MacroAssembler::cmpxchgx_hint_atomic_update()); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + +instruct getAndSetS(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src, flagsRegCR0 cr0) %{ + match(Set res (GetAndSetS mem_ptr src)); + predicate(VM_Version::has_lqarx()); + effect(TEMP_DEF res, TEMP cr0); + format %{ "GetAndSetS $res, $mem_ptr, $src" %} + ins_encode %{ + __ getandseth($res$$Register, $src$$Register, $mem_ptr$$Register, + noreg, noreg, noreg, MacroAssembler::cmpxchgx_hint_atomic_update()); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} + ins_pipe(pipe_class_default); +%} + +instruct getAndSetS4(iRegIdst res, rarg3RegP mem_ptr, iRegIsrc src, iRegIsrc tmp1, iRegIsrc tmp2, flagsRegCR0 cr0) %{ + match(Set res (GetAndSetS mem_ptr src)); + predicate(!VM_Version::has_lqarx()); + effect(TEMP_DEF res, USE_KILL mem_ptr, TEMP tmp1, TEMP tmp2, TEMP cr0); + format %{ "GetAndSetS $res, $mem_ptr, $src" %} + ins_encode %{ + __ getandseth($res$$Register, $src$$Register, $mem_ptr$$Register, + R0, $tmp1$$Register, $tmp2$$Register, MacroAssembler::cmpxchgx_hint_atomic_update()); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} ins_pipe(pipe_class_default); %} instruct getAndSetI(iRegIdst res, iRegPdst mem_ptr, iRegIsrc src, flagsRegCR0 cr0) %{ match(Set res (GetAndSetI mem_ptr src)); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); format %{ "GetAndSetI $res, $mem_ptr, $src" %} - // Variable size: instruction count smaller if regs are disjoint. - ins_encode( enc_GetAndSetI(res, mem_ptr, src) ); + ins_encode %{ + __ getandsetw($res$$Register, $src$$Register, $mem_ptr$$Register, + MacroAssembler::cmpxchgx_hint_atomic_update()); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} ins_pipe(pipe_class_default); %} instruct getAndSetL(iRegLdst res, iRegPdst mem_ptr, iRegLsrc src, flagsRegCR0 cr0) %{ match(Set res (GetAndSetL mem_ptr src)); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); format %{ "GetAndSetL $res, $mem_ptr, $src" %} - // Variable size: instruction count smaller if regs are disjoint. - ins_encode( enc_GetAndSetL(res, mem_ptr, src) ); + ins_encode %{ + __ getandsetd($res$$Register, $src$$Register, $mem_ptr$$Register, + MacroAssembler::cmpxchgx_hint_atomic_update()); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} ins_pipe(pipe_class_default); %} instruct getAndSetP(iRegPdst res, iRegPdst mem_ptr, iRegPsrc src, flagsRegCR0 cr0) %{ match(Set res (GetAndSetP mem_ptr src)); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); format %{ "GetAndSetP $res, $mem_ptr, $src" %} - // Variable size: instruction count smaller if regs are disjoint. - ins_encode( enc_GetAndSetL(res, mem_ptr, src) ); + ins_encode %{ + __ getandsetd($res$$Register, $src$$Register, $mem_ptr$$Register, + MacroAssembler::cmpxchgx_hint_atomic_update()); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} ins_pipe(pipe_class_default); %} instruct getAndSetN(iRegNdst res, iRegPdst mem_ptr, iRegNsrc src, flagsRegCR0 cr0) %{ match(Set res (GetAndSetN mem_ptr src)); - effect(TEMP cr0); + effect(TEMP_DEF res, TEMP cr0); format %{ "GetAndSetN $res, $mem_ptr, $src" %} - // Variable size: instruction count smaller if regs are disjoint. - ins_encode( enc_GetAndSetI(res, mem_ptr, src) ); + ins_encode %{ + __ getandsetw($res$$Register, $src$$Register, $mem_ptr$$Register, + MacroAssembler::cmpxchgx_hint_atomic_update()); + if (support_IRIW_for_not_multiple_copy_atomic_cpu) { + __ isync(); + } else { + __ sync(); + } + %} ins_pipe(pipe_class_default); %} @@ -11360,7 +11715,7 @@ instruct inlineCallClearArray(rarg1RegL cnt, rarg2RegP base, Universe dummy, reg effect(USE_KILL cnt, USE_KILL base, KILL ctr); ins_cost(MEMORY_REF_COST); - ins_alignment(8); // 'compute_padding()' gets called, up to this number-1 nops will get inserted. + ins_alignment(4); // 'compute_padding()' gets called, up to this number-1 nops will get inserted. format %{ "ClearArray $cnt, $base" %} ins_encode %{ @@ -11686,7 +12041,6 @@ instruct indexOfChar_U(iRegIdst result, iRegPsrc haystack, iRegIsrc haycnt, flagsRegCR0 cr0, flagsRegCR1 cr1, regCTR ctr) %{ match(Set result (StrIndexOfChar (Binary haystack haycnt) ch)); effect(TEMP tmp1, TEMP tmp2, KILL cr0, KILL cr1, KILL ctr); - predicate(CompactStrings); ins_cost(180); format %{ "String IndexOfChar $haystack[0..$haycnt], $ch" @@ -11948,283 +12302,6 @@ instruct encode_iso_array(rarg1RegP src, rarg2RegP dst, iRegIsrc len, iRegIdst r %} -// String_IndexOf for needle of length 1. -// -// Match needle into immediate operands: no loadConP node needed. Saves one -// register and two instructions over string_indexOf_imm1Node. -// -// Assumes register result differs from all input registers. -// -// Preserves registers haystack, haycnt -// Kills registers tmp1, tmp2 -// Defines registers result -// -// Use dst register classes if register gets killed, as it is the case for tmp registers! -// -// Unfortunately this does not match too often. In many situations the AddP is used -// by several nodes, even several StrIndexOf nodes, breaking the match tree. -instruct string_indexOf_imm1_char(iRegIdst result, iRegPsrc haystack, iRegIsrc haycnt, - immP needleImm, immL offsetImm, immI_1 needlecntImm, - iRegIdst tmp1, iRegIdst tmp2, - flagsRegCR0 cr0, flagsRegCR1 cr1, regCTR ctr) %{ - predicate(SpecialStringIndexOf && !CompactStrings); // type check implicit by parameter type, See Matcher::match_rule_supported - match(Set result (StrIndexOf (Binary haystack haycnt) (Binary (AddP needleImm offsetImm) needlecntImm))); - - effect(TEMP_DEF result, TEMP tmp1, TEMP tmp2, KILL cr0, KILL cr1, KILL ctr); - - ins_cost(150); - format %{ "String IndexOf CSCL1 $haystack[0..$haycnt], $needleImm+$offsetImm[0..$needlecntImm]" - "-> $result \t// KILL $haycnt, $tmp1, $tmp2, $cr0, $cr1" %} - - ins_alignment(8); // 'compute_padding()' gets called, up to this number-1 nops will get inserted - ins_encode %{ - // TODO: PPC port $archOpcode(ppc64Opcode_compound); - immPOper *needleOper = (immPOper *)$needleImm; - const TypeOopPtr *t = needleOper->type()->isa_oopptr(); - ciTypeArray* needle_values = t->const_oop()->as_type_array(); // Pointer to live char * - jchar chr; - if (java_lang_String::has_coder_field()) { - // New compact strings byte array strings -#ifdef VM_LITTLE_ENDIAN - chr = (((jchar)(unsigned char)needle_values->element_value(1).as_byte()) << 8) | - ((jchar)(unsigned char)needle_values->element_value(0).as_byte()); -#else - chr = (((jchar)(unsigned char)needle_values->element_value(0).as_byte()) << 8) | - ((jchar)(unsigned char)needle_values->element_value(1).as_byte()); -#endif - } else { - // Old char array strings - chr = needle_values->char_at(0); - } - __ string_indexof_1($result$$Register, - $haystack$$Register, $haycnt$$Register, - R0, chr, - $tmp1$$Register, $tmp2$$Register); - %} - ins_pipe(pipe_class_compare); -%} - -// String_IndexOf for needle of length 1. -// -// Special case requires less registers and emits less instructions. -// -// Assumes register result differs from all input registers. -// -// Preserves registers haystack, haycnt -// Kills registers tmp1, tmp2, needle -// Defines registers result -// -// Use dst register classes if register gets killed, as it is the case for tmp registers! -instruct string_indexOf_imm1(iRegIdst result, iRegPsrc haystack, iRegIsrc haycnt, - rscratch2RegP needle, immI_1 needlecntImm, - iRegIdst tmp1, iRegIdst tmp2, - flagsRegCR0 cr0, flagsRegCR1 cr1, regCTR ctr) %{ - match(Set result (StrIndexOf (Binary haystack haycnt) (Binary needle needlecntImm))); - effect(USE_KILL needle, /* TDEF needle, */ TEMP_DEF result, - TEMP tmp1, TEMP tmp2, KILL cr0, KILL cr1, KILL ctr); - // Required for EA: check if it is still a type_array. - predicate(SpecialStringIndexOf && !CompactStrings && - n->in(3)->in(1)->bottom_type()->is_aryptr()->const_oop() && - n->in(3)->in(1)->bottom_type()->is_aryptr()->const_oop()->is_type_array()); - ins_cost(180); - - ins_alignment(8); // 'compute_padding()' gets called, up to this number-1 nops will get inserted. - - format %{ "String IndexOf SCL1 $haystack[0..$haycnt], $needle[0..$needlecntImm]" - " -> $result \t// KILL $haycnt, $needle, $tmp1, $tmp2, $cr0, $cr1" %} - ins_encode %{ - // TODO: PPC port $archOpcode(ppc64Opcode_compound); - Node *ndl = in(operand_index($needle)); // The node that defines needle. - ciTypeArray* needle_values = ndl->bottom_type()->is_aryptr()->const_oop()->as_type_array(); - guarantee(needle_values, "sanity"); - jchar chr; - if (java_lang_String::has_coder_field()) { - // New compact strings byte array strings -#ifdef VM_LITTLE_ENDIAN - chr = (((jchar)(unsigned char)needle_values->element_value(1).as_byte()) << 8) | - ((jchar)(unsigned char)needle_values->element_value(0).as_byte()); -#else - chr = (((jchar)(unsigned char)needle_values->element_value(0).as_byte()) << 8) | - ((jchar)(unsigned char)needle_values->element_value(1).as_byte()); -#endif - } else { - // Old char array strings - chr = needle_values->char_at(0); - } - __ string_indexof_1($result$$Register, - $haystack$$Register, $haycnt$$Register, - R0, chr, - $tmp1$$Register, $tmp2$$Register); - %} - ins_pipe(pipe_class_compare); -%} - -// String_IndexOfChar -// -// Assumes register result differs from all input registers. -// -// Preserves registers haystack, haycnt -// Kills registers tmp1, tmp2 -// Defines registers result -// -// Use dst register classes if register gets killed, as it is the case for tmp registers! -instruct string_indexOfChar(iRegIdst result, iRegPsrc haystack, iRegIsrc haycnt, - iRegIsrc ch, iRegIdst tmp1, iRegIdst tmp2, - flagsRegCR0 cr0, flagsRegCR1 cr1, regCTR ctr) %{ - match(Set result (StrIndexOfChar (Binary haystack haycnt) ch)); - effect(TEMP_DEF result, TEMP tmp1, TEMP tmp2, KILL cr0, KILL cr1, KILL ctr); - predicate(SpecialStringIndexOf && !CompactStrings); - ins_cost(180); - - ins_alignment(8); // 'compute_padding()' gets called, up to this number-1 nops will get inserted. - - format %{ "String IndexOfChar $haystack[0..$haycnt], $ch" - " -> $result \t// KILL $haycnt, $tmp1, $tmp2, $cr0, $cr1" %} - ins_encode %{ - __ string_indexof_1($result$$Register, - $haystack$$Register, $haycnt$$Register, - $ch$$Register, 0 /* this is not used if the character is already in a register */, - $tmp1$$Register, $tmp2$$Register); - %} - ins_pipe(pipe_class_compare); -%} - -// String_IndexOf. -// -// Length of needle as immediate. This saves instruction loading constant needle -// length. -// @@@ TODO Specify rules for length < 8 or so, and roll out comparison of needle -// completely or do it in vector instruction. This should save registers for -// needlecnt and needle. -// -// Assumes register result differs from all input registers. -// Overwrites haycnt, needlecnt. -// Use dst register classes if register gets killed, as it is the case for tmp registers! -instruct string_indexOf_imm(iRegIdst result, iRegPsrc haystack, rscratch1RegI haycnt, - iRegPsrc needle, uimmI15 needlecntImm, - iRegIdst tmp1, iRegIdst tmp2, iRegIdst tmp3, iRegIdst tmp4, iRegIdst tmp5, - flagsRegCR0 cr0, flagsRegCR1 cr1, flagsRegCR6 cr6, regCTR ctr) %{ - match(Set result (StrIndexOf (Binary haystack haycnt) (Binary needle needlecntImm))); - effect(USE_KILL haycnt, /* better: TDEF haycnt, */ TEMP_DEF result, - TEMP tmp1, TEMP tmp2, TEMP tmp3, TEMP tmp4, TEMP tmp5, KILL cr0, KILL cr1, KILL cr6, KILL ctr); - // Required for EA: check if it is still a type_array. - predicate(SpecialStringIndexOf && !CompactStrings && n->in(3)->in(1)->bottom_type()->is_aryptr()->const_oop() && - n->in(3)->in(1)->bottom_type()->is_aryptr()->const_oop()->is_type_array()); - ins_cost(250); - - ins_alignment(8); // 'compute_padding()' gets called, up to this number-1 nops will get inserted. - - format %{ "String IndexOf SCL $haystack[0..$haycnt], $needle[0..$needlecntImm]" - " -> $result \t// KILL $haycnt, $tmp1, $tmp2, $tmp3, $tmp4, $tmp5, $cr0, $cr1" %} - ins_encode %{ - // TODO: PPC port $archOpcode(ppc64Opcode_compound); - Node *ndl = in(operand_index($needle)); // The node that defines needle. - ciTypeArray* needle_values = ndl->bottom_type()->is_aryptr()->const_oop()->as_type_array(); - - __ string_indexof($result$$Register, - $haystack$$Register, $haycnt$$Register, - $needle$$Register, needle_values, $tmp5$$Register, $needlecntImm$$constant, - $tmp1$$Register, $tmp2$$Register, $tmp3$$Register, $tmp4$$Register); - %} - ins_pipe(pipe_class_compare); -%} - -// StrIndexOf node. -// -// Assumes register result differs from all input registers. -// Overwrites haycnt, needlecnt. -// Use dst register classes if register gets killed, as it is the case for tmp registers! -instruct string_indexOf(iRegIdst result, iRegPsrc haystack, rscratch1RegI haycnt, iRegPsrc needle, rscratch2RegI needlecnt, - iRegLdst tmp1, iRegLdst tmp2, iRegLdst tmp3, iRegLdst tmp4, - flagsRegCR0 cr0, flagsRegCR1 cr1, flagsRegCR6 cr6, regCTR ctr) %{ - match(Set result (StrIndexOf (Binary haystack haycnt) (Binary needle needlecnt))); - effect(USE_KILL haycnt, USE_KILL needlecnt, /*better: TDEF haycnt, TDEF needlecnt,*/ - TEMP_DEF result, - TEMP tmp1, TEMP tmp2, TEMP tmp3, TEMP tmp4, KILL cr0, KILL cr1, KILL cr6, KILL ctr); - predicate(SpecialStringIndexOf && !CompactStrings); // See Matcher::match_rule_supported. - ins_cost(300); - - ins_alignment(8); // 'compute_padding()' gets called, up to this number-1 nops will get inserted. - - format %{ "String IndexOf $haystack[0..$haycnt], $needle[0..$needlecnt]" - " -> $result \t// KILL $haycnt, $needlecnt, $tmp1, $tmp2, $tmp3, $tmp4, $cr0, $cr1" %} - ins_encode %{ - // TODO: PPC port $archOpcode(ppc64Opcode_compound); - __ string_indexof($result$$Register, - $haystack$$Register, $haycnt$$Register, - $needle$$Register, NULL, $needlecnt$$Register, 0, // needlecnt not constant. - $tmp1$$Register, $tmp2$$Register, $tmp3$$Register, $tmp4$$Register); - %} - ins_pipe(pipe_class_compare); -%} - -// String equals with immediate. -instruct string_equals_imm(iRegPsrc str1, iRegPsrc str2, uimmI15 cntImm, iRegIdst result, - iRegPdst tmp1, iRegPdst tmp2, - flagsRegCR0 cr0, flagsRegCR6 cr6, regCTR ctr) %{ - match(Set result (StrEquals (Binary str1 str2) cntImm)); - effect(TEMP_DEF result, TEMP tmp1, TEMP tmp2, - KILL cr0, KILL cr6, KILL ctr); - predicate(SpecialStringEquals && !CompactStrings); // See Matcher::match_rule_supported. - ins_cost(250); - - ins_alignment(8); // 'compute_padding()' gets called, up to this number-1 nops will get inserted. - - format %{ "String Equals SCL [0..$cntImm]($str1),[0..$cntImm]($str2)" - " -> $result \t// KILL $cr0, $cr6, $ctr, TEMP $result, $tmp1, $tmp2" %} - ins_encode %{ - // TODO: PPC port $archOpcode(ppc64Opcode_compound); - __ char_arrays_equalsImm($str1$$Register, $str2$$Register, $cntImm$$constant, - $result$$Register, $tmp1$$Register, $tmp2$$Register); - %} - ins_pipe(pipe_class_compare); -%} - -// String equals. -// Use dst register classes if register gets killed, as it is the case for TEMP operands! -instruct string_equals(iRegPsrc str1, iRegPsrc str2, iRegIsrc cnt, iRegIdst result, - iRegPdst tmp1, iRegPdst tmp2, iRegPdst tmp3, iRegPdst tmp4, iRegPdst tmp5, - flagsRegCR0 cr0, flagsRegCR1 cr1, flagsRegCR6 cr6, regCTR ctr) %{ - match(Set result (StrEquals (Binary str1 str2) cnt)); - effect(TEMP_DEF result, TEMP tmp1, TEMP tmp2, TEMP tmp3, TEMP tmp4, TEMP tmp5, - KILL cr0, KILL cr1, KILL cr6, KILL ctr); - predicate(SpecialStringEquals && !CompactStrings); // See Matcher::match_rule_supported. - ins_cost(300); - - ins_alignment(8); // 'compute_padding()' gets called, up to this number-1 nops will get inserted. - - format %{ "String Equals [0..$cnt]($str1),[0..$cnt]($str2) -> $result" - " \t// KILL $cr0, $cr1, $cr6, $ctr, TEMP $result, $tmp1, $tmp2, $tmp3, $tmp4, $tmp5" %} - ins_encode %{ - // TODO: PPC port $archOpcode(ppc64Opcode_compound); - __ char_arrays_equals($str1$$Register, $str2$$Register, $cnt$$Register, $result$$Register, - $tmp1$$Register, $tmp2$$Register, $tmp3$$Register, $tmp4$$Register, $tmp5$$Register); - %} - ins_pipe(pipe_class_compare); -%} - -// String compare. -// Char[] pointers are passed in. -// Use dst register classes if register gets killed, as it is the case for TEMP operands! -instruct string_compare(rarg1RegP str1, rarg2RegP str2, rarg3RegI cnt1, rarg4RegI cnt2, iRegIdst result, - iRegPdst tmp, flagsRegCR0 cr0, regCTR ctr) %{ - predicate(!CompactStrings); - match(Set result (StrComp (Binary str1 cnt1) (Binary str2 cnt2))); - effect(USE_KILL cnt1, USE_KILL cnt2, USE_KILL str1, USE_KILL str2, TEMP_DEF result, TEMP tmp, KILL cr0, KILL ctr); - ins_cost(300); - - ins_alignment(8); // 'compute_padding()' gets called, up to this number-1 nops will get inserted. - - format %{ "String Compare $str1[0..$cnt1], $str2[0..$cnt2] -> $result" - " \t// TEMP $tmp, $result KILLs $str1, $cnt1, $str2, $cnt2, $cr0, $ctr" %} - ins_encode %{ - // TODO: PPC port $archOpcode(ppc64Opcode_compound); - __ string_compare($str1$$Register, $str2$$Register, $cnt1$$Register, $cnt2$$Register, - $result$$Register, $tmp$$Register); - %} - ins_pipe(pipe_class_compare); -%} - //---------- Min/Max Instructions --------------------------------------------- instruct minI_reg_reg_Ex(iRegIdst dst, iRegIsrc src1, iRegIsrc src2) %{ diff --git a/hotspot/src/cpu/ppc/vm/stubGenerator_ppc.cpp b/hotspot/src/cpu/ppc/vm/stubGenerator_ppc.cpp index e845d2872ed..cf07f2bd5dc 100644 --- a/hotspot/src/cpu/ppc/vm/stubGenerator_ppc.cpp +++ b/hotspot/src/cpu/ppc/vm/stubGenerator_ppc.cpp @@ -1123,7 +1123,10 @@ class StubGenerator: public StubCodeGenerator { Register tmp3 = R8_ARG6; Register tmp4 = R9_ARG7; - Label l_1, l_2, l_3, l_4, l_5, l_6, l_7, l_8, l_9; + VectorSRegister tmp_vsr1 = VSR1; + VectorSRegister tmp_vsr2 = VSR2; + + Label l_1, l_2, l_3, l_4, l_5, l_6, l_7, l_8, l_9, l_10; // Don't try anything fancy if arrays don't have many elements. __ li(tmp3, 0); @@ -1178,6 +1181,8 @@ class StubGenerator: public StubCodeGenerator { __ andi_(R5_ARG3, R5_ARG3, 31); __ mtctr(tmp1); + if (!VM_Version::has_vsx()) { + __ bind(l_8); // Use unrolled version for mass copying (copy 32 elements a time) // Load feeding store gets zero latency on Power6, however not on Power5. @@ -1193,7 +1198,44 @@ class StubGenerator: public StubCodeGenerator { __ addi(R3_ARG1, R3_ARG1, 32); __ addi(R4_ARG2, R4_ARG2, 32); __ bdnz(l_8); - } + + } else { // Processor supports VSX, so use it to mass copy. + + // Prefetch the data into the L2 cache. + __ dcbt(R3_ARG1, 0); + + // If supported set DSCR pre-fetch to deepest. + if (VM_Version::has_mfdscr()) { + __ load_const_optimized(tmp2, VM_Version::_dscr_val | 7); + __ mtdscr(tmp2); + } + + __ li(tmp1, 16); + + // Backbranch target aligned to 32-byte. Not 16-byte align as + // loop contains < 8 instructions that fit inside a single + // i-cache sector. + __ align(32); + + __ bind(l_10); + // Use loop with VSX load/store instructions to + // copy 32 elements a time. + __ lxvd2x(tmp_vsr1, 0, R3_ARG1); // Load src + __ stxvd2x(tmp_vsr1, 0, R4_ARG2); // Store to dst + __ lxvd2x(tmp_vsr2, tmp1, R3_ARG1); // Load src + 16 + __ stxvd2x(tmp_vsr2, tmp1, R4_ARG2); // Store to dst + 16 + __ addi(R3_ARG1, R3_ARG1, 32); // Update src+=32 + __ addi(R4_ARG2, R4_ARG2, 32); // Update dsc+=32 + __ bdnz(l_10); // Dec CTR and loop if not zero. + + // Restore DSCR pre-fetch value. + if (VM_Version::has_mfdscr()) { + __ load_const_optimized(tmp2, VM_Version::_dscr_val); + __ mtdscr(tmp2); + } + + } // VSX + } // FasterArrayCopy __ bind(l_6); @@ -1557,7 +1599,10 @@ class StubGenerator: public StubCodeGenerator { Register tmp3 = R8_ARG6; Register tmp4 = R0; - Label l_1, l_2, l_3, l_4, l_5, l_6; + VectorSRegister tmp_vsr1 = VSR1; + VectorSRegister tmp_vsr2 = VSR2; + + Label l_1, l_2, l_3, l_4, l_5, l_6, l_7; // for short arrays, just do single element copy __ li(tmp3, 0); @@ -1593,6 +1638,8 @@ class StubGenerator: public StubCodeGenerator { __ andi_(R5_ARG3, R5_ARG3, 7); __ mtctr(tmp1); + if (!VM_Version::has_vsx()) { + __ bind(l_6); // Use unrolled version for mass copying (copy 8 elements a time). // Load feeding store gets zero latency on power6, however not on power 5. @@ -1608,7 +1655,44 @@ class StubGenerator: public StubCodeGenerator { __ addi(R3_ARG1, R3_ARG1, 32); __ addi(R4_ARG2, R4_ARG2, 32); __ bdnz(l_6); - } + + } else { // Processor supports VSX, so use it to mass copy. + + // Prefetch the data into the L2 cache. + __ dcbt(R3_ARG1, 0); + + // If supported set DSCR pre-fetch to deepest. + if (VM_Version::has_mfdscr()) { + __ load_const_optimized(tmp2, VM_Version::_dscr_val | 7); + __ mtdscr(tmp2); + } + + __ li(tmp1, 16); + + // Backbranch target aligned to 32-byte. Not 16-byte align as + // loop contains < 8 instructions that fit inside a single + // i-cache sector. + __ align(32); + + __ bind(l_7); + // Use loop with VSX load/store instructions to + // copy 8 elements a time. + __ lxvd2x(tmp_vsr1, 0, R3_ARG1); // Load src + __ stxvd2x(tmp_vsr1, 0, R4_ARG2); // Store to dst + __ lxvd2x(tmp_vsr2, tmp1, R3_ARG1); // Load src + 16 + __ stxvd2x(tmp_vsr2, tmp1, R4_ARG2); // Store to dst + 16 + __ addi(R3_ARG1, R3_ARG1, 32); // Update src+=32 + __ addi(R4_ARG2, R4_ARG2, 32); // Update dsc+=32 + __ bdnz(l_7); // Dec CTR and loop if not zero. + + // Restore DSCR pre-fetch value. + if (VM_Version::has_mfdscr()) { + __ load_const_optimized(tmp2, VM_Version::_dscr_val); + __ mtdscr(tmp2); + } + + } // VSX + } // FasterArrayCopy // copy 1 element at a time __ bind(l_2); @@ -1757,7 +1841,10 @@ class StubGenerator: public StubCodeGenerator { Register tmp3 = R8_ARG6; Register tmp4 = R0; - Label l_1, l_2, l_3, l_4; + Label l_1, l_2, l_3, l_4, l_5; + + VectorSRegister tmp_vsr1 = VSR1; + VectorSRegister tmp_vsr2 = VSR2; { // FasterArrayCopy __ cmpwi(CCR0, R5_ARG3, 3); @@ -1767,6 +1854,7 @@ class StubGenerator: public StubCodeGenerator { __ andi_(R5_ARG3, R5_ARG3, 3); __ mtctr(tmp1); + if (!VM_Version::has_vsx()) { __ bind(l_4); // Use unrolled version for mass copying (copy 4 elements a time). // Load feeding store gets zero latency on Power6, however not on Power5. @@ -1782,7 +1870,44 @@ class StubGenerator: public StubCodeGenerator { __ addi(R3_ARG1, R3_ARG1, 32); __ addi(R4_ARG2, R4_ARG2, 32); __ bdnz(l_4); - } + + } else { // Processor supports VSX, so use it to mass copy. + + // Prefetch the data into the L2 cache. + __ dcbt(R3_ARG1, 0); + + // If supported set DSCR pre-fetch to deepest. + if (VM_Version::has_mfdscr()) { + __ load_const_optimized(tmp2, VM_Version::_dscr_val | 7); + __ mtdscr(tmp2); + } + + __ li(tmp1, 16); + + // Backbranch target aligned to 32-byte. Not 16-byte align as + // loop contains < 8 instructions that fit inside a single + // i-cache sector. + __ align(32); + + __ bind(l_5); + // Use loop with VSX load/store instructions to + // copy 4 elements a time. + __ lxvd2x(tmp_vsr1, 0, R3_ARG1); // Load src + __ stxvd2x(tmp_vsr1, 0, R4_ARG2); // Store to dst + __ lxvd2x(tmp_vsr2, tmp1, R3_ARG1); // Load src + 16 + __ stxvd2x(tmp_vsr2, tmp1, R4_ARG2); // Store to dst + 16 + __ addi(R3_ARG1, R3_ARG1, 32); // Update src+=32 + __ addi(R4_ARG2, R4_ARG2, 32); // Update dsc+=32 + __ bdnz(l_5); // Dec CTR and loop if not zero. + + // Restore DSCR pre-fetch value. + if (VM_Version::has_mfdscr()) { + __ load_const_optimized(tmp2, VM_Version::_dscr_val); + __ mtdscr(tmp2); + } + + } // VSX + } // FasterArrayCopy // copy 1 element at a time __ bind(l_3); diff --git a/hotspot/src/cpu/ppc/vm/templateInterpreterGenerator_ppc.cpp b/hotspot/src/cpu/ppc/vm/templateInterpreterGenerator_ppc.cpp index 11690a1ddf7..591db706231 100644 --- a/hotspot/src/cpu/ppc/vm/templateInterpreterGenerator_ppc.cpp +++ b/hotspot/src/cpu/ppc/vm/templateInterpreterGenerator_ppc.cpp @@ -845,9 +845,40 @@ void TemplateInterpreterGenerator::generate_counter_overflow(Label& continue_ent __ b(continue_entry); } +// See if we've got enough room on the stack for locals plus overhead below +// JavaThread::stack_overflow_limit(). If not, throw a StackOverflowError +// without going through the signal handler, i.e., reserved and yellow zones +// will not be made usable. The shadow zone must suffice to handle the +// overflow. +// +// Kills Rmem_frame_size, Rscratch1. void TemplateInterpreterGenerator::generate_stack_overflow_check(Register Rmem_frame_size, Register Rscratch1) { + Label done; assert_different_registers(Rmem_frame_size, Rscratch1); - __ generate_stack_overflow_check_with_compare_and_throw(Rmem_frame_size, Rscratch1); + + BLOCK_COMMENT("stack_overflow_check_with_compare {"); + __ sub(Rmem_frame_size, R1_SP, Rmem_frame_size); + __ ld(Rscratch1, thread_(stack_overflow_limit)); + __ cmpld(CCR0/*is_stack_overflow*/, Rmem_frame_size, Rscratch1); + __ bgt(CCR0/*is_stack_overflow*/, done); + + // The stack overflows. Load target address of the runtime stub and call it. + assert(StubRoutines::throw_StackOverflowError_entry() != NULL, "generated in wrong order"); + __ load_const_optimized(Rscratch1, (StubRoutines::throw_StackOverflowError_entry()), R0); + __ mtctr(Rscratch1); + // Restore caller_sp. +#ifdef ASSERT + __ ld(Rscratch1, 0, R1_SP); + __ ld(R0, 0, R21_sender_SP); + __ cmpd(CCR0, R0, Rscratch1); + __ asm_assert_eq("backlink", 0x547); +#endif // ASSERT + __ mr(R1_SP, R21_sender_SP); + __ bctr(); + + __ align(32, 12); + __ bind(done); + BLOCK_COMMENT("} stack_overflow_check_with_compare"); } void TemplateInterpreterGenerator::unlock_method(bool check_exceptions) { @@ -1014,10 +1045,10 @@ void TemplateInterpreterGenerator::generate_fixed_frame(bool native_call, Regist // Enlarge by locals-parameters (not in case of native_call), shrink by ESP-SP-ABI48. if (!native_call) { - // -------------------------------------------------------------------------- - // Stack overflow check - - Label cont; + // Stack overflow check. + // Native calls don't need the stack size check since they have no + // expression stack and the arguments are already on the stack and + // we only add a handful of words to the stack. __ add(R11_scratch1, parent_frame_resize, top_frame_size); generate_stack_overflow_check(R11_scratch1, R12_scratch2); } diff --git a/hotspot/src/cpu/ppc/vm/templateTable_ppc_64.cpp b/hotspot/src/cpu/ppc/vm/templateTable_ppc_64.cpp index 6b8f658ff09..e27601c707c 100644 --- a/hotspot/src/cpu/ppc/vm/templateTable_ppc_64.cpp +++ b/hotspot/src/cpu/ppc/vm/templateTable_ppc_64.cpp @@ -1,6 +1,6 @@ /* * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. - * Copyright (c) 2013, 2015 SAP SE. All rights reserved. + * Copyright (c) 2013, 2016 SAP SE. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -4093,20 +4093,8 @@ void TemplateTable::monitorenter() { __ lock_object(Rcurrent_monitor, Robj_to_lock); // Check if there's enough space on the stack for the monitors after locking. - Label Lskip_stack_check; - // Optimization: If the monitors stack section is less then a std page size (4K) don't run - // the stack check. There should be enough shadow pages to fit that in. - __ ld(Rscratch3, 0, R1_SP); - __ sub(Rscratch3, Rscratch3, R26_monitor); - __ cmpdi(CCR0, Rscratch3, 4*K); - __ blt(CCR0, Lskip_stack_check); - - DEBUG_ONLY(__ untested("stack overflow check during monitor enter");) - __ li(Rscratch1, 0); - __ generate_stack_overflow_check_with_compare_and_throw(Rscratch1, Rscratch2); - - __ align(32, 12); - __ bind(Lskip_stack_check); + // This emits a single store. + __ generate_stack_overflow_check(0); // The bcp has already been incremented. Just need to dispatch to next instruction. __ dispatch_next(vtos); diff --git a/hotspot/src/cpu/sparc/vm/globals_sparc.hpp b/hotspot/src/cpu/sparc/vm/globals_sparc.hpp index 1e1ef759b45..d1ae77b5df0 100644 --- a/hotspot/src/cpu/sparc/vm/globals_sparc.hpp +++ b/hotspot/src/cpu/sparc/vm/globals_sparc.hpp @@ -59,11 +59,11 @@ define_pd_global(intx, InlineSmallCode, 1500); // Stack slots are 2X larger in LP64 than in the 32 bit VM. define_pd_global(intx, ThreadStackSize, 1024); define_pd_global(intx, VMThreadStackSize, 1024); -#define DEFAULT_STACK_SHADOW_PAGES (10 DEBUG_ONLY(+1)) +#define DEFAULT_STACK_SHADOW_PAGES (20 DEBUG_ONLY(+2)) #else define_pd_global(intx, ThreadStackSize, 512); define_pd_global(intx, VMThreadStackSize, 512); -#define DEFAULT_STACK_SHADOW_PAGES (3 DEBUG_ONLY(+1)) +#define DEFAULT_STACK_SHADOW_PAGES (6 DEBUG_ONLY(+2)) #endif // _LP64 #define MIN_STACK_YELLOW_PAGES DEFAULT_STACK_YELLOW_PAGES diff --git a/hotspot/src/cpu/sparc/vm/templateInterpreterGenerator_sparc.cpp b/hotspot/src/cpu/sparc/vm/templateInterpreterGenerator_sparc.cpp index f96b3e440a5..7df0e9896c1 100644 --- a/hotspot/src/cpu/sparc/vm/templateInterpreterGenerator_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/templateInterpreterGenerator_sparc.cpp @@ -578,51 +578,39 @@ void TemplateInterpreterGenerator::lock_method() { __ lock_object(Lmonitors, O0); } - +// See if we've got enough room on the stack for locals plus overhead below +// JavaThread::stack_overflow_limit(). If not, throw a StackOverflowError +// without going through the signal handler, i.e., reserved and yellow zones +// will not be made usable. The shadow zone must suffice to handle the +// overflow. void TemplateInterpreterGenerator::generate_stack_overflow_check(Register Rframe_size, - Register Rscratch, - Register Rscratch2) { + Register Rscratch) { const int page_size = os::vm_page_size(); Label after_frame_check; - assert_different_registers(Rframe_size, Rscratch, Rscratch2); + assert_different_registers(Rframe_size, Rscratch); __ set(page_size, Rscratch); __ cmp_and_br_short(Rframe_size, Rscratch, Assembler::lessEqual, Assembler::pt, after_frame_check); - // get the stack base, and in debug, verify it is non-zero - __ ld_ptr( G2_thread, Thread::stack_base_offset(), Rscratch ); + // Get the stack overflow limit, and in debug, verify it is non-zero. + __ ld_ptr(G2_thread, JavaThread::stack_overflow_limit_offset(), Rscratch); #ifdef ASSERT - Label base_not_zero; - __ br_notnull_short(Rscratch, Assembler::pn, base_not_zero); - __ stop("stack base is zero in generate_stack_overflow_check"); - __ bind(base_not_zero); + Label limit_ok; + __ br_notnull_short(Rscratch, Assembler::pn, limit_ok); + __ stop("stack overflow limit is zero in generate_stack_overflow_check"); + __ bind(limit_ok); #endif - // get the stack size, and in debug, verify it is non-zero - assert( sizeof(size_t) == sizeof(intptr_t), "wrong load size" ); - __ ld_ptr( G2_thread, Thread::stack_size_offset(), Rscratch2 ); -#ifdef ASSERT - Label size_not_zero; - __ br_notnull_short(Rscratch2, Assembler::pn, size_not_zero); - __ stop("stack size is zero in generate_stack_overflow_check"); - __ bind(size_not_zero); -#endif - - // compute the beginning of the protected zone minus the requested frame size - __ sub( Rscratch, Rscratch2, Rscratch ); - __ set(MAX2(JavaThread::stack_shadow_zone_size(), JavaThread::stack_guard_zone_size()), Rscratch2 ); - __ add( Rscratch, Rscratch2, Rscratch ); - // Add in the size of the frame (which is the same as subtracting it from the - // SP, which would take another register - __ add( Rscratch, Rframe_size, Rscratch ); + // SP, which would take another register. + __ add(Rscratch, Rframe_size, Rscratch); - // the frame is greater than one page in size, so check against - // the bottom of the stack + // The frame is greater than one page in size, so check against + // the bottom of the stack. __ cmp_and_brx_short(SP, Rscratch, Assembler::greaterUnsigned, Assembler::pt, after_frame_check); - // the stack will overflow, throw an exception + // The stack will overflow, throw an exception. // Note that SP is restored to sender's sp (in the delay slot). This // is necessary if the sender's frame is an extended compiled frame @@ -636,8 +624,8 @@ void TemplateInterpreterGenerator::generate_stack_overflow_check(Register Rframe __ jump_to(stub, Rscratch); __ delayed()->mov(O5_savedSP, SP); - // if you get to here, then there is enough stack space - __ bind( after_frame_check ); + // If you get to here, then there is enough stack space. + __ bind(after_frame_check); } @@ -821,40 +809,44 @@ void TemplateInterpreterGenerator::generate_fixed_frame(bool native_call) { __ add( Gframe_size, extra_space, Gframe_size); __ round_to( Gframe_size, WordsPerLong ); __ sll( Gframe_size, LogBytesPerWord, Gframe_size ); + + // Native calls don't need the stack size check since they have no + // expression stack and the arguments are already on the stack and + // we only add a handful of words to the stack. } else { // // Compute number of locals in method apart from incoming parameters // - const Address size_of_locals (Otmp1, ConstMethod::size_of_locals_offset()); - __ ld_ptr( constMethod, Otmp1 ); - __ lduh( size_of_locals, Otmp1 ); - __ sub( Otmp1, Glocals_size, Glocals_size ); - __ round_to( Glocals_size, WordsPerLong ); - __ sll( Glocals_size, Interpreter::logStackElementSize, Glocals_size ); + const Address size_of_locals(Otmp1, ConstMethod::size_of_locals_offset()); + __ ld_ptr(constMethod, Otmp1); + __ lduh(size_of_locals, Otmp1); + __ sub(Otmp1, Glocals_size, Glocals_size); + __ round_to(Glocals_size, WordsPerLong); + __ sll(Glocals_size, Interpreter::logStackElementSize, Glocals_size); - // see if the frame is greater than one page in size. If so, - // then we need to verify there is enough stack space remaining + // See if the frame is greater than one page in size. If so, + // then we need to verify there is enough stack space remaining. // Frame_size = (max_stack + extra_space) * BytesPerWord; - __ ld_ptr( constMethod, Gframe_size ); - __ lduh( Gframe_size, in_bytes(ConstMethod::max_stack_offset()), Gframe_size ); - __ add( Gframe_size, extra_space, Gframe_size ); - __ round_to( Gframe_size, WordsPerLong ); - __ sll( Gframe_size, Interpreter::logStackElementSize, Gframe_size); + __ ld_ptr(constMethod, Gframe_size); + __ lduh(Gframe_size, in_bytes(ConstMethod::max_stack_offset()), Gframe_size); + __ add(Gframe_size, extra_space, Gframe_size); + __ round_to(Gframe_size, WordsPerLong); + __ sll(Gframe_size, Interpreter::logStackElementSize, Gframe_size); // Add in java locals size for stack overflow check only - __ add( Gframe_size, Glocals_size, Gframe_size ); + __ add(Gframe_size, Glocals_size, Gframe_size); const Register Otmp2 = O4; assert_different_registers(Otmp1, Otmp2, O5_savedSP); - generate_stack_overflow_check(Gframe_size, Otmp1, Otmp2); + generate_stack_overflow_check(Gframe_size, Otmp1); - __ sub( Gframe_size, Glocals_size, Gframe_size); + __ sub(Gframe_size, Glocals_size, Gframe_size); // // bump SP to accomodate the extra locals // - __ sub( SP, Glocals_size, SP ); + __ sub(SP, Glocals_size, SP); } // diff --git a/hotspot/src/cpu/x86/vm/assembler_x86.cpp b/hotspot/src/cpu/x86/vm/assembler_x86.cpp index d65577ffca5..94f37e4d4b4 100644 --- a/hotspot/src/cpu/x86/vm/assembler_x86.cpp +++ b/hotspot/src/cpu/x86/vm/assembler_x86.cpp @@ -1173,6 +1173,23 @@ void Assembler::addl(Address dst, int32_t imm32) { emit_arith_operand(0x81, rax, dst, imm32); } +void Assembler::addb(Address dst, int imm8) { + InstructionMark im(this); + prefix(dst); + emit_int8((unsigned char)0x80); + emit_operand(rax, dst, 1); + emit_int8(imm8); +} + +void Assembler::addw(Address dst, int imm16) { + InstructionMark im(this); + emit_int8(0x66); + prefix(dst); + emit_int8((unsigned char)0x81); + emit_operand(rax, dst, 2); + emit_int16(imm16); +} + void Assembler::addl(Address dst, Register src) { InstructionMark im(this); prefix(dst, src); @@ -4567,6 +4584,23 @@ void Assembler::xabort(int8_t imm8) { emit_int8((unsigned char)(imm8 & 0xFF)); } +void Assembler::xaddb(Address dst, Register src) { + InstructionMark im(this); + prefix(dst, src, true); + emit_int8(0x0F); + emit_int8((unsigned char)0xC0); + emit_operand(src, dst); +} + +void Assembler::xaddw(Address dst, Register src) { + InstructionMark im(this); + emit_int8(0x66); + prefix(dst, src); + emit_int8(0x0F); + emit_int8((unsigned char)0xC1); + emit_operand(src, dst); +} + void Assembler::xaddl(Address dst, Register src) { InstructionMark im(this); prefix(dst, src); @@ -4593,6 +4627,21 @@ void Assembler::xbegin(Label& abort, relocInfo::relocType rtype) { } } +void Assembler::xchgb(Register dst, Address src) { // xchg + InstructionMark im(this); + prefix(src, dst, true); + emit_int8((unsigned char)0x86); + emit_operand(dst, src); +} + +void Assembler::xchgw(Register dst, Address src) { // xchg + InstructionMark im(this); + emit_int8(0x66); + prefix(src, dst); + emit_int8((unsigned char)0x87); + emit_operand(dst, src); +} + void Assembler::xchgl(Register dst, Address src) { // xchg InstructionMark im(this); prefix(src, dst); diff --git a/hotspot/src/cpu/x86/vm/assembler_x86.hpp b/hotspot/src/cpu/x86/vm/assembler_x86.hpp index 56165382936..5911b8368c2 100644 --- a/hotspot/src/cpu/x86/vm/assembler_x86.hpp +++ b/hotspot/src/cpu/x86/vm/assembler_x86.hpp @@ -881,6 +881,9 @@ private: void adcq(Register dst, Address src); void adcq(Register dst, Register src); + void addb(Address dst, int imm8); + void addw(Address dst, int imm16); + void addl(Address dst, int32_t imm32); void addl(Address dst, Register src); void addl(Register dst, int32_t imm32); @@ -1816,12 +1819,15 @@ private: void xabort(int8_t imm8); + void xaddb(Address dst, Register src); + void xaddw(Address dst, Register src); void xaddl(Address dst, Register src); - void xaddq(Address dst, Register src); void xbegin(Label& abort, relocInfo::relocType rtype = relocInfo::none); + void xchgb(Register reg, Address adr); + void xchgw(Register reg, Address adr); void xchgl(Register reg, Address adr); void xchgl(Register dst, Register src); diff --git a/hotspot/src/cpu/x86/vm/templateInterpreterGenerator_x86.cpp b/hotspot/src/cpu/x86/vm/templateInterpreterGenerator_x86.cpp index 6d07051c901..225850e8f40 100644 --- a/hotspot/src/cpu/x86/vm/templateInterpreterGenerator_x86.cpp +++ b/hotspot/src/cpu/x86/vm/templateInterpreterGenerator_x86.cpp @@ -473,7 +473,11 @@ void TemplateInterpreterGenerator::generate_counter_overflow(Label& do_continue) __ jmp(do_continue, relocInfo::none); } -// See if we've got enough room on the stack for locals plus overhead. +// See if we've got enough room on the stack for locals plus overhead below +// JavaThread::stack_overflow_limit(). If not, throw a StackOverflowError +// without going through the signal handler, i.e., reserved and yellow zones +// will not be made usable. The shadow zone must suffice to handle the +// overflow. // The expression stack grows down incrementally, so the normal guard // page mechanism will work for that. // @@ -518,40 +522,26 @@ void TemplateInterpreterGenerator::generate_stack_overflow_check(void) { __ get_thread(thread); #endif - const Address stack_base(thread, Thread::stack_base_offset()); - const Address stack_size(thread, Thread::stack_size_offset()); + const Address stack_limit(thread, JavaThread::stack_overflow_limit_offset()); // locals + overhead, in bytes __ mov(rax, rdx); - __ shlptr(rax, Interpreter::logStackElementSize); // 2 slots per parameter. + __ shlptr(rax, Interpreter::logStackElementSize); // Convert parameter count to bytes. __ addptr(rax, overhead_size); #ifdef ASSERT - Label stack_base_okay, stack_size_okay; - // verify that thread stack base is non-zero - __ cmpptr(stack_base, (int32_t)NULL_WORD); - __ jcc(Assembler::notEqual, stack_base_okay); - __ stop("stack base is zero"); - __ bind(stack_base_okay); - // verify that thread stack size is non-zero - __ cmpptr(stack_size, 0); - __ jcc(Assembler::notEqual, stack_size_okay); - __ stop("stack size is zero"); - __ bind(stack_size_okay); + Label limit_okay; + // Verify that thread stack overflow limit is non-zero. + __ cmpptr(stack_limit, (int32_t)NULL_WORD); + __ jcc(Assembler::notEqual, limit_okay); + __ stop("stack overflow limit is zero"); + __ bind(limit_okay); #endif - // Add stack base to locals and subtract stack size - __ addptr(rax, stack_base); - __ subptr(rax, stack_size); + // Add locals/frame size to stack limit. + __ addptr(rax, stack_limit); - // Use the bigger size for banging. - const int max_bang_size = (int)MAX2(JavaThread::stack_shadow_zone_size(), - JavaThread::stack_guard_zone_size()); - - // add in the red and yellow zone sizes - __ addptr(rax, max_bang_size); - - // check against the current stack bottom + // Check against the current stack bottom. __ cmpptr(rsp, rax); __ jcc(Assembler::above, after_frame_check_pop); @@ -782,8 +772,6 @@ address TemplateInterpreterGenerator::generate_Reference_get_entry(void) { return NULL; } -// TODO: rather than touching all pages, check against stack_overflow_limit and bang yellow page to -// generate exception. Windows might need this to map the shadow pages though. void TemplateInterpreterGenerator::bang_stack_shadow_pages(bool native_call) { // Quick & dirty stack overflow checking: bang the stack & handle trap. // Note that we do the banging after the frame is setup, since the exception @@ -945,7 +933,7 @@ address TemplateInterpreterGenerator::generate_native_entry(bool synchronized) { __ load_unsigned_short(t, Address(t, ConstMethod::size_of_parameters_offset())); #ifndef _LP64 - __ shlptr(t, Interpreter::logStackElementSize); + __ shlptr(t, Interpreter::logStackElementSize); // Convert parameter count to bytes. __ addptr(t, 2*wordSize); // allocate two more slots for JNIEnv and possible mirror __ subptr(rsp, t); __ andptr(rsp, -(StackAlignmentInBytes)); // gcc needs 16 byte aligned stacks to do XMM intrinsics diff --git a/hotspot/src/cpu/x86/vm/x86_32.ad b/hotspot/src/cpu/x86/vm/x86_32.ad index a45cb554e3c..4f7d3aacfd9 100644 --- a/hotspot/src/cpu/x86/vm/x86_32.ad +++ b/hotspot/src/cpu/x86/vm/x86_32.ad @@ -2127,6 +2127,31 @@ encode %{ emit_rm( cbuf, 0x0, 1, $mem_ptr$$reg ); %} + enc_class enc_cmpxchgb(eSIRegP mem_ptr) %{ + // [Lock] + if( os::is_MP() ) + emit_opcode(cbuf,0xF0); + + // CMPXCHGB [Eptr] + emit_opcode(cbuf,0x0F); + emit_opcode(cbuf,0xB0); + emit_rm( cbuf, 0x0, 1, $mem_ptr$$reg ); + %} + + enc_class enc_cmpxchgw(eSIRegP mem_ptr) %{ + // [Lock] + if( os::is_MP() ) + emit_opcode(cbuf,0xF0); + + // 16-bit mode + emit_opcode(cbuf, 0x66); + + // CMPXCHGW [Eptr] + emit_opcode(cbuf,0x0F); + emit_opcode(cbuf,0xB1); + emit_rm( cbuf, 0x0, 1, $mem_ptr$$reg ); + %} + enc_class enc_flags_ne_to_boolean( iRegI res ) %{ int res_encoding = $res$$reg; @@ -7262,6 +7287,34 @@ instruct compareAndSwapP( rRegI res, pRegP mem_ptr, eAXRegP oldval, eCXRegP new ins_pipe( pipe_cmpxchg ); %} +instruct compareAndSwapB( rRegI res, pRegP mem_ptr, eAXRegI oldval, eCXRegI newval, eFlagsReg cr ) %{ + match(Set res (CompareAndSwapB mem_ptr (Binary oldval newval))); + match(Set res (WeakCompareAndSwapB mem_ptr (Binary oldval newval))); + effect(KILL cr, KILL oldval); + format %{ "CMPXCHGB [$mem_ptr],$newval\t# If EAX==[$mem_ptr] Then store $newval into [$mem_ptr]\n\t" + "MOV $res,0\n\t" + "JNE,s fail\n\t" + "MOV $res,1\n" + "fail:" %} + ins_encode( enc_cmpxchgb(mem_ptr), + enc_flags_ne_to_boolean(res) ); + ins_pipe( pipe_cmpxchg ); +%} + +instruct compareAndSwapS( rRegI res, pRegP mem_ptr, eAXRegI oldval, eCXRegI newval, eFlagsReg cr ) %{ + match(Set res (CompareAndSwapS mem_ptr (Binary oldval newval))); + match(Set res (WeakCompareAndSwapS mem_ptr (Binary oldval newval))); + effect(KILL cr, KILL oldval); + format %{ "CMPXCHGW [$mem_ptr],$newval\t# If EAX==[$mem_ptr] Then store $newval into [$mem_ptr]\n\t" + "MOV $res,0\n\t" + "JNE,s fail\n\t" + "MOV $res,1\n" + "fail:" %} + ins_encode( enc_cmpxchgw(mem_ptr), + enc_flags_ne_to_boolean(res) ); + ins_pipe( pipe_cmpxchg ); +%} + instruct compareAndSwapI( rRegI res, pRegP mem_ptr, eAXRegI oldval, eCXRegI newval, eFlagsReg cr) %{ match(Set res (CompareAndSwapI mem_ptr (Binary oldval newval))); match(Set res (WeakCompareAndSwapI mem_ptr (Binary oldval newval))); @@ -7292,6 +7345,22 @@ instruct compareAndExchangeP( pRegP mem_ptr, eAXRegP oldval, eCXRegP newval, eFl ins_pipe( pipe_cmpxchg ); %} +instruct compareAndExchangeB( pRegP mem_ptr, eAXRegI oldval, eCXRegI newval, eFlagsReg cr) %{ + match(Set oldval (CompareAndExchangeB mem_ptr (Binary oldval newval))); + effect(KILL cr); + format %{ "CMPXCHGB [$mem_ptr],$newval\t# If EAX==[$mem_ptr] Then store $newval into [$mem_ptr]\n\t" %} + ins_encode( enc_cmpxchgb(mem_ptr) ); + ins_pipe( pipe_cmpxchg ); +%} + +instruct compareAndExchangeS( pRegP mem_ptr, eAXRegI oldval, eCXRegI newval, eFlagsReg cr) %{ + match(Set oldval (CompareAndExchangeS mem_ptr (Binary oldval newval))); + effect(KILL cr); + format %{ "CMPXCHGW [$mem_ptr],$newval\t# If EAX==[$mem_ptr] Then store $newval into [$mem_ptr]\n\t" %} + ins_encode( enc_cmpxchgw(mem_ptr) ); + ins_pipe( pipe_cmpxchg ); +%} + instruct compareAndExchangeI( pRegP mem_ptr, eAXRegI oldval, eCXRegI newval, eFlagsReg cr) %{ match(Set oldval (CompareAndExchangeI mem_ptr (Binary oldval newval))); effect(KILL cr); @@ -7300,6 +7369,53 @@ instruct compareAndExchangeI( pRegP mem_ptr, eAXRegI oldval, eCXRegI newval, eFl ins_pipe( pipe_cmpxchg ); %} +instruct xaddB_no_res( memory mem, Universe dummy, immI add, eFlagsReg cr) %{ + predicate(n->as_LoadStore()->result_not_used()); + match(Set dummy (GetAndAddB mem add)); + effect(KILL cr); + format %{ "ADDB [$mem],$add" %} + ins_encode %{ + if (os::is_MP()) { __ lock(); } + __ addb($mem$$Address, $add$$constant); + %} + ins_pipe( pipe_cmpxchg ); +%} + +// Important to match to xRegI: only 8-bit regs. +instruct xaddB( memory mem, xRegI newval, eFlagsReg cr) %{ + match(Set newval (GetAndAddB mem newval)); + effect(KILL cr); + format %{ "XADDB [$mem],$newval" %} + ins_encode %{ + if (os::is_MP()) { __ lock(); } + __ xaddb($mem$$Address, $newval$$Register); + %} + ins_pipe( pipe_cmpxchg ); +%} + +instruct xaddS_no_res( memory mem, Universe dummy, immI add, eFlagsReg cr) %{ + predicate(n->as_LoadStore()->result_not_used()); + match(Set dummy (GetAndAddS mem add)); + effect(KILL cr); + format %{ "ADDS [$mem],$add" %} + ins_encode %{ + if (os::is_MP()) { __ lock(); } + __ addw($mem$$Address, $add$$constant); + %} + ins_pipe( pipe_cmpxchg ); +%} + +instruct xaddS( memory mem, rRegI newval, eFlagsReg cr) %{ + match(Set newval (GetAndAddS mem newval)); + effect(KILL cr); + format %{ "XADDS [$mem],$newval" %} + ins_encode %{ + if (os::is_MP()) { __ lock(); } + __ xaddw($mem$$Address, $newval$$Register); + %} + ins_pipe( pipe_cmpxchg ); +%} + instruct xaddI_no_res( memory mem, Universe dummy, immI add, eFlagsReg cr) %{ predicate(n->as_LoadStore()->result_not_used()); match(Set dummy (GetAndAddI mem add)); @@ -7323,6 +7439,25 @@ instruct xaddI( memory mem, rRegI newval, eFlagsReg cr) %{ ins_pipe( pipe_cmpxchg ); %} +// Important to match to xRegI: only 8-bit regs. +instruct xchgB( memory mem, xRegI newval) %{ + match(Set newval (GetAndSetB mem newval)); + format %{ "XCHGB $newval,[$mem]" %} + ins_encode %{ + __ xchgb($newval$$Register, $mem$$Address); + %} + ins_pipe( pipe_cmpxchg ); +%} + +instruct xchgS( memory mem, rRegI newval) %{ + match(Set newval (GetAndSetS mem newval)); + format %{ "XCHGW $newval,[$mem]" %} + ins_encode %{ + __ xchgw($newval$$Register, $mem$$Address); + %} + ins_pipe( pipe_cmpxchg ); +%} + instruct xchgI( memory mem, rRegI newval) %{ match(Set newval (GetAndSetI mem newval)); format %{ "XCHGL $newval,[$mem]" %} diff --git a/hotspot/src/cpu/x86/vm/x86_64.ad b/hotspot/src/cpu/x86/vm/x86_64.ad index a680d60e994..52b58ec0281 100644 --- a/hotspot/src/cpu/x86/vm/x86_64.ad +++ b/hotspot/src/cpu/x86/vm/x86_64.ad @@ -7340,6 +7340,54 @@ instruct compareAndSwapI(rRegI res, ins_pipe( pipe_cmpxchg ); %} +instruct compareAndSwapB(rRegI res, + memory mem_ptr, + rax_RegI oldval, rRegI newval, + rFlagsReg cr) +%{ + match(Set res (CompareAndSwapB mem_ptr (Binary oldval newval))); + match(Set res (WeakCompareAndSwapB mem_ptr (Binary oldval newval))); + effect(KILL cr, KILL oldval); + + format %{ "cmpxchgb $mem_ptr,$newval\t# " + "If rax == $mem_ptr then store $newval into $mem_ptr\n\t" + "sete $res\n\t" + "movzbl $res, $res" %} + opcode(0x0F, 0xB0); + ins_encode(lock_prefix, + REX_reg_mem(newval, mem_ptr), + OpcP, OpcS, + reg_mem(newval, mem_ptr), + REX_breg(res), Opcode(0x0F), Opcode(0x94), reg(res), // sete + REX_reg_breg(res, res), // movzbl + Opcode(0xF), Opcode(0xB6), reg_reg(res, res)); + ins_pipe( pipe_cmpxchg ); +%} + +instruct compareAndSwapS(rRegI res, + memory mem_ptr, + rax_RegI oldval, rRegI newval, + rFlagsReg cr) +%{ + match(Set res (CompareAndSwapS mem_ptr (Binary oldval newval))); + match(Set res (WeakCompareAndSwapS mem_ptr (Binary oldval newval))); + effect(KILL cr, KILL oldval); + + format %{ "cmpxchgw $mem_ptr,$newval\t# " + "If rax == $mem_ptr then store $newval into $mem_ptr\n\t" + "sete $res\n\t" + "movzbl $res, $res" %} + opcode(0x0F, 0xB1); + ins_encode(lock_prefix, + SizePrefix, + REX_reg_mem(newval, mem_ptr), + OpcP, OpcS, + reg_mem(newval, mem_ptr), + REX_breg(res), Opcode(0x0F), Opcode(0x94), reg(res), // sete + REX_reg_breg(res, res), // movzbl + Opcode(0xF), Opcode(0xB6), reg_reg(res, res)); + ins_pipe( pipe_cmpxchg ); +%} instruct compareAndSwapN(rRegI res, memory mem_ptr, @@ -7364,6 +7412,45 @@ instruct compareAndSwapN(rRegI res, ins_pipe( pipe_cmpxchg ); %} +instruct compareAndExchangeB( + memory mem_ptr, + rax_RegI oldval, rRegI newval, + rFlagsReg cr) +%{ + match(Set oldval (CompareAndExchangeB mem_ptr (Binary oldval newval))); + effect(KILL cr); + + format %{ "cmpxchgb $mem_ptr,$newval\t# " + "If rax == $mem_ptr then store $newval into $mem_ptr\n\t" %} + opcode(0x0F, 0xB0); + ins_encode(lock_prefix, + REX_reg_mem(newval, mem_ptr), + OpcP, OpcS, + reg_mem(newval, mem_ptr) // lock cmpxchg + ); + ins_pipe( pipe_cmpxchg ); +%} + +instruct compareAndExchangeS( + memory mem_ptr, + rax_RegI oldval, rRegI newval, + rFlagsReg cr) +%{ + match(Set oldval (CompareAndExchangeS mem_ptr (Binary oldval newval))); + effect(KILL cr); + + format %{ "cmpxchgw $mem_ptr,$newval\t# " + "If rax == $mem_ptr then store $newval into $mem_ptr\n\t" %} + opcode(0x0F, 0xB1); + ins_encode(lock_prefix, + SizePrefix, + REX_reg_mem(newval, mem_ptr), + OpcP, OpcS, + reg_mem(newval, mem_ptr) // lock cmpxchg + ); + ins_pipe( pipe_cmpxchg ); +%} + instruct compareAndExchangeI( memory mem_ptr, rax_RegI oldval, rRegI newval, @@ -7441,6 +7528,52 @@ instruct compareAndExchangeP( ins_pipe( pipe_cmpxchg ); %} +instruct xaddB_no_res( memory mem, Universe dummy, immI add, rFlagsReg cr) %{ + predicate(n->as_LoadStore()->result_not_used()); + match(Set dummy (GetAndAddB mem add)); + effect(KILL cr); + format %{ "ADDB [$mem],$add" %} + ins_encode %{ + if (os::is_MP()) { __ lock(); } + __ addb($mem$$Address, $add$$constant); + %} + ins_pipe( pipe_cmpxchg ); +%} + +instruct xaddB( memory mem, rRegI newval, rFlagsReg cr) %{ + match(Set newval (GetAndAddB mem newval)); + effect(KILL cr); + format %{ "XADDB [$mem],$newval" %} + ins_encode %{ + if (os::is_MP()) { __ lock(); } + __ xaddb($mem$$Address, $newval$$Register); + %} + ins_pipe( pipe_cmpxchg ); +%} + +instruct xaddS_no_res( memory mem, Universe dummy, immI add, rFlagsReg cr) %{ + predicate(n->as_LoadStore()->result_not_used()); + match(Set dummy (GetAndAddS mem add)); + effect(KILL cr); + format %{ "ADDW [$mem],$add" %} + ins_encode %{ + if (os::is_MP()) { __ lock(); } + __ addw($mem$$Address, $add$$constant); + %} + ins_pipe( pipe_cmpxchg ); +%} + +instruct xaddS( memory mem, rRegI newval, rFlagsReg cr) %{ + match(Set newval (GetAndAddS mem newval)); + effect(KILL cr); + format %{ "XADDW [$mem],$newval" %} + ins_encode %{ + if (os::is_MP()) { __ lock(); } + __ xaddw($mem$$Address, $newval$$Register); + %} + ins_pipe( pipe_cmpxchg ); +%} + instruct xaddI_no_res( memory mem, Universe dummy, immI add, rFlagsReg cr) %{ predicate(n->as_LoadStore()->result_not_used()); match(Set dummy (GetAndAddI mem add)); @@ -7487,6 +7620,24 @@ instruct xaddL( memory mem, rRegL newval, rFlagsReg cr) %{ ins_pipe( pipe_cmpxchg ); %} +instruct xchgB( memory mem, rRegI newval) %{ + match(Set newval (GetAndSetB mem newval)); + format %{ "XCHGB $newval,[$mem]" %} + ins_encode %{ + __ xchgb($newval$$Register, $mem$$Address); + %} + ins_pipe( pipe_cmpxchg ); +%} + +instruct xchgS( memory mem, rRegI newval) %{ + match(Set newval (GetAndSetS mem newval)); + format %{ "XCHGW $newval,[$mem]" %} + ins_encode %{ + __ xchgw($newval$$Register, $mem$$Address); + %} + ins_pipe( pipe_cmpxchg ); +%} + instruct xchgI( memory mem, rRegI newval) %{ match(Set newval (GetAndSetI mem newval)); format %{ "XCHGL $newval,[$mem]" %} diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.aarch64/src/jdk/vm/ci/aarch64/AArch64.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.aarch64/src/jdk/vm/ci/aarch64/AArch64.java index 582d3004424..a21f0844c61 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.aarch64/src/jdk/vm/ci/aarch64/AArch64.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.aarch64/src/jdk/vm/ci/aarch64/AArch64.java @@ -28,6 +28,7 @@ import java.util.EnumSet; import jdk.vm.ci.code.Architecture; import jdk.vm.ci.code.Register; import jdk.vm.ci.code.Register.RegisterCategory; +import jdk.vm.ci.code.RegisterArray; import jdk.vm.ci.meta.JavaKind; import jdk.vm.ci.meta.PlatformKind; @@ -84,13 +85,13 @@ public class AArch64 extends Architecture { public static final Register lr = r30; // @formatter:off - public static final Register[] cpuRegisters = { + public static final RegisterArray cpuRegisters = new RegisterArray( r0, r1, r2, r3, r4, r5, r6, r7, r8, r9, r10, r11, r12, r13, r14, r15, r16, r17, r18, r19, r20, r21, r22, r23, r24, r25, r26, r27, r28, r29, r30, r31, zr, sp - }; + ); // @formatter:on public static final RegisterCategory SIMD = new RegisterCategory("SIMD"); @@ -130,16 +131,16 @@ public class AArch64 extends Architecture { public static final Register v31 = new Register(65, 31, "v31", SIMD); // @formatter:off - public static final Register[] simdRegisters = { + public static final RegisterArray simdRegisters = new RegisterArray( v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15, v16, v17, v18, v19, v20, v21, v22, v23, v24, v25, v26, v27, v28, v29, v30, v31 - }; + ); // @formatter:on // @formatter:off - public static final Register[] allRegisters = { + public static final RegisterArray allRegisters = new RegisterArray( r0, r1, r2, r3, r4, r5, r6, r7, r8, r9, r10, r11, r12, r13, r14, r15, r16, r17, r18, r19, r20, r21, r22, r23, @@ -150,7 +151,7 @@ public class AArch64 extends Architecture { v8, v9, v10, v11, v12, v13, v14, v15, v16, v17, v18, v19, v20, v21, v22, v23, v24, v25, v26, v27, v28, v29, v30, v31 - }; + ); // @formatter:on /** diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.amd64/src/jdk/vm/ci/amd64/AMD64.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.amd64/src/jdk/vm/ci/amd64/AMD64.java index 3fb9046711b..2e68bb8b8c9 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.amd64/src/jdk/vm/ci/amd64/AMD64.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.amd64/src/jdk/vm/ci/amd64/AMD64.java @@ -33,6 +33,7 @@ import java.util.EnumSet; import jdk.vm.ci.code.Architecture; import jdk.vm.ci.code.Register; import jdk.vm.ci.code.Register.RegisterCategory; +import jdk.vm.ci.code.RegisterArray; import jdk.vm.ci.meta.JavaKind; import jdk.vm.ci.meta.PlatformKind; @@ -131,14 +132,14 @@ public class AMD64 extends Architecture { public static final Register k6 = new Register(54, 6, "k6", MASK); public static final Register k7 = new Register(55, 7, "k7", MASK); - public static final Register[] valueRegistersSSE = { + public static final RegisterArray valueRegistersSSE = new RegisterArray( rax, rcx, rdx, rbx, rsp, rbp, rsi, rdi, r8, r9, r10, r11, r12, r13, r14, r15, xmm0, xmm1, xmm2, xmm3, xmm4, xmm5, xmm6, xmm7, xmm8, xmm9, xmm10, xmm11, xmm12, xmm13, xmm14, xmm15 - }; + ); - public static final Register[] valueRegistersAVX512 = { + public static final RegisterArray valueRegistersAVX512 = new RegisterArray( rax, rcx, rdx, rbx, rsp, rbp, rsi, rdi, r8, r9, r10, r11, r12, r13, r14, r15, xmm0, xmm1, xmm2, xmm3, xmm4, xmm5, xmm6, xmm7, @@ -146,14 +147,14 @@ public class AMD64 extends Architecture { xmm16, xmm17, xmm18, xmm19, xmm20, xmm21, xmm22, xmm23, xmm24, xmm25, xmm26, xmm27, xmm28, xmm29, xmm30, xmm31, k0, k1, k2, k3, k4, k5, k6, k7 - }; + ); /** * Register used to construct an instruction-relative address. */ public static final Register rip = new Register(56, -1, "rip", SPECIAL); - public static final Register[] allRegisters = { + public static final RegisterArray allRegisters = new RegisterArray( rax, rcx, rdx, rbx, rsp, rbp, rsi, rdi, r8, r9, r10, r11, r12, r13, r14, r15, xmm0, xmm1, xmm2, xmm3, xmm4, xmm5, xmm6, xmm7, @@ -162,7 +163,7 @@ public class AMD64 extends Architecture { xmm24, xmm25, xmm26, xmm27, xmm28, xmm29, xmm30, xmm31, k0, k1, k2, k3, k4, k5, k6, k7, rip - }; + ); // @formatter:on @@ -245,7 +246,7 @@ public class AMD64 extends Architecture { } @Override - public Register[] getAvailableValueRegisters() { + public RegisterArray getAvailableValueRegisters() { if (features.contains(CPUFeature.AVX512F)) { return valueRegistersAVX512; } else { diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/Architecture.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/Architecture.java index 10bf6a81fe7..3c2fc5aa4eb 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/Architecture.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/Architecture.java @@ -23,7 +23,6 @@ package jdk.vm.ci.code; import java.nio.ByteOrder; -import java.util.Arrays; import jdk.vm.ci.code.Register.RegisterCategory; import jdk.vm.ci.meta.JavaKind; @@ -46,10 +45,10 @@ public abstract class Architecture { private final String name; /** - * Array of all available registers on this architecture. The index of each register in this - * array is equal to its {@linkplain Register#number number}. + * List of all available registers on this architecture. The index of each register in this list + * is equal to its {@linkplain Register#number number}. */ - private final Register[] registers; + private final RegisterArray registers; /** * The byte ordering can be either little or big endian. @@ -78,7 +77,8 @@ public abstract class Architecture { */ private final int returnAddressSize; - protected Architecture(String name, PlatformKind wordKind, ByteOrder byteOrder, boolean unalignedMemoryAccess, Register[] registers, int implicitMemoryBarriers, int nativeCallDisplacementOffset, + protected Architecture(String name, PlatformKind wordKind, ByteOrder byteOrder, boolean unalignedMemoryAccess, RegisterArray registers, int implicitMemoryBarriers, + int nativeCallDisplacementOffset, int returnAddressSize) { this.name = name; this.registers = registers; @@ -120,20 +120,20 @@ public abstract class Architecture { } /** - * Gets an array of all registers that exist on this architecture. This contains all registers + * Gets the list of all registers that exist on this architecture. This contains all registers * that exist in the specification of this architecture. Not all of them may be available on - * this particular architecture instance. The index of each register in this array is equal to + * this particular architecture instance. The index of each register in this list is equal to * its {@linkplain Register#number number}. */ - public Register[] getRegisters() { - return registers.clone(); + public RegisterArray getRegisters() { + return registers; } /** - * Gets an array of all registers available for storing values on this architecture. This may be - * a subset of {@link #getRegisters()}, depending on the capabilities of this particular CPU. + * Gets a list of all registers available for storing values on this architecture. This may be a + * subset of {@link #getRegisters()}, depending on the capabilities of this particular CPU. */ - public Register[] getAvailableValueRegisters() { + public RegisterArray getAvailableValueRegisters() { return getRegisters(); } @@ -206,7 +206,7 @@ public abstract class Architecture { assert this.byteOrder.equals(that.byteOrder); assert this.implicitMemoryBarriers == that.implicitMemoryBarriers; assert this.machineCodeCallDisplacementOffset == that.machineCodeCallDisplacementOffset; - assert Arrays.equals(this.registers, that.registers); + assert this.registers.equals(that.registers); assert this.returnAddressSize == that.returnAddressSize; assert this.unalignedMemoryAccess == that.unalignedMemoryAccess; assert this.wordKind == that.wordKind; diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/BytecodeFrame.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/BytecodeFrame.java index d7aa4af0133..f731cdd3235 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/BytecodeFrame.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/BytecodeFrame.java @@ -34,7 +34,7 @@ import jdk.vm.ci.meta.Value; * where to find the local variables, operand stack values and locked objects of the bytecode * frame(s). */ -public class BytecodeFrame extends BytecodePosition { +public final class BytecodeFrame extends BytecodePosition { /** * An array of values representing how to reconstruct the state of the Java frame. This is array @@ -65,14 +65,18 @@ public class BytecodeFrame extends BytecodePosition { *

* Note that the number of locals and the number of stack slots may be smaller than the maximum * number of locals and stack slots as specified in the compiled method. + * + * This field is intentionally exposed as a mutable array that a compiler may modify (e.g. + * during register allocation). */ + @SuppressFBWarnings(value = "EI_EXPOSE_REP2", justification = "field is intentionally mutable")// public final JavaValue[] values; /** - * An array describing the Java kind of the {@link #values}. It records a kind for the locals - * and the operand stack. + * An array describing the Java kinds in {@link #values}. It records a kind for the locals and + * the operand stack. */ - public final JavaKind[] slotKinds; + private final JavaKind[] slotKinds; /** * The number of locals in the values array. @@ -99,8 +103,8 @@ public class BytecodeFrame extends BytecodePosition { public final boolean rethrowException; /** - * Specifies if this object represents a frame state in the middle of executing a call. If - * true, the arguments to the call have been popped from the stack and the return value (for a + * Specifies if this object represents a frame state in the middle of executing a call. If true, + * the arguments to the call have been popped from the stack and the return value (for a * non-void call) has not yet been pushed. */ public final boolean duringCall; @@ -178,11 +182,14 @@ public class BytecodeFrame extends BytecodePosition { * @param bci a BCI within the method * @param rethrowException specifies if the VM should re-throw the pending exception when * deopt'ing using this frame - * @param values the frame state {@link #values} + * @param values the frame state {@link #values}. + * @param slotKinds the kinds in {@code values}. This array is now owned by this object and must + * not be mutated by the caller. * @param numLocals the number of local variables * @param numStack the depth of the stack * @param numLocks the number of locked objects */ + @SuppressFBWarnings(value = "EI_EXPOSE_REP2", justification = "caller transfers ownership of `slotKinds`") public BytecodeFrame(BytecodeFrame caller, ResolvedJavaMethod method, int bci, boolean rethrowException, boolean duringCall, JavaValue[] values, JavaKind[] slotKinds, int numLocals, int numStack, int numLocks) { super(caller, method, bci); @@ -218,13 +225,45 @@ public class BytecodeFrame extends BytecodePosition { return true; } + /** + * Gets the kind of a local variable. + * + * @param i the local variable to query + * @return the kind of local variable {@code i} + * @throw {@link IndexOutOfBoundsException} if {@code i < 0 || i >= this.numLocals} + */ + public JavaKind getLocalValueKind(int i) { + if (i < 0 || i >= numLocals) { + throw new IndexOutOfBoundsException(); + } + return slotKinds[i]; + } + + /** + * Gets the kind of a stack slot. + * + * @param i the local variable to query + * @return the kind of stack slot {@code i} + * @throw {@link IndexOutOfBoundsException} if {@code i < 0 || i >= this.numStack} + */ + public JavaKind getStackValueKind(int i) { + if (i < 0 || i >= numStack) { + throw new IndexOutOfBoundsException(); + } + return slotKinds[i + numLocals]; + } + /** * Gets the value representing the specified local variable. * * @param i the local variable index * @return the value that can be used to reconstruct the local's current value + * @throw {@link IndexOutOfBoundsException} if {@code i < 0 || i >= this.numLocals} */ public JavaValue getLocalValue(int i) { + if (i < 0 || i >= numLocals) { + throw new IndexOutOfBoundsException(); + } return values[i]; } @@ -233,8 +272,12 @@ public class BytecodeFrame extends BytecodePosition { * * @param i the stack index * @return the value that can be used to reconstruct the stack slot's current value + * @throw {@link IndexOutOfBoundsException} if {@code i < 0 || i >= this.numStack} */ public JavaValue getStackValue(int i) { + if (i < 0 || i >= numStack) { + throw new IndexOutOfBoundsException(); + } return values[i + numLocals]; } @@ -243,8 +286,12 @@ public class BytecodeFrame extends BytecodePosition { * * @param i the lock index * @return the value that can be used to reconstruct the lock's current value + * @throw {@link IndexOutOfBoundsException} if {@code i < 0 || i >= this.numLocks} */ public JavaValue getLockValue(int i) { + if (i < 0 || i >= numLocks) { + throw new IndexOutOfBoundsException(); + } return values[i + numLocals + numStack]; } @@ -257,6 +304,11 @@ public class BytecodeFrame extends BytecodePosition { return (BytecodeFrame) getCaller(); } + @Override + public int hashCode() { + return (numLocals + 1) ^ (numStack + 11) ^ (numLocks + 7); + } + @Override public boolean equals(Object obj) { if (this == obj) { diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/CallingConvention.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/CallingConvention.java index 240b4be1423..1c839e9ba54 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/CallingConvention.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/CallingConvention.java @@ -100,6 +100,7 @@ public class CallingConvention { /** * Gets the locations required for the arguments. */ + @SuppressFBWarnings(value = "EI_EXPOSE_REP", justification = "FB false positive") public AllocatableValue[] getArguments() { if (argumentLocations.length == 0) { return argumentLocations; diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/DebugInfo.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/DebugInfo.java index be7729fb76f..0638d139739 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/DebugInfo.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/DebugInfo.java @@ -48,8 +48,10 @@ public final class DebugInfo { * * @param codePos the {@linkplain BytecodePosition code position} or {@linkplain BytecodeFrame * frame} info - * @param virtualObjectMapping the mapping of {@link VirtualObject}s to their real values + * @param virtualObjectMapping the mapping of {@link VirtualObject}s to their real values. This + * array is now owned by this object and must not be mutated by the caller. */ + @SuppressFBWarnings(value = "EI_EXPOSE_REP2", justification = "caller transfers ownership of `virtualObjectMapping`") public DebugInfo(BytecodePosition codePos, VirtualObject[] virtualObjectMapping) { this.bytecodePosition = codePos; this.virtualObjectMapping = virtualObjectMapping; diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterArray.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterArray.java new file mode 100644 index 00000000000..a7fac1f2d3d --- /dev/null +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterArray.java @@ -0,0 +1,105 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +package jdk.vm.ci.code; + +import java.util.Arrays; +import java.util.Collection; +import java.util.Collections; +import java.util.Iterator; +import java.util.List; + +/** + * An immutable ordered list of registers. Only required because Java lacks immutable arrays. + */ +public final class RegisterArray implements Iterable { + + private final Register[] registers; + private int hash; + + public RegisterArray(Register... registers) { + this.registers = registers; + } + + public RegisterArray(Collection registers) { + this.registers = registers.toArray(new Register[registers.size()]); + } + + /** + * Gets the number of registers. + */ + public int size() { + return registers.length; + } + + /** + * Gets the register at a given index. + * + * @param index the index of the register to retrieve + */ + public Register get(int index) { + return registers[index]; + } + + public void addTo(Collection collection) { + collection.addAll(Arrays.asList(registers)); + } + + /** + * Gets an immutable view of the registers as a list. + */ + public List asList() { + return Collections.unmodifiableList(Arrays.asList(registers)); + } + + /** + * Gets a copy of the registers as an array. + */ + public Register[] toArray() { + return registers.clone(); + } + + public Iterator iterator() { + return Arrays.asList(registers).iterator(); + } + + @Override + public int hashCode() { + if (hash == 0 && registers.length > 0) { + hash = Arrays.hashCode(registers); + } + return hash; + } + + @Override + public boolean equals(Object obj) { + if (obj instanceof RegisterArray) { + return Arrays.equals(registers, ((RegisterArray) obj).registers); + } + return false; + } + + @Override + public String toString() { + return Arrays.toString(registers); + } +} diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterAttributes.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterAttributes.java index b8c15075627..cde1df0bfc5 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterAttributes.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterAttributes.java @@ -23,6 +23,8 @@ package jdk.vm.ci.code; import java.util.Arrays; +import java.util.Collections; +import java.util.List; /** * A collection of register attributes. The specific attribute values for a register may be local to @@ -53,13 +55,14 @@ public class RegisterAttributes { * @return an array whose length is the max register number in {@code registers} plus 1. An * element at index i holds the attributes of the register whose number is i. */ - public static RegisterAttributes[] createMap(RegisterConfig registerConfig, Register[] registers) { - RegisterAttributes[] map = new RegisterAttributes[registers.length]; + public static RegisterAttributes[] createMap(RegisterConfig registerConfig, RegisterArray registers) { + RegisterAttributes[] map = new RegisterAttributes[registers.size()]; + List callerSaveRegisters = registerConfig.getCallerSaveRegisters().asList(); + List calleeSaveRegisters = registerConfig.getCalleeSaveRegisters() == null ? Collections.emptyList() : registerConfig.getCalleeSaveRegisters().asList(); + List allocatableRegisters = registerConfig.getAllocatableRegisters().asList(); for (Register reg : registers) { if (reg != null) { - Register[] csr = registerConfig.getCalleeSaveRegisters(); - RegisterAttributes attr = new RegisterAttributes(Arrays.asList(registerConfig.getCallerSaveRegisters()).contains(reg), csr == null ? false : Arrays.asList(csr).contains(reg), - Arrays.asList(registerConfig.getAllocatableRegisters()).contains(reg)); + RegisterAttributes attr = new RegisterAttributes(callerSaveRegisters.contains(reg), calleeSaveRegisters.contains(reg), allocatableRegisters.contains(reg)); if (map.length <= reg.number) { map = Arrays.copyOf(map, reg.number + 1); } @@ -75,23 +78,24 @@ public class RegisterAttributes { } /** - * @return Denotes a register that is available for use by a register allocator. + * @return {@code true} if a register is available for use by a register allocator otherwise + * {@code false} */ public boolean isAllocatable() { return allocatable; } /** - * @return Denotes a register whose value preservation (if required) across a call is the - * responsibility of the callee. + * @return {@code true} if a register whose value preservation (if required) across a call is + * the responsibility of the callee otherwise {@code false} */ public boolean isCalleeSave() { return calleeSave; } /** - * @return Denotes a register whose value preservation (if required) across a call is the - * responsibility of the caller. + * @return {@code true} if a register whose value preservation (if required) across a call is + * the responsibility of the caller otherwise {@code false} */ public boolean isCallerSave() { return callerSave; diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterConfig.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterConfig.java index d2b83496af9..fac19780ae0 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterConfig.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterConfig.java @@ -71,7 +71,7 @@ public interface RegisterConfig { * @return the ordered set of registers that may be used to pass parameters in a call conforming * to {@code type} */ - Register[] getCallingConventionRegisters(Type type, JavaKind kind); + RegisterArray getCallingConventionRegisters(Type type, JavaKind kind); /** * Gets the set of all registers that might be used by the register allocator. @@ -80,23 +80,23 @@ public interface RegisterConfig { * {@link RegisterAllocationConfig#getAllocatableRegisters()} */ @SuppressWarnings("javadoc") - Register[] getAllocatableRegisters(); + RegisterArray getAllocatableRegisters(); /** * Filters a set of registers and returns only those that can be used by the register allocator * for a value of a particular kind. */ - Register[] filterAllocatableRegisters(PlatformKind kind, Register[] registers); + RegisterArray filterAllocatableRegisters(PlatformKind kind, RegisterArray registers); /** * Gets the registers whose values must be preserved by a method across any call it makes. */ - Register[] getCallerSaveRegisters(); + RegisterArray getCallerSaveRegisters(); /** * Gets the registers whose values must be preserved by the callee. */ - Register[] getCalleeSaveRegisters(); + RegisterArray getCalleeSaveRegisters(); /** * Gets a map from register {@linkplain Register#number numbers} to register diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterSaveLayout.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterSaveLayout.java index 86b92579654..bc7421b9741 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterSaveLayout.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/RegisterSaveLayout.java @@ -50,6 +50,7 @@ public final class RegisterSaveLayout { * @param registers the keys in the map * @param slots frame slot index for each register in {@code registers} */ + @SuppressFBWarnings(value = "EI_EXPOSE_REP2", justification = "caller transfers ownership of `registers` and `slots`") public RegisterSaveLayout(Register[] registers, int[] slots) { assert registers.length == slots.length; this.registers = registers; diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMConstant.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/SuppressFBWarnings.java similarity index 55% rename from hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMConstant.java rename to hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/SuppressFBWarnings.java index 10da8b6ecdd..21a59625b13 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMConstant.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/SuppressFBWarnings.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -20,32 +20,21 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ -package jdk.vm.ci.hotspotvmconfig; - -import java.lang.annotation.ElementType; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.Target; +package jdk.vm.ci.code; /** - * Refers to a C++ constant in the VM. + * Used to suppress FindBugs warnings. */ -@Target(ElementType.FIELD) -@Retention(RetentionPolicy.RUNTIME) -public @interface HotSpotVMConstant { +@interface SuppressFBWarnings { + /** + * The set of FindBugs + * warnings that are to be + * suppressed in annotated element. The value can be a bug category, kind or pattern. + */ + String[] value(); /** - * Returns the name of the constant. - * - * @return name of constant + * Reason why the warning is suppressed. */ - String name(); - - /** - * List of architectures where this constant is required. Names are derived from - * {@link HotSpotVMConfig#getHostArchitectureName()}. An empty list implies that the constant is - * required on all architectures. - */ - @SuppressWarnings("javadoc") - String[] archs() default {}; + String justification(); } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/VirtualObject.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/VirtualObject.java index 7b4b2e60af7..60ef30078cd 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/VirtualObject.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.code/src/jdk/vm/ci/code/VirtualObject.java @@ -119,17 +119,20 @@ public final class VirtualObject implements JavaValue { } /** - * Returns an array containing all the values to be stored into the object when it is recreated. + * Returns the array containing all the values to be stored into the object when it is + * recreated. This field is intentional exposed as a mutable array that a compiler may modify + * (e.g. during register allocation). */ + @SuppressFBWarnings(value = "EI_EXPOSE_REP", justification = "`values` is intentional mutable")// public JavaValue[] getValues() { return values; } /** - * Returns an array containing the Java kind of all values in the object. + * Returns the kind of the value at {@code index}. */ - public JavaKind[] getSlotKinds() { - return slotKinds; + public JavaKind getSlotKind(int index) { + return slotKinds[index]; } /** @@ -145,9 +148,13 @@ public final class VirtualObject implements JavaValue { * * @param values an array containing all the values to be stored into the object when it is * recreated. - * @param slotKinds an array containing the Java kinds of the values. + * @param slotKinds an array containing the Java kinds of the values. This must have the same + * length as {@code values}. This array is now owned by this object and must not be + * mutated by the caller. */ + @SuppressFBWarnings(value = "EI_EXPOSE_REP2", justification = "caller transfers ownership of `slotKinds`") public void setValues(JavaValue[] values, JavaKind[] slotKinds) { + assert values.length == slotKinds.length; this.values = values; this.slotKinds = slotKinds; } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.common/src/jdk/vm/ci/common/InitTimer.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.common/src/jdk/vm/ci/common/InitTimer.java index 85eb72e49ac..19af5f5a0d9 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.common/src/jdk/vm/ci/common/InitTimer.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.common/src/jdk/vm/ci/common/InitTimer.java @@ -30,8 +30,8 @@ import java.util.concurrent.atomic.AtomicInteger; * {@code "jvmci.inittimer"} system property to {@code "true"}. */ public final class InitTimer implements AutoCloseable { - final String name; - final long start; + private final String name; + private final long start; private InitTimer(String name) { int n = nesting.getAndIncrement(); @@ -76,5 +76,5 @@ public final class InitTimer implements AutoCloseable { /** * Used to assert the invariant that all related initialization happens on the same thread. */ - public static Thread initializingThread; + static Thread initializingThread; } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.aarch64/src/jdk/vm/ci/hotspot/aarch64/AArch64HotSpotJVMCIBackendFactory.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.aarch64/src/jdk/vm/ci/hotspot/aarch64/AArch64HotSpotJVMCIBackendFactory.java index 86ab33b915e..42d6a159d43 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.aarch64/src/jdk/vm/ci/hotspot/aarch64/AArch64HotSpotJVMCIBackendFactory.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.aarch64/src/jdk/vm/ci/hotspot/aarch64/AArch64HotSpotJVMCIBackendFactory.java @@ -38,24 +38,23 @@ import jdk.vm.ci.hotspot.HotSpotJVMCIBackendFactory; import jdk.vm.ci.hotspot.HotSpotJVMCIRuntimeProvider; import jdk.vm.ci.hotspot.HotSpotMetaAccessProvider; import jdk.vm.ci.hotspot.HotSpotStackIntrospection; -import jdk.vm.ci.hotspot.HotSpotVMConfig; import jdk.vm.ci.meta.ConstantReflectionProvider; import jdk.vm.ci.runtime.JVMCIBackend; public class AArch64HotSpotJVMCIBackendFactory implements HotSpotJVMCIBackendFactory { - protected EnumSet computeFeatures(@SuppressWarnings("unused") HotSpotVMConfig config) { + protected EnumSet computeFeatures(@SuppressWarnings("unused") AArch64HotSpotVMConfig config) { // Configure the feature set using the HotSpot flag settings. EnumSet features = EnumSet.noneOf(AArch64.CPUFeature.class); return features; } - protected EnumSet computeFlags(@SuppressWarnings("unused") HotSpotVMConfig config) { + protected EnumSet computeFlags(@SuppressWarnings("unused") AArch64HotSpotVMConfig config) { EnumSet flags = EnumSet.noneOf(AArch64.Flag.class); return flags; } - protected TargetDescription createTarget(HotSpotVMConfig config) { + protected TargetDescription createTarget(AArch64HotSpotVMConfig config) { final int stackFrameAlignment = 16; final int implicitNullCheckLimit = 4096; final boolean inlineObjects = true; @@ -67,8 +66,8 @@ public class AArch64HotSpotJVMCIBackendFactory implements HotSpotJVMCIBackendFac return new HotSpotConstantReflectionProvider(runtime); } - protected RegisterConfig createRegisterConfig(HotSpotJVMCIRuntimeProvider runtime, TargetDescription target) { - return new AArch64HotSpotRegisterConfig(target, runtime.getConfig()); + protected RegisterConfig createRegisterConfig(AArch64HotSpotVMConfig config, TargetDescription target) { + return new AArch64HotSpotRegisterConfig(target, config.useCompressedOops); } protected HotSpotCodeCacheProvider createCodeCache(HotSpotJVMCIRuntimeProvider runtime, TargetDescription target, RegisterConfig regConfig) { @@ -93,7 +92,8 @@ public class AArch64HotSpotJVMCIBackendFactory implements HotSpotJVMCIBackendFac public JVMCIBackend createJVMCIBackend(HotSpotJVMCIRuntimeProvider runtime, JVMCIBackend host) { assert host == null; - TargetDescription target = createTarget(runtime.getConfig()); + AArch64HotSpotVMConfig config = new AArch64HotSpotVMConfig(runtime.getConfigStore()); + TargetDescription target = createTarget(config); RegisterConfig regConfig; HotSpotCodeCacheProvider codeCache; @@ -105,7 +105,7 @@ public class AArch64HotSpotJVMCIBackendFactory implements HotSpotJVMCIBackendFac metaAccess = createMetaAccess(runtime); } try (InitTimer rt = timer("create RegisterConfig")) { - regConfig = createRegisterConfig(runtime, target); + regConfig = createRegisterConfig(config, target); } try (InitTimer rt = timer("create CodeCache provider")) { codeCache = createCodeCache(runtime, target, regConfig); diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.aarch64/src/jdk/vm/ci/hotspot/aarch64/AArch64HotSpotRegisterConfig.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.aarch64/src/jdk/vm/ci/hotspot/aarch64/AArch64HotSpotRegisterConfig.java index 41a85806197..24f4e02eca6 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.aarch64/src/jdk/vm/ci/hotspot/aarch64/AArch64HotSpotRegisterConfig.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.aarch64/src/jdk/vm/ci/hotspot/aarch64/AArch64HotSpotRegisterConfig.java @@ -49,8 +49,6 @@ import static jdk.vm.ci.aarch64.AArch64.v7; import static jdk.vm.ci.aarch64.AArch64.zr; import java.util.ArrayList; -import java.util.Arrays; -import java.util.Collections; import java.util.HashSet; import java.util.List; import java.util.Set; @@ -60,6 +58,7 @@ import jdk.vm.ci.code.Architecture; import jdk.vm.ci.code.CallingConvention; import jdk.vm.ci.code.CallingConvention.Type; import jdk.vm.ci.code.Register; +import jdk.vm.ci.code.RegisterArray; import jdk.vm.ci.code.RegisterAttributes; import jdk.vm.ci.code.RegisterConfig; import jdk.vm.ci.code.StackSlot; @@ -67,7 +66,6 @@ import jdk.vm.ci.code.TargetDescription; import jdk.vm.ci.code.ValueKindFactory; import jdk.vm.ci.common.JVMCIError; import jdk.vm.ci.hotspot.HotSpotCallingConventionType; -import jdk.vm.ci.hotspot.HotSpotVMConfig; import jdk.vm.ci.meta.AllocatableValue; import jdk.vm.ci.meta.JavaKind; import jdk.vm.ci.meta.JavaType; @@ -79,30 +77,24 @@ public class AArch64HotSpotRegisterConfig implements RegisterConfig { private final TargetDescription target; - private final Register[] allocatable; - - private final int maxFrameSize; + private final RegisterArray allocatable; /** * The caller saved registers always include all parameter registers. */ - private final Register[] callerSaved; + private final RegisterArray callerSaved; private final boolean allAllocatableAreCallerSaved; private final RegisterAttributes[] attributesMap; - public int getMaximumFrameSize() { - return maxFrameSize; + @Override + public RegisterArray getAllocatableRegisters() { + return allocatable; } @Override - public Register[] getAllocatableRegisters() { - return allocatable.clone(); - } - - @Override - public Register[] filterAllocatableRegisters(PlatformKind kind, Register[] registers) { + public RegisterArray filterAllocatableRegisters(PlatformKind kind, RegisterArray registers) { ArrayList list = new ArrayList<>(); for (Register reg : registers) { if (target.arch.canStoreValue(reg.getRegisterCategory(), kind)) { @@ -110,8 +102,7 @@ public class AArch64HotSpotRegisterConfig implements RegisterConfig { } } - Register[] ret = list.toArray(new Register[list.size()]); - return ret; + return new RegisterArray(list); } @Override @@ -119,9 +110,9 @@ public class AArch64HotSpotRegisterConfig implements RegisterConfig { return attributesMap.clone(); } - private final Register[] javaGeneralParameterRegisters = {r1, r2, r3, r4, r5, r6, r7, r0}; - private final Register[] nativeGeneralParameterRegisters = {r0, r1, r2, r3, r4, r5, r6, r7}; - private final Register[] simdParameterRegisters = {v0, v1, v2, v3, v4, v5, v6, v7}; + private final RegisterArray javaGeneralParameterRegisters = new RegisterArray(r1, r2, r3, r4, r5, r6, r7, r0); + private final RegisterArray nativeGeneralParameterRegisters = new RegisterArray(r0, r1, r2, r3, r4, r5, r6, r7); + private final RegisterArray simdParameterRegisters = new RegisterArray(v0, v1, v2, v3, v4, v5, v6, v7); public static final Register inlineCacheRegister = r9; @@ -134,12 +125,12 @@ public class AArch64HotSpotRegisterConfig implements RegisterConfig { public static final Register threadRegister = r28; public static final Register fp = r29; - private static final Register[] reservedRegisters = {threadRegister, fp, lr, r31, zr, sp}; + private static final RegisterArray reservedRegisters = new RegisterArray(threadRegister, fp, lr, r31, zr, sp); - private static Register[] initAllocatable(Architecture arch, boolean reserveForHeapBase) { - Register[] allRegisters = arch.getAvailableValueRegisters(); - Register[] registers = new Register[allRegisters.length - reservedRegisters.length - (reserveForHeapBase ? 1 : 0)]; - List reservedRegistersList = Arrays.asList(reservedRegisters); + private static RegisterArray initAllocatable(Architecture arch, boolean reserveForHeapBase) { + RegisterArray allRegisters = arch.getAvailableValueRegisters(); + Register[] registers = new Register[allRegisters.size() - reservedRegisters.size() - (reserveForHeapBase ? 1 : 0)]; + List reservedRegistersList = reservedRegisters.asList(); int idx = 0; for (Register reg : allRegisters) { @@ -157,36 +148,35 @@ public class AArch64HotSpotRegisterConfig implements RegisterConfig { } assert idx == registers.length; - return registers; + return new RegisterArray(registers); } - public AArch64HotSpotRegisterConfig(TargetDescription target, HotSpotVMConfig config) { - this(target, config, initAllocatable(target.arch, config.useCompressedOops)); - assert callerSaved.length >= allocatable.length; + public AArch64HotSpotRegisterConfig(TargetDescription target, boolean useCompressedOops) { + this(target, initAllocatable(target.arch, useCompressedOops)); + assert callerSaved.size() >= allocatable.size(); } - public AArch64HotSpotRegisterConfig(TargetDescription target, HotSpotVMConfig config, Register[] allocatable) { + public AArch64HotSpotRegisterConfig(TargetDescription target, RegisterArray allocatable) { this.target = target; - this.maxFrameSize = config.maxFrameSize; - this.allocatable = allocatable.clone(); + this.allocatable = allocatable; Set callerSaveSet = new HashSet<>(); - Collections.addAll(callerSaveSet, allocatable); - Collections.addAll(callerSaveSet, simdParameterRegisters); - Collections.addAll(callerSaveSet, javaGeneralParameterRegisters); - Collections.addAll(callerSaveSet, nativeGeneralParameterRegisters); - callerSaved = callerSaveSet.toArray(new Register[callerSaveSet.size()]); + allocatable.addTo(callerSaveSet); + simdParameterRegisters.addTo(callerSaveSet); + javaGeneralParameterRegisters.addTo(callerSaveSet); + nativeGeneralParameterRegisters.addTo(callerSaveSet); + callerSaved = new RegisterArray(callerSaveSet); allAllocatableAreCallerSaved = true; attributesMap = RegisterAttributes.createMap(this, AArch64.allRegisters); } @Override - public Register[] getCallerSaveRegisters() { + public RegisterArray getCallerSaveRegisters() { return callerSaved; } - public Register[] getCalleeSaveRegisters() { + public RegisterArray getCalleeSaveRegisters() { return null; } @@ -207,7 +197,7 @@ public class AArch64HotSpotRegisterConfig implements RegisterConfig { } @Override - public Register[] getCallingConventionRegisters(Type type, JavaKind kind) { + public RegisterArray getCallingConventionRegisters(Type type, JavaKind kind) { HotSpotCallingConventionType hotspotType = (HotSpotCallingConventionType) type; switch (kind) { case Boolean: @@ -226,7 +216,7 @@ public class AArch64HotSpotRegisterConfig implements RegisterConfig { } } - private CallingConvention callingConvention(Register[] generalParameterRegisters, JavaType returnType, JavaType[] parameterTypes, HotSpotCallingConventionType type, + private CallingConvention callingConvention(RegisterArray generalParameterRegisters, JavaType returnType, JavaType[] parameterTypes, HotSpotCallingConventionType type, ValueKindFactory valueKindFactory) { AllocatableValue[] locations = new AllocatableValue[parameterTypes.length]; @@ -245,15 +235,15 @@ public class AArch64HotSpotRegisterConfig implements RegisterConfig { case Int: case Long: case Object: - if (currentGeneral < generalParameterRegisters.length) { - Register register = generalParameterRegisters[currentGeneral++]; + if (currentGeneral < generalParameterRegisters.size()) { + Register register = generalParameterRegisters.get(currentGeneral++); locations[i] = register.asValue(valueKindFactory.getValueKind(kind)); } break; case Float: case Double: - if (currentSIMD < simdParameterRegisters.length) { - Register register = simdParameterRegisters[currentSIMD++]; + if (currentSIMD < simdParameterRegisters.size()) { + Register register = simdParameterRegisters.get(currentSIMD++); locations[i] = register.asValue(valueKindFactory.getValueKind(kind)); } break; @@ -302,6 +292,6 @@ public class AArch64HotSpotRegisterConfig implements RegisterConfig { @Override public String toString() { - return String.format("Allocatable: " + Arrays.toString(getAllocatableRegisters()) + "%n" + "CallerSave: " + Arrays.toString(getCallerSaveRegisters()) + "%n"); + return String.format("Allocatable: " + getAllocatableRegisters() + "%n" + "CallerSave: " + getCallerSaveRegisters() + "%n"); } } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.aarch64/src/jdk/vm/ci/hotspot/aarch64/AArch64HotSpotVMConfig.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.aarch64/src/jdk/vm/ci/hotspot/aarch64/AArch64HotSpotVMConfig.java new file mode 100644 index 00000000000..41dd2ef7677 --- /dev/null +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.aarch64/src/jdk/vm/ci/hotspot/aarch64/AArch64HotSpotVMConfig.java @@ -0,0 +1,42 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +package jdk.vm.ci.hotspot.aarch64; + +import jdk.vm.ci.hotspot.HotSpotVMConfigAccess; +import jdk.vm.ci.hotspot.HotSpotVMConfigStore; + +/** + * Used to access native configuration details. + * + * All non-static, public fields in this class are so that they can be compiled as constants. + */ +class AArch64HotSpotVMConfig extends HotSpotVMConfigAccess { + + AArch64HotSpotVMConfig(HotSpotVMConfigStore config) { + super(config); + } + + final boolean linuxOs = System.getProperty("os.name", "").startsWith("Linux"); + + final boolean useCompressedOops = getFlag("UseCompressedOops", Boolean.class); +} diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.amd64/src/jdk/vm/ci/hotspot/amd64/AMD64HotSpotJVMCIBackendFactory.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.amd64/src/jdk/vm/ci/hotspot/amd64/AMD64HotSpotJVMCIBackendFactory.java index 474153c707e..fa749bf2735 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.amd64/src/jdk/vm/ci/hotspot/amd64/AMD64HotSpotJVMCIBackendFactory.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.amd64/src/jdk/vm/ci/hotspot/amd64/AMD64HotSpotJVMCIBackendFactory.java @@ -38,13 +38,12 @@ import jdk.vm.ci.hotspot.HotSpotJVMCIBackendFactory; import jdk.vm.ci.hotspot.HotSpotJVMCIRuntimeProvider; import jdk.vm.ci.hotspot.HotSpotMetaAccessProvider; import jdk.vm.ci.hotspot.HotSpotStackIntrospection; -import jdk.vm.ci.hotspot.HotSpotVMConfig; import jdk.vm.ci.meta.ConstantReflectionProvider; import jdk.vm.ci.runtime.JVMCIBackend; public class AMD64HotSpotJVMCIBackendFactory implements HotSpotJVMCIBackendFactory { - protected EnumSet computeFeatures(HotSpotVMConfig config) { + protected EnumSet computeFeatures(AMD64HotSpotVMConfig config) { // Configure the feature set using the HotSpot flag settings. EnumSet features = EnumSet.noneOf(AMD64.CPUFeature.class); if ((config.vmVersionFeatures & config.amd643DNOWPREFETCH) != 0) { @@ -128,7 +127,7 @@ public class AMD64HotSpotJVMCIBackendFactory implements HotSpotJVMCIBackendFacto return features; } - protected EnumSet computeFlags(HotSpotVMConfig config) { + protected EnumSet computeFlags(AMD64HotSpotVMConfig config) { EnumSet flags = EnumSet.noneOf(AMD64.Flag.class); if (config.useCountLeadingZerosInstruction) { flags.add(AMD64.Flag.UseCountLeadingZerosInstruction); @@ -139,7 +138,7 @@ public class AMD64HotSpotJVMCIBackendFactory implements HotSpotJVMCIBackendFacto return flags; } - protected TargetDescription createTarget(HotSpotVMConfig config) { + protected TargetDescription createTarget(AMD64HotSpotVMConfig config) { final int stackFrameAlignment = 16; final int implicitNullCheckLimit = 4096; final boolean inlineObjects = true; @@ -151,8 +150,8 @@ public class AMD64HotSpotJVMCIBackendFactory implements HotSpotJVMCIBackendFacto return new HotSpotConstantReflectionProvider(runtime); } - protected RegisterConfig createRegisterConfig(HotSpotJVMCIRuntimeProvider runtime, TargetDescription target) { - return new AMD64HotSpotRegisterConfig(target, runtime.getConfig()); + protected RegisterConfig createRegisterConfig(AMD64HotSpotVMConfig config, TargetDescription target) { + return new AMD64HotSpotRegisterConfig(target, config.useCompressedOops, config.windowsOs); } protected HotSpotCodeCacheProvider createCodeCache(HotSpotJVMCIRuntimeProvider runtime, TargetDescription target, RegisterConfig regConfig) { @@ -175,9 +174,9 @@ public class AMD64HotSpotJVMCIBackendFactory implements HotSpotJVMCIBackendFacto @SuppressWarnings("try") public JVMCIBackend createJVMCIBackend(HotSpotJVMCIRuntimeProvider runtime, JVMCIBackend host) { - assert host == null; - TargetDescription target = createTarget(runtime.getConfig()); + AMD64HotSpotVMConfig config = new AMD64HotSpotVMConfig(runtime.getConfigStore()); + TargetDescription target = createTarget(config); RegisterConfig regConfig; HotSpotCodeCacheProvider codeCache; @@ -189,7 +188,7 @@ public class AMD64HotSpotJVMCIBackendFactory implements HotSpotJVMCIBackendFacto metaAccess = createMetaAccess(runtime); } try (InitTimer rt = timer("create RegisterConfig")) { - regConfig = createRegisterConfig(runtime, target); + regConfig = createRegisterConfig(config, target); } try (InitTimer rt = timer("create CodeCache provider")) { codeCache = createCodeCache(runtime, target, regConfig); diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.amd64/src/jdk/vm/ci/hotspot/amd64/AMD64HotSpotRegisterConfig.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.amd64/src/jdk/vm/ci/hotspot/amd64/AMD64HotSpotRegisterConfig.java index 0424d3aa0e7..7f3eb35f7b3 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.amd64/src/jdk/vm/ci/hotspot/amd64/AMD64HotSpotRegisterConfig.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.amd64/src/jdk/vm/ci/hotspot/amd64/AMD64HotSpotRegisterConfig.java @@ -42,8 +42,6 @@ import static jdk.vm.ci.amd64.AMD64.xmm6; import static jdk.vm.ci.amd64.AMD64.xmm7; import java.util.ArrayList; -import java.util.Arrays; -import java.util.Collections; import java.util.HashSet; import java.util.List; import java.util.Set; @@ -52,6 +50,7 @@ import jdk.vm.ci.code.Architecture; import jdk.vm.ci.code.CallingConvention; import jdk.vm.ci.code.CallingConvention.Type; import jdk.vm.ci.code.Register; +import jdk.vm.ci.code.RegisterArray; import jdk.vm.ci.code.RegisterAttributes; import jdk.vm.ci.code.RegisterConfig; import jdk.vm.ci.code.StackSlot; @@ -59,7 +58,6 @@ import jdk.vm.ci.code.TargetDescription; import jdk.vm.ci.code.ValueKindFactory; import jdk.vm.ci.common.JVMCIError; import jdk.vm.ci.hotspot.HotSpotCallingConventionType; -import jdk.vm.ci.hotspot.HotSpotVMConfig; import jdk.vm.ci.meta.AllocatableValue; import jdk.vm.ci.meta.JavaKind; import jdk.vm.ci.meta.JavaType; @@ -71,30 +69,24 @@ public class AMD64HotSpotRegisterConfig implements RegisterConfig { private final TargetDescription target; - private final Register[] allocatable; - - private final int maxFrameSize; + private final RegisterArray allocatable; /** * The caller saved registers always include all parameter registers. */ - private final Register[] callerSaved; + private final RegisterArray callerSaved; private final boolean allAllocatableAreCallerSaved; private final RegisterAttributes[] attributesMap; - public int getMaximumFrameSize() { - return maxFrameSize; + @Override + public RegisterArray getAllocatableRegisters() { + return allocatable; } @Override - public Register[] getAllocatableRegisters() { - return allocatable.clone(); - } - - @Override - public Register[] filterAllocatableRegisters(PlatformKind kind, Register[] registers) { + public RegisterArray filterAllocatableRegisters(PlatformKind kind, RegisterArray registers) { ArrayList list = new ArrayList<>(); for (Register reg : registers) { if (target.arch.canStoreValue(reg.getRegisterCategory(), kind)) { @@ -102,7 +94,7 @@ public class AMD64HotSpotRegisterConfig implements RegisterConfig { } } - Register[] ret = list.toArray(new Register[list.size()]); + RegisterArray ret = new RegisterArray(list); return ret; } @@ -111,9 +103,9 @@ public class AMD64HotSpotRegisterConfig implements RegisterConfig { return attributesMap.clone(); } - private final Register[] javaGeneralParameterRegisters; - private final Register[] nativeGeneralParameterRegisters; - private final Register[] xmmParameterRegisters = {xmm0, xmm1, xmm2, xmm3, xmm4, xmm5, xmm6, xmm7}; + private final RegisterArray javaGeneralParameterRegisters; + private final RegisterArray nativeGeneralParameterRegisters; + private final RegisterArray xmmParameterRegisters = new RegisterArray(xmm0, xmm1, xmm2, xmm3, xmm4, xmm5, xmm6, xmm7); /* * Some ABIs (e.g. Windows) require a so-called "home space", that is a save area on the stack @@ -121,12 +113,12 @@ public class AMD64HotSpotRegisterConfig implements RegisterConfig { */ private final boolean needsNativeStackHomeSpace; - private static final Register[] reservedRegisters = {rsp, r15}; + private static final RegisterArray reservedRegisters = new RegisterArray(rsp, r15); - private static Register[] initAllocatable(Architecture arch, boolean reserveForHeapBase) { - Register[] allRegisters = arch.getAvailableValueRegisters(); - Register[] registers = new Register[allRegisters.length - reservedRegisters.length - (reserveForHeapBase ? 1 : 0)]; - List reservedRegistersList = Arrays.asList(reservedRegisters); + private static RegisterArray initAllocatable(Architecture arch, boolean reserveForHeapBase) { + RegisterArray allRegisters = arch.getAvailableValueRegisters(); + Register[] registers = new Register[allRegisters.size() - reservedRegisters.size() - (reserveForHeapBase ? 1 : 0)]; + List reservedRegistersList = reservedRegisters.asList(); int idx = 0; for (Register reg : allRegisters) { @@ -143,47 +135,46 @@ public class AMD64HotSpotRegisterConfig implements RegisterConfig { } assert idx == registers.length; - return registers; + return new RegisterArray(registers); } - public AMD64HotSpotRegisterConfig(TargetDescription target, HotSpotVMConfig config) { - this(target, config, initAllocatable(target.arch, config.useCompressedOops)); - assert callerSaved.length >= allocatable.length; + public AMD64HotSpotRegisterConfig(TargetDescription target, boolean useCompressedOops, boolean windowsOs) { + this(target, initAllocatable(target.arch, useCompressedOops), windowsOs); + assert callerSaved.size() >= allocatable.size(); } - public AMD64HotSpotRegisterConfig(TargetDescription target, HotSpotVMConfig config, Register[] allocatable) { + public AMD64HotSpotRegisterConfig(TargetDescription target, RegisterArray allocatable, boolean windowsOs) { this.target = target; - this.maxFrameSize = config.maxFrameSize; - if (config.windowsOs) { - javaGeneralParameterRegisters = new Register[]{rdx, r8, r9, rdi, rsi, rcx}; - nativeGeneralParameterRegisters = new Register[]{rcx, rdx, r8, r9}; + if (windowsOs) { + javaGeneralParameterRegisters = new RegisterArray(rdx, r8, r9, rdi, rsi, rcx); + nativeGeneralParameterRegisters = new RegisterArray(rcx, rdx, r8, r9); this.needsNativeStackHomeSpace = true; } else { - javaGeneralParameterRegisters = new Register[]{rsi, rdx, rcx, r8, r9, rdi}; - nativeGeneralParameterRegisters = new Register[]{rdi, rsi, rdx, rcx, r8, r9}; + javaGeneralParameterRegisters = new RegisterArray(rsi, rdx, rcx, r8, r9, rdi); + nativeGeneralParameterRegisters = new RegisterArray(rdi, rsi, rdx, rcx, r8, r9); this.needsNativeStackHomeSpace = false; } this.allocatable = allocatable; Set callerSaveSet = new HashSet<>(); - Collections.addAll(callerSaveSet, allocatable); - Collections.addAll(callerSaveSet, xmmParameterRegisters); - Collections.addAll(callerSaveSet, javaGeneralParameterRegisters); - Collections.addAll(callerSaveSet, nativeGeneralParameterRegisters); - callerSaved = callerSaveSet.toArray(new Register[callerSaveSet.size()]); + allocatable.addTo(callerSaveSet); + xmmParameterRegisters.addTo(callerSaveSet); + callerSaveSet.addAll(javaGeneralParameterRegisters.asList()); + nativeGeneralParameterRegisters.addTo(callerSaveSet); + callerSaved = new RegisterArray(callerSaveSet); allAllocatableAreCallerSaved = true; attributesMap = RegisterAttributes.createMap(this, target.arch.getRegisters()); } @Override - public Register[] getCallerSaveRegisters() { + public RegisterArray getCallerSaveRegisters() { return callerSaved; } @Override - public Register[] getCalleeSaveRegisters() { + public RegisterArray getCalleeSaveRegisters() { return null; } @@ -204,7 +195,7 @@ public class AMD64HotSpotRegisterConfig implements RegisterConfig { } @Override - public Register[] getCallingConventionRegisters(Type type, JavaKind kind) { + public RegisterArray getCallingConventionRegisters(Type type, JavaKind kind) { HotSpotCallingConventionType hotspotType = (HotSpotCallingConventionType) type; switch (kind) { case Boolean: @@ -223,13 +214,13 @@ public class AMD64HotSpotRegisterConfig implements RegisterConfig { } } - private CallingConvention callingConvention(Register[] generalParameterRegisters, JavaType returnType, JavaType[] parameterTypes, HotSpotCallingConventionType type, + private CallingConvention callingConvention(RegisterArray generalParameterRegisters, JavaType returnType, JavaType[] parameterTypes, HotSpotCallingConventionType type, ValueKindFactory valueKindFactory) { AllocatableValue[] locations = new AllocatableValue[parameterTypes.length]; int currentGeneral = 0; int currentXMM = 0; - int currentStackOffset = type == HotSpotCallingConventionType.NativeCall && needsNativeStackHomeSpace ? generalParameterRegisters.length * target.wordSize : 0; + int currentStackOffset = type == HotSpotCallingConventionType.NativeCall && needsNativeStackHomeSpace ? generalParameterRegisters.size() * target.wordSize : 0; for (int i = 0; i < parameterTypes.length; i++) { final JavaKind kind = parameterTypes[i].getJavaKind().getStackKind(); @@ -242,15 +233,15 @@ public class AMD64HotSpotRegisterConfig implements RegisterConfig { case Int: case Long: case Object: - if (currentGeneral < generalParameterRegisters.length) { - Register register = generalParameterRegisters[currentGeneral++]; + if (currentGeneral < generalParameterRegisters.size()) { + Register register = generalParameterRegisters.get(currentGeneral++); locations[i] = register.asValue(valueKindFactory.getValueKind(kind)); } break; case Float: case Double: - if (currentXMM < xmmParameterRegisters.length) { - Register register = xmmParameterRegisters[currentXMM++]; + if (currentXMM < xmmParameterRegisters.size()) { + Register register = xmmParameterRegisters.get(currentXMM++); locations[i] = register.asValue(valueKindFactory.getValueKind(kind)); } break; @@ -299,6 +290,6 @@ public class AMD64HotSpotRegisterConfig implements RegisterConfig { @Override public String toString() { - return String.format("Allocatable: " + Arrays.toString(getAllocatableRegisters()) + "%n" + "CallerSave: " + Arrays.toString(getCallerSaveRegisters()) + "%n"); + return String.format("Allocatable: " + getAllocatableRegisters() + "%n" + "CallerSave: " + getCallerSaveRegisters() + "%n"); } } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.amd64/src/jdk/vm/ci/hotspot/amd64/AMD64HotSpotVMConfig.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.amd64/src/jdk/vm/ci/hotspot/amd64/AMD64HotSpotVMConfig.java new file mode 100644 index 00000000000..4506916fbdd --- /dev/null +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.amd64/src/jdk/vm/ci/hotspot/amd64/AMD64HotSpotVMConfig.java @@ -0,0 +1,81 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +package jdk.vm.ci.hotspot.amd64; + +import jdk.vm.ci.hotspot.HotSpotVMConfigAccess; +import jdk.vm.ci.hotspot.HotSpotVMConfigStore; + +class AMD64HotSpotVMConfig extends HotSpotVMConfigAccess { + + AMD64HotSpotVMConfig(HotSpotVMConfigStore config) { + super(config); + } + + final boolean windowsOs = System.getProperty("os.name", "").startsWith("Windows"); + + final boolean useCountLeadingZerosInstruction = getFlag("UseCountLeadingZerosInstruction", Boolean.class); + final boolean useCountTrailingZerosInstruction = getFlag("UseCountTrailingZerosInstruction", Boolean.class); + final boolean useCompressedOops = getFlag("UseCompressedOops", Boolean.class); + + // CPU capabilities + final int useSSE = getFlag("UseSSE", Integer.class); + final int useAVX = getFlag("UseAVX", Integer.class); + + final long vmVersionFeatures = getFieldValue("Abstract_VM_Version::_features", Long.class, "uint64_t"); + + // CPU feature flags + final long amd64CX8 = getConstant("VM_Version::CPU_CX8", Long.class); + final long amd64CMOV = getConstant("VM_Version::CPU_CMOV", Long.class); + final long amd64FXSR = getConstant("VM_Version::CPU_FXSR", Long.class); + final long amd64HT = getConstant("VM_Version::CPU_HT", Long.class); + final long amd64MMX = getConstant("VM_Version::CPU_MMX", Long.class); + final long amd643DNOWPREFETCH = getConstant("VM_Version::CPU_3DNOW_PREFETCH", Long.class); + final long amd64SSE = getConstant("VM_Version::CPU_SSE", Long.class); + final long amd64SSE2 = getConstant("VM_Version::CPU_SSE2", Long.class); + final long amd64SSE3 = getConstant("VM_Version::CPU_SSE3", Long.class); + final long amd64SSSE3 = getConstant("VM_Version::CPU_SSSE3", Long.class); + final long amd64SSE4A = getConstant("VM_Version::CPU_SSE4A", Long.class); + final long amd64SSE41 = getConstant("VM_Version::CPU_SSE4_1", Long.class); + final long amd64SSE42 = getConstant("VM_Version::CPU_SSE4_2", Long.class); + final long amd64POPCNT = getConstant("VM_Version::CPU_POPCNT", Long.class); + final long amd64LZCNT = getConstant("VM_Version::CPU_LZCNT", Long.class); + final long amd64TSC = getConstant("VM_Version::CPU_TSC", Long.class); + final long amd64TSCINV = getConstant("VM_Version::CPU_TSCINV", Long.class); + final long amd64AVX = getConstant("VM_Version::CPU_AVX", Long.class); + final long amd64AVX2 = getConstant("VM_Version::CPU_AVX2", Long.class); + final long amd64AES = getConstant("VM_Version::CPU_AES", Long.class); + final long amd64ERMS = getConstant("VM_Version::CPU_ERMS", Long.class); + final long amd64CLMUL = getConstant("VM_Version::CPU_CLMUL", Long.class); + final long amd64BMI1 = getConstant("VM_Version::CPU_BMI1", Long.class); + final long amd64BMI2 = getConstant("VM_Version::CPU_BMI2", Long.class); + final long amd64RTM = getConstant("VM_Version::CPU_RTM", Long.class); + final long amd64ADX = getConstant("VM_Version::CPU_ADX", Long.class); + final long amd64AVX512F = getConstant("VM_Version::CPU_AVX512F", Long.class); + final long amd64AVX512DQ = getConstant("VM_Version::CPU_AVX512DQ", Long.class); + final long amd64AVX512PF = getConstant("VM_Version::CPU_AVX512PF", Long.class); + final long amd64AVX512ER = getConstant("VM_Version::CPU_AVX512ER", Long.class); + final long amd64AVX512CD = getConstant("VM_Version::CPU_AVX512CD", Long.class); + final long amd64AVX512BW = getConstant("VM_Version::CPU_AVX512BW", Long.class); + final long amd64AVX512VL = getConstant("VM_Version::CPU_AVX512VL", Long.class); + final long amd64SHA = getConstant("VM_Version::CPU_SHA", Long.class); +} diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.sparc/src/jdk/vm/ci/hotspot/sparc/SPARCHotSpotJVMCIBackendFactory.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.sparc/src/jdk/vm/ci/hotspot/sparc/SPARCHotSpotJVMCIBackendFactory.java index 724266baf8a..e5b2d65b1ec 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.sparc/src/jdk/vm/ci/hotspot/sparc/SPARCHotSpotJVMCIBackendFactory.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.sparc/src/jdk/vm/ci/hotspot/sparc/SPARCHotSpotJVMCIBackendFactory.java @@ -37,14 +37,13 @@ import jdk.vm.ci.hotspot.HotSpotJVMCIBackendFactory; import jdk.vm.ci.hotspot.HotSpotJVMCIRuntimeProvider; import jdk.vm.ci.hotspot.HotSpotMetaAccessProvider; import jdk.vm.ci.hotspot.HotSpotStackIntrospection; -import jdk.vm.ci.hotspot.HotSpotVMConfig; import jdk.vm.ci.runtime.JVMCIBackend; import jdk.vm.ci.sparc.SPARC; import jdk.vm.ci.sparc.SPARC.CPUFeature; public class SPARCHotSpotJVMCIBackendFactory implements HotSpotJVMCIBackendFactory { - protected TargetDescription createTarget(HotSpotVMConfig config) { + protected TargetDescription createTarget(SPARCHotSpotVMConfig config) { final int stackFrameAlignment = 16; final int implicitNullCheckLimit = 4096; final boolean inlineObjects = false; @@ -56,7 +55,7 @@ public class SPARCHotSpotJVMCIBackendFactory implements HotSpotJVMCIBackendFacto return new HotSpotCodeCacheProvider(runtime, runtime.getConfig(), target, regConfig); } - protected EnumSet computeFeatures(HotSpotVMConfig config) { + protected EnumSet computeFeatures(SPARCHotSpotVMConfig config) { EnumSet features = EnumSet.noneOf(CPUFeature.class); if ((config.vmVersionFeatures & config.sparcVis1Instructions) != 0) { features.add(CPUFeature.VIS1); @@ -143,10 +142,11 @@ public class SPARCHotSpotJVMCIBackendFactory implements HotSpotJVMCIBackendFacto @SuppressWarnings("try") public JVMCIBackend createJVMCIBackend(HotSpotJVMCIRuntimeProvider runtime, JVMCIBackend host) { assert host == null; - TargetDescription target = createTarget(runtime.getConfig()); + SPARCHotSpotVMConfig config = new SPARCHotSpotVMConfig(runtime.getConfigStore()); + TargetDescription target = createTarget(config); HotSpotMetaAccessProvider metaAccess = new HotSpotMetaAccessProvider(runtime); - RegisterConfig regConfig = new SPARCHotSpotRegisterConfig(target, runtime.getConfig()); + RegisterConfig regConfig = new SPARCHotSpotRegisterConfig(target, config.useCompressedOops); HotSpotCodeCacheProvider codeCache = createCodeCache(runtime, target, regConfig); HotSpotConstantReflectionProvider constantReflection = new HotSpotConstantReflectionProvider(runtime); StackIntrospection stackIntrospection = new HotSpotStackIntrospection(runtime); diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.sparc/src/jdk/vm/ci/hotspot/sparc/SPARCHotSpotRegisterConfig.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.sparc/src/jdk/vm/ci/hotspot/sparc/SPARCHotSpotRegisterConfig.java index af1b0ef591a..bb25c611df5 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.sparc/src/jdk/vm/ci/hotspot/sparc/SPARCHotSpotRegisterConfig.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.sparc/src/jdk/vm/ci/hotspot/sparc/SPARCHotSpotRegisterConfig.java @@ -65,8 +65,6 @@ import static jdk.vm.ci.sparc.SPARC.o5; import static jdk.vm.ci.sparc.SPARC.sp; import java.util.ArrayList; -import java.util.Arrays; -import java.util.Collections; import java.util.HashSet; import java.util.List; @@ -74,6 +72,7 @@ import jdk.vm.ci.code.Architecture; import jdk.vm.ci.code.CallingConvention; import jdk.vm.ci.code.CallingConvention.Type; import jdk.vm.ci.code.Register; +import jdk.vm.ci.code.RegisterArray; import jdk.vm.ci.code.RegisterAttributes; import jdk.vm.ci.code.RegisterConfig; import jdk.vm.ci.code.StackSlot; @@ -81,7 +80,6 @@ import jdk.vm.ci.code.TargetDescription; import jdk.vm.ci.code.ValueKindFactory; import jdk.vm.ci.common.JVMCIError; import jdk.vm.ci.hotspot.HotSpotCallingConventionType; -import jdk.vm.ci.hotspot.HotSpotVMConfig; import jdk.vm.ci.meta.AllocatableValue; import jdk.vm.ci.meta.JavaKind; import jdk.vm.ci.meta.JavaType; @@ -93,7 +91,7 @@ public class SPARCHotSpotRegisterConfig implements RegisterConfig { private final TargetDescription target; - private final Register[] allocatable; + private final RegisterArray allocatable; private final RegisterAttributes[] attributesMap; @@ -103,20 +101,19 @@ public class SPARCHotSpotRegisterConfig implements RegisterConfig { private final boolean addNativeRegisterArgumentSlots; @Override - public Register[] getAllocatableRegisters() { - return allocatable.clone(); + public RegisterArray getAllocatableRegisters() { + return allocatable; } @Override - public Register[] filterAllocatableRegisters(PlatformKind kind, Register[] registers) { + public RegisterArray filterAllocatableRegisters(PlatformKind kind, RegisterArray registers) { ArrayList list = new ArrayList<>(); for (Register reg : registers) { if (target.arch.canStoreValue(reg.getRegisterCategory(), kind)) { list.add(reg); } } - Register[] ret = list.toArray(new Register[list.size()]); - return ret; + return new RegisterArray(list); } @Override @@ -124,30 +121,29 @@ public class SPARCHotSpotRegisterConfig implements RegisterConfig { return attributesMap.clone(); } - private final Register[] cpuCallerParameterRegisters = {o0, o1, o2, o3, o4, o5}; - private final Register[] cpuCalleeParameterRegisters = {i0, i1, i2, i3, i4, i5}; + private final RegisterArray cpuCallerParameterRegisters = new RegisterArray(o0, o1, o2, o3, o4, o5); + private final RegisterArray cpuCalleeParameterRegisters = new RegisterArray(i0, i1, i2, i3, i4, i5); - private final Register[] fpuFloatParameterRegisters = {f0, f1, f2, f3, f4, f5, f6, f7}; - private final Register[] fpuDoubleParameterRegisters = {d0, null, d2, null, d4, null, d6, null}; + private final RegisterArray fpuFloatParameterRegisters = new RegisterArray(f0, f1, f2, f3, f4, f5, f6, f7); + private final RegisterArray fpuDoubleParameterRegisters = new RegisterArray(d0, null, d2, null, d4, null, d6, null); // @formatter:off - private final Register[] callerSaveRegisters; + private final RegisterArray callerSaveRegisters; /** - * Registers saved by the callee. This lists all L and I registers which are saved in the - * register window. + * This lists all L and I registers which are saved in the register window. */ - private final Register[] calleeSaveRegisters = { + private final RegisterArray windowSaveRegisters = new RegisterArray( l0, l1, l2, l3, l4, l5, l6, l7, - i0, i1, i2, i3, i4, i5, i6, i7}; + i0, i1, i2, i3, i4, i5, i6, i7); // @formatter:on - private static final Register[] reservedRegisters = {sp, g0, g2}; + private static final RegisterArray reservedRegisters = new RegisterArray(sp, g0, g2); - private static Register[] initAllocatable(Architecture arch, boolean reserveForHeapBase) { - Register[] allRegisters = arch.getAvailableValueRegisters(); - Register[] registers = new Register[allRegisters.length - reservedRegisters.length - (reserveForHeapBase ? 1 : 0)]; - List reservedRegistersList = Arrays.asList(reservedRegisters); + private static RegisterArray initAllocatable(Architecture arch, boolean reserveForHeapBase) { + RegisterArray allRegisters = arch.getAvailableValueRegisters(); + Register[] registers = new Register[allRegisters.size() - reservedRegisters.size() - (reserveForHeapBase ? 1 : 0)]; + List reservedRegistersList = reservedRegisters.asList(); int idx = 0; for (Register reg : allRegisters) { @@ -164,33 +160,33 @@ public class SPARCHotSpotRegisterConfig implements RegisterConfig { } assert idx == registers.length; - return registers; + return new RegisterArray(registers); } - public SPARCHotSpotRegisterConfig(TargetDescription target, HotSpotVMConfig config) { - this(target, initAllocatable(target.arch, config.useCompressedOops), config); + public SPARCHotSpotRegisterConfig(TargetDescription target, boolean useCompressedOops) { + this(target, initAllocatable(target.arch, useCompressedOops)); } - public SPARCHotSpotRegisterConfig(TargetDescription target, Register[] allocatable, HotSpotVMConfig config) { + public SPARCHotSpotRegisterConfig(TargetDescription target, RegisterArray allocatable) { this.target = target; - this.allocatable = allocatable.clone(); - this.addNativeRegisterArgumentSlots = config.linuxOs; - HashSet callerSaveSet = new HashSet<>(); - Collections.addAll(callerSaveSet, target.arch.getAvailableValueRegisters()); - for (Register cs : calleeSaveRegisters) { + this.allocatable = allocatable; + this.addNativeRegisterArgumentSlots = false; + HashSet callerSaveSet = new HashSet<>(target.arch.getAvailableValueRegisters().asList()); + for (Register cs : windowSaveRegisters) { callerSaveSet.remove(cs); } - this.callerSaveRegisters = callerSaveSet.toArray(new Register[callerSaveSet.size()]); + this.callerSaveRegisters = new RegisterArray(callerSaveSet); attributesMap = RegisterAttributes.createMap(this, SPARC.allRegisters); } @Override - public Register[] getCallerSaveRegisters() { + public RegisterArray getCallerSaveRegisters() { return callerSaveRegisters; } - public Register[] getCalleeSaveRegisters() { - return calleeSaveRegisters; + @Override + public RegisterArray getCalleeSaveRegisters() { + return null; } @Override @@ -211,7 +207,7 @@ public class SPARCHotSpotRegisterConfig implements RegisterConfig { } @Override - public Register[] getCallingConventionRegisters(Type type, JavaKind kind) { + public RegisterArray getCallingConventionRegisters(Type type, JavaKind kind) { HotSpotCallingConventionType hotspotType = (HotSpotCallingConventionType) type; switch (kind) { case Boolean: @@ -230,7 +226,7 @@ public class SPARCHotSpotRegisterConfig implements RegisterConfig { } } - private CallingConvention callingConvention(Register[] generalParameterRegisters, JavaType returnType, JavaType[] parameterTypes, HotSpotCallingConventionType type, + private CallingConvention callingConvention(RegisterArray generalParameterRegisters, JavaType returnType, JavaType[] parameterTypes, HotSpotCallingConventionType type, ValueKindFactory valueKindFactory) { AllocatableValue[] locations = new AllocatableValue[parameterTypes.length]; @@ -249,25 +245,25 @@ public class SPARCHotSpotRegisterConfig implements RegisterConfig { case Int: case Long: case Object: - if (currentGeneral < generalParameterRegisters.length) { - Register register = generalParameterRegisters[currentGeneral++]; + if (currentGeneral < generalParameterRegisters.size()) { + Register register = generalParameterRegisters.get(currentGeneral++); locations[i] = register.asValue(valueKindFactory.getValueKind(kind)); } break; case Double: - if (currentFloating < fpuFloatParameterRegisters.length) { + if (currentFloating < fpuFloatParameterRegisters.size()) { if (currentFloating % 2 != 0) { // Make register number even to be a double reg currentFloating++; } - Register register = fpuDoubleParameterRegisters[currentFloating]; + Register register = fpuDoubleParameterRegisters.get(currentFloating); currentFloating += 2; // Only every second is a double register locations[i] = register.asValue(valueKindFactory.getValueKind(kind)); } break; case Float: - if (currentFloating < fpuFloatParameterRegisters.length) { - Register register = fpuFloatParameterRegisters[currentFloating++]; + if (currentFloating < fpuFloatParameterRegisters.size()) { + Register register = fpuFloatParameterRegisters.get(currentFloating++); locations[i] = register.asValue(valueKindFactory.getValueKind(kind)); } break; @@ -292,7 +288,7 @@ public class SPARCHotSpotRegisterConfig implements RegisterConfig { int outArgSpillArea; if (type == HotSpotCallingConventionType.NativeCall && addNativeRegisterArgumentSlots) { // Space for native callee which may spill our outgoing arguments - outArgSpillArea = Math.min(locations.length, generalParameterRegisters.length) * target.wordSize; + outArgSpillArea = Math.min(locations.length, generalParameterRegisters.size()) * target.wordSize; } else { outArgSpillArea = 0; } @@ -337,6 +333,6 @@ public class SPARCHotSpotRegisterConfig implements RegisterConfig { @Override public String toString() { - return String.format("Allocatable: " + Arrays.toString(getAllocatableRegisters()) + "%n" + "CallerSave: " + Arrays.toString(getCallerSaveRegisters()) + "%n"); + return String.format("Allocatable: " + getAllocatableRegisters() + "%n" + "CallerSave: " + getCallerSaveRegisters() + "%n"); } } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.sparc/src/jdk/vm/ci/hotspot/sparc/SPARCHotSpotVMConfig.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.sparc/src/jdk/vm/ci/hotspot/sparc/SPARCHotSpotVMConfig.java new file mode 100644 index 00000000000..d5eee90672f --- /dev/null +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot.sparc/src/jdk/vm/ci/hotspot/sparc/SPARCHotSpotVMConfig.java @@ -0,0 +1,71 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +package jdk.vm.ci.hotspot.sparc; + +import jdk.vm.ci.hotspot.HotSpotVMConfigAccess; +import jdk.vm.ci.hotspot.HotSpotVMConfigStore; + +/** + * Used to access native configuration details. + * + * All non-static, public fields in this class are so that they can be compiled as constants. + */ +class SPARCHotSpotVMConfig extends HotSpotVMConfigAccess { + + SPARCHotSpotVMConfig(HotSpotVMConfigStore config) { + super(config); + } + + final boolean useCompressedOops = getFlag("UseCompressedOops", Boolean.class); + + // CPU capabilities + final long vmVersionFeatures = getFieldValue("Abstract_VM_Version::_features", Long.class, "uint64_t"); + + // SPARC specific values + final int sparcVis3Instructions = getConstant("VM_Version::vis3_instructions_m", Integer.class); + final int sparcVis2Instructions = getConstant("VM_Version::vis2_instructions_m", Integer.class); + final int sparcVis1Instructions = getConstant("VM_Version::vis1_instructions_m", Integer.class); + final int sparcCbcondInstructions = getConstant("VM_Version::cbcond_instructions_m", Integer.class); + final int sparcV8Instructions = getConstant("VM_Version::v8_instructions_m", Integer.class); + final int sparcHardwareMul32 = getConstant("VM_Version::hardware_mul32_m", Integer.class); + final int sparcHardwareDiv32 = getConstant("VM_Version::hardware_div32_m", Integer.class); + final int sparcHardwareFsmuld = getConstant("VM_Version::hardware_fsmuld_m", Integer.class); + final int sparcHardwarePopc = getConstant("VM_Version::hardware_popc_m", Integer.class); + final int sparcV9Instructions = getConstant("VM_Version::v9_instructions_m", Integer.class); + final int sparcSun4v = getConstant("VM_Version::sun4v_m", Integer.class); + final int sparcBlkInitInstructions = getConstant("VM_Version::blk_init_instructions_m", Integer.class); + final int sparcFmafInstructions = getConstant("VM_Version::fmaf_instructions_m", Integer.class); + final int sparcFmauInstructions = getConstant("VM_Version::fmau_instructions_m", Integer.class); + final int sparcSparc64Family = getConstant("VM_Version::sparc64_family_m", Integer.class); + final int sparcMFamily = getConstant("VM_Version::M_family_m", Integer.class); + final int sparcTFamily = getConstant("VM_Version::T_family_m", Integer.class); + final int sparcT1Model = getConstant("VM_Version::T1_model_m", Integer.class); + final int sparcSparc5Instructions = getConstant("VM_Version::sparc5_instructions_m", Integer.class); + final int sparcAesInstructions = getConstant("VM_Version::aes_instructions_m", Integer.class); + final int sparcSha1Instruction = getConstant("VM_Version::sha1_instruction_m", Integer.class); + final int sparcSha256Instruction = getConstant("VM_Version::sha256_instruction_m", Integer.class); + final int sparcSha512Instruction = getConstant("VM_Version::sha512_instruction_m", Integer.class); + + final boolean useBlockZeroing = getFlag("UseBlockZeroing", Boolean.class); + final int blockZeroingLowLimit = getFlag("BlockZeroingLowLimit", Integer.class); +} diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/CompilerToVM.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/CompilerToVM.java index 760a4e64d49..72f9d18caa3 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/CompilerToVM.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/CompilerToVM.java @@ -35,11 +35,9 @@ import jdk.vm.ci.code.InvalidInstalledCodeException; import jdk.vm.ci.code.TargetDescription; import jdk.vm.ci.common.InitTimer; import jdk.vm.ci.common.JVMCIError; -import jdk.vm.ci.hotspotvmconfig.HotSpotVMField; import jdk.vm.ci.meta.JavaType; import jdk.vm.ci.meta.ResolvedJavaMethod; import jdk.vm.ci.meta.ResolvedJavaType; -import jdk.internal.misc.Unsafe; /** * Calls from Java into HotSpot. The behavior of all the methods in this class that take a native @@ -267,8 +265,9 @@ final class CompilerToVM { native HotSpotResolvedObjectTypeImpl resolveTypeInPool(HotSpotConstantPool constantPool, int cpi) throws LinkageError; /** - * Looks up and attempts to resolve the {@code JVM_CONSTANT_Field} entry at index {@code cpi} in - * {@code constantPool}. The values returned in {@code info} are: + * Looks up and attempts to resolve the {@code JVM_CONSTANT_Field} entry for at index {@code cpi} in + * {@code constantPool}. For some opcodes, checks are performed that require the {@code method} + * that contains {@code opcode} to be specified. The values returned in {@code info} are: * *

      *     [(int) flags,   // only valid if field is resolved
@@ -281,7 +280,7 @@ final class CompilerToVM {
      * @param info an array in which the details of the field are returned
      * @return the type defining the field if resolution is successful, 0 otherwise
      */
-    native HotSpotResolvedObjectTypeImpl resolveFieldInPool(HotSpotConstantPool constantPool, int cpi, byte opcode, long[] info);
+    native HotSpotResolvedObjectTypeImpl resolveFieldInPool(HotSpotConstantPool constantPool, int cpi, HotSpotResolvedJavaMethodImpl method, byte opcode, long[] info);
 
     /**
      * Converts {@code cpci} from an index into the cache for {@code constantPool} to an index
@@ -338,9 +337,22 @@ final class CompilerToVM {
     native void resetCompilationStatistics();
 
     /**
-     * Initializes the fields of {@code config}.
+     * Reads the database of VM info. The return value encodes the info in a nested object array
+     * that is described by the pseudo Java object {@code info} below:
+     *
+     * 
+     *     info = [
+     *         VMField[] vmFields,
+     *         [String name, Long size, ...] vmTypeSizes,
+     *         [String name, Long value, ...] vmConstants,
+     *         [String name, Long value, ...] vmAddresses,
+     *         VMFlag[] vmFlags
+     *     ]
+     * 
+ * + * @return VM info as encoded above */ - native long initializeConfiguration(HotSpotVMConfig config); + native Object[] readConfiguration(); /** * Resolves the implementation of {@code method} for virtual dispatches on objects of dynamic @@ -428,7 +440,6 @@ final class CompilerToVM { *
  • {@link HotSpotVMConfig#localVariableTableElementLengthOffset}
  • *
  • {@link HotSpotVMConfig#localVariableTableElementNameCpIndexOffset}
  • *
  • {@link HotSpotVMConfig#localVariableTableElementDescriptorCpIndexOffset}
  • - *
  • {@link HotSpotVMConfig#localVariableTableElementSignatureCpIndexOffset} *
  • {@link HotSpotVMConfig#localVariableTableElementSlotOffset} *
  • {@link HotSpotVMConfig#localVariableTableElementStartBciOffset} * diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotCodeCacheProvider.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotCodeCacheProvider.java index dac0fb3a553..803f55a21f0 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotCodeCacheProvider.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotCodeCacheProvider.java @@ -42,7 +42,7 @@ import jdk.vm.ci.meta.SpeculationLog; public class HotSpotCodeCacheProvider implements CodeCacheProvider { protected final HotSpotJVMCIRuntimeProvider runtime; - public final HotSpotVMConfig config; + protected final HotSpotVMConfig config; protected final TargetDescription target; protected final RegisterConfig regConfig; @@ -80,12 +80,13 @@ public class HotSpotCodeCacheProvider implements CodeCacheProvider { for (Field f : fields) { if (f.getName().endsWith("Stub")) { f.setAccessible(true); + Object address; try { - Object address = f.get(runtime.getConfig()); + address = f.get(runtime.getConfig()); if (address.equals(call.target)) { return f.getName() + ":0x" + Long.toHexString((Long) address); } - } catch (Exception e) { + } catch (IllegalArgumentException | IllegalAccessException e) { } } } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotCompiledCode.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotCompiledCode.java index 48d861515ab..be909cfc40a 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotCompiledCode.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotCompiledCode.java @@ -115,6 +115,7 @@ public class HotSpotCompiledCode implements CompiledCode { } } + @SuppressFBWarnings(value = "EI_EXPOSE_REP2", justification = "caller transfers ownership of `sites`, `targetCode`, `comments`, `methods`, `dataSection`, `dataSectionPatches` and `assumptions`") public HotSpotCompiledCode(String name, byte[] targetCode, int targetCodeSize, Site[] sites, Assumption[] assumptions, ResolvedJavaMethod[] methods, Comment[] comments, byte[] dataSection, int dataSectionAlignment, DataPatch[] dataSectionPatches, boolean isImmutablePIC, int totalFrameSize, StackSlot deoptRescueSlot) { this.name = name; diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotConstantPool.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotConstantPool.java index 4143d1babed..1f29ff8cce4 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotConstantPool.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotConstantPool.java @@ -196,7 +196,9 @@ final class HotSpotConstantPool implements ConstantPool, MetaspaceWrapperObject */ @SuppressWarnings("unused") private static HotSpotConstantPool fromMetaspace(long metaspaceConstantPool) { - return new HotSpotConstantPool(metaspaceConstantPool); + HotSpotConstantPool cp = new HotSpotConstantPool(metaspaceConstantPool); + runtime().metaAccessContext.add(cp); + return cp; } private HotSpotConstantPool(long metaspaceConstantPool) { @@ -298,7 +300,8 @@ final class HotSpotConstantPool implements ConstantPool, MetaspaceWrapperObject */ private long getEntryAt(int index) { assertBounds(index); - return UNSAFE.getAddress(getMetaspaceConstantPool() + config().constantPoolSize + index * runtime().getHostJVMCIBackend().getTarget().wordSize); + int offset = index * runtime().getHostJVMCIBackend().getTarget().wordSize; + return UNSAFE.getAddress(getMetaspaceConstantPool() + config().constantPoolSize + offset); } /** @@ -309,7 +312,8 @@ final class HotSpotConstantPool implements ConstantPool, MetaspaceWrapperObject */ private int getIntAt(int index) { assertTag(index, JVM_CONSTANT.Integer); - return UNSAFE.getInt(getMetaspaceConstantPool() + config().constantPoolSize + index * runtime().getHostJVMCIBackend().getTarget().wordSize); + int offset = index * runtime().getHostJVMCIBackend().getTarget().wordSize; + return UNSAFE.getInt(getMetaspaceConstantPool() + config().constantPoolSize + offset); } /** @@ -320,7 +324,8 @@ final class HotSpotConstantPool implements ConstantPool, MetaspaceWrapperObject */ private long getLongAt(int index) { assertTag(index, JVM_CONSTANT.Long); - return UNSAFE.getLong(getMetaspaceConstantPool() + config().constantPoolSize + index * runtime().getHostJVMCIBackend().getTarget().wordSize); + int offset = index * runtime().getHostJVMCIBackend().getTarget().wordSize; + return UNSAFE.getLong(getMetaspaceConstantPool() + config().constantPoolSize + offset); } /** @@ -331,7 +336,8 @@ final class HotSpotConstantPool implements ConstantPool, MetaspaceWrapperObject */ private float getFloatAt(int index) { assertTag(index, JVM_CONSTANT.Float); - return UNSAFE.getFloat(getMetaspaceConstantPool() + config().constantPoolSize + index * runtime().getHostJVMCIBackend().getTarget().wordSize); + int offset = index * runtime().getHostJVMCIBackend().getTarget().wordSize; + return UNSAFE.getFloat(getMetaspaceConstantPool() + config().constantPoolSize + offset); } /** @@ -342,7 +348,8 @@ final class HotSpotConstantPool implements ConstantPool, MetaspaceWrapperObject */ private double getDoubleAt(int index) { assertTag(index, JVM_CONSTANT.Double); - return UNSAFE.getDouble(getMetaspaceConstantPool() + config().constantPoolSize + index * runtime().getHostJVMCIBackend().getTarget().wordSize); + int offset = index * runtime().getHostJVMCIBackend().getTarget().wordSize; + return UNSAFE.getDouble(getMetaspaceConstantPool() + config().constantPoolSize + offset); } /** @@ -353,7 +360,8 @@ final class HotSpotConstantPool implements ConstantPool, MetaspaceWrapperObject */ private int getNameAndTypeAt(int index) { assertTag(index, JVM_CONSTANT.NameAndType); - return UNSAFE.getInt(getMetaspaceConstantPool() + config().constantPoolSize + index * runtime().getHostJVMCIBackend().getTarget().wordSize); + int offset = index * runtime().getHostJVMCIBackend().getTarget().wordSize; + return UNSAFE.getInt(getMetaspaceConstantPool() + config().constantPoolSize + offset); } /** @@ -434,7 +442,8 @@ final class HotSpotConstantPool implements ConstantPool, MetaspaceWrapperObject */ private int getUncachedKlassRefIndexAt(int index) { assertTagIsFieldOrMethod(index); - final int refIndex = UNSAFE.getInt(getMetaspaceConstantPool() + config().constantPoolSize + index * runtime().getHostJVMCIBackend().getTarget().wordSize); + int offset = index * runtime().getHostJVMCIBackend().getTarget().wordSize; + final int refIndex = UNSAFE.getInt(getMetaspaceConstantPool() + config().constantPoolSize + offset); // klass ref index is in the low 16-bits. return refIndex & 0xFFFF; } @@ -587,7 +596,7 @@ final class HotSpotConstantPool implements ConstantPool, MetaspaceWrapperObject } @Override - public JavaField lookupField(int cpi, int opcode) { + public JavaField lookupField(int cpi, ResolvedJavaMethod method, int opcode) { final int index = rawIndexToConstantPoolIndex(cpi, opcode); final int nameAndTypeIndex = getNameAndTypeRefIndexAt(index); final int nameIndex = getNameRefIndexAt(nameAndTypeIndex); @@ -603,7 +612,7 @@ final class HotSpotConstantPool implements ConstantPool, MetaspaceWrapperObject long[] info = new long[2]; HotSpotResolvedObjectTypeImpl resolvedHolder; try { - resolvedHolder = compilerToVM().resolveFieldInPool(this, index, (byte) opcode, info); + resolvedHolder = compilerToVM().resolveFieldInPool(this, index, (HotSpotResolvedJavaMethodImpl) method, (byte) opcode, info); } catch (Throwable t) { /* * If there was an exception resolving the field we give up and return an unresolved @@ -680,15 +689,15 @@ final class HotSpotConstantPool implements ConstantPool, MetaspaceWrapperObject if (!klass.isPrimitive() && !klass.isArray()) { UNSAFE.ensureClassInitialized(klass); } - switch (tag) { - case MethodRef: - if (Bytecodes.isInvokeHandleAlias(opcode)) { - final int methodRefCacheIndex = rawIndexToConstantPoolIndex(cpi, opcode); - if (isInvokeHandle(methodRefCacheIndex, type)) { - compilerToVM().resolveInvokeHandleInPool(this, methodRefCacheIndex); - } + if (tag == JVM_CONSTANT.MethodRef) { + if (Bytecodes.isInvokeHandleAlias(opcode)) { + final int methodRefCacheIndex = rawIndexToConstantPoolIndex(cpi, opcode); + if (isInvokeHandle(methodRefCacheIndex, type)) { + compilerToVM().resolveInvokeHandleInPool(this, methodRefCacheIndex); } + } } + break; case InvokeDynamic: if (isInvokedynamicIndex(cpi)) { diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotConstantReflectionProvider.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotConstantReflectionProvider.java index 9538dbcfbb8..e74027f2dd1 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotConstantReflectionProvider.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotConstantReflectionProvider.java @@ -25,7 +25,6 @@ package jdk.vm.ci.hotspot; import java.lang.reflect.Array; import java.util.Objects; -import jdk.internal.vm.annotation.Stable; import jdk.vm.ci.common.JVMCIError; import jdk.vm.ci.meta.Constant; import jdk.vm.ci.meta.ConstantReflectionProvider; diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotForeignCallTarget.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotForeignCallTarget.java index 2b4d0e1166f..cdce4f473f7 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotForeignCallTarget.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotForeignCallTarget.java @@ -29,6 +29,7 @@ public class HotSpotForeignCallTarget implements InvokeTarget { /** * The entry point address of this call's target. */ + @SuppressFBWarnings(value = "URF_UNREAD_PUBLIC_OR_PROTECTED_FIELD", justification = "accessed by subclasses")// protected long address; public HotSpotForeignCallTarget(long address) { diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCICompilerConfig.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCICompilerConfig.java index a3db464894a..672cf0b2b39 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCICompilerConfig.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCICompilerConfig.java @@ -22,8 +22,6 @@ */ package jdk.vm.ci.hotspot; -import java.lang.reflect.Module; - import jdk.vm.ci.code.CompilationRequest; import jdk.vm.ci.common.JVMCIError; import jdk.vm.ci.hotspot.HotSpotJVMCIRuntime.Option; @@ -68,7 +66,6 @@ final class HotSpotJVMCICompilerConfig { if (compilerName != null) { for (JVMCICompilerFactory f : Services.load(JVMCICompilerFactory.class)) { if (f.getCompilerName().equals(compilerName)) { - Module jvmciModule = JVMCICompilerFactory.class.getModule(); Services.exportJVMCITo(f.getClass()); f.onSelection(); factory = f; diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIMetaAccessContext.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIMetaAccessContext.java index c0de936bd4d..529a561eb5e 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIMetaAccessContext.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIMetaAccessContext.java @@ -135,6 +135,7 @@ public class HotSpotJVMCIMetaAccessContext { */ metadataRoots = list.getHead(); } + assert isRegistered(metaspaceObject); } protected ResolvedJavaType createClass(Class javaClass) { @@ -208,7 +209,7 @@ public class HotSpotJVMCIMetaAccessContext { ChunkIterator() { currentChunk = head; currentIndex = -1; - findNext(); + next = findNext(); } Object[] currentChunk; @@ -245,4 +246,13 @@ public class HotSpotJVMCIMetaAccessContext { } } + + synchronized boolean isRegistered(MetaspaceWrapperObject wrapper) { + for (WeakReference m : list) { + if (m != null && m.get() == wrapper) { + return true; + } + } + return false; + } } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIRuntime.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIRuntime.java index c8b12aefe32..4d6be98fc6f 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIRuntime.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIRuntime.java @@ -27,10 +27,6 @@ import static jdk.vm.ci.common.InitTimer.timer; import java.io.IOException; import java.io.OutputStream; import java.io.PrintStream; -import java.lang.reflect.Array; -import java.lang.reflect.Field; -import java.lang.reflect.Method; -import java.lang.reflect.Modifier; import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; @@ -48,6 +44,7 @@ import jdk.vm.ci.code.InstalledCode; import jdk.vm.ci.common.InitTimer; import jdk.vm.ci.common.JVMCIError; import jdk.vm.ci.hotspot.services.HotSpotJVMCICompilerFactory; +import jdk.vm.ci.hotspot.services.HotSpotJVMCICompilerFactory.CompilationLevel; import jdk.vm.ci.hotspot.services.HotSpotVMEventListener; import jdk.vm.ci.meta.JavaKind; import jdk.vm.ci.meta.JavaType; @@ -94,9 +91,10 @@ public final class HotSpotJVMCIRuntime implements HotSpotJVMCIRuntimeProvider { */ public enum Option { Compiler(String.class, null, "Selects the system compiler."), - // Note: The following one is not used (see InitTimer.ENABLED). + // Note: The following one is not used (see InitTimer.ENABLED). It is added here + // so that -Djvmci.PrintFlags=true shows the option. InitTimer(boolean.class, false, "Specifies if initialization timing is enabled."), - PrintConfig(boolean.class, false, "Prints all HotSpotVMConfig fields."), + PrintConfig(boolean.class, false, "Prints VM configuration available via JVMCI and exits."), PrintFlags(boolean.class, false, "Prints all JVMCI flags and exits."), ShowFlags(boolean.class, false, "Prints all JVMCI flags and continues."), TraceMethodDataFilter(String.class, null, ""); @@ -200,6 +198,7 @@ public final class HotSpotJVMCIRuntime implements HotSpotJVMCIRuntimeProvider { protected final CompilerToVM compilerToVm; + protected final HotSpotVMConfigStore configStore; protected final HotSpotVMConfig config; private final JVMCIBackend hostBackend; @@ -240,11 +239,13 @@ public final class HotSpotJVMCIRuntime implements HotSpotJVMCIRuntimeProvider { @SuppressWarnings("unused") private final String[] trivialPrefixes; @SuppressWarnings("try") + @SuppressFBWarnings(value = "DM_EXIT", justification = "PrintFlags is meant to exit the VM") private HotSpotJVMCIRuntime() { compilerToVm = new CompilerToVM(); try (InitTimer t = timer("HotSpotVMConfig")) { - config = new HotSpotVMConfig(compilerToVm); + configStore = new HotSpotVMConfigStore(compilerToVm); + config = new HotSpotVMConfig(configStore); } String hostArchitecture = config.getHostArchitectureName(); @@ -270,18 +271,32 @@ public final class HotSpotJVMCIRuntime implements HotSpotJVMCIRuntimeProvider { } if (Option.PrintConfig.getBoolean()) { - printConfig(config, compilerToVm); + printConfig(configStore, compilerToVm); + System.exit(0); } compilerFactory = HotSpotJVMCICompilerConfig.getCompilerFactory(); if (compilerFactory instanceof HotSpotJVMCICompilerFactory) { hsCompilerFactory = (HotSpotJVMCICompilerFactory) compilerFactory; trivialPrefixes = hsCompilerFactory.getTrivialPrefixes(); - compilationLevelAdjustment = hsCompilerFactory.getCompilationLevelAdjustment(config); + switch (hsCompilerFactory.getCompilationLevelAdjustment()) { + case None: + compilationLevelAdjustment = config.compLevelAdjustmentNone; + break; + case ByHolder: + compilationLevelAdjustment = config.compLevelAdjustmentByHolder; + break; + case ByFullSignature: + compilationLevelAdjustment = config.compLevelAdjustmentByFullSignature; + break; + default: + compilationLevelAdjustment = config.compLevelAdjustmentNone; + break; + } } else { hsCompilerFactory = null; trivialPrefixes = null; - compilationLevelAdjustment = 0; + compilationLevelAdjustment = config.compLevelAdjustmentNone; } } @@ -296,6 +311,10 @@ public final class HotSpotJVMCIRuntime implements HotSpotJVMCIRuntimeProvider { return metaAccessContext.fromClass(javaClass); } + public HotSpotVMConfigStore getConfigStore() { + return configStore; + } + public HotSpotVMConfig getConfig() { return config; } @@ -352,7 +371,35 @@ public final class HotSpotJVMCIRuntime implements HotSpotJVMCIRuntimeProvider { */ @SuppressWarnings({"unused"}) private int adjustCompilationLevel(Class declaringClass, String name, String signature, boolean isOsr, int level) { - return hsCompilerFactory.adjustCompilationLevel(config, declaringClass, name, signature, isOsr, level); + CompilationLevel curLevel; + if (level == config.compilationLevelNone) { + curLevel = CompilationLevel.None; + } else if (level == config.compilationLevelSimple) { + curLevel = CompilationLevel.Simple; + } else if (level == config.compilationLevelLimitedProfile) { + curLevel = CompilationLevel.LimitedProfile; + } else if (level == config.compilationLevelFullProfile) { + curLevel = CompilationLevel.FullProfile; + } else if (level == config.compilationLevelFullOptimization) { + curLevel = CompilationLevel.FullOptimization; + } else { + throw JVMCIError.shouldNotReachHere(); + } + + switch (hsCompilerFactory.adjustCompilationLevel(declaringClass, name, signature, isOsr, curLevel)) { + case None: + return config.compilationLevelNone; + case Simple: + return config.compilationLevelSimple; + case LimitedProfile: + return config.compilationLevelLimitedProfile; + case FullProfile: + return config.compilationLevelFullProfile; + case FullOptimization: + return config.compilationLevelFullOptimization; + default: + return level; + } } /** @@ -416,71 +463,40 @@ public final class HotSpotJVMCIRuntime implements HotSpotJVMCIRuntimeProvider { } } - private static void printConfig(HotSpotVMConfig config, CompilerToVM vm) { - Field[] fields = config.getClass().getDeclaredFields(); - Map sortedFields = new TreeMap<>(); - for (Field f : fields) { - if (!f.isSynthetic() && !Modifier.isStatic(f.getModifiers())) { - f.setAccessible(true); - sortedFields.put(f.getName(), f); - } - } - for (Field f : sortedFields.values()) { - try { - String line = String.format("%9s %-40s = %s%n", f.getType().getSimpleName(), f.getName(), pretty(f.get(config))); - byte[] lineBytes = line.getBytes(); - vm.writeDebugOutput(lineBytes, 0, lineBytes.length); - vm.flushDebugOutput(); - } catch (Exception e) { - } - } + @SuppressFBWarnings(value = "DM_DEFAULT_ENCODING", justification = "no localization here please!") + private static void printConfigLine(CompilerToVM vm, String format, Object... args) { + String line = String.format(format, args); + byte[] lineBytes = line.getBytes(); + vm.writeDebugOutput(lineBytes, 0, lineBytes.length); + vm.flushDebugOutput(); } - private static String pretty(Object value) { - if (value == null) { - return "null"; + private static void printConfig(HotSpotVMConfigStore store, CompilerToVM vm) { + TreeMap fields = new TreeMap<>(store.getFields()); + for (VMField field : fields.values()) { + if (!field.isStatic()) { + printConfigLine(vm, "[vmconfig:instance field] %s %s {offset=%d[0x%x]}%n", field.type, field.name, field.offset, field.offset); + } else { + String value = field.value == null ? "null" : String.format("%d[0x%x]", field.value, field.value); + printConfigLine(vm, "[vmconfig:static field] %s %s = %s {address=0x%x}%n", field.type, field.name, value, field.address); + } } - - Class klass = value.getClass(); - if (value instanceof String) { - return "\"" + value + "\""; - } else if (value instanceof Method) { - return "method \"" + ((Method) value).getName() + "\""; - } else if (value instanceof Class) { - return "class \"" + ((Class) value).getSimpleName() + "\""; - } else if (value instanceof Integer) { - if ((Integer) value < 10) { - return value.toString(); - } - return value + " (0x" + Integer.toHexString((Integer) value) + ")"; - } else if (value instanceof Long) { - if ((Long) value < 10 && (Long) value > -10) { - return value + "l"; - } - return value + "l (0x" + Long.toHexString((Long) value) + "l)"; - } else if (klass.isArray()) { - StringBuilder str = new StringBuilder(); - int dimensions = 0; - while (klass.isArray()) { - dimensions++; - klass = klass.getComponentType(); - } - int length = Array.getLength(value); - str.append(klass.getSimpleName()).append('[').append(length).append(']'); - for (int i = 1; i < dimensions; i++) { - str.append("[]"); - } - str.append(" {"); - for (int i = 0; i < length; i++) { - str.append(pretty(Array.get(value, i))); - if (i < length - 1) { - str.append(", "); - } - } - str.append('}'); - return str.toString(); + TreeMap flags = new TreeMap<>(store.getFlags()); + for (VMFlag flag : flags.values()) { + printConfigLine(vm, "[vmconfig:flag] %s %s = %s%n", flag.type, flag.name, flag.value); + } + TreeMap addresses = new TreeMap<>(store.getAddresses()); + for (Map.Entry e : addresses.entrySet()) { + printConfigLine(vm, "[vmconfig:address] %s = %d[0x%x]%n", e.getKey(), e.getValue(), e.getValue()); + } + TreeMap constants = new TreeMap<>(store.getConstants()); + for (Map.Entry e : constants.entrySet()) { + printConfigLine(vm, "[vmconfig:constant] %s = %d[0x%x]%n", e.getKey(), e.getValue(), e.getValue()); + } + TreeMap typeSizes = new TreeMap<>(store.getTypeSizes()); + for (Map.Entry e : typeSizes.entrySet()) { + printConfigLine(vm, "[vmconfig:type size] %s = %d%n", e.getKey(), e.getValue()); } - return value.toString(); } public OutputStream getLogStream() { diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIRuntimeProvider.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIRuntimeProvider.java index 6ad27247907..3397af80aa7 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIRuntimeProvider.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotJVMCIRuntimeProvider.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -36,6 +36,8 @@ import jdk.vm.ci.runtime.JVMCIRuntime; */ public interface HotSpotJVMCIRuntimeProvider extends JVMCIRuntime { + HotSpotVMConfigStore getConfigStore(); + HotSpotVMConfig getConfig(); CompilerToVM getCompilerToVM(); diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMemoryAccessProvider.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMemoryAccessProvider.java index c5779332e5a..a4d68b56f19 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMemoryAccessProvider.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMemoryAccessProvider.java @@ -22,7 +22,6 @@ */ package jdk.vm.ci.hotspot; -import jdk.vm.ci.hotspot.HotSpotVMConfig.CompressEncoding; import jdk.vm.ci.meta.Constant; import jdk.vm.ci.meta.JavaConstant; import jdk.vm.ci.meta.MemoryAccessProvider; @@ -32,11 +31,11 @@ import jdk.vm.ci.meta.MemoryAccessProvider; */ public interface HotSpotMemoryAccessProvider extends MemoryAccessProvider { - JavaConstant readNarrowOopConstant(Constant base, long displacement, CompressEncoding encoding); + JavaConstant readNarrowOopConstant(Constant base, long displacement); Constant readKlassPointerConstant(Constant base, long displacement); - Constant readNarrowKlassPointerConstant(Constant base, long displacement, CompressEncoding encoding); + Constant readNarrowKlassPointerConstant(Constant base, long displacement); Constant readMethodPointerConstant(Constant base, long displacement); } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMemoryAccessProviderImpl.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMemoryAccessProviderImpl.java index 1d8828bb3bf..6bdf2ee4598 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMemoryAccessProviderImpl.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMemoryAccessProviderImpl.java @@ -23,7 +23,7 @@ package jdk.vm.ci.hotspot; import static jdk.vm.ci.hotspot.UnsafeAccess.UNSAFE; -import jdk.vm.ci.hotspot.HotSpotVMConfig.CompressEncoding; + import jdk.vm.ci.meta.Constant; import jdk.vm.ci.meta.JavaConstant; import jdk.vm.ci.meta.JavaKind; @@ -206,8 +206,7 @@ class HotSpotMemoryAccessProviderImpl implements HotSpotMemoryAccessProvider { } @Override - public JavaConstant readNarrowOopConstant(Constant base, long displacement, CompressEncoding encoding) { - assert encoding.equals(runtime.getConfig().getOopEncoding()) : "unexpected oop encoding: " + encoding + " != " + runtime.getConfig().getOopEncoding(); + public JavaConstant readNarrowOopConstant(Constant base, long displacement) { return HotSpotObjectConstantImpl.forObject(readRawObject(base, displacement, true), true); } @@ -227,7 +226,7 @@ class HotSpotMemoryAccessProviderImpl implements HotSpotMemoryAccessProvider { } @Override - public Constant readNarrowKlassPointerConstant(Constant base, long displacement, CompressEncoding encoding) { + public Constant readNarrowKlassPointerConstant(Constant base, long displacement) { HotSpotResolvedObjectTypeImpl klass = readKlass(base, displacement, true); if (klass == null) { return HotSpotCompressedNullConstant.COMPRESSED_NULL; diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMethodData.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMethodData.java index dfdc3ebf3f6..0471ae50c48 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMethodData.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMethodData.java @@ -30,7 +30,7 @@ import static jdk.vm.ci.hotspot.UnsafeAccess.UNSAFE; import java.util.Arrays; -import jdk.vm.ci.hotspot.HotSpotMethodDataAccessor.Tag; +import jdk.internal.misc.Unsafe; import jdk.vm.ci.meta.DeoptimizationReason; import jdk.vm.ci.meta.JavaMethodProfile; import jdk.vm.ci.meta.JavaMethodProfile.ProfiledMethod; @@ -39,41 +39,20 @@ import jdk.vm.ci.meta.JavaTypeProfile.ProfiledType; import jdk.vm.ci.meta.ResolvedJavaMethod; import jdk.vm.ci.meta.ResolvedJavaType; import jdk.vm.ci.meta.TriState; -import jdk.internal.misc.Unsafe; /** - * Access to a HotSpot MethodData structure (defined in methodData.hpp). + * Access to a HotSpot {@code MethodData} structure (defined in methodData.hpp). */ -public final class HotSpotMethodData { +final class HotSpotMethodData { - private static final HotSpotVMConfig config = config(); - private static final HotSpotMethodDataAccessor NO_DATA_NO_EXCEPTION_ACCESSOR = new NoMethodData(TriState.FALSE); - private static final HotSpotMethodDataAccessor NO_DATA_EXCEPTION_POSSIBLY_NOT_RECORDED_ACCESSOR = new NoMethodData(TriState.UNKNOWN); - - // sorted by tag - // @formatter:off - private static final HotSpotMethodDataAccessor[] PROFILE_DATA_ACCESSORS = { - null, - new BitData(), - new CounterData(), - new JumpData(), - new ReceiverTypeData(), - new VirtualCallData(), - new RetData(), - new BranchData(), - new MultiBranchData(), - new ArgInfoData(), - new UnknownProfileData(Tag.CallTypeData), - new VirtualCallTypeData(), - new UnknownProfileData(Tag.ParametersTypeData), - new UnknownProfileData(Tag.SpeculativeTrapData), - }; - // @formatter:on + static final HotSpotVMConfig config = config(); + static final HotSpotMethodDataAccessor NO_DATA_NO_EXCEPTION_ACCESSOR = new NoMethodData(config, config.dataLayoutNoTag, TriState.FALSE); + static final HotSpotMethodDataAccessor NO_DATA_EXCEPTION_POSSIBLY_NOT_RECORDED_ACCESSOR = new NoMethodData(config, config.dataLayoutNoTag, TriState.UNKNOWN); /** * Reference to the C++ MethodData object. */ - private final long metaspaceMethodData; + final long metaspaceMethodData; @SuppressWarnings("unused") private final HotSpotResolvedJavaMethodImpl method; public HotSpotMethodData(long metaspaceMethodData, HotSpotResolvedJavaMethodImpl method) { @@ -133,10 +112,7 @@ public final class HotSpotMethodData { return null; } - HotSpotMethodDataAccessor result = getData(position); - final Tag tag = AbstractMethodData.readTag(this, position); - assert result != null : "NO_DATA tag is not allowed " + tag; - return result; + return getData(position); } public HotSpotMethodDataAccessor getExtraData(int position) { @@ -160,18 +136,18 @@ public final class HotSpotMethodData { private HotSpotMethodDataAccessor getData(int position) { assert position >= 0 : "out of bounds"; - final Tag tag = AbstractMethodData.readTag(this, position); - HotSpotMethodDataAccessor accessor = PROFILE_DATA_ACCESSORS[tag.getValue()]; + final int tag = HotSpotMethodDataAccessor.readTag(config, this, position); + HotSpotMethodDataAccessor accessor = PROFILE_DATA_ACCESSORS[tag]; assert accessor == null || accessor.getTag() == tag : "wrong data accessor " + accessor + " for tag " + tag; return accessor; } - private int readUnsignedByte(int position, int offsetInBytes) { + int readUnsignedByte(int position, int offsetInBytes) { long fullOffsetInBytes = computeFullOffset(position, offsetInBytes); return UNSAFE.getByte(metaspaceMethodData + fullOffsetInBytes) & 0xFF; } - private int readUnsignedShort(int position, int offsetInBytes) { + int readUnsignedShort(int position, int offsetInBytes) { long fullOffsetInBytes = computeFullOffset(position, offsetInBytes); return UNSAFE.getShort(metaspaceMethodData + fullOffsetInBytes) & 0xFFFF; } @@ -269,102 +245,14 @@ public final class HotSpotMethodData { return sb.toString(); } - private abstract static class AbstractMethodData implements HotSpotMethodDataAccessor { + static final int NO_DATA_SIZE = cellIndexToOffset(0); - /** - * Corresponds to {@code exception_seen_flag}. - */ - private static final int EXCEPTIONS_MASK = 1 << config.bitDataExceptionSeenFlag; - - private final Tag tag; - protected final int staticSize; - - protected AbstractMethodData(Tag tag, int staticSize) { - this.tag = tag; - this.staticSize = staticSize; - } - - public Tag getTag() { - return tag; - } - - public static Tag readTag(HotSpotMethodData data, int position) { - final int tag = data.readUnsignedByte(position, config.dataLayoutTagOffset); - return Tag.getEnum(tag); - } - - @Override - public int getBCI(HotSpotMethodData data, int position) { - return data.readUnsignedShort(position, config.dataLayoutBCIOffset); - } - - @Override - public final int getSize(HotSpotMethodData data, int position) { - int size = staticSize + getDynamicSize(data, position); - // Sanity check against VM - int vmSize = HotSpotJVMCIRuntime.runtime().compilerToVm.methodDataProfileDataSize(data.metaspaceMethodData, position); - assert size == vmSize : size + " != " + vmSize; - return size; - } - - @Override - public TriState getExceptionSeen(HotSpotMethodData data, int position) { - return TriState.get((getFlags(data, position) & EXCEPTIONS_MASK) != 0); - } - - @Override - public JavaTypeProfile getTypeProfile(HotSpotMethodData data, int position) { - return null; - } - - @Override - public JavaMethodProfile getMethodProfile(HotSpotMethodData data, int position) { - return null; - } - - @Override - public double getBranchTakenProbability(HotSpotMethodData data, int position) { - return -1; - } - - @Override - public double[] getSwitchProbabilities(HotSpotMethodData data, int position) { - return null; - } - - @Override - public int getExecutionCount(HotSpotMethodData data, int position) { - return -1; - } - - @Override - public TriState getNullSeen(HotSpotMethodData data, int position) { - return TriState.UNKNOWN; - } - - protected int getFlags(HotSpotMethodData data, int position) { - return data.readUnsignedByte(position, config.dataLayoutFlagsOffset); - } - - /** - * @param data - * @param position - */ - protected int getDynamicSize(HotSpotMethodData data, int position) { - return 0; - } - - public abstract StringBuilder appendTo(StringBuilder sb, HotSpotMethodData data, int pos); - } - - private static class NoMethodData extends AbstractMethodData { - - private static final int NO_DATA_SIZE = cellIndexToOffset(0); + static class NoMethodData extends HotSpotMethodDataAccessor { private final TriState exceptionSeen; - protected NoMethodData(TriState exceptionSeen) { - super(Tag.No, NO_DATA_SIZE); + protected NoMethodData(HotSpotVMConfig config, int tag, TriState exceptionSeen) { + super(config, tag, NO_DATA_SIZE); this.exceptionSeen = exceptionSeen; } @@ -384,17 +272,17 @@ public final class HotSpotMethodData { } } - private static class BitData extends AbstractMethodData { + static final int BIT_DATA_SIZE = cellIndexToOffset(0); + static final int BIT_DATA_NULL_SEEN_FLAG = 1 << config.bitDataNullSeenFlag; - private static final int BIT_DATA_SIZE = cellIndexToOffset(0); - private static final int BIT_DATA_NULL_SEEN_FLAG = 1 << config.bitDataNullSeenFlag; + static class BitData extends HotSpotMethodDataAccessor { - private BitData() { - super(Tag.BitData, BIT_DATA_SIZE); + private BitData(HotSpotVMConfig config, int tag) { + super(config, tag, BIT_DATA_SIZE); } - protected BitData(Tag tag, int staticSize) { - super(tag, staticSize); + protected BitData(HotSpotVMConfig config, int tag, int staticSize) { + super(config, tag, staticSize); } @Override @@ -408,17 +296,17 @@ public final class HotSpotMethodData { } } - private static class CounterData extends BitData { + static final int COUNTER_DATA_SIZE = cellIndexToOffset(1); + static final int COUNTER_DATA_COUNT_OFFSET = cellIndexToOffset(config.methodDataCountOffset); - private static final int COUNTER_DATA_SIZE = cellIndexToOffset(1); - private static final int COUNTER_DATA_COUNT_OFFSET = cellIndexToOffset(config.methodDataCountOffset); + static class CounterData extends BitData { - CounterData() { - super(Tag.CounterData, COUNTER_DATA_SIZE); + CounterData(HotSpotVMConfig config, int tag) { + super(config, tag, COUNTER_DATA_SIZE); } - protected CounterData(Tag tag, int staticSize) { - super(tag, staticSize); + protected CounterData(HotSpotVMConfig config, int tag, int staticSize) { + super(config, tag, staticSize); } @Override @@ -436,18 +324,18 @@ public final class HotSpotMethodData { } } - private static class JumpData extends AbstractMethodData { + static final int JUMP_DATA_SIZE = cellIndexToOffset(2); + static final int TAKEN_COUNT_OFFSET = cellIndexToOffset(config.jumpDataTakenOffset); + static final int TAKEN_DISPLACEMENT_OFFSET = cellIndexToOffset(config.jumpDataDisplacementOffset); - private static final int JUMP_DATA_SIZE = cellIndexToOffset(2); - protected static final int TAKEN_COUNT_OFFSET = cellIndexToOffset(config.jumpDataTakenOffset); - protected static final int TAKEN_DISPLACEMENT_OFFSET = cellIndexToOffset(config.jumpDataDisplacementOffset); + static class JumpData extends HotSpotMethodDataAccessor { - JumpData() { - super(Tag.JumpData, JUMP_DATA_SIZE); + JumpData(HotSpotVMConfig config, int tag) { + super(config, tag, JUMP_DATA_SIZE); } - protected JumpData(Tag tag, int staticSize) { - super(tag, staticSize); + protected JumpData(HotSpotVMConfig config, int tag, int staticSize) { + super(config, tag, staticSize); } @Override @@ -484,16 +372,16 @@ public final class HotSpotMethodData { } } - private abstract static class AbstractTypeData extends CounterData { + static final int TYPE_DATA_ROW_SIZE = cellsToBytes(config.receiverTypeDataReceiverTypeRowCellCount); - protected static final int TYPE_DATA_ROW_SIZE = cellsToBytes(config.receiverTypeDataReceiverTypeRowCellCount); + static final int NONPROFILED_COUNT_OFFSET = cellIndexToOffset(config.receiverTypeDataNonprofiledCountOffset); + static final int TYPE_DATA_FIRST_TYPE_OFFSET = cellIndexToOffset(config.receiverTypeDataReceiver0Offset); + static final int TYPE_DATA_FIRST_TYPE_COUNT_OFFSET = cellIndexToOffset(config.receiverTypeDataCount0Offset); - protected static final int NONPROFILED_COUNT_OFFSET = cellIndexToOffset(config.receiverTypeDataNonprofiledCountOffset); - protected static final int TYPE_DATA_FIRST_TYPE_OFFSET = cellIndexToOffset(config.receiverTypeDataReceiver0Offset); - protected static final int TYPE_DATA_FIRST_TYPE_COUNT_OFFSET = cellIndexToOffset(config.receiverTypeDataCount0Offset); + abstract static class AbstractTypeData extends CounterData { - protected AbstractTypeData(Tag tag, int staticSize) { - super(tag, staticSize); + protected AbstractTypeData(HotSpotVMConfig config, int tag, int staticSize) { + super(config, tag, staticSize); } @Override @@ -539,7 +427,7 @@ public final class HotSpotMethodData { protected abstract long getTypesNotRecordedExecutionCount(HotSpotMethodData data, int position); - private static JavaTypeProfile createTypeProfile(TriState nullSeen, RawItemProfile profile) { + private JavaTypeProfile createTypeProfile(TriState nullSeen, RawItemProfile profile) { if (profile.entries <= 0 || profile.totalCount <= 0) { return null; } @@ -583,16 +471,16 @@ public final class HotSpotMethodData { } } - private static class ReceiverTypeData extends AbstractTypeData { + static final int TYPE_CHECK_DATA_SIZE = cellIndexToOffset(2) + TYPE_DATA_ROW_SIZE * config.typeProfileWidth; - private static final int TYPE_CHECK_DATA_SIZE = cellIndexToOffset(2) + TYPE_DATA_ROW_SIZE * config.typeProfileWidth; + static class ReceiverTypeData extends AbstractTypeData { - ReceiverTypeData() { - super(Tag.ReceiverTypeData, TYPE_CHECK_DATA_SIZE); + ReceiverTypeData(HotSpotVMConfig config, int tag) { + super(config, tag, TYPE_CHECK_DATA_SIZE); } - protected ReceiverTypeData(Tag tag, int staticSize) { - super(tag, staticSize); + protected ReceiverTypeData(HotSpotVMConfig config, int tag, int staticSize) { + super(config, tag, staticSize); } @Override @@ -606,18 +494,18 @@ public final class HotSpotMethodData { } } - private static class VirtualCallData extends ReceiverTypeData { + static final int VIRTUAL_CALL_DATA_SIZE = cellIndexToOffset(2) + TYPE_DATA_ROW_SIZE * (config.typeProfileWidth + config.methodProfileWidth); + static final int VIRTUAL_CALL_DATA_FIRST_METHOD_OFFSET = TYPE_DATA_FIRST_TYPE_OFFSET + TYPE_DATA_ROW_SIZE * config.typeProfileWidth; + static final int VIRTUAL_CALL_DATA_FIRST_METHOD_COUNT_OFFSET = TYPE_DATA_FIRST_TYPE_COUNT_OFFSET + TYPE_DATA_ROW_SIZE * config.typeProfileWidth; - private static final int VIRTUAL_CALL_DATA_SIZE = cellIndexToOffset(2) + TYPE_DATA_ROW_SIZE * (config.typeProfileWidth + config.methodProfileWidth); - private static final int VIRTUAL_CALL_DATA_FIRST_METHOD_OFFSET = TYPE_DATA_FIRST_TYPE_OFFSET + TYPE_DATA_ROW_SIZE * config.typeProfileWidth; - private static final int VIRTUAL_CALL_DATA_FIRST_METHOD_COUNT_OFFSET = TYPE_DATA_FIRST_TYPE_COUNT_OFFSET + TYPE_DATA_ROW_SIZE * config.typeProfileWidth; + static class VirtualCallData extends ReceiverTypeData { - VirtualCallData() { - super(Tag.VirtualCallData, VIRTUAL_CALL_DATA_SIZE); + VirtualCallData(HotSpotVMConfig config, int tag) { + super(config, tag, VIRTUAL_CALL_DATA_SIZE); } - protected VirtualCallData(Tag tag, int staticSize) { - super(tag, staticSize); + protected VirtualCallData(HotSpotVMConfig config, int tag, int staticSize) { + super(config, tag, staticSize); } @Override @@ -647,7 +535,7 @@ public final class HotSpotMethodData { return createMethodProfile(getRawMethodProfile(data, position)); } - private static RawItemProfile getRawMethodProfile(HotSpotMethodData data, int position) { + private RawItemProfile getRawMethodProfile(HotSpotMethodData data, int position) { int profileWidth = config.methodProfileWidth; ResolvedJavaMethod[] methods = new ResolvedJavaMethod[profileWidth]; @@ -671,7 +559,7 @@ public final class HotSpotMethodData { return new RawItemProfile<>(entries, methods, counts, totalCount); } - private static JavaMethodProfile createMethodProfile(RawItemProfile profile) { + private JavaMethodProfile createMethodProfile(RawItemProfile profile) { if (profile.entries <= 0 || profile.totalCount <= 0) { return null; } @@ -712,10 +600,10 @@ public final class HotSpotMethodData { } } - private static class VirtualCallTypeData extends VirtualCallData { + static class VirtualCallTypeData extends VirtualCallData { - VirtualCallTypeData() { - super(Tag.VirtualCallTypeData, 0); + VirtualCallTypeData(HotSpotVMConfig config, int tag) { + super(config, tag, 0); } @Override @@ -725,23 +613,23 @@ public final class HotSpotMethodData { } } - private static class RetData extends CounterData { + static final int RET_DATA_ROW_SIZE = cellsToBytes(3); + static final int RET_DATA_SIZE = cellIndexToOffset(1) + RET_DATA_ROW_SIZE * config.bciProfileWidth; - private static final int RET_DATA_ROW_SIZE = cellsToBytes(3); - private static final int RET_DATA_SIZE = cellIndexToOffset(1) + RET_DATA_ROW_SIZE * config.bciProfileWidth; + static class RetData extends CounterData { - RetData() { - super(Tag.RetData, RET_DATA_SIZE); + RetData(HotSpotVMConfig config, int tag) { + super(config, tag, RET_DATA_SIZE); } } - private static class BranchData extends JumpData { + static final int BRANCH_DATA_SIZE = cellIndexToOffset(3); + static final int NOT_TAKEN_COUNT_OFFSET = cellIndexToOffset(config.branchDataNotTakenOffset); - private static final int BRANCH_DATA_SIZE = cellIndexToOffset(3); - private static final int NOT_TAKEN_COUNT_OFFSET = cellIndexToOffset(config.branchDataNotTakenOffset); + static class BranchData extends JumpData { - BranchData() { - super(Tag.BranchData, BRANCH_DATA_SIZE); + BranchData(HotSpotVMConfig config, int tag) { + super(config, tag, BRANCH_DATA_SIZE); } @Override @@ -768,13 +656,13 @@ public final class HotSpotMethodData { } } - private static class ArrayData extends AbstractMethodData { + static final int ARRAY_DATA_LENGTH_OFFSET = cellIndexToOffset(config.arrayDataArrayLenOffset); + static final int ARRAY_DATA_START_OFFSET = cellIndexToOffset(config.arrayDataArrayStartOffset); - private static final int ARRAY_DATA_LENGTH_OFFSET = cellIndexToOffset(config.arrayDataArrayLenOffset); - protected static final int ARRAY_DATA_START_OFFSET = cellIndexToOffset(config.arrayDataArrayStartOffset); + static class ArrayData extends HotSpotMethodDataAccessor { - ArrayData(Tag tag, int staticSize) { - super(tag, staticSize); + ArrayData(HotSpotVMConfig config, int tag, int staticSize) { + super(config, tag, staticSize); } @Override @@ -792,16 +680,16 @@ public final class HotSpotMethodData { } } - private static class MultiBranchData extends ArrayData { + static final int MULTI_BRANCH_DATA_SIZE = cellIndexToOffset(1); + static final int MULTI_BRANCH_DATA_ROW_SIZE_IN_CELLS = config.multiBranchDataPerCaseCellCount; + static final int MULTI_BRANCH_DATA_ROW_SIZE = cellsToBytes(MULTI_BRANCH_DATA_ROW_SIZE_IN_CELLS); + static final int MULTI_BRANCH_DATA_FIRST_COUNT_OFFSET = ARRAY_DATA_START_OFFSET + cellsToBytes(0); + static final int MULTI_BRANCH_DATA_FIRST_DISPLACEMENT_OFFSET = ARRAY_DATA_START_OFFSET + cellsToBytes(1); - private static final int MULTI_BRANCH_DATA_SIZE = cellIndexToOffset(1); - private static final int MULTI_BRANCH_DATA_ROW_SIZE_IN_CELLS = config.multiBranchDataPerCaseCellCount; - private static final int MULTI_BRANCH_DATA_ROW_SIZE = cellsToBytes(MULTI_BRANCH_DATA_ROW_SIZE_IN_CELLS); - private static final int MULTI_BRANCH_DATA_FIRST_COUNT_OFFSET = ARRAY_DATA_START_OFFSET + cellsToBytes(0); - private static final int MULTI_BRANCH_DATA_FIRST_DISPLACEMENT_OFFSET = ARRAY_DATA_START_OFFSET + cellsToBytes(1); + static class MultiBranchData extends ArrayData { - MultiBranchData() { - super(Tag.MultiBranchData, MULTI_BRANCH_DATA_SIZE); + MultiBranchData(HotSpotVMConfig config, int tag) { + super(config, tag, MULTI_BRANCH_DATA_SIZE); } @Override @@ -878,18 +766,18 @@ public final class HotSpotMethodData { } } - private static class ArgInfoData extends ArrayData { + static final int ARG_INFO_DATA_SIZE = cellIndexToOffset(1); - private static final int ARG_INFO_DATA_SIZE = cellIndexToOffset(1); + static class ArgInfoData extends ArrayData { - ArgInfoData() { - super(Tag.ArgInfoData, ARG_INFO_DATA_SIZE); + ArgInfoData(HotSpotVMConfig config, int tag) { + super(config, tag, ARG_INFO_DATA_SIZE); } } - private static class UnknownProfileData extends AbstractMethodData { - UnknownProfileData(Tag tag) { - super(tag, 0); + static class UnknownProfileData extends HotSpotMethodDataAccessor { + UnknownProfileData(HotSpotVMConfig config, int tag) { + super(config, tag, 0); } @Override @@ -900,7 +788,6 @@ public final class HotSpotMethodData { @Override public StringBuilder appendTo(StringBuilder sb, HotSpotMethodData data, int pos) { - // TODO Auto-generated method stub return null; } } @@ -912,4 +799,41 @@ public final class HotSpotMethodData { public int getCompiledIRSize() { return UNSAFE.getInt(metaspaceMethodData + config.methodDataIRSizeOffset); } + + // sorted by tag + // @formatter:off + static final HotSpotMethodDataAccessor[] PROFILE_DATA_ACCESSORS = { + null, + new BitData(config, config.dataLayoutBitDataTag), + new CounterData(config, config.dataLayoutCounterDataTag), + new JumpData(config, config.dataLayoutJumpDataTag), + new ReceiverTypeData(config, config.dataLayoutReceiverTypeDataTag), + new VirtualCallData(config, config.dataLayoutVirtualCallDataTag), + new RetData(config, config.dataLayoutRetDataTag), + new BranchData(config, config.dataLayoutBranchDataTag), + new MultiBranchData(config, config.dataLayoutMultiBranchDataTag), + new ArgInfoData(config, config.dataLayoutArgInfoDataTag), + new UnknownProfileData(config, config.dataLayoutCallTypeDataTag), + new VirtualCallTypeData(config, config.dataLayoutVirtualCallTypeDataTag), + new UnknownProfileData(config, config.dataLayoutParametersTypeDataTag), + new UnknownProfileData(config, config.dataLayoutSpeculativeTrapDataTag), + }; + + private static boolean checkAccessorTags() { + int expectedTag = 0; + for (HotSpotMethodDataAccessor accessor : PROFILE_DATA_ACCESSORS) { + if (expectedTag ==0 ) { + assert accessor == null; + } else { + assert accessor.tag == expectedTag: expectedTag + " != " + accessor.tag + " " + accessor; + } + expectedTag++; + } + return true; + } + + static { + assert checkAccessorTags(); + } + // @formatter:on } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMethodDataAccessor.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMethodDataAccessor.java index baf175f0e9a..6edff1da0a1 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMethodDataAccessor.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMethodDataAccessor.java @@ -1,110 +1,129 @@ -/* - * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ package jdk.vm.ci.hotspot; -import static jdk.vm.ci.hotspot.HotSpotVMConfig.config; import jdk.vm.ci.meta.JavaMethodProfile; import jdk.vm.ci.meta.JavaTypeProfile; import jdk.vm.ci.meta.ProfilingInfo; import jdk.vm.ci.meta.TriState; /** - * Interface for accessor objects that encapsulate the logic for accessing the different kinds of - * data in a HotSpot methodDataOop. This interface is similar to the interface {@link ProfilingInfo} - * , but most methods require a MethodDataObject and the exact position within the methodData. + * Base class for accessing the different kinds of data in a HotSpot {@code MethodData}. This is + * similar to {@link ProfilingInfo}, but most methods require a {@link HotSpotMethodData} and the + * exact position within the method data. */ -public interface HotSpotMethodDataAccessor { +abstract class HotSpotMethodDataAccessor { - /** - * {@code DataLayout} tag values. - */ - enum Tag { - No(config().dataLayoutNoTag), - BitData(config().dataLayoutBitDataTag), - CounterData(config().dataLayoutCounterDataTag), - JumpData(config().dataLayoutJumpDataTag), - ReceiverTypeData(config().dataLayoutReceiverTypeDataTag), - VirtualCallData(config().dataLayoutVirtualCallDataTag), - RetData(config().dataLayoutRetDataTag), - BranchData(config().dataLayoutBranchDataTag), - MultiBranchData(config().dataLayoutMultiBranchDataTag), - ArgInfoData(config().dataLayoutArgInfoDataTag), - CallTypeData(config().dataLayoutCallTypeDataTag), - VirtualCallTypeData(config().dataLayoutVirtualCallTypeDataTag), - ParametersTypeData(config().dataLayoutParametersTypeDataTag), - SpeculativeTrapData(config().dataLayoutSpeculativeTrapDataTag); + final int tag; + final int staticSize; + final HotSpotVMConfig config; - private final int value; - - Tag(int value) { - this.value = value; - } - - public int getValue() { - return value; - } - - public static Tag getEnum(int value) { - Tag result = values()[value]; - assert value == result.value; - return result; - } + protected HotSpotMethodDataAccessor(HotSpotVMConfig config, int tag, int staticSize) { + this.config = config; + this.tag = tag; + this.staticSize = staticSize; } /** - * Returns the {@link Tag} stored in the LayoutData header. + * Returns the tag stored in the LayoutData header. * * @return tag stored in the LayoutData header */ - Tag getTag(); + int getTag() { + return tag; + } + + static int readTag(HotSpotVMConfig config, HotSpotMethodData data, int position) { + final int tag = data.readUnsignedByte(position, config.dataLayoutTagOffset); + assert tag >= config.dataLayoutNoTag && tag <= config.dataLayoutSpeculativeTrapDataTag : "profile data tag out of bounds: " + tag; + return tag; + } /** * Returns the BCI stored in the LayoutData header. * - * @return An integer ≥ 0 and ≤ Short.MAX_VALUE, or -1 if not supported. + * @return an integer between 0 and {@link Short#MAX_VALUE} inclusive, or -1 if not supported */ - int getBCI(HotSpotMethodData data, int position); + int getBCI(HotSpotMethodData data, int position) { + return data.readUnsignedShort(position, config.dataLayoutBCIOffset); + } /** * Computes the size for the specific data at the given position. * - * @return An integer > 0. + * @return a value greater than 0 */ - int getSize(HotSpotMethodData data, int position); + final int getSize(HotSpotMethodData data, int position) { + int size = staticSize + getDynamicSize(data, position); + // Sanity check against VM + int vmSize = HotSpotJVMCIRuntime.runtime().compilerToVm.methodDataProfileDataSize(data.metaspaceMethodData, position); + assert size == vmSize : size + " != " + vmSize; + return size; + } - JavaTypeProfile getTypeProfile(HotSpotMethodData data, int position); + TriState getExceptionSeen(HotSpotMethodData data, int position) { + final int EXCEPTIONS_MASK = 1 << config.bitDataExceptionSeenFlag; + return TriState.get((getFlags(data, position) & EXCEPTIONS_MASK) != 0); + } - JavaMethodProfile getMethodProfile(HotSpotMethodData data, int position); + /** + * @param data + * @param position + */ + JavaTypeProfile getTypeProfile(HotSpotMethodData data, int position) { + return null; + } - double getBranchTakenProbability(HotSpotMethodData data, int position); + /** + * @param data + * @param position + */ + JavaMethodProfile getMethodProfile(HotSpotMethodData data, int position) { + return null; + } - double[] getSwitchProbabilities(HotSpotMethodData data, int position); + /** + * @param data + * @param position + */ + double getBranchTakenProbability(HotSpotMethodData data, int position) { + return -1; + } - TriState getExceptionSeen(HotSpotMethodData data, int position); + /** + * @param data + * @param position + */ + double[] getSwitchProbabilities(HotSpotMethodData data, int position) { + return null; + } - TriState getNullSeen(HotSpotMethodData data, int position); + /** + * @param data + * @param position + */ + int getExecutionCount(HotSpotMethodData data, int position) { + return -1; + } - int getExecutionCount(HotSpotMethodData data, int position); + /** + * @param data + * @param position + */ + TriState getNullSeen(HotSpotMethodData data, int position) { + return TriState.UNKNOWN; + } - StringBuilder appendTo(StringBuilder sb, HotSpotMethodData data, int pos); -} + protected int getFlags(HotSpotMethodData data, int position) { + return data.readUnsignedByte(position, config.dataLayoutFlagsOffset); + } + + /** + * @param data + * @param position + */ + protected int getDynamicSize(HotSpotMethodData data, int position) { + return 0; + } + + abstract StringBuilder appendTo(StringBuilder sb, HotSpotMethodData data, int pos); + +} \ No newline at end of file diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotReferenceMap.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotReferenceMap.java index 8d88147688b..bb983c173e9 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotReferenceMap.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotReferenceMap.java @@ -27,13 +27,25 @@ import java.util.Arrays; import jdk.vm.ci.code.Location; import jdk.vm.ci.code.ReferenceMap; +/** + * Describes where the object references are in machine state, compliant with what HotSpot expects. + */ public final class HotSpotReferenceMap extends ReferenceMap { - final Location[] objects; - final Location[] derivedBase; - final int[] sizeInBytes; - final int maxRegisterSize; + private final Location[] objects; + private final Location[] derivedBase; + private final int[] sizeInBytes; + private final int maxRegisterSize; + /** + * + * @param objects This array is now owned by this object and must not be mutated by the caller. + * @param derivedBase This array is now owned by this object and must not be mutated by the + * caller. + * @param sizeInBytes This array is now owned by this object and must not be mutated by the + * caller. + */ + @SuppressFBWarnings(value = "EI_EXPOSE_REP2", justification = "caller transfers ownership of `objects`, `derivedBase` and `sizeInBytes`") public HotSpotReferenceMap(Location[] objects, Location[] derivedBase, int[] sizeInBytes, int maxRegisterSize) { this.objects = objects; this.derivedBase = derivedBase; diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotResolvedJavaFieldImpl.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotResolvedJavaFieldImpl.java index e8544775ec0..3cd69d9a9c0 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotResolvedJavaFieldImpl.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotResolvedJavaFieldImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -28,12 +28,8 @@ import java.lang.annotation.Annotation; import java.lang.reflect.Field; import jdk.internal.vm.annotation.Stable; -import jdk.vm.ci.common.JVMCIError; -import jdk.vm.ci.hotspot.HotSpotJVMCIRuntime.Option; import jdk.vm.ci.meta.JavaType; -import jdk.vm.ci.meta.MetaAccessProvider; import jdk.vm.ci.meta.ModifiersProvider; -import jdk.vm.ci.meta.ResolvedJavaField; import jdk.vm.ci.meta.ResolvedJavaType; /** diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotResolvedObjectTypeImpl.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotResolvedObjectTypeImpl.java index f180891829e..636c26c2c6c 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotResolvedObjectTypeImpl.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotResolvedObjectTypeImpl.java @@ -132,10 +132,20 @@ final class HotSpotResolvedObjectTypeImpl extends HotSpotResolvedJavaType implem return UNSAFE.getInt(javaClass, config().klassOffset) & 0xFFFFFFFFL; } + @Override public long getMetaspacePointer() { return getMetaspaceKlass(); } + /** + * The Klass* for this object is kept alive by the direct reference to {@link #javaClass} so no + * extra work is required. + */ + @Override + public boolean isRegistered() { + return true; + } + @Override public int getModifiers() { if (isArray()) { @@ -428,7 +438,13 @@ final class HotSpotResolvedObjectTypeImpl extends HotSpotResolvedJavaType implem } public HotSpotConstantPool getConstantPool() { - if (constantPool == null) { + if (constantPool == null || !isArray() && UNSAFE.getAddress(getMetaspaceKlass() + config().instanceKlassConstantsOffset) != constantPool.getMetaspaceConstantPool()) { + /* + * If the pointer to the ConstantPool has changed since this was last read refresh the + * HotSpotConstantPool wrapper object. This ensures that uses of the constant pool are + * operating on the latest one and that HotSpotResolvedJavaMethodImpls will be able to + * use the shared copy instead of creating their own instance. + */ constantPool = compilerToVM().getConstantPool(this, config().instanceKlassConstantsOffset); } return constantPool; @@ -575,7 +591,8 @@ final class HotSpotResolvedObjectTypeImpl extends HotSpotResolvedJavaType implem // Get Klass::_fields final long metaspaceFields = UNSAFE.getAddress(getMetaspaceKlass() + config.instanceKlassFieldsOffset); assert config.fieldInfoFieldSlots == 6 : "revisit the field parsing code"; - metaspaceData = metaspaceFields + config.arrayU2DataOffset + config.fieldInfoFieldSlots * Short.BYTES * index; + int offset = config.fieldInfoFieldSlots * Short.BYTES * index; + metaspaceData = metaspaceFields + config.arrayU2DataOffset + offset; } private int getAccessFlags() { @@ -603,7 +620,8 @@ final class HotSpotResolvedObjectTypeImpl extends HotSpotResolvedJavaType implem * on top an array of Java shorts. */ private int readFieldSlot(int index) { - return UNSAFE.getChar(metaspaceData + Short.BYTES * index); + int offset = Short.BYTES * index; + return UNSAFE.getChar(metaspaceData + offset); } /** @@ -612,7 +630,7 @@ final class HotSpotResolvedObjectTypeImpl extends HotSpotResolvedJavaType implem */ public String getName() { final int nameIndex = getNameIndex(); - return isInternal() ? HotSpotVmSymbols.symbolAt(nameIndex) : getConstantPool().lookupUtf8(nameIndex); + return isInternal() ? config().symbolAt(nameIndex) : getConstantPool().lookupUtf8(nameIndex); } /** @@ -621,7 +639,7 @@ final class HotSpotResolvedObjectTypeImpl extends HotSpotResolvedJavaType implem */ public String getSignature() { final int signatureIndex = getSignatureIndex(); - return isInternal() ? HotSpotVmSymbols.symbolAt(signatureIndex) : getConstantPool().lookupUtf8(signatureIndex); + return isInternal() ? config().symbolAt(signatureIndex) : getConstantPool().lookupUtf8(signatureIndex); } public JavaType getType() { @@ -642,6 +660,7 @@ final class HotSpotResolvedObjectTypeImpl extends HotSpotResolvedJavaType implem } } + @SuppressFBWarnings(value = "SE_COMPARATOR_SHOULD_BE_SERIALIZABLE", justification = "comparator is only used transiently") private static class OffsetComparator implements java.util.Comparator { @Override public int compare(HotSpotResolvedJavaField o1, HotSpotResolvedJavaField o2) { diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotSpeculationLog.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotSpeculationLog.java index 0cd643fa3ca..989c719144b 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotSpeculationLog.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotSpeculationLog.java @@ -35,7 +35,7 @@ public class HotSpotSpeculationLog implements SpeculationLog { /** Written by the C++ code that performs deoptimization. */ private volatile Object lastFailed; - /** All speculations that have been a deoptimization reason. */ + /** All speculations that have caused a deoptimization. */ private Set failedSpeculations; /** Strong references to all reasons embedded in the current nmethod. */ @@ -54,7 +54,7 @@ public class HotSpotSpeculationLog implements SpeculationLog { } @Override - public boolean maySpeculate(SpeculationReason reason) { + public synchronized boolean maySpeculate(SpeculationReason reason) { if (failedSpeculations != null && failedSpeculations.contains(reason)) { return false; } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVMConfig.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVMConfig.java index b20da3d535b..c446eda9aac 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVMConfig.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVMConfig.java @@ -25,1639 +25,310 @@ package jdk.vm.ci.hotspot; import static jdk.vm.ci.hotspot.HotSpotJVMCIRuntime.runtime; import static jdk.vm.ci.hotspot.UnsafeAccess.UNSAFE; -import java.lang.reflect.Field; -import java.lang.reflect.Modifier; -import java.util.HashMap; -import java.util.Iterator; - import jdk.internal.misc.Unsafe; -import jdk.internal.vm.annotation.Stable; -import jdk.vm.ci.common.JVMCIError; -import jdk.vm.ci.hotspotvmconfig.HotSpotVMAddress; -import jdk.vm.ci.hotspotvmconfig.HotSpotVMConstant; -import jdk.vm.ci.hotspotvmconfig.HotSpotVMData; -import jdk.vm.ci.hotspotvmconfig.HotSpotVMField; -import jdk.vm.ci.hotspotvmconfig.HotSpotVMFlag; -import jdk.vm.ci.hotspotvmconfig.HotSpotVMType; /** * Used to access native configuration details. * * All non-static, public fields in this class are so that they can be compiled as constants. */ -public class HotSpotVMConfig { +class HotSpotVMConfig extends HotSpotVMConfigAccess { /** * Gets the configuration associated with the singleton {@link HotSpotJVMCIRuntime}. */ - public static HotSpotVMConfig config() { + static HotSpotVMConfig config() { return runtime().getConfig(); } - /** - * Maximum allowed size of allocated area for a frame. - */ - public final int maxFrameSize = 16 * 1024; + private final String osArch = getHostArchitectureName(); - public HotSpotVMConfig(CompilerToVM compilerToVm) { - // Get raw pointer to the array that contains all gHotSpotVM values. - final long gHotSpotVMData = compilerToVm.initializeConfiguration(this); - assert gHotSpotVMData != 0; - - // Make FindBugs happy. - jvmciHotSpotVMStructs = 0; - jvmciHotSpotVMTypes = 0; - jvmciHotSpotVMIntConstants = 0; - jvmciHotSpotVMLongConstants = 0; - jvmciHotSpotVMAddresses = 0; - - // Initialize the gHotSpotVM fields. - for (Field f : HotSpotVMConfig.class.getDeclaredFields()) { - if (f.isAnnotationPresent(HotSpotVMData.class)) { - HotSpotVMData annotation = f.getAnnotation(HotSpotVMData.class); - final int index = annotation.index(); - final long value = UNSAFE.getAddress(gHotSpotVMData + Unsafe.ADDRESS_SIZE * index); - try { - f.setLong(this, value); - } catch (IllegalAccessException e) { - throw new JVMCIError("index " + index, e); - } - } - } - - // Quick sanity check. - assert jvmciHotSpotVMStructs != 0; - assert jvmciHotSpotVMTypes != 0; - assert jvmciHotSpotVMIntConstants != 0; - assert jvmciHotSpotVMLongConstants != 0; - assert jvmciHotSpotVMAddresses != 0; - - initialize(); - - oopEncoding = new CompressEncoding(narrowOopBase, narrowOopShift, logMinObjAlignment()); - klassEncoding = new CompressEncoding(narrowKlassBase, narrowKlassShift, logKlassAlignment); - - assert check(); - assert HotSpotVMConfigVerifier.check(); - } - - @Override - public String toString() { - return getClass().getSimpleName(); - } - - /** - * Reads a {@code '\0'} terminated C string from native memory and converts it to a - * {@link String}. - * - * @return a Java string - */ - private static String readCString(Unsafe unsafe, long address) { - if (address == 0) { - return null; - } - StringBuilder sb = new StringBuilder(); - for (int i = 0;; i++) { - char c = (char) unsafe.getByte(address + i); - if (c == 0) { - break; - } - sb.append(c); - } - return sb.toString(); - } - - /** - * Initialize fields by reading their values from vmStructs. - */ - private void initialize() { - // Fill the VM fields hash map. - HashMap vmFields = new HashMap<>(); - for (VMFields.Field e : new VMFields(jvmciHotSpotVMStructs)) { - vmFields.put(e.getName(), e); - } - - // Fill the VM types hash map. - HashMap vmTypes = new HashMap<>(); - for (VMTypes.Type e : new VMTypes(jvmciHotSpotVMTypes)) { - vmTypes.put(e.getTypeName(), e); - } - - // Fill the VM constants hash map. - HashMap vmConstants = new HashMap<>(); - for (AbstractConstant e : new VMIntConstants(jvmciHotSpotVMIntConstants)) { - vmConstants.put(e.getName(), e); - } - for (AbstractConstant e : new VMLongConstants(jvmciHotSpotVMLongConstants)) { - vmConstants.put(e.getName(), e); - } - - // Fill the VM addresses hash map. - HashMap vmAddresses = new HashMap<>(); - for (VMAddresses.Address e : new VMAddresses(jvmciHotSpotVMAddresses)) { - vmAddresses.put(e.getName(), e); - } - - // Fill the flags hash map. - HashMap flags = new HashMap<>(); - for (Flags.Flag e : new Flags(vmFields, vmTypes)) { - flags.put(e.getName(), e); - } - - String osName = getHostOSName(); - String osArch = getHostArchitectureName(); - - for (Field f : HotSpotVMConfig.class.getDeclaredFields()) { - if (f.isAnnotationPresent(HotSpotVMField.class)) { - HotSpotVMField annotation = f.getAnnotation(HotSpotVMField.class); - String name = annotation.name(); - String type = annotation.type(); - VMFields.Field entry = vmFields.get(name); - if (entry == null) { - if (!isRequired(osArch, annotation.archs())) { - continue; - } - throw new JVMCIError(f.getName() + ": expected VM field not found: " + name); - } - - // Make sure the native type is still the type we expect. - if (!type.isEmpty()) { - if (!type.equals(entry.getTypeString())) { - throw new JVMCIError(f.getName() + ": compiler expects type " + type + " but VM field " + name + " is of type " + entry.getTypeString()); - } - } - - switch (annotation.get()) { - case OFFSET: - setField(f, entry.getOffset()); - break; - case ADDRESS: - setField(f, entry.getAddress()); - break; - case VALUE: - setField(f, entry.getValue()); - break; - default: - throw new JVMCIError(f.getName() + ": unknown kind: " + annotation.get()); - } - } else if (f.isAnnotationPresent(HotSpotVMType.class)) { - HotSpotVMType annotation = f.getAnnotation(HotSpotVMType.class); - String name = annotation.name(); - VMTypes.Type entry = vmTypes.get(name); - if (entry == null) { - throw new JVMCIError(f.getName() + ": expected VM type not found: " + name); - } - - switch (annotation.get()) { - case SIZE: - setField(f, entry.getSize()); - break; - default: - throw new JVMCIError(f.getName() + ": unknown kind: " + annotation.get()); - } - } else if (f.isAnnotationPresent(HotSpotVMConstant.class)) { - HotSpotVMConstant annotation = f.getAnnotation(HotSpotVMConstant.class); - String name = annotation.name(); - AbstractConstant entry = vmConstants.get(name); - if (entry == null) { - if (!isRequired(osArch, annotation.archs())) { - continue; - } - throw new JVMCIError(f.getName() + ": expected VM constant not found: " + name); - } - setField(f, entry.getValue()); - } else if (f.isAnnotationPresent(HotSpotVMAddress.class)) { - HotSpotVMAddress annotation = f.getAnnotation(HotSpotVMAddress.class); - String name = annotation.name(); - VMAddresses.Address entry = vmAddresses.get(name); - if (entry == null) { - if (!isRequired(osName, annotation.os())) { - continue; - } - throw new JVMCIError(f.getName() + ": expected VM address not found: " + name); - } - setField(f, entry.getValue()); - } else if (f.isAnnotationPresent(HotSpotVMFlag.class)) { - HotSpotVMFlag annotation = f.getAnnotation(HotSpotVMFlag.class); - String name = annotation.name(); - Flags.Flag entry = flags.get(name); - if (entry == null) { - if (annotation.optional() || !isRequired(osArch, annotation.archs())) { - continue; - } - throw new JVMCIError(f.getName() + ": expected VM flag not found: " + name); - - } - setField(f, entry.getValue()); - } - } - } - - private final CompressEncoding oopEncoding; - private final CompressEncoding klassEncoding; - - public CompressEncoding getOopEncoding() { - return oopEncoding; - } - - public CompressEncoding getKlassEncoding() { - return klassEncoding; - } - - private void setField(Field field, Object value) { - try { - Class fieldType = field.getType(); - if (fieldType == boolean.class) { - if (value instanceof String) { - field.setBoolean(this, Boolean.valueOf((String) value)); - } else if (value instanceof Boolean) { - field.setBoolean(this, (boolean) value); - } else if (value instanceof Long) { - field.setBoolean(this, ((long) value) != 0); - } else { - throw new JVMCIError(value.getClass().getSimpleName()); - } - } else if (fieldType == byte.class) { - if (value instanceof Long) { - field.setByte(this, (byte) (long) value); - } else { - throw new JVMCIError(value.getClass().getSimpleName()); - } - } else if (fieldType == int.class) { - if (value instanceof Integer) { - field.setInt(this, (int) value); - } else if (value instanceof Long) { - field.setInt(this, (int) (long) value); - } else { - throw new JVMCIError(value.getClass().getSimpleName()); - } - } else if (fieldType == long.class) { - field.setLong(this, (long) value); - } else { - throw new JVMCIError(field.toString()); - } - } catch (IllegalAccessException e) { - throw new JVMCIError("%s: %s", field, e); - } - } - - /** - * Gets the host operating system name. - */ - private static String getHostOSName() { - String osName = System.getProperty("os.name"); - switch (osName) { - case "Linux": - osName = "linux"; - break; - case "SunOS": - osName = "solaris"; - break; - case "Mac OS X": - osName = "bsd"; - break; - default: - // Of course Windows is different... - if (osName.startsWith("Windows")) { - osName = "windows"; - } else { - throw new JVMCIError("Unexpected OS name: " + osName); - } - } - return osName; + HotSpotVMConfig(HotSpotVMConfigStore store) { + super(store); } /** * Gets the host architecture name for the purpose of finding the corresponding * {@linkplain HotSpotJVMCIBackendFactory backend}. */ - public String getHostArchitectureName() { + String getHostArchitectureName() { String arch = System.getProperty("os.arch"); switch (arch) { case "x86_64": - arch = "amd64"; - break; + return "amd64"; + case "sparcv9": - arch = "sparc"; - break; - } - return arch; - } - - /** - * Determines if the current specification is included in a given set of specifications. - * - * @param current - * @param specification specifies a set of specifications, e.g. architectures or operating - * systems. A zero length value implies all. - */ - private static boolean isRequired(String current, String[] specification) { - if (specification.length == 0) { - return true; - } - for (String arch : specification) { - if (arch.equals(current)) { - return true; - } - } - return false; - } - - /** - * VMStructEntry (see {@code vmStructs.hpp}). - */ - @HotSpotVMData(index = 0) @Stable private long jvmciHotSpotVMStructs; - @HotSpotVMData(index = 1) @Stable private long jvmciHotSpotVMStructEntryTypeNameOffset; - @HotSpotVMData(index = 2) @Stable private long jvmciHotSpotVMStructEntryFieldNameOffset; - @HotSpotVMData(index = 3) @Stable private long jvmciHotSpotVMStructEntryTypeStringOffset; - @HotSpotVMData(index = 4) @Stable private long jvmciHotSpotVMStructEntryIsStaticOffset; - @HotSpotVMData(index = 5) @Stable private long jvmciHotSpotVMStructEntryOffsetOffset; - @HotSpotVMData(index = 6) @Stable private long jvmciHotSpotVMStructEntryAddressOffset; - @HotSpotVMData(index = 7) @Stable private long jvmciHotSpotVMStructEntryArrayStride; - - final class VMFields implements Iterable { - - private final long address; - - VMFields(long address) { - this.address = address; - } - - public Iterator iterator() { - return new Iterator() { - - private int index = 0; - - private Field current() { - return new Field(address + jvmciHotSpotVMStructEntryArrayStride * index); - } - - /** - * The last entry is identified by a NULL fieldName. - */ - public boolean hasNext() { - Field entry = current(); - return entry.getFieldName() != null; - } - - public Field next() { - Field entry = current(); - index++; - return entry; - } - }; - } - - final class Field { - - private final long entryAddress; - - Field(long address) { - this.entryAddress = address; - } - - public String getTypeName() { - long typeNameAddress = UNSAFE.getAddress(entryAddress + jvmciHotSpotVMStructEntryTypeNameOffset); - return readCString(UNSAFE, typeNameAddress); - } - - public String getFieldName() { - long fieldNameAddress = UNSAFE.getAddress(entryAddress + jvmciHotSpotVMStructEntryFieldNameOffset); - return readCString(UNSAFE, fieldNameAddress); - } - - public String getTypeString() { - long typeStringAddress = UNSAFE.getAddress(entryAddress + jvmciHotSpotVMStructEntryTypeStringOffset); - return readCString(UNSAFE, typeStringAddress); - } - - public boolean isStatic() { - return UNSAFE.getInt(entryAddress + jvmciHotSpotVMStructEntryIsStaticOffset) != 0; - } - - public long getOffset() { - return UNSAFE.getLong(entryAddress + jvmciHotSpotVMStructEntryOffsetOffset); - } - - public long getAddress() { - return UNSAFE.getAddress(entryAddress + jvmciHotSpotVMStructEntryAddressOffset); - } - - public String getName() { - String typeName = getTypeName(); - String fieldName = getFieldName(); - return typeName + "::" + fieldName; - } - - public long getValue() { - String type = getTypeString(); - switch (type) { - case "bool": - return UNSAFE.getByte(getAddress()); - case "int": - return UNSAFE.getInt(getAddress()); - case "uint64_t": - return UNSAFE.getLong(getAddress()); - case "address": - case "intptr_t": - case "uintptr_t": - case "size_t": - return UNSAFE.getAddress(getAddress()); - default: - // All foo* types are addresses. - if (type.endsWith("*")) { - return UNSAFE.getAddress(getAddress()); - } - throw new JVMCIError(type); - } - } - - @Override - public String toString() { - return String.format("Field[typeName=%s, fieldName=%s, typeString=%s, isStatic=%b, offset=%d, address=0x%x]", getTypeName(), getFieldName(), getTypeString(), isStatic(), getOffset(), - getAddress()); - } + return "sparc"; + default: + return arch; } } - /** - * VMTypeEntry (see vmStructs.hpp). - */ - @HotSpotVMData(index = 8) @Stable private long jvmciHotSpotVMTypes; - @HotSpotVMData(index = 9) @Stable private long jvmciHotSpotVMTypeEntryTypeNameOffset; - @HotSpotVMData(index = 10) @Stable private long jvmciHotSpotVMTypeEntrySuperclassNameOffset; - @HotSpotVMData(index = 11) @Stable private long jvmciHotSpotVMTypeEntryIsOopTypeOffset; - @HotSpotVMData(index = 12) @Stable private long jvmciHotSpotVMTypeEntryIsIntegerTypeOffset; - @HotSpotVMData(index = 13) @Stable private long jvmciHotSpotVMTypeEntryIsUnsignedOffset; - @HotSpotVMData(index = 14) @Stable private long jvmciHotSpotVMTypeEntrySizeOffset; - @HotSpotVMData(index = 15) @Stable private long jvmciHotSpotVMTypeEntryArrayStride; + final boolean useDeferredInitBarriers = getFlag("ReduceInitialCardMarks", Boolean.class); - final class VMTypes implements Iterable { + final boolean useCompressedOops = getFlag("UseCompressedOops", Boolean.class); - private final long address; - - VMTypes(long address) { - this.address = address; - } - - public Iterator iterator() { - return new Iterator() { - - private int index = 0; - - private Type current() { - return new Type(address + jvmciHotSpotVMTypeEntryArrayStride * index); - } - - /** - * The last entry is identified by a NULL type name. - */ - public boolean hasNext() { - Type entry = current(); - return entry.getTypeName() != null; - } - - public Type next() { - Type entry = current(); - index++; - return entry; - } - }; - } - - final class Type { - - private final long entryAddress; - - Type(long address) { - this.entryAddress = address; - } - - public String getTypeName() { - long typeNameAddress = UNSAFE.getAddress(entryAddress + jvmciHotSpotVMTypeEntryTypeNameOffset); - return readCString(UNSAFE, typeNameAddress); - } - - public String getSuperclassName() { - long superclassNameAddress = UNSAFE.getAddress(entryAddress + jvmciHotSpotVMTypeEntrySuperclassNameOffset); - return readCString(UNSAFE, superclassNameAddress); - } - - public boolean isOopType() { - return UNSAFE.getInt(entryAddress + jvmciHotSpotVMTypeEntryIsOopTypeOffset) != 0; - } - - public boolean isIntegerType() { - return UNSAFE.getInt(entryAddress + jvmciHotSpotVMTypeEntryIsIntegerTypeOffset) != 0; - } - - public boolean isUnsigned() { - return UNSAFE.getInt(entryAddress + jvmciHotSpotVMTypeEntryIsUnsignedOffset) != 0; - } - - public long getSize() { - return UNSAFE.getLong(entryAddress + jvmciHotSpotVMTypeEntrySizeOffset); - } - - @Override - public String toString() { - return String.format("Type[typeName=%s, superclassName=%s, isOopType=%b, isIntegerType=%b, isUnsigned=%b, size=%d]", getTypeName(), getSuperclassName(), isOopType(), isIntegerType(), - isUnsigned(), getSize()); - } - } - } - - public abstract class AbstractConstant { - - protected final long address; - protected final long nameOffset; - protected final long valueOffset; - - AbstractConstant(long address, long nameOffset, long valueOffset) { - this.address = address; - this.nameOffset = nameOffset; - this.valueOffset = valueOffset; - } - - public String getName() { - long nameAddress = UNSAFE.getAddress(address + nameOffset); - return readCString(UNSAFE, nameAddress); - } - - public abstract long getValue(); - } - - /** - * VMIntConstantEntry (see vmStructs.hpp). - */ - @HotSpotVMData(index = 16) @Stable private long jvmciHotSpotVMIntConstants; - @HotSpotVMData(index = 17) @Stable private long jvmciHotSpotVMIntConstantEntryNameOffset; - @HotSpotVMData(index = 18) @Stable private long jvmciHotSpotVMIntConstantEntryValueOffset; - @HotSpotVMData(index = 19) @Stable private long jvmciHotSpotVMIntConstantEntryArrayStride; - - final class VMIntConstants implements Iterable { - - private final long address; - - VMIntConstants(long address) { - this.address = address; - } - - public Iterator iterator() { - return new Iterator() { - - private int index = 0; - - private Constant current() { - return new Constant(address + jvmciHotSpotVMIntConstantEntryArrayStride * index); - } - - /** - * The last entry is identified by a NULL name. - */ - public boolean hasNext() { - Constant entry = current(); - return entry.getName() != null; - } - - public Constant next() { - Constant entry = current(); - index++; - return entry; - } - }; - } - - final class Constant extends AbstractConstant { - - Constant(long address) { - super(address, jvmciHotSpotVMIntConstantEntryNameOffset, jvmciHotSpotVMIntConstantEntryValueOffset); - } - - @Override - public long getValue() { - return UNSAFE.getInt(address + valueOffset); - } - - @Override - public String toString() { - return String.format("IntConstant[name=%s, value=%d (0x%x)]", getName(), getValue(), getValue()); - } - } - } - - /** - * VMLongConstantEntry (see vmStructs.hpp). - */ - @HotSpotVMData(index = 20) @Stable private long jvmciHotSpotVMLongConstants; - @HotSpotVMData(index = 21) @Stable private long jvmciHotSpotVMLongConstantEntryNameOffset; - @HotSpotVMData(index = 22) @Stable private long jvmciHotSpotVMLongConstantEntryValueOffset; - @HotSpotVMData(index = 23) @Stable private long jvmciHotSpotVMLongConstantEntryArrayStride; - - final class VMLongConstants implements Iterable { - - private final long address; - - VMLongConstants(long address) { - this.address = address; - } - - public Iterator iterator() { - return new Iterator() { - - private int index = 0; - - private Constant currentEntry() { - return new Constant(address + jvmciHotSpotVMLongConstantEntryArrayStride * index); - } - - /** - * The last entry is identified by a NULL name. - */ - public boolean hasNext() { - Constant entry = currentEntry(); - return entry.getName() != null; - } - - public Constant next() { - Constant entry = currentEntry(); - index++; - return entry; - } - }; - } - - final class Constant extends AbstractConstant { - - Constant(long address) { - super(address, jvmciHotSpotVMLongConstantEntryNameOffset, jvmciHotSpotVMLongConstantEntryValueOffset); - } - - @Override - public long getValue() { - return UNSAFE.getLong(address + valueOffset); - } - - @Override - public String toString() { - return String.format("LongConstant[name=%s, value=%d (0x%x)]", getName(), getValue(), getValue()); - } - } - } - - /** - * VMAddressEntry (see vmStructs.hpp). - */ - @HotSpotVMData(index = 24) @Stable private long jvmciHotSpotVMAddresses; - @HotSpotVMData(index = 25) @Stable private long jvmciHotSpotVMAddressEntryNameOffset; - @HotSpotVMData(index = 26) @Stable private long jvmciHotSpotVMAddressEntryValueOffset; - @HotSpotVMData(index = 27) @Stable private long jvmciHotSpotVMAddressEntryArrayStride; - - final class VMAddresses implements Iterable { - - private final long address; - - VMAddresses(long address) { - this.address = address; - } - - public Iterator iterator() { - return new Iterator() { - - private int index = 0; - - private Address currentEntry() { - return new Address(address + jvmciHotSpotVMAddressEntryArrayStride * index); - } - - /** - * The last entry is identified by a NULL name. - */ - public boolean hasNext() { - Address entry = currentEntry(); - return entry.getName() != null; - } - - public Address next() { - Address entry = currentEntry(); - index++; - return entry; - } - }; - } - - final class Address extends AbstractConstant { - - Address(long address) { - super(address, jvmciHotSpotVMAddressEntryNameOffset, jvmciHotSpotVMAddressEntryValueOffset); - } - - @Override - public long getValue() { - return UNSAFE.getLong(address + valueOffset); - } - - @Override - public String toString() { - return String.format("Address[name=%s, value=%d (0x%x)]", getName(), getValue(), getValue()); - } - } - } - - final class Flags implements Iterable { - - private final long address; - private final long entrySize; - private final long typeOffset; - private final long nameOffset; - private final long addrOffset; - - Flags(HashMap vmStructs, HashMap vmTypes) { - address = vmStructs.get("Flag::flags").getValue(); - entrySize = vmTypes.get("Flag").getSize(); - typeOffset = vmStructs.get("Flag::_type").getOffset(); - nameOffset = vmStructs.get("Flag::_name").getOffset(); - addrOffset = vmStructs.get("Flag::_addr").getOffset(); - - assert vmTypes.get("bool").getSize() == Byte.BYTES; - assert vmTypes.get("intx").getSize() == Long.BYTES; - assert vmTypes.get("uintx").getSize() == Long.BYTES; - } - - public Iterator iterator() { - return new Iterator() { - - private int index = 0; - - private Flag current() { - return new Flag(address + entrySize * index); - } - - /** - * The last entry is identified by a NULL name. - */ - public boolean hasNext() { - Flag entry = current(); - return entry.getName() != null; - } - - public Flag next() { - Flag entry = current(); - index++; - return entry; - } - }; - } - - final class Flag { - - private final long entryAddress; - - Flag(long address) { - this.entryAddress = address; - } - - public String getType() { - long typeAddress = UNSAFE.getAddress(entryAddress + typeOffset); - return readCString(UNSAFE, typeAddress); - } - - public String getName() { - long nameAddress = UNSAFE.getAddress(entryAddress + nameOffset); - return readCString(UNSAFE, nameAddress); - } - - public long getAddr() { - return UNSAFE.getAddress(entryAddress + addrOffset); - } - - public Object getValue() { - switch (getType()) { - case "bool": - return Boolean.valueOf(UNSAFE.getByte(getAddr()) != 0); - case "intx": - case "uintx": - case "uint64_t": - return Long.valueOf(UNSAFE.getLong(getAddr())); - case "double": - return Double.valueOf(UNSAFE.getDouble(getAddr())); - case "ccstr": - case "ccstrlist": - return readCString(UNSAFE, getAddr()); - default: - throw new JVMCIError(getType()); - } - } - - @Override - public String toString() { - return String.format("Flag[type=%s, name=%s, value=%s]", getType(), getName(), getValue()); - } - } - } - - @HotSpotVMConstant(name = "ASSERT") @Stable public boolean cAssertions; - public final boolean windowsOs = System.getProperty("os.name", "").startsWith("Windows"); - public final boolean linuxOs = System.getProperty("os.name", "").startsWith("Linux"); - - @HotSpotVMFlag(name = "CodeEntryAlignment") @Stable public int codeEntryAlignment; - @HotSpotVMFlag(name = "VerifyOops") @Stable public boolean verifyOops; - @HotSpotVMFlag(name = "CITime") @Stable public boolean ciTime; - @HotSpotVMFlag(name = "CITimeEach") @Stable public boolean ciTimeEach; - @HotSpotVMFlag(name = "CompileTheWorldStartAt", optional = true) @Stable public int compileTheWorldStartAt; - @HotSpotVMFlag(name = "CompileTheWorldStopAt", optional = true) @Stable public int compileTheWorldStopAt; - @HotSpotVMFlag(name = "DontCompileHugeMethods") @Stable public boolean dontCompileHugeMethods; - @HotSpotVMFlag(name = "HugeMethodLimit") @Stable public int hugeMethodLimit; - @HotSpotVMFlag(name = "PrintInlining") @Stable public boolean printInlining; - @HotSpotVMFlag(name = "Inline") @Stable public boolean inline; - @HotSpotVMFlag(name = "JVMCIUseFastLocking") @Stable public boolean useFastLocking; - @HotSpotVMFlag(name = "ForceUnreachable") @Stable public boolean forceUnreachable; - @HotSpotVMFlag(name = "CodeCacheSegmentSize") @Stable public int codeSegmentSize; - @HotSpotVMFlag(name = "FoldStableValues") @Stable public boolean foldStableValues; - - @HotSpotVMFlag(name = "UseTLAB") @Stable public boolean useTLAB; - @HotSpotVMFlag(name = "UseBiasedLocking") @Stable public boolean useBiasedLocking; - @HotSpotVMFlag(name = "UsePopCountInstruction") @Stable public boolean usePopCountInstruction; - @HotSpotVMFlag(name = "UseCountLeadingZerosInstruction", archs = {"amd64"}) @Stable public boolean useCountLeadingZerosInstruction; - @HotSpotVMFlag(name = "UseCountTrailingZerosInstruction", archs = {"amd64"}) @Stable public boolean useCountTrailingZerosInstruction; - @HotSpotVMFlag(name = "UseAESIntrinsics") @Stable public boolean useAESIntrinsics; - @HotSpotVMFlag(name = "UseCRC32Intrinsics") @Stable public boolean useCRC32Intrinsics; - @HotSpotVMFlag(name = "UseG1GC") @Stable public boolean useG1GC; - @HotSpotVMFlag(name = "UseConcMarkSweepGC") @Stable public boolean useCMSGC; - - @HotSpotVMFlag(name = "AllocatePrefetchStyle") @Stable public int allocatePrefetchStyle; - @HotSpotVMFlag(name = "AllocatePrefetchInstr") @Stable public int allocatePrefetchInstr; - @HotSpotVMFlag(name = "AllocatePrefetchLines") @Stable public int allocatePrefetchLines; - @HotSpotVMFlag(name = "AllocateInstancePrefetchLines") @Stable public int allocateInstancePrefetchLines; - @HotSpotVMFlag(name = "AllocatePrefetchStepSize") @Stable public int allocatePrefetchStepSize; - @HotSpotVMFlag(name = "AllocatePrefetchDistance") @Stable public int allocatePrefetchDistance; - - @HotSpotVMFlag(name = "FlightRecorder", optional = true) @Stable public boolean flightRecorder; - - @HotSpotVMField(name = "CompilerToVM::Data::Universe_collectedHeap", type = "CollectedHeap*", get = HotSpotVMField.Type.VALUE) @Stable private long universeCollectedHeap; - @HotSpotVMField(name = "CollectedHeap::_total_collections", type = "unsigned int", get = HotSpotVMField.Type.OFFSET) @Stable private int collectedHeapTotalCollectionsOffset; - - public long gcTotalCollectionsAddress() { - return universeCollectedHeap + collectedHeapTotalCollectionsOffset; - } - - @HotSpotVMFlag(name = "ReduceInitialCardMarks") @Stable public boolean useDeferredInitBarriers; - - // Compressed Oops related values. - @HotSpotVMFlag(name = "UseCompressedOops") @Stable public boolean useCompressedOops; - @HotSpotVMFlag(name = "UseCompressedClassPointers") @Stable public boolean useCompressedClassPointers; - - @HotSpotVMField(name = "CompilerToVM::Data::Universe_narrow_oop_base", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long narrowOopBase; - @HotSpotVMField(name = "CompilerToVM::Data::Universe_narrow_oop_shift", type = "int", get = HotSpotVMField.Type.VALUE) @Stable public int narrowOopShift; - @HotSpotVMFlag(name = "ObjectAlignmentInBytes") @Stable public int objectAlignment; - - public final int minObjAlignment() { - return objectAlignment / heapWordSize; - } - - public final int logMinObjAlignment() { - return (int) (Math.log(objectAlignment) / Math.log(2)); - } - - @HotSpotVMType(name = "narrowKlass", get = HotSpotVMType.Type.SIZE) @Stable public int narrowKlassSize; - @HotSpotVMField(name = "CompilerToVM::Data::Universe_narrow_klass_base", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long narrowKlassBase; - @HotSpotVMField(name = "CompilerToVM::Data::Universe_narrow_klass_shift", type = "int", get = HotSpotVMField.Type.VALUE) @Stable public int narrowKlassShift; - @HotSpotVMConstant(name = "LogKlassAlignmentInBytes") @Stable public int logKlassAlignment; - - // CPU capabilities - @HotSpotVMFlag(name = "UseSSE") @Stable public int useSSE; - @HotSpotVMFlag(name = "UseAVX", archs = {"amd64"}) @Stable public int useAVX; - - @HotSpotVMField(name = "Abstract_VM_Version::_features", type = "uint64_t", get = HotSpotVMField.Type.VALUE) @Stable public long vmVersionFeatures; - - // AMD64 specific values - @HotSpotVMConstant(name = "VM_Version::CPU_CX8", archs = {"amd64"}) @Stable public long amd64CX8; - @HotSpotVMConstant(name = "VM_Version::CPU_CMOV", archs = {"amd64"}) @Stable public long amd64CMOV; - @HotSpotVMConstant(name = "VM_Version::CPU_FXSR", archs = {"amd64"}) @Stable public long amd64FXSR; - @HotSpotVMConstant(name = "VM_Version::CPU_HT", archs = {"amd64"}) @Stable public long amd64HT; - @HotSpotVMConstant(name = "VM_Version::CPU_MMX", archs = {"amd64"}) @Stable public long amd64MMX; - @HotSpotVMConstant(name = "VM_Version::CPU_3DNOW_PREFETCH", archs = {"amd64"}) @Stable public long amd643DNOWPREFETCH; - @HotSpotVMConstant(name = "VM_Version::CPU_SSE", archs = {"amd64"}) @Stable public long amd64SSE; - @HotSpotVMConstant(name = "VM_Version::CPU_SSE2", archs = {"amd64"}) @Stable public long amd64SSE2; - @HotSpotVMConstant(name = "VM_Version::CPU_SSE3", archs = {"amd64"}) @Stable public long amd64SSE3; - @HotSpotVMConstant(name = "VM_Version::CPU_SSSE3", archs = {"amd64"}) @Stable public long amd64SSSE3; - @HotSpotVMConstant(name = "VM_Version::CPU_SSE4A", archs = {"amd64"}) @Stable public long amd64SSE4A; - @HotSpotVMConstant(name = "VM_Version::CPU_SSE4_1", archs = {"amd64"}) @Stable public long amd64SSE41; - @HotSpotVMConstant(name = "VM_Version::CPU_SSE4_2", archs = {"amd64"}) @Stable public long amd64SSE42; - @HotSpotVMConstant(name = "VM_Version::CPU_POPCNT", archs = {"amd64"}) @Stable public long amd64POPCNT; - @HotSpotVMConstant(name = "VM_Version::CPU_LZCNT", archs = {"amd64"}) @Stable public long amd64LZCNT; - @HotSpotVMConstant(name = "VM_Version::CPU_TSC", archs = {"amd64"}) @Stable public long amd64TSC; - @HotSpotVMConstant(name = "VM_Version::CPU_TSCINV", archs = {"amd64"}) @Stable public long amd64TSCINV; - @HotSpotVMConstant(name = "VM_Version::CPU_AVX", archs = {"amd64"}) @Stable public long amd64AVX; - @HotSpotVMConstant(name = "VM_Version::CPU_AVX2", archs = {"amd64"}) @Stable public long amd64AVX2; - @HotSpotVMConstant(name = "VM_Version::CPU_AES", archs = {"amd64"}) @Stable public long amd64AES; - @HotSpotVMConstant(name = "VM_Version::CPU_ERMS", archs = {"amd64"}) @Stable public long amd64ERMS; - @HotSpotVMConstant(name = "VM_Version::CPU_CLMUL", archs = {"amd64"}) @Stable public long amd64CLMUL; - @HotSpotVMConstant(name = "VM_Version::CPU_BMI1", archs = {"amd64"}) @Stable public long amd64BMI1; - @HotSpotVMConstant(name = "VM_Version::CPU_BMI2", archs = {"amd64"}) @Stable public long amd64BMI2; - @HotSpotVMConstant(name = "VM_Version::CPU_RTM", archs = {"amd64"}) @Stable public long amd64RTM; - @HotSpotVMConstant(name = "VM_Version::CPU_ADX", archs = {"amd64"}) @Stable public long amd64ADX; - @HotSpotVMConstant(name = "VM_Version::CPU_AVX512F", archs = {"amd64"}) @Stable public long amd64AVX512F; - @HotSpotVMConstant(name = "VM_Version::CPU_AVX512DQ", archs = {"amd64"}) @Stable public long amd64AVX512DQ; - @HotSpotVMConstant(name = "VM_Version::CPU_AVX512PF", archs = {"amd64"}) @Stable public long amd64AVX512PF; - @HotSpotVMConstant(name = "VM_Version::CPU_AVX512ER", archs = {"amd64"}) @Stable public long amd64AVX512ER; - @HotSpotVMConstant(name = "VM_Version::CPU_AVX512CD", archs = {"amd64"}) @Stable public long amd64AVX512CD; - @HotSpotVMConstant(name = "VM_Version::CPU_AVX512BW", archs = {"amd64"}) @Stable public long amd64AVX512BW; - @HotSpotVMConstant(name = "VM_Version::CPU_AVX512VL", archs = {"amd64"}) @Stable public long amd64AVX512VL; - @HotSpotVMConstant(name = "VM_Version::CPU_SHA", archs = {"amd64"}) @Stable public long amd64SHA; - - // SPARC specific values - @HotSpotVMConstant(name = "VM_Version::vis3_instructions_m", archs = {"sparc"}) @Stable public int sparcVis3Instructions; - @HotSpotVMConstant(name = "VM_Version::vis2_instructions_m", archs = {"sparc"}) @Stable public int sparcVis2Instructions; - @HotSpotVMConstant(name = "VM_Version::vis1_instructions_m", archs = {"sparc"}) @Stable public int sparcVis1Instructions; - @HotSpotVMConstant(name = "VM_Version::cbcond_instructions_m", archs = {"sparc"}) @Stable public int sparcCbcondInstructions; - @HotSpotVMConstant(name = "VM_Version::v8_instructions_m", archs = {"sparc"}) @Stable public int sparcV8Instructions; - @HotSpotVMConstant(name = "VM_Version::hardware_mul32_m", archs = {"sparc"}) @Stable public int sparcHardwareMul32; - @HotSpotVMConstant(name = "VM_Version::hardware_div32_m", archs = {"sparc"}) @Stable public int sparcHardwareDiv32; - @HotSpotVMConstant(name = "VM_Version::hardware_fsmuld_m", archs = {"sparc"}) @Stable public int sparcHardwareFsmuld; - @HotSpotVMConstant(name = "VM_Version::hardware_popc_m", archs = {"sparc"}) @Stable public int sparcHardwarePopc; - @HotSpotVMConstant(name = "VM_Version::v9_instructions_m", archs = {"sparc"}) @Stable public int sparcV9Instructions; - @HotSpotVMConstant(name = "VM_Version::sun4v_m", archs = {"sparc"}) @Stable public int sparcSun4v; - @HotSpotVMConstant(name = "VM_Version::blk_init_instructions_m", archs = {"sparc"}) @Stable public int sparcBlkInitInstructions; - @HotSpotVMConstant(name = "VM_Version::fmaf_instructions_m", archs = {"sparc"}) @Stable public int sparcFmafInstructions; - @HotSpotVMConstant(name = "VM_Version::fmau_instructions_m", archs = {"sparc"}) @Stable public int sparcFmauInstructions; - @HotSpotVMConstant(name = "VM_Version::sparc64_family_m", archs = {"sparc"}) @Stable public int sparcSparc64Family; - @HotSpotVMConstant(name = "VM_Version::M_family_m", archs = {"sparc"}) @Stable public int sparcMFamily; - @HotSpotVMConstant(name = "VM_Version::T_family_m", archs = {"sparc"}) @Stable public int sparcTFamily; - @HotSpotVMConstant(name = "VM_Version::T1_model_m", archs = {"sparc"}) @Stable public int sparcT1Model; - @HotSpotVMConstant(name = "VM_Version::sparc5_instructions_m", archs = {"sparc"}) @Stable public int sparcSparc5Instructions; - @HotSpotVMConstant(name = "VM_Version::aes_instructions_m", archs = {"sparc"}) @Stable public int sparcAesInstructions; - @HotSpotVMConstant(name = "VM_Version::sha1_instruction_m", archs = {"sparc"}) @Stable public int sparcSha1Instruction; - @HotSpotVMConstant(name = "VM_Version::sha256_instruction_m", archs = {"sparc"}) @Stable public int sparcSha256Instruction; - @HotSpotVMConstant(name = "VM_Version::sha512_instruction_m", archs = {"sparc"}) @Stable public int sparcSha512Instruction; - - @HotSpotVMFlag(name = "UseBlockZeroing", archs = {"sparc"}) @Stable public boolean useBlockZeroing; - @HotSpotVMFlag(name = "BlockZeroingLowLimit", archs = {"sparc"}) @Stable public int blockZeroingLowLimit; - - @HotSpotVMFlag(name = "StackShadowPages") @Stable public int stackShadowPages; - @HotSpotVMFlag(name = "StackReservedPages") @Stable public int stackReservedPages; - @HotSpotVMFlag(name = "UseStackBanging") @Stable public boolean useStackBanging; - @HotSpotVMConstant(name = "STACK_BIAS") @Stable public int stackBias; - @HotSpotVMField(name = "CompilerToVM::Data::vm_page_size", type = "int", get = HotSpotVMField.Type.VALUE) @Stable public int vmPageSize; - - // offsets, ... - @HotSpotVMField(name = "oopDesc::_mark", type = "markOop", get = HotSpotVMField.Type.OFFSET) @Stable public int markOffset; - @HotSpotVMField(name = "oopDesc::_metadata._klass", type = "Klass*", get = HotSpotVMField.Type.OFFSET) @Stable public int hubOffset; - - @HotSpotVMField(name = "Klass::_prototype_header", type = "markOop", get = HotSpotVMField.Type.OFFSET) @Stable public int prototypeMarkWordOffset; - @HotSpotVMField(name = "Klass::_subklass", type = "Klass*", get = HotSpotVMField.Type.OFFSET) @Stable public int subklassOffset; - @HotSpotVMField(name = "Klass::_next_sibling", type = "Klass*", get = HotSpotVMField.Type.OFFSET) @Stable public int nextSiblingOffset; - @HotSpotVMField(name = "Klass::_super_check_offset", type = "juint", get = HotSpotVMField.Type.OFFSET) @Stable public int superCheckOffsetOffset; - @HotSpotVMField(name = "Klass::_secondary_super_cache", type = "Klass*", get = HotSpotVMField.Type.OFFSET) @Stable public int secondarySuperCacheOffset; - @HotSpotVMField(name = "Klass::_secondary_supers", type = "Array*", get = HotSpotVMField.Type.OFFSET) @Stable public int secondarySupersOffset; + final int prototypeMarkWordOffset = getFieldOffset("Klass::_prototype_header", Integer.class, "markOop"); + final int subklassOffset = getFieldOffset("Klass::_subklass", Integer.class, "Klass*"); + final int nextSiblingOffset = getFieldOffset("Klass::_next_sibling", Integer.class, "Klass*"); + final int superCheckOffsetOffset = getFieldOffset("Klass::_super_check_offset", Integer.class, "juint"); + final int secondarySuperCacheOffset = getFieldOffset("Klass::_secondary_super_cache", Integer.class, "Klass*"); /** * The offset of the _java_mirror field (of type {@link Class}) in a Klass. */ - @HotSpotVMField(name = "Klass::_java_mirror", type = "oop", get = HotSpotVMField.Type.OFFSET) @Stable public int classMirrorOffset; + final int classMirrorOffset = getFieldOffset("Klass::_java_mirror", Integer.class, "oop"); - @HotSpotVMField(name = "Klass::_super", type = "Klass*", get = HotSpotVMField.Type.OFFSET) @Stable public int klassSuperKlassOffset; - @HotSpotVMField(name = "Klass::_modifier_flags", type = "jint", get = HotSpotVMField.Type.OFFSET) @Stable public int klassModifierFlagsOffset; - @HotSpotVMField(name = "Klass::_access_flags", type = "AccessFlags", get = HotSpotVMField.Type.OFFSET) @Stable public int klassAccessFlagsOffset; - @HotSpotVMField(name = "Klass::_layout_helper", type = "jint", get = HotSpotVMField.Type.OFFSET) @Stable public int klassLayoutHelperOffset; - @HotSpotVMField(name = "Klass::_name", type = "Symbol*", get = HotSpotVMField.Type.OFFSET) @Stable public int klassNameOffset; + final int klassAccessFlagsOffset = getFieldOffset("Klass::_access_flags", Integer.class, "AccessFlags"); + final int klassLayoutHelperOffset = getFieldOffset("Klass::_layout_helper", Integer.class, "jint"); - @HotSpotVMConstant(name = "Klass::_lh_neutral_value") @Stable public int klassLayoutHelperNeutralValue; - @HotSpotVMConstant(name = "Klass::_lh_instance_slow_path_bit") @Stable public int klassLayoutHelperInstanceSlowPathBit; - @HotSpotVMConstant(name = "Klass::_lh_log2_element_size_shift") @Stable public int layoutHelperLog2ElementSizeShift; - @HotSpotVMConstant(name = "Klass::_lh_log2_element_size_mask") @Stable public int layoutHelperLog2ElementSizeMask; - @HotSpotVMConstant(name = "Klass::_lh_element_type_shift") @Stable public int layoutHelperElementTypeShift; - @HotSpotVMConstant(name = "Klass::_lh_element_type_mask") @Stable public int layoutHelperElementTypeMask; - @HotSpotVMConstant(name = "Klass::_lh_header_size_shift") @Stable public int layoutHelperHeaderSizeShift; - @HotSpotVMConstant(name = "Klass::_lh_header_size_mask") @Stable public int layoutHelperHeaderSizeMask; - @HotSpotVMConstant(name = "Klass::_lh_array_tag_shift") @Stable public int layoutHelperArrayTagShift; - @HotSpotVMConstant(name = "Klass::_lh_array_tag_type_value") @Stable public int layoutHelperArrayTagTypeValue; - @HotSpotVMConstant(name = "Klass::_lh_array_tag_obj_value") @Stable public int layoutHelperArrayTagObjectValue; + final int klassLayoutHelperNeutralValue = getConstant("Klass::_lh_neutral_value", Integer.class); + final int klassLayoutHelperInstanceSlowPathBit = getConstant("Klass::_lh_instance_slow_path_bit", Integer.class); - /** - * This filters out the bit that differentiates a type array from an object array. - */ - public int layoutHelperElementTypePrimitiveInPlace() { - return (layoutHelperArrayTagTypeValue & ~layoutHelperArrayTagObjectValue) << layoutHelperArrayTagShift; - } + final int vtableEntrySize = getTypeSize("vtableEntry"); + final int vtableEntryMethodOffset = getFieldOffset("vtableEntry::_method", Integer.class, "Method*"); - /** - * Bit pattern in the klass layout helper that can be used to identify arrays. - */ - public final int arrayKlassLayoutHelperIdentifier = 0x80000000; + final int instanceKlassSourceFileNameIndexOffset = getFieldOffset("InstanceKlass::_source_file_name_index", Integer.class, "u2"); + final int instanceKlassInitStateOffset = getFieldOffset("InstanceKlass::_init_state", Integer.class, "u1"); + final int instanceKlassConstantsOffset = getFieldOffset("InstanceKlass::_constants", Integer.class, "ConstantPool*"); + final int instanceKlassFieldsOffset = getFieldOffset("InstanceKlass::_fields", Integer.class, "Array*"); + final int klassVtableStartOffset = getFieldValue("CompilerToVM::Data::Klass_vtable_start_offset", Integer.class, "int"); + final int klassVtableLengthOffset = getFieldValue("CompilerToVM::Data::Klass_vtable_length_offset", Integer.class, "int"); - @HotSpotVMType(name = "vtableEntry", get = HotSpotVMType.Type.SIZE) @Stable public int vtableEntrySize; - @HotSpotVMField(name = "vtableEntry::_method", type = "Method*", get = HotSpotVMField.Type.OFFSET) @Stable public int vtableEntryMethodOffset; + final int instanceKlassStateLinked = getConstant("InstanceKlass::linked", Integer.class); + final int instanceKlassStateFullyInitialized = getConstant("InstanceKlass::fully_initialized", Integer.class); - @HotSpotVMType(name = "InstanceKlass", get = HotSpotVMType.Type.SIZE) @Stable public int instanceKlassSize; - @HotSpotVMField(name = "InstanceKlass::_source_file_name_index", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int instanceKlassSourceFileNameIndexOffset; - @HotSpotVMField(name = "InstanceKlass::_init_state", type = "u1", get = HotSpotVMField.Type.OFFSET) @Stable public int instanceKlassInitStateOffset; - @HotSpotVMField(name = "InstanceKlass::_constants", type = "ConstantPool*", get = HotSpotVMField.Type.OFFSET) @Stable public int instanceKlassConstantsOffset; - @HotSpotVMField(name = "InstanceKlass::_fields", type = "Array*", get = HotSpotVMField.Type.OFFSET) @Stable public int instanceKlassFieldsOffset; - @HotSpotVMField(name = "CompilerToVM::Data::Klass_vtable_start_offset", type = "int", get = HotSpotVMField.Type.VALUE) @Stable public int klassVtableStartOffset; - @HotSpotVMField(name = "CompilerToVM::Data::Klass_vtable_length_offset", type = "int", get = HotSpotVMField.Type.VALUE) @Stable public int klassVtableLengthOffset; + final int arrayU1LengthOffset = getFieldOffset("Array::_length", Integer.class, "int"); + final int arrayU1DataOffset = getFieldOffset("Array::_data", Integer.class); + final int arrayU2DataOffset = getFieldOffset("Array::_data", Integer.class); - @HotSpotVMConstant(name = "InstanceKlass::linked") @Stable public int instanceKlassStateLinked; - @HotSpotVMConstant(name = "InstanceKlass::fully_initialized") @Stable public int instanceKlassStateFullyInitialized; + final int fieldInfoAccessFlagsOffset = getConstant("FieldInfo::access_flags_offset", Integer.class); + final int fieldInfoNameIndexOffset = getConstant("FieldInfo::name_index_offset", Integer.class); + final int fieldInfoSignatureIndexOffset = getConstant("FieldInfo::signature_index_offset", Integer.class); + final int fieldInfoLowPackedOffset = getConstant("FieldInfo::low_packed_offset", Integer.class); + final int fieldInfoHighPackedOffset = getConstant("FieldInfo::high_packed_offset", Integer.class); + final int fieldInfoFieldSlots = getConstant("FieldInfo::field_slots", Integer.class); - @HotSpotVMType(name = "arrayOopDesc", get = HotSpotVMType.Type.SIZE) @Stable public int arrayOopDescSize; + final int fieldInfoTagSize = getConstant("FIELDINFO_TAG_SIZE", Integer.class); - /** - * The offset of the array length word in an array object's header. - * - * See {@code arrayOopDesc::length_offset_in_bytes()}. - */ - public final int arrayOopDescLengthOffset() { - return useCompressedClassPointers ? hubOffset + narrowKlassSize : arrayOopDescSize; - } - - @HotSpotVMField(name = "Array::_length", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int arrayU1LengthOffset; - @HotSpotVMField(name = "Array::_data", type = "", get = HotSpotVMField.Type.OFFSET) @Stable public int arrayU1DataOffset; - @HotSpotVMField(name = "Array::_data", type = "", get = HotSpotVMField.Type.OFFSET) @Stable public int arrayU2DataOffset; - @HotSpotVMField(name = "Array::_length", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int metaspaceArrayLengthOffset; - @HotSpotVMField(name = "Array::_data[0]", type = "Klass*", get = HotSpotVMField.Type.OFFSET) @Stable public int metaspaceArrayBaseOffset; - - @HotSpotVMField(name = "ObjArrayKlass::_element_klass", type = "Klass*", get = HotSpotVMField.Type.OFFSET) @Stable public int arrayClassElementOffset; - - @HotSpotVMConstant(name = "FieldInfo::access_flags_offset") @Stable public int fieldInfoAccessFlagsOffset; - @HotSpotVMConstant(name = "FieldInfo::name_index_offset") @Stable public int fieldInfoNameIndexOffset; - @HotSpotVMConstant(name = "FieldInfo::signature_index_offset") @Stable public int fieldInfoSignatureIndexOffset; - @HotSpotVMConstant(name = "FieldInfo::initval_index_offset") @Stable public int fieldInfoInitvalIndexOffset; - @HotSpotVMConstant(name = "FieldInfo::low_packed_offset") @Stable public int fieldInfoLowPackedOffset; - @HotSpotVMConstant(name = "FieldInfo::high_packed_offset") @Stable public int fieldInfoHighPackedOffset; - @HotSpotVMConstant(name = "FieldInfo::field_slots") @Stable public int fieldInfoFieldSlots; - - @HotSpotVMConstant(name = "FIELDINFO_TAG_SIZE") @Stable public int fieldInfoTagSize; - - @HotSpotVMConstant(name = "JVM_ACC_MONITOR_MATCH") @Stable public int jvmAccMonitorMatch; - @HotSpotVMConstant(name = "JVM_ACC_HAS_MONITOR_BYTECODES") @Stable public int jvmAccHasMonitorBytecodes; - @HotSpotVMConstant(name = "JVM_ACC_HAS_FINALIZER") @Stable public int jvmAccHasFinalizer; - @HotSpotVMConstant(name = "JVM_ACC_FIELD_INTERNAL") @Stable public int jvmAccFieldInternal; - @HotSpotVMConstant(name = "JVM_ACC_FIELD_STABLE") @Stable public int jvmAccFieldStable; - @HotSpotVMConstant(name = "JVM_ACC_FIELD_HAS_GENERIC_SIGNATURE") @Stable public int jvmAccFieldHasGenericSignature; - @HotSpotVMConstant(name = "JVM_ACC_WRITTEN_FLAGS") @Stable public int jvmAccWrittenFlags; - @HotSpotVMConstant(name = "JVM_ACC_IS_CLONEABLE_FAST") @Stable public int jvmAccIsCloneableFast; + final int jvmAccHasFinalizer = getConstant("JVM_ACC_HAS_FINALIZER", Integer.class); + final int jvmAccFieldInternal = getConstant("JVM_ACC_FIELD_INTERNAL", Integer.class); + final int jvmAccFieldStable = getConstant("JVM_ACC_FIELD_STABLE", Integer.class); + final int jvmAccFieldHasGenericSignature = getConstant("JVM_ACC_FIELD_HAS_GENERIC_SIGNATURE", Integer.class); + final int jvmAccIsCloneableFast = getConstant("JVM_ACC_IS_CLONEABLE_FAST", Integer.class); // Modifier.SYNTHETIC is not public so we get it via vmStructs. - @HotSpotVMConstant(name = "JVM_ACC_SYNTHETIC") @Stable public int jvmAccSynthetic; + final int jvmAccSynthetic = getConstant("JVM_ACC_SYNTHETIC", Integer.class); - /** - * @see HotSpotResolvedObjectTypeImpl#createField - */ - @HotSpotVMConstant(name = "JVM_RECOGNIZED_FIELD_MODIFIERS") @Stable public int recognizedFieldModifiers; + // This is only valid on AMD64. + final int runtimeCallStackSize = getConstant("frame::arg_reg_save_area_bytes", Integer.class, osArch.equals("amd64") ? null : 0); - @HotSpotVMField(name = "Thread::_tlab", type = "ThreadLocalAllocBuffer", get = HotSpotVMField.Type.OFFSET) @Stable public int threadTlabOffset; - - @HotSpotVMField(name = "JavaThread::_anchor", type = "JavaFrameAnchor", get = HotSpotVMField.Type.OFFSET) @Stable public int javaThreadAnchorOffset; - @HotSpotVMField(name = "JavaThread::_threadObj", type = "oop", get = HotSpotVMField.Type.OFFSET) @Stable public int threadObjectOffset; - @HotSpotVMField(name = "JavaThread::_osthread", type = "OSThread*", get = HotSpotVMField.Type.OFFSET) @Stable public int osThreadOffset; - @HotSpotVMField(name = "JavaThread::_dirty_card_queue", type = "DirtyCardQueue", get = HotSpotVMField.Type.OFFSET) @Stable public int javaThreadDirtyCardQueueOffset; - @HotSpotVMField(name = "JavaThread::_is_method_handle_return", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int threadIsMethodHandleReturnOffset; - @HotSpotVMField(name = "JavaThread::_satb_mark_queue", type = "SATBMarkQueue", get = HotSpotVMField.Type.OFFSET) @Stable public int javaThreadSatbMarkQueueOffset; - @HotSpotVMField(name = "JavaThread::_vm_result", type = "oop", get = HotSpotVMField.Type.OFFSET) @Stable public int threadObjectResultOffset; - @HotSpotVMField(name = "JavaThread::_jvmci_counters", type = "jlong*", get = HotSpotVMField.Type.OFFSET) @Stable public int jvmciCountersThreadOffset; - @HotSpotVMField(name = "JavaThread::_reserved_stack_activation", type = "address", get = HotSpotVMField.Type.OFFSET) @Stable public int javaThreadReservedStackActivationOffset; - - /** - * An invalid value for {@link #rtldDefault}. - */ - public static final long INVALID_RTLD_DEFAULT_HANDLE = 0xDEADFACE; - - /** - * Address of the library lookup routine. The C signature of this routine is: - * - *
    -     *     void* (const char *filename, char *ebuf, int ebuflen)
    -     * 
    - */ - @HotSpotVMAddress(name = "os::dll_load") @Stable public long dllLoad; - - /** - * Address of the library lookup routine. The C signature of this routine is: - * - *
    -     *     void* (void* handle, const char* name)
    -     * 
    - */ - @HotSpotVMAddress(name = "os::dll_lookup") @Stable public long dllLookup; - - /** - * A pseudo-handle which when used as the first argument to {@link #dllLookup} means lookup will - * return the first occurrence of the desired symbol using the default library search order. If - * this field is {@value #INVALID_RTLD_DEFAULT_HANDLE}, then this capability is not supported on - * the current platform. - */ - @HotSpotVMAddress(name = "RTLD_DEFAULT", os = {"bsd", "linux"}) @Stable public long rtldDefault = INVALID_RTLD_DEFAULT_HANDLE; - - /** - * This field is used to pass exception objects into and out of the runtime system during - * exception handling for compiled code. - */ - @HotSpotVMField(name = "JavaThread::_exception_oop", type = "oop", get = HotSpotVMField.Type.OFFSET) @Stable public int threadExceptionOopOffset; - @HotSpotVMField(name = "JavaThread::_exception_pc", type = "address", get = HotSpotVMField.Type.OFFSET) @Stable public int threadExceptionPcOffset; - @HotSpotVMField(name = "ThreadShadow::_pending_exception", type = "oop", get = HotSpotVMField.Type.OFFSET) @Stable public int pendingExceptionOffset; - - @HotSpotVMField(name = "JavaThread::_pending_deoptimization", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int pendingDeoptimizationOffset; - @HotSpotVMField(name = "JavaThread::_pending_failed_speculation", type = "oop", get = HotSpotVMField.Type.OFFSET) @Stable public int pendingFailedSpeculationOffset; - @HotSpotVMField(name = "JavaThread::_pending_transfer_to_interpreter", type = "bool", get = HotSpotVMField.Type.OFFSET) @Stable public int pendingTransferToInterpreterOffset; - - @HotSpotVMField(name = "JavaFrameAnchor::_last_Java_sp", type = "intptr_t*", get = HotSpotVMField.Type.OFFSET) @Stable private int javaFrameAnchorLastJavaSpOffset; - @HotSpotVMField(name = "JavaFrameAnchor::_last_Java_pc", type = "address", get = HotSpotVMField.Type.OFFSET) @Stable private int javaFrameAnchorLastJavaPcOffset; - @HotSpotVMField(name = "JavaFrameAnchor::_last_Java_fp", type = "intptr_t*", get = HotSpotVMField.Type.OFFSET, archs = {"aarch64, amd64"}) @Stable private int javaFrameAnchorLastJavaFpOffset; - @HotSpotVMField(name = "JavaFrameAnchor::_flags", type = "int", get = HotSpotVMField.Type.OFFSET, archs = {"sparc"}) @Stable private int javaFrameAnchorFlagsOffset; - - public int threadLastJavaSpOffset() { - return javaThreadAnchorOffset + javaFrameAnchorLastJavaSpOffset; - } - - public int threadLastJavaPcOffset() { - return javaThreadAnchorOffset + javaFrameAnchorLastJavaPcOffset; - } - - public int threadLastJavaFpOffset() { - assert getHostArchitectureName().equals("aarch64") || getHostArchitectureName().equals("amd64"); - return javaThreadAnchorOffset + javaFrameAnchorLastJavaFpOffset; - } - - /** - * This value is only valid on SPARC. - */ - public int threadJavaFrameAnchorFlagsOffset() { - // TODO add an assert for SPARC - return javaThreadAnchorOffset + javaFrameAnchorFlagsOffset; - } - - // These are only valid on AMD64. - @HotSpotVMConstant(name = "frame::arg_reg_save_area_bytes", archs = {"amd64"}) @Stable public int runtimeCallStackSize; - @HotSpotVMConstant(name = "frame::interpreter_frame_sender_sp_offset", archs = {"amd64"}) @Stable public int frameInterpreterFrameSenderSpOffset; - @HotSpotVMConstant(name = "frame::interpreter_frame_last_sp_offset", archs = {"amd64"}) @Stable public int frameInterpreterFrameLastSpOffset; - - @HotSpotVMConstant(name = "dirtyCardQueueBufferOffset") @Stable private int dirtyCardQueueBufferOffset; - @HotSpotVMConstant(name = "dirtyCardQueueIndexOffset") @Stable private int dirtyCardQueueIndexOffset; - - @HotSpotVMConstant(name = "satbMarkQueueBufferOffset") @Stable private int satbMarkQueueBufferOffset; - @HotSpotVMConstant(name = "satbMarkQueueIndexOffset") @Stable private int satbMarkQueueIndexOffset; - @HotSpotVMConstant(name = "satbMarkQueueActiveOffset") @Stable private int satbMarkQueueActiveOffset; - - @HotSpotVMField(name = "OSThread::_interrupted", type = "jint", get = HotSpotVMField.Type.OFFSET) @Stable public int osThreadInterruptedOffset; - - @HotSpotVMConstant(name = "markOopDesc::hash_shift") @Stable public long markOopDescHashShift; - - @HotSpotVMConstant(name = "markOopDesc::biased_lock_mask_in_place") @Stable public int biasedLockMaskInPlace; - @HotSpotVMConstant(name = "markOopDesc::age_mask_in_place") @Stable public int ageMaskInPlace; - @HotSpotVMConstant(name = "markOopDesc::epoch_mask_in_place") @Stable public int epochMaskInPlace; - @HotSpotVMConstant(name = "markOopDesc::hash_mask") @Stable public long markOopDescHashMask; - @HotSpotVMConstant(name = "markOopDesc::hash_mask_in_place") @Stable public long markOopDescHashMaskInPlace; - - @HotSpotVMConstant(name = "markOopDesc::unlocked_value") @Stable public int unlockedMask; - @HotSpotVMConstant(name = "markOopDesc::biased_lock_pattern") @Stable public int biasedLockPattern; - - @HotSpotVMConstant(name = "markOopDesc::no_hash_in_place") @Stable public int markWordNoHashInPlace; - @HotSpotVMConstant(name = "markOopDesc::no_lock_in_place") @Stable public int markWordNoLockInPlace; + private final int markWordNoHashInPlace = getConstant("markOopDesc::no_hash_in_place", Integer.class); + private final int markWordNoLockInPlace = getConstant("markOopDesc::no_lock_in_place", Integer.class); /** * See {@code markOopDesc::prototype()}. */ - public long arrayPrototypeMarkWord() { + long arrayPrototypeMarkWord() { return markWordNoHashInPlace | markWordNoLockInPlace; } + final int methodAccessFlagsOffset = getFieldOffset("Method::_access_flags", Integer.class, "AccessFlags"); + final int methodConstMethodOffset = getFieldOffset("Method::_constMethod", Integer.class, "ConstMethod*"); + final int methodIntrinsicIdOffset = getFieldOffset("Method::_intrinsic_id", Integer.class, "u2"); + final int methodFlagsOffset = getFieldOffset("Method::_flags", Integer.class, "u2"); + final int methodVtableIndexOffset = getFieldOffset("Method::_vtable_index", Integer.class, "int"); + + final int methodDataOffset = getFieldOffset("Method::_method_data", Integer.class, "MethodData*"); + final int methodCodeOffset = getFieldOffset("Method::_code", Integer.class, "CompiledMethod*"); + + final int methodFlagsCallerSensitive = getConstant("Method::_caller_sensitive", Integer.class); + final int methodFlagsForceInline = getConstant("Method::_force_inline", Integer.class); + final int methodFlagsDontInline = getConstant("Method::_dont_inline", Integer.class); + final int methodFlagsReservedStackAccess = getConstant("Method::_reserved_stack_access", Integer.class); + final int nonvirtualVtableIndex = getConstant("Method::nonvirtual_vtable_index", Integer.class); + final int invalidVtableIndex = getConstant("Method::invalid_vtable_index", Integer.class); + + final int methodDataSize = getFieldOffset("MethodData::_size", Integer.class, "int"); + final int methodDataDataSize = getFieldOffset("MethodData::_data_size", Integer.class, "int"); + final int methodDataOopDataOffset = getFieldOffset("MethodData::_data[0]", Integer.class, "intptr_t"); + final int methodDataOopTrapHistoryOffset = getFieldOffset("MethodData::_trap_hist._array[0]", Integer.class, "u1"); + final int methodDataIRSizeOffset = getFieldOffset("MethodData::_jvmci_ir_size", Integer.class, "int"); + + final int nmethodCompLevelOffset = getFieldOffset("nmethod::_comp_level", Integer.class, "int"); + + final int compilationLevelNone = getConstant("CompLevel_none", Integer.class); + final int compilationLevelSimple = getConstant("CompLevel_simple", Integer.class); + final int compilationLevelLimitedProfile = getConstant("CompLevel_limited_profile", Integer.class); + final int compilationLevelFullProfile = getConstant("CompLevel_full_profile", Integer.class); + final int compilationLevelFullOptimization = getConstant("CompLevel_full_optimization", Integer.class); + + final int compLevelAdjustmentNone = getConstant("JVMCIRuntime::none", Integer.class); + final int compLevelAdjustmentByHolder = getConstant("JVMCIRuntime::by_holder", Integer.class); + final int compLevelAdjustmentByFullSignature = getConstant("JVMCIRuntime::by_full_signature", Integer.class); + + final int invocationEntryBci = getConstant("InvocationEntryBci", Integer.class); + + final int extraStackEntries = getFieldValue("CompilerToVM::Data::Method_extra_stack_entries", Integer.class, "int"); + + final int constMethodConstantsOffset = getFieldOffset("ConstMethod::_constants", Integer.class, "ConstantPool*"); + final int constMethodFlagsOffset = getFieldOffset("ConstMethod::_flags", Integer.class, "u2"); + final int constMethodCodeSizeOffset = getFieldOffset("ConstMethod::_code_size", Integer.class, "u2"); + final int constMethodNameIndexOffset = getFieldOffset("ConstMethod::_name_index", Integer.class, "u2"); + final int constMethodSignatureIndexOffset = getFieldOffset("ConstMethod::_signature_index", Integer.class, "u2"); + final int constMethodMaxStackOffset = getFieldOffset("ConstMethod::_max_stack", Integer.class, "u2"); + final int methodMaxLocalsOffset = getFieldOffset("ConstMethod::_max_locals", Integer.class, "u2"); + + final int constMethodHasLineNumberTable = getConstant("ConstMethod::_has_linenumber_table", Integer.class); + final int constMethodHasLocalVariableTable = getConstant("ConstMethod::_has_localvariable_table", Integer.class); + final int constMethodHasExceptionTable = getConstant("ConstMethod::_has_exception_table", Integer.class); + + final int exceptionTableElementSize = getTypeSize("ExceptionTableElement"); + final int exceptionTableElementStartPcOffset = getFieldOffset("ExceptionTableElement::start_pc", Integer.class, "u2"); + final int exceptionTableElementEndPcOffset = getFieldOffset("ExceptionTableElement::end_pc", Integer.class, "u2"); + final int exceptionTableElementHandlerPcOffset = getFieldOffset("ExceptionTableElement::handler_pc", Integer.class, "u2"); + final int exceptionTableElementCatchTypeIndexOffset = getFieldOffset("ExceptionTableElement::catch_type_index", Integer.class, "u2"); + + final int localVariableTableElementSize = getTypeSize("LocalVariableTableElement"); + final int localVariableTableElementStartBciOffset = getFieldOffset("LocalVariableTableElement::start_bci", Integer.class, "u2"); + final int localVariableTableElementLengthOffset = getFieldOffset("LocalVariableTableElement::length", Integer.class, "u2"); + final int localVariableTableElementNameCpIndexOffset = getFieldOffset("LocalVariableTableElement::name_cp_index", Integer.class, "u2"); + final int localVariableTableElementDescriptorCpIndexOffset = getFieldOffset("LocalVariableTableElement::descriptor_cp_index", Integer.class, "u2"); + final int localVariableTableElementSlotOffset = getFieldOffset("LocalVariableTableElement::slot", Integer.class, "u2"); + + final int constantPoolSize = getTypeSize("ConstantPool"); + final int constantPoolTagsOffset = getFieldOffset("ConstantPool::_tags", Integer.class, "Array*"); + final int constantPoolHolderOffset = getFieldOffset("ConstantPool::_pool_holder", Integer.class, "InstanceKlass*"); + final int constantPoolLengthOffset = getFieldOffset("ConstantPool::_length", Integer.class, "int"); + + final int constantPoolCpCacheIndexTag = getConstant("ConstantPool::CPCACHE_INDEX_TAG", Integer.class); + + final int jvmConstantUtf8 = getConstant("JVM_CONSTANT_Utf8", Integer.class); + final int jvmConstantInteger = getConstant("JVM_CONSTANT_Integer", Integer.class); + final int jvmConstantLong = getConstant("JVM_CONSTANT_Long", Integer.class); + final int jvmConstantFloat = getConstant("JVM_CONSTANT_Float", Integer.class); + final int jvmConstantDouble = getConstant("JVM_CONSTANT_Double", Integer.class); + final int jvmConstantClass = getConstant("JVM_CONSTANT_Class", Integer.class); + final int jvmConstantUnresolvedClass = getConstant("JVM_CONSTANT_UnresolvedClass", Integer.class); + final int jvmConstantUnresolvedClassInError = getConstant("JVM_CONSTANT_UnresolvedClassInError", Integer.class); + final int jvmConstantString = getConstant("JVM_CONSTANT_String", Integer.class); + final int jvmConstantFieldref = getConstant("JVM_CONSTANT_Fieldref", Integer.class); + final int jvmConstantMethodref = getConstant("JVM_CONSTANT_Methodref", Integer.class); + final int jvmConstantInterfaceMethodref = getConstant("JVM_CONSTANT_InterfaceMethodref", Integer.class); + final int jvmConstantNameAndType = getConstant("JVM_CONSTANT_NameAndType", Integer.class); + final int jvmConstantMethodHandle = getConstant("JVM_CONSTANT_MethodHandle", Integer.class); + final int jvmConstantMethodHandleInError = getConstant("JVM_CONSTANT_MethodHandleInError", Integer.class); + final int jvmConstantMethodType = getConstant("JVM_CONSTANT_MethodType", Integer.class); + final int jvmConstantMethodTypeInError = getConstant("JVM_CONSTANT_MethodTypeInError", Integer.class); + final int jvmConstantInvokeDynamic = getConstant("JVM_CONSTANT_InvokeDynamic", Integer.class); + + final int jvmConstantExternalMax = getConstant("JVM_CONSTANT_ExternalMax", Integer.class); + final int jvmConstantInternalMin = getConstant("JVM_CONSTANT_InternalMin", Integer.class); + final int jvmConstantInternalMax = getConstant("JVM_CONSTANT_InternalMax", Integer.class); + + final int heapWordSize = getConstant("HeapWordSize", Integer.class); + + final int symbolPointerSize = getTypeSize("Symbol*"); + + final long vmSymbolsSymbols = getFieldAddress("vmSymbols::_symbols[0]", "Symbol*"); + final int vmSymbolsFirstSID = getConstant("vmSymbols::FIRST_SID", Integer.class); + final int vmSymbolsSIDLimit = getConstant("vmSymbols::SID_LIMIT", Integer.class); + /** - * See {@code markOopDesc::copy_set_hash()}. + * Returns the symbol in the {@code vmSymbols} table at position {@code index} as a + * {@link String}. + * + * @param index position in the symbol table + * @return the symbol at position id */ - public long tlabIntArrayMarkWord() { - long tmp = arrayPrototypeMarkWord() & (~markOopDescHashMaskInPlace); - tmp |= ((0x2 & markOopDescHashMask) << markOopDescHashShift); - return tmp; + String symbolAt(int index) { + HotSpotJVMCIRuntimeProvider runtime = runtime(); + assert vmSymbolsFirstSID <= index && index < vmSymbolsSIDLimit : "index " + index + " is out of bounds"; + assert symbolPointerSize == Unsafe.ADDRESS_SIZE : "the following address read is broken"; + int offset = index * symbolPointerSize; + return runtime.getCompilerToVM().getSymbol(UNSAFE.getAddress(vmSymbolsSymbols + offset)); } - /** - * Mark word right shift to get identity hash code. - */ - @HotSpotVMConstant(name = "markOopDesc::hash_shift") @Stable public int identityHashCodeShift; + final int universeBaseVtableSize = getFieldValue("CompilerToVM::Data::Universe_base_vtable_size", Integer.class, "int"); - /** - * Identity hash code value when uninitialized. - */ - @HotSpotVMConstant(name = "markOopDesc::no_hash") @Stable public int uninitializedIdentityHashCodeValue; - - @HotSpotVMField(name = "Method::_access_flags", type = "AccessFlags", get = HotSpotVMField.Type.OFFSET) @Stable public int methodAccessFlagsOffset; - @HotSpotVMField(name = "Method::_constMethod", type = "ConstMethod*", get = HotSpotVMField.Type.OFFSET) @Stable public int methodConstMethodOffset; - @HotSpotVMField(name = "Method::_intrinsic_id", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int methodIntrinsicIdOffset; - @HotSpotVMField(name = "Method::_flags", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int methodFlagsOffset; - @HotSpotVMField(name = "Method::_vtable_index", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int methodVtableIndexOffset; - - @HotSpotVMField(name = "Method::_method_counters", type = "MethodCounters*", get = HotSpotVMField.Type.OFFSET) @Stable public int methodCountersOffset; - @HotSpotVMField(name = "Method::_method_data", type = "MethodData*", get = HotSpotVMField.Type.OFFSET) @Stable public int methodDataOffset; - @HotSpotVMField(name = "Method::_from_compiled_entry", type = "address", get = HotSpotVMField.Type.OFFSET) @Stable public int methodCompiledEntryOffset; - @HotSpotVMField(name = "Method::_code", type = "CompiledMethod*", get = HotSpotVMField.Type.OFFSET) @Stable public int methodCodeOffset; - - @HotSpotVMConstant(name = "Method::_jfr_towrite") @Stable public int methodFlagsJfrTowrite; - @HotSpotVMConstant(name = "Method::_caller_sensitive") @Stable public int methodFlagsCallerSensitive; - @HotSpotVMConstant(name = "Method::_force_inline") @Stable public int methodFlagsForceInline; - @HotSpotVMConstant(name = "Method::_dont_inline") @Stable public int methodFlagsDontInline; - @HotSpotVMConstant(name = "Method::_hidden") @Stable public int methodFlagsHidden; - @HotSpotVMConstant(name = "Method::_reserved_stack_access") @Stable public int methodFlagsReservedStackAccess; - @HotSpotVMConstant(name = "Method::nonvirtual_vtable_index") @Stable public int nonvirtualVtableIndex; - @HotSpotVMConstant(name = "Method::invalid_vtable_index") @Stable public int invalidVtableIndex; - - @HotSpotVMField(name = "MethodCounters::_invocation_counter", type = "InvocationCounter", get = HotSpotVMField.Type.OFFSET) @Stable public int invocationCounterOffset; - @HotSpotVMField(name = "MethodCounters::_backedge_counter", type = "InvocationCounter", get = HotSpotVMField.Type.OFFSET) @Stable public int backedgeCounterOffset; - @HotSpotVMConstant(name = "InvocationCounter::count_increment") @Stable public int invocationCounterIncrement; - @HotSpotVMConstant(name = "InvocationCounter::count_shift") @Stable public int invocationCounterShift; - - @HotSpotVMField(name = "MethodData::_size", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int methodDataSize; - @HotSpotVMField(name = "MethodData::_data_size", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int methodDataDataSize; - @HotSpotVMField(name = "MethodData::_data[0]", type = "intptr_t", get = HotSpotVMField.Type.OFFSET) @Stable public int methodDataOopDataOffset; - @HotSpotVMField(name = "MethodData::_trap_hist._array[0]", type = "u1", get = HotSpotVMField.Type.OFFSET) @Stable public int methodDataOopTrapHistoryOffset; - @HotSpotVMField(name = "MethodData::_jvmci_ir_size", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int methodDataIRSizeOffset; - - @HotSpotVMField(name = "nmethod::_verified_entry_point", type = "address", get = HotSpotVMField.Type.OFFSET) @Stable public int nmethodEntryOffset; - @HotSpotVMField(name = "nmethod::_comp_level", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int nmethodCompLevelOffset; - - @HotSpotVMConstant(name = "CompLevel_none") @Stable public int compilationLevelNone; - @HotSpotVMConstant(name = "CompLevel_simple") @Stable public int compilationLevelSimple; - @HotSpotVMConstant(name = "CompLevel_limited_profile") @Stable public int compilationLevelLimitedProfile; - @HotSpotVMConstant(name = "CompLevel_full_profile") @Stable public int compilationLevelFullProfile; - @HotSpotVMConstant(name = "CompLevel_full_optimization") @Stable public int compilationLevelFullOptimization; - - @HotSpotVMConstant(name = "JVMCIRuntime::none") @Stable public int compLevelAdjustmentNone; - @HotSpotVMConstant(name = "JVMCIRuntime::by_holder") @Stable public int compLevelAdjustmentByHolder; - @HotSpotVMConstant(name = "JVMCIRuntime::by_full_signature") @Stable public int compLevelAdjustmentByFullSignature; - - @HotSpotVMConstant(name = "InvocationEntryBci") @Stable public int invocationEntryBci; - - @HotSpotVMField(name = "JVMCIEnv::_task", type = "CompileTask*", get = HotSpotVMField.Type.OFFSET) @Stable public int jvmciEnvTaskOffset; - @HotSpotVMField(name = "JVMCIEnv::_jvmti_can_hotswap_or_post_breakpoint", type = "bool", get = HotSpotVMField.Type.OFFSET) @Stable public int jvmciEnvJvmtiCanHotswapOrPostBreakpointOffset; - @HotSpotVMField(name = "CompileTask::_num_inlined_bytecodes", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int compileTaskNumInlinedBytecodesOffset; - - @HotSpotVMField(name = "CompilerToVM::Data::Method_extra_stack_entries", type = "int", get = HotSpotVMField.Type.VALUE) @Stable public int extraStackEntries; - - @HotSpotVMField(name = "ConstMethod::_constants", type = "ConstantPool*", get = HotSpotVMField.Type.OFFSET) @Stable public int constMethodConstantsOffset; - @HotSpotVMField(name = "ConstMethod::_flags", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int constMethodFlagsOffset; - @HotSpotVMField(name = "ConstMethod::_code_size", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int constMethodCodeSizeOffset; - @HotSpotVMField(name = "ConstMethod::_name_index", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int constMethodNameIndexOffset; - @HotSpotVMField(name = "ConstMethod::_signature_index", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int constMethodSignatureIndexOffset; - @HotSpotVMField(name = "ConstMethod::_max_stack", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int constMethodMaxStackOffset; - @HotSpotVMField(name = "ConstMethod::_max_locals", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int methodMaxLocalsOffset; - - @HotSpotVMConstant(name = "ConstMethod::_has_linenumber_table") @Stable public int constMethodHasLineNumberTable; - @HotSpotVMConstant(name = "ConstMethod::_has_localvariable_table") @Stable public int constMethodHasLocalVariableTable; - @HotSpotVMConstant(name = "ConstMethod::_has_exception_table") @Stable public int constMethodHasExceptionTable; - - @HotSpotVMType(name = "ExceptionTableElement", get = HotSpotVMType.Type.SIZE) @Stable public int exceptionTableElementSize; - @HotSpotVMField(name = "ExceptionTableElement::start_pc", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int exceptionTableElementStartPcOffset; - @HotSpotVMField(name = "ExceptionTableElement::end_pc", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int exceptionTableElementEndPcOffset; - @HotSpotVMField(name = "ExceptionTableElement::handler_pc", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int exceptionTableElementHandlerPcOffset; - @HotSpotVMField(name = "ExceptionTableElement::catch_type_index", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int exceptionTableElementCatchTypeIndexOffset; - - @HotSpotVMType(name = "LocalVariableTableElement", get = HotSpotVMType.Type.SIZE) @Stable public int localVariableTableElementSize; - @HotSpotVMField(name = "LocalVariableTableElement::start_bci", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int localVariableTableElementStartBciOffset; - @HotSpotVMField(name = "LocalVariableTableElement::length", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int localVariableTableElementLengthOffset; - @HotSpotVMField(name = "LocalVariableTableElement::name_cp_index", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int localVariableTableElementNameCpIndexOffset; - @HotSpotVMField(name = "LocalVariableTableElement::descriptor_cp_index", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int localVariableTableElementDescriptorCpIndexOffset; - @HotSpotVMField(name = "LocalVariableTableElement::signature_cp_index", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int localVariableTableElementSignatureCpIndexOffset; - @HotSpotVMField(name = "LocalVariableTableElement::slot", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int localVariableTableElementSlotOffset; - - @HotSpotVMType(name = "ConstantPool", get = HotSpotVMType.Type.SIZE) @Stable public int constantPoolSize; - @HotSpotVMField(name = "ConstantPool::_tags", type = "Array*", get = HotSpotVMField.Type.OFFSET) @Stable public int constantPoolTagsOffset; - @HotSpotVMField(name = "ConstantPool::_pool_holder", type = "InstanceKlass*", get = HotSpotVMField.Type.OFFSET) @Stable public int constantPoolHolderOffset; - @HotSpotVMField(name = "ConstantPool::_length", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int constantPoolLengthOffset; - - @HotSpotVMConstant(name = "ConstantPool::CPCACHE_INDEX_TAG") @Stable public int constantPoolCpCacheIndexTag; - - @HotSpotVMConstant(name = "JVM_CONSTANT_Utf8") @Stable public int jvmConstantUtf8; - @HotSpotVMConstant(name = "JVM_CONSTANT_Integer") @Stable public int jvmConstantInteger; - @HotSpotVMConstant(name = "JVM_CONSTANT_Long") @Stable public int jvmConstantLong; - @HotSpotVMConstant(name = "JVM_CONSTANT_Float") @Stable public int jvmConstantFloat; - @HotSpotVMConstant(name = "JVM_CONSTANT_Double") @Stable public int jvmConstantDouble; - @HotSpotVMConstant(name = "JVM_CONSTANT_Class") @Stable public int jvmConstantClass; - @HotSpotVMConstant(name = "JVM_CONSTANT_UnresolvedClass") @Stable public int jvmConstantUnresolvedClass; - @HotSpotVMConstant(name = "JVM_CONSTANT_UnresolvedClassInError") @Stable public int jvmConstantUnresolvedClassInError; - @HotSpotVMConstant(name = "JVM_CONSTANT_String") @Stable public int jvmConstantString; - @HotSpotVMConstant(name = "JVM_CONSTANT_Fieldref") @Stable public int jvmConstantFieldref; - @HotSpotVMConstant(name = "JVM_CONSTANT_Methodref") @Stable public int jvmConstantMethodref; - @HotSpotVMConstant(name = "JVM_CONSTANT_InterfaceMethodref") @Stable public int jvmConstantInterfaceMethodref; - @HotSpotVMConstant(name = "JVM_CONSTANT_NameAndType") @Stable public int jvmConstantNameAndType; - @HotSpotVMConstant(name = "JVM_CONSTANT_MethodHandle") @Stable public int jvmConstantMethodHandle; - @HotSpotVMConstant(name = "JVM_CONSTANT_MethodHandleInError") @Stable public int jvmConstantMethodHandleInError; - @HotSpotVMConstant(name = "JVM_CONSTANT_MethodType") @Stable public int jvmConstantMethodType; - @HotSpotVMConstant(name = "JVM_CONSTANT_MethodTypeInError") @Stable public int jvmConstantMethodTypeInError; - @HotSpotVMConstant(name = "JVM_CONSTANT_InvokeDynamic") @Stable public int jvmConstantInvokeDynamic; - - @HotSpotVMConstant(name = "JVM_CONSTANT_ExternalMax") @Stable public int jvmConstantExternalMax; - @HotSpotVMConstant(name = "JVM_CONSTANT_InternalMin") @Stable public int jvmConstantInternalMin; - @HotSpotVMConstant(name = "JVM_CONSTANT_InternalMax") @Stable public int jvmConstantInternalMax; - - @HotSpotVMConstant(name = "HeapWordSize") @Stable public int heapWordSize; - - @HotSpotVMType(name = "Symbol*", get = HotSpotVMType.Type.SIZE) @Stable public int symbolPointerSize; - - @HotSpotVMField(name = "vmSymbols::_symbols[0]", type = "Symbol*", get = HotSpotVMField.Type.ADDRESS) @Stable public long vmSymbolsSymbols; - @HotSpotVMConstant(name = "vmSymbols::FIRST_SID") @Stable public int vmSymbolsFirstSID; - @HotSpotVMConstant(name = "vmSymbols::SID_LIMIT") @Stable public int vmSymbolsSIDLimit; - - /** - * Bit pattern that represents a non-oop. Neither the high bits nor the low bits of this value - * are allowed to look like (respectively) the high or low bits of a real oop. - */ - @HotSpotVMField(name = "CompilerToVM::Data::Universe_non_oop_bits", type = "void*", get = HotSpotVMField.Type.VALUE) @Stable public long nonOopBits; - - @HotSpotVMField(name = "StubRoutines::_verify_oop_count", type = "jint", get = HotSpotVMField.Type.ADDRESS) @Stable public long verifyOopCounterAddress; - @HotSpotVMField(name = "CompilerToVM::Data::Universe_verify_oop_mask", type = "uintptr_t", get = HotSpotVMField.Type.VALUE) @Stable public long verifyOopMask; - @HotSpotVMField(name = "CompilerToVM::Data::Universe_verify_oop_bits", type = "uintptr_t", get = HotSpotVMField.Type.VALUE) @Stable public long verifyOopBits; - @HotSpotVMField(name = "CompilerToVM::Data::Universe_base_vtable_size", type = "int", get = HotSpotVMField.Type.VALUE) @Stable public int universeBaseVtableSize; - - public final int baseVtableLength() { + final int baseVtableLength() { return universeBaseVtableSize / vtableEntrySize; } - @HotSpotVMField(name = "HeapRegion::LogOfHRGrainBytes", type = "int", get = HotSpotVMField.Type.VALUE) @Stable public int logOfHRGrainBytes; - - @HotSpotVMConstant(name = "CardTableModRefBS::dirty_card") @Stable public byte dirtyCardValue; - @HotSpotVMConstant(name = "G1SATBCardTableModRefBS::g1_young_gen") @Stable public byte g1YoungCardValue; - - @HotSpotVMField(name = "CompilerToVM::Data::cardtable_start_address", type = "jbyte*", get = HotSpotVMField.Type.VALUE) @Stable private long cardtableStartAddress; - @HotSpotVMField(name = "CompilerToVM::Data::cardtable_shift", type = "int", get = HotSpotVMField.Type.VALUE) @Stable private int cardtableShift; - - public long cardtableStartAddress() { - return cardtableStartAddress; - } - - public int cardtableShift() { - return cardtableShift; - } - - @HotSpotVMField(name = "os::_polling_page", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long safepointPollingAddress; - - // G1 Collector Related Values. - - public int g1CardQueueIndexOffset() { - return javaThreadDirtyCardQueueOffset + dirtyCardQueueIndexOffset; - } - - public int g1CardQueueBufferOffset() { - return javaThreadDirtyCardQueueOffset + dirtyCardQueueBufferOffset; - } - - public int g1SATBQueueMarkingOffset() { - return javaThreadSatbMarkQueueOffset + satbMarkQueueActiveOffset; - } - - public int g1SATBQueueIndexOffset() { - return javaThreadSatbMarkQueueOffset + satbMarkQueueIndexOffset; - } - - public int g1SATBQueueBufferOffset() { - return javaThreadSatbMarkQueueOffset + satbMarkQueueBufferOffset; - } - - @HotSpotVMField(name = "java_lang_Class::_klass_offset", type = "int", get = HotSpotVMField.Type.VALUE) @Stable public int klassOffset; - @HotSpotVMField(name = "java_lang_Class::_array_klass_offset", type = "int", get = HotSpotVMField.Type.VALUE) @Stable public int arrayKlassOffset; - - @HotSpotVMType(name = "BasicLock", get = HotSpotVMType.Type.SIZE) @Stable public int basicLockSize; - @HotSpotVMField(name = "BasicLock::_displaced_header", type = "markOop", get = HotSpotVMField.Type.OFFSET) @Stable public int basicLockDisplacedHeaderOffset; - - @HotSpotVMField(name = "Thread::_allocated_bytes", type = "jlong", get = HotSpotVMField.Type.OFFSET) @Stable public int threadAllocatedBytesOffset; - - @HotSpotVMFlag(name = "TLABWasteIncrement") @Stable public int tlabRefillWasteIncrement; - - @HotSpotVMField(name = "ThreadLocalAllocBuffer::_start", type = "HeapWord*", get = HotSpotVMField.Type.OFFSET) @Stable private int threadLocalAllocBufferStartOffset; - @HotSpotVMField(name = "ThreadLocalAllocBuffer::_end", type = "HeapWord*", get = HotSpotVMField.Type.OFFSET) @Stable private int threadLocalAllocBufferEndOffset; - @HotSpotVMField(name = "ThreadLocalAllocBuffer::_top", type = "HeapWord*", get = HotSpotVMField.Type.OFFSET) @Stable private int threadLocalAllocBufferTopOffset; - @HotSpotVMField(name = "ThreadLocalAllocBuffer::_pf_top", type = "HeapWord*", get = HotSpotVMField.Type.OFFSET) @Stable private int threadLocalAllocBufferPfTopOffset; - @HotSpotVMField(name = "ThreadLocalAllocBuffer::_slow_allocations", type = "unsigned", get = HotSpotVMField.Type.OFFSET) @Stable private int threadLocalAllocBufferSlowAllocationsOffset; - @HotSpotVMField(name = "ThreadLocalAllocBuffer::_fast_refill_waste", type = "unsigned", get = HotSpotVMField.Type.OFFSET) @Stable private int threadLocalAllocBufferFastRefillWasteOffset; - @HotSpotVMField(name = "ThreadLocalAllocBuffer::_number_of_refills", type = "unsigned", get = HotSpotVMField.Type.OFFSET) @Stable private int threadLocalAllocBufferNumberOfRefillsOffset; - @HotSpotVMField(name = "ThreadLocalAllocBuffer::_refill_waste_limit", type = "size_t", get = HotSpotVMField.Type.OFFSET) @Stable private int threadLocalAllocBufferRefillWasteLimitOffset; - @HotSpotVMField(name = "ThreadLocalAllocBuffer::_desired_size", type = "size_t", get = HotSpotVMField.Type.OFFSET) @Stable private int threadLocalAllocBufferDesiredSizeOffset; - - public int tlabSlowAllocationsOffset() { - return threadTlabOffset + threadLocalAllocBufferSlowAllocationsOffset; - } - - public int tlabFastRefillWasteOffset() { - return threadTlabOffset + threadLocalAllocBufferFastRefillWasteOffset; - } - - public int tlabNumberOfRefillsOffset() { - return threadTlabOffset + threadLocalAllocBufferNumberOfRefillsOffset; - } - - public int tlabRefillWasteLimitOffset() { - return threadTlabOffset + threadLocalAllocBufferRefillWasteLimitOffset; - } - - public int threadTlabSizeOffset() { - return threadTlabOffset + threadLocalAllocBufferDesiredSizeOffset; - } - - public int threadTlabStartOffset() { - return threadTlabOffset + threadLocalAllocBufferStartOffset; - } - - public int threadTlabEndOffset() { - return threadTlabOffset + threadLocalAllocBufferEndOffset; - } - - public int threadTlabTopOffset() { - return threadTlabOffset + threadLocalAllocBufferTopOffset; - } - - public int threadTlabPfTopOffset() { - return threadTlabOffset + threadLocalAllocBufferPfTopOffset; - } - - @HotSpotVMField(name = "CompilerToVM::Data::ThreadLocalAllocBuffer_alignment_reserve", type = "size_t", get = HotSpotVMField.Type.VALUE) @Stable public int tlabAlignmentReserve; - - @HotSpotVMFlag(name = "TLABStats") @Stable public boolean tlabStats; - - // FIXME This is only temporary until the GC code is changed. - @HotSpotVMField(name = "CompilerToVM::Data::_supports_inline_contig_alloc", type = "bool", get = HotSpotVMField.Type.VALUE) @Stable public boolean inlineContiguousAllocationSupported; - @HotSpotVMField(name = "CompilerToVM::Data::_heap_end_addr", type = "HeapWord**", get = HotSpotVMField.Type.VALUE) @Stable public long heapEndAddress; - @HotSpotVMField(name = "CompilerToVM::Data::_heap_top_addr", type = "HeapWord**", get = HotSpotVMField.Type.VALUE) @Stable public long heapTopAddress; + final int klassOffset = getFieldValue("java_lang_Class::_klass_offset", Integer.class, "int"); /** * The DataLayout header size is the same as the cell size. */ - @HotSpotVMConstant(name = "DataLayout::cell_size") @Stable public int dataLayoutHeaderSize; - @HotSpotVMField(name = "DataLayout::_header._struct._tag", type = "u1", get = HotSpotVMField.Type.OFFSET) @Stable public int dataLayoutTagOffset; - @HotSpotVMField(name = "DataLayout::_header._struct._flags", type = "u1", get = HotSpotVMField.Type.OFFSET) @Stable public int dataLayoutFlagsOffset; - @HotSpotVMField(name = "DataLayout::_header._struct._bci", type = "u2", get = HotSpotVMField.Type.OFFSET) @Stable public int dataLayoutBCIOffset; - @HotSpotVMField(name = "DataLayout::_cells[0]", type = "intptr_t", get = HotSpotVMField.Type.OFFSET) @Stable public int dataLayoutCellsOffset; - @HotSpotVMConstant(name = "DataLayout::cell_size") @Stable public int dataLayoutCellSize; + final int dataLayoutHeaderSize = getConstant("DataLayout::cell_size", Integer.class); + final int dataLayoutTagOffset = getFieldOffset("DataLayout::_header._struct._tag", Integer.class, "u1"); + final int dataLayoutFlagsOffset = getFieldOffset("DataLayout::_header._struct._flags", Integer.class, "u1"); + final int dataLayoutBCIOffset = getFieldOffset("DataLayout::_header._struct._bci", Integer.class, "u2"); + final int dataLayoutCellSize = getConstant("DataLayout::cell_size", Integer.class); - @HotSpotVMConstant(name = "DataLayout::no_tag") @Stable public int dataLayoutNoTag; - @HotSpotVMConstant(name = "DataLayout::bit_data_tag") @Stable public int dataLayoutBitDataTag; - @HotSpotVMConstant(name = "DataLayout::counter_data_tag") @Stable public int dataLayoutCounterDataTag; - @HotSpotVMConstant(name = "DataLayout::jump_data_tag") @Stable public int dataLayoutJumpDataTag; - @HotSpotVMConstant(name = "DataLayout::receiver_type_data_tag") @Stable public int dataLayoutReceiverTypeDataTag; - @HotSpotVMConstant(name = "DataLayout::virtual_call_data_tag") @Stable public int dataLayoutVirtualCallDataTag; - @HotSpotVMConstant(name = "DataLayout::ret_data_tag") @Stable public int dataLayoutRetDataTag; - @HotSpotVMConstant(name = "DataLayout::branch_data_tag") @Stable public int dataLayoutBranchDataTag; - @HotSpotVMConstant(name = "DataLayout::multi_branch_data_tag") @Stable public int dataLayoutMultiBranchDataTag; - @HotSpotVMConstant(name = "DataLayout::arg_info_data_tag") @Stable public int dataLayoutArgInfoDataTag; - @HotSpotVMConstant(name = "DataLayout::call_type_data_tag") @Stable public int dataLayoutCallTypeDataTag; - @HotSpotVMConstant(name = "DataLayout::virtual_call_type_data_tag") @Stable public int dataLayoutVirtualCallTypeDataTag; - @HotSpotVMConstant(name = "DataLayout::parameters_type_data_tag") @Stable public int dataLayoutParametersTypeDataTag; - @HotSpotVMConstant(name = "DataLayout::speculative_trap_data_tag") @Stable public int dataLayoutSpeculativeTrapDataTag; + final int dataLayoutNoTag = getConstant("DataLayout::no_tag", Integer.class); + final int dataLayoutBitDataTag = getConstant("DataLayout::bit_data_tag", Integer.class); + final int dataLayoutCounterDataTag = getConstant("DataLayout::counter_data_tag", Integer.class); + final int dataLayoutJumpDataTag = getConstant("DataLayout::jump_data_tag", Integer.class); + final int dataLayoutReceiverTypeDataTag = getConstant("DataLayout::receiver_type_data_tag", Integer.class); + final int dataLayoutVirtualCallDataTag = getConstant("DataLayout::virtual_call_data_tag", Integer.class); + final int dataLayoutRetDataTag = getConstant("DataLayout::ret_data_tag", Integer.class); + final int dataLayoutBranchDataTag = getConstant("DataLayout::branch_data_tag", Integer.class); + final int dataLayoutMultiBranchDataTag = getConstant("DataLayout::multi_branch_data_tag", Integer.class); + final int dataLayoutArgInfoDataTag = getConstant("DataLayout::arg_info_data_tag", Integer.class); + final int dataLayoutCallTypeDataTag = getConstant("DataLayout::call_type_data_tag", Integer.class); + final int dataLayoutVirtualCallTypeDataTag = getConstant("DataLayout::virtual_call_type_data_tag", Integer.class); + final int dataLayoutParametersTypeDataTag = getConstant("DataLayout::parameters_type_data_tag", Integer.class); + final int dataLayoutSpeculativeTrapDataTag = getConstant("DataLayout::speculative_trap_data_tag", Integer.class); - @HotSpotVMFlag(name = "BciProfileWidth") @Stable public int bciProfileWidth; - @HotSpotVMFlag(name = "TypeProfileWidth") @Stable public int typeProfileWidth; - @HotSpotVMFlag(name = "MethodProfileWidth") @Stable public int methodProfileWidth; + final int bciProfileWidth = getFlag("BciProfileWidth", Integer.class); + final int typeProfileWidth = getFlag("TypeProfileWidth", Integer.class); + final int methodProfileWidth = getFlag("MethodProfileWidth", Integer.class); - @HotSpotVMField(name = "CompilerToVM::Data::SharedRuntime_ic_miss_stub", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long inlineCacheMissStub; - @HotSpotVMField(name = "CompilerToVM::Data::SharedRuntime_handle_wrong_method_stub", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long handleWrongMethodStub; + final int deoptReasonNone = getConstant("Deoptimization::Reason_none", Integer.class); + final int deoptReasonNullCheck = getConstant("Deoptimization::Reason_null_check", Integer.class); + final int deoptReasonRangeCheck = getConstant("Deoptimization::Reason_range_check", Integer.class); + final int deoptReasonClassCheck = getConstant("Deoptimization::Reason_class_check", Integer.class); + final int deoptReasonArrayCheck = getConstant("Deoptimization::Reason_array_check", Integer.class); + final int deoptReasonUnreached0 = getConstant("Deoptimization::Reason_unreached0", Integer.class); + final int deoptReasonTypeCheckInlining = getConstant("Deoptimization::Reason_type_checked_inlining", Integer.class); + final int deoptReasonOptimizedTypeCheck = getConstant("Deoptimization::Reason_optimized_type_check", Integer.class); + final int deoptReasonNotCompiledExceptionHandler = getConstant("Deoptimization::Reason_not_compiled_exception_handler", Integer.class); + final int deoptReasonUnresolved = getConstant("Deoptimization::Reason_unresolved", Integer.class); + final int deoptReasonJsrMismatch = getConstant("Deoptimization::Reason_jsr_mismatch", Integer.class); + final int deoptReasonDiv0Check = getConstant("Deoptimization::Reason_div0_check", Integer.class); + final int deoptReasonConstraint = getConstant("Deoptimization::Reason_constraint", Integer.class); + final int deoptReasonLoopLimitCheck = getConstant("Deoptimization::Reason_loop_limit_check", Integer.class); + final int deoptReasonAliasing = getConstant("Deoptimization::Reason_aliasing", Integer.class); + final int deoptReasonTransferToInterpreter = getConstant("Deoptimization::Reason_transfer_to_interpreter", Integer.class); + final int deoptReasonOSROffset = getConstant("Deoptimization::Reason_LIMIT", Integer.class); - @HotSpotVMField(name = "CompilerToVM::Data::SharedRuntime_deopt_blob_unpack", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long handleDeoptStub; - @HotSpotVMField(name = "CompilerToVM::Data::SharedRuntime_deopt_blob_uncommon_trap", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long uncommonTrapStub; + final int deoptActionNone = getConstant("Deoptimization::Action_none", Integer.class); + final int deoptActionMaybeRecompile = getConstant("Deoptimization::Action_maybe_recompile", Integer.class); + final int deoptActionReinterpret = getConstant("Deoptimization::Action_reinterpret", Integer.class); + final int deoptActionMakeNotEntrant = getConstant("Deoptimization::Action_make_not_entrant", Integer.class); + final int deoptActionMakeNotCompilable = getConstant("Deoptimization::Action_make_not_compilable", Integer.class); - @HotSpotVMField(name = "CodeCache::_low_bound", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long codeCacheLowBound; - @HotSpotVMField(name = "CodeCache::_high_bound", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long codeCacheHighBound; + final int deoptimizationActionBits = getConstant("Deoptimization::_action_bits", Integer.class); + final int deoptimizationReasonBits = getConstant("Deoptimization::_reason_bits", Integer.class); + final int deoptimizationDebugIdBits = getConstant("Deoptimization::_debug_id_bits", Integer.class); + final int deoptimizationActionShift = getConstant("Deoptimization::_action_shift", Integer.class); + final int deoptimizationReasonShift = getConstant("Deoptimization::_reason_shift", Integer.class); + final int deoptimizationDebugIdShift = getConstant("Deoptimization::_debug_id_shift", Integer.class); - @HotSpotVMField(name = "StubRoutines::_aescrypt_encryptBlock", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long aescryptEncryptBlockStub; - @HotSpotVMField(name = "StubRoutines::_aescrypt_decryptBlock", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long aescryptDecryptBlockStub; - @HotSpotVMField(name = "StubRoutines::_cipherBlockChaining_encryptAESCrypt", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long cipherBlockChainingEncryptAESCryptStub; - @HotSpotVMField(name = "StubRoutines::_cipherBlockChaining_decryptAESCrypt", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long cipherBlockChainingDecryptAESCryptStub; - @HotSpotVMField(name = "StubRoutines::_updateBytesCRC32", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long updateBytesCRC32Stub; - @HotSpotVMField(name = "StubRoutines::_crc_table_adr", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long crcTableAddress; + final int vmIntrinsicInvokeBasic = getConstant("vmIntrinsics::_invokeBasic", Integer.class); + final int vmIntrinsicLinkToVirtual = getConstant("vmIntrinsics::_linkToVirtual", Integer.class); + final int vmIntrinsicLinkToStatic = getConstant("vmIntrinsics::_linkToStatic", Integer.class); + final int vmIntrinsicLinkToSpecial = getConstant("vmIntrinsics::_linkToSpecial", Integer.class); + final int vmIntrinsicLinkToInterface = getConstant("vmIntrinsics::_linkToInterface", Integer.class); - @HotSpotVMField(name = "StubRoutines::_throw_delayed_StackOverflowError_entry", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long throwDelayedStackOverflowErrorEntry; + final int codeInstallResultOk = getConstant("JVMCIEnv::ok", Integer.class); + final int codeInstallResultDependenciesFailed = getConstant("JVMCIEnv::dependencies_failed", Integer.class); + final int codeInstallResultDependenciesInvalid = getConstant("JVMCIEnv::dependencies_invalid", Integer.class); + final int codeInstallResultCacheFull = getConstant("JVMCIEnv::cache_full", Integer.class); + final int codeInstallResultCodeTooLarge = getConstant("JVMCIEnv::code_too_large", Integer.class); - @HotSpotVMField(name = "StubRoutines::_jbyte_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jbyteArraycopy; - @HotSpotVMField(name = "StubRoutines::_jshort_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jshortArraycopy; - @HotSpotVMField(name = "StubRoutines::_jint_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jintArraycopy; - @HotSpotVMField(name = "StubRoutines::_jlong_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jlongArraycopy; - @HotSpotVMField(name = "StubRoutines::_oop_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long oopArraycopy; - @HotSpotVMField(name = "StubRoutines::_oop_arraycopy_uninit", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long oopArraycopyUninit; - @HotSpotVMField(name = "StubRoutines::_jbyte_disjoint_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jbyteDisjointArraycopy; - @HotSpotVMField(name = "StubRoutines::_jshort_disjoint_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jshortDisjointArraycopy; - @HotSpotVMField(name = "StubRoutines::_jint_disjoint_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jintDisjointArraycopy; - @HotSpotVMField(name = "StubRoutines::_jlong_disjoint_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jlongDisjointArraycopy; - @HotSpotVMField(name = "StubRoutines::_oop_disjoint_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long oopDisjointArraycopy; - @HotSpotVMField(name = "StubRoutines::_oop_disjoint_arraycopy_uninit", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long oopDisjointArraycopyUninit; - @HotSpotVMField(name = "StubRoutines::_arrayof_jbyte_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jbyteAlignedArraycopy; - @HotSpotVMField(name = "StubRoutines::_arrayof_jshort_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jshortAlignedArraycopy; - @HotSpotVMField(name = "StubRoutines::_arrayof_jint_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jintAlignedArraycopy; - @HotSpotVMField(name = "StubRoutines::_arrayof_jlong_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jlongAlignedArraycopy; - @HotSpotVMField(name = "StubRoutines::_arrayof_oop_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long oopAlignedArraycopy; - @HotSpotVMField(name = "StubRoutines::_arrayof_oop_arraycopy_uninit", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long oopAlignedArraycopyUninit; - @HotSpotVMField(name = "StubRoutines::_arrayof_jbyte_disjoint_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jbyteAlignedDisjointArraycopy; - @HotSpotVMField(name = "StubRoutines::_arrayof_jshort_disjoint_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jshortAlignedDisjointArraycopy; - @HotSpotVMField(name = "StubRoutines::_arrayof_jint_disjoint_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jintAlignedDisjointArraycopy; - @HotSpotVMField(name = "StubRoutines::_arrayof_jlong_disjoint_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long jlongAlignedDisjointArraycopy; - @HotSpotVMField(name = "StubRoutines::_arrayof_oop_disjoint_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long oopAlignedDisjointArraycopy; - @HotSpotVMField(name = "StubRoutines::_arrayof_oop_disjoint_arraycopy_uninit", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long oopAlignedDisjointArraycopyUninit; - @HotSpotVMField(name = "StubRoutines::_checkcast_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long checkcastArraycopy; - @HotSpotVMField(name = "StubRoutines::_checkcast_arraycopy_uninit", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long checkcastArraycopyUninit; - @HotSpotVMField(name = "StubRoutines::_unsafe_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long unsafeArraycopy; - @HotSpotVMField(name = "StubRoutines::_generic_arraycopy", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long genericArraycopy; - - @HotSpotVMAddress(name = "JVMCIRuntime::new_instance") @Stable public long newInstanceAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::new_array") @Stable public long newArrayAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::new_multi_array") @Stable public long newMultiArrayAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::dynamic_new_array") @Stable public long dynamicNewArrayAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::dynamic_new_instance") @Stable public long dynamicNewInstanceAddress; - - @HotSpotVMAddress(name = "JVMCIRuntime::thread_is_interrupted") @Stable public long threadIsInterruptedAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::vm_message") @Stable public long vmMessageAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::identity_hash_code") @Stable public long identityHashCodeAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::exception_handler_for_pc") @Stable public long exceptionHandlerForPcAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::monitorenter") @Stable public long monitorenterAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::monitorexit") @Stable public long monitorexitAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::throw_and_post_jvmti_exception") @Stable public long throwAndPostJvmtiExceptionAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::throw_klass_external_name_exception") @Stable public long throwKlassExternalNameExceptionAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::throw_class_cast_exception") @Stable public long throwClassCastExceptionAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::log_primitive") @Stable public long logPrimitiveAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::log_object") @Stable public long logObjectAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::log_printf") @Stable public long logPrintfAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::vm_error") @Stable public long vmErrorAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::load_and_clear_exception") @Stable public long loadAndClearExceptionAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::write_barrier_pre") @Stable public long writeBarrierPreAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::write_barrier_post") @Stable public long writeBarrierPostAddress; - @HotSpotVMAddress(name = "JVMCIRuntime::validate_object") @Stable public long validateObject; - - @HotSpotVMAddress(name = "JVMCIRuntime::test_deoptimize_call_int") @Stable public long testDeoptimizeCallInt; - - @HotSpotVMAddress(name = "SharedRuntime::register_finalizer") @Stable public long registerFinalizerAddress; - @HotSpotVMAddress(name = "SharedRuntime::exception_handler_for_return_address") @Stable public long exceptionHandlerForReturnAddressAddress; - @HotSpotVMAddress(name = "SharedRuntime::OSR_migration_end") @Stable public long osrMigrationEndAddress; - @HotSpotVMAddress(name = "SharedRuntime::enable_stack_reserved_zone") @Stable public long enableStackReservedZoneAddress; - - @HotSpotVMAddress(name = "os::javaTimeMillis") @Stable public long javaTimeMillisAddress; - @HotSpotVMAddress(name = "os::javaTimeNanos") @Stable public long javaTimeNanosAddress; - @HotSpotVMField(name = "CompilerToVM::Data::dsin", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long arithmeticSinAddress; - @HotSpotVMField(name = "CompilerToVM::Data::dcos", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long arithmeticCosAddress; - @HotSpotVMField(name = "CompilerToVM::Data::dtan", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long arithmeticTanAddress; - @HotSpotVMField(name = "CompilerToVM::Data::dexp", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long arithmeticExpAddress; - @HotSpotVMField(name = "CompilerToVM::Data::dlog", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long arithmeticLogAddress; - @HotSpotVMField(name = "CompilerToVM::Data::dlog10", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long arithmeticLog10Address; - @HotSpotVMField(name = "CompilerToVM::Data::dpow", type = "address", get = HotSpotVMField.Type.VALUE) @Stable public long arithmeticPowAddress; - - @HotSpotVMFlag(name = "JVMCICounterSize") @Stable public int jvmciCountersSize; - - @HotSpotVMAddress(name = "Deoptimization::fetch_unroll_info") @Stable public long deoptimizationFetchUnrollInfo; - @HotSpotVMAddress(name = "Deoptimization::uncommon_trap") @Stable public long deoptimizationUncommonTrap; - @HotSpotVMAddress(name = "Deoptimization::unpack_frames") @Stable public long deoptimizationUnpackFrames; - - @HotSpotVMConstant(name = "Deoptimization::Reason_none") @Stable public int deoptReasonNone; - @HotSpotVMConstant(name = "Deoptimization::Reason_null_check") @Stable public int deoptReasonNullCheck; - @HotSpotVMConstant(name = "Deoptimization::Reason_range_check") @Stable public int deoptReasonRangeCheck; - @HotSpotVMConstant(name = "Deoptimization::Reason_class_check") @Stable public int deoptReasonClassCheck; - @HotSpotVMConstant(name = "Deoptimization::Reason_array_check") @Stable public int deoptReasonArrayCheck; - @HotSpotVMConstant(name = "Deoptimization::Reason_unreached0") @Stable public int deoptReasonUnreached0; - @HotSpotVMConstant(name = "Deoptimization::Reason_type_checked_inlining") @Stable public int deoptReasonTypeCheckInlining; - @HotSpotVMConstant(name = "Deoptimization::Reason_optimized_type_check") @Stable public int deoptReasonOptimizedTypeCheck; - @HotSpotVMConstant(name = "Deoptimization::Reason_not_compiled_exception_handler") @Stable public int deoptReasonNotCompiledExceptionHandler; - @HotSpotVMConstant(name = "Deoptimization::Reason_unresolved") @Stable public int deoptReasonUnresolved; - @HotSpotVMConstant(name = "Deoptimization::Reason_jsr_mismatch") @Stable public int deoptReasonJsrMismatch; - @HotSpotVMConstant(name = "Deoptimization::Reason_div0_check") @Stable public int deoptReasonDiv0Check; - @HotSpotVMConstant(name = "Deoptimization::Reason_constraint") @Stable public int deoptReasonConstraint; - @HotSpotVMConstant(name = "Deoptimization::Reason_loop_limit_check") @Stable public int deoptReasonLoopLimitCheck; - @HotSpotVMConstant(name = "Deoptimization::Reason_aliasing") @Stable public int deoptReasonAliasing; - @HotSpotVMConstant(name = "Deoptimization::Reason_transfer_to_interpreter") @Stable public int deoptReasonTransferToInterpreter; - @HotSpotVMConstant(name = "Deoptimization::Reason_LIMIT") @Stable public int deoptReasonOSROffset; - - @HotSpotVMConstant(name = "Deoptimization::Action_none") @Stable public int deoptActionNone; - @HotSpotVMConstant(name = "Deoptimization::Action_maybe_recompile") @Stable public int deoptActionMaybeRecompile; - @HotSpotVMConstant(name = "Deoptimization::Action_reinterpret") @Stable public int deoptActionReinterpret; - @HotSpotVMConstant(name = "Deoptimization::Action_make_not_entrant") @Stable public int deoptActionMakeNotEntrant; - @HotSpotVMConstant(name = "Deoptimization::Action_make_not_compilable") @Stable public int deoptActionMakeNotCompilable; - - @HotSpotVMConstant(name = "Deoptimization::_action_bits") @Stable public int deoptimizationActionBits; - @HotSpotVMConstant(name = "Deoptimization::_reason_bits") @Stable public int deoptimizationReasonBits; - @HotSpotVMConstant(name = "Deoptimization::_debug_id_bits") @Stable public int deoptimizationDebugIdBits; - @HotSpotVMConstant(name = "Deoptimization::_action_shift") @Stable public int deoptimizationActionShift; - @HotSpotVMConstant(name = "Deoptimization::_reason_shift") @Stable public int deoptimizationReasonShift; - @HotSpotVMConstant(name = "Deoptimization::_debug_id_shift") @Stable public int deoptimizationDebugIdShift; - - @HotSpotVMConstant(name = "Deoptimization::Unpack_deopt") @Stable public int deoptimizationUnpackDeopt; - @HotSpotVMConstant(name = "Deoptimization::Unpack_exception") @Stable public int deoptimizationUnpackException; - @HotSpotVMConstant(name = "Deoptimization::Unpack_uncommon_trap") @Stable public int deoptimizationUnpackUncommonTrap; - @HotSpotVMConstant(name = "Deoptimization::Unpack_reexecute") @Stable public int deoptimizationUnpackReexecute; - - @HotSpotVMField(name = "Deoptimization::UnrollBlock::_size_of_deoptimized_frame", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int deoptimizationUnrollBlockSizeOfDeoptimizedFrameOffset; - @HotSpotVMField(name = "Deoptimization::UnrollBlock::_caller_adjustment", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int deoptimizationUnrollBlockCallerAdjustmentOffset; - @HotSpotVMField(name = "Deoptimization::UnrollBlock::_number_of_frames", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int deoptimizationUnrollBlockNumberOfFramesOffset; - @HotSpotVMField(name = "Deoptimization::UnrollBlock::_total_frame_sizes", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int deoptimizationUnrollBlockTotalFrameSizesOffset; - @HotSpotVMField(name = "Deoptimization::UnrollBlock::_unpack_kind", type = "int", get = HotSpotVMField.Type.OFFSET) @Stable public int deoptimizationUnrollBlockUnpackKindOffset; - @HotSpotVMField(name = "Deoptimization::UnrollBlock::_frame_sizes", type = "intptr_t*", get = HotSpotVMField.Type.OFFSET) @Stable public int deoptimizationUnrollBlockFrameSizesOffset; - @HotSpotVMField(name = "Deoptimization::UnrollBlock::_frame_pcs", type = "address*", get = HotSpotVMField.Type.OFFSET) @Stable public int deoptimizationUnrollBlockFramePcsOffset; - @HotSpotVMField(name = "Deoptimization::UnrollBlock::_initial_info", type = "intptr_t", get = HotSpotVMField.Type.OFFSET) @Stable public int deoptimizationUnrollBlockInitialInfoOffset; - - @HotSpotVMConstant(name = "vmIntrinsics::_invokeBasic") @Stable public int vmIntrinsicInvokeBasic; - @HotSpotVMConstant(name = "vmIntrinsics::_linkToVirtual") @Stable public int vmIntrinsicLinkToVirtual; - @HotSpotVMConstant(name = "vmIntrinsics::_linkToStatic") @Stable public int vmIntrinsicLinkToStatic; - @HotSpotVMConstant(name = "vmIntrinsics::_linkToSpecial") @Stable public int vmIntrinsicLinkToSpecial; - @HotSpotVMConstant(name = "vmIntrinsics::_linkToInterface") @Stable public int vmIntrinsicLinkToInterface; - - @HotSpotVMConstant(name = "JVMCIEnv::ok") @Stable public int codeInstallResultOk; - @HotSpotVMConstant(name = "JVMCIEnv::dependencies_failed") @Stable public int codeInstallResultDependenciesFailed; - @HotSpotVMConstant(name = "JVMCIEnv::dependencies_invalid") @Stable public int codeInstallResultDependenciesInvalid; - @HotSpotVMConstant(name = "JVMCIEnv::cache_full") @Stable public int codeInstallResultCacheFull; - @HotSpotVMConstant(name = "JVMCIEnv::code_too_large") @Stable public int codeInstallResultCodeTooLarge; - - public String getCodeInstallResultDescription(int codeInstallResult) { + String getCodeInstallResultDescription(int codeInstallResult) { if (codeInstallResult == codeInstallResultOk) { return "ok"; } @@ -1677,114 +348,17 @@ public class HotSpotVMConfig { return "unknown"; } - // Checkstyle: stop - @HotSpotVMConstant(name = "CodeInstaller::VERIFIED_ENTRY") @Stable public int MARKID_VERIFIED_ENTRY; - @HotSpotVMConstant(name = "CodeInstaller::UNVERIFIED_ENTRY") @Stable public int MARKID_UNVERIFIED_ENTRY; - @HotSpotVMConstant(name = "CodeInstaller::OSR_ENTRY") @Stable public int MARKID_OSR_ENTRY; - @HotSpotVMConstant(name = "CodeInstaller::EXCEPTION_HANDLER_ENTRY") @Stable public int MARKID_EXCEPTION_HANDLER_ENTRY; - @HotSpotVMConstant(name = "CodeInstaller::DEOPT_HANDLER_ENTRY") @Stable public int MARKID_DEOPT_HANDLER_ENTRY; - @HotSpotVMConstant(name = "CodeInstaller::INVOKEINTERFACE") @Stable public int MARKID_INVOKEINTERFACE; - @HotSpotVMConstant(name = "CodeInstaller::INVOKEVIRTUAL") @Stable public int MARKID_INVOKEVIRTUAL; - @HotSpotVMConstant(name = "CodeInstaller::INVOKESTATIC") @Stable public int MARKID_INVOKESTATIC; - @HotSpotVMConstant(name = "CodeInstaller::INVOKESPECIAL") @Stable public int MARKID_INVOKESPECIAL; - @HotSpotVMConstant(name = "CodeInstaller::INLINE_INVOKE") @Stable public int MARKID_INLINE_INVOKE; - @HotSpotVMConstant(name = "CodeInstaller::POLL_NEAR") @Stable public int MARKID_POLL_NEAR; - @HotSpotVMConstant(name = "CodeInstaller::POLL_RETURN_NEAR") @Stable public int MARKID_POLL_RETURN_NEAR; - @HotSpotVMConstant(name = "CodeInstaller::POLL_FAR") @Stable public int MARKID_POLL_FAR; - @HotSpotVMConstant(name = "CodeInstaller::POLL_RETURN_FAR") @Stable public int MARKID_POLL_RETURN_FAR; - @HotSpotVMConstant(name = "CodeInstaller::CARD_TABLE_SHIFT") @Stable public int MARKID_CARD_TABLE_SHIFT; - @HotSpotVMConstant(name = "CodeInstaller::CARD_TABLE_ADDRESS") @Stable public int MARKID_CARD_TABLE_ADDRESS; - @HotSpotVMConstant(name = "CodeInstaller::HEAP_TOP_ADDRESS") @Stable public int MARKID_HEAP_TOP_ADDRESS; - @HotSpotVMConstant(name = "CodeInstaller::HEAP_END_ADDRESS") @Stable public int MARKID_HEAP_END_ADDRESS; - @HotSpotVMConstant(name = "CodeInstaller::NARROW_KLASS_BASE_ADDRESS") @Stable public int MARKID_NARROW_KLASS_BASE_ADDRESS; - @HotSpotVMConstant(name = "CodeInstaller::CRC_TABLE_ADDRESS") @Stable public int MARKID_CRC_TABLE_ADDRESS; - @HotSpotVMConstant(name = "CodeInstaller::INVOKE_INVALID") @Stable public int MARKID_INVOKE_INVALID; - - @HotSpotVMConstant(name = "BitData::exception_seen_flag") @Stable public int bitDataExceptionSeenFlag; - @HotSpotVMConstant(name = "BitData::null_seen_flag") @Stable public int bitDataNullSeenFlag; - @HotSpotVMConstant(name = "CounterData::count_off") @Stable public int methodDataCountOffset; - @HotSpotVMConstant(name = "JumpData::taken_off_set") @Stable public int jumpDataTakenOffset; - @HotSpotVMConstant(name = "JumpData::displacement_off_set") @Stable public int jumpDataDisplacementOffset; - @HotSpotVMConstant(name = "ReceiverTypeData::nonprofiled_count_off_set") @Stable public int receiverTypeDataNonprofiledCountOffset; - @HotSpotVMConstant(name = "ReceiverTypeData::receiver_type_row_cell_count") @Stable public int receiverTypeDataReceiverTypeRowCellCount; - @HotSpotVMConstant(name = "ReceiverTypeData::receiver0_offset") @Stable public int receiverTypeDataReceiver0Offset; - @HotSpotVMConstant(name = "ReceiverTypeData::count0_offset") @Stable public int receiverTypeDataCount0Offset; - @HotSpotVMConstant(name = "BranchData::not_taken_off_set") @Stable public int branchDataNotTakenOffset; - @HotSpotVMConstant(name = "ArrayData::array_len_off_set") @Stable public int arrayDataArrayLenOffset; - @HotSpotVMConstant(name = "ArrayData::array_start_off_set") @Stable public int arrayDataArrayStartOffset; - @HotSpotVMConstant(name = "MultiBranchData::per_case_cell_count") @Stable public int multiBranchDataPerCaseCellCount; - - // Checkstyle: resume - - private boolean check() { - for (Field f : getClass().getDeclaredFields()) { - int modifiers = f.getModifiers(); - if (Modifier.isPublic(modifiers) && !Modifier.isStatic(modifiers)) { - assert Modifier.isFinal(modifiers) || f.getAnnotation(Stable.class) != null : "field should either be final or @Stable: " + f; - } - } - - assert codeEntryAlignment > 0 : codeEntryAlignment; - assert (layoutHelperArrayTagObjectValue & (1 << (Integer.SIZE - 1))) != 0 : "object array must have first bit set"; - assert (layoutHelperArrayTagTypeValue & (1 << (Integer.SIZE - 1))) != 0 : "type array must have first bit set"; - - return true; - } - - /** - * A compact representation of the different encoding strategies for Objects and metadata. - */ - public static class CompressEncoding { - public final long base; - public final int shift; - public final int alignment; - - CompressEncoding(long base, int shift, int alignment) { - this.base = base; - this.shift = shift; - this.alignment = alignment; - } - - public int compress(long ptr) { - if (ptr == 0L) { - return 0; - } else { - return (int) ((ptr - base) >>> shift); - } - } - - public long uncompress(int ptr) { - if (ptr == 0) { - return 0L; - } else { - return ((ptr & 0xFFFFFFFFL) << shift) + base; - } - } - - @Override - public String toString() { - return "base: " + base + " shift: " + shift + " alignment: " + alignment; - } - - @Override - public int hashCode() { - final int prime = 31; - int result = 1; - result = prime * result + alignment; - result = prime * result + (int) (base ^ (base >>> 32)); - result = prime * result + shift; - return result; - } - - @Override - public boolean equals(Object obj) { - if (obj instanceof CompressEncoding) { - CompressEncoding other = (CompressEncoding) obj; - return alignment == other.alignment && base == other.base && shift == other.shift; - } else { - return false; - } - } - } - + final int bitDataExceptionSeenFlag = getConstant("BitData::exception_seen_flag", Integer.class); + final int bitDataNullSeenFlag = getConstant("BitData::null_seen_flag", Integer.class); + final int methodDataCountOffset = getConstant("CounterData::count_off", Integer.class); + final int jumpDataTakenOffset = getConstant("JumpData::taken_off_set", Integer.class); + final int jumpDataDisplacementOffset = getConstant("JumpData::displacement_off_set", Integer.class); + final int receiverTypeDataNonprofiledCountOffset = getConstant("ReceiverTypeData::nonprofiled_count_off_set", Integer.class); + final int receiverTypeDataReceiverTypeRowCellCount = getConstant("ReceiverTypeData::receiver_type_row_cell_count", Integer.class); + final int receiverTypeDataReceiver0Offset = getConstant("ReceiverTypeData::receiver0_offset", Integer.class); + final int receiverTypeDataCount0Offset = getConstant("ReceiverTypeData::count0_offset", Integer.class); + final int branchDataNotTakenOffset = getConstant("BranchData::not_taken_off_set", Integer.class); + final int arrayDataArrayLenOffset = getConstant("ArrayData::array_len_off_set", Integer.class); + final int arrayDataArrayStartOffset = getConstant("ArrayData::array_start_off_set", Integer.class); + final int multiBranchDataPerCaseCellCount = getConstant("MultiBranchData::per_case_cell_count", Integer.class); } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVMConfigAccess.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVMConfigAccess.java new file mode 100644 index 00000000000..73ce3c545f0 --- /dev/null +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVMConfigAccess.java @@ -0,0 +1,327 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +package jdk.vm.ci.hotspot; + +import jdk.vm.ci.common.JVMCIError; + +/** + * Access to VM configuration data. + */ +public class HotSpotVMConfigAccess { + + /** + * Gets the address of a C++ symbol. + * + * @param name name of C++ symbol + * @param notPresent if non-null and the symbol is not present then this value is returned + * @return the address of the symbol + * @throws JVMCIError if the symbol is not present and {@code notPresent == null} + */ + public long getAddress(String name, Long notPresent) { + Long entry = store.vmAddresses.get(name); + if (entry == null) { + if (notPresent != null) { + return notPresent; + } + throw new JVMCIError("expected VM symbol not found: " + name); + } + return entry; + } + + /** + * Gets the address of a C++ symbol. + * + * @param name name of C++ symbol + * @return the address of the symbol + * @throws JVMCIError if the symbol is not present + */ + public long getAddress(String name) { + return getAddress(name, null); + } + + /** + * Gets the size of a C++ type. + * + * @param name name of the type + * @return the size in bytes of the requested field + * @throws JVMCIError if the field is not present and {@code notPresent} is null + */ + public int getTypeSize(String name) { + Long entry = store.vmTypeSizes.get(name); + if (entry == null) { + throw new JVMCIError("expected VM type not found: " + name); + } + return (int) (long) entry; + } + + /** + * Gets the value of a C++ constant. + * + * @param name name of the constant (e.g., {@code "frame::arg_reg_save_area_bytes"}) + * @param type the boxed type to which the constant value will be converted + * @param notPresent if non-null and the constant is not present then this value is returned + * @return the constant value converted to {@code type} + * @throws JVMCIError if the constant is not present and {@code notPresent == null} + */ + public T getConstant(String name, Class type, T notPresent) { + Long c = store.vmConstants.get(name); + if (c == null) { + if (notPresent != null) { + return notPresent; + } + throw new JVMCIError("expected VM constant not found: " + name); + } + return type.cast(convertValue(name, type, c, null)); + } + + /** + * Gets the value of a C++ constant. + * + * @param name name of the constant (e.g., {@code "frame::arg_reg_save_area_bytes"}) + * @param type the boxed type to which the constant value will be converted + * @return the constant value converted to {@code type} + * @throws JVMCIError if the constant is not present + */ + public T getConstant(String name, Class type) { + return getConstant(name, type, null); + } + + /** + * Gets the offset of a non-static C++ field. + * + * @param name fully qualified name of the field + * @param type the boxed type to which the offset value will be converted (must be + * {@link Integer} or {@link Long}) + * @param cppType if non-null, the expected C++ type of the field (e.g., {@code "HeapWord*"}) + * @param notPresent if non-null and the field is not present then this value is returned + * @return the offset in bytes of the requested field + * @throws JVMCIError if the field is static or not present and {@code notPresent} is null + */ + public T getFieldOffset(String name, Class type, String cppType, T notPresent) { + assert type == Integer.class || type == Long.class; + VMField entry = getField(name, cppType, notPresent == null); + if (entry == null) { + return notPresent; + } + if (entry.address != 0) { + throw new JVMCIError("cannot get offset of static field " + name); + } + return type.cast(convertValue(name, type, entry.offset, cppType)); + } + + /** + * Gets the offset of a non-static C++ field. + * + * @param name fully qualified name of the field + * @param type the boxed type to which the offset value will be converted (must be + * {@link Integer} or {@link Long}) + * @param cppType if non-null, the expected C++ type of the field (e.g., {@code "HeapWord*"}) + * @return the offset in bytes of the requested field + * @throws JVMCIError if the field is static or not present + */ + public T getFieldOffset(String name, Class type, String cppType) { + return getFieldOffset(name, type, cppType, null); + } + + /** + * Gets the offset of a non-static C++ field. + * + * @param name fully qualified name of the field + * @param type the boxed type to which the offset value will be converted (must be + * {@link Integer} or {@link Long}) + * @return the offset in bytes of the requested field + * @throws JVMCIError if the field is static or not present + */ + public T getFieldOffset(String name, Class type) { + return getFieldOffset(name, type, null, null); + } + + /** + * Gets the address of a static C++ field. + * + * @param name fully qualified name of the field + * @param cppType if non-null, the expected C++ type of the field (e.g., {@code "HeapWord*"}) + * @param notPresent if non-null and the field is not present then this value is returned + * @return the address of the requested field + * @throws JVMCIError if the field is not static or not present and {@code notPresent} is null + */ + public long getFieldAddress(String name, String cppType, Long notPresent) { + VMField entry = getField(name, cppType, notPresent == null); + if (entry == null) { + return notPresent; + } + if (entry.address == 0) { + throw new JVMCIError(name + " is not a static field"); + } + return entry.address; + } + + /** + * Gets the address of a static C++ field. + * + * @param name fully qualified name of the field + * @param cppType if non-null, the expected C++ type of the field (e.g., {@code "HeapWord*"}) + * @return the address of the requested field + * @throws JVMCIError if the field is not static or not present + */ + public long getFieldAddress(String name, String cppType) { + return getFieldAddress(name, cppType, null); + } + + /** + * Gets the value of a static C++ field. + * + * @param name fully qualified name of the field + * @param type the boxed type to which the constant value will be converted + * @param cppType if non-null, the expected C++ type of the field (e.g., {@code "HeapWord*"}) + * @param notPresent if non-null and the field is not present then this value is returned + * @return the value of the requested field + * @throws JVMCIError if the field is not static or not present and {@code notPresent} is null + */ + public T getFieldValue(String name, Class type, String cppType, T notPresent) { + VMField entry = getField(name, cppType, notPresent == null); + if (entry == null) { + return notPresent; + } + if (entry.value == null) { + throw new JVMCIError(name + " is not a static field"); + } + return type.cast(convertValue(name, type, entry.value, cppType)); + } + + /** + * Gets the value of a static C++ field. + * + * @param name fully qualified name of the field + * @param type the boxed type to which the constant value will be converted + * @param cppType if non-null, the expected C++ type of the field (e.g., {@code "HeapWord*"}) + * @return the value of the requested field + * @throws JVMCIError if the field is not static or not present + */ + public T getFieldValue(String name, Class type, String cppType) { + return getFieldValue(name, type, cppType, null); + } + + /** + * Gets the value of a static C++ field. + * + * @param name fully qualified name of the field + * @param type the boxed type to which the constant value will be converted + * @return the value of the requested field + * @throws JVMCIError if the field is not static or not present + */ + public T getFieldValue(String name, Class type) { + return getFieldValue(name, type, null, null); + } + + /** + * Gets a C++ field. + * + * @param name fully qualified name of the field + * @param cppType if non-null, the expected C++ type of the field (e.g., {@code "HeapWord*"}) + * @param required specifies if the field must be present + * @return the field + * @throws JVMCIError if the field is not present and {@code required == true} + */ + private VMField getField(String name, String cppType, boolean required) { + VMField entry = store.vmFields.get(name); + if (entry == null) { + if (!required) { + return null; + } + throw new JVMCIError("expected VM field not found: " + name); + } + + // Make sure the native type is still the type we expect. + if (cppType != null && !cppType.equals(entry.type)) { + throw new JVMCIError("expected type " + cppType + " but VM field " + name + " is of type " + entry.type); + } + return entry; + } + + /** + * Gets a VM flag value. + * + * @param name name of the flag (e.g., {@code "CompileTheWorldStartAt"}) + * @param type the boxed type to which the flag's value will be converted + * @return the flag's value converted to {@code type} or {@code notPresent} if the flag is not + * present + * @throws JVMCIError if the flag is not present + */ + public T getFlag(String name, Class type) { + return getFlag(name, type, null); + } + + /** + * Gets a VM flag value. + * + * @param name name of the flag (e.g., {@code "CompileTheWorldStartAt"}) + * @param type the boxed type to which the flag's value will be converted + * @param notPresent if non-null and the flag is not present then this value is returned + * @return the flag's value converted to {@code type} or {@code notPresent} if the flag is not + * present + * @throws JVMCIError if the flag is not present and {@code notPresent == null} + */ + public T getFlag(String name, Class type, T notPresent) { + VMFlag entry = store.vmFlags.get(name); + if (entry == null) { + if (notPresent != null) { + return notPresent; + } + throw new JVMCIError("expected VM flag not found: " + name); + } + return type.cast(convertValue(name, type, entry.value, entry.type)); + } + + private static Object convertValue(String name, Class toType, Object value, String cppType) throws JVMCIError { + if (toType == Boolean.class) { + if (value instanceof String) { + return Boolean.valueOf((String) value); + } else if (value instanceof Boolean) { + return value; + } else if (value instanceof Long) { + return ((long) value) != 0; + } + } else if (toType == Byte.class) { + if (value instanceof Long) { + return (byte) (long) value; + } + } else if (toType == Integer.class) { + if (value instanceof Integer) { + return value; + } else if (value instanceof Long) { + return (int) (long) value; + } + } else if (toType == Long.class) { + return value; + } + + throw new JVMCIError("cannot convert " + name + " of type " + value.getClass().getSimpleName() + (cppType == null ? "" : " [" + cppType + "]") + " to " + toType.getSimpleName()); + } + + private final HotSpotVMConfigStore store; + + public HotSpotVMConfigAccess(HotSpotVMConfigStore store) { + this.store = store; + } +} diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVMConfigStore.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVMConfigStore.java new file mode 100644 index 00000000000..c0554391a79 --- /dev/null +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVMConfigStore.java @@ -0,0 +1,153 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +package jdk.vm.ci.hotspot; + +import static jdk.vm.ci.common.InitTimer.timer; + +import java.util.Collections; +import java.util.HashMap; +import java.util.Map; + +import jdk.vm.ci.common.InitTimer; + +/** + * Access to VM configuration data. + */ +public final class HotSpotVMConfigStore { + + /** + * Gets the C++ symbols whose addresses are exposed by this object. + * + * @return an unmodifiable map from the symbol names to their addresses + */ + public Map getAddresses() { + return Collections.unmodifiableMap(vmAddresses); + } + + /** + * Gets the C++ type sizes exposed by this object. + * + * @return an unmodifiable map from C++ type names to their sizes in bytes + */ + public Map getTypeSizes() { + return Collections.unmodifiableMap(vmTypeSizes); + } + + /** + * Gets the C++ constants exposed by this object. + * + * @return an unmodifiable map from the names of C++ constants to their values + */ + public Map getConstants() { + return Collections.unmodifiableMap(vmConstants); + } + + /** + * Gets the VM flags exposed by this object. + * + * @return an unmodifiable map from VM flag names to {@link VMFlag} objects + */ + public Map getFlags() { + return Collections.unmodifiableMap(vmFlags); + } + + /** + * Gets the C++ fields exposed by this object. + * + * @return an unmodifiable map from VM field names to {@link VMField} objects + */ + public Map getFields() { + return Collections.unmodifiableMap(vmFields); + } + + final HashMap vmFields; + final HashMap vmTypeSizes; + final HashMap vmConstants; + final HashMap vmAddresses; + final HashMap vmFlags; + + /** + * Reads the database of VM info. The return value encodes the info in a nested object array + * that is described by the pseudo Java object {@code info} below: + * + *
    +     *     info = [
    +     *         VMField[] vmFields,
    +     *         [String name, Long size, ...] vmTypeSizes,
    +     *         [String name, Long value, ...] vmConstants,
    +     *         [String name, Long value, ...] vmAddresses,
    +     *         VMFlag[] vmFlags
    +     *     ]
    +     * 
    + */ + @SuppressWarnings("try") + HotSpotVMConfigStore(CompilerToVM compilerToVm) { + Object[] data; + try (InitTimer t = timer("CompilerToVm readConfiguration")) { + data = compilerToVm.readConfiguration(); + } + assert data.length == 5 : data.length; + + // @formatter:off + VMField[] vmFieldsInfo = (VMField[]) data[0]; + Object[] vmTypesSizesInfo = (Object[]) data[1]; + Object[] vmConstantsInfo = (Object[]) data[2]; + Object[] vmAddressesInfo = (Object[]) data[3]; + VMFlag[] vmFlagsInfo = (VMFlag[]) data[4]; + + vmFields = new HashMap<>(vmFieldsInfo.length); + vmTypeSizes = new HashMap<>(vmTypesSizesInfo.length); + vmConstants = new HashMap<>(vmConstantsInfo.length); + vmAddresses = new HashMap<>(vmAddressesInfo.length); + vmFlags = new HashMap<>(vmFlagsInfo.length); + // @formatter:on + + try (InitTimer t = timer("HotSpotVMConfigStore fill maps")) { + for (VMField vmField : vmFieldsInfo) { + vmFields.put(vmField.name, vmField); + } + + for (int i = 0; i < vmTypesSizesInfo.length / 2; i++) { + String name = (String) vmTypesSizesInfo[i * 2]; + Long size = (Long) vmTypesSizesInfo[i * 2 + 1]; + vmTypeSizes.put(name, size); + } + + for (int i = 0; i < vmConstantsInfo.length / 2; i++) { + String name = (String) vmConstantsInfo[i * 2]; + Long value = (Long) vmConstantsInfo[i * 2 + 1]; + vmConstants.put(name, value); + } + + for (int i = 0; i < vmAddressesInfo.length / 2; i++) { + String name = (String) vmAddressesInfo[i * 2]; + Long value = (Long) vmAddressesInfo[i * 2 + 1]; + vmAddresses.put(name, value); + } + + for (VMFlag vmFlag : vmFlagsInfo) { + vmFlags.put(vmFlag.name, vmFlag); + } + } + } +} diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVMConfigVerifier.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVMConfigVerifier.java deleted file mode 100644 index 8995bd60797..00000000000 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVMConfigVerifier.java +++ /dev/null @@ -1,164 +0,0 @@ -/* - * Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.vm.ci.hotspot; - -import static java.lang.String.format; - -import java.io.IOException; -import java.io.InputStream; -import java.lang.reflect.Constructor; -import java.lang.reflect.Executable; -import java.lang.reflect.Method; -import java.lang.reflect.Modifier; -import java.util.Arrays; -import java.util.Objects; - -import jdk.vm.ci.common.JVMCIError; -import jdk.internal.org.objectweb.asm.ClassReader; -import jdk.internal.org.objectweb.asm.ClassVisitor; -import jdk.internal.org.objectweb.asm.Label; -import jdk.internal.org.objectweb.asm.MethodVisitor; -import jdk.internal.org.objectweb.asm.Opcodes; -import jdk.internal.org.objectweb.asm.Type; -import jdk.internal.misc.Unsafe; - -/** - * A {@link ClassVisitor} that verifies {@link HotSpotVMConfig} does not access {@link Unsafe} from - * any of its non-static, non-constructor methods. This ensures that a deserialized - * {@link HotSpotVMConfig} object does not perform any unsafe reads on addresses that are only valid - * in the context in which the object was serialized. Note that this does not catch cases where a - * client uses an address stored in a {@link HotSpotVMConfig} field. - */ -final class HotSpotVMConfigVerifier extends ClassVisitor { - - public static boolean check() { - Class cls = HotSpotVMConfig.class; - String classFilePath = "/" + cls.getName().replace('.', '/') + ".class"; - try { - InputStream classfile = cls.getResourceAsStream(classFilePath); - ClassReader cr = new ClassReader(Objects.requireNonNull(classfile, "Could not find class file for " + cls.getName())); - ClassVisitor cv = new HotSpotVMConfigVerifier(); - cr.accept(cv, 0); - return true; - } catch (IOException e) { - throw new JVMCIError(e); - } - } - - /** - * Source file context for error reporting. - */ - String sourceFile = null; - - /** - * Line number for error reporting. - */ - int lineNo = -1; - - private static Class resolve(String name) { - try { - return Class.forName(name.replace('/', '.')); - } catch (ClassNotFoundException e) { - throw new JVMCIError(e); - } - } - - HotSpotVMConfigVerifier() { - super(Opcodes.ASM5); - } - - @Override - public void visitSource(String source, String debug) { - this.sourceFile = source; - } - - void verify(boolean condition, String message) { - if (!condition) { - error(message); - } - } - - void error(String message) { - String errorMessage = format("%s:%d: %s is not allowed in the context of compilation replay. The unsafe access should be moved into the %s constructor and the result cached in a field", - sourceFile, lineNo, message, HotSpotVMConfig.class.getSimpleName()); - throw new JVMCIError(errorMessage); - - } - - @Override - public MethodVisitor visitMethod(int access, String name, String d, String signature, String[] exceptions) { - if (!Modifier.isStatic(access) && Modifier.isPublic(access) && !name.equals("")) { - return new MethodVisitor(Opcodes.ASM5) { - - @Override - public void visitLineNumber(int line, Label start) { - lineNo = line; - } - - private Executable resolveMethod(String owner, String methodName, String methodDesc) { - Class declaringClass = resolve(owner); - while (declaringClass != null) { - if (methodName.equals("")) { - for (Constructor c : declaringClass.getDeclaredConstructors()) { - if (methodDesc.equals(Type.getConstructorDescriptor(c))) { - return c; - } - } - } else { - Type[] argumentTypes = Type.getArgumentTypes(methodDesc); - for (Method m : declaringClass.getDeclaredMethods()) { - if (m.getName().equals(methodName)) { - if (Arrays.equals(argumentTypes, Type.getArgumentTypes(m))) { - if (Type.getReturnType(methodDesc).equals(Type.getReturnType(m))) { - return m; - } - } - } - } - } - declaringClass = declaringClass.getSuperclass(); - } - throw new NoSuchMethodError(owner + "." + methodName + methodDesc); - } - - /** - * Checks whether a given method is allowed to be called. - */ - private boolean checkInvokeTarget(Executable method) { - if (method.getDeclaringClass().equals(Unsafe.class)) { - return false; - } - return true; - } - - @Override - public void visitMethodInsn(int opcode, String owner, String methodName, String methodDesc, boolean itf) { - Executable callee = resolveMethod(owner, methodName, methodDesc); - verify(checkInvokeTarget(callee), "invocation of " + callee); - } - }; - } else { - return null; - } - } -} diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVmSymbols.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVmSymbols.java deleted file mode 100644 index bcc2b8f99eb..00000000000 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotVmSymbols.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.vm.ci.hotspot; - -import static jdk.vm.ci.hotspot.HotSpotJVMCIRuntime.runtime; -import static jdk.vm.ci.hotspot.UnsafeAccess.UNSAFE; -import jdk.internal.misc.Unsafe; - -/** - * Class to access the C++ {@code vmSymbols} table. - */ -final class HotSpotVmSymbols { - - /** - * Returns the symbol in the {@code vmSymbols} table at position {@code index} as {@link String} - * . - * - * @param index position in the symbol table - * @return the symbol at position id - */ - static String symbolAt(int index) { - HotSpotJVMCIRuntimeProvider runtime = runtime(); - HotSpotVMConfig config = runtime.getConfig(); - assert config.vmSymbolsFirstSID <= index && index < config.vmSymbolsSIDLimit : "index " + index + " is out of bounds"; - assert config.symbolPointerSize == Unsafe.ADDRESS_SIZE : "the following address read is broken"; - return runtime.getCompilerToVM().getSymbol(UNSAFE.getAddress(config.vmSymbolsSymbols + index * config.symbolPointerSize)); - } -} diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/MetaspaceWrapperObject.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/MetaspaceWrapperObject.java index 444b25bed3d..1cb4dad6596 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/MetaspaceWrapperObject.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/MetaspaceWrapperObject.java @@ -23,7 +23,8 @@ package jdk.vm.ci.hotspot; /** - * A tag interface indicating that this type is a wrapper around a HotSpot metaspace object. + * A tag interface indicating that this type is a wrapper around a HotSpot metaspace object that + * requires GC interaction to keep alive. * * It would preferable if this were the base class containing the pointer but that would require * mixins since most of the wrapper types have complex supertype hierarchies. @@ -31,4 +32,18 @@ package jdk.vm.ci.hotspot; interface MetaspaceWrapperObject { long getMetaspacePointer(); + + /** + * Check if this object is properly registered for metadata tracking. All classes which + * implement this interface must be registered with the + * {@link HotSpotJVMCIMetaAccessContext#add} unless they are kept alive through other means. + * Currently the only type which doesn't require explicit registration is + * {@link HotSpotResolvedObjectTypeImpl} since it's kept alive by references to the + * {@link Class}. + * + * @return true if this object is properly registered for meta data tracking. + */ + default boolean isRegistered() { + return HotSpotJVMCIRuntime.runtime().metaAccessContext.isRegistered(this); + } } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/VMField.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/VMField.java new file mode 100644 index 00000000000..094d92cdd32 --- /dev/null +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/VMField.java @@ -0,0 +1,92 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +package jdk.vm.ci.hotspot; + +/** + * Describes a C++ field exposed via {@link HotSpotVMConfigAccess}. + */ +public final class VMField { + + /** + * Fully qualified name of the represented field (e.g., "Klass::_name"). + */ + public final String name; + + /** + * The represented field's type (e.g., "Symbol*"). This may be {@code null}. + */ + public final String type; + + /** + * If represented field is non-static, this is its offset within the containing structure. + */ + public final long offset; + + /** + * If represented field is static, this is its address. Otherwise, this field is 0. + */ + public final long address; + + /** + * Value of the field represented as a boxed long; only valid for non-oop static fields. This + * value is only captured once, during JVMCI initialization. If {@link #type} cannot be + * meaningfully (e.g., a struct) or safely (e.g., an oop) expressed as a boxed long, this is + * {@code null}. + */ + public final Long value; + + /** + * Determines if the represented field is static. + */ + public boolean isStatic() { + return address != 0; + } + + /** + * Creates a description of a non-static field. + */ + public VMField(String name, String type, long offset) { + this.name = name; + this.type = type; + this.offset = offset; + this.address = 0; + this.value = null; + } + + /** + * Creates a description of a static field. + */ + public VMField(String name, String type, long address, Long value) { + this.name = name; + this.type = type; + this.offset = 0; + this.address = address; + this.value = value; + } + + @Override + public String toString() { + String val = value == null ? "null" : String.format("0x%x", value); + return String.format("Field[name=%s, type=%s, offset=%d, address=0x%x, value=%s]", name, type, offset, address, val); + } +} diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMType.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/VMFlag.java similarity index 57% rename from hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMType.java rename to hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/VMFlag.java index 1be06f15630..77ede1c3796 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMType.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/VMFlag.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -20,41 +20,36 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ -package jdk.vm.ci.hotspotvmconfig; - -import java.lang.annotation.ElementType; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.Target; +package jdk.vm.ci.hotspot; /** - * Refers to a C++ type in the VM. + * Describes a VM flag exposed via {@link HotSpotVMConfigAccess}. */ -@Target(ElementType.FIELD) -@Retention(RetentionPolicy.RUNTIME) -public @interface HotSpotVMType { +public final class VMFlag { /** - * Types of information this annotation can return. + * The name of the flag. */ - enum Type { - /** - * Returns the size of the type (C++ {@code sizeof()}). - */ - SIZE; + public final String name; + + /** + * The C++ type of the flag. + */ + public final String type; + + /** + * The flag's value. + */ + public final Object value; + + VMFlag(String name, String type, Object value) { + this.name = name; + this.type = type; + this.value = value; } - /** - * Specifies what type of information to return. - * - * @see Type - */ - Type get(); - - /** - * Returns the name of the type. - * - * @return name of type - */ - String name(); + @Override + public String toString() { + return String.format("Flag[type=%s, name=%s, value=%s]", type, name, value); + } } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/services/HotSpotJVMCICompilerFactory.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/services/HotSpotJVMCICompilerFactory.java index 6b7d48bec07..e629bc91150 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/services/HotSpotJVMCICompilerFactory.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/services/HotSpotJVMCICompilerFactory.java @@ -22,7 +22,6 @@ */ package jdk.vm.ci.hotspot.services; -import jdk.vm.ci.hotspot.HotSpotVMConfig; import jdk.vm.ci.runtime.services.JVMCICompilerFactory; /** @@ -42,35 +41,54 @@ public abstract class HotSpotJVMCICompilerFactory extends JVMCICompilerFactory { return null; } + public enum CompilationLevelAdjustment { + /** + * No adjustment. + */ + None, + + /** + * Adjust based on declaring class of method. + */ + ByHolder, + + /** + * Adjust based on declaring class, name and signature of method. + */ + ByFullSignature + } + /** * Determines if this object may want to adjust the compilation level for a method that is being - * scheduled by the VM for compilation. The legal return values and their meanings are: - *
      - *
    • 0 - no adjustment
    • - *
    • 1 - adjust based on declaring class of method
    • - *
    • 2 - adjust based on declaring class, name and signature of method
    • - *
    + * scheduled by the VM for compilation. */ - public int getCompilationLevelAdjustment(HotSpotVMConfig config) { - return config.compLevelAdjustmentNone; + public CompilationLevelAdjustment getCompilationLevelAdjustment() { + return CompilationLevelAdjustment.None; + } + + public enum CompilationLevel { + None, + Simple, + LimitedProfile, + FullProfile, + FullOptimization } /** * Potentially modifies the compilation level currently selected by the VM compilation policy * for a method. * - * @param config object for reading HotSpot {@code CompLevel} enum values * @param declaringClass the class in which the method is declared * @param name the name of the method or {@code null} depending on the value that was returned - * by {@link #getCompilationLevelAdjustment(HotSpotVMConfig)} + * by {@link #getCompilationLevelAdjustment()} * @param signature the signature of the method or {@code null} depending on the value that was - * returned by {@link #getCompilationLevelAdjustment(HotSpotVMConfig)} + * returned by {@link #getCompilationLevelAdjustment()} * @param isOsr specifies if the compilation being scheduled in an OSR compilation * @param level the compilation level currently selected by the VM compilation policy * @return the compilation level to use for the compilation being scheduled (must be a valid * {@code CompLevel} enum value) */ - public int adjustCompilationLevel(HotSpotVMConfig config, Class declaringClass, String name, String signature, boolean isOsr, int level) { + public CompilationLevel adjustCompilationLevel(Class declaringClass, String name, String signature, boolean isOsr, CompilationLevel level) { throw new InternalError("Should not reach here"); } } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMAddress.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMAddress.java deleted file mode 100644 index 0900bfa207d..00000000000 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMAddress.java +++ /dev/null @@ -1,60 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.vm.ci.hotspotvmconfig; - -import java.lang.annotation.ElementType; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.Target; - -/** - * Refers to a C++ address in the VM. - */ -@Target(ElementType.FIELD) -@Retention(RetentionPolicy.RUNTIME) -public @interface HotSpotVMAddress { - - /** - * Returns the name of the symbol this address is referring to. - * - * @return name of symbol of this address - */ - String name(); - - /** - * List of architectures where this constant is required. Names are derived from - * {@link HotSpotVMConfig#getHostArchitectureName()}. An empty list implies that the constant is - * required on all architectures. - */ - @SuppressWarnings("javadoc") - String[] archs() default {}; - - /** - * List of operating systems where this constant is required. Names are derived from - * {@link HotSpotVMConfig#getHostOSName()}. An empty list implies that the constant is required - * on all operating systems. - */ - @SuppressWarnings("javadoc") - String[] os() default {}; - -} diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMField.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMField.java deleted file mode 100644 index c58c9e72fd5..00000000000 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMField.java +++ /dev/null @@ -1,85 +0,0 @@ -/* - * Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.vm.ci.hotspotvmconfig; - -import java.lang.annotation.ElementType; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.Target; - -/** - * Refers to a C++ field in the VM. - */ -@Target(ElementType.FIELD) -@Retention(RetentionPolicy.RUNTIME) -public @interface HotSpotVMField { - - /** - * Types of information this annotation can return. - */ - enum Type { - /** - * Returns the offset of this field within the type. Only valid for instance fields. - */ - OFFSET, - - /** - * Returns the absolute address of this field. Only valid for static fields. - */ - ADDRESS, - - /** - * Returns the value of this field. Only valid for static fields. - */ - VALUE; - } - - /** - * Specifies what type of information to return. - * - * @see Type - */ - Type get(); - - /** - * Returns the type name containing this field. - * - * @return name of containing type - */ - String type(); - - /** - * Returns the name of this field. - * - * @return name of field - */ - String name(); - - /** - * List of architectures where this constant is required. Names are derived from - * {@link HotSpotVMConfig#getHostArchitectureName()}. An empty list implies that the constant is - * required on all architectures. - */ - @SuppressWarnings("javadoc") - String[] archs() default {}; -} diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/AbstractJavaProfile.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/AbstractJavaProfile.java index 27eac0ec032..4e703beddf6 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/AbstractJavaProfile.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/AbstractJavaProfile.java @@ -37,6 +37,12 @@ public abstract class AbstractJavaProfile, U> private final double notRecordedProbability; private final T[] pitems; + /** + * + * @param notRecordedProbability + * @param pitems + */ + @SuppressFBWarnings(value = "EI_EXPOSE_REP2", justification = "caller transfers ownership of the `pitems` array parameter") public AbstractJavaProfile(double notRecordedProbability, T[] pitems) { this.pitems = pitems; assert !Double.isNaN(notRecordedProbability); diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/AbstractProfiledItem.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/AbstractProfiledItem.java index d4e551d40ae..87b8c99f1f6 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/AbstractProfiledItem.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/AbstractProfiledItem.java @@ -51,14 +51,14 @@ public abstract class AbstractProfiledItem implements Comparable o) { - if (getProbability() > o.getProbability()) { - return -1; - } else if (getProbability() < o.getProbability()) { - return 1; - } - return 0; + // Need to swap the order of operands so that higher probabilities are sorted first + return Double.compare(o.getProbability(), getProbability()); } @Override diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/ConstantPool.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/ConstantPool.java index f56e802431e..1df1c1faee4 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/ConstantPool.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/ConstantPool.java @@ -48,16 +48,18 @@ public interface ConstantPool { /** * Looks up a reference to a field. If {@code opcode} is non-negative, then resolution checks - * specific to the bytecode it denotes are performed if the field is already resolved. Should + * specific to the bytecode it denotes are performed if the field is already resolved. Checks + * for some bytecodes require the method that contains the bytecode to be specified. Should * any of these checks fail, an unresolved field reference is returned. * * @param cpi the constant pool index * @param opcode the opcode of the instruction for which the lookup is being performed or * {@code -1} + * @param method the method for which the lookup is being performed * @return a reference to the field at {@code cpi} in this pool * @throws ClassFormatError if the entry at {@code cpi} is not a field */ - JavaField lookupField(int cpi, int opcode); + JavaField lookupField(int cpi, ResolvedJavaMethod method, int opcode); /** * Looks up a reference to a method. If {@code opcode} is non-negative, then resolution checks diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/LineNumberTable.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/LineNumberTable.java index d3b87f7d390..71109dccf1b 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/LineNumberTable.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/LineNumberTable.java @@ -22,24 +22,34 @@ */ package jdk.vm.ci.meta; +/** + * Maps bytecode indexes to source line numbers. + * + * @see "https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.7.12" + */ public class LineNumberTable { private final int[] lineNumbers; private final int[] bci; + /** + * + * @param lineNumbers an array or source line numbers. This array is now owned by this object + * and should not be mutated by the caller. + * @param bci an array of bytecode indexes the same length at {@code lineNumbers} whose entries + * are sorted in ascending order. This array is now owned by this object and must not + * be mutated by the caller. + */ + @SuppressFBWarnings(value = "EI_EXPOSE_REP2", justification = "caller transfers ownership of `lineNumbers` and `bcis`") public LineNumberTable(int[] lineNumbers, int[] bci) { + assert bci.length == lineNumbers.length; this.lineNumbers = lineNumbers; this.bci = bci; } - public int[] getLineNumberEntries() { - return lineNumbers; - } - - public int[] getBciEntries() { - return bci; - } - + /** + * Gets a source line number for {@code atBci}. + */ public int getLineNumber(int atBci) { for (int i = 0; i < this.bci.length - 1; i++) { if (this.bci[i] <= atBci && atBci < this.bci[i + 1]) { diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/Local.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/Local.java index 285fdd72a0e..ff444ffe094 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/Local.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/Local.java @@ -22,6 +22,9 @@ */ package jdk.vm.ci.meta; +/** + * Describes the type and bytecode index range in which a local variable is live. + */ public class Local { private final String name; diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/LocalVariableTable.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/LocalVariableTable.java index f8bf703bc38..b81ec8d3880 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/LocalVariableTable.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/LocalVariableTable.java @@ -25,10 +25,19 @@ package jdk.vm.ci.meta; import java.util.ArrayList; import java.util.List; +/** + * @see "https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.7.13" + */ public class LocalVariableTable { private final Local[] locals; + /** + * + * @param locals array of objects describing local variables. This array is now owned by this + * object and must not be mutated by the caller. + */ + @SuppressFBWarnings(value = "EI_EXPOSE_REP2", justification = "caller transfers ownership of `locals`") public LocalVariableTable(Local[] locals) { this.locals = locals; } @@ -47,10 +56,6 @@ public class LocalVariableTable { return result; } - public Local[] getLocals() { - return locals; - } - public Local[] getLocalsAt(int bci) { List result = new ArrayList<>(); for (Local l : locals) { diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMFlag.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/SuppressFBWarnings.java similarity index 55% rename from hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMFlag.java rename to hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/SuppressFBWarnings.java index 99e9ac39fb2..5d28bd8f3db 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMFlag.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/SuppressFBWarnings.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -20,34 +20,21 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ -package jdk.vm.ci.hotspotvmconfig; - -import java.lang.annotation.ElementType; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.Target; +package jdk.vm.ci.meta; /** - * Refers to a C++ flag in the VM. + * Used to suppress FindBugs warnings. */ -@Target(ElementType.FIELD) -@Retention(RetentionPolicy.RUNTIME) -public @interface HotSpotVMFlag { +@interface SuppressFBWarnings { + /** + * The set of FindBugs + * warnings that are to be + * suppressed in annotated element. The value can be a bug category, kind or pattern. + */ + String[] value(); /** - * Returns the name of this flag. - * - * @return name of flag. + * Reason why the warning is suppressed. */ - String name(); - - /** - * List of architectures where this constant is required. Names are derived from - * {@link HotSpotVMConfig#getHostArchitectureName()}. An empty list implies that the constant is - * required on all architectures. - */ - @SuppressWarnings("javadoc") - String[] archs() default {}; - - boolean optional() default false; + String justification(); } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/Value.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/Value.java index 6d364d72f53..5118a90df5b 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/Value.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/Value.java @@ -65,7 +65,7 @@ public abstract class Value { * {@link #toString()} implementation of subclasses. */ protected final String getKindSuffix() { - return "|" + getPlatformKind().getTypeChar(); + return "|" + valueKind.getKindSuffix(); } public final ValueKind getValueKind() { diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/ValueKind.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/ValueKind.java index 84a10ababfc..a4d5f2190d9 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/ValueKind.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/ValueKind.java @@ -60,6 +60,11 @@ public abstract class ValueKind> { public IllegalValueKind changeType(PlatformKind newPlatformKind) { return this; } + + @Override + public String toString() { + return "ILLEGAL"; + } } /** @@ -82,4 +87,13 @@ public abstract class ValueKind> { * override this to preserve the additional information added by the compiler. */ public abstract K changeType(PlatformKind newPlatformKind); + + /** + * Returns a String representation of the kind, which will be included at the end of + * {@link Value#toString()} implementation. Defaults to {@link #toString()} but can be + * overridden to provide something more specific. + */ + public String getKindSuffix() { + return toString(); + } } diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.sparc/src/jdk/vm/ci/sparc/SPARC.java b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.sparc/src/jdk/vm/ci/sparc/SPARC.java index 7f99e331e1b..672970c2026 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.sparc/src/jdk/vm/ci/sparc/SPARC.java +++ b/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.sparc/src/jdk/vm/ci/sparc/SPARC.java @@ -32,6 +32,7 @@ import java.util.Set; import jdk.vm.ci.code.Architecture; import jdk.vm.ci.code.Register; import jdk.vm.ci.code.Register.RegisterCategory; +import jdk.vm.ci.code.RegisterArray; import jdk.vm.ci.meta.JavaKind; import jdk.vm.ci.meta.PlatformKind; @@ -179,35 +180,35 @@ public class SPARC extends Architecture { public static final Register q60 = new Register(111, getQuadncoding(60), "q60", FPUq); // @formatter:off - public static final Register[] cpuRegisters = { + public static final RegisterArray cpuRegisters = new RegisterArray( g0, g1, g2, g3, g4, g5, g6, g7, o0, o1, o2, o3, o4, o5, o6, o7, l0, l1, l2, l3, l4, l5, l6, l7, i0, i1, i2, i3, i4, i5, i6, i7 - }; + ); - public static final Register[] fpusRegisters = { + public static final RegisterArray fpusRegisters = new RegisterArray( f0, f1, f2, f3, f4, f5, f6, f7, f8, f9, f10, f11, f12, f13, f14, f15, f16, f17, f18, f19, f20, f21, f22, f23, f24, f25, f26, f27, f28, f29, f30, f31 - }; + ); - public static final Register[] fpudRegisters = { + public static final RegisterArray fpudRegisters = new RegisterArray( d0, d2, d4, d6, d8, d10, d12, d14, d16, d18, d20, d22, d24, d26, d28, d30, d32, d34, d36, d38, d40, d42, d44, d46, d48, d50, d52, d54, d56, d58, d60, d62 - }; + ); - public static final Register[] fpuqRegisters = { + public static final RegisterArray fpuqRegisters = new RegisterArray( q0, q4, q8, q12, q16, q20, q24, q28, q32, q36, q40, q44, - q48, q52, q56, q60, - }; + q48, q52, q56, q60 + ); - public static final Register[] allRegisters = { + public static final RegisterArray allRegisters = new RegisterArray( g0, g1, g2, g3, g4, g5, g6, g7, o0, o1, o2, o3, o4, o5, o6, o7, l0, l1, l2, l3, l4, l5, l6, l7, @@ -226,8 +227,8 @@ public class SPARC extends Architecture { q0, q4, q8, q12, q16, q20, q24, q28, q32, q36, q40, q44, - q48, q52, q56, q60, - }; + q48, q52, q56, q60 + ); // @formatter:on /** @@ -248,7 +249,7 @@ public class SPARC extends Architecture { } @Override - public Register[] getAvailableValueRegisters() { + public RegisterArray getAvailableValueRegisters() { return allRegisters; } diff --git a/hotspot/src/os/aix/vm/os_aix.cpp b/hotspot/src/os/aix/vm/os_aix.cpp index 20e3770af33..6b676df416c 100644 --- a/hotspot/src/os/aix/vm/os_aix.cpp +++ b/hotspot/src/os/aix/vm/os_aix.cpp @@ -156,8 +156,6 @@ int os::Aix::_on_pase = -1; // SS - service pack, if known, 0 otherwise uint32_t os::Aix::_os_version = 0; -int os::Aix::_stack_page_size = -1; - // -1 = uninitialized, 0 - no, 1 - yes int os::Aix::_xpg_sus_mode = -1; @@ -1499,7 +1497,6 @@ void os::print_memory_info(outputStream* st) { g_multipage_support.error); st->cr(); st->print_cr(" os::vm_page_size: %s", describe_pagesize(os::vm_page_size())); - // not used in OpenJDK st->print_cr(" os::stack_page_size: %s", describe_pagesize(os::stack_page_size())); // print out LDR_CNTRL because it affects the default page sizes const char* const ldr_cntrl = ::getenv("LDR_CNTRL"); @@ -3451,10 +3448,6 @@ void os::init(void) { FLAG_SET_ERGO(bool, Use64KPages, true); } - // Short-wire stack page size to base page size; if that works, we just remove - // that stack page size altogether. - Aix::_stack_page_size = Aix::_page_size; - // For now UseLargePages is just ignored. FLAG_SET_ERGO(bool, UseLargePages, false); _page_sizes[0] = 0; @@ -3589,15 +3582,15 @@ jint os::init_2(void) { // Check minimum allowable stack size for thread creation and to initialize // the java system classes, including StackOverflowError - depends on page - // size. Add a page for compiler2 recursion in main thread. - // Add in 2*BytesPerWord times page size to account for VM stack during + // size. Add two 4K pages for compiler2 recursion in main thread. + // Add in 4*BytesPerWord 4K pages to account for VM stack during // class initialization depending on 32 or 64 bit VM. os::Aix::min_stack_allowed = MAX2(os::Aix::min_stack_allowed, JavaThread::stack_guard_zone_size() + JavaThread::stack_shadow_zone_size() + - (2*BytesPerWord COMPILER2_PRESENT(+1)) * Aix::vm_default_page_size()); + (4*BytesPerWord COMPILER2_PRESENT(+2)) * 4 * K); - os::Aix::min_stack_allowed = align_size_up(os::Aix::min_stack_allowed, os::Aix::page_size()); + os::Aix::min_stack_allowed = align_size_up(os::Aix::min_stack_allowed, os::vm_page_size()); size_t threadStackSizeInBytes = ThreadStackSize * K; if (threadStackSizeInBytes != 0 && diff --git a/hotspot/src/os/aix/vm/os_aix.hpp b/hotspot/src/os/aix/vm/os_aix.hpp index db8c38aca5e..c17cd686c1c 100644 --- a/hotspot/src/os/aix/vm/os_aix.hpp +++ b/hotspot/src/os/aix/vm/os_aix.hpp @@ -49,9 +49,6 @@ class Aix { static Mutex* _createThread_lock; static int _page_size; - // Page size of newly created pthreads. - static int _stack_page_size; - // -1 = uninitialized, 0 = AIX, 1 = OS/400 (PASE) static int _on_pase; @@ -113,15 +110,6 @@ class Aix { return _page_size; } - // Accessor methods for stack page size which may be different from usual page size. - static int stack_page_size(void) { - assert(_stack_page_size != -1, "not initialized"); - return _stack_page_size; - } - - // This is used to scale stack space (guard pages etc.). The name is somehow misleading. - static int vm_default_page_size(void ) { return 8*K; } - static address ucontext_get_pc(const ucontext_t* uc); static intptr_t* ucontext_get_sp(const ucontext_t* uc); static intptr_t* ucontext_get_fp(const ucontext_t* uc); diff --git a/hotspot/src/os/aix/vm/os_aix.inline.hpp b/hotspot/src/os/aix/vm/os_aix.inline.hpp index 11c0c3fc5d3..0ff36f11452 100644 --- a/hotspot/src/os/aix/vm/os_aix.inline.hpp +++ b/hotspot/src/os/aix/vm/os_aix.inline.hpp @@ -1,6 +1,6 @@ /* * Copyright (c) 1999, 2016, Oracle and/or its affiliates. All rights reserved. - * Copyright (c) 2012, 2015 SAP SE. All rights reserved. + * Copyright (c) 2012, 2016 SAP SE. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -52,7 +52,7 @@ inline bool os::uses_stack_guard_pages() { // Whether or not calling code should/can commit/uncommit stack pages // before guarding them. Answer for AIX is definitly no, because memory // is automatically committed on touch. -inline bool os::allocate_stack_guard_pages() { +inline bool os::must_commit_stack_guard_pages() { assert(uses_stack_guard_pages(), "sanity check"); return false; } @@ -65,7 +65,7 @@ inline void os::pd_split_reserved_memory(char *base, size_t size, } // Bang the shadow pages if they need to be touched to be mapped. -inline void os::map_stack_shadow_pages() { +inline void os::map_stack_shadow_pages(address sp) { } inline void os::dll_unload(void *lib) { diff --git a/hotspot/src/os/bsd/vm/os_bsd.cpp b/hotspot/src/os/bsd/vm/os_bsd.cpp index 6de75924e8d..b8c40f60a00 100644 --- a/hotspot/src/os/bsd/vm/os_bsd.cpp +++ b/hotspot/src/os/bsd/vm/os_bsd.cpp @@ -3491,13 +3491,15 @@ jint os::init_2(void) { // Check minimum allowable stack size for thread creation and to initialize // the java system classes, including StackOverflowError - depends on page - // size. Add a page for compiler2 recursion in main thread. - // Add in 2*BytesPerWord times page size to account for VM stack during + // size. Add two 4K pages for compiler2 recursion in main thread. + // Add in 4*BytesPerWord 4K pages to account for VM stack during // class initialization depending on 32 or 64 bit VM. os::Bsd::min_stack_allowed = MAX2(os::Bsd::min_stack_allowed, JavaThread::stack_guard_zone_size() + JavaThread::stack_shadow_zone_size() + - (2*BytesPerWord COMPILER2_PRESENT(+1)) * Bsd::page_size()); + (4*BytesPerWord COMPILER2_PRESENT(+2)) * 4 * K); + + os::Bsd::min_stack_allowed = align_size_up(os::Bsd::min_stack_allowed, os::vm_page_size()); size_t threadStackSizeInBytes = ThreadStackSize * K; if (threadStackSizeInBytes != 0 && diff --git a/hotspot/src/os/bsd/vm/os_bsd.inline.hpp b/hotspot/src/os/bsd/vm/os_bsd.inline.hpp index b4a89aa4d8f..3a405dec283 100644 --- a/hotspot/src/os/bsd/vm/os_bsd.inline.hpp +++ b/hotspot/src/os/bsd/vm/os_bsd.inline.hpp @@ -47,7 +47,7 @@ inline bool os::uses_stack_guard_pages() { return true; } -inline bool os::allocate_stack_guard_pages() { +inline bool os::must_commit_stack_guard_pages() { assert(uses_stack_guard_pages(), "sanity check"); #if !defined(__FreeBSD__) || __FreeBSD__ < 5 // Since FreeBSD 4 uses malloc() for allocating the thread stack @@ -68,7 +68,7 @@ inline void os::pd_split_reserved_memory(char *base, size_t size, // Bang the shadow pages if they need to be touched to be mapped. -inline void os::map_stack_shadow_pages() { +inline void os::map_stack_shadow_pages(address sp) { } inline void os::dll_unload(void *lib) { diff --git a/hotspot/src/os/linux/vm/os_linux.cpp b/hotspot/src/os/linux/vm/os_linux.cpp index 004779ab740..94d1889d65a 100644 --- a/hotspot/src/os/linux/vm/os_linux.cpp +++ b/hotspot/src/os/linux/vm/os_linux.cpp @@ -142,7 +142,6 @@ int (*os::Linux::_pthread_setname_np)(pthread_t, const char*) = NULL; Mutex* os::Linux::_createThread_lock = NULL; pthread_t os::Linux::_main_thread; int os::Linux::_page_size = -1; -const int os::Linux::_vm_default_page_size = (8 * K); bool os::Linux::_supports_fast_thread_cpu_time = false; uint32_t os::Linux::_os_version = 0; const char * os::Linux::_glibc_version = NULL; @@ -4784,13 +4783,15 @@ jint os::init_2(void) { // Check minimum allowable stack size for thread creation and to initialize // the java system classes, including StackOverflowError - depends on page - // size. Add a page for compiler2 recursion in main thread. - // Add in 2*BytesPerWord times page size to account for VM stack during + // size. Add two 4K pages for compiler2 recursion in main thread. + // Add in 4*BytesPerWord 4K pages to account for VM stack during // class initialization depending on 32 or 64 bit VM. os::Linux::min_stack_allowed = MAX2(os::Linux::min_stack_allowed, JavaThread::stack_guard_zone_size() + JavaThread::stack_shadow_zone_size() + - (2*BytesPerWord COMPILER2_PRESENT(+1)) * Linux::vm_default_page_size()); + (4*BytesPerWord COMPILER2_PRESENT(+2)) * 4 * K); + + os::Linux::min_stack_allowed = align_size_up(os::Linux::min_stack_allowed, os::vm_page_size()); size_t threadStackSizeInBytes = ThreadStackSize * K; if (threadStackSizeInBytes != 0 && diff --git a/hotspot/src/os/linux/vm/os_linux.hpp b/hotspot/src/os/linux/vm/os_linux.hpp index 68e1968d2a1..2b6ae922e3f 100644 --- a/hotspot/src/os/linux/vm/os_linux.hpp +++ b/hotspot/src/os/linux/vm/os_linux.hpp @@ -71,7 +71,6 @@ class Linux { static pthread_t _main_thread; static Mutex* _createThread_lock; static int _page_size; - static const int _vm_default_page_size; static julong available_memory(); static julong physical_memory() { return _physical_memory; } @@ -130,8 +129,6 @@ class Linux { static int page_size(void) { return _page_size; } static void set_page_size(int val) { _page_size = val; } - static int vm_default_page_size(void) { return _vm_default_page_size; } - static address ucontext_get_pc(const ucontext_t* uc); static void ucontext_set_pc(ucontext_t* uc, address pc); static intptr_t* ucontext_get_sp(const ucontext_t* uc); diff --git a/hotspot/src/os/linux/vm/os_linux.inline.hpp b/hotspot/src/os/linux/vm/os_linux.inline.hpp index 935b7c3ebd0..937cd474c1c 100644 --- a/hotspot/src/os/linux/vm/os_linux.inline.hpp +++ b/hotspot/src/os/linux/vm/os_linux.inline.hpp @@ -47,7 +47,7 @@ inline bool os::uses_stack_guard_pages() { return true; } -inline bool os::allocate_stack_guard_pages() { +inline bool os::must_commit_stack_guard_pages() { assert(uses_stack_guard_pages(), "sanity check"); return true; } @@ -60,7 +60,7 @@ inline void os::pd_split_reserved_memory(char *base, size_t size, // Bang the shadow pages if they need to be touched to be mapped. -inline void os::map_stack_shadow_pages() { +inline void os::map_stack_shadow_pages(address sp) { } inline void os::dll_unload(void *lib) { diff --git a/hotspot/src/os/solaris/vm/os_solaris.cpp b/hotspot/src/os/solaris/vm/os_solaris.cpp index 169937db642..b8cbb78a159 100644 --- a/hotspot/src/os/solaris/vm/os_solaris.cpp +++ b/hotspot/src/os/solaris/vm/os_solaris.cpp @@ -4477,13 +4477,15 @@ jint os::init_2(void) { // Check minimum allowable stack size for thread creation and to initialize // the java system classes, including StackOverflowError - depends on page - // size. Add a page for compiler2 recursion in main thread. - // Add in 2*BytesPerWord times page size to account for VM stack during + // size. Add two 4K pages for compiler2 recursion in main thread. + // Add in 4*BytesPerWord 4K pages to account for VM stack during // class initialization depending on 32 or 64 bit VM. os::Solaris::min_stack_allowed = MAX2(os::Solaris::min_stack_allowed, JavaThread::stack_guard_zone_size() + JavaThread::stack_shadow_zone_size() + - (2*BytesPerWord COMPILER2_PRESENT(+1)) * page_size); + (4*BytesPerWord COMPILER2_PRESENT(+2)) * 4 * K); + + os::Solaris::min_stack_allowed = align_size_up(os::Solaris::min_stack_allowed, os::vm_page_size()); size_t threadStackSizeInBytes = ThreadStackSize * K; if (threadStackSizeInBytes != 0 && diff --git a/hotspot/src/os/solaris/vm/os_solaris.inline.hpp b/hotspot/src/os/solaris/vm/os_solaris.inline.hpp index 24f44704470..b1eb5bbabae 100644 --- a/hotspot/src/os/solaris/vm/os_solaris.inline.hpp +++ b/hotspot/src/os/solaris/vm/os_solaris.inline.hpp @@ -46,7 +46,7 @@ inline bool os::uses_stack_guard_pages() { return true; } -inline bool os::allocate_stack_guard_pages() { +inline bool os::must_commit_stack_guard_pages() { assert(uses_stack_guard_pages(), "sanity check"); int r = thr_main() ; guarantee (r == 0 || r == 1, "CR6501650 or CR6493689") ; @@ -61,8 +61,9 @@ inline void os::pd_split_reserved_memory(char *base, size_t size, // Bang the shadow pages if they need to be touched to be mapped. -inline void os::map_stack_shadow_pages() { +inline void os::map_stack_shadow_pages(address sp) { } + inline void os::dll_unload(void *lib) { ::dlclose(lib); } inline const int os::default_file_open_flags() { return 0;} diff --git a/hotspot/src/os/windows/vm/os_windows.cpp b/hotspot/src/os/windows/vm/os_windows.cpp index fcdddd32c26..23a06c9db24 100644 --- a/hotspot/src/os/windows/vm/os_windows.cpp +++ b/hotspot/src/os/windows/vm/os_windows.cpp @@ -4183,13 +4183,16 @@ jint os::init_2(void) { // Check minimum allowable stack size for thread creation and to initialize // the java system classes, including StackOverflowError - depends on page - // size. Add a page for compiler2 recursion in main thread. - // Add in 2*BytesPerWord times page size to account for VM stack during + // size. Add two 4K pages for compiler2 recursion in main thread. + // Add in 4*BytesPerWord 4K pages to account for VM stack during // class initialization depending on 32 or 64 bit VM. size_t min_stack_allowed = - (size_t)(JavaThread::stack_yellow_zone_size() + JavaThread::stack_red_zone_size() + + (size_t)(JavaThread::stack_guard_zone_size() + JavaThread::stack_shadow_zone_size() + - (2*BytesPerWord COMPILER2_PRESENT(+1)) * os::vm_page_size()); + (4*BytesPerWord COMPILER2_PRESENT(+2)) * 4 * K); + + min_stack_allowed = align_size_up(min_stack_allowed, os::vm_page_size()); + if (actual_reserve_size < min_stack_allowed) { tty->print_cr("\nThe stack size specified is too small, " "Specify at least %dk", @@ -5247,6 +5250,12 @@ int os::fork_and_exec(char* cmd) { static int mallocDebugIntervalCounter = 0; static int mallocDebugCounter = 0; + +// For debugging possible bugs inside HeapWalk (a ring buffer) +#define SAVE_COUNT 8 +static PROCESS_HEAP_ENTRY saved_heap_entries[SAVE_COUNT]; +static int saved_heap_entry_index; + bool os::check_heap(bool force) { if (++mallocDebugCounter < MallocVerifyStart && !force) return true; if (++mallocDebugIntervalCounter >= MallocVerifyInterval || force) { @@ -5267,13 +5276,28 @@ bool os::check_heap(bool force) { if (HeapLock(heap) != 0) { PROCESS_HEAP_ENTRY phe; phe.lpData = NULL; + memset(saved_heap_entries, 0, sizeof(saved_heap_entries)); + saved_heap_entry_index = 0; + int count = 0; + while (HeapWalk(heap, &phe) != 0) { + count ++; if ((phe.wFlags & PROCESS_HEAP_ENTRY_BUSY) && !HeapValidate(heap, 0, phe.lpData)) { tty->print_cr("C heap has been corrupted (time: %d allocations)", mallocDebugCounter); - tty->print_cr("corrupted block near address %#x, length %d", phe.lpData, phe.cbData); + tty->print_cr("corrupted block near address %#x, length %d, count %d", phe.lpData, phe.cbData, count); HeapUnlock(heap); fatal("corrupted C heap"); + } else { + // Save previous seen entries in a ring buffer. We have seen strange + // heap corruption fatal errors that produced mdmp files, but when we load + // these mdmp files in WinDBG, "!heap -triage" shows no error. + // We can examine the saved_heap_entries[] array in the mdmp file to + // diagnose such seemingly spurious errors reported by HeapWalk. + saved_heap_entries[saved_heap_entry_index++] = phe; + if (saved_heap_entry_index >= SAVE_COUNT) { + saved_heap_entry_index = 0; + } } } DWORD err = GetLastError(); diff --git a/hotspot/src/os/windows/vm/os_windows.inline.hpp b/hotspot/src/os/windows/vm/os_windows.inline.hpp index cf4a3005aae..2231b42d581 100644 --- a/hotspot/src/os/windows/vm/os_windows.inline.hpp +++ b/hotspot/src/os/windows/vm/os_windows.inline.hpp @@ -53,7 +53,7 @@ inline bool os::uses_stack_guard_pages() { return true; } -inline bool os::allocate_stack_guard_pages() { +inline bool os::must_commit_stack_guard_pages() { return true; } @@ -66,14 +66,16 @@ inline int os::readdir_buf_size(const char *path) } // Bang the shadow pages if they need to be touched to be mapped. -inline void os::map_stack_shadow_pages() { +inline void os::map_stack_shadow_pages(address sp) { // Write to each page of our new frame to force OS mapping. // If we decrement stack pointer more than one page // the OS may not map an intervening page into our space // and may fault on a memory access to interior of our frame. - address sp = current_stack_pointer(); - for (size_t pages = 1; pages <= (JavaThread::stack_shadow_zone_size() / os::vm_page_size()); pages++) { - *((int *)(sp - (pages * vm_page_size()))) = 0; + const int page_size = os::win32::vm_page_size(); + const size_t n_pages = JavaThread::stack_shadow_zone_size() / page_size; + for (size_t pages = 1; pages <= n_pages; pages++) { + sp -= page_size; + *sp = 0; } } diff --git a/hotspot/src/os_cpu/aix_ppc/vm/atomic_aix_ppc.inline.hpp b/hotspot/src/os_cpu/aix_ppc/vm/atomic_aix_ppc.inline.hpp index 5cbb383f4b8..a7462ad395e 100644 --- a/hotspot/src/os_cpu/aix_ppc/vm/atomic_aix_ppc.inline.hpp +++ b/hotspot/src/os_cpu/aix_ppc/vm/atomic_aix_ppc.inline.hpp @@ -291,12 +291,30 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* dest) { return (void*)xchg_ptr((intptr_t)exchange_value, (volatile intptr_t*)dest); } +inline void cmpxchg_pre_membar(cmpxchg_memory_order order) { + if (order != memory_order_relaxed) { + __asm__ __volatile__ ( + /* fence */ + strasm_sync + ); + } +} + +inline void cmpxchg_post_membar(cmpxchg_memory_order order) { + if (order != memory_order_relaxed) { + __asm__ __volatile__ ( + /* fence */ + strasm_sync + ); + } +} + #define VM_HAS_SPECIALIZED_CMPXCHG_BYTE -inline jbyte Atomic::cmpxchg(jbyte exchange_value, volatile jbyte* dest, jbyte compare_value) { +inline jbyte Atomic::cmpxchg(jbyte exchange_value, volatile jbyte* dest, jbyte compare_value, cmpxchg_memory_order order) { // Note that cmpxchg guarantees a two-way memory barrier across - // the cmpxchg, so it's really a a 'fence_cmpxchg_acquire' - // (see atomic.hpp). + // the cmpxchg, so it's really a a 'fence_cmpxchg_fence' if not + // specified otherwise (see atomic.hpp). // Using 32 bit internally. volatile int *dest_base = (volatile int*)((uintptr_t)dest & ~3); @@ -312,9 +330,9 @@ inline jbyte Atomic::cmpxchg(jbyte exchange_value, volatile jbyte* dest, jbyte c unsigned int old_value, value32; + cmpxchg_pre_membar(order); + __asm__ __volatile__ ( - /* fence */ - strasm_sync /* simple guard */ " lbz %[old_value], 0(%[dest]) \n" " cmpw %[masked_compare_val], %[old_value] \n" @@ -331,8 +349,6 @@ inline jbyte Atomic::cmpxchg(jbyte exchange_value, volatile jbyte* dest, jbyte c " xor %[value32], %[xor_value], %[value32] \n" " stwcx. %[value32], 0, %[dest_base] \n" " bne- 1b \n" - /* acquire */ - strasm_sync /* exit */ "2: \n" /* out */ @@ -353,21 +369,23 @@ inline jbyte Atomic::cmpxchg(jbyte exchange_value, volatile jbyte* dest, jbyte c "memory" ); + cmpxchg_post_membar(order); + return (jbyte)(unsigned char)old_value; } -inline jint Atomic::cmpxchg(jint exchange_value, volatile jint* dest, jint compare_value) { +inline jint Atomic::cmpxchg(jint exchange_value, volatile jint* dest, jint compare_value, cmpxchg_memory_order order) { // Note that cmpxchg guarantees a two-way memory barrier across - // the cmpxchg, so it's really a a 'fence_cmpxchg_acquire' - // (see atomic.hpp). + // the cmpxchg, so it's really a a 'fence_cmpxchg_fence' if not + // specified otherwise (see atomic.hpp). unsigned int old_value; const uint64_t zero = 0; + cmpxchg_pre_membar(order); + __asm__ __volatile__ ( - /* fence */ - strasm_sync /* simple guard */ " lwz %[old_value], 0(%[dest]) \n" " cmpw %[compare_value], %[old_value] \n" @@ -379,8 +397,6 @@ inline jint Atomic::cmpxchg(jint exchange_value, volatile jint* dest, jint compa " bne- 2f \n" " stwcx. %[exchange_value], %[dest], %[zero] \n" " bne- 1b \n" - /* acquire */ - strasm_sync /* exit */ "2: \n" /* out */ @@ -397,21 +413,23 @@ inline jint Atomic::cmpxchg(jint exchange_value, volatile jint* dest, jint compa "memory" ); + cmpxchg_post_membar(order); + return (jint) old_value; } -inline jlong Atomic::cmpxchg(jlong exchange_value, volatile jlong* dest, jlong compare_value) { +inline jlong Atomic::cmpxchg(jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order) { // Note that cmpxchg guarantees a two-way memory barrier across - // the cmpxchg, so it's really a a 'fence_cmpxchg_acquire' - // (see atomic.hpp). + // the cmpxchg, so it's really a a 'fence_cmpxchg_fence' if not + // specified otherwise (see atomic.hpp). long old_value; const uint64_t zero = 0; + cmpxchg_pre_membar(order); + __asm__ __volatile__ ( - /* fence */ - strasm_sync /* simple guard */ " ld %[old_value], 0(%[dest]) \n" " cmpd %[compare_value], %[old_value] \n" @@ -423,8 +441,6 @@ inline jlong Atomic::cmpxchg(jlong exchange_value, volatile jlong* dest, jlong c " bne- 2f \n" " stdcx. %[exchange_value], %[dest], %[zero] \n" " bne- 1b \n" - /* acquire */ - strasm_sync /* exit */ "2: \n" /* out */ @@ -441,15 +457,17 @@ inline jlong Atomic::cmpxchg(jlong exchange_value, volatile jlong* dest, jlong c "memory" ); + cmpxchg_post_membar(order); + return (jlong) old_value; } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) { - return (intptr_t)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value); +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { + return (intptr_t)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value, order); } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) { - return (void*)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value); +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { + return (void*)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value, order); } #undef strasm_sync diff --git a/hotspot/src/os_cpu/bsd_x86/vm/atomic_bsd_x86.inline.hpp b/hotspot/src/os_cpu/bsd_x86/vm/atomic_bsd_x86.inline.hpp index 9108476c2d5..8310003a8f1 100644 --- a/hotspot/src/os_cpu/bsd_x86/vm/atomic_bsd_x86.inline.hpp +++ b/hotspot/src/os_cpu/bsd_x86/vm/atomic_bsd_x86.inline.hpp @@ -89,7 +89,7 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* des } #define VM_HAS_SPECIALIZED_CMPXCHG_BYTE -inline jbyte Atomic::cmpxchg (jbyte exchange_value, volatile jbyte* dest, jbyte compare_value) { +inline jbyte Atomic::cmpxchg (jbyte exchange_value, volatile jbyte* dest, jbyte compare_value, cmpxchg_memory_order order) { int mp = os::is_MP(); __asm__ volatile (LOCK_IF_MP(%4) "cmpxchgb %1,(%3)" : "=a" (exchange_value) @@ -98,7 +98,7 @@ inline jbyte Atomic::cmpxchg (jbyte exchange_value, volatile jbyte* return exchange_value; } -inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value) { +inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value, cmpxchg_memory_order order) { int mp = os::is_MP(); __asm__ volatile (LOCK_IF_MP(%4) "cmpxchgl %1,(%3)" : "=a" (exchange_value) @@ -149,7 +149,7 @@ inline intptr_t Atomic::xchg_ptr(intptr_t exchange_value, volatile intptr_t* des return exchange_value; } -inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value) { +inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order) { bool mp = os::is_MP(); __asm__ __volatile__ (LOCK_IF_MP(%4) "cmpxchgq %1,(%3)" : "=a" (exchange_value) @@ -158,12 +158,12 @@ inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* return exchange_value; } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) { - return (intptr_t)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value); +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { + return (intptr_t)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value, order); } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) { - return (void*)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value); +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { + return (void*)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value, order); } inline jlong Atomic::load(volatile jlong* src) { return *src; } @@ -197,16 +197,16 @@ extern "C" { void _Atomic_move_long(volatile jlong* src, volatile jlong* dst); } -inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value) { +inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order) { return _Atomic_cmpxchg_long(exchange_value, dest, compare_value, os::is_MP()); } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) { - return (intptr_t)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value); +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { + return (intptr_t)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value, order); } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) { - return (void*)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value); +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { + return (void*)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value, order); } inline jlong Atomic::load(volatile jlong* src) { diff --git a/hotspot/src/os_cpu/bsd_zero/vm/atomic_bsd_zero.inline.hpp b/hotspot/src/os_cpu/bsd_zero/vm/atomic_bsd_zero.inline.hpp index 4e7e702ad66..4490e49020c 100644 --- a/hotspot/src/os_cpu/bsd_zero/vm/atomic_bsd_zero.inline.hpp +++ b/hotspot/src/os_cpu/bsd_zero/vm/atomic_bsd_zero.inline.hpp @@ -270,7 +270,8 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* dest) { inline jint Atomic::cmpxchg(jint exchange_value, volatile jint* dest, - jint compare_value) { + jint compare_value, + cmpxchg_memory_order order) { #ifdef ARM return arm_compare_and_swap(dest, compare_value, exchange_value); #else @@ -284,14 +285,16 @@ inline jint Atomic::cmpxchg(jint exchange_value, inline jlong Atomic::cmpxchg(jlong exchange_value, volatile jlong* dest, - jlong compare_value) { + jlong compare_value, + cmpxchg_memory_order order) { return __sync_val_compare_and_swap(dest, compare_value, exchange_value); } inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, - intptr_t compare_value) { + intptr_t compare_value, + cmpxchg_memory_order order) { #ifdef ARM return arm_compare_and_swap(dest, compare_value, exchange_value); #else @@ -305,11 +308,13 @@ inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, - void* compare_value) { + void* compare_value, + cmpxchg_memory_order order) { return (void *) cmpxchg_ptr((intptr_t) exchange_value, (volatile intptr_t*) dest, - (intptr_t) compare_value); + (intptr_t) compare_value, + order); } inline jlong Atomic::load(volatile jlong* src) { diff --git a/hotspot/src/os_cpu/linux_aarch64/vm/atomic_linux_aarch64.inline.hpp b/hotspot/src/os_cpu/linux_aarch64/vm/atomic_linux_aarch64.inline.hpp index d47e6cc82ac..95d007fc21b 100644 --- a/hotspot/src/os_cpu/linux_aarch64/vm/atomic_linux_aarch64.inline.hpp +++ b/hotspot/src/os_cpu/linux_aarch64/vm/atomic_linux_aarch64.inline.hpp @@ -87,10 +87,28 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* dest) (volatile intptr_t*) dest); } - -inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value) +template T generic_cmpxchg(T exchange_value, volatile T* dest, + T compare_value, cmpxchg_memory_order order) { - return __sync_val_compare_and_swap(dest, compare_value, exchange_value); + if (order == memory_order_relaxed) { + T value = compare_value; + __atomic_compare_exchange(dest, &value, &exchange_value, /*weak*/false, + __ATOMIC_RELAXED, __ATOMIC_RELAXED); + return value; + } else { + return __sync_val_compare_and_swap(dest, compare_value, exchange_value); + } +} + +#define VM_HAS_SPECIALIZED_CMPXCHG_BYTE +inline jbyte Atomic::cmpxchg (jbyte exchange_value, volatile jbyte* dest, jbyte compare_value, cmpxchg_memory_order order) +{ + return generic_cmpxchg(exchange_value, dest, compare_value, order); +} + +inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value, cmpxchg_memory_order order) +{ + return generic_cmpxchg(exchange_value, dest, compare_value, order); } inline void Atomic::store (jlong store_value, jlong* dest) { *dest = store_value; } @@ -123,21 +141,22 @@ inline intptr_t Atomic::xchg_ptr(intptr_t exchange_value, volatile intptr_t* des return res; } -inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value) +inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order) { - return __sync_val_compare_and_swap(dest, compare_value, exchange_value); + return generic_cmpxchg(exchange_value, dest, compare_value, order); } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { - return __sync_val_compare_and_swap(dest, compare_value, exchange_value); + return generic_cmpxchg(exchange_value, dest, compare_value, order); } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { return (void *) cmpxchg_ptr((intptr_t) exchange_value, (volatile intptr_t*) dest, - (intptr_t) compare_value); + (intptr_t) compare_value, + order); } inline jlong Atomic::load(volatile jlong* src) { return *src; } diff --git a/hotspot/src/os_cpu/linux_ppc/vm/atomic_linux_ppc.inline.hpp b/hotspot/src/os_cpu/linux_ppc/vm/atomic_linux_ppc.inline.hpp index c40ce1fbe4e..6c8498c4508 100644 --- a/hotspot/src/os_cpu/linux_ppc/vm/atomic_linux_ppc.inline.hpp +++ b/hotspot/src/os_cpu/linux_ppc/vm/atomic_linux_ppc.inline.hpp @@ -291,12 +291,30 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* dest) { return (void*)xchg_ptr((intptr_t)exchange_value, (volatile intptr_t*)dest); } +inline void cmpxchg_pre_membar(cmpxchg_memory_order order) { + if (order != memory_order_relaxed) { + __asm__ __volatile__ ( + /* fence */ + strasm_sync + ); + } +} + +inline void cmpxchg_post_membar(cmpxchg_memory_order order) { + if (order != memory_order_relaxed) { + __asm__ __volatile__ ( + /* fence */ + strasm_sync + ); + } +} + #define VM_HAS_SPECIALIZED_CMPXCHG_BYTE -inline jbyte Atomic::cmpxchg(jbyte exchange_value, volatile jbyte* dest, jbyte compare_value) { +inline jbyte Atomic::cmpxchg(jbyte exchange_value, volatile jbyte* dest, jbyte compare_value, cmpxchg_memory_order order) { // Note that cmpxchg guarantees a two-way memory barrier across - // the cmpxchg, so it's really a a 'fence_cmpxchg_acquire' - // (see atomic.hpp). + // the cmpxchg, so it's really a a 'fence_cmpxchg_fence' if not + // specified otherwise (see atomic.hpp). // Using 32 bit internally. volatile int *dest_base = (volatile int*)((uintptr_t)dest & ~3); @@ -312,9 +330,9 @@ inline jbyte Atomic::cmpxchg(jbyte exchange_value, volatile jbyte* dest, jbyte c unsigned int old_value, value32; + cmpxchg_pre_membar(order); + __asm__ __volatile__ ( - /* fence */ - strasm_sync /* simple guard */ " lbz %[old_value], 0(%[dest]) \n" " cmpw %[masked_compare_val], %[old_value] \n" @@ -331,8 +349,6 @@ inline jbyte Atomic::cmpxchg(jbyte exchange_value, volatile jbyte* dest, jbyte c " xor %[value32], %[xor_value], %[value32] \n" " stwcx. %[value32], 0, %[dest_base] \n" " bne- 1b \n" - /* acquire */ - strasm_sync /* exit */ "2: \n" /* out */ @@ -353,21 +369,23 @@ inline jbyte Atomic::cmpxchg(jbyte exchange_value, volatile jbyte* dest, jbyte c "memory" ); + cmpxchg_post_membar(order); + return (jbyte)(unsigned char)old_value; } -inline jint Atomic::cmpxchg(jint exchange_value, volatile jint* dest, jint compare_value) { +inline jint Atomic::cmpxchg(jint exchange_value, volatile jint* dest, jint compare_value, cmpxchg_memory_order order) { // Note that cmpxchg guarantees a two-way memory barrier across - // the cmpxchg, so it's really a a 'fence_cmpxchg_acquire' - // (see atomic.hpp). + // the cmpxchg, so it's really a a 'fence_cmpxchg_fence' if not + // specified otherwise (see atomic.hpp). unsigned int old_value; const uint64_t zero = 0; + cmpxchg_pre_membar(order); + __asm__ __volatile__ ( - /* fence */ - strasm_sync /* simple guard */ " lwz %[old_value], 0(%[dest]) \n" " cmpw %[compare_value], %[old_value] \n" @@ -379,8 +397,6 @@ inline jint Atomic::cmpxchg(jint exchange_value, volatile jint* dest, jint compa " bne- 2f \n" " stwcx. %[exchange_value], %[dest], %[zero] \n" " bne- 1b \n" - /* acquire */ - strasm_sync /* exit */ "2: \n" /* out */ @@ -397,21 +413,23 @@ inline jint Atomic::cmpxchg(jint exchange_value, volatile jint* dest, jint compa "memory" ); + cmpxchg_post_membar(order); + return (jint) old_value; } -inline jlong Atomic::cmpxchg(jlong exchange_value, volatile jlong* dest, jlong compare_value) { +inline jlong Atomic::cmpxchg(jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order) { // Note that cmpxchg guarantees a two-way memory barrier across - // the cmpxchg, so it's really a a 'fence_cmpxchg_acquire' - // (see atomic.hpp). + // the cmpxchg, so it's really a a 'fence_cmpxchg_fence' if not + // specified otherwise (see atomic.hpp). long old_value; const uint64_t zero = 0; + cmpxchg_pre_membar(order); + __asm__ __volatile__ ( - /* fence */ - strasm_sync /* simple guard */ " ld %[old_value], 0(%[dest]) \n" " cmpd %[compare_value], %[old_value] \n" @@ -423,8 +441,6 @@ inline jlong Atomic::cmpxchg(jlong exchange_value, volatile jlong* dest, jlong c " bne- 2f \n" " stdcx. %[exchange_value], %[dest], %[zero] \n" " bne- 1b \n" - /* acquire */ - strasm_sync /* exit */ "2: \n" /* out */ @@ -441,15 +457,17 @@ inline jlong Atomic::cmpxchg(jlong exchange_value, volatile jlong* dest, jlong c "memory" ); + cmpxchg_post_membar(order); + return (jlong) old_value; } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) { - return (intptr_t)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value); +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { + return (intptr_t)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value, order); } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) { - return (void*)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value); +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { + return (void*)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value, order); } #undef strasm_sync diff --git a/hotspot/src/os_cpu/linux_sparc/vm/atomic_linux_sparc.inline.hpp b/hotspot/src/os_cpu/linux_sparc/vm/atomic_linux_sparc.inline.hpp index 29b51d70f7f..b0df28daea3 100644 --- a/hotspot/src/os_cpu/linux_sparc/vm/atomic_linux_sparc.inline.hpp +++ b/hotspot/src/os_cpu/linux_sparc/vm/atomic_linux_sparc.inline.hpp @@ -148,7 +148,7 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* des } -inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value) { +inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value, cmpxchg_memory_order order) { jint rv; __asm__ volatile( " cas [%2], %3, %0" @@ -158,7 +158,7 @@ inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* return rv; } -inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value) { +inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order) { #ifdef _LP64 jlong rv; __asm__ volatile( @@ -190,7 +190,7 @@ inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* #endif } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) { +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { intptr_t rv; #ifdef _LP64 __asm__ volatile( @@ -208,8 +208,8 @@ inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* return rv; } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) { - return (void*)cmpxchg_ptr((intptr_t)exchange_value, (volatile intptr_t*)dest, (intptr_t)compare_value); +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { + return (void*)cmpxchg_ptr((intptr_t)exchange_value, (volatile intptr_t*)dest, (intptr_t)compare_value, order); } #endif // OS_CPU_LINUX_SPARC_VM_ATOMIC_LINUX_SPARC_INLINE_HPP diff --git a/hotspot/src/os_cpu/linux_x86/vm/atomic_linux_x86.inline.hpp b/hotspot/src/os_cpu/linux_x86/vm/atomic_linux_x86.inline.hpp index 03fa9bcf840..faf0a8043f7 100644 --- a/hotspot/src/os_cpu/linux_x86/vm/atomic_linux_x86.inline.hpp +++ b/hotspot/src/os_cpu/linux_x86/vm/atomic_linux_x86.inline.hpp @@ -89,7 +89,7 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* des } #define VM_HAS_SPECIALIZED_CMPXCHG_BYTE -inline jbyte Atomic::cmpxchg (jbyte exchange_value, volatile jbyte* dest, jbyte compare_value) { +inline jbyte Atomic::cmpxchg (jbyte exchange_value, volatile jbyte* dest, jbyte compare_value, cmpxchg_memory_order order) { int mp = os::is_MP(); __asm__ volatile (LOCK_IF_MP(%4) "cmpxchgb %1,(%3)" : "=a" (exchange_value) @@ -98,7 +98,7 @@ inline jbyte Atomic::cmpxchg (jbyte exchange_value, volatile jbyte* return exchange_value; } -inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value) { +inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value, cmpxchg_memory_order order) { int mp = os::is_MP(); __asm__ volatile (LOCK_IF_MP(%4) "cmpxchgl %1,(%3)" : "=a" (exchange_value) @@ -149,7 +149,7 @@ inline intptr_t Atomic::xchg_ptr(intptr_t exchange_value, volatile intptr_t* des return exchange_value; } -inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value) { +inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order) { bool mp = os::is_MP(); __asm__ __volatile__ (LOCK_IF_MP(%4) "cmpxchgq %1,(%3)" : "=a" (exchange_value) @@ -158,12 +158,12 @@ inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* return exchange_value; } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) { - return (intptr_t)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value); +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { + return (intptr_t)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value, order); } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) { - return (void*)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value); +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { + return (void*)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value, order); } inline jlong Atomic::load(volatile jlong* src) { return *src; } @@ -197,16 +197,16 @@ extern "C" { void _Atomic_move_long(volatile jlong* src, volatile jlong* dst); } -inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value) { +inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order) { return _Atomic_cmpxchg_long(exchange_value, dest, compare_value, os::is_MP()); } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) { - return (intptr_t)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value); +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { + return (intptr_t)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value, order); } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) { - return (void*)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value); +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { + return (void*)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value, order); } inline jlong Atomic::load(volatile jlong* src) { diff --git a/hotspot/src/os_cpu/linux_zero/vm/atomic_linux_zero.inline.hpp b/hotspot/src/os_cpu/linux_zero/vm/atomic_linux_zero.inline.hpp index 266c950422b..4a9b2c05da9 100644 --- a/hotspot/src/os_cpu/linux_zero/vm/atomic_linux_zero.inline.hpp +++ b/hotspot/src/os_cpu/linux_zero/vm/atomic_linux_zero.inline.hpp @@ -264,7 +264,8 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* dest) { inline jint Atomic::cmpxchg(jint exchange_value, volatile jint* dest, - jint compare_value) { + jint compare_value, + cmpxchg_memory_order order) { #ifdef ARM return arm_compare_and_swap(dest, compare_value, exchange_value); #else @@ -278,14 +279,16 @@ inline jint Atomic::cmpxchg(jint exchange_value, inline jlong Atomic::cmpxchg(jlong exchange_value, volatile jlong* dest, - jlong compare_value) { + jlong compare_value, + cmpxchg_memory_order order) { return __sync_val_compare_and_swap(dest, compare_value, exchange_value); } inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, - intptr_t compare_value) { + intptr_t compare_value, + cmpxchg_memory_order order) { #ifdef ARM return arm_compare_and_swap(dest, compare_value, exchange_value); #else @@ -299,11 +302,13 @@ inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, - void* compare_value) { + void* compare_value, + cmpxchg_memory_order order) { return (void *) cmpxchg_ptr((intptr_t) exchange_value, (volatile intptr_t*) dest, - (intptr_t) compare_value); + (intptr_t) compare_value, + order); } inline jlong Atomic::load(volatile jlong* src) { diff --git a/hotspot/src/os_cpu/solaris_sparc/vm/atomic_solaris_sparc.inline.hpp b/hotspot/src/os_cpu/solaris_sparc/vm/atomic_solaris_sparc.inline.hpp index 83a07ce3fe5..03c4326073a 100644 --- a/hotspot/src/os_cpu/solaris_sparc/vm/atomic_solaris_sparc.inline.hpp +++ b/hotspot/src/os_cpu/solaris_sparc/vm/atomic_solaris_sparc.inline.hpp @@ -177,7 +177,7 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* des } -inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value) { +inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value, cmpxchg_memory_order order) { jint rv; __asm__ volatile( " cas [%2], %3, %0" @@ -187,7 +187,7 @@ inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* return rv; } -inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value) { +inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order) { #ifdef _LP64 jlong rv; __asm__ volatile( @@ -219,7 +219,7 @@ inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* #endif //_LP64 } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) { +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { intptr_t rv; #ifdef _LP64 __asm__ volatile( @@ -237,8 +237,8 @@ inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* return rv; } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) { - return (void*)cmpxchg_ptr((intptr_t)exchange_value, (volatile intptr_t*)dest, (intptr_t)compare_value); +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { + return (void*)cmpxchg_ptr((intptr_t)exchange_value, (volatile intptr_t*)dest, (intptr_t)compare_value, order); } #else // _GNU_SOURCE @@ -296,11 +296,11 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* des } -inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value) { +inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value, cmpxchg_memory_order order) { return _Atomic_cas32(exchange_value, dest, compare_value); } -inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value) { +inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order) { #ifdef _LP64 // Return 64 bit value in %o0 return _Atomic_cas64((intptr_t)exchange_value, (intptr_t *)dest, (intptr_t)compare_value); @@ -310,7 +310,7 @@ inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* #endif // _LP64 } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) { +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { #ifdef _LP64 return _Atomic_cas64(exchange_value, dest, compare_value); #else // _LP64 @@ -318,8 +318,8 @@ inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* #endif // _LP64 } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) { - return (void*)cmpxchg_ptr((intptr_t)exchange_value, (volatile intptr_t*)dest, (intptr_t)compare_value); +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { + return (void*)cmpxchg_ptr((intptr_t)exchange_value, (volatile intptr_t*)dest, (intptr_t)compare_value, order); } @@ -354,20 +354,20 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* des } -inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value) { +inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value, cmpxchg_memory_order order) { return (*os::atomic_cmpxchg_func)(exchange_value, dest, compare_value); } -inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value) { +inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order) { return (*os::atomic_cmpxchg_long_func)(exchange_value, dest, compare_value); } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) { - return (intptr_t)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value); +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { + return (intptr_t)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value, order); } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) { - return (void*)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value); +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { + return (void*)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value, order); } #endif // _LP64 || COMPILER2 diff --git a/hotspot/src/os_cpu/solaris_x86/vm/atomic_solaris_x86.inline.hpp b/hotspot/src/os_cpu/solaris_x86/vm/atomic_solaris_x86.inline.hpp index f8b47f56495..e856b755cf2 100644 --- a/hotspot/src/os_cpu/solaris_x86/vm/atomic_solaris_x86.inline.hpp +++ b/hotspot/src/os_cpu/solaris_x86/vm/atomic_solaris_x86.inline.hpp @@ -85,15 +85,15 @@ inline jint Atomic::xchg (jint exchange_value, volatile jint* } #define VM_HAS_SPECIALIZED_CMPXCHG_BYTE -inline jbyte Atomic::cmpxchg (jbyte exchange_value, volatile jbyte* dest, jbyte compare_value) { +inline jbyte Atomic::cmpxchg (jbyte exchange_value, volatile jbyte* dest, jbyte compare_value, cmpxchg_memory_order order) { return _Atomic_cmpxchg_byte(exchange_value, dest, compare_value IS_MP_ARG()); } -inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value) { +inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value, cmpxchg_memory_order order) { return _Atomic_cmpxchg(exchange_value, dest, compare_value IS_MP_ARG()); } -inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value) { +inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order) { return _Atomic_cmpxchg_long(exchange_value, dest, compare_value IS_MP_ARG()); } @@ -120,11 +120,11 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* des return (void*)_Atomic_xchg_long((jlong)exchange_value, (volatile jlong*)dest); } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) { +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { return (intptr_t)_Atomic_cmpxchg_long((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value); } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) { +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { return (void*)_Atomic_cmpxchg_long((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value); } @@ -148,12 +148,12 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* des return (void*)xchg((jint)exchange_value, (volatile jint*)dest); } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) { - return (intptr_t)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value); +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { + return (intptr_t)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value, order); } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) { - return (void*)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value); +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { + return (void*)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value, order); } extern "C" void _Atomic_move_long(volatile jlong* src, volatile jlong* dst); diff --git a/hotspot/src/os_cpu/windows_x86/vm/atomic_windows_x86.inline.hpp b/hotspot/src/os_cpu/windows_x86/vm/atomic_windows_x86.inline.hpp index d8c5f70870c..3d7662e5cd7 100644 --- a/hotspot/src/os_cpu/windows_x86/vm/atomic_windows_x86.inline.hpp +++ b/hotspot/src/os_cpu/windows_x86/vm/atomic_windows_x86.inline.hpp @@ -119,25 +119,25 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* des return (void *)(os::atomic_xchg_ptr_func)((intptr_t)exchange_value, (volatile intptr_t*)dest); } -inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value) { +inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value, cmpxchg_memory_order order) { return (*os::atomic_cmpxchg_func)(exchange_value, dest, compare_value); } #define VM_HAS_SPECIALIZED_CMPXCHG_BYTE -inline jbyte Atomic::cmpxchg (jbyte exchange_value, volatile jbyte* dest, jbyte compare_value) { +inline jbyte Atomic::cmpxchg (jbyte exchange_value, volatile jbyte* dest, jbyte compare_value, cmpxchg_memory_order order) { return (*os::atomic_cmpxchg_byte_func)(exchange_value, dest, compare_value); } -inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value) { +inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order) { return (*os::atomic_cmpxchg_long_func)(exchange_value, dest, compare_value); } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) { - return (intptr_t)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value); +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { + return (intptr_t)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value, order); } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) { - return (void*)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value); +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { + return (void*)cmpxchg((jlong)exchange_value, (volatile jlong*)dest, (jlong)compare_value, order); } inline jlong Atomic::load(volatile jlong* src) { return *src; } @@ -218,7 +218,7 @@ inline void* Atomic::xchg_ptr(void* exchange_value, volatile void* des } #define VM_HAS_SPECIALIZED_CMPXCHG_BYTE -inline jbyte Atomic::cmpxchg (jbyte exchange_value, volatile jbyte* dest, jbyte compare_value) { +inline jbyte Atomic::cmpxchg (jbyte exchange_value, volatile jbyte* dest, jbyte compare_value, cmpxchg_memory_order order) { // alternative for InterlockedCompareExchange int mp = os::is_MP(); __asm { @@ -230,7 +230,7 @@ inline jbyte Atomic::cmpxchg (jbyte exchange_value, volatile jbyte* } } -inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value) { +inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value, cmpxchg_memory_order order) { // alternative for InterlockedCompareExchange int mp = os::is_MP(); __asm { @@ -242,7 +242,7 @@ inline jint Atomic::cmpxchg (jint exchange_value, volatile jint* } } -inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value) { +inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order) { int mp = os::is_MP(); jint ex_lo = (jint)exchange_value; jint ex_hi = *( ((jint*)&exchange_value) + 1 ); @@ -263,12 +263,12 @@ inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong* } } -inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value) { - return (intptr_t)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value); +inline intptr_t Atomic::cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order) { + return (intptr_t)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value, order); } -inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value) { - return (void*)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value); +inline void* Atomic::cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order) { + return (void*)cmpxchg((jint)exchange_value, (volatile jint*)dest, (jint)compare_value, order); } inline jlong Atomic::load(volatile jlong* src) { diff --git a/hotspot/src/share/vm/adlc/formssel.cpp b/hotspot/src/share/vm/adlc/formssel.cpp index aaef59a9441..42aefeb2575 100644 --- a/hotspot/src/share/vm/adlc/formssel.cpp +++ b/hotspot/src/share/vm/adlc/formssel.cpp @@ -1246,8 +1246,7 @@ bool InstructForm::check_branch_variant(ArchDesc &AD, InstructForm *short_branch !is_short_branch() && // Don't match another short branch variant reduce_result() != NULL && strcmp(reduce_result(), short_branch->reduce_result()) == 0 && - _matrule->equivalent(AD.globalNames(), short_branch->_matrule) && - equivalent_predicates(this, short_branch)) { + _matrule->equivalent(AD.globalNames(), short_branch->_matrule)) { // The instructions are equivalent. // Now verify that both instructions have the same parameters and @@ -3491,13 +3490,13 @@ int MatchNode::needs_ideal_memory_edge(FormDict &globals) const { "LoadRange", "LoadKlass", "LoadNKlass", "LoadL_unaligned", "LoadD_unaligned", "LoadPLocked", "StorePConditional", "StoreIConditional", "StoreLConditional", - "CompareAndSwapI", "CompareAndSwapL", "CompareAndSwapP", "CompareAndSwapN", - "WeakCompareAndSwapI", "WeakCompareAndSwapL", "WeakCompareAndSwapP", "WeakCompareAndSwapN", - "CompareAndExchangeI", "CompareAndExchangeL", "CompareAndExchangeP", "CompareAndExchangeN", + "CompareAndSwapB", "CompareAndSwapS", "CompareAndSwapI", "CompareAndSwapL", "CompareAndSwapP", "CompareAndSwapN", + "WeakCompareAndSwapB", "WeakCompareAndSwapS", "WeakCompareAndSwapI", "WeakCompareAndSwapL", "WeakCompareAndSwapP", "WeakCompareAndSwapN", + "CompareAndExchangeB", "CompareAndExchangeS", "CompareAndExchangeI", "CompareAndExchangeL", "CompareAndExchangeP", "CompareAndExchangeN", "StoreCM", "ClearArray", - "GetAndAddI", "GetAndSetI", "GetAndSetP", - "GetAndAddL", "GetAndSetL", "GetAndSetN", + "GetAndSetB", "GetAndSetS", "GetAndAddI", "GetAndSetI", "GetAndSetP", + "GetAndAddB", "GetAndAddS", "GetAndAddL", "GetAndSetL", "GetAndSetN", }; int cnt = sizeof(needs_ideal_memory_list)/sizeof(char*); if( strcmp(_opType,"PrefetchAllocation")==0 ) diff --git a/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp b/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp index 0c06df4751c..7120e76c874 100644 --- a/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp +++ b/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp @@ -1600,7 +1600,7 @@ void GraphBuilder::access_field(Bytecodes::Code code) { ValueType* type = as_ValueType(field_type); // call will_link again to determine if the field is valid. const bool needs_patching = !holder->is_loaded() || - !field->will_link(method()->holder(), code) || + !field->will_link(method(), code) || PatchALot; ValueStack* state_before = NULL; diff --git a/hotspot/src/share/vm/c1/c1_Runtime1.cpp b/hotspot/src/share/vm/c1/c1_Runtime1.cpp index be57ef53e78..3ee774ec00f 100644 --- a/hotspot/src/share/vm/c1/c1_Runtime1.cpp +++ b/hotspot/src/share/vm/c1/c1_Runtime1.cpp @@ -759,10 +759,10 @@ static Klass* resolve_field_return_klass(methodHandle caller, int bci, TRAPS) { // This can be static or non-static field access Bytecodes::Code code = field_access.code(); - // We must load class, initialize class and resolvethe field + // We must load class, initialize class and resolve the field fieldDescriptor result; // initialize class if needed constantPoolHandle constants(THREAD, caller->constants()); - LinkResolver::resolve_field_access(result, constants, field_access.index(), Bytecodes::java_code(code), CHECK_NULL); + LinkResolver::resolve_field_access(result, constants, field_access.index(), caller, Bytecodes::java_code(code), CHECK_NULL); return result.field_holder(); } @@ -879,7 +879,7 @@ JRT_ENTRY(void, Runtime1::patch_code(JavaThread* thread, Runtime1::StubID stub_i fieldDescriptor result; // initialize class if needed Bytecodes::Code code = field_access.code(); constantPoolHandle constants(THREAD, caller_method->constants()); - LinkResolver::resolve_field_access(result, constants, field_access.index(), Bytecodes::java_code(code), CHECK); + LinkResolver::resolve_field_access(result, constants, field_access.index(), caller_method, Bytecodes::java_code(code), CHECK); patch_field_offset = result.offset(); // If we're patching a field which is volatile then at compile it diff --git a/hotspot/src/share/vm/ci/ciField.cpp b/hotspot/src/share/vm/ci/ciField.cpp index 4d37c923ffe..e066be87191 100644 --- a/hotspot/src/share/vm/ci/ciField.cpp +++ b/hotspot/src/share/vm/ci/ciField.cpp @@ -66,7 +66,8 @@ // ------------------------------------------------------------------ // ciField::ciField -ciField::ciField(ciInstanceKlass* klass, int index): _known_to_link_with_put(NULL), _known_to_link_with_get(NULL) { +ciField::ciField(ciInstanceKlass* klass, int index) : + _known_to_link_with_put(NULL), _known_to_link_with_get(NULL) { ASSERT_IN_VM; CompilerThread *thread = CompilerThread::current(); @@ -173,7 +174,8 @@ ciField::ciField(ciInstanceKlass* klass, int index): _known_to_link_with_put(NUL initialize_from(&field_desc); } -ciField::ciField(fieldDescriptor *fd): _known_to_link_with_put(NULL), _known_to_link_with_get(NULL) { +ciField::ciField(fieldDescriptor *fd) : + _known_to_link_with_put(NULL), _known_to_link_with_get(NULL) { ASSERT_IN_VM; // Get the field's name, signature, and type. @@ -237,7 +239,7 @@ void ciField::initialize_from(fieldDescriptor* fd) { // Check to see if the field is constant. Klass* k = _holder->get_Klass(); bool is_stable_field = FoldStableValues && is_stable(); - if (is_final() || is_stable_field) { + if ((is_final() && !has_initialized_final_update()) || is_stable_field) { if (is_static()) { // This field just may be constant. The only case where it will // not be constant is when the field is a *special* static & final field @@ -265,6 +267,7 @@ void ciField::initialize_from(fieldDescriptor* fd) { assert(SystemDictionary::CallSite_klass() != NULL, "should be already initialized"); if (k == SystemDictionary::CallSite_klass() && _offset == java_lang_invoke_CallSite::target_offset_in_bytes()) { + assert(!has_initialized_final_update(), "CallSite is not supposed to have writes to final fields outside initializers"); _is_constant = true; } else { // Non-final & non-stable fields are not constants. @@ -340,7 +343,7 @@ ciType* ciField::compute_type_impl() { // // Can a specific access to this field be made without causing // link errors? -bool ciField::will_link(ciInstanceKlass* accessing_klass, +bool ciField::will_link(ciMethod* accessing_method, Bytecodes::Code bc) { VM_ENTRY_MARK; assert(bc == Bytecodes::_getstatic || bc == Bytecodes::_putstatic || @@ -363,27 +366,27 @@ bool ciField::will_link(ciInstanceKlass* accessing_klass, // Get and put can have different accessibility rules bool is_put = (bc == Bytecodes::_putfield || bc == Bytecodes::_putstatic); if (is_put) { - if (_known_to_link_with_put == accessing_klass) { + if (_known_to_link_with_put == accessing_method) { return true; } } else { - if (_known_to_link_with_get == accessing_klass) { + if (_known_to_link_with_get == accessing_method->holder()) { return true; } } LinkInfo link_info(_holder->get_instanceKlass(), _name->get_symbol(), _signature->get_symbol(), - accessing_klass->get_Klass()); + accessing_method->get_Method()); fieldDescriptor result; LinkResolver::resolve_field(result, link_info, bc, false, KILL_COMPILE_ON_FATAL_(false)); // update the hit-cache, unless there is a problem with memory scoping: - if (accessing_klass->is_shared() || !is_shared()) { + if (accessing_method->holder()->is_shared() || !is_shared()) { if (is_put) { - _known_to_link_with_put = accessing_klass; + _known_to_link_with_put = accessing_method; } else { - _known_to_link_with_get = accessing_klass; + _known_to_link_with_get = accessing_method->holder(); } } diff --git a/hotspot/src/share/vm/ci/ciField.hpp b/hotspot/src/share/vm/ci/ciField.hpp index f30e7144e12..4ff3209d50a 100644 --- a/hotspot/src/share/vm/ci/ciField.hpp +++ b/hotspot/src/share/vm/ci/ciField.hpp @@ -48,7 +48,7 @@ private: ciType* _type; int _offset; bool _is_constant; - ciInstanceKlass* _known_to_link_with_put; + ciMethod* _known_to_link_with_put; ciInstanceKlass* _known_to_link_with_get; ciConstant _constant_value; @@ -131,8 +131,12 @@ public: // non-constant fields. These are java.lang.System.in // and java.lang.System.out. Abomination. // - // A field is also considered constant if it is marked @Stable - // and is non-null (or non-zero, if a primitive). + // A field is also considered constant if + // - it is marked @Stable and is non-null (or non-zero, if a primitive) or + // - it is trusted or + // - it is the target field of a CallSite object. + // + // See ciField::initialize_from() for more details. // // A user should also check the field value (constant_value().is_valid()), since // constant fields of non-initialized classes don't have values yet. @@ -150,25 +154,28 @@ public: ciConstant constant_value_of(ciObject* object); // Check for link time errors. Accessing a field from a - // certain class via a certain bytecode may or may not be legal. + // certain method via a certain bytecode may or may not be legal. // This call checks to see if an exception may be raised by // an access of this field. // // Usage note: if the same field is accessed multiple times // in the same compilation, will_link will need to be checked // at each point of access. - bool will_link(ciInstanceKlass* accessing_klass, + bool will_link(ciMethod* accessing_method, Bytecodes::Code bc); // Java access flags - bool is_public () const { return flags().is_public(); } - bool is_private () const { return flags().is_private(); } - bool is_protected () const { return flags().is_protected(); } - bool is_static () const { return flags().is_static(); } - bool is_final () const { return flags().is_final(); } - bool is_stable () const { return flags().is_stable(); } - bool is_volatile () const { return flags().is_volatile(); } - bool is_transient () const { return flags().is_transient(); } + bool is_public () const { return flags().is_public(); } + bool is_private () const { return flags().is_private(); } + bool is_protected () const { return flags().is_protected(); } + bool is_static () const { return flags().is_static(); } + bool is_final () const { return flags().is_final(); } + bool is_stable () const { return flags().is_stable(); } + bool is_volatile () const { return flags().is_volatile(); } + bool is_transient () const { return flags().is_transient(); } + // The field is modified outside of instance initializer methods + // (or class/initializer methods if the field is static). + bool has_initialized_final_update() const { return flags().has_initialized_final_update(); } bool is_call_site_target() { ciInstanceKlass* callsite_klass = CURRENT_ENV->CallSite_klass(); diff --git a/hotspot/src/share/vm/ci/ciFlags.hpp b/hotspot/src/share/vm/ci/ciFlags.hpp index 783064253c1..52b2c6a0322 100644 --- a/hotspot/src/share/vm/ci/ciFlags.hpp +++ b/hotspot/src/share/vm/ci/ciFlags.hpp @@ -47,20 +47,25 @@ private: public: // Java access flags - bool is_public () const { return (_flags & JVM_ACC_PUBLIC ) != 0; } - bool is_private () const { return (_flags & JVM_ACC_PRIVATE ) != 0; } - bool is_protected () const { return (_flags & JVM_ACC_PROTECTED ) != 0; } - bool is_static () const { return (_flags & JVM_ACC_STATIC ) != 0; } - bool is_final () const { return (_flags & JVM_ACC_FINAL ) != 0; } - bool is_synchronized() const { return (_flags & JVM_ACC_SYNCHRONIZED) != 0; } - bool is_super () const { return (_flags & JVM_ACC_SUPER ) != 0; } - bool is_volatile () const { return (_flags & JVM_ACC_VOLATILE ) != 0; } - bool is_transient () const { return (_flags & JVM_ACC_TRANSIENT ) != 0; } - bool is_native () const { return (_flags & JVM_ACC_NATIVE ) != 0; } - bool is_interface () const { return (_flags & JVM_ACC_INTERFACE ) != 0; } - bool is_abstract () const { return (_flags & JVM_ACC_ABSTRACT ) != 0; } - bool is_strict () const { return (_flags & JVM_ACC_STRICT ) != 0; } - bool is_stable () const { return (_flags & JVM_ACC_FIELD_STABLE) != 0; } + bool is_public () const { return (_flags & JVM_ACC_PUBLIC ) != 0; } + bool is_private () const { return (_flags & JVM_ACC_PRIVATE ) != 0; } + bool is_protected () const { return (_flags & JVM_ACC_PROTECTED ) != 0; } + bool is_static () const { return (_flags & JVM_ACC_STATIC ) != 0; } + bool is_final () const { return (_flags & JVM_ACC_FINAL ) != 0; } + bool is_synchronized () const { return (_flags & JVM_ACC_SYNCHRONIZED ) != 0; } + bool is_super () const { return (_flags & JVM_ACC_SUPER ) != 0; } + bool is_volatile () const { return (_flags & JVM_ACC_VOLATILE ) != 0; } + bool is_transient () const { return (_flags & JVM_ACC_TRANSIENT ) != 0; } + bool is_native () const { return (_flags & JVM_ACC_NATIVE ) != 0; } + bool is_interface () const { return (_flags & JVM_ACC_INTERFACE ) != 0; } + bool is_abstract () const { return (_flags & JVM_ACC_ABSTRACT ) != 0; } + bool is_strict () const { return (_flags & JVM_ACC_STRICT ) != 0; } + bool is_stable () const { return (_flags & JVM_ACC_FIELD_STABLE ) != 0; } + // In case the current object represents a field, return true if + // the field is modified outside of instance initializer methods + // (or class/initializer methods if the field is static) and false + // otherwise. + bool has_initialized_final_update() const { return (_flags & JVM_ACC_FIELD_INITIALIZED_FINAL_UPDATE) != 0; }; // Conversion jint as_int() { return _flags; } diff --git a/hotspot/src/share/vm/ci/ciStreams.cpp b/hotspot/src/share/vm/ci/ciStreams.cpp index a4eaf473984..2edd0d39b8c 100644 --- a/hotspot/src/share/vm/ci/ciStreams.cpp +++ b/hotspot/src/share/vm/ci/ciStreams.cpp @@ -278,7 +278,7 @@ int ciBytecodeStream::get_field_index() { // or put_static, get the referenced field. ciField* ciBytecodeStream::get_field(bool& will_link) { ciField* f = CURRENT_ENV->get_field_by_index(_holder, get_field_index()); - will_link = f->will_link(_holder, _bc); + will_link = f->will_link(_method, _bc); return f; } diff --git a/hotspot/src/share/vm/classfile/javaClasses.cpp b/hotspot/src/share/vm/classfile/javaClasses.cpp index 4ea507532ea..9924eac1422 100644 --- a/hotspot/src/share/vm/classfile/javaClasses.cpp +++ b/hotspot/src/share/vm/classfile/javaClasses.cpp @@ -1377,7 +1377,6 @@ int java_lang_ThreadGroup::_groups_offset = 0; int java_lang_ThreadGroup::_maxPriority_offset = 0; int java_lang_ThreadGroup::_destroyed_offset = 0; int java_lang_ThreadGroup::_daemon_offset = 0; -int java_lang_ThreadGroup::_vmAllowSuspension_offset = 0; int java_lang_ThreadGroup::_nthreads_offset = 0; int java_lang_ThreadGroup::_ngroups_offset = 0; @@ -1435,11 +1434,6 @@ bool java_lang_ThreadGroup::is_daemon(oop java_thread_group) { return java_thread_group->bool_field(_daemon_offset) != 0; } -bool java_lang_ThreadGroup::is_vmAllowSuspension(oop java_thread_group) { - assert(java_thread_group->is_oop(), "thread group must be oop"); - return java_thread_group->bool_field(_vmAllowSuspension_offset) != 0; -} - void java_lang_ThreadGroup::compute_offsets() { assert(_parent_offset == 0, "offsets should be initialized only once"); @@ -1452,7 +1446,6 @@ void java_lang_ThreadGroup::compute_offsets() { compute_offset(_maxPriority_offset, k, vmSymbols::maxPriority_name(), vmSymbols::int_signature()); compute_offset(_destroyed_offset, k, vmSymbols::destroyed_name(), vmSymbols::bool_signature()); compute_offset(_daemon_offset, k, vmSymbols::daemon_name(), vmSymbols::bool_signature()); - compute_offset(_vmAllowSuspension_offset, k, vmSymbols::vmAllowSuspension_name(), vmSymbols::bool_signature()); compute_offset(_nthreads_offset, k, vmSymbols::nthreads_name(), vmSymbols::int_signature()); compute_offset(_ngroups_offset, k, vmSymbols::ngroups_name(), vmSymbols::int_signature()); } diff --git a/hotspot/src/share/vm/classfile/javaClasses.hpp b/hotspot/src/share/vm/classfile/javaClasses.hpp index d9113adc4e7..0d39a32a70d 100644 --- a/hotspot/src/share/vm/classfile/javaClasses.hpp +++ b/hotspot/src/share/vm/classfile/javaClasses.hpp @@ -413,7 +413,6 @@ class java_lang_ThreadGroup : AllStatic { static int _maxPriority_offset; static int _destroyed_offset; static int _daemon_offset; - static int _vmAllowSuspension_offset; static int _nthreads_offset; static int _ngroups_offset; @@ -439,8 +438,6 @@ class java_lang_ThreadGroup : AllStatic { static bool is_destroyed(oop java_thread_group); // Daemon static bool is_daemon(oop java_thread_group); - // vmAllowSuspension - static bool is_vmAllowSuspension(oop java_thread_group); // Debugging friend class JavaClasses; }; diff --git a/hotspot/src/share/vm/classfile/vmSymbols.hpp b/hotspot/src/share/vm/classfile/vmSymbols.hpp index 585c8b5382e..aedc036a7ed 100644 --- a/hotspot/src/share/vm/classfile/vmSymbols.hpp +++ b/hotspot/src/share/vm/classfile/vmSymbols.hpp @@ -354,7 +354,6 @@ template(groups_name, "groups") \ template(maxPriority_name, "maxPriority") \ template(destroyed_name, "destroyed") \ - template(vmAllowSuspension_name, "vmAllowSuspension") \ template(nthreads_name, "nthreads") \ template(ngroups_name, "ngroups") \ template(shutdown_method_name, "shutdown") \ @@ -1239,6 +1238,10 @@ do_signature(compareAndExchangeLong_signature, "(Ljava/lang/Object;JJJ)J") \ do_signature(compareAndSwapInt_signature, "(Ljava/lang/Object;JII)Z") \ do_signature(compareAndExchangeInt_signature, "(Ljava/lang/Object;JII)I") \ + do_signature(compareAndSwapByte_signature, "(Ljava/lang/Object;JBB)Z") \ + do_signature(compareAndExchangeByte_signature, "(Ljava/lang/Object;JBB)B") \ + do_signature(compareAndSwapShort_signature, "(Ljava/lang/Object;JSS)Z") \ + do_signature(compareAndExchangeShort_signature, "(Ljava/lang/Object;JSS)S") \ \ do_name(compareAndSwapObject_name, "compareAndSwapObject") \ do_name(compareAndExchangeObjectVolatile_name, "compareAndExchangeObjectVolatile") \ @@ -1252,6 +1255,14 @@ do_name(compareAndExchangeIntVolatile_name, "compareAndExchangeIntVolatile") \ do_name(compareAndExchangeIntAcquire_name, "compareAndExchangeIntAcquire") \ do_name(compareAndExchangeIntRelease_name, "compareAndExchangeIntRelease") \ + do_name(compareAndSwapByte_name, "compareAndSwapByte") \ + do_name(compareAndExchangeByteVolatile_name, "compareAndExchangeByteVolatile") \ + do_name(compareAndExchangeByteAcquire_name, "compareAndExchangeByteAcquire") \ + do_name(compareAndExchangeByteRelease_name, "compareAndExchangeByteRelease") \ + do_name(compareAndSwapShort_name, "compareAndSwapShort") \ + do_name(compareAndExchangeShortVolatile_name, "compareAndExchangeShortVolatile") \ + do_name(compareAndExchangeShortAcquire_name, "compareAndExchangeShortAcquire") \ + do_name(compareAndExchangeShortRelease_name, "compareAndExchangeShortRelease") \ \ do_name(weakCompareAndSwapObject_name, "weakCompareAndSwapObject") \ do_name(weakCompareAndSwapObjectAcquire_name, "weakCompareAndSwapObjectAcquire") \ @@ -1265,6 +1276,14 @@ do_name(weakCompareAndSwapIntAcquire_name, "weakCompareAndSwapIntAcquire") \ do_name(weakCompareAndSwapIntRelease_name, "weakCompareAndSwapIntRelease") \ do_name(weakCompareAndSwapIntVolatile_name, "weakCompareAndSwapIntVolatile") \ + do_name(weakCompareAndSwapByte_name, "weakCompareAndSwapByte") \ + do_name(weakCompareAndSwapByteAcquire_name, "weakCompareAndSwapByteAcquire") \ + do_name(weakCompareAndSwapByteRelease_name, "weakCompareAndSwapByteRelease") \ + do_name(weakCompareAndSwapByteVolatile_name, "weakCompareAndSwapByteVolatile") \ + do_name(weakCompareAndSwapShort_name, "weakCompareAndSwapShort") \ + do_name(weakCompareAndSwapShortAcquire_name, "weakCompareAndSwapShortAcquire") \ + do_name(weakCompareAndSwapShortRelease_name, "weakCompareAndSwapShortRelease") \ + do_name(weakCompareAndSwapShortVolatile_name, "weakCompareAndSwapShortVolatile") \ \ do_intrinsic(_compareAndSwapObject, jdk_internal_misc_Unsafe, compareAndSwapObject_name, compareAndSwapObject_signature, F_RN) \ do_intrinsic(_compareAndExchangeObjectVolatile, jdk_internal_misc_Unsafe, compareAndExchangeObjectVolatile_name, compareAndExchangeObject_signature, F_RN) \ @@ -1278,7 +1297,15 @@ do_intrinsic(_compareAndExchangeIntVolatile, jdk_internal_misc_Unsafe, compareAndExchangeIntVolatile_name, compareAndExchangeInt_signature, F_RN) \ do_intrinsic(_compareAndExchangeIntAcquire, jdk_internal_misc_Unsafe, compareAndExchangeIntAcquire_name, compareAndExchangeInt_signature, F_R) \ do_intrinsic(_compareAndExchangeIntRelease, jdk_internal_misc_Unsafe, compareAndExchangeIntRelease_name, compareAndExchangeInt_signature, F_R) \ - \ + do_intrinsic(_compareAndSwapByte, jdk_internal_misc_Unsafe, compareAndSwapByte_name, compareAndSwapByte_signature, F_R) \ + do_intrinsic(_compareAndExchangeByteVolatile, jdk_internal_misc_Unsafe, compareAndExchangeByteVolatile_name, compareAndExchangeByte_signature, F_R) \ + do_intrinsic(_compareAndExchangeByteAcquire, jdk_internal_misc_Unsafe, compareAndExchangeByteAcquire_name, compareAndExchangeByte_signature, F_R) \ + do_intrinsic(_compareAndExchangeByteRelease, jdk_internal_misc_Unsafe, compareAndExchangeByteRelease_name, compareAndExchangeByte_signature, F_R) \ + do_intrinsic(_compareAndSwapShort, jdk_internal_misc_Unsafe, compareAndSwapShort_name, compareAndSwapShort_signature, F_R) \ + do_intrinsic(_compareAndExchangeShortVolatile, jdk_internal_misc_Unsafe, compareAndExchangeShortVolatile_name, compareAndExchangeShort_signature, F_R) \ + do_intrinsic(_compareAndExchangeShortAcquire, jdk_internal_misc_Unsafe, compareAndExchangeShortAcquire_name, compareAndExchangeShort_signature, F_R) \ + do_intrinsic(_compareAndExchangeShortRelease, jdk_internal_misc_Unsafe, compareAndExchangeShortRelease_name, compareAndExchangeShort_signature, F_R) \ + \ do_intrinsic(_weakCompareAndSwapObject, jdk_internal_misc_Unsafe, weakCompareAndSwapObject_name, compareAndSwapObject_signature, F_R) \ do_intrinsic(_weakCompareAndSwapObjectAcquire, jdk_internal_misc_Unsafe, weakCompareAndSwapObjectAcquire_name, compareAndSwapObject_signature, F_R) \ do_intrinsic(_weakCompareAndSwapObjectRelease, jdk_internal_misc_Unsafe, weakCompareAndSwapObjectRelease_name, compareAndSwapObject_signature, F_R) \ @@ -1291,19 +1318,39 @@ do_intrinsic(_weakCompareAndSwapIntAcquire, jdk_internal_misc_Unsafe, weakCompareAndSwapIntAcquire_name, compareAndSwapInt_signature, F_R) \ do_intrinsic(_weakCompareAndSwapIntRelease, jdk_internal_misc_Unsafe, weakCompareAndSwapIntRelease_name, compareAndSwapInt_signature, F_R) \ do_intrinsic(_weakCompareAndSwapIntVolatile, jdk_internal_misc_Unsafe, weakCompareAndSwapIntVolatile_name, compareAndSwapInt_signature, F_R) \ - \ + do_intrinsic(_weakCompareAndSwapByte, jdk_internal_misc_Unsafe, weakCompareAndSwapByte_name, compareAndSwapByte_signature, F_R) \ + do_intrinsic(_weakCompareAndSwapByteAcquire, jdk_internal_misc_Unsafe, weakCompareAndSwapByteAcquire_name, compareAndSwapByte_signature, F_R) \ + do_intrinsic(_weakCompareAndSwapByteRelease, jdk_internal_misc_Unsafe, weakCompareAndSwapByteRelease_name, compareAndSwapByte_signature, F_R) \ + do_intrinsic(_weakCompareAndSwapByteVolatile, jdk_internal_misc_Unsafe, weakCompareAndSwapByteVolatile_name, compareAndSwapByte_signature, F_R) \ + do_intrinsic(_weakCompareAndSwapShort, jdk_internal_misc_Unsafe, weakCompareAndSwapShort_name, compareAndSwapShort_signature, F_R) \ + do_intrinsic(_weakCompareAndSwapShortAcquire, jdk_internal_misc_Unsafe, weakCompareAndSwapShortAcquire_name, compareAndSwapShort_signature, F_R) \ + do_intrinsic(_weakCompareAndSwapShortRelease, jdk_internal_misc_Unsafe, weakCompareAndSwapShortRelease_name, compareAndSwapShort_signature, F_R) \ + do_intrinsic(_weakCompareAndSwapShortVolatile, jdk_internal_misc_Unsafe, weakCompareAndSwapShortVolatile_name, compareAndSwapShort_signature, F_R) \ + \ do_intrinsic(_getAndAddInt, jdk_internal_misc_Unsafe, getAndAddInt_name, getAndAddInt_signature, F_R) \ do_name( getAndAddInt_name, "getAndAddInt") \ do_signature(getAndAddInt_signature, "(Ljava/lang/Object;JI)I" ) \ do_intrinsic(_getAndAddLong, jdk_internal_misc_Unsafe, getAndAddLong_name, getAndAddLong_signature, F_R) \ do_name( getAndAddLong_name, "getAndAddLong") \ do_signature(getAndAddLong_signature, "(Ljava/lang/Object;JJ)J" ) \ + do_intrinsic(_getAndAddByte, jdk_internal_misc_Unsafe, getAndAddByte_name, getAndAddByte_signature, F_R) \ + do_name( getAndAddByte_name, "getAndAddByte") \ + do_signature(getAndAddByte_signature, "(Ljava/lang/Object;JB)B" ) \ + do_intrinsic(_getAndAddShort, jdk_internal_misc_Unsafe, getAndAddShort_name, getAndAddShort_signature, F_R) \ + do_name( getAndAddShort_name, "getAndAddShort") \ + do_signature(getAndAddShort_signature, "(Ljava/lang/Object;JS)S" ) \ do_intrinsic(_getAndSetInt, jdk_internal_misc_Unsafe, getAndSetInt_name, getAndSetInt_signature, F_R) \ do_name( getAndSetInt_name, "getAndSetInt") \ do_alias( getAndSetInt_signature, /*"(Ljava/lang/Object;JI)I"*/ getAndAddInt_signature) \ do_intrinsic(_getAndSetLong, jdk_internal_misc_Unsafe, getAndSetLong_name, getAndSetLong_signature, F_R) \ do_name( getAndSetLong_name, "getAndSetLong") \ do_alias( getAndSetLong_signature, /*"(Ljava/lang/Object;JJ)J"*/ getAndAddLong_signature) \ + do_intrinsic(_getAndSetByte, jdk_internal_misc_Unsafe, getAndSetByte_name, getAndSetByte_signature, F_R) \ + do_name( getAndSetByte_name, "getAndSetByte") \ + do_alias( getAndSetByte_signature, /*"(Ljava/lang/Object;JB)B"*/ getAndAddByte_signature) \ + do_intrinsic(_getAndSetShort, jdk_internal_misc_Unsafe, getAndSetShort_name, getAndSetShort_signature, F_R) \ + do_name( getAndSetShort_name, "getAndSetShort") \ + do_alias( getAndSetShort_signature, /*"(Ljava/lang/Object;JS)S"*/ getAndAddShort_signature) \ do_intrinsic(_getAndSetObject, jdk_internal_misc_Unsafe, getAndSetObject_name, getAndSetObject_signature, F_R)\ do_name( getAndSetObject_name, "getAndSetObject") \ do_signature(getAndSetObject_signature, "(Ljava/lang/Object;JLjava/lang/Object;)Ljava/lang/Object;" ) \ diff --git a/hotspot/src/share/vm/code/compiledMethod.cpp b/hotspot/src/share/vm/code/compiledMethod.cpp index 5ca594579ce..5031b364d18 100644 --- a/hotspot/src/share/vm/code/compiledMethod.cpp +++ b/hotspot/src/share/vm/code/compiledMethod.cpp @@ -63,7 +63,7 @@ bool CompiledMethod::is_method_handle_return(address return_pc) { bool CompiledMethod::is_deopt_entry(address pc) { return pc == deopt_handler_begin() #if INCLUDE_JVMCI - || pc == (deopt_handler_begin() + NativeCall::instruction_size) + || (is_compiled_by_jvmci() && pc == (deopt_handler_begin() + NativeCall::instruction_size)) #endif ; } diff --git a/hotspot/src/share/vm/code/dependencies.hpp b/hotspot/src/share/vm/code/dependencies.hpp index 22a2fd2ce53..eeedcb10e8b 100644 --- a/hotspot/src/share/vm/code/dependencies.hpp +++ b/hotspot/src/share/vm/code/dependencies.hpp @@ -168,7 +168,7 @@ class Dependencies: public ResourceObj { LG2_TYPE_LIMIT = 4, // assert(TYPE_LIMIT <= (1<(_analytics); } - // Add the given number of bytes to the total number of allocated bytes in the old gen. void add_bytes_allocated_in_old_since_last_gc(size_t bytes) { _bytes_allocated_in_old_since_last_gc += bytes; } - // Accessors - void set_region_eden(HeapRegion* hr) { hr->set_eden(); hr->install_surv_rate_group(_short_lived_surv_rate_group); @@ -164,8 +156,6 @@ public: return _mmu_tracker->max_gc_time() * 1000.0; } - // Returns an estimate of the survival rate of the region at yg-age - // "yg_age". double predict_yg_surv_rate(int age, SurvRateGroup* surv_rate_group) const; double predict_yg_surv_rate(int age) const; @@ -250,16 +240,9 @@ private: public: size_t pending_cards() const { return _pending_cards; } - // Calculate the minimum number of old regions we'll add to the CSet - // during a mixed GC. uint calc_min_old_cset_length() const; - - // Calculate the maximum number of old regions we'll add to the CSet - // during a mixed GC. uint calc_max_old_cset_length() const; - // Returns the given amount of uncollected reclaimable space - // as a percentage of the current heap capacity. double reclaimable_bytes_perc(size_t reclaimable_bytes) const; private: @@ -293,12 +276,8 @@ public: G1GCPhaseTimes* phase_times() const { return _phase_times; } - // Check the current value of the young list RSet lengths and - // compare it against the last prediction. If the current value is - // higher, recalculate the young list target length prediction. void revise_young_list_target_length_if_necessary(size_t rs_lengths); - // This should be called after the heap is resized. void record_new_heap_size(uint new_number_of_regions); void init(G1CollectedHeap* g1h, G1CollectionSet* collection_set); @@ -309,42 +288,31 @@ public: bool about_to_start_mixed_phase() const; - // Record the start and end of an evacuation pause. void record_collection_pause_start(double start_time_sec); void record_collection_pause_end(double pause_time_ms, size_t cards_scanned, size_t heap_used_bytes_before_gc); - // Record the start and end of a full collection. void record_full_collection_start(); void record_full_collection_end(); - // Must currently be called while the world is stopped. void record_concurrent_mark_init_end(double mark_init_elapsed_time_ms); - // Record start and end of remark. void record_concurrent_mark_remark_start(); void record_concurrent_mark_remark_end(); - // Record start, end, and completion of cleanup. void record_concurrent_mark_cleanup_start(); void record_concurrent_mark_cleanup_end(); void record_concurrent_mark_cleanup_completed(); virtual void print_phases(); - // Record how much space we copied during a GC. This is typically - // called when a GC alloc region is being retired. void record_bytes_copied_during_gc(size_t bytes) { _bytes_copied_during_gc += bytes; } - // The amount of space we copied during a GC. size_t bytes_copied_during_gc() const { return _bytes_copied_during_gc; } - // Determine whether there are candidate regions so that the - // next GC should be mixed. The two action strings are used - // in the ergo output when the method returns true or false. bool next_gc_should_be_mixed(const char* true_action_str, const char* false_action_str) const; @@ -356,18 +324,8 @@ private: void initiate_conc_mark(); public: - // This sets the initiate_conc_mark_if_possible() flag to start a - // new cycle, as long as we are not already in one. It's best if it - // is called during a safepoint when the test whether a cycle is in - // progress or not is stable. bool force_initial_mark_if_outside_cycle(GCCause::Cause gc_cause); - // This is called at the very beginning of an evacuation pause (it - // has to be the first thing that the pause does). If - // initiate_conc_mark_if_possible() is true, and the concurrent - // marking thread has completed its work during the previous cycle, - // it will set during_initial_mark_pause() to so that the pause does - // the initial-mark work and start a marking cycle. void decide_on_conc_mark_initiation(); void finished_recalculating_age_indexes(bool is_survivors) { @@ -431,7 +389,6 @@ public: void update_max_gc_locker_expansion(); - // Calculates survivor space parameters. void update_survivors_policy(); }; diff --git a/hotspot/src/share/vm/gc/g1/g1ParScanThreadState.cpp b/hotspot/src/share/vm/gc/g1/g1ParScanThreadState.cpp index dc324322ae8..5caeb3abaa2 100644 --- a/hotspot/src/share/vm/gc/g1/g1ParScanThreadState.cpp +++ b/hotspot/src/share/vm/gc/g1/g1ParScanThreadState.cpp @@ -137,7 +137,9 @@ void G1ParScanThreadState::trim_queue() { do { // Drain the overflow stack first, so other threads can steal. while (_refs->pop_overflow(ref)) { - dispatch_reference(ref); + if (!_refs->try_push_to_taskqueue(ref)) { + dispatch_reference(ref); + } } while (_refs->pop_local(ref)) { diff --git a/hotspot/src/share/vm/gc/g1/g1StringDedupTable.cpp b/hotspot/src/share/vm/gc/g1/g1StringDedupTable.cpp index 3075c269ebc..01ef9dcc3c2 100644 --- a/hotspot/src/share/vm/gc/g1/g1StringDedupTable.cpp +++ b/hotspot/src/share/vm/gc/g1/g1StringDedupTable.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -37,16 +37,16 @@ #include "runtime/mutexLocker.hpp" // -// Freelist in the deduplication table entry cache. Links table +// List of deduplication table entries. Links table // entries together using their _next fields. // -class G1StringDedupEntryFreeList : public CHeapObj { +class G1StringDedupEntryList : public CHeapObj { private: G1StringDedupEntry* _list; size_t _length; public: - G1StringDedupEntryFreeList() : + G1StringDedupEntryList() : _list(NULL), _length(0) { } @@ -66,6 +66,12 @@ public: return entry; } + G1StringDedupEntry* remove_all() { + G1StringDedupEntry* list = _list; + _list = NULL; + return list; + } + size_t length() { return _length; } @@ -87,43 +93,53 @@ public: // class G1StringDedupEntryCache : public CHeapObj { private: - // One freelist per GC worker to allow lock less freeing of - // entries while doing a parallel scan of the table. Using - // PaddedEnd to avoid false sharing. - PaddedEnd* _lists; - size_t _nlists; + // One cache/overflow list per GC worker to allow lock less freeing of + // entries while doing a parallel scan of the table. Using PaddedEnd to + // avoid false sharing. + size_t _nlists; + size_t _max_list_length; + PaddedEnd* _cached; + PaddedEnd* _overflowed; public: - G1StringDedupEntryCache(); + G1StringDedupEntryCache(size_t max_size); ~G1StringDedupEntryCache(); - // Get a table entry from the cache freelist, or allocate a new - // entry if the cache is empty. + // Set max number of table entries to cache. + void set_max_size(size_t max_size); + + // Get a table entry from the cache, or allocate a new entry if the cache is empty. G1StringDedupEntry* alloc(); - // Insert a table entry into the cache freelist. + // Insert a table entry into the cache. void free(G1StringDedupEntry* entry, uint worker_id); // Returns current number of entries in the cache. size_t size(); - // If the cache has grown above the given max size, trim it down - // and deallocate the memory occupied by trimmed of entries. - void trim(size_t max_size); + // Deletes overflowed entries. + void delete_overflowed(); }; -G1StringDedupEntryCache::G1StringDedupEntryCache() { - _nlists = ParallelGCThreads; - _lists = PaddedArray::create_unfreeable((uint)_nlists); +G1StringDedupEntryCache::G1StringDedupEntryCache(size_t max_size) : + _nlists(ParallelGCThreads), + _max_list_length(0), + _cached(PaddedArray::create_unfreeable((uint)_nlists)), + _overflowed(PaddedArray::create_unfreeable((uint)_nlists)) { + set_max_size(max_size); } G1StringDedupEntryCache::~G1StringDedupEntryCache() { ShouldNotReachHere(); } +void G1StringDedupEntryCache::set_max_size(size_t size) { + _max_list_length = size / _nlists; +} + G1StringDedupEntry* G1StringDedupEntryCache::alloc() { for (size_t i = 0; i < _nlists; i++) { - G1StringDedupEntry* entry = _lists[i].remove(); + G1StringDedupEntry* entry = _cached[i].remove(); if (entry != NULL) { return entry; } @@ -134,31 +150,53 @@ G1StringDedupEntry* G1StringDedupEntryCache::alloc() { void G1StringDedupEntryCache::free(G1StringDedupEntry* entry, uint worker_id) { assert(entry->obj() != NULL, "Double free"); assert(worker_id < _nlists, "Invalid worker id"); + entry->set_obj(NULL); entry->set_hash(0); - _lists[worker_id].add(entry); + + if (_cached[worker_id].length() < _max_list_length) { + // Cache is not full + _cached[worker_id].add(entry); + } else { + // Cache is full, add to overflow list for later deletion + _overflowed[worker_id].add(entry); + } } size_t G1StringDedupEntryCache::size() { size_t size = 0; for (size_t i = 0; i < _nlists; i++) { - size += _lists[i].length(); + size += _cached[i].length(); } return size; } -void G1StringDedupEntryCache::trim(size_t max_size) { - size_t cache_size = 0; +void G1StringDedupEntryCache::delete_overflowed() { + double start = os::elapsedTime(); + uintx count = 0; + for (size_t i = 0; i < _nlists; i++) { - G1StringDedupEntryFreeList* list = &_lists[i]; - cache_size += list->length(); - while (cache_size > max_size) { - G1StringDedupEntry* entry = list->remove(); - assert(entry != NULL, "Should not be null"); - cache_size--; + G1StringDedupEntry* entry; + + { + // The overflow list can be modified during safepoints, therefore + // we temporarily join the suspendible thread set while removing + // all entries from the list. + SuspendibleThreadSetJoiner sts_join; + entry = _overflowed[i].remove_all(); + } + + // Delete all entries + while (entry != NULL) { + G1StringDedupEntry* next = entry->next(); delete entry; + entry = next; + count++; } } + + double end = os::elapsedTime(); + log_trace(gc, stringdedup)("Deleted " UINTX_FORMAT " entries, " G1_STRDEDUP_TIME_FORMAT, count, end - start); } G1StringDedupTable* G1StringDedupTable::_table = NULL; @@ -195,7 +233,7 @@ G1StringDedupTable::~G1StringDedupTable() { void G1StringDedupTable::create() { assert(_table == NULL, "One string deduplication table allowed"); - _entry_cache = new G1StringDedupEntryCache(); + _entry_cache = new G1StringDedupEntryCache(_min_size * _max_cache_factor); _table = new G1StringDedupTable(_min_size); } @@ -389,6 +427,9 @@ G1StringDedupTable* G1StringDedupTable::prepare_resize() { // Update statistics _resize_count++; + // Update max cache size + _entry_cache->set_max_size(size * _max_cache_factor); + // Allocate the new table. The new table will be populated by workers // calling unlink_or_oops_do() and finally installed by finish_resize(). return new G1StringDedupTable(size, _table->_hash_seed); @@ -441,7 +482,7 @@ void G1StringDedupTable::unlink_or_oops_do(G1StringDedupUnlinkOrOopsDoClosure* c removed += unlink_or_oops_do(cl, table_half + partition_begin, table_half + partition_end, worker_id); } - // Delayed update avoid contention on the table lock + // Delayed update to avoid contention on the table lock if (removed > 0) { MutexLockerEx ml(StringDedupTable_lock, Mutex::_no_safepoint_check_flag); _table->_entries -= removed; @@ -563,10 +604,8 @@ void G1StringDedupTable::verify() { } } -void G1StringDedupTable::trim_entry_cache() { - MutexLockerEx ml(StringDedupTable_lock, Mutex::_no_safepoint_check_flag); - size_t max_cache_size = (size_t)(_table->_size * _max_cache_factor); - _entry_cache->trim(max_cache_size); +void G1StringDedupTable::clean_entry_cache() { + _entry_cache->delete_overflowed(); } void G1StringDedupTable::print_statistics() { diff --git a/hotspot/src/share/vm/gc/g1/g1StringDedupTable.hpp b/hotspot/src/share/vm/gc/g1/g1StringDedupTable.hpp index 4375f4dafb3..c30d0403ead 100644 --- a/hotspot/src/share/vm/gc/g1/g1StringDedupTable.hpp +++ b/hotspot/src/share/vm/gc/g1/g1StringDedupTable.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -229,8 +229,8 @@ public: // and deletes the previously active table. static void finish_rehash(G1StringDedupTable* rehashed_table); - // If the table entry cache has grown too large, trim it down according to policy - static void trim_entry_cache(); + // If the table entry cache has grown too large, delete overflowed entries. + static void clean_entry_cache(); static void unlink_or_oops_do(G1StringDedupUnlinkOrOopsDoClosure* cl, uint worker_id); diff --git a/hotspot/src/share/vm/gc/g1/g1StringDedupThread.cpp b/hotspot/src/share/vm/gc/g1/g1StringDedupThread.cpp index 4c6dc45fc90..57337d1d7dd 100644 --- a/hotspot/src/share/vm/gc/g1/g1StringDedupThread.cpp +++ b/hotspot/src/share/vm/gc/g1/g1StringDedupThread.cpp @@ -121,16 +121,15 @@ void G1StringDedupThread::run_service() { } } - G1StringDedupTable::trim_entry_cache(); - stat.mark_done(); // Print statistics total_stat.add(stat); print(stat, total_stat); } - } + G1StringDedupTable::clean_entry_cache(); + } } void G1StringDedupThread::stop_service() { diff --git a/hotspot/src/share/vm/gc/shared/taskqueue.hpp b/hotspot/src/share/vm/gc/shared/taskqueue.hpp index e61a6c2451b..7ba1d38441b 100644 --- a/hotspot/src/share/vm/gc/shared/taskqueue.hpp +++ b/hotspot/src/share/vm/gc/shared/taskqueue.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -330,6 +330,8 @@ public: // Push task t onto the queue or onto the overflow stack. Return true. inline bool push(E t); + // Try to push task t onto the queue only. Returns true if successful, false otherwise. + inline bool try_push_to_taskqueue(E t); // Attempt to pop from the overflow stack; return true if anything was popped. inline bool pop_overflow(E& t); diff --git a/hotspot/src/share/vm/gc/shared/taskqueue.inline.hpp b/hotspot/src/share/vm/gc/shared/taskqueue.inline.hpp index 8ba1577002c..baa35059bed 100644 --- a/hotspot/src/share/vm/gc/shared/taskqueue.inline.hpp +++ b/hotspot/src/share/vm/gc/shared/taskqueue.inline.hpp @@ -103,6 +103,11 @@ inline bool OverflowTaskQueue::push(E t) return true; } +template +inline bool OverflowTaskQueue::try_push_to_taskqueue(E t) { + return taskqueue_t::push(t); +} + // pop_local_slow() is done by the owning thread and is trying to // get the last task in the queue. It will compete with pop_global() // that will be used by other threads. The tag age is incremented diff --git a/hotspot/src/share/vm/interpreter/interpreterRuntime.cpp b/hotspot/src/share/vm/interpreter/interpreterRuntime.cpp index cd1d88926aa..77309bb34bb 100644 --- a/hotspot/src/share/vm/interpreter/interpreterRuntime.cpp +++ b/hotspot/src/share/vm/interpreter/interpreterRuntime.cpp @@ -558,6 +558,7 @@ void InterpreterRuntime::resolve_get_put(JavaThread* thread, Bytecodes::Code byt // resolve field fieldDescriptor info; constantPoolHandle pool(thread, method(thread)->constants()); + methodHandle m(thread, method(thread)); bool is_put = (bytecode == Bytecodes::_putfield || bytecode == Bytecodes::_nofast_putfield || bytecode == Bytecodes::_putstatic); bool is_static = (bytecode == Bytecodes::_getstatic || bytecode == Bytecodes::_putstatic); @@ -565,7 +566,7 @@ void InterpreterRuntime::resolve_get_put(JavaThread* thread, Bytecodes::Code byt { JvmtiHideSingleStepping jhss(thread); LinkResolver::resolve_field_access(info, pool, get_index_u2_cpcache(thread, bytecode), - bytecode, CHECK); + m, bytecode, CHECK); } // end JvmtiHideSingleStepping // check if link resolution caused cpCache to be updated diff --git a/hotspot/src/share/vm/interpreter/linkResolver.cpp b/hotspot/src/share/vm/interpreter/linkResolver.cpp index f0337146a82..ed49b476484 100644 --- a/hotspot/src/share/vm/interpreter/linkResolver.cpp +++ b/hotspot/src/share/vm/interpreter/linkResolver.cpp @@ -223,6 +223,22 @@ void CallInfo::print() { //------------------------------------------------------------------------------------------------------------------------ // Implementation of LinkInfo +LinkInfo::LinkInfo(const constantPoolHandle& pool, int index, methodHandle current_method, TRAPS) { + // resolve klass + Klass* result = pool->klass_ref_at(index, CHECK); + _resolved_klass = KlassHandle(THREAD, result); + + // Get name, signature, and static klass + _name = pool->name_ref_at(index); + _signature = pool->signature_ref_at(index); + _tag = pool->tag_ref_at(index); + _current_klass = KlassHandle(THREAD, pool->pool_holder()); + _current_method = current_method; + + // Coming from the constant pool always checks access + _check_access = true; +} + LinkInfo::LinkInfo(const constantPoolHandle& pool, int index, TRAPS) { // resolve klass Klass* result = pool->klass_ref_at(index, CHECK); @@ -233,6 +249,7 @@ LinkInfo::LinkInfo(const constantPoolHandle& pool, int index, TRAPS) { _signature = pool->signature_ref_at(index); _tag = pool->tag_ref_at(index); _current_klass = KlassHandle(THREAD, pool->pool_holder()); + _current_method = methodHandle(); // Coming from the constant pool always checks access _check_access = true; @@ -577,7 +594,7 @@ methodHandle LinkResolver::resolve_method_statically(Bytecodes::Code code, return resolve_method(link_info, code, THREAD); } - LinkInfo link_info(pool, index, CHECK_NULL); + LinkInfo link_info(pool, index, methodHandle(), CHECK_NULL); resolved_klass = link_info.resolved_klass(); if (pool->has_preresolution() @@ -875,8 +892,8 @@ void LinkResolver::check_field_accessability(KlassHandle ref_klass, } } -void LinkResolver::resolve_field_access(fieldDescriptor& fd, const constantPoolHandle& pool, int index, Bytecodes::Code byte, TRAPS) { - LinkInfo link_info(pool, index, CHECK); +void LinkResolver::resolve_field_access(fieldDescriptor& fd, const constantPoolHandle& pool, int index, const methodHandle& method, Bytecodes::Code byte, TRAPS) { + LinkInfo link_info(pool, index, method, CHECK); resolve_field(fd, link_info, byte, true, CHECK); } @@ -925,9 +942,39 @@ void LinkResolver::resolve_field(fieldDescriptor& fd, THROW_MSG(vmSymbols::java_lang_IncompatibleClassChangeError(), msg); } - // Final fields can only be accessed from its own class. - if (is_put && fd.access_flags().is_final() && sel_klass() != current_klass()) { - THROW(vmSymbols::java_lang_IllegalAccessError()); + // A final field can be modified only + // (1) by methods declared in the class declaring the field and + // (2) by the method (in case of a static field) + // or by the method (in case of an instance field). + if (is_put && fd.access_flags().is_final()) { + ResourceMark rm(THREAD); + stringStream ss; + + if (sel_klass() != current_klass()) { + ss.print("Update to %s final field %s.%s attempted from a different class (%s) than the field's declaring class", + is_static ? "static" : "non-static", resolved_klass()->external_name(), fd.name()->as_C_string(), + current_klass()->external_name()); + THROW_MSG(vmSymbols::java_lang_IllegalAccessError(), ss.as_string()); + } + + if (fd.constants()->pool_holder()->major_version() >= 53) { + methodHandle m = link_info.current_method(); + assert(!m.is_null(), "information about the current method must be available for 'put' bytecodes"); + bool is_initialized_static_final_update = (byte == Bytecodes::_putstatic && + fd.is_static() && + !m()->is_static_initializer()); + bool is_initialized_instance_final_update = ((byte == Bytecodes::_putfield || byte == Bytecodes::_nofast_putfield) && + !fd.is_static() && + !m->is_object_initializer()); + + if (is_initialized_static_final_update || is_initialized_instance_final_update) { + ss.print("Update to %s final field %s.%s attempted from a different method (%s) than the initializer method %s ", + is_static ? "static" : "non-static", resolved_klass()->external_name(), fd.name()->as_C_string(), + current_klass()->external_name(), + is_static ? "" : ""); + THROW_MSG(vmSymbols::java_lang_IllegalAccessError(), ss.as_string()); + } + } } // initialize resolved_klass if necessary diff --git a/hotspot/src/share/vm/interpreter/linkResolver.hpp b/hotspot/src/share/vm/interpreter/linkResolver.hpp index 263365b56bf..1c02898b42d 100644 --- a/hotspot/src/share/vm/interpreter/linkResolver.hpp +++ b/hotspot/src/share/vm/interpreter/linkResolver.hpp @@ -131,19 +131,23 @@ class CallInfo : public StackObj { // resolved_klass = specified class (i.e., static receiver class) // current_klass = sending method holder (i.e., class containing the method // containing the call being resolved) +// current_method = sending method (relevant for field resolution) class LinkInfo : public StackObj { Symbol* _name; // extracted from JVM_CONSTANT_NameAndType Symbol* _signature; KlassHandle _resolved_klass; // class that the constant pool entry points to KlassHandle _current_klass; // class that owns the constant pool + methodHandle _current_method; // sending method bool _check_access; constantTag _tag; + public: enum AccessCheck { - needs_access_check, - skip_access_check + needs_access_check, + skip_access_check }; + LinkInfo(const constantPoolHandle& pool, int index, methodHandle current_method, TRAPS); LinkInfo(const constantPoolHandle& pool, int index, TRAPS); // Condensed information from other call sites within the vm. @@ -151,13 +155,20 @@ class LinkInfo : public StackObj { AccessCheck check_access = needs_access_check, constantTag tag = JVM_CONSTANT_Invalid) : _resolved_klass(resolved_klass), - _name(name), _signature(signature), _current_klass(current_klass), + _name(name), _signature(signature), _current_klass(current_klass), _current_method(NULL), + _check_access(check_access == needs_access_check), _tag(tag) {} + + LinkInfo(KlassHandle resolved_klass, Symbol* name, Symbol* signature, methodHandle current_method, + AccessCheck check_access = needs_access_check, + constantTag tag = JVM_CONSTANT_Invalid) : + _resolved_klass(resolved_klass), + _name(name), _signature(signature), _current_klass(current_method->method_holder()), _current_method(current_method), _check_access(check_access == needs_access_check), _tag(tag) {} // Case where we just find the method and don't check access against the current class LinkInfo(KlassHandle resolved_klass, Symbol*name, Symbol* signature) : _resolved_klass(resolved_klass), - _name(name), _signature(signature), _current_klass(NULL), + _name(name), _signature(signature), _current_klass(NULL), _current_method(NULL), _check_access(false), _tag(JVM_CONSTANT_Invalid) {} // accessors @@ -165,6 +176,7 @@ class LinkInfo : public StackObj { Symbol* signature() const { return _signature; } KlassHandle resolved_klass() const { return _resolved_klass; } KlassHandle current_klass() const { return _current_klass; } + methodHandle current_method() const { return _current_method; } constantTag tag() const { return _tag; } bool check_access() const { return _check_access; } char* method_string() const; @@ -266,7 +278,9 @@ class LinkResolver: AllStatic { static void resolve_field_access(fieldDescriptor& result, const constantPoolHandle& pool, - int index, Bytecodes::Code byte, TRAPS); + int index, + const methodHandle& method, + Bytecodes::Code byte, TRAPS); static void resolve_field(fieldDescriptor& result, const LinkInfo& link_info, Bytecodes::Code access_kind, bool initialize_class, TRAPS); diff --git a/hotspot/src/share/vm/interpreter/rewriter.cpp b/hotspot/src/share/vm/interpreter/rewriter.cpp index 7680fbf4b50..52832e781ab 100644 --- a/hotspot/src/share/vm/interpreter/rewriter.cpp +++ b/hotspot/src/share/vm/interpreter/rewriter.cpp @@ -406,10 +406,45 @@ void Rewriter::scan_method(Method* method, bool reverse, bool* invokespecial_err break; } + case Bytecodes::_putstatic : + case Bytecodes::_putfield : { + if (!reverse) { + // Check if any final field of the class given as parameter is modified + // outside of initializer methods of the class. Fields that are modified + // are marked with a flag. For marked fields, the compilers do not perform + // constant folding (as the field can be changed after initialization). + // + // The check is performed after verification and only if verification has + // succeeded. Therefore, the class is guaranteed to be well-formed. + InstanceKlass* klass = method->method_holder(); + u2 bc_index = Bytes::get_Java_u2(bcp + prefix_length + 1); + constantPoolHandle cp(method->constants()); + Symbol* field_name = cp->name_ref_at(bc_index); + Symbol* field_sig = cp->signature_ref_at(bc_index); + Symbol* ref_class_name = cp->klass_name_at(cp->klass_ref_index_at(bc_index)); + + if (klass->name() == ref_class_name) { + fieldDescriptor fd; + klass->find_field(field_name, field_sig, &fd); + if (fd.access_flags().is_final()) { + if (fd.access_flags().is_static()) { + assert(c == Bytecodes::_putstatic, "must be putstatic"); + if (!method->is_static_initializer()) { + fd.set_has_initialized_final_update(true); + } + } else { + assert(c == Bytecodes::_putfield, "must be putfield"); + if (!method->is_object_initializer()) { + fd.set_has_initialized_final_update(true); + } + } + } + } + } + } + // fall through case Bytecodes::_getstatic : // fall through - case Bytecodes::_putstatic : // fall through case Bytecodes::_getfield : // fall through - case Bytecodes::_putfield : // fall through case Bytecodes::_invokevirtual : // fall through case Bytecodes::_invokestatic : case Bytecodes::_invokeinterface: diff --git a/hotspot/src/share/vm/interpreter/templateInterpreterGenerator.hpp b/hotspot/src/share/vm/interpreter/templateInterpreterGenerator.hpp index 3f45525224a..38bad1811d8 100644 --- a/hotspot/src/share/vm/interpreter/templateInterpreterGenerator.hpp +++ b/hotspot/src/share/vm/interpreter/templateInterpreterGenerator.hpp @@ -108,8 +108,7 @@ class TemplateInterpreterGenerator: public AbstractInterpreterGenerator { void generate_fixed_frame(bool native_call); #ifdef SPARC - void generate_stack_overflow_check(Register Rframe_size, Register Rscratch, - Register Rscratch2); + void generate_stack_overflow_check(Register Rframe_size, Register Rscratch); void save_native_result(void); void restore_native_result(void); #endif // SPARC diff --git a/hotspot/src/share/vm/jvmci/jvmciCodeInstaller.cpp b/hotspot/src/share/vm/jvmci/jvmciCodeInstaller.cpp index 8e2111ea0fd..979be2a66e6 100644 --- a/hotspot/src/share/vm/jvmci/jvmciCodeInstaller.cpp +++ b/hotspot/src/share/vm/jvmci/jvmciCodeInstaller.cpp @@ -91,7 +91,19 @@ VMReg getVMRegFromLocation(Handle location, int total_frame_size, TRAPS) { } else { // stack slot if (offset % 4 == 0) { - return VMRegImpl::stack2reg(offset / 4); + VMReg vmReg = VMRegImpl::stack2reg(offset / 4); + if (!OopMapValue::legal_vm_reg_name(vmReg)) { + // This restriction only applies to VMRegs that are used in OopMap but + // since that's the only use of VMRegs it's simplest to put this test + // here. This test should also be equivalent legal_vm_reg_name but JVMCI + // clients can use max_oop_map_stack_stack_offset to detect this problem + // directly. The asserts just ensure that the tests are in agreement. + assert(offset > CompilerToVM::Data::max_oop_map_stack_offset(), "illegal VMReg"); + JVMCI_ERROR_NULL("stack offset %d is too large to be encoded in OopMap (max %d)", + offset, CompilerToVM::Data::max_oop_map_stack_offset()); + } + assert(OopMapValue::legal_vm_reg_name(vmReg), "illegal VMReg"); + return vmReg; } else { JVMCI_ERROR_NULL("unaligned stack offset %d in oop map", offset); } diff --git a/hotspot/src/share/vm/jvmci/jvmciCompilerToVM.cpp b/hotspot/src/share/vm/jvmci/jvmciCompilerToVM.cpp index 63387feb6fb..36837cda7f4 100644 --- a/hotspot/src/share/vm/jvmci/jvmciCompilerToVM.cpp +++ b/hotspot/src/share/vm/jvmci/jvmciCompilerToVM.cpp @@ -88,41 +88,6 @@ oop CompilerToVM::get_jvmci_type(KlassHandle klass, TRAPS) { return NULL; } -extern "C" { -extern VMStructEntry* jvmciHotSpotVMStructs; -extern uint64_t jvmciHotSpotVMStructEntryTypeNameOffset; -extern uint64_t jvmciHotSpotVMStructEntryFieldNameOffset; -extern uint64_t jvmciHotSpotVMStructEntryTypeStringOffset; -extern uint64_t jvmciHotSpotVMStructEntryIsStaticOffset; -extern uint64_t jvmciHotSpotVMStructEntryOffsetOffset; -extern uint64_t jvmciHotSpotVMStructEntryAddressOffset; -extern uint64_t jvmciHotSpotVMStructEntryArrayStride; - -extern VMTypeEntry* jvmciHotSpotVMTypes; -extern uint64_t jvmciHotSpotVMTypeEntryTypeNameOffset; -extern uint64_t jvmciHotSpotVMTypeEntrySuperclassNameOffset; -extern uint64_t jvmciHotSpotVMTypeEntryIsOopTypeOffset; -extern uint64_t jvmciHotSpotVMTypeEntryIsIntegerTypeOffset; -extern uint64_t jvmciHotSpotVMTypeEntryIsUnsignedOffset; -extern uint64_t jvmciHotSpotVMTypeEntrySizeOffset; -extern uint64_t jvmciHotSpotVMTypeEntryArrayStride; - -extern VMIntConstantEntry* jvmciHotSpotVMIntConstants; -extern uint64_t jvmciHotSpotVMIntConstantEntryNameOffset; -extern uint64_t jvmciHotSpotVMIntConstantEntryValueOffset; -extern uint64_t jvmciHotSpotVMIntConstantEntryArrayStride; - -extern VMLongConstantEntry* jvmciHotSpotVMLongConstants; -extern uint64_t jvmciHotSpotVMLongConstantEntryNameOffset; -extern uint64_t jvmciHotSpotVMLongConstantEntryValueOffset; -extern uint64_t jvmciHotSpotVMLongConstantEntryArrayStride; - -extern VMAddressEntry* jvmciHotSpotVMAddresses; -extern uint64_t jvmciHotSpotVMAddressEntryNameOffset; -extern uint64_t jvmciHotSpotVMAddressEntryValueOffset; -extern uint64_t jvmciHotSpotVMAddressEntryArrayStride; -} - int CompilerToVM::Data::Klass_vtable_start_offset; int CompilerToVM::Data::Klass_vtable_length_offset; @@ -148,6 +113,7 @@ uintptr_t CompilerToVM::Data::Universe_verify_oop_bits; bool CompilerToVM::Data::_supports_inline_contig_alloc; HeapWord** CompilerToVM::Data::_heap_end_addr; HeapWord** CompilerToVM::Data::_heap_top_addr; +int CompilerToVM::Data::_max_oop_map_stack_offset; jbyte* CompilerToVM::Data::cardtable_start_address; int CompilerToVM::Data::cardtable_shift; @@ -189,6 +155,11 @@ void CompilerToVM::Data::initialize() { _heap_end_addr = _supports_inline_contig_alloc ? Universe::heap()->end_addr() : (HeapWord**) -1; _heap_top_addr = _supports_inline_contig_alloc ? Universe::heap()->top_addr() : (HeapWord**) -1; + _max_oop_map_stack_offset = (OopMapValue::register_mask - VMRegImpl::stack2reg(0)->value()) * VMRegImpl::stack_slot_size; + int max_oop_map_stack_index = _max_oop_map_stack_offset / VMRegImpl::stack_slot_size; + assert(OopMapValue::legal_vm_reg_name(VMRegImpl::stack2reg(max_oop_map_stack_index)), "should be valid"); + assert(!OopMapValue::legal_vm_reg_name(VMRegImpl::stack2reg(max_oop_map_stack_index + 1)), "should be invalid"); + BarrierSet* bs = Universe::heap()->barrier_set(); switch (bs->kind()) { case BarrierSet::CardTableModRef: @@ -232,48 +203,151 @@ void CompilerToVM::Data::initialize() { #undef SET_TRIGFUNC } -/** - * We put all jvmciHotSpotVM values in an array so we can read them easily from Java. - */ -static uintptr_t ciHotSpotVMData[28]; - -C2V_VMENTRY(jlong, initializeConfiguration, (JNIEnv *env, jobject)) - ciHotSpotVMData[0] = (uintptr_t) jvmciHotSpotVMStructs; - ciHotSpotVMData[1] = jvmciHotSpotVMStructEntryTypeNameOffset; - ciHotSpotVMData[2] = jvmciHotSpotVMStructEntryFieldNameOffset; - ciHotSpotVMData[3] = jvmciHotSpotVMStructEntryTypeStringOffset; - ciHotSpotVMData[4] = jvmciHotSpotVMStructEntryIsStaticOffset; - ciHotSpotVMData[5] = jvmciHotSpotVMStructEntryOffsetOffset; - ciHotSpotVMData[6] = jvmciHotSpotVMStructEntryAddressOffset; - ciHotSpotVMData[7] = jvmciHotSpotVMStructEntryArrayStride; - - ciHotSpotVMData[8] = (uintptr_t) jvmciHotSpotVMTypes; - ciHotSpotVMData[9] = jvmciHotSpotVMTypeEntryTypeNameOffset; - ciHotSpotVMData[10] = jvmciHotSpotVMTypeEntrySuperclassNameOffset; - ciHotSpotVMData[11] = jvmciHotSpotVMTypeEntryIsOopTypeOffset; - ciHotSpotVMData[12] = jvmciHotSpotVMTypeEntryIsIntegerTypeOffset; - ciHotSpotVMData[13] = jvmciHotSpotVMTypeEntryIsUnsignedOffset; - ciHotSpotVMData[14] = jvmciHotSpotVMTypeEntrySizeOffset; - ciHotSpotVMData[15] = jvmciHotSpotVMTypeEntryArrayStride; - - ciHotSpotVMData[16] = (uintptr_t) jvmciHotSpotVMIntConstants; - ciHotSpotVMData[17] = jvmciHotSpotVMIntConstantEntryNameOffset; - ciHotSpotVMData[18] = jvmciHotSpotVMIntConstantEntryValueOffset; - ciHotSpotVMData[19] = jvmciHotSpotVMIntConstantEntryArrayStride; - - ciHotSpotVMData[20] = (uintptr_t) jvmciHotSpotVMLongConstants; - ciHotSpotVMData[21] = jvmciHotSpotVMLongConstantEntryNameOffset; - ciHotSpotVMData[22] = jvmciHotSpotVMLongConstantEntryValueOffset; - ciHotSpotVMData[23] = jvmciHotSpotVMLongConstantEntryArrayStride; - - ciHotSpotVMData[24] = (uintptr_t) jvmciHotSpotVMAddresses; - ciHotSpotVMData[25] = jvmciHotSpotVMAddressEntryNameOffset; - ciHotSpotVMData[26] = jvmciHotSpotVMAddressEntryValueOffset; - ciHotSpotVMData[27] = jvmciHotSpotVMAddressEntryArrayStride; +C2V_VMENTRY(jobjectArray, readConfiguration, (JNIEnv *env)) +#define BOXED_LONG(name, value) oop name; do { jvalue p; p.j = (jlong) (value); name = java_lang_boxing_object::create(T_LONG, &p, CHECK_NULL);} while(0) +#define BOXED_DOUBLE(name, value) oop name; do { jvalue p; p.d = (jdouble) (value); name = java_lang_boxing_object::create(T_DOUBLE, &p, CHECK_NULL);} while(0) + ResourceMark rm; + HandleMark hm; CompilerToVM::Data::initialize(); - return (jlong) (address) &ciHotSpotVMData; + VMField::klass()->initialize(thread); + VMFlag::klass()->initialize(thread); + + int len = JVMCIVMStructs::localHotSpotVMStructs_count(); + objArrayHandle vmFields = oopFactory::new_objArray(VMField::klass(), len, CHECK_NULL); + for (int i = 0; i < len ; i++) { + VMStructEntry vmField = JVMCIVMStructs::localHotSpotVMStructs[i]; + instanceHandle vmFieldObj = InstanceKlass::cast(VMField::klass())->allocate_instance_handle(CHECK_NULL); + size_t name_buf_len = strlen(vmField.typeName) + strlen(vmField.fieldName) + 2 /* "::" */; + char* name_buf = NEW_RESOURCE_ARRAY(char, name_buf_len + 1); + sprintf(name_buf, "%s::%s", vmField.typeName, vmField.fieldName); + Handle name = java_lang_String::create_from_str(name_buf, CHECK_NULL); + Handle type = java_lang_String::create_from_str(vmField.typeString, CHECK_NULL); + VMField::set_name(vmFieldObj, name()); + VMField::set_type(vmFieldObj, type()); + VMField::set_offset(vmFieldObj, vmField.offset); + VMField::set_address(vmFieldObj, (jlong) vmField.address); + if (vmField.isStatic) { + if (strcmp(vmField.typeString, "bool") == 0) { + BOXED_LONG(value, *(jbyte*) vmField.address); + VMField::set_value(vmFieldObj, value); + } else if (strcmp(vmField.typeString, "int") == 0 || + strcmp(vmField.typeString, "jint") == 0) { + BOXED_LONG(value, *(jint*) vmField.address); + VMField::set_value(vmFieldObj, value); + } else if (strcmp(vmField.typeString, "uint64_t") == 0) { + BOXED_LONG(value, *(uint64_t*) vmField.address); + VMField::set_value(vmFieldObj, value); + } else if (strcmp(vmField.typeString, "address") == 0 || + strcmp(vmField.typeString, "intptr_t") == 0 || + strcmp(vmField.typeString, "uintptr_t") == 0 || + strcmp(vmField.typeString, "size_t") == 0 || + // All foo* types are addresses. + vmField.typeString[strlen(vmField.typeString) - 1] == '*') { + BOXED_LONG(value, *((address*) vmField.address)); + VMField::set_value(vmFieldObj, value); + } else { + JVMCI_ERROR_NULL("VM field %s has unsupported type %s", name_buf, vmField.typeString); + } + } + vmFields->obj_at_put(i, vmFieldObj()); + } + + len = JVMCIVMStructs::localHotSpotVMTypes_count(); + objArrayHandle vmTypes = oopFactory::new_objArray(SystemDictionary::Object_klass(), len * 2, CHECK_NULL); + for (int i = 0; i < len ; i++) { + VMTypeEntry vmType = JVMCIVMStructs::localHotSpotVMTypes[i]; + Handle name = java_lang_String::create_from_str(vmType.typeName, CHECK_NULL); + BOXED_LONG(size, vmType.size); + vmTypes->obj_at_put(i * 2, name()); + vmTypes->obj_at_put(i * 2 + 1, size); + } + + int ints_len = JVMCIVMStructs::localHotSpotVMIntConstants_count(); + int longs_len = JVMCIVMStructs::localHotSpotVMLongConstants_count(); + len = ints_len + longs_len; + objArrayHandle vmConstants = oopFactory::new_objArray(SystemDictionary::Object_klass(), len * 2, CHECK_NULL); + int insert = 0; + for (int i = 0; i < ints_len ; i++) { + VMIntConstantEntry c = JVMCIVMStructs::localHotSpotVMIntConstants[i]; + Handle name = java_lang_String::create_from_str(c.name, CHECK_NULL); + BOXED_LONG(value, c.value); + vmConstants->obj_at_put(insert++, name()); + vmConstants->obj_at_put(insert++, value); + } + for (int i = 0; i < longs_len ; i++) { + VMLongConstantEntry c = JVMCIVMStructs::localHotSpotVMLongConstants[i]; + Handle name = java_lang_String::create_from_str(c.name, CHECK_NULL); + BOXED_LONG(value, c.value); + vmConstants->obj_at_put(insert++, name()); + vmConstants->obj_at_put(insert++, value); + } + assert(insert == len * 2, "must be"); + + len = JVMCIVMStructs::localHotSpotVMAddresses_count(); + objArrayHandle vmAddresses = oopFactory::new_objArray(SystemDictionary::Object_klass(), len * 2, CHECK_NULL); + for (int i = 0; i < len ; i++) { + VMAddressEntry a = JVMCIVMStructs::localHotSpotVMAddresses[i]; + Handle name = java_lang_String::create_from_str(a.name, CHECK_NULL); + BOXED_LONG(value, a.value); + vmAddresses->obj_at_put(i * 2, name()); + vmAddresses->obj_at_put(i * 2 + 1, value); + } + + // The last entry is the null entry. + len = (int) Flag::numFlags - 1; + objArrayHandle vmFlags = oopFactory::new_objArray(VMFlag::klass(), len, CHECK_NULL); + for (int i = 0; i < len; i++) { + Flag* flag = &Flag::flags[i]; + instanceHandle vmFlagObj = InstanceKlass::cast(VMFlag::klass())->allocate_instance_handle(CHECK_NULL); + Handle name = java_lang_String::create_from_str(flag->_name, CHECK_NULL); + Handle type = java_lang_String::create_from_str(flag->_type, CHECK_NULL); + VMFlag::set_name(vmFlagObj, name()); + VMFlag::set_type(vmFlagObj, type()); + if (flag->is_bool()) { + BOXED_LONG(value, flag->get_bool()); + VMFlag::set_value(vmFlagObj, value); + } else if (flag->is_ccstr()) { + Handle value = java_lang_String::create_from_str(flag->get_ccstr(), CHECK_NULL); + VMFlag::set_value(vmFlagObj, value()); + } else if (flag->is_int()) { + BOXED_LONG(value, flag->get_int()); + VMFlag::set_value(vmFlagObj, value); + } else if (flag->is_intx()) { + BOXED_LONG(value, flag->get_intx()); + VMFlag::set_value(vmFlagObj, value); + } else if (flag->is_uint()) { + BOXED_LONG(value, flag->get_uint()); + VMFlag::set_value(vmFlagObj, value); + } else if (flag->is_uint64_t()) { + BOXED_LONG(value, flag->get_uint64_t()); + VMFlag::set_value(vmFlagObj, value); + } else if (flag->is_uintx()) { + BOXED_LONG(value, flag->get_uintx()); + VMFlag::set_value(vmFlagObj, value); + } else if (flag->is_double()) { + BOXED_DOUBLE(value, flag->get_double()); + VMFlag::set_value(vmFlagObj, value); + } else if (flag->is_size_t()) { + BOXED_LONG(value, flag->get_size_t()); + VMFlag::set_value(vmFlagObj, value); + } else { + JVMCI_ERROR_NULL("VM flag %s has unsupported type %s", flag->_name, flag->_type); + } + vmFlags->obj_at_put(i, vmFlagObj()); + } + + objArrayOop data = oopFactory::new_objArray(SystemDictionary::Object_klass(), 5, CHECK_NULL); + data->obj_at_put(0, vmFields()); + data->obj_at_put(1, vmTypes()); + data->obj_at_put(2, vmConstants()); + data->obj_at_put(3, vmAddresses()); + data->obj_at_put(4, vmFlags()); + + return (jobjectArray) JNIHandles::make_local(THREAD, data); +#undef BOXED_LONG +#undef BOXED_DOUBLE C2V_END C2V_VMENTRY(jbyteArray, getBytecode, (JNIEnv *, jobject, jobject jvmci_method)) @@ -621,12 +695,12 @@ C2V_VMENTRY(jint, constantPoolRemapInstructionOperandFromCache, (JNIEnv*, jobjec return cp->remap_instruction_operand_from_cache(index); C2V_END -C2V_VMENTRY(jobject, resolveFieldInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint index, jbyte opcode, jlongArray info_handle)) +C2V_VMENTRY(jobject, resolveFieldInPool, (JNIEnv*, jobject, jobject jvmci_constant_pool, jint index, jobject jvmci_method, jbyte opcode, jlongArray info_handle)) ResourceMark rm; constantPoolHandle cp = CompilerToVM::asConstantPool(jvmci_constant_pool); Bytecodes::Code code = (Bytecodes::Code)(((int) opcode) & 0xFF); fieldDescriptor fd; - LinkInfo link_info(cp, index, CHECK_0); + LinkInfo link_info(cp, index, (jvmci_method != NULL) ? CompilerToVM::asMethod(jvmci_method) : NULL, CHECK_0); LinkResolver::resolve_field(fd, link_info, Bytecodes::java_code(code), false, CHECK_0); typeArrayOop info = (typeArrayOop) JNIHandles::resolve(info_handle); assert(info != NULL && info->length() == 2, "must be"); @@ -1438,7 +1512,7 @@ JNINativeMethod CompilerToVM::methods[] = { {CC "resolveConstantInPool", CC "(" HS_CONSTANT_POOL "I)" OBJECT, FN_PTR(resolveConstantInPool)}, {CC "resolvePossiblyCachedConstantInPool", CC "(" HS_CONSTANT_POOL "I)" OBJECT, FN_PTR(resolvePossiblyCachedConstantInPool)}, {CC "resolveTypeInPool", CC "(" HS_CONSTANT_POOL "I)" HS_RESOLVED_KLASS, FN_PTR(resolveTypeInPool)}, - {CC "resolveFieldInPool", CC "(" HS_CONSTANT_POOL "IB[J)" HS_RESOLVED_KLASS, FN_PTR(resolveFieldInPool)}, + {CC "resolveFieldInPool", CC "(" HS_CONSTANT_POOL "I" HS_RESOLVED_METHOD "B[J)" HS_RESOLVED_KLASS, FN_PTR(resolveFieldInPool)}, {CC "resolveInvokeDynamicInPool", CC "(" HS_CONSTANT_POOL "I)V", FN_PTR(resolveInvokeDynamicInPool)}, {CC "resolveInvokeHandleInPool", CC "(" HS_CONSTANT_POOL "I)V", FN_PTR(resolveInvokeHandleInPool)}, {CC "resolveMethod", CC "(" HS_RESOLVED_KLASS HS_RESOLVED_METHOD HS_RESOLVED_KLASS ")" HS_RESOLVED_METHOD, FN_PTR(resolveMethod)}, @@ -1450,7 +1524,7 @@ JNINativeMethod CompilerToVM::methods[] = { {CC "getResolvedJavaMethod", CC "(Ljava/lang/Object;J)" HS_RESOLVED_METHOD, FN_PTR(getResolvedJavaMethod)}, {CC "getConstantPool", CC "(Ljava/lang/Object;J)" HS_CONSTANT_POOL, FN_PTR(getConstantPool)}, {CC "getResolvedJavaType", CC "(Ljava/lang/Object;JZ)" HS_RESOLVED_KLASS, FN_PTR(getResolvedJavaType)}, - {CC "initializeConfiguration", CC "(" HS_CONFIG ")J", FN_PTR(initializeConfiguration)}, + {CC "readConfiguration", CC "()[" OBJECT, FN_PTR(readConfiguration)}, {CC "installCode", CC "(" TARGET_DESCRIPTION HS_COMPILED_CODE INSTALLED_CODE HS_SPECULATION_LOG ")I", FN_PTR(installCode)}, {CC "getMetadata", CC "(" TARGET_DESCRIPTION HS_COMPILED_CODE HS_METADATA ")I", FN_PTR(getMetadata)}, {CC "resetCompilationStatistics", CC "()V", FN_PTR(resetCompilationStatistics)}, diff --git a/hotspot/src/share/vm/jvmci/jvmciCompilerToVM.hpp b/hotspot/src/share/vm/jvmci/jvmciCompilerToVM.hpp index f6790375d64..2bbd2034795 100644 --- a/hotspot/src/share/vm/jvmci/jvmciCompilerToVM.hpp +++ b/hotspot/src/share/vm/jvmci/jvmciCompilerToVM.hpp @@ -59,6 +59,7 @@ class CompilerToVM { static bool _supports_inline_contig_alloc; static HeapWord** _heap_end_addr; static HeapWord** _heap_top_addr; + static int _max_oop_map_stack_offset; static jbyte* cardtable_start_address; static int cardtable_shift; @@ -75,6 +76,11 @@ class CompilerToVM { public: static void initialize(); + + static int max_oop_map_stack_offset() { + assert(_max_oop_map_stack_offset > 0, "must be initialized"); + return Data::_max_oop_map_stack_offset; + } }; public: diff --git a/hotspot/src/share/vm/jvmci/jvmciJavaClasses.hpp b/hotspot/src/share/vm/jvmci/jvmciJavaClasses.hpp index 312ae64b952..8f8f0715ef7 100644 --- a/hotspot/src/share/vm/jvmci/jvmciJavaClasses.hpp +++ b/hotspot/src/share/vm/jvmci/jvmciJavaClasses.hpp @@ -112,6 +112,18 @@ class JVMCIJavaClasses : AllStatic { start_class(HotSpotForeignCallTarget) \ long_field(HotSpotForeignCallTarget, address) \ end_class \ + start_class(VMField) \ + oop_field(VMField, name, "Ljava/lang/String;") \ + oop_field(VMField, type, "Ljava/lang/String;") \ + long_field(VMField, offset) \ + long_field(VMField, address) \ + oop_field(VMField, value, "Ljava/lang/Long;") \ + end_class \ + start_class(VMFlag) \ + oop_field(VMFlag, name, "Ljava/lang/String;") \ + oop_field(VMFlag, type, "Ljava/lang/String;") \ + oop_field(VMFlag, value, "Ljava/lang/Object;") \ + end_class \ start_class(Assumptions_NoFinalizableSubclass) \ oop_field(Assumptions_NoFinalizableSubclass, receiverType, "Ljdk/vm/ci/meta/ResolvedJavaType;") \ end_class \ diff --git a/hotspot/src/share/vm/jvmci/systemDictionary_jvmci.hpp b/hotspot/src/share/vm/jvmci/systemDictionary_jvmci.hpp index ae905169ef1..05f12fb84ed 100644 --- a/hotspot/src/share/vm/jvmci/systemDictionary_jvmci.hpp +++ b/hotspot/src/share/vm/jvmci/systemDictionary_jvmci.hpp @@ -49,6 +49,8 @@ do_klass(HotSpotJVMCIRuntime_klass, jdk_vm_ci_hotspot_HotSpotJVMCIRuntime, Jvmci) \ do_klass(HotSpotSpeculationLog_klass, jdk_vm_ci_hotspot_HotSpotSpeculationLog, Jvmci) \ do_klass(HotSpotCompilationRequestResult_klass, jdk_vm_ci_hotspot_HotSpotCompilationRequestResult, Jvmci) \ + do_klass(VMField_klass, jdk_vm_ci_hotspot_VMField, Jvmci) \ + do_klass(VMFlag_klass, jdk_vm_ci_hotspot_VMFlag, Jvmci) \ do_klass(Assumptions_ConcreteMethod_klass, jdk_vm_ci_meta_Assumptions_ConcreteMethod, Jvmci) \ do_klass(Assumptions_NoFinalizableSubclass_klass, jdk_vm_ci_meta_Assumptions_NoFinalizableSubclass, Jvmci) \ do_klass(Assumptions_ConcreteSubtype_klass, jdk_vm_ci_meta_Assumptions_ConcreteSubtype, Jvmci) \ diff --git a/hotspot/src/share/vm/jvmci/vmStructs_jvmci.cpp b/hotspot/src/share/vm/jvmci/vmStructs_jvmci.cpp index e35345b42a8..9244cd46cda 100644 --- a/hotspot/src/share/vm/jvmci/vmStructs_jvmci.cpp +++ b/hotspot/src/share/vm/jvmci/vmStructs_jvmci.cpp @@ -71,6 +71,8 @@ static_field(CompilerToVM::Data, _heap_end_addr, HeapWord**) \ static_field(CompilerToVM::Data, _heap_top_addr, HeapWord**) \ \ + static_field(CompilerToVM::Data, _max_oop_map_stack_offset, int) \ + \ static_field(CompilerToVM::Data, cardtable_start_address, jbyte*) \ static_field(CompilerToVM::Data, cardtable_shift, int) \ \ @@ -539,6 +541,8 @@ declare_function(SharedRuntime::exception_handler_for_return_address) \ declare_function(SharedRuntime::OSR_migration_end) \ declare_function(SharedRuntime::enable_stack_reserved_zone) \ + declare_function(SharedRuntime::frem) \ + declare_function(SharedRuntime::drem) \ \ declare_function(os::dll_load) \ declare_function(os::dll_lookup) \ @@ -733,22 +737,6 @@ #endif -// whole purpose of this function is to work around bug c++/27724 in gcc 4.1.1 -// with optimization turned on it doesn't affect produced code -static inline uint64_t cast_uint64_t(size_t x) -{ - return x; -} - -#define ASSIGN_CONST_TO_64BIT_VAR(var, expr) \ - JNIEXPORT uint64_t var = cast_uint64_t(expr); - -#define ASSIGN_OFFSET_TO_64BIT_VAR(var, type, field) \ - ASSIGN_CONST_TO_64BIT_VAR(var, offset_of(type, field)) - -#define ASSIGN_STRIDE_TO_64BIT_VAR(var, array) \ - ASSIGN_CONST_TO_64BIT_VAR(var, (char*)&array[1] - (char*)&array[0]) - // // Instantiation of VMStructEntries, VMTypeEntries and VMIntConstantEntries // @@ -871,37 +859,31 @@ VMAddressEntry JVMCIVMStructs::localHotSpotVMAddresses[] = { GENERATE_VM_ADDRESS_LAST_ENTRY() }; +int JVMCIVMStructs::localHotSpotVMStructs_count() { + // Ignore sentinel entry at the end + return (sizeof(localHotSpotVMStructs) / sizeof(VMStructEntry)) - 1; +} +int JVMCIVMStructs::localHotSpotVMTypes_count() { + // Ignore sentinel entry at the end + return (sizeof(localHotSpotVMTypes) / sizeof(VMTypeEntry)) - 1; +} +int JVMCIVMStructs::localHotSpotVMIntConstants_count() { + // Ignore sentinel entry at the end + return (sizeof(localHotSpotVMIntConstants) / sizeof(VMIntConstantEntry)) - 1; +} +int JVMCIVMStructs::localHotSpotVMLongConstants_count() { + // Ignore sentinel entry at the end + return (sizeof(localHotSpotVMLongConstants) / sizeof(VMLongConstantEntry)) - 1; +} +int JVMCIVMStructs::localHotSpotVMAddresses_count() { + // Ignore sentinel entry at the end + return (sizeof(localHotSpotVMAddresses) / sizeof(VMAddressEntry)) - 1; +} + extern "C" { JNIEXPORT VMStructEntry* jvmciHotSpotVMStructs = JVMCIVMStructs::localHotSpotVMStructs; -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMStructEntryTypeNameOffset, VMStructEntry, typeName); -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMStructEntryFieldNameOffset, VMStructEntry, fieldName); -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMStructEntryTypeStringOffset, VMStructEntry, typeString); -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMStructEntryIsStaticOffset, VMStructEntry, isStatic); -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMStructEntryOffsetOffset, VMStructEntry, offset); -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMStructEntryAddressOffset, VMStructEntry, address); -ASSIGN_STRIDE_TO_64BIT_VAR(jvmciHotSpotVMStructEntryArrayStride, jvmciHotSpotVMStructs); - JNIEXPORT VMTypeEntry* jvmciHotSpotVMTypes = JVMCIVMStructs::localHotSpotVMTypes; -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMTypeEntryTypeNameOffset, VMTypeEntry, typeName); -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMTypeEntrySuperclassNameOffset, VMTypeEntry, superclassName); -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMTypeEntryIsOopTypeOffset, VMTypeEntry, isOopType); -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMTypeEntryIsIntegerTypeOffset, VMTypeEntry, isIntegerType); -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMTypeEntryIsUnsignedOffset, VMTypeEntry, isUnsigned); -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMTypeEntrySizeOffset, VMTypeEntry, size); -ASSIGN_STRIDE_TO_64BIT_VAR(jvmciHotSpotVMTypeEntryArrayStride, jvmciHotSpotVMTypes); - JNIEXPORT VMIntConstantEntry* jvmciHotSpotVMIntConstants = JVMCIVMStructs::localHotSpotVMIntConstants; -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMIntConstantEntryNameOffset, VMIntConstantEntry, name); -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMIntConstantEntryValueOffset, VMIntConstantEntry, value); -ASSIGN_STRIDE_TO_64BIT_VAR(jvmciHotSpotVMIntConstantEntryArrayStride, jvmciHotSpotVMIntConstants); - JNIEXPORT VMLongConstantEntry* jvmciHotSpotVMLongConstants = JVMCIVMStructs::localHotSpotVMLongConstants; -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMLongConstantEntryNameOffset, VMLongConstantEntry, name); -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMLongConstantEntryValueOffset, VMLongConstantEntry, value); -ASSIGN_STRIDE_TO_64BIT_VAR(jvmciHotSpotVMLongConstantEntryArrayStride, jvmciHotSpotVMLongConstants); - JNIEXPORT VMAddressEntry* jvmciHotSpotVMAddresses = JVMCIVMStructs::localHotSpotVMAddresses; -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMAddressEntryNameOffset, VMAddressEntry, name); -ASSIGN_OFFSET_TO_64BIT_VAR(jvmciHotSpotVMAddressEntryValueOffset, VMAddressEntry, value); -ASSIGN_STRIDE_TO_64BIT_VAR(jvmciHotSpotVMAddressEntryArrayStride, jvmciHotSpotVMAddresses); } diff --git a/hotspot/src/share/vm/jvmci/vmStructs_jvmci.hpp b/hotspot/src/share/vm/jvmci/vmStructs_jvmci.hpp index 36bfe7289c9..bacfee0d984 100644 --- a/hotspot/src/share/vm/jvmci/vmStructs_jvmci.hpp +++ b/hotspot/src/share/vm/jvmci/vmStructs_jvmci.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -55,6 +55,12 @@ public: * Table of addresses. */ static VMAddressEntry localHotSpotVMAddresses[]; + + static int localHotSpotVMStructs_count(); + static int localHotSpotVMTypes_count(); + static int localHotSpotVMIntConstants_count(); + static int localHotSpotVMLongConstants_count(); + static int localHotSpotVMAddresses_count(); }; #endif // SHARE_VM_JVMCI_VMSTRUCTS_JVMCI_HPP diff --git a/hotspot/src/share/vm/jvmci/vmSymbols_jvmci.hpp b/hotspot/src/share/vm/jvmci/vmSymbols_jvmci.hpp index fe853aa9e91..70d4b99fb23 100644 --- a/hotspot/src/share/vm/jvmci/vmSymbols_jvmci.hpp +++ b/hotspot/src/share/vm/jvmci/vmSymbols_jvmci.hpp @@ -50,6 +50,8 @@ template(jdk_vm_ci_hotspot_HotSpotJVMCIRuntime, "jdk/vm/ci/hotspot/HotSpotJVMCIRuntime") \ template(jdk_vm_ci_hotspot_HotSpotSpeculationLog, "jdk/vm/ci/hotspot/HotSpotSpeculationLog") \ template(jdk_vm_ci_hotspot_HotSpotCompilationRequestResult, "jdk/vm/ci/hotspot/HotSpotCompilationRequestResult") \ + template(jdk_vm_ci_hotspot_VMField, "jdk/vm/ci/hotspot/VMField") \ + template(jdk_vm_ci_hotspot_VMFlag, "jdk/vm/ci/hotspot/VMFlag") \ template(jdk_vm_ci_meta_JavaConstant, "jdk/vm/ci/meta/JavaConstant") \ template(jdk_vm_ci_meta_PrimitiveConstant, "jdk/vm/ci/meta/PrimitiveConstant") \ template(jdk_vm_ci_meta_RawConstant, "jdk/vm/ci/meta/RawConstant") \ diff --git a/hotspot/src/share/vm/memory/allocation.inline.hpp b/hotspot/src/share/vm/memory/allocation.inline.hpp index 27c9c786fbc..5fe55f4a292 100644 --- a/hotspot/src/share/vm/memory/allocation.inline.hpp +++ b/hotspot/src/share/vm/memory/allocation.inline.hpp @@ -28,6 +28,7 @@ #include "runtime/atomic.inline.hpp" #include "runtime/os.hpp" #include "services/memTracker.hpp" +#include "utilities/globalDefinitions.hpp" // Explicit C-heap memory management @@ -63,18 +64,12 @@ inline char* AllocateHeap(size_t size, MEMFLAGS flags, return p; } -#ifdef __GNUC__ -__attribute__((always_inline)) -#endif -inline char* AllocateHeap(size_t size, MEMFLAGS flags, +ALWAYSINLINE char* AllocateHeap(size_t size, MEMFLAGS flags, AllocFailType alloc_failmode = AllocFailStrategy::EXIT_OOM) { return AllocateHeap(size, flags, CURRENT_PC, alloc_failmode); } -#ifdef __GNUC__ -__attribute__((always_inline)) -#endif -inline char* ReallocateHeap(char *old, size_t size, MEMFLAGS flag, +ALWAYSINLINE char* ReallocateHeap(char *old, size_t size, MEMFLAGS flag, AllocFailType alloc_failmode = AllocFailStrategy::EXIT_OOM) { char* p = (char*) os::realloc(old, size, flag, CURRENT_PC); #ifdef ASSERT diff --git a/hotspot/src/share/vm/memory/universe.cpp b/hotspot/src/share/vm/memory/universe.cpp index 9c17574bed9..a3dff52548f 100644 --- a/hotspot/src/share/vm/memory/universe.cpp +++ b/hotspot/src/share/vm/memory/universe.cpp @@ -1070,13 +1070,13 @@ void Universe::compute_base_vtable_size() { } void Universe::print_on(outputStream* st) { + GCMutexLocker hl(Heap_lock); // Heap_lock might be locked by caller thread. st->print_cr("Heap"); heap()->print_on(st); } void Universe::print_heap_at_SIGBREAK() { if (PrintHeapAtSIGBREAK) { - MutexLocker hl(Heap_lock); print_on(tty); tty->cr(); tty->flush(); diff --git a/hotspot/src/share/vm/oops/constantPool.cpp b/hotspot/src/share/vm/oops/constantPool.cpp index 29110089d3b..d50351e1b9e 100644 --- a/hotspot/src/share/vm/oops/constantPool.cpp +++ b/hotspot/src/share/vm/oops/constantPool.cpp @@ -691,16 +691,21 @@ oop ConstantPool::resolve_constant_at_impl(const constantPoolHandle& this_cp, in ref_kind, index, this_cp->method_handle_index_at(index), callee_index, name->as_C_string(), signature->as_C_string()); } - KlassHandle callee; - { Klass* k = klass_at_impl(this_cp, callee_index, true, CHECK_NULL); - callee = KlassHandle(THREAD, k); - } + + Klass* k = klass_at_impl(this_cp, callee_index, true, CHECK_NULL); + KlassHandle callee(THREAD, k); + + // Check constant pool method consistency if ((callee->is_interface() && m_tag.is_method()) || - (!callee->is_interface() && m_tag.is_interface_method())) { + ((!callee->is_interface() && m_tag.is_interface_method()))) { ResourceMark rm(THREAD); - char buf[200]; - jio_snprintf(buf, sizeof(buf), "Inconsistent constant data for %s.%s%s at index %d", - callee->name()->as_C_string(), name->as_C_string(), signature->as_C_string(), index); + char buf[400]; + jio_snprintf(buf, sizeof(buf), + "Inconsistent constant pool data in classfile for class %s. " + "Method %s%s at index %d is %s and should be %s", + callee->name()->as_C_string(), name->as_C_string(), signature->as_C_string(), index, + callee->is_interface() ? "CONSTANT_MethodRef" : "CONSTANT_InterfaceMethodRef", + callee->is_interface() ? "CONSTANT_InterfaceMethodRef" : "CONSTANT_MethodRef"); THROW_MSG_NULL(vmSymbols::java_lang_IncompatibleClassChangeError(), buf); } diff --git a/hotspot/src/share/vm/oops/cpCache.hpp b/hotspot/src/share/vm/oops/cpCache.hpp index 840177a10cd..e58d7c16ceb 100644 --- a/hotspot/src/share/vm/oops/cpCache.hpp +++ b/hotspot/src/share/vm/oops/cpCache.hpp @@ -193,7 +193,7 @@ class ConstantPoolCacheEntry VALUE_OBJ_CLASS_SPEC { field_index_mask = right_n_bits(field_index_bits), parameter_size_bits = 8, // subset of field_index_mask, range is 0..255 parameter_size_mask = right_n_bits(parameter_size_bits), - option_bits_mask = ~(((-1) << tos_state_shift) | (field_index_mask | parameter_size_mask)) + option_bits_mask = ~(((~0u) << tos_state_shift) | (field_index_mask | parameter_size_mask)) }; // specific bit definitions for the indices field: diff --git a/hotspot/src/share/vm/oops/instanceKlass.cpp b/hotspot/src/share/vm/oops/instanceKlass.cpp index eb2d48e8900..7d15ab37c49 100644 --- a/hotspot/src/share/vm/oops/instanceKlass.cpp +++ b/hotspot/src/share/vm/oops/instanceKlass.cpp @@ -1961,6 +1961,11 @@ void InstanceKlass::remove_unshareable_info() { m->remove_unshareable_info(); } + // cached_class_file might be pointing to a malloc'ed buffer allocated by + // event-based tracing code at CDS dump time. It's not usable at runtime + // so let's clear it. + set_cached_class_file(NULL); + // do array classes also. array_klasses_do(remove_unshareable_in_class); } diff --git a/hotspot/src/share/vm/oops/klass.cpp b/hotspot/src/share/vm/oops/klass.cpp index d31e9e5706c..d7fb8924e71 100644 --- a/hotspot/src/share/vm/oops/klass.cpp +++ b/hotspot/src/share/vm/oops/klass.cpp @@ -482,6 +482,7 @@ void Klass::oops_do(OopClosure* cl) { void Klass::remove_unshareable_info() { assert (DumpSharedSpaces, "only called for DumpSharedSpaces"); + TRACE_REMOVE_KLASS_ID(this); set_subklass(NULL); set_next_sibling(NULL); @@ -494,7 +495,8 @@ void Klass::remove_unshareable_info() { } void Klass::restore_unshareable_info(ClassLoaderData* loader_data, Handle protection_domain, TRAPS) { - TRACE_INIT_KLASS_ID(this); + TRACE_RESTORE_KLASS_ID(this); + // If an exception happened during CDS restore, some of these fields may already be // set. We leave the class on the CLD list, even if incomplete so that we don't // modify the CLD list outside a safepoint. diff --git a/hotspot/src/share/vm/oops/method.cpp b/hotspot/src/share/vm/oops/method.cpp index 8e7f9c8b42e..1a33bab678f 100644 --- a/hotspot/src/share/vm/oops/method.cpp +++ b/hotspot/src/share/vm/oops/method.cpp @@ -627,7 +627,7 @@ bool Method::is_constant_getter() const { } bool Method::is_initializer() const { - return name() == vmSymbols::object_initializer_name() || is_static_initializer(); + return is_object_initializer() || is_static_initializer(); } bool Method::has_valid_initializer_flags() const { @@ -643,6 +643,9 @@ bool Method::is_static_initializer() const { has_valid_initializer_flags(); } +bool Method::is_object_initializer() const { + return name() == vmSymbols::object_initializer_name(); +} objArrayHandle Method::resolved_checked_exceptions_impl(Method* method, TRAPS) { int length = method->checked_exceptions_length(); diff --git a/hotspot/src/share/vm/oops/method.hpp b/hotspot/src/share/vm/oops/method.hpp index f1bbf9ea84f..5a635f8935f 100644 --- a/hotspot/src/share/vm/oops/method.hpp +++ b/hotspot/src/share/vm/oops/method.hpp @@ -638,6 +638,9 @@ class Method : public Metadata { // valid static initializer flags. bool is_static_initializer() const; + // returns true if the method name is + bool is_object_initializer() const; + // compiled code support // NOTE: code() is inherently racy as deopt can be clearing code // simultaneously. Use with caution. diff --git a/hotspot/src/share/vm/opto/c2_globals.hpp b/hotspot/src/share/vm/opto/c2_globals.hpp index 83229dd7b27..686615a6396 100644 --- a/hotspot/src/share/vm/opto/c2_globals.hpp +++ b/hotspot/src/share/vm/opto/c2_globals.hpp @@ -73,10 +73,10 @@ constraint, \ writeable) \ \ - develop(bool, StressLCM, false, \ + diagnostic(bool, StressLCM, false, \ "Randomize instruction scheduling in LCM") \ \ - develop(bool, StressGCM, false, \ + diagnostic(bool, StressGCM, false, \ "Randomize instruction scheduling in GCM") \ \ develop(intx, OptoPrologueNops, 0, \ diff --git a/hotspot/src/share/vm/opto/c2compiler.cpp b/hotspot/src/share/vm/opto/c2compiler.cpp index a91b1c2f6e0..c80ca6eaa8c 100644 --- a/hotspot/src/share/vm/opto/c2compiler.cpp +++ b/hotspot/src/share/vm/opto/c2compiler.cpp @@ -256,6 +256,7 @@ bool C2Compiler::is_intrinsic_supported(const methodHandle& method, bool is_virt case vmIntrinsics::_weakCompareAndSwapObject: case vmIntrinsics::_weakCompareAndSwapObjectAcquire: case vmIntrinsics::_weakCompareAndSwapObjectRelease: + case vmIntrinsics::_weakCompareAndSwapObjectVolatile: #ifdef _LP64 if ( UseCompressedOops && !Matcher::match_rule_supported(Op_WeakCompareAndSwapN)) return false; if (!UseCompressedOops && !Matcher::match_rule_supported(Op_WeakCompareAndSwapP)) return false; @@ -270,6 +271,7 @@ bool C2Compiler::is_intrinsic_supported(const methodHandle& method, bool is_virt case vmIntrinsics::_weakCompareAndSwapLong: case vmIntrinsics::_weakCompareAndSwapLongAcquire: case vmIntrinsics::_weakCompareAndSwapLongRelease: + case vmIntrinsics::_weakCompareAndSwapLongVolatile: if (!Matcher::match_rule_supported(Op_WeakCompareAndSwapL)) return false; break; @@ -280,9 +282,32 @@ bool C2Compiler::is_intrinsic_supported(const methodHandle& method, bool is_virt case vmIntrinsics::_weakCompareAndSwapInt: case vmIntrinsics::_weakCompareAndSwapIntAcquire: case vmIntrinsics::_weakCompareAndSwapIntRelease: + case vmIntrinsics::_weakCompareAndSwapIntVolatile: if (!Matcher::match_rule_supported(Op_WeakCompareAndSwapL)) return false; break; + /* CompareAndSwap, Byte: */ + case vmIntrinsics::_compareAndSwapByte: + if (!Matcher::match_rule_supported(Op_CompareAndSwapB)) return false; + break; + case vmIntrinsics::_weakCompareAndSwapByte: + case vmIntrinsics::_weakCompareAndSwapByteAcquire: + case vmIntrinsics::_weakCompareAndSwapByteRelease: + case vmIntrinsics::_weakCompareAndSwapByteVolatile: + if (!Matcher::match_rule_supported(Op_WeakCompareAndSwapB)) return false; + break; + + /* CompareAndSwap, Short: */ + case vmIntrinsics::_compareAndSwapShort: + if (!Matcher::match_rule_supported(Op_CompareAndSwapS)) return false; + break; + case vmIntrinsics::_weakCompareAndSwapShort: + case vmIntrinsics::_weakCompareAndSwapShortAcquire: + case vmIntrinsics::_weakCompareAndSwapShortRelease: + case vmIntrinsics::_weakCompareAndSwapShortVolatile: + if (!Matcher::match_rule_supported(Op_WeakCompareAndSwapS)) return false; + break; + /* CompareAndExchange, Object: */ case vmIntrinsics::_compareAndExchangeObjectVolatile: case vmIntrinsics::_compareAndExchangeObjectAcquire: @@ -309,12 +334,39 @@ bool C2Compiler::is_intrinsic_supported(const methodHandle& method, bool is_virt if (!Matcher::match_rule_supported(Op_CompareAndExchangeI)) return false; break; + /* CompareAndExchange, Byte: */ + case vmIntrinsics::_compareAndExchangeByteVolatile: + case vmIntrinsics::_compareAndExchangeByteAcquire: + case vmIntrinsics::_compareAndExchangeByteRelease: + if (!Matcher::match_rule_supported(Op_CompareAndExchangeB)) return false; + break; + + /* CompareAndExchange, Short: */ + case vmIntrinsics::_compareAndExchangeShortVolatile: + case vmIntrinsics::_compareAndExchangeShortAcquire: + case vmIntrinsics::_compareAndExchangeShortRelease: + if (!Matcher::match_rule_supported(Op_CompareAndExchangeS)) return false; + break; + + case vmIntrinsics::_getAndAddByte: + if (!Matcher::match_rule_supported(Op_GetAndAddB)) return false; + break; + case vmIntrinsics::_getAndAddShort: + if (!Matcher::match_rule_supported(Op_GetAndAddS)) return false; + break; case vmIntrinsics::_getAndAddInt: if (!Matcher::match_rule_supported(Op_GetAndAddI)) return false; break; case vmIntrinsics::_getAndAddLong: if (!Matcher::match_rule_supported(Op_GetAndAddL)) return false; break; + + case vmIntrinsics::_getAndSetByte: + if (!Matcher::match_rule_supported(Op_GetAndSetB)) return false; + break; + case vmIntrinsics::_getAndSetShort: + if (!Matcher::match_rule_supported(Op_GetAndSetS)) return false; + break; case vmIntrinsics::_getAndSetInt: if (!Matcher::match_rule_supported(Op_GetAndSetI)) return false; break; diff --git a/hotspot/src/share/vm/opto/classes.hpp b/hotspot/src/share/vm/opto/classes.hpp index 790f4f499be..eab270ee399 100644 --- a/hotspot/src/share/vm/opto/classes.hpp +++ b/hotspot/src/share/vm/opto/classes.hpp @@ -81,20 +81,30 @@ macro(CmpL3) macro(CmpLTMask) macro(CmpP) macro(CmpU) +macro(CompareAndSwapB) +macro(CompareAndSwapS) macro(CompareAndSwapI) macro(CompareAndSwapL) macro(CompareAndSwapP) macro(CompareAndSwapN) +macro(WeakCompareAndSwapB) +macro(WeakCompareAndSwapS) macro(WeakCompareAndSwapI) macro(WeakCompareAndSwapL) macro(WeakCompareAndSwapP) macro(WeakCompareAndSwapN) +macro(CompareAndExchangeB) +macro(CompareAndExchangeS) macro(CompareAndExchangeI) macro(CompareAndExchangeL) macro(CompareAndExchangeP) macro(CompareAndExchangeN) +macro(GetAndAddB) +macro(GetAndAddS) macro(GetAndAddI) macro(GetAndAddL) +macro(GetAndSetB) +macro(GetAndSetS) macro(GetAndSetI) macro(GetAndSetL) macro(GetAndSetP) diff --git a/hotspot/src/share/vm/opto/compile.cpp b/hotspot/src/share/vm/opto/compile.cpp index 5e1e50ef6af..9946071c5f0 100644 --- a/hotspot/src/share/vm/opto/compile.cpp +++ b/hotspot/src/share/vm/opto/compile.cpp @@ -778,7 +778,7 @@ Compile::Compile( ciEnv* ci_env, C2Compiler* compiler, ciMethod* target, int osr } if (failing()) return; if (cg == NULL) { - record_method_not_compilable_all_tiers("cannot parse method"); + record_method_not_compilable("cannot parse method"); return; } JVMState* jvms = build_start_state(start(), tf()); @@ -2794,20 +2794,30 @@ void Compile::final_graph_reshaping_impl( Node *n, Final_Reshape_Counts &frc) { case Op_StoreL: case Op_StoreIConditional: case Op_StoreLConditional: + case Op_CompareAndSwapB: + case Op_CompareAndSwapS: case Op_CompareAndSwapI: case Op_CompareAndSwapL: case Op_CompareAndSwapP: case Op_CompareAndSwapN: + case Op_WeakCompareAndSwapB: + case Op_WeakCompareAndSwapS: case Op_WeakCompareAndSwapI: case Op_WeakCompareAndSwapL: case Op_WeakCompareAndSwapP: case Op_WeakCompareAndSwapN: + case Op_CompareAndExchangeB: + case Op_CompareAndExchangeS: case Op_CompareAndExchangeI: case Op_CompareAndExchangeL: case Op_CompareAndExchangeP: case Op_CompareAndExchangeN: + case Op_GetAndAddS: + case Op_GetAndAddB: case Op_GetAndAddI: case Op_GetAndAddL: + case Op_GetAndSetS: + case Op_GetAndSetB: case Op_GetAndSetI: case Op_GetAndSetL: case Op_GetAndSetP: diff --git a/hotspot/src/share/vm/opto/compile.hpp b/hotspot/src/share/vm/opto/compile.hpp index f8743d86ba9..79575dc3e91 100644 --- a/hotspot/src/share/vm/opto/compile.hpp +++ b/hotspot/src/share/vm/opto/compile.hpp @@ -823,16 +823,12 @@ class Compile : public Phase { } void record_failure(const char* reason); - void record_method_not_compilable(const char* reason, bool all_tiers = false) { - // All bailouts cover "all_tiers" when TieredCompilation is off. - if (!TieredCompilation) all_tiers = true; - env()->record_method_not_compilable(reason, all_tiers); + void record_method_not_compilable(const char* reason) { + // Bailouts cover "all_tiers" when TieredCompilation is off. + env()->record_method_not_compilable(reason, !TieredCompilation); // Record failure reason. record_failure(reason); } - void record_method_not_compilable_all_tiers(const char* reason) { - record_method_not_compilable(reason, true); - } bool check_node_count(uint margin, const char* reason) { if (live_nodes() + margin > max_node_limit()) { record_method_not_compilable(reason); diff --git a/hotspot/src/share/vm/opto/library_call.cpp b/hotspot/src/share/vm/opto/library_call.cpp index 12c59133a7d..cf1e506cf58 100644 --- a/hotspot/src/share/vm/opto/library_call.cpp +++ b/hotspot/src/share/vm/opto/library_call.cpp @@ -645,6 +645,8 @@ bool LibraryCallKit::try_to_inline(int predicate) { case vmIntrinsics::_putDoubleOpaque: return inline_unsafe_access( is_store, T_DOUBLE, Opaque, false); case vmIntrinsics::_compareAndSwapObject: return inline_unsafe_load_store(T_OBJECT, LS_cmp_swap, Volatile); + case vmIntrinsics::_compareAndSwapByte: return inline_unsafe_load_store(T_BYTE, LS_cmp_swap, Volatile); + case vmIntrinsics::_compareAndSwapShort: return inline_unsafe_load_store(T_SHORT, LS_cmp_swap, Volatile); case vmIntrinsics::_compareAndSwapInt: return inline_unsafe_load_store(T_INT, LS_cmp_swap, Volatile); case vmIntrinsics::_compareAndSwapLong: return inline_unsafe_load_store(T_LONG, LS_cmp_swap, Volatile); @@ -652,6 +654,14 @@ bool LibraryCallKit::try_to_inline(int predicate) { case vmIntrinsics::_weakCompareAndSwapObjectAcquire: return inline_unsafe_load_store(T_OBJECT, LS_cmp_swap_weak, Acquire); case vmIntrinsics::_weakCompareAndSwapObjectRelease: return inline_unsafe_load_store(T_OBJECT, LS_cmp_swap_weak, Release); case vmIntrinsics::_weakCompareAndSwapObjectVolatile: return inline_unsafe_load_store(T_OBJECT, LS_cmp_swap_weak, Volatile); + case vmIntrinsics::_weakCompareAndSwapByte: return inline_unsafe_load_store(T_BYTE, LS_cmp_swap_weak, Relaxed); + case vmIntrinsics::_weakCompareAndSwapByteAcquire: return inline_unsafe_load_store(T_BYTE, LS_cmp_swap_weak, Acquire); + case vmIntrinsics::_weakCompareAndSwapByteRelease: return inline_unsafe_load_store(T_BYTE, LS_cmp_swap_weak, Release); + case vmIntrinsics::_weakCompareAndSwapByteVolatile: return inline_unsafe_load_store(T_BYTE, LS_cmp_swap_weak, Volatile); + case vmIntrinsics::_weakCompareAndSwapShort: return inline_unsafe_load_store(T_SHORT, LS_cmp_swap_weak, Relaxed); + case vmIntrinsics::_weakCompareAndSwapShortAcquire: return inline_unsafe_load_store(T_SHORT, LS_cmp_swap_weak, Acquire); + case vmIntrinsics::_weakCompareAndSwapShortRelease: return inline_unsafe_load_store(T_SHORT, LS_cmp_swap_weak, Release); + case vmIntrinsics::_weakCompareAndSwapShortVolatile: return inline_unsafe_load_store(T_SHORT, LS_cmp_swap_weak, Volatile); case vmIntrinsics::_weakCompareAndSwapInt: return inline_unsafe_load_store(T_INT, LS_cmp_swap_weak, Relaxed); case vmIntrinsics::_weakCompareAndSwapIntAcquire: return inline_unsafe_load_store(T_INT, LS_cmp_swap_weak, Acquire); case vmIntrinsics::_weakCompareAndSwapIntRelease: return inline_unsafe_load_store(T_INT, LS_cmp_swap_weak, Release); @@ -664,6 +674,12 @@ bool LibraryCallKit::try_to_inline(int predicate) { case vmIntrinsics::_compareAndExchangeObjectVolatile: return inline_unsafe_load_store(T_OBJECT, LS_cmp_exchange, Volatile); case vmIntrinsics::_compareAndExchangeObjectAcquire: return inline_unsafe_load_store(T_OBJECT, LS_cmp_exchange, Acquire); case vmIntrinsics::_compareAndExchangeObjectRelease: return inline_unsafe_load_store(T_OBJECT, LS_cmp_exchange, Release); + case vmIntrinsics::_compareAndExchangeByteVolatile: return inline_unsafe_load_store(T_BYTE, LS_cmp_exchange, Volatile); + case vmIntrinsics::_compareAndExchangeByteAcquire: return inline_unsafe_load_store(T_BYTE, LS_cmp_exchange, Acquire); + case vmIntrinsics::_compareAndExchangeByteRelease: return inline_unsafe_load_store(T_BYTE, LS_cmp_exchange, Release); + case vmIntrinsics::_compareAndExchangeShortVolatile: return inline_unsafe_load_store(T_SHORT, LS_cmp_exchange, Volatile); + case vmIntrinsics::_compareAndExchangeShortAcquire: return inline_unsafe_load_store(T_SHORT, LS_cmp_exchange, Acquire); + case vmIntrinsics::_compareAndExchangeShortRelease: return inline_unsafe_load_store(T_SHORT, LS_cmp_exchange, Release); case vmIntrinsics::_compareAndExchangeIntVolatile: return inline_unsafe_load_store(T_INT, LS_cmp_exchange, Volatile); case vmIntrinsics::_compareAndExchangeIntAcquire: return inline_unsafe_load_store(T_INT, LS_cmp_exchange, Acquire); case vmIntrinsics::_compareAndExchangeIntRelease: return inline_unsafe_load_store(T_INT, LS_cmp_exchange, Release); @@ -671,8 +687,13 @@ bool LibraryCallKit::try_to_inline(int predicate) { case vmIntrinsics::_compareAndExchangeLongAcquire: return inline_unsafe_load_store(T_LONG, LS_cmp_exchange, Acquire); case vmIntrinsics::_compareAndExchangeLongRelease: return inline_unsafe_load_store(T_LONG, LS_cmp_exchange, Release); + case vmIntrinsics::_getAndAddByte: return inline_unsafe_load_store(T_BYTE, LS_get_add, Volatile); + case vmIntrinsics::_getAndAddShort: return inline_unsafe_load_store(T_SHORT, LS_get_add, Volatile); case vmIntrinsics::_getAndAddInt: return inline_unsafe_load_store(T_INT, LS_get_add, Volatile); case vmIntrinsics::_getAndAddLong: return inline_unsafe_load_store(T_LONG, LS_get_add, Volatile); + + case vmIntrinsics::_getAndSetByte: return inline_unsafe_load_store(T_BYTE, LS_get_set, Volatile); + case vmIntrinsics::_getAndSetShort: return inline_unsafe_load_store(T_SHORT, LS_get_set, Volatile); case vmIntrinsics::_getAndSetInt: return inline_unsafe_load_store(T_INT, LS_get_set, Volatile); case vmIntrinsics::_getAndSetLong: return inline_unsafe_load_store(T_LONG, LS_get_set, Volatile); case vmIntrinsics::_getAndSetObject: return inline_unsafe_load_store(T_OBJECT, LS_get_set, Volatile); @@ -2849,6 +2870,48 @@ bool LibraryCallKit::inline_unsafe_load_store(const BasicType type, const LoadSt // longs, and Object. Adding others should be straightforward. Node* load_store = NULL; switch(type) { + case T_BYTE: + switch(kind) { + case LS_get_add: + load_store = _gvn.transform(new GetAndAddBNode(control(), mem, adr, newval, adr_type)); + break; + case LS_get_set: + load_store = _gvn.transform(new GetAndSetBNode(control(), mem, adr, newval, adr_type)); + break; + case LS_cmp_swap_weak: + load_store = _gvn.transform(new WeakCompareAndSwapBNode(control(), mem, adr, newval, oldval, mo)); + break; + case LS_cmp_swap: + load_store = _gvn.transform(new CompareAndSwapBNode(control(), mem, adr, newval, oldval, mo)); + break; + case LS_cmp_exchange: + load_store = _gvn.transform(new CompareAndExchangeBNode(control(), mem, adr, newval, oldval, adr_type, mo)); + break; + default: + ShouldNotReachHere(); + } + break; + case T_SHORT: + switch(kind) { + case LS_get_add: + load_store = _gvn.transform(new GetAndAddSNode(control(), mem, adr, newval, adr_type)); + break; + case LS_get_set: + load_store = _gvn.transform(new GetAndSetSNode(control(), mem, adr, newval, adr_type)); + break; + case LS_cmp_swap_weak: + load_store = _gvn.transform(new WeakCompareAndSwapSNode(control(), mem, adr, newval, oldval, mo)); + break; + case LS_cmp_swap: + load_store = _gvn.transform(new CompareAndSwapSNode(control(), mem, adr, newval, oldval, mo)); + break; + case LS_cmp_exchange: + load_store = _gvn.transform(new CompareAndExchangeSNode(control(), mem, adr, newval, oldval, adr_type, mo)); + break; + default: + ShouldNotReachHere(); + } + break; case T_INT: switch(kind) { case LS_get_add: diff --git a/hotspot/src/share/vm/opto/loopTransform.cpp b/hotspot/src/share/vm/opto/loopTransform.cpp index 7e33dc3dd84..282c5c11de2 100644 --- a/hotspot/src/share/vm/opto/loopTransform.cpp +++ b/hotspot/src/share/vm/opto/loopTransform.cpp @@ -868,7 +868,7 @@ bool IdealLoopTree::policy_range_check( PhaseIdealLoop *phase ) const { Node *bol = iff->in(1); if (bol->req() != 2) continue; // dead constant test if (!bol->is_Bool()) { - assert(UseLoopPredicate && bol->Opcode() == Op_Conv2B, "predicate check only"); + assert(bol->Opcode() == Op_Conv2B, "predicate check only"); continue; } if (bol->as_Bool()->_test._test == BoolTest::ne) @@ -1760,14 +1760,6 @@ void PhaseIdealLoop::mark_reductions(IdealLoopTree *loop) { } } -//------------------------------dominates_backedge--------------------------------- -// Returns true if ctrl is executed on every complete iteration -bool IdealLoopTree::dominates_backedge(Node* ctrl) { - assert(ctrl->is_CFG(), "must be control"); - Node* backedge = _head->as_Loop()->in(LoopNode::LoopBackControl); - return _phase->dom_lca_internal(ctrl, backedge) == ctrl; -} - //------------------------------adjust_limit----------------------------------- // Helper function for add_constraint(). Node* PhaseIdealLoop::adjust_limit(int stride_con, Node * scale, Node *offset, Node *rc_limit, Node *loop_limit, Node *pre_ctrl) { @@ -2187,10 +2179,8 @@ int PhaseIdealLoop::do_range_check( IdealLoopTree *loop, Node_List &old_new ) { if( b_test._test == BoolTest::lt ) { // Range checks always use lt // The underflow and overflow limits: 0 <= scale*I+offset < limit add_constraint( stride_con, scale_con, offset, zero, limit, pre_ctrl, &pre_limit, &main_limit ); - if (!conditional_rc) { - // (0-offset)/scale could be outside of loop iterations range. - conditional_rc = !loop->dominates_backedge(iff); - } + // (0-offset)/scale could be outside of loop iterations range. + conditional_rc = true; } else { if (PrintOpto) { tty->print_cr("missed RCE opportunity"); @@ -2221,12 +2211,10 @@ int PhaseIdealLoop::do_range_check( IdealLoopTree *loop, Node_List &old_new ) { // Note: (MIN_INT+1 == -MAX_INT) is used instead of MIN_INT here // to avoid problem with scale == -1: MIN_INT/(-1) == MIN_INT. add_constraint( stride_con, scale_con, offset, mini, limit, pre_ctrl, &pre_limit, &main_limit ); - if (!conditional_rc) { - // ((MIN_INT+1)-offset)/scale could be outside of loop iterations range. - // Note: negative offset is replaced with 0 but (MIN_INT+1)/scale could - // still be outside of loop range. - conditional_rc = !loop->dominates_backedge(iff); - } + // ((MIN_INT+1)-offset)/scale could be outside of loop iterations range. + // Note: negative offset is replaced with 0 but (MIN_INT+1)/scale could + // still be outside of loop range. + conditional_rc = true; break; default: if (PrintOpto) { @@ -2484,14 +2472,20 @@ void IdealLoopTree::adjust_loop_exit_prob( PhaseIdealLoop *phase ) { ((bol->in(1)->Opcode() == Op_StorePConditional ) || (bol->in(1)->Opcode() == Op_StoreIConditional ) || (bol->in(1)->Opcode() == Op_StoreLConditional ) || + (bol->in(1)->Opcode() == Op_CompareAndExchangeB ) || + (bol->in(1)->Opcode() == Op_CompareAndExchangeS ) || (bol->in(1)->Opcode() == Op_CompareAndExchangeI ) || (bol->in(1)->Opcode() == Op_CompareAndExchangeL ) || (bol->in(1)->Opcode() == Op_CompareAndExchangeP ) || (bol->in(1)->Opcode() == Op_CompareAndExchangeN ) || + (bol->in(1)->Opcode() == Op_WeakCompareAndSwapB ) || + (bol->in(1)->Opcode() == Op_WeakCompareAndSwapS ) || (bol->in(1)->Opcode() == Op_WeakCompareAndSwapI ) || (bol->in(1)->Opcode() == Op_WeakCompareAndSwapL ) || (bol->in(1)->Opcode() == Op_WeakCompareAndSwapP ) || (bol->in(1)->Opcode() == Op_WeakCompareAndSwapN ) || + (bol->in(1)->Opcode() == Op_CompareAndSwapB ) || + (bol->in(1)->Opcode() == Op_CompareAndSwapS ) || (bol->in(1)->Opcode() == Op_CompareAndSwapI ) || (bol->in(1)->Opcode() == Op_CompareAndSwapL ) || (bol->in(1)->Opcode() == Op_CompareAndSwapP ) || diff --git a/hotspot/src/share/vm/opto/loopnode.cpp b/hotspot/src/share/vm/opto/loopnode.cpp index 4068e27bf90..7862a71a164 100644 --- a/hotspot/src/share/vm/opto/loopnode.cpp +++ b/hotspot/src/share/vm/opto/loopnode.cpp @@ -2225,9 +2225,7 @@ void PhaseIdealLoop::build_and_optimize(bool do_split_ifs, bool skip_loop_opts) // Some parser-inserted loop predicates could never be used by loop // predication or they were moved away from loop during some optimizations. // For example, peeling. Eliminate them before next loop optimizations. - if (UseLoopPredicate) { - eliminate_useless_predicates(); - } + eliminate_useless_predicates(); #ifndef PRODUCT C->verify_graph_edges(); diff --git a/hotspot/src/share/vm/opto/loopnode.hpp b/hotspot/src/share/vm/opto/loopnode.hpp index ba83e503178..1e215096c1e 100644 --- a/hotspot/src/share/vm/opto/loopnode.hpp +++ b/hotspot/src/share/vm/opto/loopnode.hpp @@ -468,9 +468,6 @@ public: // Check for Node being a loop-breaking test Node *is_loop_exit(Node *iff) const; - // Returns true if ctrl is executed on every complete iteration - bool dominates_backedge(Node* ctrl); - // Remove simplistic dead code from loop body void DCE_loop_body(); diff --git a/hotspot/src/share/vm/opto/matcher.cpp b/hotspot/src/share/vm/opto/matcher.cpp index ed06b1e7459..963c56fc833 100644 --- a/hotspot/src/share/vm/opto/matcher.cpp +++ b/hotspot/src/share/vm/opto/matcher.cpp @@ -124,7 +124,7 @@ OptoReg::Name Matcher::warp_incoming_stk_arg( VMReg reg ) { _in_arg_limit = OptoReg::add(warped, 1); // Bump max stack slot seen if (!RegMask::can_represent_arg(warped)) { // the compiler cannot represent this method's calling sequence - C->record_method_not_compilable_all_tiers("unsupported incoming calling sequence"); + C->record_method_not_compilable("unsupported incoming calling sequence"); return OptoReg::Bad; } return warped; @@ -1120,7 +1120,7 @@ OptoReg::Name Matcher::warp_outgoing_stk_arg( VMReg reg, OptoReg::Name begin_out if( warped >= out_arg_limit_per_call ) out_arg_limit_per_call = OptoReg::add(warped,1); if (!RegMask::can_represent_arg(warped)) { - C->record_method_not_compilable_all_tiers("unsupported calling sequence"); + C->record_method_not_compilable("unsupported calling sequence"); return OptoReg::Bad; } return warped; @@ -1300,7 +1300,7 @@ MachNode *Matcher::match_sfpt( SafePointNode *sfpt ) { uint r_cnt = mcall->tf()->range()->cnt(); MachProjNode *proj = new MachProjNode( mcall, r_cnt+10000, RegMask::Empty, MachProjNode::fat_proj ); if (!RegMask::can_represent_arg(OptoReg::Name(out_arg_limit_per_call-1))) { - C->record_method_not_compilable_all_tiers("unsupported outgoing calling sequence"); + C->record_method_not_compilable("unsupported outgoing calling sequence"); } else { for (int i = begin_out_arg_area; i < out_arg_limit_per_call; i++) proj->_rout.Insert(OptoReg::Name(i)); @@ -1488,7 +1488,7 @@ Node *Matcher::Label_Root( const Node *n, State *svec, Node *control, const Node // out of stack space. See bugs 6272980 & 6227033 for more info. LabelRootDepth++; if (LabelRootDepth > MaxLabelRootDepth) { - C->record_method_not_compilable_all_tiers("Out of stack space, increase MaxLabelRootDepth"); + C->record_method_not_compilable("Out of stack space, increase MaxLabelRootDepth"); return NULL; } uint care = 0; // Edges matcher cares about @@ -2228,14 +2228,20 @@ void Matcher::find_shared( Node *n ) { case Op_StorePConditional: case Op_StoreIConditional: case Op_StoreLConditional: + case Op_CompareAndExchangeB: + case Op_CompareAndExchangeS: case Op_CompareAndExchangeI: case Op_CompareAndExchangeL: case Op_CompareAndExchangeP: case Op_CompareAndExchangeN: + case Op_WeakCompareAndSwapB: + case Op_WeakCompareAndSwapS: case Op_WeakCompareAndSwapI: case Op_WeakCompareAndSwapL: case Op_WeakCompareAndSwapP: case Op_WeakCompareAndSwapN: + case Op_CompareAndSwapB: + case Op_CompareAndSwapS: case Op_CompareAndSwapI: case Op_CompareAndSwapL: case Op_CompareAndSwapP: @@ -2453,14 +2459,20 @@ bool Matcher::post_store_load_barrier(const Node* vmb) { // that a monitor exit operation contains a serializing instruction. if (xop == Op_MemBarVolatile || + xop == Op_CompareAndExchangeB || + xop == Op_CompareAndExchangeS || xop == Op_CompareAndExchangeI || xop == Op_CompareAndExchangeL || xop == Op_CompareAndExchangeP || xop == Op_CompareAndExchangeN || + xop == Op_WeakCompareAndSwapB || + xop == Op_WeakCompareAndSwapS || xop == Op_WeakCompareAndSwapL || xop == Op_WeakCompareAndSwapP || xop == Op_WeakCompareAndSwapN || xop == Op_WeakCompareAndSwapI || + xop == Op_CompareAndSwapB || + xop == Op_CompareAndSwapS || xop == Op_CompareAndSwapL || xop == Op_CompareAndSwapP || xop == Op_CompareAndSwapN || diff --git a/hotspot/src/share/vm/opto/memnode.hpp b/hotspot/src/share/vm/opto/memnode.hpp index 438fc7476e6..f0608bc752d 100644 --- a/hotspot/src/share/vm/opto/memnode.hpp +++ b/hotspot/src/share/vm/opto/memnode.hpp @@ -885,13 +885,19 @@ public: } }; -//------------------------------CompareAndSwapLNode--------------------------- -class CompareAndSwapLNode : public CompareAndSwapNode { +//------------------------------CompareAndSwapBNode--------------------------- +class CompareAndSwapBNode : public CompareAndSwapNode { public: - CompareAndSwapLNode( Node *c, Node *mem, Node *adr, Node *val, Node *ex, MemNode::MemOrd mem_ord) : CompareAndSwapNode(c, mem, adr, val, ex, mem_ord) { } + CompareAndSwapBNode( Node *c, Node *mem, Node *adr, Node *val, Node *ex, MemNode::MemOrd mem_ord) : CompareAndSwapNode(c, mem, adr, val, ex, mem_ord) { } virtual int Opcode() const; }; +//------------------------------CompareAndSwapSNode--------------------------- +class CompareAndSwapSNode : public CompareAndSwapNode { +public: + CompareAndSwapSNode( Node *c, Node *mem, Node *adr, Node *val, Node *ex, MemNode::MemOrd mem_ord) : CompareAndSwapNode(c, mem, adr, val, ex, mem_ord) { } + virtual int Opcode() const; +}; //------------------------------CompareAndSwapINode--------------------------- class CompareAndSwapINode : public CompareAndSwapNode { @@ -900,6 +906,12 @@ public: virtual int Opcode() const; }; +//------------------------------CompareAndSwapLNode--------------------------- +class CompareAndSwapLNode : public CompareAndSwapNode { +public: + CompareAndSwapLNode( Node *c, Node *mem, Node *adr, Node *val, Node *ex, MemNode::MemOrd mem_ord) : CompareAndSwapNode(c, mem, adr, val, ex, mem_ord) { } + virtual int Opcode() const; +}; //------------------------------CompareAndSwapPNode--------------------------- class CompareAndSwapPNode : public CompareAndSwapNode { @@ -915,14 +927,19 @@ public: virtual int Opcode() const; }; - -//------------------------------WeakCompareAndSwapLNode--------------------------- -class WeakCompareAndSwapLNode : public CompareAndSwapNode { +//------------------------------WeakCompareAndSwapBNode--------------------------- +class WeakCompareAndSwapBNode : public CompareAndSwapNode { public: - WeakCompareAndSwapLNode( Node *c, Node *mem, Node *adr, Node *val, Node *ex, MemNode::MemOrd mem_ord) : CompareAndSwapNode(c, mem, adr, val, ex, mem_ord) { } + WeakCompareAndSwapBNode( Node *c, Node *mem, Node *adr, Node *val, Node *ex, MemNode::MemOrd mem_ord) : CompareAndSwapNode(c, mem, adr, val, ex, mem_ord) { } virtual int Opcode() const; }; +//------------------------------WeakCompareAndSwapSNode--------------------------- +class WeakCompareAndSwapSNode : public CompareAndSwapNode { +public: + WeakCompareAndSwapSNode( Node *c, Node *mem, Node *adr, Node *val, Node *ex, MemNode::MemOrd mem_ord) : CompareAndSwapNode(c, mem, adr, val, ex, mem_ord) { } + virtual int Opcode() const; +}; //------------------------------WeakCompareAndSwapINode--------------------------- class WeakCompareAndSwapINode : public CompareAndSwapNode { @@ -931,6 +948,12 @@ public: virtual int Opcode() const; }; +//------------------------------WeakCompareAndSwapLNode--------------------------- +class WeakCompareAndSwapLNode : public CompareAndSwapNode { +public: + WeakCompareAndSwapLNode( Node *c, Node *mem, Node *adr, Node *val, Node *ex, MemNode::MemOrd mem_ord) : CompareAndSwapNode(c, mem, adr, val, ex, mem_ord) { } + virtual int Opcode() const; +}; //------------------------------WeakCompareAndSwapPNode--------------------------- class WeakCompareAndSwapPNode : public CompareAndSwapNode { @@ -946,6 +969,21 @@ public: virtual int Opcode() const; }; +//------------------------------CompareAndExchangeBNode--------------------------- +class CompareAndExchangeBNode : public CompareAndExchangeNode { +public: + CompareAndExchangeBNode( Node *c, Node *mem, Node *adr, Node *val, Node *ex, const TypePtr* at, MemNode::MemOrd mem_ord) : CompareAndExchangeNode(c, mem, adr, val, ex, mem_ord, at, TypeInt::BYTE) { } + virtual int Opcode() const; +}; + + +//------------------------------CompareAndExchangeSNode--------------------------- +class CompareAndExchangeSNode : public CompareAndExchangeNode { +public: + CompareAndExchangeSNode( Node *c, Node *mem, Node *adr, Node *val, Node *ex, const TypePtr* at, MemNode::MemOrd mem_ord) : CompareAndExchangeNode(c, mem, adr, val, ex, mem_ord, at, TypeInt::SHORT) { } + virtual int Opcode() const; +}; + //------------------------------CompareAndExchangeLNode--------------------------- class CompareAndExchangeLNode : public CompareAndExchangeNode { public: @@ -976,6 +1014,20 @@ public: virtual int Opcode() const; }; +//------------------------------GetAndAddBNode--------------------------- +class GetAndAddBNode : public LoadStoreNode { +public: + GetAndAddBNode( Node *c, Node *mem, Node *adr, Node *val, const TypePtr* at ) : LoadStoreNode(c, mem, adr, val, at, TypeInt::BYTE, 4) { } + virtual int Opcode() const; +}; + +//------------------------------GetAndAddSNode--------------------------- +class GetAndAddSNode : public LoadStoreNode { +public: + GetAndAddSNode( Node *c, Node *mem, Node *adr, Node *val, const TypePtr* at ) : LoadStoreNode(c, mem, adr, val, at, TypeInt::SHORT, 4) { } + virtual int Opcode() const; +}; + //------------------------------GetAndAddINode--------------------------- class GetAndAddINode : public LoadStoreNode { public: @@ -990,6 +1042,19 @@ public: virtual int Opcode() const; }; +//------------------------------GetAndSetBNode--------------------------- +class GetAndSetBNode : public LoadStoreNode { +public: + GetAndSetBNode( Node *c, Node *mem, Node *adr, Node *val, const TypePtr* at ) : LoadStoreNode(c, mem, adr, val, at, TypeInt::BYTE, 4) { } + virtual int Opcode() const; +}; + +//------------------------------GetAndSetSNode--------------------------- +class GetAndSetSNode : public LoadStoreNode { +public: + GetAndSetSNode( Node *c, Node *mem, Node *adr, Node *val, const TypePtr* at ) : LoadStoreNode(c, mem, adr, val, at, TypeInt::SHORT, 4) { } + virtual int Opcode() const; +}; //------------------------------GetAndSetINode--------------------------- class GetAndSetINode : public LoadStoreNode { @@ -998,7 +1063,7 @@ public: virtual int Opcode() const; }; -//------------------------------GetAndSetINode--------------------------- +//------------------------------GetAndSetLNode--------------------------- class GetAndSetLNode : public LoadStoreNode { public: GetAndSetLNode( Node *c, Node *mem, Node *adr, Node *val, const TypePtr* at ) : LoadStoreNode(c, mem, adr, val, at, TypeLong::LONG, 4) { } diff --git a/hotspot/src/share/vm/opto/parse1.cpp b/hotspot/src/share/vm/opto/parse1.cpp index b2044d3d5e1..be1d82d7554 100644 --- a/hotspot/src/share/vm/opto/parse1.cpp +++ b/hotspot/src/share/vm/opto/parse1.cpp @@ -425,7 +425,7 @@ Parse::Parse(JVMState* caller, ciMethod* parse_method, float expected_uses) _iter.reset_to_method(method()); _flow = method()->get_flow_analysis(); if (_flow->failing()) { - C->record_method_not_compilable_all_tiers(_flow->failure_reason()); + C->record_method_not_compilable(_flow->failure_reason()); } #ifndef PRODUCT @@ -662,7 +662,7 @@ void Parse::do_all_blocks() { // (Note that dead locals do not get phis built, ever.) ensure_phis_everywhere(); - if (block->is_SEL_head() && UseLoopPredicate) { + if (block->is_SEL_head()) { // Add predicate to single entry (not irreducible) loop head. assert(!block->has_merged_backedge(), "only entry paths should be merged for now"); // Need correct bci for predicate. @@ -1118,7 +1118,7 @@ SafePointNode* Parse::create_entry_map() { // Check for really stupid bail-out cases. uint len = TypeFunc::Parms + method()->max_locals() + method()->max_stack(); if (len >= 32760) { - C->record_method_not_compilable_all_tiers("too many local variables"); + C->record_method_not_compilable("too many local variables"); return NULL; } diff --git a/hotspot/src/share/vm/opto/parse3.cpp b/hotspot/src/share/vm/opto/parse3.cpp index bd6dcf30b84..ca571af0dd2 100644 --- a/hotspot/src/share/vm/opto/parse3.cpp +++ b/hotspot/src/share/vm/opto/parse3.cpp @@ -109,7 +109,7 @@ void Parse::do_field_access(bool is_get, bool is_field) { return; } - assert(field->will_link(method()->holder(), bc()), "getfield: typeflow responsibility"); + assert(field->will_link(method(), bc()), "getfield: typeflow responsibility"); // Note: We do not check for an unloaded field type here any more. diff --git a/hotspot/src/share/vm/opto/stringopts.cpp b/hotspot/src/share/vm/opto/stringopts.cpp index 4ec1419250b..85151b0b99e 100644 --- a/hotspot/src/share/vm/opto/stringopts.cpp +++ b/hotspot/src/share/vm/opto/stringopts.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2009, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -1958,6 +1958,12 @@ void PhaseStringOpts::replace_string_concat(StringConcat* sc) { // Initialize the string kit.store_String_value(kit.control(), result, dst_array); kit.store_String_coder(kit.control(), result, coder); + + // The value field is final. Emit a barrier here to ensure that the effect + // of the initialization is committed to memory before any code publishes + // a reference to the newly constructed object (see Parse::do_exits()). + assert(AllocateNode::Ideal_allocation(result, _gvn) != NULL, "should be newly allocated"); + kit.insert_mem_bar(Op_MemBarRelease, result); } else { result = C->top(); } diff --git a/hotspot/src/share/vm/runtime/atomic.cpp b/hotspot/src/share/vm/runtime/atomic.cpp deleted file mode 100644 index 9aaa416e24c..00000000000 --- a/hotspot/src/share/vm/runtime/atomic.cpp +++ /dev/null @@ -1,103 +0,0 @@ -/* - * Copyright (c) 2001, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - * - */ - -#include "precompiled.hpp" -#include "runtime/atomic.inline.hpp" - -/* - * This is the default implementation of byte-sized cmpxchg. It emulates jbyte-sized cmpxchg - * in terms of jint-sized cmpxchg. Platforms may override this by defining their own inline definition - * as well as defining VM_HAS_SPECIALIZED_CMPXCHG_BYTE. This will cause the platform specific - * implementation to be used instead. - */ -jbyte Atomic::cmpxchg_general(jbyte exchange_value, volatile jbyte* dest, jbyte compare_value) { - assert(sizeof(jbyte) == 1, "assumption."); - uintptr_t dest_addr = (uintptr_t)dest; - uintptr_t offset = dest_addr % sizeof(jint); - volatile jint* dest_int = (volatile jint*)(dest_addr - offset); - jint cur = *dest_int; - jbyte* cur_as_bytes = (jbyte*)(&cur); - jint new_val = cur; - jbyte* new_val_as_bytes = (jbyte*)(&new_val); - new_val_as_bytes[offset] = exchange_value; - while (cur_as_bytes[offset] == compare_value) { - jint res = cmpxchg(new_val, dest_int, cur); - if (res == cur) break; - cur = res; - new_val = cur; - new_val_as_bytes[offset] = exchange_value; - } - return cur_as_bytes[offset]; -} - -unsigned Atomic::xchg(unsigned int exchange_value, volatile unsigned int* dest) { - assert(sizeof(unsigned int) == sizeof(jint), "more work to do"); - return (unsigned int)Atomic::xchg((jint)exchange_value, (volatile jint*)dest); -} - -unsigned Atomic::cmpxchg(unsigned int exchange_value, - volatile unsigned int* dest, unsigned int compare_value) { - assert(sizeof(unsigned int) == sizeof(jint), "more work to do"); - return (unsigned int)Atomic::cmpxchg((jint)exchange_value, (volatile jint*)dest, - (jint)compare_value); -} - -jlong Atomic::add(jlong add_value, volatile jlong* dest) { - jlong old = load(dest); - jlong new_value = old + add_value; - while (old != cmpxchg(new_value, dest, old)) { - old = load(dest); - new_value = old + add_value; - } - return old; -} - -void Atomic::inc(volatile short* dest) { - // Most platforms do not support atomic increment on a 2-byte value. However, - // if the value occupies the most significant 16 bits of an aligned 32-bit - // word, then we can do this with an atomic add of 0x10000 to the 32-bit word. - // - // The least significant parts of this 32-bit word will never be affected, even - // in case of overflow/underflow. - // - // Use the ATOMIC_SHORT_PAIR macro to get the desired alignment. -#ifdef VM_LITTLE_ENDIAN - assert((intx(dest) & 0x03) == 0x02, "wrong alignment"); - (void)Atomic::add(0x10000, (volatile int*)(dest-1)); -#else - assert((intx(dest) & 0x03) == 0x00, "wrong alignment"); - (void)Atomic::add(0x10000, (volatile int*)(dest)); -#endif -} - -void Atomic::dec(volatile short* dest) { -#ifdef VM_LITTLE_ENDIAN - assert((intx(dest) & 0x03) == 0x02, "wrong alignment"); - (void)Atomic::add(-0x10000, (volatile int*)(dest-1)); -#else - assert((intx(dest) & 0x03) == 0x00, "wrong alignment"); - (void)Atomic::add(-0x10000, (volatile int*)(dest)); -#endif -} - diff --git a/hotspot/src/share/vm/runtime/atomic.hpp b/hotspot/src/share/vm/runtime/atomic.hpp index 0662c8e3b2a..c71a2d3f3a5 100644 --- a/hotspot/src/share/vm/runtime/atomic.hpp +++ b/hotspot/src/share/vm/runtime/atomic.hpp @@ -27,10 +27,13 @@ #include "memory/allocation.hpp" -class Atomic : AllStatic { - private: - static jbyte cmpxchg_general(jbyte exchange_value, volatile jbyte* dest, jbyte compare_value); +enum cmpxchg_memory_order { + memory_order_relaxed, + // Use value which doesn't interfere with C++2011. We need to be more conservative. + memory_order_conservative = 8 +}; +class Atomic : AllStatic { public: // Atomic operations on jlong types are not available on all 32-bit // platforms. If atomic ops on jlongs are defined here they must only @@ -77,12 +80,12 @@ class Atomic : AllStatic { inline static intptr_t add_ptr(intptr_t add_value, volatile intptr_t* dest); inline static void* add_ptr(intptr_t add_value, volatile void* dest); // See comment above about using jlong atomics on 32-bit platforms - static jlong add (jlong add_value, volatile jlong* dest); + inline static jlong add (jlong add_value, volatile jlong* dest); // Atomically increment location. inc*() provide: // increment-dest inline static void inc (volatile jint* dest); - static void inc (volatile jshort* dest); + inline static void inc (volatile jshort* dest); inline static void inc (volatile size_t* dest); inline static void inc_ptr(volatile intptr_t* dest); inline static void inc_ptr(volatile void* dest); @@ -90,7 +93,7 @@ class Atomic : AllStatic { // Atomically decrement a location. dec*() provide: // decrement-dest inline static void dec (volatile jint* dest); - static void dec (volatile jshort* dest); + inline static void dec (volatile jshort* dest); inline static void dec (volatile size_t* dest); inline static void dec_ptr(volatile intptr_t* dest); inline static void dec_ptr(volatile void* dest); @@ -98,22 +101,22 @@ class Atomic : AllStatic { // Performs atomic exchange of *dest with exchange_value. Returns old // prior value of *dest. xchg*() provide: // exchange-value-with-dest - inline static jint xchg (jint exchange_value, volatile jint* dest); - static unsigned int xchg (unsigned int exchange_value, volatile unsigned int* dest); - inline static intptr_t xchg_ptr(intptr_t exchange_value, volatile intptr_t* dest); - inline static void* xchg_ptr(void* exchange_value, volatile void* dest); + inline static jint xchg (jint exchange_value, volatile jint* dest); + inline static unsigned int xchg (unsigned int exchange_value, volatile unsigned int* dest); + inline static intptr_t xchg_ptr(intptr_t exchange_value, volatile intptr_t* dest); + inline static void* xchg_ptr(void* exchange_value, volatile void* dest); // Performs atomic compare of *dest and compare_value, and exchanges // *dest with exchange_value if the comparison succeeded. Returns prior // value of *dest. cmpxchg*() provide: // compare-and-exchange - inline static jbyte cmpxchg (jbyte exchange_value, volatile jbyte* dest, jbyte compare_value); - inline static jint cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value); + inline static jbyte cmpxchg (jbyte exchange_value, volatile jbyte* dest, jbyte compare_value, cmpxchg_memory_order order = memory_order_conservative); + inline static jint cmpxchg (jint exchange_value, volatile jint* dest, jint compare_value, cmpxchg_memory_order order = memory_order_conservative); // See comment above about using jlong atomics on 32-bit platforms - inline static jlong cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value); - static unsigned int cmpxchg (unsigned int exchange_value, volatile unsigned int* dest, unsigned int compare_value); - inline static intptr_t cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value); - inline static void* cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value); + inline static jlong cmpxchg (jlong exchange_value, volatile jlong* dest, jlong compare_value, cmpxchg_memory_order order = memory_order_conservative); + inline static unsigned int cmpxchg (unsigned int exchange_value, volatile unsigned int* dest, unsigned int compare_value, cmpxchg_memory_order order = memory_order_conservative); + inline static intptr_t cmpxchg_ptr(intptr_t exchange_value, volatile intptr_t* dest, intptr_t compare_value, cmpxchg_memory_order order = memory_order_conservative); + inline static void* cmpxchg_ptr(void* exchange_value, volatile void* dest, void* compare_value, cmpxchg_memory_order order = memory_order_conservative); }; // To use Atomic::inc(jshort* dest) and Atomic::dec(jshort* dest), the address must be specially diff --git a/hotspot/src/share/vm/runtime/atomic.inline.hpp b/hotspot/src/share/vm/runtime/atomic.inline.hpp index 593db7d03f3..8abc7293b24 100644 --- a/hotspot/src/share/vm/runtime/atomic.inline.hpp +++ b/hotspot/src/share/vm/runtime/atomic.inline.hpp @@ -91,11 +91,83 @@ inline void Atomic::dec(volatile size_t* dest) { } #ifndef VM_HAS_SPECIALIZED_CMPXCHG_BYTE -// See comment in atomic.cpp how to override. -inline jbyte Atomic::cmpxchg(jbyte exchange_value, volatile jbyte *dest, jbyte comparand) +/* + * This is the default implementation of byte-sized cmpxchg. It emulates jbyte-sized cmpxchg + * in terms of jint-sized cmpxchg. Platforms may override this by defining their own inline definition + * as well as defining VM_HAS_SPECIALIZED_CMPXCHG_BYTE. This will cause the platform specific + * implementation to be used instead. + */ +inline jbyte Atomic::cmpxchg(jbyte exchange_value, volatile jbyte *dest, jbyte comparand, cmpxchg_memory_order order) { - return cmpxchg_general(exchange_value, dest, comparand); + assert(sizeof(jbyte) == 1, "assumption."); + uintptr_t dest_addr = (uintptr_t)dest; + uintptr_t offset = dest_addr % sizeof(jint); + volatile jint* dest_int = (volatile jint*)(dest_addr - offset); + jint cur = *dest_int; + jbyte* cur_as_bytes = (jbyte*)(&cur); + jint new_val = cur; + jbyte* new_val_as_bytes = (jbyte*)(&new_val); + new_val_as_bytes[offset] = exchange_value; + while (cur_as_bytes[offset] == comparand) { + jint res = cmpxchg(new_val, dest_int, cur, order); + if (res == cur) break; + cur = res; + new_val = cur; + new_val_as_bytes[offset] = exchange_value; + } + return cur_as_bytes[offset]; } #endif // VM_HAS_SPECIALIZED_CMPXCHG_BYTE +inline unsigned Atomic::xchg(unsigned int exchange_value, volatile unsigned int* dest) { + assert(sizeof(unsigned int) == sizeof(jint), "more work to do"); + return (unsigned int)Atomic::xchg((jint)exchange_value, (volatile jint*)dest); +} + +inline unsigned Atomic::cmpxchg(unsigned int exchange_value, + volatile unsigned int* dest, unsigned int compare_value, + cmpxchg_memory_order order) { + assert(sizeof(unsigned int) == sizeof(jint), "more work to do"); + return (unsigned int)Atomic::cmpxchg((jint)exchange_value, (volatile jint*)dest, + (jint)compare_value, order); +} + +inline jlong Atomic::add(jlong add_value, volatile jlong* dest) { + jlong old = load(dest); + jlong new_value = old + add_value; + while (old != cmpxchg(new_value, dest, old)) { + old = load(dest); + new_value = old + add_value; + } + return old; +} + +inline void Atomic::inc(volatile short* dest) { + // Most platforms do not support atomic increment on a 2-byte value. However, + // if the value occupies the most significant 16 bits of an aligned 32-bit + // word, then we can do this with an atomic add of 0x10000 to the 32-bit word. + // + // The least significant parts of this 32-bit word will never be affected, even + // in case of overflow/underflow. + // + // Use the ATOMIC_SHORT_PAIR macro to get the desired alignment. +#ifdef VM_LITTLE_ENDIAN + assert((intx(dest) & 0x03) == 0x02, "wrong alignment"); + (void)Atomic::add(0x10000, (volatile int*)(dest-1)); +#else + assert((intx(dest) & 0x03) == 0x00, "wrong alignment"); + (void)Atomic::add(0x10000, (volatile int*)(dest)); +#endif +} + +inline void Atomic::dec(volatile short* dest) { +#ifdef VM_LITTLE_ENDIAN + assert((intx(dest) & 0x03) == 0x02, "wrong alignment"); + (void)Atomic::add(-0x10000, (volatile int*)(dest-1)); +#else + assert((intx(dest) & 0x03) == 0x00, "wrong alignment"); + (void)Atomic::add(-0x10000, (volatile int*)(dest)); +#endif +} + #endif // SHARE_VM_RUNTIME_ATOMIC_INLINE_HPP diff --git a/hotspot/src/share/vm/runtime/fieldDescriptor.hpp b/hotspot/src/share/vm/runtime/fieldDescriptor.hpp index 9c3101b38ba..1810a16cd3d 100644 --- a/hotspot/src/share/vm/runtime/fieldDescriptor.hpp +++ b/hotspot/src/share/vm/runtime/fieldDescriptor.hpp @@ -106,6 +106,7 @@ class fieldDescriptor VALUE_OBJ_CLASS_SPEC { bool is_field_access_watched() const { return access_flags().is_field_access_watched(); } bool is_field_modification_watched() const { return access_flags().is_field_modification_watched(); } + bool has_initialized_final_update() const { return access_flags().has_field_initialized_final_update(); } bool has_generic_signature() const { return access_flags().field_has_generic_signature(); } void set_is_field_access_watched(const bool value) { @@ -118,6 +119,11 @@ class fieldDescriptor VALUE_OBJ_CLASS_SPEC { update_klass_field_access_flag(); } + void set_has_initialized_final_update(const bool value) { + _access_flags.set_has_field_initialized_final_update(value); + update_klass_field_access_flag(); + } + // Initialization void reinitialize(InstanceKlass* ik, int index); diff --git a/hotspot/src/share/vm/runtime/globals.hpp b/hotspot/src/share/vm/runtime/globals.hpp index e72826b7df6..e54ea9abb8b 100644 --- a/hotspot/src/share/vm/runtime/globals.hpp +++ b/hotspot/src/share/vm/runtime/globals.hpp @@ -463,6 +463,29 @@ class SizeTFlagSetting { ~SizeTFlagSetting() { *flag = val; } }; +// Helper class for temporarily saving the value of a flag during a scope. +template +class FlagGuard { + unsigned char _value[SIZE]; + void* const _addr; + + // Hide operator new, this class should only be allocated on the stack. + // NOTE: Cannot include memory/allocation.hpp here due to circular + // dependencies. + void* operator new(size_t size) throw(); + void* operator new [](size_t size) throw(); + + public: + FlagGuard(void* flag_addr) : _addr(flag_addr) { + memcpy(_value, _addr, SIZE); + } + + ~FlagGuard() { + memcpy(_addr, _value, SIZE); + } +}; + +#define FLAG_GUARD(f) FlagGuard f ## _guard(&f) class CommandLineFlags { public: diff --git a/hotspot/src/share/vm/runtime/javaCalls.cpp b/hotspot/src/share/vm/runtime/javaCalls.cpp index 34a0787eaac..5c544b4b5dc 100644 --- a/hotspot/src/share/vm/runtime/javaCalls.cpp +++ b/hotspot/src/share/vm/runtime/javaCalls.cpp @@ -372,14 +372,16 @@ void JavaCalls::call_helper(JavaValue* result, const methodHandle& method, JavaC } // Check that there are shadow pages available before changing thread state - // to Java - if (!os::stack_shadow_pages_available(THREAD, method)) { + // to Java. Calculate current_stack_pointer here to make sure + // stack_shadow_pages_available() and bang_stack_shadow_pages() use the same sp. + address sp = os::current_stack_pointer(); + if (!os::stack_shadow_pages_available(THREAD, method, sp)) { // Throw stack overflow exception with preinitialized exception. Exceptions::throw_stack_overflow_exception(THREAD, __FILE__, __LINE__, method); return; } else { // Touch pages checked if the OS needs them to be touched to be mapped. - os::map_stack_shadow_pages(); + os::map_stack_shadow_pages(sp); } #if INCLUDE_JVMCI diff --git a/hotspot/src/share/vm/runtime/os.cpp b/hotspot/src/share/vm/runtime/os.cpp index 8acc60b24b2..554a183857e 100644 --- a/hotspot/src/share/vm/runtime/os.cpp +++ b/hotspot/src/share/vm/runtime/os.cpp @@ -1325,9 +1325,8 @@ void os::serialize_thread_states() { // Returns true if the current stack pointer is above the stack shadow // pages, false otherwise. -bool os::stack_shadow_pages_available(Thread *thread, const methodHandle& method) { +bool os::stack_shadow_pages_available(Thread *thread, const methodHandle& method, address sp) { if (!thread->is_Java_thread()) return false; - address sp = current_stack_pointer(); // Check if we have StackShadowPages above the yellow zone. This parameter // is dependent on the depth of the maximum VM call stack possible from // the handler for stack overflow. 'instanceof' in the stack overflow diff --git a/hotspot/src/share/vm/runtime/os.hpp b/hotspot/src/share/vm/runtime/os.hpp index 4abbdbb0a52..f99088bd999 100644 --- a/hotspot/src/share/vm/runtime/os.hpp +++ b/hotspot/src/share/vm/runtime/os.hpp @@ -260,9 +260,9 @@ class os: AllStatic { // exception processing) There are guard pages, and above that shadow // pages for stack overflow checking. static bool uses_stack_guard_pages(); - static bool allocate_stack_guard_pages(); - static void map_stack_shadow_pages(); - static bool stack_shadow_pages_available(Thread *thread, const methodHandle& method); + static bool must_commit_stack_guard_pages(); + static void map_stack_shadow_pages(address sp); + static bool stack_shadow_pages_available(Thread *thread, const methodHandle& method, address sp); // OS interface to Virtual Memory diff --git a/hotspot/src/share/vm/runtime/thread.cpp b/hotspot/src/share/vm/runtime/thread.cpp index a3f0561c93a..588c263a345 100644 --- a/hotspot/src/share/vm/runtime/thread.cpp +++ b/hotspot/src/share/vm/runtime/thread.cpp @@ -2493,10 +2493,10 @@ void JavaThread::create_stack_guard_pages() { address low_addr = stack_end(); size_t len = stack_guard_zone_size(); - int allocate = os::allocate_stack_guard_pages(); + int must_commit = os::must_commit_stack_guard_pages(); // warning("Guarding at " PTR_FORMAT " for len " SIZE_FORMAT "\n", low_addr, len); - if (allocate && !os::create_stack_guard_pages((char *) low_addr, len)) { + if (must_commit && !os::create_stack_guard_pages((char *) low_addr, len)) { log_warning(os, thread)("Attempt to allocate stack guard pages failed."); return; } @@ -2515,7 +2515,6 @@ void JavaThread::create_stack_guard_pages() { log_debug(os, thread)("Thread " UINTX_FORMAT " stack guard pages activated: " PTR_FORMAT "-" PTR_FORMAT ".", os::current_thread_id(), p2i(low_addr), p2i(low_addr + len)); - } void JavaThread::remove_stack_guard_pages() { @@ -2524,7 +2523,7 @@ void JavaThread::remove_stack_guard_pages() { address low_addr = stack_end(); size_t len = stack_guard_zone_size(); - if (os::allocate_stack_guard_pages()) { + if (os::must_commit_stack_guard_pages()) { if (os::remove_stack_guard_pages((char *) low_addr, len)) { _stack_guard_state = stack_guard_unused; } else { @@ -2546,7 +2545,6 @@ void JavaThread::remove_stack_guard_pages() { log_debug(os, thread)("Thread " UINTX_FORMAT " stack guard pages removed: " PTR_FORMAT "-" PTR_FORMAT ".", os::current_thread_id(), p2i(low_addr), p2i(low_addr + len)); - } void JavaThread::enable_stack_reserved_zone() { diff --git a/hotspot/src/share/vm/runtime/vmStructs.cpp b/hotspot/src/share/vm/runtime/vmStructs.cpp index dab3dbbd629..610dc13c227 100644 --- a/hotspot/src/share/vm/runtime/vmStructs.cpp +++ b/hotspot/src/share/vm/runtime/vmStructs.cpp @@ -2024,15 +2024,21 @@ typedef CompactHashtable SymbolCompactHashTable; declare_c2_type(StorePConditionalNode, LoadStoreNode) \ declare_c2_type(StoreLConditionalNode, LoadStoreNode) \ declare_c2_type(CompareAndSwapNode, LoadStoreConditionalNode) \ + declare_c2_type(CompareAndSwapBNode, CompareAndSwapNode) \ + declare_c2_type(CompareAndSwapSNode, CompareAndSwapNode) \ declare_c2_type(CompareAndSwapLNode, CompareAndSwapNode) \ declare_c2_type(CompareAndSwapINode, CompareAndSwapNode) \ declare_c2_type(CompareAndSwapPNode, CompareAndSwapNode) \ declare_c2_type(CompareAndSwapNNode, CompareAndSwapNode) \ + declare_c2_type(WeakCompareAndSwapBNode, CompareAndSwapNode) \ + declare_c2_type(WeakCompareAndSwapSNode, CompareAndSwapNode) \ declare_c2_type(WeakCompareAndSwapLNode, CompareAndSwapNode) \ declare_c2_type(WeakCompareAndSwapINode, CompareAndSwapNode) \ declare_c2_type(WeakCompareAndSwapPNode, CompareAndSwapNode) \ declare_c2_type(WeakCompareAndSwapNNode, CompareAndSwapNode) \ declare_c2_type(CompareAndExchangeNode, LoadStoreNode) \ + declare_c2_type(CompareAndExchangeBNode, CompareAndExchangeNode) \ + declare_c2_type(CompareAndExchangeSNode, CompareAndExchangeNode) \ declare_c2_type(CompareAndExchangeLNode, CompareAndExchangeNode) \ declare_c2_type(CompareAndExchangeINode, CompareAndExchangeNode) \ declare_c2_type(CompareAndExchangePNode, CompareAndExchangeNode) \ diff --git a/hotspot/src/share/vm/services/diagnosticArgument.cpp b/hotspot/src/share/vm/services/diagnosticArgument.cpp index 85db9623169..0c51a708e9a 100644 --- a/hotspot/src/share/vm/services/diagnosticArgument.cpp +++ b/hotspot/src/share/vm/services/diagnosticArgument.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -280,7 +280,7 @@ template <> void DCmdArgument::parse_value(const char* str, size_t len, TRAPS) { if (str == NULL) { THROW_MSG(vmSymbols::java_lang_IllegalArgumentException(), - "Integer parsing error nanotime value: syntax error"); + "Parsing error memory size value: syntax error, value is null"); } if (*str == '-') { diff --git a/hotspot/src/share/vm/services/diagnosticCommand.cpp b/hotspot/src/share/vm/services/diagnosticCommand.cpp index 6ed19904a78..c90bf08e39e 100644 --- a/hotspot/src/share/vm/services/diagnosticCommand.cpp +++ b/hotspot/src/share/vm/services/diagnosticCommand.cpp @@ -413,6 +413,7 @@ void RunFinalizationDCmd::execute(DCmdSource source, TRAPS) { } void HeapInfoDCmd::execute(DCmdSource source, TRAPS) { + MutexLocker hl(Heap_lock); Universe::heap()->print_on(output()); } diff --git a/hotspot/src/share/vm/trace/traceMacros.hpp b/hotspot/src/share/vm/trace/traceMacros.hpp index 63c49630473..a69acef1f70 100644 --- a/hotspot/src/share/vm/trace/traceMacros.hpp +++ b/hotspot/src/share/vm/trace/traceMacros.hpp @@ -33,6 +33,9 @@ typedef u8 traceid; #define TRACE_KLASS_DEFINITION(k, t) #define TRACE_INIT_KLASS_ID(k) +#define TRACE_REMOVE_KLASS_ID(k) +#define TRACE_RESTORE_KLASS_ID(k) + #define TRACE_INIT_MODULE_ID(m) #define TRACE_INIT_PACKAGE_ID(p) #define TRACE_INIT_THREAD_ID(td) diff --git a/hotspot/src/share/vm/utilities/accessFlags.hpp b/hotspot/src/share/vm/utilities/accessFlags.hpp index d9c1685e2b9..623def97d30 100644 --- a/hotspot/src/share/vm/utilities/accessFlags.hpp +++ b/hotspot/src/share/vm/utilities/accessFlags.hpp @@ -77,11 +77,12 @@ enum { // These bits must not conflict with any other field-related access flags // (e.g., ACC_ENUM). // Note that the class-related ACC_ANNOTATION bit conflicts with these flags. - JVM_ACC_FIELD_ACCESS_WATCHED = 0x00002000, // field access is watched by JVMTI - JVM_ACC_FIELD_MODIFICATION_WATCHED = 0x00008000, // field modification is watched by JVMTI - JVM_ACC_FIELD_INTERNAL = 0x00000400, // internal field, same as JVM_ACC_ABSTRACT - JVM_ACC_FIELD_STABLE = 0x00000020, // @Stable field, same as JVM_ACC_SYNCHRONIZED - JVM_ACC_FIELD_HAS_GENERIC_SIGNATURE = 0x00000800, // field has generic signature + JVM_ACC_FIELD_ACCESS_WATCHED = 0x00002000, // field access is watched by JVMTI + JVM_ACC_FIELD_MODIFICATION_WATCHED = 0x00008000, // field modification is watched by JVMTI + JVM_ACC_FIELD_INTERNAL = 0x00000400, // internal field, same as JVM_ACC_ABSTRACT + JVM_ACC_FIELD_STABLE = 0x00000020, // @Stable field, same as JVM_ACC_SYNCHRONIZED and JVM_ACC_SUPER + JVM_ACC_FIELD_INITIALIZED_FINAL_UPDATE = 0x00000100, // (static) final field updated outside (class) initializer, same as JVM_ACC_NATIVE + JVM_ACC_FIELD_HAS_GENERIC_SIGNATURE = 0x00000800, // field has generic signature JVM_ACC_FIELD_INTERNAL_FLAGS = JVM_ACC_FIELD_ACCESS_WATCHED | JVM_ACC_FIELD_MODIFICATION_WATCHED | @@ -154,6 +155,8 @@ class AccessFlags VALUE_OBJ_CLASS_SPEC { bool is_field_access_watched() const { return (_flags & JVM_ACC_FIELD_ACCESS_WATCHED) != 0; } bool is_field_modification_watched() const { return (_flags & JVM_ACC_FIELD_MODIFICATION_WATCHED) != 0; } + bool has_field_initialized_final_update() const + { return (_flags & JVM_ACC_FIELD_INITIALIZED_FINAL_UPDATE) != 0; } bool on_stack() const { return (_flags & JVM_ACC_ON_STACK) != 0; } bool is_internal() const { return (_flags & JVM_ACC_FIELD_INTERNAL) != 0; } bool is_stable() const { return (_flags & JVM_ACC_FIELD_STABLE) != 0; } @@ -232,6 +235,15 @@ class AccessFlags VALUE_OBJ_CLASS_SPEC { atomic_clear_bits(JVM_ACC_FIELD_MODIFICATION_WATCHED); } } + + void set_has_field_initialized_final_update(const bool value) { + if (value) { + atomic_set_bits(JVM_ACC_FIELD_INITIALIZED_FINAL_UPDATE); + } else { + atomic_clear_bits(JVM_ACC_FIELD_INITIALIZED_FINAL_UPDATE); + } + } + void set_field_has_generic_signature() { atomic_set_bits(JVM_ACC_FIELD_HAS_GENERIC_SIGNATURE); diff --git a/hotspot/src/share/vm/utilities/globalDefinitions_gcc.hpp b/hotspot/src/share/vm/utilities/globalDefinitions_gcc.hpp index 63a04ad80e0..7b6c7b9302b 100644 --- a/hotspot/src/share/vm/utilities/globalDefinitions_gcc.hpp +++ b/hotspot/src/share/vm/utilities/globalDefinitions_gcc.hpp @@ -324,6 +324,6 @@ inline int wcslen(const jchar* x) { return wcslen((const wchar_t*)x); } // Inlining support #define NOINLINE __attribute__ ((noinline)) -#define ALWAYSINLINE __attribute__ ((always_inline)) +#define ALWAYSINLINE inline __attribute__ ((always_inline)) #endif // SHARE_VM_UTILITIES_GLOBALDEFINITIONS_GCC_HPP diff --git a/hotspot/src/share/vm/utilities/globalDefinitions_sparcWorks.hpp b/hotspot/src/share/vm/utilities/globalDefinitions_sparcWorks.hpp index 8b127114ca0..755eba01c07 100644 --- a/hotspot/src/share/vm/utilities/globalDefinitions_sparcWorks.hpp +++ b/hotspot/src/share/vm/utilities/globalDefinitions_sparcWorks.hpp @@ -279,6 +279,6 @@ inline int wcslen(const jchar* x) { return wcslen((const wchar_t*)x); } // Inlining support #define NOINLINE -#define ALWAYSINLINE __attribute__((always_inline)) +#define ALWAYSINLINE inline __attribute__((always_inline)) #endif // SHARE_VM_UTILITIES_GLOBALDEFINITIONS_SPARCWORKS_HPP diff --git a/hotspot/src/share/vm/utilities/vmError.cpp b/hotspot/src/share/vm/utilities/vmError.cpp index 12ed963d17f..d2c9cadb504 100644 --- a/hotspot/src/share/vm/utilities/vmError.cpp +++ b/hotspot/src/share/vm/utilities/vmError.cpp @@ -908,6 +908,7 @@ void VMError::print_vm_info(outputStream* st) { // STEP("printing heap information") if (Universe::is_fully_initialized()) { + MutexLocker hl(Heap_lock); Universe::heap()->print_on_error(st); st->cr(); st->print_cr("Polling page: " INTPTR_FORMAT, p2i(os::get_polling_page())); diff --git a/hotspot/test/TEST.ROOT b/hotspot/test/TEST.ROOT index 00a177ae6b4..d604c52e930 100644 --- a/hotspot/test/TEST.ROOT +++ b/hotspot/test/TEST.ROOT @@ -33,8 +33,18 @@ groups=TEST.groups [closed/TEST.groups] # Source files for classes that will be used at the beginning of each test suite run, # to determine additional characteristics of the system for use with the @requires tag. +# Note: compiled bootlibs code will be located in the folder 'bootClasses' requires.extraPropDefns = ../../test/jtreg-ext/requires/VMProps.java -requires.properties=sun.arch.data.model vm.simpleArch vm.flightRecorder +requires.extraPropDefns.bootlibs = ../../test/lib/sun +requires.extraPropDefns.vmOpts = -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xbootclasspath/a:bootClasses +requires.properties= \ + sun.arch.data.model \ + vm.simpleArch \ + vm.flightRecorder \ + vm.gc.G1 \ + vm.gc.Serial \ + vm.gc.Parallel \ + vm.gc.ConcMarkSweep # Tests using jtreg 4.2 b02 features requiredVersion=4.2 b02 diff --git a/hotspot/test/compiler/arraycopy/TestArrayCopyNoInitDeopt.java b/hotspot/test/compiler/arraycopy/TestArrayCopyNoInitDeopt.java index ccd2cfe1028..6451b38795e 100644 --- a/hotspot/test/compiler/arraycopy/TestArrayCopyNoInitDeopt.java +++ b/hotspot/test/compiler/arraycopy/TestArrayCopyNoInitDeopt.java @@ -25,19 +25,17 @@ * @test * @bug 8072016 * @summary Infinite deoptimization/recompilation cycles in case of arraycopy with tightly coupled allocation - * @library /testlibrary /test/lib /compiler/whitebox / + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestArrayCopyNoInitDeopt - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * @run main ClassFileInstaller jdk.test.lib.Platform + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * jdk.test.lib.Platform * @run main/othervm -Xmixed -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:-BackgroundCompilation -XX:-UseOnStackReplacement -XX:TypeProfileLevel=020 * TestArrayCopyNoInitDeopt - * */ - import sun.hotspot.WhiteBox; import sun.hotspot.code.NMethod; import jdk.test.lib.Platform; diff --git a/hotspot/test/compiler/c1/7103261/Test7103261.java b/hotspot/test/compiler/c1/7103261/Test7103261.java index 3abdb875e15..afb3064ff68 100644 --- a/hotspot/test/compiler/c1/7103261/Test7103261.java +++ b/hotspot/test/compiler/c1/7103261/Test7103261.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -44,6 +44,7 @@ public class Test7103261 { char c; short s; boolean z; + Object o; public static void main(String[] args) { constantStore(); @@ -51,7 +52,7 @@ public class Test7103261 { valueTest(true); } static void constantStore() { - for (int field = 0; field < 8; field++) { + for (int field = 0; field < 9; field++) { try { Test7103261 o = nonnull_value; for (int i = 0; i < 100000; i++) { @@ -64,6 +65,7 @@ public class Test7103261 { case 5: o.c = 0; break; case 6: o.s = 0; break; case 7: o.z = false; break; + case 8: o.o = null; break; default: throw new InternalError(); } if (i == 90000) { @@ -76,7 +78,7 @@ public class Test7103261 { } } static void valueTest(boolean store) { - for (int field = 0; field < 8; field++) { + for (int field = 0; field < 9; field++) { try { Test7103261 o = nonnull_value; Test7103261 o2 = nonnull_value2; @@ -90,6 +92,7 @@ public class Test7103261 { case 5: o.c = o2.c; break; case 6: o.s = o2.s; break; case 7: o.z = o2.z; break; + case 8: o.o = o2.o; break; default: throw new InternalError(); } if (i == 90000) { diff --git a/hotspot/test/compiler/c2/8004867/TestIntUnsafeOrdered.java b/hotspot/test/compiler/c2/8004867/TestIntUnsafeOrdered.java index 137080eb289..3fec4bd9a7b 100644 --- a/hotspot/test/compiler/c2/8004867/TestIntUnsafeOrdered.java +++ b/hotspot/test/compiler/c2/8004867/TestIntUnsafeOrdered.java @@ -32,8 +32,8 @@ * @run main/othervm/timeout=300 -Xbatch -XX:+IgnoreUnrecognizedVMOptions -XX:-TieredCompilation -XX:+OptimizeFill TestIntUnsafeOrdered */ -import sun.misc.Unsafe; -import java.lang.reflect.*; +import jdk.internal.misc.Unsafe; +import java.lang.reflect.Field; public class TestIntUnsafeOrdered { private static final int ARRLEN = 97; @@ -47,10 +47,10 @@ public class TestIntUnsafeOrdered { private static final int BASE; static { try { - Class c = TestIntUnsafeOrdered.class.getClassLoader().loadClass("sun.misc.Unsafe"); + Class c = Unsafe.class; Field f = c.getDeclaredField("theUnsafe"); f.setAccessible(true); - unsafe = (Unsafe)f.get(c); + unsafe = (Unsafe) f.get(c); BASE = unsafe.arrayBaseOffset(int[].class); } catch (Exception e) { InternalError err = new InternalError(); @@ -771,213 +771,213 @@ public class TestIntUnsafeOrdered { static void test_ci(int[] a) { for (int i = 0; i < ARRLEN; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i), -123); + unsafe.putIntRelease(a, byte_offset(i), -123); } } static void test_vi(int[] a, int b, int old) { for (int i = 0; i < ARRLEN; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i), b); + unsafe.putIntRelease(a, byte_offset(i), b); } } static void test_cp(int[] a, int[] b) { for (int i = 0; i < ARRLEN; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i), b[i]); + unsafe.putIntRelease(a, byte_offset(i), b[i]); } } static void test_2ci(int[] a, int[] b) { for (int i = 0; i < ARRLEN; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i), -123); - unsafe.putOrderedInt(b, byte_offset(i), -103); + unsafe.putIntRelease(a, byte_offset(i), -123); + unsafe.putIntRelease(b, byte_offset(i), -103); } } static void test_2vi(int[] a, int[] b, int c, int d) { for (int i = 0; i < ARRLEN; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i), c); - unsafe.putOrderedInt(b, byte_offset(i), d); + unsafe.putIntRelease(a, byte_offset(i), c); + unsafe.putIntRelease(b, byte_offset(i), d); } } static void test_ci_neg(int[] a, int old) { for (int i = ARRLEN-1; i >= 0; i-=1) { - unsafe.putOrderedInt(a, byte_offset(i), -123); + unsafe.putIntRelease(a, byte_offset(i), -123); } } static void test_vi_neg(int[] a, int b, int old) { for (int i = ARRLEN-1; i >= 0; i-=1) { - unsafe.putOrderedInt(a, byte_offset(i), b); + unsafe.putIntRelease(a, byte_offset(i), b); } } static void test_cp_neg(int[] a, int[] b) { for (int i = ARRLEN-1; i >= 0; i-=1) { - unsafe.putOrderedInt(a, byte_offset(i), b[i]); + unsafe.putIntRelease(a, byte_offset(i), b[i]); } } static void test_2ci_neg(int[] a, int[] b) { for (int i = ARRLEN-1; i >= 0; i-=1) { - unsafe.putOrderedInt(a, byte_offset(i), -123); - unsafe.putOrderedInt(b, byte_offset(i), -103); + unsafe.putIntRelease(a, byte_offset(i), -123); + unsafe.putIntRelease(b, byte_offset(i), -103); } } static void test_2vi_neg(int[] a, int[] b, int c, int d) { for (int i = ARRLEN-1; i >= 0; i-=1) { - unsafe.putOrderedInt(a, byte_offset(i), c); - unsafe.putOrderedInt(b, byte_offset(i), d); + unsafe.putIntRelease(a, byte_offset(i), c); + unsafe.putIntRelease(b, byte_offset(i), d); } } static void test_ci_oppos(int[] a, int old) { int limit = ARRLEN-1; for (int i = 0; i < ARRLEN; i+=1) { - unsafe.putOrderedInt(a, byte_offset(limit-i), -123); + unsafe.putIntRelease(a, byte_offset(limit-i), -123); } } static void test_vi_oppos(int[] a, int b, int old) { int limit = ARRLEN-1; for (int i = limit; i >= 0; i-=1) { - unsafe.putOrderedInt(a, byte_offset(limit-i), b); + unsafe.putIntRelease(a, byte_offset(limit-i), b); } } static void test_cp_oppos(int[] a, int[] b) { int limit = ARRLEN-1; for (int i = 0; i < ARRLEN; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i), b[limit-i]); + unsafe.putIntRelease(a, byte_offset(i), b[limit-i]); } } static void test_2ci_oppos(int[] a, int[] b) { int limit = ARRLEN-1; for (int i = 0; i < ARRLEN; i+=1) { - unsafe.putOrderedInt(a, byte_offset(limit-i), -123); - unsafe.putOrderedInt(b, byte_offset(i), -103); + unsafe.putIntRelease(a, byte_offset(limit-i), -123); + unsafe.putIntRelease(b, byte_offset(i), -103); } } static void test_2vi_oppos(int[] a, int[] b, int c, int d) { int limit = ARRLEN-1; for (int i = limit; i >= 0; i-=1) { - unsafe.putOrderedInt(a, byte_offset(i), c); - unsafe.putOrderedInt(b, byte_offset(limit-i), d); + unsafe.putIntRelease(a, byte_offset(i), c); + unsafe.putIntRelease(b, byte_offset(limit-i), d); } } static void test_ci_off(int[] a, int old) { for (int i = 0; i < ARRLEN-OFFSET; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i+OFFSET), -123); + unsafe.putIntRelease(a, byte_offset(i+OFFSET), -123); } } static void test_vi_off(int[] a, int b, int old) { for (int i = 0; i < ARRLEN-OFFSET; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i+OFFSET), b); + unsafe.putIntRelease(a, byte_offset(i+OFFSET), b); } } static void test_cp_off(int[] a, int[] b) { for (int i = 0; i < ARRLEN-OFFSET; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i+OFFSET), b[i+OFFSET]); + unsafe.putIntRelease(a, byte_offset(i+OFFSET), b[i+OFFSET]); } } static void test_2ci_off(int[] a, int[] b) { for (int i = 0; i < ARRLEN-OFFSET; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i+OFFSET), -123); - unsafe.putOrderedInt(b, byte_offset(i+OFFSET), -103); + unsafe.putIntRelease(a, byte_offset(i+OFFSET), -123); + unsafe.putIntRelease(b, byte_offset(i+OFFSET), -103); } } static void test_2vi_off(int[] a, int[] b, int c, int d) { for (int i = 0; i < ARRLEN-OFFSET; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i+OFFSET), c); - unsafe.putOrderedInt(b, byte_offset(i+OFFSET), d); + unsafe.putIntRelease(a, byte_offset(i+OFFSET), c); + unsafe.putIntRelease(b, byte_offset(i+OFFSET), d); } } static void test_ci_inv(int[] a, int k, int old) { for (int i = 0; i < ARRLEN-k; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i+k), -123); + unsafe.putIntRelease(a, byte_offset(i+k), -123); } } static void test_vi_inv(int[] a, int b, int k, int old) { for (int i = 0; i < ARRLEN-k; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i+k), b); + unsafe.putIntRelease(a, byte_offset(i+k), b); } } static void test_cp_inv(int[] a, int[] b, int k) { for (int i = 0; i < ARRLEN-k; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i+k), b[i+k]); + unsafe.putIntRelease(a, byte_offset(i+k), b[i+k]); } } static void test_2ci_inv(int[] a, int[] b, int k) { for (int i = 0; i < ARRLEN-k; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i+k), -123); - unsafe.putOrderedInt(b, byte_offset(i+k), -103); + unsafe.putIntRelease(a, byte_offset(i+k), -123); + unsafe.putIntRelease(b, byte_offset(i+k), -103); } } static void test_2vi_inv(int[] a, int[] b, int c, int d, int k) { for (int i = 0; i < ARRLEN-k; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i+k), c); - unsafe.putOrderedInt(b, byte_offset(i+k), d); + unsafe.putIntRelease(a, byte_offset(i+k), c); + unsafe.putIntRelease(b, byte_offset(i+k), d); } } static void test_ci_scl(int[] a, int old) { for (int i = 0; i*SCALE < ARRLEN; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i*SCALE), -123); + unsafe.putIntRelease(a, byte_offset(i*SCALE), -123); } } static void test_vi_scl(int[] a, int b, int old) { for (int i = 0; i*SCALE < ARRLEN; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i*SCALE), b); + unsafe.putIntRelease(a, byte_offset(i*SCALE), b); } } static void test_cp_scl(int[] a, int[] b) { for (int i = 0; i*SCALE < ARRLEN; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i*SCALE), b[i*SCALE]); + unsafe.putIntRelease(a, byte_offset(i*SCALE), b[i*SCALE]); } } static void test_2ci_scl(int[] a, int[] b) { for (int i = 0; i*SCALE < ARRLEN; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i*SCALE), -123); - unsafe.putOrderedInt(b, byte_offset(i*SCALE), -103); + unsafe.putIntRelease(a, byte_offset(i*SCALE), -123); + unsafe.putIntRelease(b, byte_offset(i*SCALE), -103); } } static void test_2vi_scl(int[] a, int[] b, int c, int d) { for (int i = 0; i*SCALE < ARRLEN; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i*SCALE), c); - unsafe.putOrderedInt(b, byte_offset(i*SCALE), d); + unsafe.putIntRelease(a, byte_offset(i*SCALE), c); + unsafe.putIntRelease(b, byte_offset(i*SCALE), d); } } static void test_cp_alndst(int[] a, int[] b) { for (int i = 0; i < ARRLEN-ALIGN_OFF; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i+ALIGN_OFF), b[i]); + unsafe.putIntRelease(a, byte_offset(i+ALIGN_OFF), b[i]); } } static void test_cp_alnsrc(int[] a, int[] b) { for (int i = 0; i < ARRLEN-ALIGN_OFF; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i), b[i+ALIGN_OFF]); + unsafe.putIntRelease(a, byte_offset(i), b[i+ALIGN_OFF]); } } static void test_2ci_aln(int[] a, int[] b) { for (int i = 0; i < ARRLEN-ALIGN_OFF; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i+ALIGN_OFF), -123); - unsafe.putOrderedInt(b, byte_offset(i), -103); + unsafe.putIntRelease(a, byte_offset(i+ALIGN_OFF), -123); + unsafe.putIntRelease(b, byte_offset(i), -103); } } static void test_2vi_aln(int[] a, int[] b, int c, int d) { for (int i = 0; i < ARRLEN-ALIGN_OFF; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i), c); - unsafe.putOrderedInt(b, byte_offset(i+ALIGN_OFF), d); + unsafe.putIntRelease(a, byte_offset(i), c); + unsafe.putIntRelease(b, byte_offset(i+ALIGN_OFF), d); } } static void test_cp_unalndst(int[] a, int[] b) { for (int i = 0; i < ARRLEN-UNALIGN_OFF; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i+UNALIGN_OFF), b[i]); + unsafe.putIntRelease(a, byte_offset(i+UNALIGN_OFF), b[i]); } } static void test_cp_unalnsrc(int[] a, int[] b) { for (int i = 0; i < ARRLEN-UNALIGN_OFF; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i), b[i+UNALIGN_OFF]); + unsafe.putIntRelease(a, byte_offset(i), b[i+UNALIGN_OFF]); } } static void test_2ci_unaln(int[] a, int[] b) { for (int i = 0; i < ARRLEN-UNALIGN_OFF; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i+UNALIGN_OFF), -123); - unsafe.putOrderedInt(b, byte_offset(i), -103); + unsafe.putIntRelease(a, byte_offset(i+UNALIGN_OFF), -123); + unsafe.putIntRelease(b, byte_offset(i), -103); } } static void test_2vi_unaln(int[] a, int[] b, int c, int d) { for (int i = 0; i < ARRLEN-UNALIGN_OFF; i+=1) { - unsafe.putOrderedInt(a, byte_offset(i), c); - unsafe.putOrderedInt(b, byte_offset(i+UNALIGN_OFF), d); + unsafe.putIntRelease(a, byte_offset(i), c); + unsafe.putIntRelease(b, byte_offset(i+UNALIGN_OFF), d); } } diff --git a/hotspot/test/compiler/ciReplay/TestSA.sh b/hotspot/test/compiler/ciReplay/TestSA.sh index bf98f1a7691..03999366558 100644 --- a/hotspot/test/compiler/ciReplay/TestSA.sh +++ b/hotspot/test/compiler/ciReplay/TestSA.sh @@ -29,6 +29,7 @@ ## @ignore 8029528 ## @summary testing of ciReplay with using generated by SA replay.txt ## @author igor.ignatyev@oracle.com +## @requires vm.flightRecorder != true ## @run shell TestSA.sh ## diff --git a/hotspot/test/compiler/ciReplay/TestVM.sh b/hotspot/test/compiler/ciReplay/TestVM.sh index e58d63e16fa..9b8fe49b284 100644 --- a/hotspot/test/compiler/ciReplay/TestVM.sh +++ b/hotspot/test/compiler/ciReplay/TestVM.sh @@ -28,6 +28,7 @@ ## @bug 8011675 ## @summary testing of ciReplay with using generated by VM replay.txt ## @author igor.ignatyev@oracle.com +## @requires vm.flightRecorder != true ## @run shell TestVM.sh ## diff --git a/hotspot/test/compiler/ciReplay/TestVM_no_comp_level.sh b/hotspot/test/compiler/ciReplay/TestVM_no_comp_level.sh index d961d42541d..85ce38b6605 100644 --- a/hotspot/test/compiler/ciReplay/TestVM_no_comp_level.sh +++ b/hotspot/test/compiler/ciReplay/TestVM_no_comp_level.sh @@ -28,6 +28,7 @@ ## @bug 8011675 ## @summary testing of ciReplay with using generated by VM replay.txt w/o comp_level ## @author igor.ignatyev@oracle.com +## @requires vm.flightRecorder != true ## @run shell TestVM_no_comp_level.sh ## diff --git a/hotspot/test/compiler/codegen/8011901/Test8011901.java b/hotspot/test/compiler/codegen/8011901/Test8011901.java index 9f071d58563..837a92c0058 100644 --- a/hotspot/test/compiler/codegen/8011901/Test8011901.java +++ b/hotspot/test/compiler/codegen/8011901/Test8011901.java @@ -30,21 +30,21 @@ * */ -import java.lang.reflect.*; -import sun.misc.*; +import java.lang.reflect.Field; +import jdk.internal.misc.Unsafe; public class Test8011901 { private long ctl; - private static final sun.misc.Unsafe U; + private static final Unsafe U; private static final long CTL; static { try { - Field unsafe = sun.misc.Unsafe.class.getDeclaredField("theUnsafe"); + Field unsafe = Unsafe.class.getDeclaredField("theUnsafe"); unsafe.setAccessible(true); - U = (sun.misc.Unsafe) unsafe.get(null); + U = (Unsafe) unsafe.get(null); CTL = U.objectFieldOffset(Test8011901.class.getDeclaredField("ctl")); } catch (Exception e) { throw new Error(e); diff --git a/hotspot/test/compiler/compilercontrol/commandfile/CompileOnlyTest.java b/hotspot/test/compiler/compilercontrol/commandfile/CompileOnlyTest.java index 925c1c7ef5c..8acac55c2b5 100644 --- a/hotspot/test/compiler/compilercontrol/commandfile/CompileOnlyTest.java +++ b/hotspot/test/compiler/compilercontrol/commandfile/CompileOnlyTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests CompileCommand=compileonly * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.commandfile.CompileOnlyTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.commandfile.CompileOnlyTest */ diff --git a/hotspot/test/compiler/compilercontrol/commandfile/ExcludeTest.java b/hotspot/test/compiler/compilercontrol/commandfile/ExcludeTest.java index 98b3c715276..4a4bde5917b 100644 --- a/hotspot/test/compiler/compilercontrol/commandfile/ExcludeTest.java +++ b/hotspot/test/compiler/compilercontrol/commandfile/ExcludeTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests CompileCommand=exclude * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.commandfile.ExcludeTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.commandfile.ExcludeTest */ diff --git a/hotspot/test/compiler/compilercontrol/commandfile/LogTest.java b/hotspot/test/compiler/compilercontrol/commandfile/LogTest.java index 18dd2a7dbdd..75b9e79f6d5 100644 --- a/hotspot/test/compiler/compilercontrol/commandfile/LogTest.java +++ b/hotspot/test/compiler/compilercontrol/commandfile/LogTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests CompileCommand=log * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.commandfile.LogTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.commandfile.LogTest */ diff --git a/hotspot/test/compiler/compilercontrol/commandfile/PrintTest.java b/hotspot/test/compiler/compilercontrol/commandfile/PrintTest.java index f47b9a43bae..ed45af6018d 100644 --- a/hotspot/test/compiler/compilercontrol/commandfile/PrintTest.java +++ b/hotspot/test/compiler/compilercontrol/commandfile/PrintTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests CompileCommand=print * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.commandfile.PrintTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.commandfile.PrintTest */ diff --git a/hotspot/test/compiler/compilercontrol/commands/CompileOnlyTest.java b/hotspot/test/compiler/compilercontrol/commands/CompileOnlyTest.java index d4e57e94e40..db98ab91a85 100644 --- a/hotspot/test/compiler/compilercontrol/commands/CompileOnlyTest.java +++ b/hotspot/test/compiler/compilercontrol/commands/CompileOnlyTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests CompileCommand=compileonly * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.commands.CompileOnlyTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.commands.CompileOnlyTest */ diff --git a/hotspot/test/compiler/compilercontrol/commands/ExcludeTest.java b/hotspot/test/compiler/compilercontrol/commands/ExcludeTest.java index f8311e77c70..272d4654ab5 100644 --- a/hotspot/test/compiler/compilercontrol/commands/ExcludeTest.java +++ b/hotspot/test/compiler/compilercontrol/commands/ExcludeTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests CompileCommand=exclude * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.commands.ExcludeTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.commands.ExcludeTest */ diff --git a/hotspot/test/compiler/compilercontrol/commands/LogTest.java b/hotspot/test/compiler/compilercontrol/commands/LogTest.java index 7f9db796be6..01189e36b25 100644 --- a/hotspot/test/compiler/compilercontrol/commands/LogTest.java +++ b/hotspot/test/compiler/compilercontrol/commands/LogTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests CompileCommand=log * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.commands.LogTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.commands.LogTest */ diff --git a/hotspot/test/compiler/compilercontrol/commands/PrintTest.java b/hotspot/test/compiler/compilercontrol/commands/PrintTest.java index bbe9efec173..f1bbe20bb5d 100644 --- a/hotspot/test/compiler/compilercontrol/commands/PrintTest.java +++ b/hotspot/test/compiler/compilercontrol/commands/PrintTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests CompileCommand=print * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.commands.PrintTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.commands.PrintTest */ diff --git a/hotspot/test/compiler/compilercontrol/directives/CompileOnlyTest.java b/hotspot/test/compiler/compilercontrol/directives/CompileOnlyTest.java index e351c42fd07..d9e8bd87227 100644 --- a/hotspot/test/compiler/compilercontrol/directives/CompileOnlyTest.java +++ b/hotspot/test/compiler/compilercontrol/directives/CompileOnlyTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests directives to be able to compile only specified methods * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.directives.CompileOnlyTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.directives.CompileOnlyTest */ diff --git a/hotspot/test/compiler/compilercontrol/directives/ExcludeTest.java b/hotspot/test/compiler/compilercontrol/directives/ExcludeTest.java index 5799fe20e0e..54614ab6aa9 100644 --- a/hotspot/test/compiler/compilercontrol/directives/ExcludeTest.java +++ b/hotspot/test/compiler/compilercontrol/directives/ExcludeTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests directives to be able to exclude methods from compilation * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.directives.ExcludeTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.directives.ExcludeTest */ diff --git a/hotspot/test/compiler/compilercontrol/directives/LogTest.java b/hotspot/test/compiler/compilercontrol/directives/LogTest.java index 0d5f9cc5dd1..18323234c6b 100644 --- a/hotspot/test/compiler/compilercontrol/directives/LogTest.java +++ b/hotspot/test/compiler/compilercontrol/directives/LogTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests directives to be able to turn on LogCompilation * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.directives.LogTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.directives.LogTest */ diff --git a/hotspot/test/compiler/compilercontrol/directives/PrintTest.java b/hotspot/test/compiler/compilercontrol/directives/PrintTest.java index ac45d43a768..d551865121e 100644 --- a/hotspot/test/compiler/compilercontrol/directives/PrintTest.java +++ b/hotspot/test/compiler/compilercontrol/directives/PrintTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests directives to be able to turn on print_assembly * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.directives.PrintTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.directives.PrintTest */ diff --git a/hotspot/test/compiler/compilercontrol/jcmd/AddAndRemoveTest.java b/hotspot/test/compiler/compilercontrol/jcmd/AddAndRemoveTest.java index ec296cea78a..01de110b64c 100644 --- a/hotspot/test/compiler/compilercontrol/jcmd/AddAndRemoveTest.java +++ b/hotspot/test/compiler/compilercontrol/jcmd/AddAndRemoveTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests directives to be able to add and remove directives * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.jcmd.AddAndRemoveTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.jcmd.AddAndRemoveTest */ diff --git a/hotspot/test/compiler/compilercontrol/jcmd/AddCompileOnlyTest.java b/hotspot/test/compiler/compilercontrol/jcmd/AddCompileOnlyTest.java index 70963733f45..e3783b4f586 100644 --- a/hotspot/test/compiler/compilercontrol/jcmd/AddCompileOnlyTest.java +++ b/hotspot/test/compiler/compilercontrol/jcmd/AddCompileOnlyTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests jcmd to be able to add a directive to compile only specified methods * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.jcmd.AddCompileOnlyTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.jcmd.AddCompileOnlyTest */ diff --git a/hotspot/test/compiler/compilercontrol/jcmd/AddExcludeTest.java b/hotspot/test/compiler/compilercontrol/jcmd/AddExcludeTest.java index 38125fb6bac..a4d552f60c3 100644 --- a/hotspot/test/compiler/compilercontrol/jcmd/AddExcludeTest.java +++ b/hotspot/test/compiler/compilercontrol/jcmd/AddExcludeTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests jcmd to be able to add a directive to exclude only specified methods * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.jcmd.AddExcludeTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.jcmd.AddExcludeTest */ diff --git a/hotspot/test/compiler/compilercontrol/jcmd/AddLogTest.java b/hotspot/test/compiler/compilercontrol/jcmd/AddLogTest.java index 7c14e41cf3c..acf98fa84df 100644 --- a/hotspot/test/compiler/compilercontrol/jcmd/AddLogTest.java +++ b/hotspot/test/compiler/compilercontrol/jcmd/AddLogTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests jcmd to be able to add a directive to log only specified methods * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.jcmd.AddLogTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.jcmd.AddLogTest */ diff --git a/hotspot/test/compiler/compilercontrol/jcmd/AddPrintAssemblyTest.java b/hotspot/test/compiler/compilercontrol/jcmd/AddPrintAssemblyTest.java index ea8bd585769..aff39388cf7 100644 --- a/hotspot/test/compiler/compilercontrol/jcmd/AddPrintAssemblyTest.java +++ b/hotspot/test/compiler/compilercontrol/jcmd/AddPrintAssemblyTest.java @@ -27,12 +27,12 @@ * @summary Tests jcmd to be able to add a directive to print assembly * only for specified methods * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.jcmd.AddPrintAssemblyTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.jcmd.AddPrintAssemblyTest */ diff --git a/hotspot/test/compiler/compilercontrol/jcmd/ClearDirectivesFileStackTest.java b/hotspot/test/compiler/compilercontrol/jcmd/ClearDirectivesFileStackTest.java index 4635a7f91f3..75c2e8a34de 100644 --- a/hotspot/test/compiler/compilercontrol/jcmd/ClearDirectivesFileStackTest.java +++ b/hotspot/test/compiler/compilercontrol/jcmd/ClearDirectivesFileStackTest.java @@ -27,12 +27,12 @@ * @ignore 8140405 * @summary Tests jcmd to be able to clear directives added via options * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.jcmd.ClearDirectivesFileStackTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.jcmd.ClearDirectivesFileStackTest */ diff --git a/hotspot/test/compiler/compilercontrol/jcmd/ClearDirectivesStackTest.java b/hotspot/test/compiler/compilercontrol/jcmd/ClearDirectivesStackTest.java index 20d7a7a3441..63b467a8c85 100644 --- a/hotspot/test/compiler/compilercontrol/jcmd/ClearDirectivesStackTest.java +++ b/hotspot/test/compiler/compilercontrol/jcmd/ClearDirectivesStackTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Tests clear JCMD command * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.jcmd.ClearDirectivesStackTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.jcmd.ClearDirectivesStackTest */ diff --git a/hotspot/test/compiler/compilercontrol/jcmd/PrintDirectivesTest.java b/hotspot/test/compiler/compilercontrol/jcmd/PrintDirectivesTest.java index 74bc4eef3ae..44c1d474177 100644 --- a/hotspot/test/compiler/compilercontrol/jcmd/PrintDirectivesTest.java +++ b/hotspot/test/compiler/compilercontrol/jcmd/PrintDirectivesTest.java @@ -26,12 +26,13 @@ * @bug 8137167 * @summary Tests jcmd to be able to add a directive to compile only specified methods * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / + * @requires vm.flavor != "minimal" * @build compiler.compilercontrol.jcmd.PrintDirectivesTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.jcmd.PrintDirectivesTest */ diff --git a/hotspot/test/compiler/compilercontrol/jcmd/StressAddMultiThreadedTest.java b/hotspot/test/compiler/compilercontrol/jcmd/StressAddMultiThreadedTest.java index 4cf2945108d..83f05f84e13 100644 --- a/hotspot/test/compiler/compilercontrol/jcmd/StressAddMultiThreadedTest.java +++ b/hotspot/test/compiler/compilercontrol/jcmd/StressAddMultiThreadedTest.java @@ -27,13 +27,13 @@ * @summary Tests jcmd to be able to add a lot of huge directive files with * parallel executed jcmds until timeout has reached * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.jcmd.StressAddMultiThreadedTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils * compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver compiler.compilercontrol.jcmd.StressAddMultiThreadedTest */ diff --git a/hotspot/test/compiler/compilercontrol/logcompilation/LogTest.java b/hotspot/test/compiler/compilercontrol/logcompilation/LogTest.java index 001251c4315..68b5981a8e3 100644 --- a/hotspot/test/compiler/compilercontrol/logcompilation/LogTest.java +++ b/hotspot/test/compiler/compilercontrol/logcompilation/LogTest.java @@ -26,14 +26,13 @@ * @bug 8137167 * @summary Tests LogCompilation executed standalone without log commands or directives * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.logcompilation.LogTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission - * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI - * -XX:+UnlockDiagnosticVMOptions compiler.compilercontrol.logcompilation.LogTest + * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver compiler.compilercontrol.logcompilation.LogTest */ package compiler.compilercontrol.logcompilation; @@ -45,6 +44,8 @@ public class LogTest { public static void main(String[] args) { Scenario.Builder builder = Scenario.getBuilder(); builder.addFlag("-XX:+UnlockDiagnosticVMOptions"); + builder.addFlag("-Xbootclasspath/a:."); + builder.addFlag("-XX:+WhiteBoxAPI"); builder.addFlag("-XX:+LogCompilation"); builder.addFlag("-XX:LogFile=" + LogProcessor.LOG_FILE); Scenario scenario = builder.build(); diff --git a/hotspot/test/compiler/compilercontrol/matcher/MethodMatcherTest.java b/hotspot/test/compiler/compilercontrol/matcher/MethodMatcherTest.java index 9ec1eccf6e1..2c8bcb5e3f1 100644 --- a/hotspot/test/compiler/compilercontrol/matcher/MethodMatcherTest.java +++ b/hotspot/test/compiler/compilercontrol/matcher/MethodMatcherTest.java @@ -21,6 +21,19 @@ * questions. */ +/* + * @test + * @bug 8135068 + * @summary Tests CompilerCommand's method matcher + * @modules java.base/jdk.internal.misc + * @library /testlibrary /test/lib ../share / + * @build compiler.compilercontrol.matcher.MethodMatcherTest + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions + * -XX:+WhiteBoxAPI compiler.compilercontrol.matcher.MethodMatcherTest + */ + package compiler.compilercontrol.matcher; import jdk.test.lib.Pair; @@ -36,18 +49,6 @@ import java.util.concurrent.Callable; import java.util.regex.Matcher; import java.util.regex.Pattern; -/* - * @test - * @bug 8135068 - * @summary Tests CompilerCommand's method matcher - * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/whitebox ../share / - * @build compiler.compilercontrol.matcher.MethodMatcherTest - * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission - * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions - * -XX:+WhiteBoxAPI compiler.compilercontrol.matcher.MethodMatcherTest - */ public class MethodMatcherTest { private static final WhiteBox WB = WhiteBox.getWhiteBox(); private static final PoolHelper POOL = new PoolHelper(); diff --git a/hotspot/test/compiler/compilercontrol/mixed/RandomCommandsTest.java b/hotspot/test/compiler/compilercontrol/mixed/RandomCommandsTest.java index 11d38586a96..24557664f9c 100644 --- a/hotspot/test/compiler/compilercontrol/mixed/RandomCommandsTest.java +++ b/hotspot/test/compiler/compilercontrol/mixed/RandomCommandsTest.java @@ -26,12 +26,12 @@ * @bug 8137167 * @summary Randomly generates commands with random types * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.mixed.RandomCommandsTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run driver/timeout=600 compiler.compilercontrol.mixed.RandomCommandsTest */ diff --git a/hotspot/test/compiler/compilercontrol/mixed/RandomValidCommandsTest.java b/hotspot/test/compiler/compilercontrol/mixed/RandomValidCommandsTest.java index 46c795205a6..d573ed0f88b 100644 --- a/hotspot/test/compiler/compilercontrol/mixed/RandomValidCommandsTest.java +++ b/hotspot/test/compiler/compilercontrol/mixed/RandomValidCommandsTest.java @@ -26,13 +26,13 @@ * @bug 8137167 * @summary Randomly generates valid commands with random types * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/testlibrary ../share / + * @library /testlibrary /test/lib ../share / * @build compiler.compilercontrol.mixed.RandomValidCommandsTest * pool.sub.* pool.subpack.* sun.hotspot.WhiteBox * compiler.testlibrary.CompilerUtils compiler.compilercontrol.share.actions.* * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission - * @run main/othervm/timeout=600 compiler.compilercontrol.mixed.RandomValidCommandsTest + * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver/timeout=600 compiler.compilercontrol.mixed.RandomValidCommandsTest */ package compiler.compilercontrol.mixed; diff --git a/hotspot/test/compiler/compilercontrol/share/MultiCommand.java b/hotspot/test/compiler/compilercontrol/share/MultiCommand.java index c5bfa5347f6..ab51daa1520 100644 --- a/hotspot/test/compiler/compilercontrol/share/MultiCommand.java +++ b/hotspot/test/compiler/compilercontrol/share/MultiCommand.java @@ -73,6 +73,7 @@ public class MultiCommand extends AbstractTestBase { public void test() { Scenario.Builder builder = Scenario.getBuilder(); builder.addFlag("-Xmixed"); + builder.addFlag("-XX:+UnlockDiagnosticVMOptions"); builder.addFlag("-XX:CompilerDirectivesLimit=101"); for (CompileCommand cc : testCases) { cc.print(); diff --git a/hotspot/test/compiler/cpuflags/TestAESIntrinsicsOnSupportedConfig.java b/hotspot/test/compiler/cpuflags/TestAESIntrinsicsOnSupportedConfig.java index 3c16553a549..75c411de149 100644 --- a/hotspot/test/compiler/cpuflags/TestAESIntrinsicsOnSupportedConfig.java +++ b/hotspot/test/compiler/cpuflags/TestAESIntrinsicsOnSupportedConfig.java @@ -21,24 +21,25 @@ * questions. * */ -import jdk.test.lib.OutputAnalyzer; -import jdk.test.lib.Platform; -import jdk.test.lib.ProcessTools; /* * @test - * @library /testlibrary /test/lib /compiler/whitebox - * /compiler/testlibrary /compiler/codegen/7184394 + * @library /testlibrary /test/lib /compiler/codegen/7184394 / * @modules java.base/jdk.internal.misc * java.management * @ignore 8146128 * @build TestAESIntrinsicsOnSupportedConfig TestAESMain - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI -Xbatch * TestAESIntrinsicsOnSupportedConfig */ + +import jdk.test.lib.OutputAnalyzer; +import jdk.test.lib.Platform; +import jdk.test.lib.ProcessTools; + public class TestAESIntrinsicsOnSupportedConfig extends AESIntrinsicsBase { /** diff --git a/hotspot/test/compiler/cpuflags/TestAESIntrinsicsOnUnsupportedConfig.java b/hotspot/test/compiler/cpuflags/TestAESIntrinsicsOnUnsupportedConfig.java index 0aeca412d17..9bc466229ad 100644 --- a/hotspot/test/compiler/cpuflags/TestAESIntrinsicsOnUnsupportedConfig.java +++ b/hotspot/test/compiler/cpuflags/TestAESIntrinsicsOnUnsupportedConfig.java @@ -22,22 +22,22 @@ * */ +/* + * @test + * @library /testlibrary /test/lib /compiler/codegen/7184394 / + * @modules java.base/jdk.internal.misc + * java.management + * @build TestAESIntrinsicsOnUnsupportedConfig TestAESMain + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions + * -XX:+WhiteBoxAPI -Xbatch TestAESIntrinsicsOnUnsupportedConfig + */ + import jdk.test.lib.cli.predicate.NotPredicate; import jdk.test.lib.OutputAnalyzer; import jdk.test.lib.ProcessTools; -/* - * @test - * @library /testlibrary /test/lib /compiler/whitebox - * /compiler/testlibrary /compiler/codegen/7184394 - * @modules java.base/jdk.internal.misc - * java.management - * @build TestAESIntrinsicsOnUnsupportedConfig TestAESMain - * @run main ClassFileInstaller - * sun.hotspot.WhiteBox sun.hotspot.WhiteBox$WhiteBoxPermission - * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions - * -XX:+WhiteBoxAPI -Xbatch TestAESIntrinsicsOnUnsupportedConfig - */ public class TestAESIntrinsicsOnUnsupportedConfig extends AESIntrinsicsBase { private static final String INTRINSICS_NOT_AVAILABLE_MSG = "warning: AES " diff --git a/hotspot/test/compiler/exceptions/TestRecursiveReplacedException.java b/hotspot/test/compiler/exceptions/TestRecursiveReplacedException.java index d3cace05343..950ed18c928 100644 --- a/hotspot/test/compiler/exceptions/TestRecursiveReplacedException.java +++ b/hotspot/test/compiler/exceptions/TestRecursiveReplacedException.java @@ -25,7 +25,7 @@ * @test * @bug 8054224 * @summary Recursive method compiled by C1 is unable to catch StackOverflowError - * @run main/othervm -Xcomp -XX:CompileOnly=Test.run -XX:+TieredCompilation -XX:TieredStopAtLevel=2 -Xss392K TestRecursiveReplacedException + * @run main/othervm -Xcomp -XX:CompileOnly=Test.run -XX:+TieredCompilation -XX:TieredStopAtLevel=2 -Xss512K TestRecursiveReplacedException * */ diff --git a/hotspot/test/compiler/floatingpoint/TestPow2.java b/hotspot/test/compiler/floatingpoint/TestPow2.java index d3893e9863c..01b094ef533 100644 --- a/hotspot/test/compiler/floatingpoint/TestPow2.java +++ b/hotspot/test/compiler/floatingpoint/TestPow2.java @@ -25,11 +25,12 @@ * @test * @bug 8063086 * @summary X^2 special case for C2 yields different result than interpreter - * @library /testlibrary /test/lib /compiler/whitebox / + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * @modules java.management * @build TestPow2 - * @run main ClassFileInstaller sun.hotspot.WhiteBox + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:-BackgroundCompilation -XX:-UseOnStackReplacement TestPow2 * diff --git a/hotspot/test/compiler/intrinsics/IntrinsicAvailableTest.java b/hotspot/test/compiler/intrinsics/IntrinsicAvailableTest.java index ab582f94b18..42ddab0303c 100644 --- a/hotspot/test/compiler/intrinsics/IntrinsicAvailableTest.java +++ b/hotspot/test/compiler/intrinsics/IntrinsicAvailableTest.java @@ -20,20 +20,15 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ -import java.lang.reflect.Executable; -import java.util.concurrent.Callable; -import java.util.Objects; -import jdk.test.lib.*; -import compiler.whitebox.CompilerWhiteBoxTest; /* * @test * @bug 8130832 * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/whitebox /compiler/testlibrary / + * @library /testlibrary /test/lib / * @build IntrinsicAvailableTest - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. * -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI @@ -45,6 +40,14 @@ import compiler.whitebox.CompilerWhiteBoxTest; * -XX:-UseCRC32Intrinsics * IntrinsicAvailableTest */ + +import java.lang.reflect.Executable; +import java.util.concurrent.Callable; +import java.util.Objects; + +import jdk.test.lib.*; +import compiler.whitebox.CompilerWhiteBoxTest; + public class IntrinsicAvailableTest extends CompilerWhiteBoxTest { protected String VMName; diff --git a/hotspot/test/compiler/intrinsics/bmi/verifycode/AndnTestI.java b/hotspot/test/compiler/intrinsics/bmi/verifycode/AndnTestI.java index 15380e8cd5f..0e224f86214 100644 --- a/hotspot/test/compiler/intrinsics/bmi/verifycode/AndnTestI.java +++ b/hotspot/test/compiler/intrinsics/bmi/verifycode/AndnTestI.java @@ -24,12 +24,12 @@ /* * @test * @bug 8031321 - * @library /testlibrary /test/lib /compiler/whitebox / .. + * @library /testlibrary /test/lib / .. * @modules java.base/jdk.internal.misc * java.management * @build AndnTestI - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/bootclasspath/othervm -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:+IgnoreUnrecognizedVMOptions -XX:+UseBMI1Instructions AndnTestI */ diff --git a/hotspot/test/compiler/intrinsics/bmi/verifycode/AndnTestL.java b/hotspot/test/compiler/intrinsics/bmi/verifycode/AndnTestL.java index e0b9ecda1ea..369c0338e88 100644 --- a/hotspot/test/compiler/intrinsics/bmi/verifycode/AndnTestL.java +++ b/hotspot/test/compiler/intrinsics/bmi/verifycode/AndnTestL.java @@ -24,12 +24,12 @@ /* * @test * @bug 8031321 - * @library /testlibrary /test/lib /compiler/whitebox / .. + * @library /testlibrary /test/lib / .. * @modules java.base/jdk.internal.misc * java.management * @build AndnTestL - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/bootclasspath/othervm -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:+IgnoreUnrecognizedVMOptions -XX:+UseBMI1Instructions AndnTestL */ diff --git a/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsiTestI.java b/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsiTestI.java index fa944503aba..62860dac58c 100644 --- a/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsiTestI.java +++ b/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsiTestI.java @@ -24,12 +24,12 @@ /* * @test * @bug 8031321 - * @library /testlibrary /test/lib /compiler/whitebox / .. + * @library /testlibrary /test/lib / .. * @modules java.base/jdk.internal.misc * java.management * @build BlsiTestI - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:+IgnoreUnrecognizedVMOptions -XX:+UseBMI1Instructions BlsiTestI */ diff --git a/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsiTestL.java b/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsiTestL.java index 0ed38997ab5..ef665a1cd1d 100644 --- a/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsiTestL.java +++ b/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsiTestL.java @@ -24,12 +24,12 @@ /* * @test * @bug 8031321 - * @library /testlibrary /test/lib /compiler/whitebox / .. + * @library /testlibrary /test/lib / .. * @modules java.base/jdk.internal.misc * java.management * @build BlsiTestL - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:+IgnoreUnrecognizedVMOptions -XX:+UseBMI1Instructions BlsiTestL */ diff --git a/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsmskTestI.java b/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsmskTestI.java index bed3688eeed..e780495ce86 100644 --- a/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsmskTestI.java +++ b/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsmskTestI.java @@ -24,12 +24,12 @@ /* * @test * @bug 8031321 - * @library /testlibrary /test/lib /compiler/whitebox / .. + * @library /testlibrary /test/lib / .. * @modules java.base/jdk.internal.misc * java.management * @build BlsmskTestI - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:+IgnoreUnrecognizedVMOptions -XX:+UseBMI1Instructions BlsmskTestI */ diff --git a/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsmskTestL.java b/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsmskTestL.java index a419019fe0a..6f4346840bd 100644 --- a/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsmskTestL.java +++ b/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsmskTestL.java @@ -24,12 +24,12 @@ /* * @test * @bug 8031321 - * @library /testlibrary /test/lib /compiler/whitebox / .. + * @library /testlibrary /test/lib / .. * @modules java.base/jdk.internal.misc * java.management * @build BlsmskTestL - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:+IgnoreUnrecognizedVMOptions -XX:+UseBMI1Instructions BlsmskTestL */ diff --git a/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsrTestI.java b/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsrTestI.java index bb67b4185e9..a6791b019ee 100644 --- a/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsrTestI.java +++ b/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsrTestI.java @@ -24,12 +24,12 @@ /* * @test * @bug 8031321 - * @library /testlibrary /test/lib /compiler/whitebox / .. + * @library /testlibrary /test/lib / .. * @modules java.base/jdk.internal.misc * java.management * @build BlsrTestI - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:+IgnoreUnrecognizedVMOptions -XX:+UseBMI1Instructions BlsrTestI */ diff --git a/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsrTestL.java b/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsrTestL.java index b9ee3f3f12d..cd34faf346d 100644 --- a/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsrTestL.java +++ b/hotspot/test/compiler/intrinsics/bmi/verifycode/BlsrTestL.java @@ -24,12 +24,12 @@ /* * @test * @bug 8031321 - * @library /testlibrary /test/lib /compiler/whitebox / .. + * @library /testlibrary /test/lib / .. * @modules java.base/jdk.internal.misc * java.management * @build BlsrTestL - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:+IgnoreUnrecognizedVMOptions -XX:+UseBMI1Instructions BlsrTestL */ diff --git a/hotspot/test/compiler/intrinsics/bmi/verifycode/LZcntTestI.java b/hotspot/test/compiler/intrinsics/bmi/verifycode/LZcntTestI.java index 0cceb5847f5..f23792a1855 100644 --- a/hotspot/test/compiler/intrinsics/bmi/verifycode/LZcntTestI.java +++ b/hotspot/test/compiler/intrinsics/bmi/verifycode/LZcntTestI.java @@ -24,12 +24,12 @@ /* * @test * @bug 8031321 - * @library /testlibrary /test/lib /compiler/whitebox / .. + * @library /testlibrary /test/lib / .. * @modules java.base/jdk.internal.misc * java.management * @build LZcntTestI - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:+IgnoreUnrecognizedVMOptions -XX:+UseCountLeadingZerosInstruction LZcntTestI */ diff --git a/hotspot/test/compiler/intrinsics/bmi/verifycode/LZcntTestL.java b/hotspot/test/compiler/intrinsics/bmi/verifycode/LZcntTestL.java index 051999739c5..71a0fc0a65c 100644 --- a/hotspot/test/compiler/intrinsics/bmi/verifycode/LZcntTestL.java +++ b/hotspot/test/compiler/intrinsics/bmi/verifycode/LZcntTestL.java @@ -24,12 +24,12 @@ /* * @test * @bug 8031321 - * @library /testlibrary /test/lib /compiler/whitebox / .. + * @library /testlibrary /test/lib / .. * @modules java.base/jdk.internal.misc * java.management * @build LZcntTestL - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:+IgnoreUnrecognizedVMOptions -XX:+UseCountLeadingZerosInstruction LZcntTestL */ diff --git a/hotspot/test/compiler/intrinsics/bmi/verifycode/TZcntTestI.java b/hotspot/test/compiler/intrinsics/bmi/verifycode/TZcntTestI.java index a6d12248c47..1f71f43e22c 100644 --- a/hotspot/test/compiler/intrinsics/bmi/verifycode/TZcntTestI.java +++ b/hotspot/test/compiler/intrinsics/bmi/verifycode/TZcntTestI.java @@ -24,12 +24,12 @@ /* * @test * @bug 8031321 - * @library /testlibrary /test/lib /compiler/whitebox / .. + * @library /testlibrary /test/lib / .. * @modules java.base/jdk.internal.misc * java.management * @build TZcntTestI - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:+IgnoreUnrecognizedVMOptions -XX:+UseCountTrailingZerosInstruction TZcntTestI */ diff --git a/hotspot/test/compiler/intrinsics/bmi/verifycode/TZcntTestL.java b/hotspot/test/compiler/intrinsics/bmi/verifycode/TZcntTestL.java index 618c18aa02e..ca77c2a4d48 100644 --- a/hotspot/test/compiler/intrinsics/bmi/verifycode/TZcntTestL.java +++ b/hotspot/test/compiler/intrinsics/bmi/verifycode/TZcntTestL.java @@ -24,12 +24,12 @@ /* * @test * @bug 8031321 - * @library /testlibrary /test/lib /compiler/whitebox / .. + * @library /testlibrary /test/lib / .. * @modules java.base/jdk.internal.misc * java.management * @build TZcntTestL - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:+IgnoreUnrecognizedVMOptions -XX:+UseCountTrailingZerosInstruction TZcntTestL */ diff --git a/hotspot/test/compiler/intrinsics/mathexact/sanity/AddExactIntTest.java b/hotspot/test/compiler/intrinsics/mathexact/sanity/AddExactIntTest.java index 0a183ffe102..b9b643d60d3 100644 --- a/hotspot/test/compiler/intrinsics/mathexact/sanity/AddExactIntTest.java +++ b/hotspot/test/compiler/intrinsics/mathexact/sanity/AddExactIntTest.java @@ -23,12 +23,12 @@ /* * @test - * @library /testlibrary /test/lib /compiler/whitebox / /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build AddExactIntTest - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod @@ -37,7 +37,7 @@ * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod * -XX:LogFile=hs.log -XX:+UseMathExactIntrinsics AddExactIntTest - * @run main intrinsics.Verifier hs_neg.log hs.log + * @run driver compiler.testlibrary.intrinsics.Verifier hs_neg.log hs.log */ public class AddExactIntTest { diff --git a/hotspot/test/compiler/intrinsics/mathexact/sanity/AddExactLongTest.java b/hotspot/test/compiler/intrinsics/mathexact/sanity/AddExactLongTest.java index 961a3e2dfe6..45f78d41c4a 100644 --- a/hotspot/test/compiler/intrinsics/mathexact/sanity/AddExactLongTest.java +++ b/hotspot/test/compiler/intrinsics/mathexact/sanity/AddExactLongTest.java @@ -23,12 +23,12 @@ /* * @test - * @library /testlibrary /test/lib /compiler/whitebox / /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build AddExactLongTest - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod @@ -37,7 +37,7 @@ * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod * -XX:LogFile=hs.log -XX:+UseMathExactIntrinsics AddExactLongTest - * @run main intrinsics.Verifier hs_neg.log hs.log + * @run driver compiler.testlibrary.intrinsics.Verifier hs_neg.log hs.log */ public class AddExactLongTest { diff --git a/hotspot/test/compiler/intrinsics/mathexact/sanity/DecrementExactIntTest.java b/hotspot/test/compiler/intrinsics/mathexact/sanity/DecrementExactIntTest.java index 2e182ce6eb0..15f2d74764b 100644 --- a/hotspot/test/compiler/intrinsics/mathexact/sanity/DecrementExactIntTest.java +++ b/hotspot/test/compiler/intrinsics/mathexact/sanity/DecrementExactIntTest.java @@ -23,12 +23,12 @@ /* * @test - * @library /testlibrary /test/lib /compiler/whitebox / /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build DecrementExactIntTest - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod @@ -37,7 +37,7 @@ * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod * -XX:LogFile=hs.log -XX:+UseMathExactIntrinsics DecrementExactIntTest - * @run main intrinsics.Verifier hs_neg.log hs.log + * @run driver compiler.testlibrary.intrinsics.Verifier hs_neg.log hs.log */ public class DecrementExactIntTest { diff --git a/hotspot/test/compiler/intrinsics/mathexact/sanity/DecrementExactLongTest.java b/hotspot/test/compiler/intrinsics/mathexact/sanity/DecrementExactLongTest.java index 7c8121afab7..97fad805478 100644 --- a/hotspot/test/compiler/intrinsics/mathexact/sanity/DecrementExactLongTest.java +++ b/hotspot/test/compiler/intrinsics/mathexact/sanity/DecrementExactLongTest.java @@ -23,12 +23,12 @@ /* * @test - * @library /testlibrary /test/lib /compiler/whitebox / /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build DecrementExactLongTest - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod @@ -37,7 +37,7 @@ * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod * -XX:LogFile=hs.log -XX:+UseMathExactIntrinsics DecrementExactLongTest - * @run main intrinsics.Verifier hs_neg.log hs.log + * @run driver compiler.testlibrary.intrinsics.Verifier hs_neg.log hs.log */ public class DecrementExactLongTest { diff --git a/hotspot/test/compiler/intrinsics/mathexact/sanity/IncrementExactIntTest.java b/hotspot/test/compiler/intrinsics/mathexact/sanity/IncrementExactIntTest.java index ee47968b7e6..b1125c01408 100644 --- a/hotspot/test/compiler/intrinsics/mathexact/sanity/IncrementExactIntTest.java +++ b/hotspot/test/compiler/intrinsics/mathexact/sanity/IncrementExactIntTest.java @@ -23,12 +23,12 @@ /* * @test - * @library /testlibrary /test/lib /compiler/whitebox / /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build IncrementExactIntTest - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod @@ -37,7 +37,7 @@ * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod * -XX:LogFile=hs.log -XX:+UseMathExactIntrinsics IncrementExactIntTest - * @run main intrinsics.Verifier hs_neg.log hs.log + * @run driver compiler.testlibrary.intrinsics.Verifier hs_neg.log hs.log */ public class IncrementExactIntTest { diff --git a/hotspot/test/compiler/intrinsics/mathexact/sanity/IncrementExactLongTest.java b/hotspot/test/compiler/intrinsics/mathexact/sanity/IncrementExactLongTest.java index eb65784e18f..79f2497652f 100644 --- a/hotspot/test/compiler/intrinsics/mathexact/sanity/IncrementExactLongTest.java +++ b/hotspot/test/compiler/intrinsics/mathexact/sanity/IncrementExactLongTest.java @@ -23,12 +23,12 @@ /* * @test - * @library /testlibrary /test/lib /compiler/whitebox / /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build IncrementExactLongTest - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod @@ -37,7 +37,7 @@ * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod * -XX:LogFile=hs.log -XX:+UseMathExactIntrinsics IncrementExactLongTest - * @run main intrinsics.Verifier hs_neg.log hs.log + * @run driver compiler.testlibrary.intrinsics.Verifier hs_neg.log hs.log */ public class IncrementExactLongTest { diff --git a/hotspot/test/compiler/intrinsics/mathexact/sanity/IntrinsicBase.java b/hotspot/test/compiler/intrinsics/mathexact/sanity/IntrinsicBase.java index e271f9fd49f..f902164efa0 100644 --- a/hotspot/test/compiler/intrinsics/mathexact/sanity/IntrinsicBase.java +++ b/hotspot/test/compiler/intrinsics/mathexact/sanity/IntrinsicBase.java @@ -22,12 +22,13 @@ */ import jdk.test.lib.Platform; -import intrinsics.Verifier; import java.io.FileOutputStream; import java.lang.reflect.Executable; import java.util.Properties; + import compiler.whitebox.CompilerWhiteBoxTest; +import compiler.testlibrary.intrinsics.Verifier; public abstract class IntrinsicBase extends CompilerWhiteBoxTest { protected String javaVmName; diff --git a/hotspot/test/compiler/intrinsics/mathexact/sanity/MultiplyExactIntTest.java b/hotspot/test/compiler/intrinsics/mathexact/sanity/MultiplyExactIntTest.java index 7c53f29b0df..c3aec6265e6 100644 --- a/hotspot/test/compiler/intrinsics/mathexact/sanity/MultiplyExactIntTest.java +++ b/hotspot/test/compiler/intrinsics/mathexact/sanity/MultiplyExactIntTest.java @@ -23,12 +23,12 @@ /* * @test - * @library /testlibrary /test/lib /compiler/whitebox / /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build MultiplyExactIntTest - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod @@ -37,7 +37,7 @@ * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod * -XX:LogFile=hs.log -XX:+UseMathExactIntrinsics MultiplyExactIntTest - * @run main intrinsics.Verifier hs_neg.log hs.log + * @run driver compiler.testlibrary.intrinsics.Verifier hs_neg.log hs.log */ public class MultiplyExactIntTest { diff --git a/hotspot/test/compiler/intrinsics/mathexact/sanity/MultiplyExactLongTest.java b/hotspot/test/compiler/intrinsics/mathexact/sanity/MultiplyExactLongTest.java index 7c82e7328fd..bc49440cb46 100644 --- a/hotspot/test/compiler/intrinsics/mathexact/sanity/MultiplyExactLongTest.java +++ b/hotspot/test/compiler/intrinsics/mathexact/sanity/MultiplyExactLongTest.java @@ -23,12 +23,12 @@ /* * @test - * @library /testlibrary /test/lib /compiler/whitebox / /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build MultiplyExactLongTest - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod @@ -37,7 +37,7 @@ * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod * -XX:LogFile=hs.log -XX:+UseMathExactIntrinsics MultiplyExactLongTest - * @run main intrinsics.Verifier hs_neg.log hs.log + * @run driver compiler.testlibrary.intrinsics.Verifier hs_neg.log hs.log */ public class MultiplyExactLongTest { diff --git a/hotspot/test/compiler/intrinsics/mathexact/sanity/NegateExactIntTest.java b/hotspot/test/compiler/intrinsics/mathexact/sanity/NegateExactIntTest.java index c1ddb1649b7..d39d10871ad 100644 --- a/hotspot/test/compiler/intrinsics/mathexact/sanity/NegateExactIntTest.java +++ b/hotspot/test/compiler/intrinsics/mathexact/sanity/NegateExactIntTest.java @@ -23,12 +23,12 @@ /* * @test - * @library /testlibrary /test/lib /compiler/whitebox / /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build NegateExactIntTest - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod @@ -37,7 +37,7 @@ * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod * -XX:LogFile=hs.log -XX:+UseMathExactIntrinsics NegateExactIntTest - * @run main intrinsics.Verifier hs_neg.log hs.log + * @run driver compiler.testlibrary.intrinsics.Verifier hs_neg.log hs.log */ public class NegateExactIntTest { diff --git a/hotspot/test/compiler/intrinsics/mathexact/sanity/NegateExactLongTest.java b/hotspot/test/compiler/intrinsics/mathexact/sanity/NegateExactLongTest.java index dc18373ce95..8ad985b3d9c 100644 --- a/hotspot/test/compiler/intrinsics/mathexact/sanity/NegateExactLongTest.java +++ b/hotspot/test/compiler/intrinsics/mathexact/sanity/NegateExactLongTest.java @@ -23,12 +23,12 @@ /* * @test - * @library /testlibrary /test/lib /compiler/whitebox / /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build NegateExactLongTest - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod @@ -37,7 +37,7 @@ * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod * -XX:LogFile=hs.log -XX:+UseMathExactIntrinsics NegateExactLongTest - * @run main intrinsics.Verifier hs_neg.log hs.log + * @run driver compiler.testlibrary.intrinsics.Verifier hs_neg.log hs.log */ public class NegateExactLongTest { diff --git a/hotspot/test/compiler/intrinsics/mathexact/sanity/SubtractExactIntTest.java b/hotspot/test/compiler/intrinsics/mathexact/sanity/SubtractExactIntTest.java index 12813886b2d..cf7f2f1458c 100644 --- a/hotspot/test/compiler/intrinsics/mathexact/sanity/SubtractExactIntTest.java +++ b/hotspot/test/compiler/intrinsics/mathexact/sanity/SubtractExactIntTest.java @@ -23,12 +23,12 @@ /* * @test - * @library /testlibrary /test/lib /compiler/whitebox / /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build SubtractExactIntTest - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod @@ -37,8 +37,7 @@ * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod * -XX:LogFile=hs.log -XX:+UseMathExactIntrinsics SubtractExactIntTest - * @run main intrinsics.Verifier hs_neg.log hs.log - + * @run driver compiler.testlibrary.intrinsics.Verifier hs_neg.log hs.log */ public class SubtractExactIntTest { diff --git a/hotspot/test/compiler/intrinsics/mathexact/sanity/SubtractExactLongTest.java b/hotspot/test/compiler/intrinsics/mathexact/sanity/SubtractExactLongTest.java index dd3e1c233df..d71ee75e4c7 100644 --- a/hotspot/test/compiler/intrinsics/mathexact/sanity/SubtractExactLongTest.java +++ b/hotspot/test/compiler/intrinsics/mathexact/sanity/SubtractExactLongTest.java @@ -23,12 +23,12 @@ /* * @test - * @library /testlibrary /test/lib /compiler/whitebox / /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build SubtractExactLongTest - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod @@ -37,7 +37,7 @@ * -XX:+IgnoreUnrecognizedVMOptions -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,MathIntrinsic*::execMathMethod * -XX:LogFile=hs.log -XX:+UseMathExactIntrinsics SubtractExactLongTest - * @run main intrinsics.Verifier hs_neg.log hs.log + * @run driver compiler.testlibrary.intrinsics.Verifier hs_neg.log hs.log */ public class SubtractExactLongTest { diff --git a/hotspot/test/compiler/intrinsics/sha/cli/SHAOptionsBase.java b/hotspot/test/compiler/intrinsics/sha/cli/SHAOptionsBase.java index febf666aeb7..cb0856cc778 100644 --- a/hotspot/test/compiler/intrinsics/sha/cli/SHAOptionsBase.java +++ b/hotspot/test/compiler/intrinsics/sha/cli/SHAOptionsBase.java @@ -23,7 +23,7 @@ import jdk.test.lib.Platform; import jdk.test.lib.cli.CommandLineOptionTest; -import sha.predicate.IntrinsicPredicates; +import compiler.testlibrary.sha.predicate.IntrinsicPredicates; import java.util.function.BooleanSupplier; diff --git a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnSupportedCPU.java b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnSupportedCPU.java index ad85544a188..7fc3642e618 100644 --- a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnSupportedCPU.java +++ b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnSupportedCPU.java @@ -24,13 +24,13 @@ /** * @test * @bug 8035968 - * @summary Verify UseSHA1Intrinsics option processing on supported CPU, - * @library /testlibrary /test/lib /compiler/testlibrary testcases + * @summary Verify UseSHA1Intrinsics option processing on supported CPU. + * @library /testlibrary /test/lib testcases / * @modules java.base/jdk.internal.misc * java.management * @build TestUseSHA1IntrinsicsOptionOnSupportedCPU - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseSHA1IntrinsicsOptionOnSupportedCPU */ diff --git a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnUnsupportedCPU.java b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnUnsupportedCPU.java index f48613971eb..34b66806c37 100644 --- a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnUnsupportedCPU.java +++ b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnUnsupportedCPU.java @@ -24,13 +24,13 @@ /** * @test * @bug 8035968 - * @summary Verify UseSHA1Intrinsics option processing on unsupported CPU, - * @library /testlibrary /test/lib /compiler/testlibrary testcases + * @summary Verify UseSHA1Intrinsics option processing on unsupported CPU. + * @library /testlibrary /test/lib testcases / * @modules java.base/jdk.internal.misc * java.management * @build TestUseSHA1IntrinsicsOptionOnUnsupportedCPU - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI * TestUseSHA1IntrinsicsOptionOnUnsupportedCPU diff --git a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnSupportedCPU.java b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnSupportedCPU.java index 692bf2262fb..47106008cc1 100644 --- a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnSupportedCPU.java +++ b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnSupportedCPU.java @@ -24,13 +24,13 @@ /** * @test * @bug 8035968 - * @summary Verify UseSHA256Intrinsics option processing on supported CPU, - * @library /testlibrary /test/lib /compiler/testlibrary testcases + * @summary Verify UseSHA256Intrinsics option processing on supported CPU. + * @library /testlibrary /test/lib testcases / * @modules java.base/jdk.internal.misc * java.management * @build TestUseSHA256IntrinsicsOptionOnSupportedCPU - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI * TestUseSHA256IntrinsicsOptionOnSupportedCPU diff --git a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnUnsupportedCPU.java b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnUnsupportedCPU.java index 665a05f3f41..a23dd213bf2 100644 --- a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnUnsupportedCPU.java +++ b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnUnsupportedCPU.java @@ -24,13 +24,13 @@ /** * @test * @bug 8035968 - * @summary Verify UseSHA256Intrinsics option processing on unsupported CPU, - * @library /testlibrary /test/lib /compiler/testlibrary testcases + * @summary Verify UseSHA256Intrinsics option processing on unsupported CPU. + * @library /testlibrary /test/lib testcases / * @modules java.base/jdk.internal.misc * java.management * @build TestUseSHA256IntrinsicsOptionOnUnsupportedCPU - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI * TestUseSHA256IntrinsicsOptionOnUnsupportedCPU diff --git a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnSupportedCPU.java b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnSupportedCPU.java index e9dec043dce..fb7c06558e0 100644 --- a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnSupportedCPU.java +++ b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnSupportedCPU.java @@ -25,12 +25,12 @@ * @test * @bug 8035968 * @summary Verify UseSHA512Intrinsics option processing on supported CPU. - * @library /testlibrary /test/lib /compiler/testlibrary testcases + * @library /testlibrary /test/lib testcases / * @modules java.base/jdk.internal.misc * java.management * @build TestUseSHA512IntrinsicsOptionOnSupportedCPU - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI * TestUseSHA512IntrinsicsOptionOnSupportedCPU diff --git a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnUnsupportedCPU.java b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnUnsupportedCPU.java index ac270b055f8..d57c63ea01a 100644 --- a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnUnsupportedCPU.java +++ b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnUnsupportedCPU.java @@ -24,13 +24,13 @@ /** * @test * @bug 8035968 - * @summary Verify UseSHA512Intrinsics option processing on unsupported CPU, - * @library /testlibrary /test/lib /compiler/testlibrary testcases + * @summary Verify UseSHA512Intrinsics option processing on unsupported CPU. + * @library /testlibrary /test/lib testcases / * @modules java.base/jdk.internal.misc * java.management * @build TestUseSHA512IntrinsicsOptionOnUnsupportedCPU - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI * TestUseSHA512IntrinsicsOptionOnUnsupportedCPU diff --git a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHAOptionOnSupportedCPU.java b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHAOptionOnSupportedCPU.java index 7873eef1c95..5903dfbee89 100644 --- a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHAOptionOnSupportedCPU.java +++ b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHAOptionOnSupportedCPU.java @@ -24,13 +24,13 @@ /** * @test * @bug 8035968 - * @summary Verify UseSHA option processing on supported CPU, - * @library /testlibrary /test/lib /compiler/testlibrary testcases + * @summary Verify UseSHA option processing on supported CPU. + * @library /testlibrary /test/lib testcases / * @modules java.base/jdk.internal.misc * java.management * @build TestUseSHAOptionOnSupportedCPU - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseSHAOptionOnSupportedCPU */ diff --git a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHAOptionOnUnsupportedCPU.java b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHAOptionOnUnsupportedCPU.java index 3a5f6f08cda..3fed6d20d0d 100644 --- a/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHAOptionOnUnsupportedCPU.java +++ b/hotspot/test/compiler/intrinsics/sha/cli/TestUseSHAOptionOnUnsupportedCPU.java @@ -25,12 +25,12 @@ * @test * @bug 8035968 * @summary Verify UseSHA option processing on unsupported CPU. - * @library /testlibrary /test/lib /compiler/testlibrary testcases + * @library /testlibrary /test/lib testcases / * @modules java.base/jdk.internal.misc * java.management * @build TestUseSHAOptionOnUnsupportedCPU - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseSHAOptionOnUnsupportedCPU */ diff --git a/hotspot/test/compiler/intrinsics/sha/cli/testcases/UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU.java b/hotspot/test/compiler/intrinsics/sha/cli/testcases/UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU.java index c75a66795b8..a4dfe43742f 100644 --- a/hotspot/test/compiler/intrinsics/sha/cli/testcases/UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU.java +++ b/hotspot/test/compiler/intrinsics/sha/cli/testcases/UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU.java @@ -27,7 +27,7 @@ import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; import jdk.test.lib.cli.predicate.OrPredicate; import jdk.test.lib.cli.predicate.NotPredicate; -import sha.predicate.IntrinsicPredicates; +import compiler.testlibrary.sha.predicate.IntrinsicPredicates; /** * Test case specific to UseSHA*Intrinsics options targeted to SPARC and AArch64 diff --git a/hotspot/test/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForSupportedCPU.java b/hotspot/test/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForSupportedCPU.java index 3c1d208790e..f4ed3bb6db1 100644 --- a/hotspot/test/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForSupportedCPU.java +++ b/hotspot/test/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForSupportedCPU.java @@ -27,7 +27,7 @@ import jdk.test.lib.Platform; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; import jdk.test.lib.cli.predicate.OrPredicate; -import sha.predicate.IntrinsicPredicates; +import compiler.testlibrary.sha.predicate.IntrinsicPredicates; /** * UseSHA specific test case targeted to SPARC and AArch64 CPUs which diff --git a/hotspot/test/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForUnsupportedCPU.java b/hotspot/test/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForUnsupportedCPU.java index 22f133deaa9..bc3068deb6a 100644 --- a/hotspot/test/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForUnsupportedCPU.java +++ b/hotspot/test/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForUnsupportedCPU.java @@ -28,7 +28,7 @@ import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; import jdk.test.lib.cli.predicate.OrPredicate; import jdk.test.lib.cli.predicate.NotPredicate; -import sha.predicate.IntrinsicPredicates; +import compiler.testlibrary.sha.predicate.IntrinsicPredicates; /** * UseSHA specific test case targeted to SPARC and AArch64 CPUs which don't diff --git a/hotspot/test/compiler/intrinsics/sha/sanity/SHASanityTestBase.java b/hotspot/test/compiler/intrinsics/sha/sanity/SHASanityTestBase.java index 13b10a51269..d60671c22fc 100644 --- a/hotspot/test/compiler/intrinsics/sha/sanity/SHASanityTestBase.java +++ b/hotspot/test/compiler/intrinsics/sha/sanity/SHASanityTestBase.java @@ -21,7 +21,6 @@ * questions. */ -import intrinsics.Verifier; import sun.hotspot.WhiteBox; import java.io.FileOutputStream; @@ -30,6 +29,8 @@ import java.util.Objects; import java.util.Properties; import java.util.function.BooleanSupplier; +import compiler.testlibrary.intrinsics.Verifier; + /** * Base class for sanity tests on SHA intrinsics support. */ diff --git a/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA1Intrinsics.java b/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA1Intrinsics.java index 7f1dba6213c..98ae9c3ab0b 100644 --- a/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA1Intrinsics.java +++ b/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA1Intrinsics.java @@ -25,12 +25,12 @@ * @test * @bug 8035968 * @summary Verify that SHA-1 intrinsic is actually used. - * @library /testlibrary /test/lib /compiler/testlibrary ../ + * @library /testlibrary /test/lib / ../ * @modules java.base/jdk.internal.misc * java.management - * @build TestSHA intrinsics.Verifier TestSHA1Intrinsics - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @build TestSHA compiler.testlibrary.intrinsics.Verifier TestSHA1Intrinsics + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI -Xbatch -XX:CompileThreshold=500 * -XX:Tier4InvocationThreshold=500 @@ -48,9 +48,10 @@ * -XX:-UseSHA1Intrinsics * -Dalgorithm=SHA-1 TestSHA1Intrinsics * @run main/othervm -DverificationStrategy=VERIFY_INTRINSIC_USAGE - * intrinsics.Verifier positive.log negative.log + * compiler.testlibrary.intrinsics.Verifier positive.log negative.log */ -import sha.predicate.IntrinsicPredicates; + +import compiler.testlibrary.sha.predicate.IntrinsicPredicates; public class TestSHA1Intrinsics { public static void main(String args[]) throws Exception { diff --git a/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA1MultiBlockIntrinsics.java b/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA1MultiBlockIntrinsics.java index f4909da982b..48693030a9f 100644 --- a/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA1MultiBlockIntrinsics.java +++ b/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA1MultiBlockIntrinsics.java @@ -21,18 +21,16 @@ * questions. */ -import sha.predicate.IntrinsicPredicates; - /** * @test * @bug 8035968 * @summary Verify that SHA-1 multi block intrinsic is actually used. - * @library /testlibrary /test/lib /compiler/testlibrary ../ + * @library /testlibrary /test/lib / ../ * @modules java.base/jdk.internal.misc * java.management - * @build TestSHA intrinsics.Verifier TestSHA1MultiBlockIntrinsics - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @build TestSHA compiler.testlibrary.intrinsics.Verifier TestSHA1MultiBlockIntrinsics + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI -Xbatch -XX:CompileThreshold=500 * -XX:Tier4InvocationThreshold=500 @@ -58,9 +56,12 @@ import sha.predicate.IntrinsicPredicates; * -XX:CompileOnly=sun/security/provider/SHA -XX:-UseSHA * -Dalgorithm=SHA-1 TestSHA1MultiBlockIntrinsics * @run main/othervm -DverificationStrategy=VERIFY_INTRINSIC_USAGE - * intrinsics.Verifier positive.log positive_def.log + * compiler.testlibrary.intrinsics.Verifier positive.log positive_def.log * negative.log */ + +import compiler.testlibrary.sha.predicate.IntrinsicPredicates; + public class TestSHA1MultiBlockIntrinsics { public static void main(String args[]) throws Exception { new SHASanityTestBase(IntrinsicPredicates.SHA1_INTRINSICS_AVAILABLE, diff --git a/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA256Intrinsics.java b/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA256Intrinsics.java index 2154daf85de..51373332c95 100644 --- a/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA256Intrinsics.java +++ b/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA256Intrinsics.java @@ -21,18 +21,16 @@ * questions. */ -import sha.predicate.IntrinsicPredicates; - /** * @test * @bug 8035968 * @summary Verify that SHA-256 intrinsic is actually used. - * @library /testlibrary /test/lib /compiler/testlibrary ../ + * @library /testlibrary /test/lib / ../ * @modules java.base/jdk.internal.misc * java.management - * @build TestSHA intrinsics.Verifier TestSHA256Intrinsics - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @build TestSHA compiler.testlibrary.intrinsics.Verifier TestSHA256Intrinsics + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI -Xbatch -XX:CompileThreshold=500 * -XX:Tier4InvocationThreshold=500 @@ -66,9 +64,12 @@ import sha.predicate.IntrinsicPredicates; * -XX:-UseSHA256Intrinsics * -Dalgorithm=SHA-256 TestSHA256Intrinsics * @run main/othervm -DverificationStrategy=VERIFY_INTRINSIC_USAGE - * intrinsics.Verifier positive_224.log positive_256.log + * compiler.testlibrary.intrinsics.Verifier positive_224.log positive_256.log * negative_224.log negative_256.log */ + +import compiler.testlibrary.sha.predicate.IntrinsicPredicates; + public class TestSHA256Intrinsics { public static void main(String args[]) throws Exception { new SHASanityTestBase(IntrinsicPredicates.SHA256_INTRINSICS_AVAILABLE, diff --git a/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA256MultiBlockIntrinsics.java b/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA256MultiBlockIntrinsics.java index 3d6809fbf61..214f666cf8f 100644 --- a/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA256MultiBlockIntrinsics.java +++ b/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA256MultiBlockIntrinsics.java @@ -21,18 +21,16 @@ * questions. */ -import sha.predicate.IntrinsicPredicates; - /** * @test * @bug 8035968 * @summary Verify that SHA-256 multi block intrinsic is actually used. - * @library /testlibrary /test/lib /compiler/testlibrary ../ + * @library /testlibrary /test/lib / ../ * @modules java.base/jdk.internal.misc * java.management - * @build TestSHA intrinsics.Verifier TestSHA256MultiBlockIntrinsics - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @build TestSHA compiler.testlibrary.intrinsics.Verifier TestSHA256MultiBlockIntrinsics + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI -Xbatch -XX:CompileThreshold=500 * -XX:Tier4InvocationThreshold=500 @@ -82,10 +80,13 @@ import sha.predicate.IntrinsicPredicates; * -XX:CompileOnly=sun/security/provider/SHA -XX:-UseSHA * -Dalgorithm=SHA-256 TestSHA256MultiBlockIntrinsics * @run main/othervm -DverificationStrategy=VERIFY_INTRINSIC_USAGE - * intrinsics.Verifier positive_224.log positive_256.log + * compiler.testlibrary.intrinsics.Verifier positive_224.log positive_256.log * positive_224_def.log positive_256_def.log negative_224.log * negative_256.log */ + +import compiler.testlibrary.sha.predicate.IntrinsicPredicates; + public class TestSHA256MultiBlockIntrinsics { public static void main(String args[]) throws Exception { new SHASanityTestBase(IntrinsicPredicates.SHA256_INTRINSICS_AVAILABLE, diff --git a/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA512Intrinsics.java b/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA512Intrinsics.java index 771113cbef2..5ac5fc5f8b7 100644 --- a/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA512Intrinsics.java +++ b/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA512Intrinsics.java @@ -21,18 +21,16 @@ * questions. */ -import sha.predicate.IntrinsicPredicates; - /** * @test * @bug 8035968 * @summary Verify that SHA-512 intrinsic is actually used. - * @library /testlibrary /test/lib /compiler/testlibrary ../ + * @library /testlibrary /test/lib / ../ * @modules java.base/jdk.internal.misc * java.management - * @build TestSHA intrinsics.Verifier TestSHA512Intrinsics - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @build TestSHA compiler.testlibrary.intrinsics.Verifier TestSHA512Intrinsics + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI -Xbatch -XX:CompileThreshold=500 * -XX:Tier4InvocationThreshold=500 @@ -66,9 +64,12 @@ import sha.predicate.IntrinsicPredicates; * -XX:-UseSHA512Intrinsics * -Dalgorithm=SHA-512 TestSHA512Intrinsics * @run main/othervm -DverificationStrategy=VERIFY_INTRINSIC_USAGE - * intrinsics.Verifier positive_384.log positive_512.log + * compiler.testlibrary.intrinsics.Verifier positive_384.log positive_512.log * negative_384.log negative_512.log */ + +import compiler.testlibrary.sha.predicate.IntrinsicPredicates; + public class TestSHA512Intrinsics { public static void main(String args[]) throws Exception { new SHASanityTestBase(IntrinsicPredicates.SHA512_INTRINSICS_AVAILABLE, diff --git a/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA512MultiBlockIntrinsics.java b/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA512MultiBlockIntrinsics.java index 0497415059e..722648360ef 100644 --- a/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA512MultiBlockIntrinsics.java +++ b/hotspot/test/compiler/intrinsics/sha/sanity/TestSHA512MultiBlockIntrinsics.java @@ -21,18 +21,16 @@ * questions. */ -import sha.predicate.IntrinsicPredicates; - /** * @test * @bug 8035968 * @summary Verify that SHA-512 multi block intrinsic is actually used. - * @library /testlibrary /test/lib /compiler/testlibrary ../ + * @library /testlibrary /test/lib / ../ * @modules java.base/jdk.internal.misc * java.management - * @build TestSHA intrinsics.Verifier TestSHA512MultiBlockIntrinsics - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @build TestSHA compiler.testlibrary.intrinsics.Verifier TestSHA512MultiBlockIntrinsics + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI -Xbatch -XX:CompileThreshold=500 * -XX:Tier4InvocationThreshold=500 @@ -82,10 +80,13 @@ import sha.predicate.IntrinsicPredicates; * -XX:CompileOnly=sun/security/provider/SHA -XX:-UseSHA * -Dalgorithm=SHA-512 TestSHA512MultiBlockIntrinsics * @run main/othervm -DverificationStrategy=VERIFY_INTRINSIC_USAGE - * intrinsics.Verifier positive_384.log positive_512.log + * compiler.testlibrary.intrinsics.Verifier positive_384.log positive_512.log * positive_384_def.log positive_512_def.log negative_384.log * negative_512.log */ + +import compiler.testlibrary.sha.predicate.IntrinsicPredicates; + public class TestSHA512MultiBlockIntrinsics { public static void main(String args[]) throws Exception { new SHASanityTestBase(IntrinsicPredicates.SHA512_INTRINSICS_AVAILABLE, diff --git a/hotspot/test/compiler/jsr292/InvokerGC.java b/hotspot/test/compiler/jsr292/InvokerGC.java index 98c69b1a0b6..bcd63dd4857 100644 --- a/hotspot/test/compiler/jsr292/InvokerGC.java +++ b/hotspot/test/compiler/jsr292/InvokerGC.java @@ -25,7 +25,7 @@ * @test * @bug 8067247 * @modules java.base/jdk.internal.misc - * @library /test/lib /compiler/whitebox / + * @library /test/lib / * @run main/bootclasspath/othervm -Xcomp -Xbatch * -XX:CompileCommand=compileonly,InvokerGC::test * -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI diff --git a/hotspot/test/compiler/jsr292/NonInlinedCall/RedefineTest.java b/hotspot/test/compiler/jsr292/NonInlinedCall/RedefineTest.java index 1a77363f833..cb77918ff7e 100644 --- a/hotspot/test/compiler/jsr292/NonInlinedCall/RedefineTest.java +++ b/hotspot/test/compiler/jsr292/NonInlinedCall/RedefineTest.java @@ -28,6 +28,7 @@ * java.base/jdk.internal.misc * java.base/jdk.internal.vm.annotation * @library /testlibrary /test/lib / ../patches + * @requires vm.flavor != "minimal" * @build sun.hotspot.WhiteBox * @build java.base/java.lang.invoke.MethodHandleHelper * @build compiler.jsr292.NonInlinedCall.RedefineTest diff --git a/hotspot/test/compiler/jvmci/common/patches/jdk.vm.ci/jdk/vm/ci/hotspot/CompilerToVMHelper.java b/hotspot/test/compiler/jvmci/common/patches/jdk.vm.ci/jdk/vm/ci/hotspot/CompilerToVMHelper.java index 726ff9fc5be..e35c516880d 100644 --- a/hotspot/test/compiler/jvmci/common/patches/jdk.vm.ci/jdk/vm/ci/hotspot/CompilerToVMHelper.java +++ b/hotspot/test/compiler/jvmci/common/patches/jdk.vm.ci/jdk/vm/ci/hotspot/CompilerToVMHelper.java @@ -124,8 +124,8 @@ public class CompilerToVMHelper { } public static HotSpotResolvedObjectType resolveFieldInPool( - ConstantPool constantPool, int cpi, byte opcode, long[] info) { - return CTVM.resolveFieldInPool((HotSpotConstantPool) constantPool, cpi, opcode, info); + ConstantPool constantPool, int cpi, ResolvedJavaMethod method, byte opcode, long[] info) { + return CTVM.resolveFieldInPool((HotSpotConstantPool) constantPool, cpi, (HotSpotResolvedJavaMethodImpl) method, opcode, info); } public static int constantPoolRemapInstructionOperandFromCache( @@ -152,8 +152,8 @@ public class CompilerToVMHelper { CTVM.resetCompilationStatistics(); } - public static long initializeConfiguration(HotSpotVMConfig config) { - return CTVM.initializeConfiguration(config); + public static Object[] readConfiguration() { + return CTVM.readConfiguration(); } public static HotSpotResolvedJavaMethod resolveMethod( diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ConstantPoolTestCase.java b/hotspot/test/compiler/jvmci/compilerToVM/ConstantPoolTestCase.java index ed05fe8a188..d3f85000c4c 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ConstantPoolTestCase.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ConstantPoolTestCase.java @@ -27,6 +27,7 @@ package compiler.jvmci.compilerToVM; import java.util.HashMap; import java.util.Map; import jdk.vm.ci.hotspot.HotSpotResolvedObjectType; +import jdk.vm.ci.meta.ResolvedJavaMethod; import sun.hotspot.WhiteBox; import jdk.internal.reflect.ConstantPool; import jdk.internal.reflect.ConstantPool.Tag; @@ -184,13 +185,24 @@ public class ConstantPoolTestCase { public final String klass; public final String name; public final String type; + public final ResolvedJavaMethod[] methods; public final byte[] opcodes; public final long accFlags; public TestedCPEntry(String klass, String name, String type, byte[] opcodes, long accFlags) { + this(klass, name, type, null, opcodes, accFlags); + } + + public TestedCPEntry(String klass, String name, String type, ResolvedJavaMethod[] methods, byte[] opcodes, long accFlags) { this.klass = klass; this.name = name; this.type = type; + if (methods != null) { + this.methods = new ResolvedJavaMethod[methods.length]; + System.arraycopy(methods, 0, this.methods, 0, methods.length); + } else { + this.methods = null; + } if (opcodes != null) { this.opcodes = new byte[opcodes.length]; System.arraycopy(opcodes, 0, this.opcodes, 0, opcodes.length); diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ConstantPoolTestsHelper.java b/hotspot/test/compiler/jvmci/compilerToVM/ConstantPoolTestsHelper.java index 12310ddf3ce..fc33560b893 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ConstantPoolTestsHelper.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ConstantPoolTestsHelper.java @@ -31,6 +31,10 @@ import static compiler.jvmci.compilerToVM.ConstantPoolTestCase.ConstantTypes.*; import compiler.jvmci.compilerToVM.ConstantPoolTestCase.TestedCPEntry; import java.util.HashMap; import java.util.Map; +import jdk.vm.ci.meta.MetaAccessProvider; +import jdk.vm.ci.meta.ResolvedJavaMethod; +import jdk.vm.ci.meta.ResolvedJavaType; +import jdk.vm.ci.runtime.JVMCI; import jdk.internal.misc.SharedSecrets; import jdk.internal.org.objectweb.asm.Opcodes; import sun.hotspot.WhiteBox; @@ -44,6 +48,7 @@ import jdk.internal.reflect.ConstantPool.Tag; public class ConstantPoolTestsHelper { public static final int NO_CP_CACHE_PRESENT = Integer.MAX_VALUE; + private static final MetaAccessProvider metaAccess = JVMCI.getRuntime().getHostJVMCIBackend().getMetaAccess(); public enum DummyClasses { DUMMY_CLASS(MultipleImplementer2.class, CP_MAP_FOR_CLASS), @@ -76,6 +81,45 @@ public class ConstantPoolTestsHelper { } } + /** + * Obtain a resolved Java method declared by a given type. + * + * @param type the declaring type + * @param the method's name + * + * Currently, the lookup is based only on the method's name + * but not on the method's signature (i.e., the first method + * with a matching name declared on {@code type} is returned). + */ + private static ResolvedJavaMethod getMethod(ResolvedJavaType type, String methodName) { + if (methodName.equals("")) { + return type.getClassInitializer(); + } + + if (methodName.equals("")) { + ResolvedJavaMethod[] initializers = type.getDeclaredConstructors(); + if (initializers.length >= 0) { + return initializers[0]; + } else { + throw new IllegalArgumentException(); + } + } + + for (ResolvedJavaMethod method : type.getDeclaredMethods()) { + if (method.getName().equals(methodName)) { + return method; + } + } + + throw new IllegalArgumentException(); + } + + private static ResolvedJavaType getType(Class clazz) { + ResolvedJavaType type = metaAccess.lookupJavaType(clazz); + type.initialize(); + return type; + } + private static final Map CP_MAP_FOR_CLASS = new HashMap<>(); static { CP_MAP_FOR_CLASS.put(CONSTANT_CLASS, @@ -141,6 +185,7 @@ public class ConstantPoolTestsHelper { new TestedCPEntry("compiler/jvmci/common/testcases/MultipleImplementer2", "objectField", "Ljava/lang/Object;", + new ResolvedJavaMethod[] { getMethod(getType(MultipleImplementer2.class), ""), null }, new byte[] {(byte) Opcodes.PUTFIELD | (byte) Opcodes.GETFIELD}, Opcodes.ACC_FINAL), new TestedCPEntry("compiler/jvmci/common/testcases/MultipleImplementer2", @@ -296,6 +341,7 @@ public class ConstantPoolTestsHelper { new TestedCPEntry("compiler/jvmci/common/testcases/MultipleAbstractImplementer", "objectField", "Ljava/lang/Object;", + new ResolvedJavaMethod[] { getMethod(getType(MultipleAbstractImplementer.class), ""), null }, new byte[] {(byte) Opcodes.PUTFIELD | (byte) Opcodes.GETFIELD}, Opcodes.ACC_FINAL), new TestedCPEntry("compiler/jvmci/common/testcases/MultipleAbstractImplementer", @@ -401,6 +447,7 @@ public class ConstantPoolTestsHelper { new TestedCPEntry("compiler/jvmci/common/testcases/MultipleImplementersInterface", "OBJECT_CONSTANT", "Ljava/lang/Object;", + new ResolvedJavaMethod[] { getMethod(getType(MultipleImplementersInterface.class), ""), null }, new byte[] {(byte) Opcodes.PUTSTATIC, (byte) Opcodes.GETSTATIC}, Opcodes.ACC_STATIC | Opcodes.ACC_FINAL | Opcodes.ACC_PUBLIC), } diff --git a/hotspot/test/compiler/jvmci/compilerToVM/InitializeConfigurationTest.java b/hotspot/test/compiler/jvmci/compilerToVM/InitializeConfigurationTest.java index 2be4348c4f3..3a4597d44f7 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/InitializeConfigurationTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/InitializeConfigurationTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -45,188 +45,30 @@ import java.util.Objects; import java.util.function.Consumer; import jdk.vm.ci.hotspot.CompilerToVMHelper; import jdk.vm.ci.hotspot.HotSpotJVMCIRuntime; +import jdk.vm.ci.hotspot.HotSpotVMConfigAccess; +import jdk.vm.ci.hotspot.HotSpotVMConfigStore; import jdk.test.lib.Asserts; import jdk.test.lib.Utils; import jdk.internal.misc.Unsafe; public class InitializeConfigurationTest { - private static final Unsafe UNSAFE = Utils.getUnsafe(); - public static void main(String args[]) { - new InitializeConfigurationTest().runTest(generateTestCases()); + new InitializeConfigurationTest().runTest(); } - private static List generateTestCases() { - List result = new ArrayList<>(); - result.add(new TestCase("CodeCache", "_high_bound", "address", - InitializeConfigurationTest::verifyLongIsNotZero)); - result.add(new TestCase("StubRoutines", "_jint_arraycopy", "address", - InitializeConfigurationTest::verifyLongIsNotZero)); - return result; + private void runTest() { + TestHotSpotVMConfig config = new TestHotSpotVMConfig(HotSpotJVMCIRuntime.runtime().getConfigStore()); + Asserts.assertNE(config.codeCacheHighBound, 0L, "Got null address"); + Asserts.assertNE(config.stubRoutineJintArrayCopy, 0L, "Got null address"); } - private static void verifyLongIsNotZero(Object o) { - Asserts.assertNotNull(o, "Got null value"); - Asserts.assertEQ(o.getClass(), Long.class, "Unexpected value type"); - Asserts.assertNE(o, 0L, "Got null address"); - } + private static class TestHotSpotVMConfig extends HotSpotVMConfigAccess { - private void runTest(List tcases) { - VMStructDataReader reader = new VMStructDataReader( - CompilerToVMHelper.initializeConfiguration(HotSpotJVMCIRuntime.runtime().getConfig())); - while (reader.hasNext()) { - VMFieldData data = reader.next(); - for (TestCase tcase : tcases) { - tcase.check(data); - } - } - // now check if all passed - for (TestCase tcase: tcases) { - Asserts.assertTrue(tcase.isFound(), "Case failed: " + tcase); - } - } - - private static class VMStructDataReader implements Iterator { - // see jvmciCompilerToVM:105 static uintptr_t ciHotSpotVMData[28]; - private static final int HOTSPOT_VM_DATA_INDEX_COUNT = 28; - private final long addresses[]; - private final long vmStructsBase; - private final long entityNameFieldOffset; - private final long nameFieldOffset; - private final long typeStringFieldOffset; - private final long addressOffset; - private final long entrySize; - private long nextElementAddress; - private VMFieldData nextElement; - - public VMStructDataReader(long gHotSpotVMData) { - Asserts.assertNE(gHotSpotVMData, 0L, "Got null base address"); - addresses = new long[HOTSPOT_VM_DATA_INDEX_COUNT]; - for (int i = 0; i < HOTSPOT_VM_DATA_INDEX_COUNT; i++) { - addresses[i] = UNSAFE.getAddress( - gHotSpotVMData + Unsafe.ADDRESS_SIZE * i); - } - vmStructsBase = addresses[0]; - entityNameFieldOffset = addresses[1]; - nameFieldOffset = addresses[2]; - typeStringFieldOffset = addresses[3]; - addressOffset = addresses[6]; - entrySize = addresses[7]; - nextElementAddress = vmStructsBase; - nextElement = read(); + private TestHotSpotVMConfig(HotSpotVMConfigStore store) { + super(store); } - @Override - public boolean hasNext() { - return nextElement != null; - } - - @Override - public VMFieldData next() { - if (nextElement == null) { - throw new NoSuchElementException("Next element is null"); - } - VMFieldData toReturn = nextElement; - nextElementAddress += entrySize; - nextElement = read(); - return toReturn; - } - - private VMFieldData read() { - String entityFieldName = readCString( - UNSAFE.getAddress(nextElementAddress + nameFieldOffset)); - if (entityFieldName == null) { - return null; - } - String fieldType = readCString(UNSAFE.getAddress( - nextElementAddress + typeStringFieldOffset)); - String entityName = readCString(UNSAFE.getAddress( - nextElementAddress + entityNameFieldOffset)); - Object value; - if ("address".equals(fieldType)) { - long address = UNSAFE.getAddress( - nextElementAddress + addressOffset); - value = address; - } else { - // non-address cases are not supported - value = null; - } - return new VMFieldData(entityName, entityFieldName, fieldType, - value); - } - - private static String readCString(long address) { - if (address == 0) { - return null; - } - StringBuilder sb = new StringBuilder(); - for (int i = 0;; i++) { - char c = (char) UNSAFE.getByte(address + i); - if (c == 0) { - break; - } - sb.append(c); - } - return sb.toString(); - } - } - - private static class VMFieldData { - public final String entityFieldName; - public final String entityName; - public final String fieldType; - public final Object value; - - private VMFieldData(String entityName, String entityFieldName, - String fieldType, Object value) { - this.entityName = entityName; - this.entityFieldName = entityFieldName; - this.fieldType = fieldType; - this.value = value; - } - } - - private static class TestCase { - public final String entityName; - public final String fieldType; - public final String entityFieldName; - public final Consumer consumer; - private boolean found; - - public TestCase(String entityName, String entityFieldName, - String fieldType, Consumer predicate) { - Objects.requireNonNull(entityName, "Got null entityName"); - Objects.requireNonNull(entityFieldName, "Got null entityFieldName"); - Objects.requireNonNull(fieldType, "Got null type"); - if (!"address".equals(fieldType)) { - throw new Error("TESTBUG: unsupported testcase with fieldType=" - + fieldType); - } - this.entityName = entityName; - this.fieldType = fieldType; - this.entityFieldName = entityFieldName; - this.consumer = predicate; - this.found = false; - } - - public void check(VMFieldData data) { - if (entityFieldName.equals(data.entityFieldName) - && entityName.equals(data.entityName) - && fieldType.equals(data.fieldType)) { - Asserts.assertFalse(found, "Found 2 entries of " + this); - found = true; - consumer.accept(data.value); - } - } - - @Override - public String toString() { - return "CASE: entityName=" + entityName + " entityFieldName=" - + entityFieldName + " fieldType=" + fieldType; - } - - public boolean isFound() { - return found; - } + final long codeCacheHighBound = getFieldValue("CodeCache::_high_bound", Long.class); + final long stubRoutineJintArrayCopy = getFieldValue("StubRoutines::_jint_arraycopy", Long.class); } } diff --git a/hotspot/test/compiler/jvmci/compilerToVM/IsMatureTest.java b/hotspot/test/compiler/jvmci/compilerToVM/IsMatureTest.java index 0b1296aac5f..a05ee0271ac 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/IsMatureTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/IsMatureTest.java @@ -74,11 +74,16 @@ public class IsMatureTest { } methodData = WB.getMethodData(method); isMature = CompilerToVMHelper.isMature(methodData); - Asserts.assertNE(methodData, 0L, - "Multiple times invoked method should have method data"); - /* a method is not mature for -Xcomp and -Tiered, - see NonTieredCompPolicy::is_mature */ - Asserts.assertEQ(isMature, !(IS_XCOMP && !TIERED), - "Unexpected isMature state for multiple times invoked method"); + int compLevel = WB.getMethodCompilationLevel(method); + // methodData doesn't necessarily exist for interpreter and compilation level 1 + if (compLevel != CompilerWhiteBoxTest.COMP_LEVEL_NONE + && compLevel != CompilerWhiteBoxTest.COMP_LEVEL_SIMPLE) { + Asserts.assertNE(methodData, 0L, + "Multiple times invoked method should have method data"); + /* a method is not mature in Xcomp mode with tiered compilation disabled, + see NonTieredCompPolicy::is_mature */ + Asserts.assertEQ(isMature, !(IS_XCOMP && !TIERED), + "Unexpected isMature state for multiple times invoked method"); + } } } diff --git a/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassInPoolTest.java index 54fa2e653d2..e7db5ed1572 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassInPoolTest.java @@ -34,6 +34,7 @@ * java.base/jdk.internal.org.objectweb.asm * java.base/jdk.internal.org.objectweb.asm.tree * jdk.vm.ci/jdk.vm.ci.hotspot + * jdk.vm.ci/jdk.vm.ci.runtime * jdk.vm.ci/jdk.vm.ci.meta * @build jdk.vm.ci/jdk.vm.ci.hotspot.CompilerToVMHelper * @build sun.hotspot.WhiteBox diff --git a/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassRefIndexInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassRefIndexInPoolTest.java index 260f55387bb..284a3e380d1 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassRefIndexInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/LookupKlassRefIndexInPoolTest.java @@ -33,6 +33,7 @@ * java.base/jdk.internal.org.objectweb.asm * java.base/jdk.internal.org.objectweb.asm.tree * jdk.vm.ci/jdk.vm.ci.hotspot + * jdk.vm.ci/jdk.vm.ci.runtime * jdk.vm.ci/jdk.vm.ci.meta * @build jdk.vm.ci/jdk.vm.ci.hotspot.CompilerToVMHelper * @build sun.hotspot.WhiteBox diff --git a/hotspot/test/compiler/jvmci/compilerToVM/LookupMethodInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/LookupMethodInPoolTest.java index 302b2093123..6659178ba68 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/LookupMethodInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/LookupMethodInPoolTest.java @@ -34,6 +34,7 @@ * java.base/jdk.internal.org.objectweb.asm.tree * jdk.vm.ci/jdk.vm.ci.hotspot * jdk.vm.ci/jdk.vm.ci.meta + * jdk.vm.ci/jdk.vm.ci.runtime * @build jdk.vm.ci/jdk.vm.ci.hotspot.CompilerToVMHelper * @build sun.hotspot.WhiteBox * compiler.jvmci.compilerToVM.LookupMethodInPoolTest diff --git a/hotspot/test/compiler/jvmci/compilerToVM/LookupNameAndTypeRefIndexInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/LookupNameAndTypeRefIndexInPoolTest.java index 62093cb7d2a..52405b0bf22 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/LookupNameAndTypeRefIndexInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/LookupNameAndTypeRefIndexInPoolTest.java @@ -33,6 +33,7 @@ * java.base/jdk.internal.org.objectweb.asm * java.base/jdk.internal.org.objectweb.asm.tree * jdk.vm.ci/jdk.vm.ci.hotspot + * jdk.vm.ci/jdk.vm.ci.runtime * jdk.vm.ci/jdk.vm.ci.meta * @build jdk.vm.ci/jdk.vm.ci.hotspot.CompilerToVMHelper * @build sun.hotspot.WhiteBox diff --git a/hotspot/test/compiler/jvmci/compilerToVM/LookupNameInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/LookupNameInPoolTest.java index 7ea7b85c5cd..96d05f59f17 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/LookupNameInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/LookupNameInPoolTest.java @@ -33,6 +33,7 @@ * java.base/jdk.internal.org.objectweb.asm * java.base/jdk.internal.org.objectweb.asm.tree * jdk.vm.ci/jdk.vm.ci.hotspot + * jdk.vm.ci/jdk.vm.ci.runtime * jdk.vm.ci/jdk.vm.ci.meta * @build jdk.vm.ci/jdk.vm.ci.hotspot.CompilerToVMHelper * @build sun.hotspot.WhiteBox diff --git a/hotspot/test/compiler/jvmci/compilerToVM/LookupSignatureInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/LookupSignatureInPoolTest.java index 98fa85d476b..4f67c5a660e 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/LookupSignatureInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/LookupSignatureInPoolTest.java @@ -33,6 +33,7 @@ * java.base/jdk.internal.org.objectweb.asm * java.base/jdk.internal.org.objectweb.asm.tree * jdk.vm.ci/jdk.vm.ci.hotspot + * jdk.vm.ci/jdk.vm.ci.runtime * jdk.vm.ci/jdk.vm.ci.meta * @build jdk.vm.ci/jdk.vm.ci.hotspot.CompilerToVMHelper * @build sun.hotspot.WhiteBox diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ReprofileTest.java b/hotspot/test/compiler/jvmci/compilerToVM/ReprofileTest.java index fded2340074..169dcf749da 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ReprofileTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ReprofileTest.java @@ -34,6 +34,7 @@ * jdk.vm.ci/jdk.vm.ci.hotspot * jdk.vm.ci/jdk.vm.ci.code * jdk.vm.ci/jdk.vm.ci.meta + * @ignore 8157861 * @build jdk.vm.ci/jdk.vm.ci.hotspot.CompilerToVMHelper * @build sun.hotspot.WhiteBox * @build compiler.jvmci.compilerToVM.ReprofileTest diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ResolveConstantInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/ResolveConstantInPoolTest.java index fb0db08ecbf..1e86d3e62cb 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ResolveConstantInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ResolveConstantInPoolTest.java @@ -32,6 +32,7 @@ * java.base/jdk.internal.reflect * java.base/jdk.internal.org.objectweb.asm * jdk.vm.ci/jdk.vm.ci.hotspot + * jdk.vm.ci/jdk.vm.ci.runtime * jdk.vm.ci/jdk.vm.ci.meta * @build jdk.vm.ci/jdk.vm.ci.hotspot.CompilerToVMHelper * @build sun.hotspot.WhiteBox diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ResolveFieldInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/ResolveFieldInPoolTest.java index f0298cdf96e..62a1427ee8a 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ResolveFieldInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ResolveFieldInPoolTest.java @@ -34,6 +34,7 @@ * java.base/jdk.internal.org.objectweb.asm.tree * jdk.vm.ci/jdk.vm.ci.hotspot * jdk.vm.ci/jdk.vm.ci.meta + * jdk.vm.ci/jdk.vm.ci.runtime * @build jdk.vm.ci/jdk.vm.ci.hotspot.CompilerToVMHelper * @build sun.hotspot.WhiteBox * compiler.jvmci.compilerToVM.ResolveFieldInPoolTest @@ -107,6 +108,7 @@ public class ResolveFieldInPoolTest { HotSpotResolvedObjectType fieldToVerify = CompilerToVMHelper.resolveFieldInPool(constantPoolCTVM, index, + entry.methods == null ? null : entry.methods[j], entry.opcodes[j], info); String msg = String.format("Object returned by resolveFieldInPool method" diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ResolvePossiblyCachedConstantInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/ResolvePossiblyCachedConstantInPoolTest.java index ddec6f92a16..a284b5c3d16 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ResolvePossiblyCachedConstantInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ResolvePossiblyCachedConstantInPoolTest.java @@ -33,6 +33,7 @@ * java.base/jdk.internal.org.objectweb.asm * java.base/jdk.internal.org.objectweb.asm.tree * jdk.vm.ci/jdk.vm.ci.hotspot + * jdk.vm.ci/jdk.vm.ci.runtime * jdk.vm.ci/jdk.vm.ci.meta * @build jdk.vm.ci/jdk.vm.ci.hotspot.CompilerToVMHelper * @build sun.hotspot.WhiteBox diff --git a/hotspot/test/compiler/jvmci/compilerToVM/ResolveTypeInPoolTest.java b/hotspot/test/compiler/jvmci/compilerToVM/ResolveTypeInPoolTest.java index 37ab43922de..12055f54f7e 100644 --- a/hotspot/test/compiler/jvmci/compilerToVM/ResolveTypeInPoolTest.java +++ b/hotspot/test/compiler/jvmci/compilerToVM/ResolveTypeInPoolTest.java @@ -33,6 +33,7 @@ * java.base/jdk.internal.reflect * java.base/jdk.internal.org.objectweb.asm * jdk.vm.ci/jdk.vm.ci.hotspot + * jdk.vm.ci/jdk.vm.ci.runtime * jdk.vm.ci/jdk.vm.ci.meta * @build jdk.vm.ci/jdk.vm.ci.hotspot.CompilerToVMHelper * @build sun.hotspot.WhiteBox diff --git a/hotspot/test/compiler/jvmci/errors/CodeInstallerTest.java b/hotspot/test/compiler/jvmci/errors/CodeInstallerTest.java index 2d7617d778a..fd361bc9db6 100644 --- a/hotspot/test/compiler/jvmci/errors/CodeInstallerTest.java +++ b/hotspot/test/compiler/jvmci/errors/CodeInstallerTest.java @@ -28,6 +28,7 @@ import java.lang.reflect.Method; import jdk.vm.ci.code.Architecture; import jdk.vm.ci.code.CodeCacheProvider; import jdk.vm.ci.code.Register; +import jdk.vm.ci.code.RegisterArray; import jdk.vm.ci.code.StackSlot; import jdk.vm.ci.code.site.DataPatch; import jdk.vm.ci.code.site.Site; @@ -80,11 +81,11 @@ public class CodeInstallerTest { protected Register getRegister(PlatformKind kind, int index) { int idx = index; - Register[] allRegs = arch.getAvailableValueRegisters(); - for (int i = 0; i < allRegs.length; i++) { - if (arch.canStoreValue(allRegs[i].getRegisterCategory(), kind)) { + RegisterArray allRegs = arch.getAvailableValueRegisters(); + for (Register reg : allRegs) { + if (arch.canStoreValue(reg.getRegisterCategory(), kind)) { if (idx-- == 0) { - return allRegs[i]; + return reg; } } } diff --git a/hotspot/test/compiler/jvmci/errors/TestInvalidOopMap.java b/hotspot/test/compiler/jvmci/errors/TestInvalidOopMap.java index 1c4b8840140..fdb056ed666 100644 --- a/hotspot/test/compiler/jvmci/errors/TestInvalidOopMap.java +++ b/hotspot/test/compiler/jvmci/errors/TestInvalidOopMap.java @@ -49,7 +49,6 @@ import jdk.vm.ci.code.site.Site; import jdk.vm.ci.common.JVMCIError; import jdk.vm.ci.hotspot.HotSpotCompiledCode.Comment; import jdk.vm.ci.hotspot.HotSpotReferenceMap; -import jdk.vm.ci.hotspot.HotSpotVMConfig; import jdk.vm.ci.meta.Assumptions.Assumption; import jdk.vm.ci.meta.JavaKind; import jdk.vm.ci.meta.PlatformKind; @@ -112,21 +111,4 @@ public class TestInvalidOopMap extends CodeInstallerTest { test(new HotSpotReferenceMap(oops, base, size, 8)); } - - @Test(expected = JVMCIError.class) - public void testInvalidNarrowDerivedOop() { - if (!HotSpotVMConfig.config().useCompressedOops) { - throw new JVMCIError("skipping test"); - } - - PlatformKind kind = arch.getPlatformKind(JavaKind.Int); - Register reg = getRegister(kind, 0); - Register baseReg = getRegister(arch.getPlatformKind(JavaKind.Object), 1); - - Location[] oops = new Location[]{Location.register(reg)}; - Location[] base = new Location[]{Location.register(baseReg)}; - int[] size = new int[]{kind.getSizeInBytes()}; - - test(new HotSpotReferenceMap(oops, base, size, 8)); - } } diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/CodeInstallationTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/CodeInstallationTest.java index 67a66660ca1..9ae9d83a2d6 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/CodeInstallationTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/CodeInstallationTest.java @@ -34,6 +34,7 @@ import jdk.vm.ci.code.TargetDescription; import jdk.vm.ci.code.test.amd64.AMD64TestAssembler; import jdk.vm.ci.code.test.sparc.SPARCTestAssembler; import jdk.vm.ci.hotspot.HotSpotCompiledCode; +import jdk.vm.ci.hotspot.HotSpotJVMCIRuntime; import jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod; import jdk.vm.ci.meta.ConstantReflectionProvider; import jdk.vm.ci.meta.MetaAccessProvider; @@ -50,6 +51,7 @@ public class CodeInstallationTest { protected final CodeCacheProvider codeCache; protected final TargetDescription target; protected final ConstantReflectionProvider constantReflection; + protected final TestHotSpotVMConfig config; public CodeInstallationTest() { JVMCIBackend backend = JVMCI.getRuntime().getHostJVMCIBackend(); @@ -57,6 +59,7 @@ public class CodeInstallationTest { codeCache = backend.getCodeCache(); target = backend.getTarget(); constantReflection = backend.getConstantReflection(); + config = new TestHotSpotVMConfig(HotSpotJVMCIRuntime.runtime().getConfigStore()); } protected interface TestCompiler { @@ -67,9 +70,9 @@ public class CodeInstallationTest { private TestAssembler createAssembler() { Architecture arch = codeCache.getTarget().arch; if (arch instanceof AMD64) { - return new AMD64TestAssembler(codeCache); + return new AMD64TestAssembler(codeCache, config); } else if (arch instanceof SPARC) { - return new SPARCTestAssembler(codeCache); + return new SPARCTestAssembler(codeCache, config); } else { Assert.fail("unsupported architecture"); return null; @@ -86,17 +89,17 @@ public class CodeInstallationTest { } protected void test(TestCompiler compiler, Method method, Object... args) { - HotSpotResolvedJavaMethod resolvedMethod = (HotSpotResolvedJavaMethod) metaAccess.lookupJavaMethod(method); - TestAssembler asm = createAssembler(); - - asm.emitPrologue(); - compiler.compile(asm); - asm.emitEpilogue(); - - HotSpotCompiledCode code = asm.finish(resolvedMethod); - InstalledCode installed = codeCache.addCode(resolvedMethod, code, null, null); - try { + HotSpotResolvedJavaMethod resolvedMethod = (HotSpotResolvedJavaMethod) metaAccess.lookupJavaMethod(method); + TestAssembler asm = createAssembler(); + + asm.emitPrologue(); + compiler.compile(asm); + asm.emitEpilogue(); + + HotSpotCompiledCode code = asm.finish(resolvedMethod); + InstalledCode installed = codeCache.addCode(resolvedMethod, code, null, null); + Object expected = method.invoke(null, args); Object actual = installed.executeVarargs(args); Assert.assertEquals(expected, actual); diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/DataPatchTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/DataPatchTest.java index 5a4680de2fe..bedb1bb2c41 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/DataPatchTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/DataPatchTest.java @@ -32,22 +32,20 @@ * jdk.vm.ci/jdk.vm.ci.runtime * jdk.vm.ci/jdk.vm.ci.amd64 * jdk.vm.ci/jdk.vm.ci.sparc - * @compile CodeInstallationTest.java DebugInfoTest.java TestAssembler.java amd64/AMD64TestAssembler.java sparc/SPARCTestAssembler.java + * @compile CodeInstallationTest.java DebugInfoTest.java TestAssembler.java TestHotSpotVMConfig.java amd64/AMD64TestAssembler.java sparc/SPARCTestAssembler.java * @run junit/othervm -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI jdk.vm.ci.code.test.DataPatchTest */ package jdk.vm.ci.code.test; +import org.junit.Assume; +import org.junit.Test; + import jdk.vm.ci.code.Register; import jdk.vm.ci.code.site.DataSectionReference; import jdk.vm.ci.hotspot.HotSpotConstant; -import jdk.vm.ci.hotspot.HotSpotMetaAccessProvider; -import jdk.vm.ci.hotspot.HotSpotVMConfig; import jdk.vm.ci.meta.ResolvedJavaType; -import org.junit.Assume; -import org.junit.Test; - /** * Test code installation with data patches. */ @@ -73,12 +71,12 @@ public class DataPatchTest extends CodeInstallationTest { @Test public void testInlineNarrowObject() { - Assume.assumeTrue(HotSpotVMConfig.config().useCompressedOops); + Assume.assumeTrue(config.useCompressedOops); test(asm -> { ResolvedJavaType type = metaAccess.lookupJavaType(getConstClass()); HotSpotConstant c = (HotSpotConstant) constantReflection.asJavaClass(type); Register compressed = asm.emitLoadPointer((HotSpotConstant) c.compress()); - Register ret = asm.emitUncompressPointer(compressed, HotSpotVMConfig.config().narrowOopBase, HotSpotVMConfig.config().narrowOopShift); + Register ret = asm.emitUncompressPointer(compressed, config.narrowOopBase, config.narrowOopShift); asm.emitPointerRet(ret); }); } @@ -96,14 +94,14 @@ public class DataPatchTest extends CodeInstallationTest { @Test public void testNarrowDataSectionReference() { - Assume.assumeTrue(HotSpotVMConfig.config().useCompressedOops); + Assume.assumeTrue(config.useCompressedOops); test(asm -> { ResolvedJavaType type = metaAccess.lookupJavaType(getConstClass()); HotSpotConstant c = (HotSpotConstant) constantReflection.asJavaClass(type); HotSpotConstant cCompressed = (HotSpotConstant) c.compress(); DataSectionReference ref = asm.emitDataItem(cCompressed); Register compressed = asm.emitLoadNarrowPointer(ref); - Register ret = asm.emitUncompressPointer(compressed, HotSpotVMConfig.config().narrowOopBase, HotSpotVMConfig.config().narrowOopShift); + Register ret = asm.emitUncompressPointer(compressed, config.narrowOopBase, config.narrowOopShift); asm.emitPointerRet(ret); }); } @@ -113,20 +111,20 @@ public class DataPatchTest extends CodeInstallationTest { test(asm -> { ResolvedJavaType type = metaAccess.lookupJavaType(getConstClass()); Register klass = asm.emitLoadPointer((HotSpotConstant) constantReflection.asObjectHub(type)); - Register ret = asm.emitLoadPointer(klass, HotSpotVMConfig.config().classMirrorOffset); + Register ret = asm.emitLoadPointer(klass, config.classMirrorOffset); asm.emitPointerRet(ret); }); } @Test public void testInlineNarrowMetadata() { - Assume.assumeTrue(HotSpotVMConfig.config().useCompressedClassPointers); + Assume.assumeTrue(config.useCompressedClassPointers); test(asm -> { ResolvedJavaType type = metaAccess.lookupJavaType(getConstClass()); HotSpotConstant hub = (HotSpotConstant) constantReflection.asObjectHub(type); Register narrowKlass = asm.emitLoadPointer((HotSpotConstant) hub.compress()); - Register klass = asm.emitUncompressPointer(narrowKlass, HotSpotVMConfig.config().narrowKlassBase, HotSpotVMConfig.config().narrowKlassShift); - Register ret = asm.emitLoadPointer(klass, HotSpotVMConfig.config().classMirrorOffset); + Register klass = asm.emitUncompressPointer(narrowKlass, config.narrowKlassBase, config.narrowKlassShift); + Register ret = asm.emitLoadPointer(klass, config.classMirrorOffset); asm.emitPointerRet(ret); }); } @@ -138,22 +136,22 @@ public class DataPatchTest extends CodeInstallationTest { HotSpotConstant hub = (HotSpotConstant) constantReflection.asObjectHub(type); DataSectionReference ref = asm.emitDataItem(hub); Register klass = asm.emitLoadPointer(ref); - Register ret = asm.emitLoadPointer(klass, HotSpotVMConfig.config().classMirrorOffset); + Register ret = asm.emitLoadPointer(klass, config.classMirrorOffset); asm.emitPointerRet(ret); }); } @Test public void testNarrowMetadataInDataSection() { - Assume.assumeTrue(HotSpotVMConfig.config().useCompressedClassPointers); + Assume.assumeTrue(config.useCompressedClassPointers); test(asm -> { ResolvedJavaType type = metaAccess.lookupJavaType(getConstClass()); HotSpotConstant hub = (HotSpotConstant) constantReflection.asObjectHub(type); HotSpotConstant narrowHub = (HotSpotConstant) hub.compress(); DataSectionReference ref = asm.emitDataItem(narrowHub); Register narrowKlass = asm.emitLoadNarrowPointer(ref); - Register klass = asm.emitUncompressPointer(narrowKlass, HotSpotVMConfig.config().narrowKlassBase, HotSpotVMConfig.config().narrowKlassShift); - Register ret = asm.emitLoadPointer(klass, HotSpotVMConfig.config().classMirrorOffset); + Register klass = asm.emitUncompressPointer(narrowKlass, config.narrowKlassBase, config.narrowKlassShift); + Register ret = asm.emitLoadPointer(klass, config.classMirrorOffset); asm.emitPointerRet(ret); }); } diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/DebugInfoTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/DebugInfoTest.java index c1bdc039196..584249c21b7 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/DebugInfoTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/DebugInfoTest.java @@ -44,6 +44,10 @@ public class DebugInfoTest extends CodeInstallationTest { } protected void test(DebugInfoCompiler compiler, Method method, int bci, JavaKind... slotKinds) { + test(compiler, method, bci, new Location[0], new Location[0], new int[0], slotKinds); + } + + protected void test(DebugInfoCompiler compiler, Method method, int bci, Location[] objects, Location[] derivedBase, int[] sizeInBytes, JavaKind... slotKinds) { ResolvedJavaMethod resolvedMethod = metaAccess.lookupJavaMethod(method); int numLocals = resolvedMethod.getMaxLocals(); @@ -54,7 +58,7 @@ public class DebugInfoTest extends CodeInstallationTest { BytecodeFrame frame = new BytecodeFrame(null, resolvedMethod, bci, false, false, values, slotKinds, numLocals, numStack, 0); DebugInfo info = new DebugInfo(frame, vobjs); - info.setReferenceMap(new HotSpotReferenceMap(new Location[0], new Location[0], new int[0], 8)); + info.setReferenceMap(new HotSpotReferenceMap(objects, derivedBase, sizeInBytes, 8)); asm.emitTrap(info); }, method); diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/InterpreterFrameSizeTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/InterpreterFrameSizeTest.java index b4b3f44ffe8..2425cbc0d43 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/InterpreterFrameSizeTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/InterpreterFrameSizeTest.java @@ -32,7 +32,7 @@ * jdk.vm.ci/jdk.vm.ci.common * jdk.vm.ci/jdk.vm.ci.amd64 * jdk.vm.ci/jdk.vm.ci.sparc - * @compile CodeInstallationTest.java DebugInfoTest.java TestAssembler.java amd64/AMD64TestAssembler.java sparc/SPARCTestAssembler.java + * @compile CodeInstallationTest.java TestAssembler.java TestHotSpotVMConfig.java amd64/AMD64TestAssembler.java sparc/SPARCTestAssembler.java * @run junit/othervm -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI jdk.vm.ci.code.test.InterpreterFrameSizeTest */ diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/MaxOopMapStackOffsetTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/MaxOopMapStackOffsetTest.java new file mode 100644 index 00000000000..b9e56256b96 --- /dev/null +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/MaxOopMapStackOffsetTest.java @@ -0,0 +1,90 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/** + * @test + * @requires (os.simpleArch == "x64" | os.simpleArch == "sparcv9") & os.arch != "aarch64" + * @library / + * @modules jdk.vm.ci/jdk.vm.ci.hotspot + * jdk.vm.ci/jdk.vm.ci.meta + * jdk.vm.ci/jdk.vm.ci.code + * jdk.vm.ci/jdk.vm.ci.code.site + * jdk.vm.ci/jdk.vm.ci.common + * jdk.vm.ci/jdk.vm.ci.runtime + * jdk.vm.ci/jdk.vm.ci.amd64 + * jdk.vm.ci/jdk.vm.ci.sparc + * @compile CodeInstallationTest.java DebugInfoTest.java TestAssembler.java TestHotSpotVMConfig.java amd64/AMD64TestAssembler.java sparc/SPARCTestAssembler.java + * @run junit/othervm -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI jdk.vm.ci.code.test.MaxOopMapStackOffsetTest + */ + +package jdk.vm.ci.code.test; + +import org.junit.Test; + +import jdk.vm.ci.code.Location; +import jdk.vm.ci.code.Register; +import jdk.vm.ci.common.JVMCIError; +import jdk.vm.ci.meta.JavaConstant; +import jdk.vm.ci.meta.JavaKind; + +public class MaxOopMapStackOffsetTest extends DebugInfoTest { + + public static int pass() { + return 42; + } + + public static int fail() { + return 42; + } + + private void test(String name, int offset) { + Location location = Location.stack(offset); + DebugInfoCompiler compiler = (asm, values) -> { + asm.growFrame(offset); + Register v = asm.emitLoadInt(0); + asm.emitIntToStack(v); + values[0] = JavaConstant.forInt(42); + return null; + }; + test(compiler, getMethod(name), 2, new Location[]{location}, new Location[1], new int[]{4}, JavaKind.Int); + } + + private int maxOffset() { + return config.maxOopMapStackOffset; + } + + private int wordSize() { + return config.heapWordSize; + } + + @Test(expected = JVMCIError.class) + public void failTooLargeOffset() { + // This should throw a JVMCIError during installation because the offset is too large. + test("fail", maxOffset() + wordSize()); + } + + @Test + public void passWithLargeOffset() { + test("pass", maxOffset()); + } +} diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleCodeInstallationTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleCodeInstallationTest.java index 6db85e842e2..57496edb203 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleCodeInstallationTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleCodeInstallationTest.java @@ -32,7 +32,7 @@ * jdk.vm.ci/jdk.vm.ci.runtime * jdk.vm.ci/jdk.vm.ci.amd64 * jdk.vm.ci/jdk.vm.ci.sparc - * @compile CodeInstallationTest.java DebugInfoTest.java TestAssembler.java amd64/AMD64TestAssembler.java sparc/SPARCTestAssembler.java + * @compile CodeInstallationTest.java DebugInfoTest.java TestAssembler.java TestHotSpotVMConfig.java amd64/AMD64TestAssembler.java sparc/SPARCTestAssembler.java * @run junit/othervm -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI jdk.vm.ci.code.test.SimpleCodeInstallationTest */ diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleDebugInfoTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleDebugInfoTest.java index 057c7acfcda..f44c4801c8b 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleDebugInfoTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/SimpleDebugInfoTest.java @@ -32,7 +32,7 @@ * jdk.vm.ci/jdk.vm.ci.runtime * jdk.vm.ci/jdk.vm.ci.amd64 * jdk.vm.ci/jdk.vm.ci.sparc - * @compile CodeInstallationTest.java DebugInfoTest.java TestAssembler.java amd64/AMD64TestAssembler.java sparc/SPARCTestAssembler.java + * @compile CodeInstallationTest.java DebugInfoTest.java TestAssembler.java TestHotSpotVMConfig.java amd64/AMD64TestAssembler.java sparc/SPARCTestAssembler.java * @run junit/othervm -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI jdk.vm.ci.code.test.SimpleDebugInfoTest */ @@ -43,7 +43,6 @@ import org.junit.Test; import jdk.vm.ci.code.Register; import jdk.vm.ci.hotspot.HotSpotConstant; -import jdk.vm.ci.hotspot.HotSpotVMConfig; import jdk.vm.ci.meta.JavaConstant; import jdk.vm.ci.meta.JavaKind; import jdk.vm.ci.meta.ResolvedJavaType; @@ -255,7 +254,7 @@ public class SimpleDebugInfoTest extends DebugInfoTest { @Test public void testRegNarrowObject() { - Assume.assumeTrue(HotSpotVMConfig.config().useCompressedOops); + Assume.assumeTrue(config.useCompressedOops); ResolvedJavaType type = metaAccess.lookupJavaType(objectOnStack()); DebugInfoCompiler compiler = (asm, values) -> { HotSpotConstant wide = (HotSpotConstant) constantReflection.asJavaClass(type); @@ -269,7 +268,7 @@ public class SimpleDebugInfoTest extends DebugInfoTest { @Test public void testStackNarrowObject() { - Assume.assumeTrue(HotSpotVMConfig.config().useCompressedOops); + Assume.assumeTrue(config.useCompressedOops); ResolvedJavaType type = metaAccess.lookupJavaType(objectOnStack()); DebugInfoCompiler compiler = (asm, values) -> { HotSpotConstant wide = (HotSpotConstant) constantReflection.asJavaClass(type); diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/TestAssembler.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/TestAssembler.java index a1ca6be48d9..44b1d4bcf2a 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/TestAssembler.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/TestAssembler.java @@ -182,6 +182,7 @@ public abstract class TestAssembler { private final ArrayList dataPatches; protected final CodeCacheProvider codeCache; + protected final TestHotSpotVMConfig config; private final Register[] registers; private int nextRegister; @@ -204,7 +205,7 @@ public abstract class TestAssembler { } } - protected TestAssembler(CodeCacheProvider codeCache, int initialFrameSize, int stackAlignment, PlatformKind narrowOopKind, Register... registers) { + protected TestAssembler(CodeCacheProvider codeCache, TestHotSpotVMConfig config, int initialFrameSize, int stackAlignment, PlatformKind narrowOopKind, Register... registers) { this.narrowOopKind = new TestValueKind(narrowOopKind); this.code = new Buffer(); @@ -213,6 +214,7 @@ public abstract class TestAssembler { this.dataPatches = new ArrayList<>(); this.codeCache = codeCache; + this.config = config; this.registers = registers; this.nextRegister = 0; @@ -231,7 +233,12 @@ public abstract class TestAssembler { } protected StackSlot newStackSlot(PlatformKind kind) { - curStackSlot += kind.getSizeInBytes(); + growFrame(kind.getSizeInBytes()); + return StackSlot.get(new TestValueKind(kind), -curStackSlot, true); + } + + protected void growFrame(int sizeInBytes) { + curStackSlot += sizeInBytes; if (curStackSlot > frameSize) { int newFrameSize = curStackSlot; if (newFrameSize % stackAlignment != 0) { @@ -240,7 +247,6 @@ public abstract class TestAssembler { emitGrowStack(newFrameSize - frameSize); frameSize = newFrameSize; } - return StackSlot.get(new TestValueKind(kind), -curStackSlot, true); } protected void setDeoptRescueSlot(StackSlot deoptRescue) { diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/TestHotSpotVMConfig.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/TestHotSpotVMConfig.java new file mode 100644 index 00000000000..cc80c0bcdbe --- /dev/null +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/TestHotSpotVMConfig.java @@ -0,0 +1,50 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +package jdk.vm.ci.code.test; + +import jdk.vm.ci.hotspot.HotSpotVMConfigAccess; +import jdk.vm.ci.hotspot.HotSpotVMConfigStore; + +public class TestHotSpotVMConfig extends HotSpotVMConfigAccess { + + public TestHotSpotVMConfig(HotSpotVMConfigStore config) { + super(config); + } + + public final boolean useCompressedOops = getFlag("UseCompressedOops", Boolean.class); + public final boolean useCompressedClassPointers = getFlag("UseCompressedClassPointers", Boolean.class); + + public final long narrowOopBase = getFieldValue("CompilerToVM::Data::Universe_narrow_oop_base", Long.class, "address"); + public final int narrowOopShift = getFieldValue("CompilerToVM::Data::Universe_narrow_oop_shift", Integer.class, "int"); + + public final long narrowKlassBase = getFieldValue("CompilerToVM::Data::Universe_narrow_klass_base", Long.class, "address"); + public final int narrowKlassShift = getFieldValue("CompilerToVM::Data::Universe_narrow_klass_shift", Integer.class, "int"); + + public final int classMirrorOffset = getFieldOffset("Klass::_java_mirror", Integer.class, "oop"); + + public final int MARKID_DEOPT_HANDLER_ENTRY = getConstant("CodeInstaller::DEOPT_HANDLER_ENTRY", Integer.class); + public final long handleDeoptStub = getFieldValue("CompilerToVM::Data::SharedRuntime_deopt_blob_unpack", Long.class, "address"); + + public final int maxOopMapStackOffset = getFieldValue("CompilerToVM::Data::_max_oop_map_stack_offset", Integer.class, "int"); + public final int heapWordSize = getConstant("HeapWordSize", Integer.class); +} diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/VirtualObjectDebugInfoTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/VirtualObjectDebugInfoTest.java index 4a4b297e764..d08f6129070 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/VirtualObjectDebugInfoTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/VirtualObjectDebugInfoTest.java @@ -32,7 +32,7 @@ * jdk.vm.ci/jdk.vm.ci.runtime * jdk.vm.ci/jdk.vm.ci.amd64 * jdk.vm.ci/jdk.vm.ci.sparc - * @compile CodeInstallationTest.java DebugInfoTest.java TestAssembler.java amd64/AMD64TestAssembler.java sparc/SPARCTestAssembler.java + * @compile CodeInstallationTest.java DebugInfoTest.java TestAssembler.java TestHotSpotVMConfig.java amd64/AMD64TestAssembler.java sparc/SPARCTestAssembler.java * @run junit/othervm -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI jdk.vm.ci.code.test.VirtualObjectDebugInfoTest */ diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/amd64/AMD64TestAssembler.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/amd64/AMD64TestAssembler.java index 61dcbe36444..078af122e6b 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/amd64/AMD64TestAssembler.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/amd64/AMD64TestAssembler.java @@ -32,17 +32,17 @@ import jdk.vm.ci.code.StackSlot; import jdk.vm.ci.code.site.ConstantReference; import jdk.vm.ci.code.site.DataSectionReference; import jdk.vm.ci.code.test.TestAssembler; +import jdk.vm.ci.code.test.TestHotSpotVMConfig; import jdk.vm.ci.hotspot.HotSpotCallingConventionType; import jdk.vm.ci.hotspot.HotSpotConstant; import jdk.vm.ci.hotspot.HotSpotForeignCallTarget; -import jdk.vm.ci.hotspot.HotSpotVMConfig; import jdk.vm.ci.meta.JavaKind; import jdk.vm.ci.meta.VMConstant; public class AMD64TestAssembler extends TestAssembler { - public AMD64TestAssembler(CodeCacheProvider codeCache) { - super(codeCache, 16, 16, AMD64Kind.DWORD, AMD64.rax, AMD64.rcx, AMD64.rdi, AMD64.r8, AMD64.r9, AMD64.r10); + public AMD64TestAssembler(CodeCacheProvider codeCache, TestHotSpotVMConfig config) { + super(codeCache, config, 16, 16, AMD64Kind.DWORD, AMD64.rax, AMD64.rcx, AMD64.rdi, AMD64.r8, AMD64.r9, AMD64.r10); } private void emitFatNop() { @@ -68,7 +68,6 @@ public class AMD64TestAssembler extends TestAssembler { @Override public void emitEpilogue() { - HotSpotVMConfig config = HotSpotVMConfig.config(); recordMark(config.MARKID_DEOPT_HANDLER_ENTRY); recordCall(new HotSpotForeignCallTarget(config.handleDeoptStub), 5, true, null); code.emitByte(0xE8); // CALL rel32 @@ -86,12 +85,12 @@ public class AMD64TestAssembler extends TestAssembler { @Override public Register emitIntArg0() { - return codeCache.getRegisterConfig().getCallingConventionRegisters(HotSpotCallingConventionType.JavaCall, JavaKind.Int)[0]; + return codeCache.getRegisterConfig().getCallingConventionRegisters(HotSpotCallingConventionType.JavaCall, JavaKind.Int).get(0); } @Override public Register emitIntArg1() { - return codeCache.getRegisterConfig().getCallingConventionRegisters(HotSpotCallingConventionType.JavaCall, JavaKind.Int)[1]; + return codeCache.getRegisterConfig().getCallingConventionRegisters(HotSpotCallingConventionType.JavaCall, JavaKind.Int).get(1); } private void emitREX(boolean w, int r, int x, int b) { diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/sparc/SPARCTestAssembler.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/sparc/SPARCTestAssembler.java index 5ac0592a74e..26826fa2fc0 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/sparc/SPARCTestAssembler.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.code.test/src/jdk/vm/ci/code/test/sparc/SPARCTestAssembler.java @@ -30,12 +30,12 @@ import jdk.vm.ci.code.StackSlot; import jdk.vm.ci.code.site.ConstantReference; import jdk.vm.ci.code.site.DataSectionReference; import jdk.vm.ci.code.test.TestAssembler; +import jdk.vm.ci.code.test.TestHotSpotVMConfig; import jdk.vm.ci.hotspot.HotSpotCallingConventionType; import jdk.vm.ci.hotspot.HotSpotCompiledCode; import jdk.vm.ci.hotspot.HotSpotConstant; import jdk.vm.ci.hotspot.HotSpotForeignCallTarget; import jdk.vm.ci.hotspot.HotSpotResolvedJavaMethod; -import jdk.vm.ci.hotspot.HotSpotVMConfig; import jdk.vm.ci.meta.JavaKind; import jdk.vm.ci.meta.VMConstant; import jdk.vm.ci.sparc.SPARC; @@ -45,11 +45,12 @@ public class SPARCTestAssembler extends TestAssembler { private static final int MASK13 = (1 << 13) - 1; - public SPARCTestAssembler(CodeCacheProvider codeCache) { - super(codeCache, 0, 16, SPARCKind.WORD, SPARC.l0, SPARC.l1, SPARC.l2, SPARC.l3, SPARC.l4, SPARC.l5, SPARC.l6, SPARC.l7); + public SPARCTestAssembler(CodeCacheProvider codeCache, TestHotSpotVMConfig config) { + super(codeCache, config, 0, 16, SPARCKind.WORD, SPARC.l0, SPARC.l1, SPARC.l2, SPARC.l3, SPARC.l4, SPARC.l5, SPARC.l6, SPARC.l7); } private void emitOp2(Register rd, int op2, int imm22) { + assert isSimm(imm22, 22); code.emitInt((0b00 << 30) | (rd.encoding << 25) | (op2 << 22) | imm22); } @@ -58,6 +59,7 @@ public class SPARCTestAssembler extends TestAssembler { } private void emitOp3(int op, Register rd, int op3, Register rs1, int simm13) { + assert isSimm(simm13, 13); code.emitInt((op << 30) | (rd.encoding << 25) | (op3 << 19) | (rs1.encoding << 14) | (1 << 13) | (simm13 & MASK13)); } @@ -65,6 +67,27 @@ public class SPARCTestAssembler extends TestAssembler { code.emitInt(1 << 24); } + /** + * Minimum value for signed immediate ranges. + */ + public static long minSimm(long nbits) { + return -(1L << (nbits - 1)); + } + + /** + * Maximum value for signed immediate ranges. + */ + public static long maxSimm(long nbits) { + return (1L << (nbits - 1)) - 1; + } + + /** + * Test if imm is within signed immediate range for nbits. + */ + public static boolean isSimm(long imm, int nbits) { + return minSimm(nbits) <= imm && imm <= maxSimm(nbits); + } + @Override public void emitPrologue() { // SAVE sp, -128, sp @@ -74,7 +97,6 @@ public class SPARCTestAssembler extends TestAssembler { @Override public void emitEpilogue() { - HotSpotVMConfig config = HotSpotVMConfig.config(); recordMark(config.MARKID_DEOPT_HANDLER_ENTRY); recordCall(new HotSpotForeignCallTarget(config.handleDeoptStub), 4, true, null); code.emitInt(1 << 30); // CALL @@ -88,22 +110,33 @@ public class SPARCTestAssembler extends TestAssembler { @Override public void emitGrowStack(int size) { - emitOp3(0b10, SPARC.sp, 0b000100, SPARC.sp, size); // SUB sp, size, sp + frameSize += size; + if (isSimm(size, 13)) { + emitOp3(0b10, SPARC.sp, 0b000100, SPARC.sp, size); // SUB sp, size, sp + } else { + Register r = emitLoadInt(size); + emitOp3(0b10, SPARC.sp, 0b000100, SPARC.sp, r); // SUB sp, size, sp + } } @Override public Register emitIntArg0() { - return codeCache.getRegisterConfig().getCallingConventionRegisters(HotSpotCallingConventionType.JavaCallee, JavaKind.Int)[0]; + return codeCache.getRegisterConfig().getCallingConventionRegisters(HotSpotCallingConventionType.JavaCallee, JavaKind.Int).get(0); } @Override public Register emitIntArg1() { - return codeCache.getRegisterConfig().getCallingConventionRegisters(HotSpotCallingConventionType.JavaCallee, JavaKind.Int)[1]; + return codeCache.getRegisterConfig().getCallingConventionRegisters(HotSpotCallingConventionType.JavaCallee, JavaKind.Int).get(1); } @Override public Register emitLoadInt(int c) { Register ret = newRegister(); + loadIntToRegister(c, ret); + return ret; + } + + private void loadIntToRegister(int c, Register ret) { int hi = c >>> 10; int lo = c & ((1 << 10) - 1); if (hi == 0) { @@ -114,19 +147,28 @@ public class SPARCTestAssembler extends TestAssembler { emitOp3(0b10, ret, 0b000010, ret, lo); // OR ret, lo, ret } } - return ret; } @Override public Register emitLoadLong(long c) { + Register ret = newRegister(); + emitLoadLongToRegister(c, ret); + return ret; + } + + private void loadLongToRegister(long c, Register ret) { + DataSectionReference ref = new DataSectionReference(); + data.align(8); + ref.setOffset(data.position()); + data.emitLong(c); + emitLoadPointerToRegister(ref, ret); + } + + public void emitLoadLongToRegister(long c, Register r) { if ((c & 0xFFFF_FFFFL) == c) { - return emitLoadInt((int) c); + loadIntToRegister((int) c, r); } else { - DataSectionReference ref = new DataSectionReference(); - data.align(8); - ref.setOffset(data.position()); - data.emitLong(c); - return emitLoadPointer(ref); + loadLongToRegister(c, r); } } @@ -169,10 +211,14 @@ public class SPARCTestAssembler extends TestAssembler { @Override public Register emitLoadPointer(DataSectionReference ref) { Register ret = newRegister(); + emitLoadPointerToRegister(ref, ret); + return ret; + } + + private void emitLoadPointerToRegister(DataSectionReference ref, Register ret) { recordDataPatchInCode(ref); emitPatchableSethi(ret, true); emitOp3(0b11, ret, 0b001011, ret, 0); // LDX [ret+0], ret - return ret; } @Override @@ -195,15 +241,15 @@ public class SPARCTestAssembler extends TestAssembler { public StackSlot emitIntToStack(Register a) { StackSlot ret = newStackSlot(SPARCKind.WORD); // STW a, [fp+offset] - emitOp3(0b11, a, 0b000100, SPARC.fp, ret.getRawOffset() + SPARC.STACK_BIAS); + emitStore(0b000100, a, ret); return ret; } @Override public StackSlot emitLongToStack(Register a) { StackSlot ret = newStackSlot(SPARCKind.XWORD); - // STX a, [fp+offset] - emitOp3(0b11, a, 0b001110, SPARC.fp, ret.getRawOffset() + SPARC.STACK_BIAS); + // STX a, [sp+offset] + emitStore(0b001110, a, ret); return ret; } @@ -211,7 +257,7 @@ public class SPARCTestAssembler extends TestAssembler { public StackSlot emitFloatToStack(Register a) { StackSlot ret = newStackSlot(SPARCKind.SINGLE); // STF a, [fp+offset] - emitOp3(0b11, a, 0b100100, SPARC.fp, ret.getRawOffset() + SPARC.STACK_BIAS); + emitStore(0b100100, a, ret); return ret; } @@ -219,7 +265,7 @@ public class SPARCTestAssembler extends TestAssembler { public StackSlot emitPointerToStack(Register a) { StackSlot ret = newStackSlot(SPARCKind.XWORD); // STX a, [fp+offset] - emitOp3(0b11, a, 0b001110, SPARC.fp, ret.getRawOffset() + SPARC.STACK_BIAS); + emitStore(0b001110, a, ret); return ret; } @@ -227,10 +273,24 @@ public class SPARCTestAssembler extends TestAssembler { public StackSlot emitNarrowPointerToStack(Register a) { StackSlot ret = newStackSlot(SPARCKind.WORD); // STW a, [fp+offset] - emitOp3(0b11, a, 0b000100, SPARC.fp, ret.getRawOffset() + SPARC.STACK_BIAS); + emitStore(0b000100, a, ret); return ret; } + private void emitStore(int op3, Register a, StackSlot ret) { + int offset = ret.getRawOffset() + SPARC.STACK_BIAS; + if (isSimm(offset, 13)) { + // op3 a, [sp+offset] + emitOp3(0b11, a, op3, SPARC.fp, offset); + } else { + assert a != SPARC.g3; + Register r = SPARC.g3; + loadLongToRegister(offset, r); + // op3 a, [sp+g3] + emitOp3(0b11, a, op3, SPARC.fp, r); + } + } + @Override public Register emitUncompressPointer(Register compressed, long base, int shift) { Register ret; diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MemoryAccessProviderData.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MemoryAccessProviderData.java index e07963f191b..a880dc452bb 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MemoryAccessProviderData.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MemoryAccessProviderData.java @@ -24,15 +24,18 @@ package jdk.vm.ci.hotspot.test; import java.lang.reflect.Field; -import jdk.vm.ci.meta.JavaConstant; -import jdk.vm.ci.meta.JavaKind; -import jdk.vm.ci.runtime.JVMCI; + import org.testng.annotations.DataProvider; + +import jdk.internal.misc.Unsafe; import jdk.vm.ci.hotspot.HotSpotConstantReflectionProvider; import jdk.vm.ci.hotspot.HotSpotJVMCIRuntimeProvider; import jdk.vm.ci.hotspot.HotSpotResolvedObjectType; +import jdk.vm.ci.hotspot.HotSpotVMConfigAccess; import jdk.vm.ci.meta.Constant; -import jdk.internal.misc.Unsafe; +import jdk.vm.ci.meta.JavaConstant; +import jdk.vm.ci.meta.JavaKind; +import jdk.vm.ci.runtime.JVMCI; public class MemoryAccessProviderData { private static final Unsafe UNSAFE = getUnsafe(); @@ -54,7 +57,7 @@ public class MemoryAccessProviderData { @DataProvider(name = "positiveObject") public static Object[][] getPositiveObjectJavaKind() { HotSpotJVMCIRuntimeProvider runtime = (HotSpotJVMCIRuntimeProvider) JVMCI.getRuntime(); - int offset = runtime.getConfig().classMirrorOffset; + int offset = new HotSpotVMConfigAccess(runtime.getConfigStore()).getFieldOffset("Klass::_java_mirror", Integer.class, "oop"); Constant wrappedKlassPointer = ((HotSpotResolvedObjectType) runtime.fromClass(TestClass.class)).klass(); return new Object[][]{new Object[]{JavaKind.Object, wrappedKlassPointer, (long) offset, TEST_CLASS_CONSTANT, 0}}; } diff --git a/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MethodHandleAccessProviderTest.java b/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MethodHandleAccessProviderTest.java index dedb1cffcd2..110615dc48d 100644 --- a/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MethodHandleAccessProviderTest.java +++ b/hotspot/test/compiler/jvmci/jdk.vm.ci.hotspot.test/src/jdk/vm/ci/hotspot/test/MethodHandleAccessProviderTest.java @@ -29,6 +29,7 @@ * @modules jdk.vm.ci/jdk.vm.ci.meta * jdk.vm.ci/jdk.vm.ci.runtime * jdk.vm.ci/jdk.vm.ci.hotspot + * @ignore 8161068 * @run testng/othervm -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI * jdk.vm.ci.hotspot.test.MethodHandleAccessProviderTest */ diff --git a/hotspot/test/compiler/rangechecks/TestExplicitRangeChecks.java b/hotspot/test/compiler/rangechecks/TestExplicitRangeChecks.java index c4c97f98038..a023d5a4e74 100644 --- a/hotspot/test/compiler/rangechecks/TestExplicitRangeChecks.java +++ b/hotspot/test/compiler/rangechecks/TestExplicitRangeChecks.java @@ -26,10 +26,10 @@ * @bug 8073480 * @summary explicit range checks should be recognized by C2 * @modules java.base/jdk.internal.misc - * @library /testlibrary /test/lib /compiler/whitebox / + * @library /testlibrary /test/lib / * @build TestExplicitRangeChecks - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * @run main ClassFileInstaller jdk.test.lib.Platform + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * jdk.test.lib.Platform * @run main/othervm -ea -Xmixed -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:-BackgroundCompilation -XX:-UseOnStackReplacement -XX:CompileCommand=compileonly,TestExplicitRangeChecks.test* TestExplicitRangeChecks * diff --git a/hotspot/test/compiler/rangechecks/TestRangeCheckSmearing.java b/hotspot/test/compiler/rangechecks/TestRangeCheckSmearing.java index 72b78738288..33ff3e01d93 100644 --- a/hotspot/test/compiler/rangechecks/TestRangeCheckSmearing.java +++ b/hotspot/test/compiler/rangechecks/TestRangeCheckSmearing.java @@ -25,12 +25,12 @@ * @test * @bug 8066103 * @summary C2's range check smearing allows out of bound array accesses - * @library /testlibrary /test/lib /compiler/whitebox / + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRangeCheckSmearing - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * @run main ClassFileInstaller jdk.test.lib.Platform + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * jdk.test.lib.Platform * @run main/othervm -ea -Xmixed -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:-BackgroundCompilation -XX:-UseOnStackReplacement TestRangeCheckSmearing * diff --git a/hotspot/test/compiler/regalloc/C1ObjectSpillInLogicOp.java b/hotspot/test/compiler/regalloc/C1ObjectSpillInLogicOp.java index f8fc1879644..cf7b65b6dc9 100644 --- a/hotspot/test/compiler/regalloc/C1ObjectSpillInLogicOp.java +++ b/hotspot/test/compiler/regalloc/C1ObjectSpillInLogicOp.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,7 +24,7 @@ /* * @test * @bug 8027751 - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @summary C1 crashes generating G1 post-barrier in Unsafe.getAndSetObject() intrinsic because of the new value spill * @run main/othervm -XX:+UseG1GC C1ObjectSpillInLogicOp * diff --git a/hotspot/test/compiler/rtm/cli/RTMLockingAwareTest.java b/hotspot/test/compiler/rtm/cli/RTMLockingAwareTest.java index 1d42662fa31..654040a1f4f 100644 --- a/hotspot/test/compiler/rtm/cli/RTMLockingAwareTest.java +++ b/hotspot/test/compiler/rtm/cli/RTMLockingAwareTest.java @@ -28,8 +28,8 @@ import java.util.LinkedList; import jdk.test.lib.ExitCode; import jdk.test.lib.cli.*; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Base for all RTM-related CLI tests on options whose processing depends diff --git a/hotspot/test/compiler/rtm/cli/TestPrintPreciseRTMLockingStatisticsOptionOnSupportedConfig.java b/hotspot/test/compiler/rtm/cli/TestPrintPreciseRTMLockingStatisticsOptionOnSupportedConfig.java index c4eacf5f111..e8e9fdb870a 100644 --- a/hotspot/test/compiler/rtm/cli/TestPrintPreciseRTMLockingStatisticsOptionOnSupportedConfig.java +++ b/hotspot/test/compiler/rtm/cli/TestPrintPreciseRTMLockingStatisticsOptionOnSupportedConfig.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify PrintPreciseRTMLockingStatistics on CPUs with * rtm support and on VM with rtm locking support, - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestPrintPreciseRTMLockingStatisticsOptionOnSupportedConfig - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI * TestPrintPreciseRTMLockingStatisticsOptionOnSupportedConfig @@ -40,8 +40,8 @@ import jdk.test.lib.cli.*; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; public class TestPrintPreciseRTMLockingStatisticsOptionOnSupportedConfig extends TestPrintPreciseRTMLockingStatisticsBase { diff --git a/hotspot/test/compiler/rtm/cli/TestPrintPreciseRTMLockingStatisticsOptionOnUnsupportedConfig.java b/hotspot/test/compiler/rtm/cli/TestPrintPreciseRTMLockingStatisticsOptionOnUnsupportedConfig.java index 29cbee10771..ec2b4311568 100644 --- a/hotspot/test/compiler/rtm/cli/TestPrintPreciseRTMLockingStatisticsOptionOnUnsupportedConfig.java +++ b/hotspot/test/compiler/rtm/cli/TestPrintPreciseRTMLockingStatisticsOptionOnUnsupportedConfig.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify PrintPreciseRTMLockingStatistics on CPUs without * rtm support and/or unsupported VM. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestPrintPreciseRTMLockingStatisticsOptionOnUnsupportedConfig - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI * TestPrintPreciseRTMLockingStatisticsOptionOnUnsupportedConfig @@ -40,8 +40,8 @@ import jdk.test.lib.cli.predicate.AndPredicate; import jdk.test.lib.cli.predicate.NotPredicate; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; public class TestPrintPreciseRTMLockingStatisticsOptionOnUnsupportedConfig extends TestPrintPreciseRTMLockingStatisticsBase { diff --git a/hotspot/test/compiler/rtm/cli/TestRTMAbortRatioOptionOnSupportedConfig.java b/hotspot/test/compiler/rtm/cli/TestRTMAbortRatioOptionOnSupportedConfig.java index aa5fc122a64..b1a761df8af 100644 --- a/hotspot/test/compiler/rtm/cli/TestRTMAbortRatioOptionOnSupportedConfig.java +++ b/hotspot/test/compiler/rtm/cli/TestRTMAbortRatioOptionOnSupportedConfig.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify RTMAbortRatio option processing on CPU with rtm * support and on VM with rtm locking support. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRTMAbortRatioOptionOnSupportedConfig - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestRTMAbortRatioOptionOnSupportedConfig */ diff --git a/hotspot/test/compiler/rtm/cli/TestRTMAbortRatioOptionOnUnsupportedConfig.java b/hotspot/test/compiler/rtm/cli/TestRTMAbortRatioOptionOnUnsupportedConfig.java index 5c97ade4ce2..0104b8f3f83 100644 --- a/hotspot/test/compiler/rtm/cli/TestRTMAbortRatioOptionOnUnsupportedConfig.java +++ b/hotspot/test/compiler/rtm/cli/TestRTMAbortRatioOptionOnUnsupportedConfig.java @@ -27,20 +27,20 @@ * @bug 8031320 * @summary Verify RTMAbortRatio option processing on CPU without rtm * support or on VM that does not support rtm locking. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRTMAbortRatioOptionOnUnsupportedConfig - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestRTMAbortRatioOptionOnUnsupportedConfig */ import jdk.test.lib.cli.predicate.AndPredicate; import jdk.test.lib.cli.predicate.NotPredicate; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; public class TestRTMAbortRatioOptionOnUnsupportedConfig extends RTMGenericCommandLineOptionTest { diff --git a/hotspot/test/compiler/rtm/cli/TestRTMTotalCountIncrRateOptionOnSupportedConfig.java b/hotspot/test/compiler/rtm/cli/TestRTMTotalCountIncrRateOptionOnSupportedConfig.java index b76fc6f7408..1e9300428a9 100644 --- a/hotspot/test/compiler/rtm/cli/TestRTMTotalCountIncrRateOptionOnSupportedConfig.java +++ b/hotspot/test/compiler/rtm/cli/TestRTMTotalCountIncrRateOptionOnSupportedConfig.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify RTMTotalCountIncrRate option processing on CPU with * rtm support and on VM with rtm locking support. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRTMTotalCountIncrRateOptionOnSupportedConfig - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI * TestRTMTotalCountIncrRateOptionOnSupportedConfig diff --git a/hotspot/test/compiler/rtm/cli/TestRTMTotalCountIncrRateOptionOnUnsupportedConfig.java b/hotspot/test/compiler/rtm/cli/TestRTMTotalCountIncrRateOptionOnUnsupportedConfig.java index c1d26ccd3a3..c855876cca8 100644 --- a/hotspot/test/compiler/rtm/cli/TestRTMTotalCountIncrRateOptionOnUnsupportedConfig.java +++ b/hotspot/test/compiler/rtm/cli/TestRTMTotalCountIncrRateOptionOnUnsupportedConfig.java @@ -24,20 +24,20 @@ import jdk.test.lib.cli.predicate.AndPredicate; import jdk.test.lib.cli.predicate.NotPredicate; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * @test * @bug 8031320 * @summary Verify RTMTotalCountIncrRate option processing on CPU without * rtm support and/or on VM without rtm locking support. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRTMTotalCountIncrRateOptionOnUnsupportedConfig - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI * TestRTMTotalCountIncrRateOptionOnUnsupportedConfig diff --git a/hotspot/test/compiler/rtm/cli/TestUseRTMDeoptOptionOnSupportedConfig.java b/hotspot/test/compiler/rtm/cli/TestUseRTMDeoptOptionOnSupportedConfig.java index 07431f3e91f..5ac9c26dd9b 100644 --- a/hotspot/test/compiler/rtm/cli/TestUseRTMDeoptOptionOnSupportedConfig.java +++ b/hotspot/test/compiler/rtm/cli/TestUseRTMDeoptOptionOnSupportedConfig.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify UseRTMDeopt option processing on CPUs with rtm support * when rtm locking is supported by VM. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestUseRTMDeoptOptionOnSupportedConfig - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseRTMDeoptOptionOnSupportedConfig */ @@ -40,8 +40,8 @@ import jdk.test.lib.ExitCode; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; public class TestUseRTMDeoptOptionOnSupportedConfig extends CommandLineOptionTest { diff --git a/hotspot/test/compiler/rtm/cli/TestUseRTMDeoptOptionOnUnsupportedConfig.java b/hotspot/test/compiler/rtm/cli/TestUseRTMDeoptOptionOnUnsupportedConfig.java index 59b87002aa7..fd6ef44d53e 100644 --- a/hotspot/test/compiler/rtm/cli/TestUseRTMDeoptOptionOnUnsupportedConfig.java +++ b/hotspot/test/compiler/rtm/cli/TestUseRTMDeoptOptionOnUnsupportedConfig.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify UseRTMDeopt option processing on CPUs without rtm support * or on VMs without rtm locking support. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestUseRTMDeoptOptionOnUnsupportedConfig - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseRTMDeoptOptionOnUnsupportedConfig */ @@ -41,8 +41,8 @@ import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; import jdk.test.lib.cli.predicate.NotPredicate; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; public class TestUseRTMDeoptOptionOnUnsupportedConfig extends RTMGenericCommandLineOptionTest { diff --git a/hotspot/test/compiler/rtm/cli/TestUseRTMForStackLocksOptionOnSupportedConfig.java b/hotspot/test/compiler/rtm/cli/TestUseRTMForStackLocksOptionOnSupportedConfig.java index a6520551d52..49c9ebd5638 100644 --- a/hotspot/test/compiler/rtm/cli/TestUseRTMForStackLocksOptionOnSupportedConfig.java +++ b/hotspot/test/compiler/rtm/cli/TestUseRTMForStackLocksOptionOnSupportedConfig.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify UseRTMForStackLocks option processing on CPU with * rtm support when VM supports rtm locking. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestUseRTMForStackLocksOptionOnSupportedConfig - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI * TestUseRTMForStackLocksOptionOnSupportedConfig @@ -41,8 +41,8 @@ import jdk.test.lib.*; import jdk.test.lib.cli.*; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; public class TestUseRTMForStackLocksOptionOnSupportedConfig extends CommandLineOptionTest { diff --git a/hotspot/test/compiler/rtm/cli/TestUseRTMForStackLocksOptionOnUnsupportedConfig.java b/hotspot/test/compiler/rtm/cli/TestUseRTMForStackLocksOptionOnUnsupportedConfig.java index 54bc3e94ba4..ea1555ab57f 100644 --- a/hotspot/test/compiler/rtm/cli/TestUseRTMForStackLocksOptionOnUnsupportedConfig.java +++ b/hotspot/test/compiler/rtm/cli/TestUseRTMForStackLocksOptionOnUnsupportedConfig.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify UseRTMForStackLocks option processing on CPUs without * rtm support and/or on VMs without rtm locking support. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestUseRTMForStackLocksOptionOnUnsupportedConfig - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI * TestUseRTMForStackLocksOptionOnUnsupportedConfig @@ -42,8 +42,8 @@ import jdk.test.lib.ExitCode; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; import jdk.test.lib.cli.predicate.NotPredicate; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; public class TestUseRTMForStackLocksOptionOnUnsupportedConfig extends RTMGenericCommandLineOptionTest { diff --git a/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionOnSupportedConfig.java b/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionOnSupportedConfig.java index 8a923eb5b7c..ed8e386deb6 100644 --- a/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionOnSupportedConfig.java +++ b/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionOnSupportedConfig.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify UseRTMLocking option processing on CPU with rtm support and * on VM with rtm-locking support. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestUseRTMLockingOptionOnSupportedConfig - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseRTMLockingOptionOnSupportedConfig */ @@ -40,8 +40,8 @@ import jdk.test.lib.ExitCode; import jdk.test.lib.cli.*; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; public class TestUseRTMLockingOptionOnSupportedConfig extends CommandLineOptionTest { diff --git a/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionOnUnsupportedCPU.java b/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionOnUnsupportedCPU.java index fa77a22d164..e5d24060824 100644 --- a/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionOnUnsupportedCPU.java +++ b/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionOnUnsupportedCPU.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify UseRTMLocking option processing on CPU without * rtm support. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestUseRTMLockingOptionOnUnsupportedCPU - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseRTMLockingOptionOnUnsupportedCPU */ @@ -41,8 +41,8 @@ import jdk.test.lib.*; import jdk.test.lib.cli.*; import jdk.test.lib.cli.predicate.AndPredicate; import jdk.test.lib.cli.predicate.NotPredicate; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; public class TestUseRTMLockingOptionOnUnsupportedCPU extends CommandLineOptionTest { diff --git a/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionOnUnsupportedVM.java b/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionOnUnsupportedVM.java index 69c5d1580e7..6b9c50d678b 100644 --- a/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionOnUnsupportedVM.java +++ b/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionOnUnsupportedVM.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify UseRTMLocking option processing on CPU with rtm support * in case when VM should not support this option. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestUseRTMLockingOptionOnUnsupportedVM - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseRTMLockingOptionOnUnsupportedVM */ @@ -41,8 +41,8 @@ import jdk.test.lib.ExitCode; import jdk.test.lib.cli.*; import jdk.test.lib.cli.predicate.AndPredicate; import jdk.test.lib.cli.predicate.NotPredicate; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; public class TestUseRTMLockingOptionOnUnsupportedVM extends CommandLineOptionTest { diff --git a/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionWithBiasedLocking.java b/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionWithBiasedLocking.java index 33a39468dd0..d43c25bfc92 100644 --- a/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionWithBiasedLocking.java +++ b/hotspot/test/compiler/rtm/cli/TestUseRTMLockingOptionWithBiasedLocking.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify processing of UseRTMLocking and UseBiasedLocking * options combination on CPU and VM with rtm support. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestUseRTMLockingOptionWithBiasedLocking - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseRTMLockingOptionWithBiasedLocking */ @@ -40,8 +40,8 @@ import jdk.test.lib.*; import jdk.test.lib.cli.*; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; public class TestUseRTMLockingOptionWithBiasedLocking extends CommandLineOptionTest { diff --git a/hotspot/test/compiler/rtm/locking/TestRTMAbortRatio.java b/hotspot/test/compiler/rtm/locking/TestRTMAbortRatio.java index 574b7cc74fd..c9b601247b8 100644 --- a/hotspot/test/compiler/rtm/locking/TestRTMAbortRatio.java +++ b/hotspot/test/compiler/rtm/locking/TestRTMAbortRatio.java @@ -27,11 +27,11 @@ * @bug 8031320 * @summary Verify that RTMAbortRatio affects amount of aborts before * deoptimization. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRTMAbortRatio - * @run main ClassFileInstaller sun.hotspot.WhiteBox + * @run driver ClassFileInstaller sun.hotspot.WhiteBox * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestRTMAbortRatio @@ -41,9 +41,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; import jdk.internal.misc.Unsafe; /** diff --git a/hotspot/test/compiler/rtm/locking/TestRTMAbortThreshold.java b/hotspot/test/compiler/rtm/locking/TestRTMAbortThreshold.java index 3597c8362bf..c3a4f39b8fc 100644 --- a/hotspot/test/compiler/rtm/locking/TestRTMAbortThreshold.java +++ b/hotspot/test/compiler/rtm/locking/TestRTMAbortThreshold.java @@ -27,11 +27,11 @@ * @bug 8031320 * @summary Verify that RTMAbortThreshold option affects * amount of aborts after which abort ratio is calculated. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRTMAbortThreshold - * @run main ClassFileInstaller sun.hotspot.WhiteBox + * @run driver ClassFileInstaller sun.hotspot.WhiteBox * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestRTMAbortThreshold @@ -41,9 +41,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Test verifies that on RTMAbortThreshold option actually affects how soon diff --git a/hotspot/test/compiler/rtm/locking/TestRTMAfterNonRTMDeopt.java b/hotspot/test/compiler/rtm/locking/TestRTMAfterNonRTMDeopt.java index e4623c2c077..cbb3da2a191 100644 --- a/hotspot/test/compiler/rtm/locking/TestRTMAfterNonRTMDeopt.java +++ b/hotspot/test/compiler/rtm/locking/TestRTMAfterNonRTMDeopt.java @@ -29,12 +29,12 @@ * caused by reason other then rtm_state_change will reset * method's RTM state. And if we don't use RTMDeopt, then * RTM state remain the same after such deoptimization. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRTMAfterNonRTMDeopt - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestRTMAfterNonRTMDeopt */ @@ -43,9 +43,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; import jdk.internal.misc.Unsafe; /** diff --git a/hotspot/test/compiler/rtm/locking/TestRTMDeoptOnHighAbortRatio.java b/hotspot/test/compiler/rtm/locking/TestRTMDeoptOnHighAbortRatio.java index eddc3cc3200..25e24e45384 100644 --- a/hotspot/test/compiler/rtm/locking/TestRTMDeoptOnHighAbortRatio.java +++ b/hotspot/test/compiler/rtm/locking/TestRTMDeoptOnHighAbortRatio.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify that on high abort ratio method will be recompiled * without rtm locking. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRTMDeoptOnHighAbortRatio - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestRTMDeoptOnHighAbortRatio */ @@ -41,9 +41,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Test verifies that on high abort ratio method wil be deoptimized with diff --git a/hotspot/test/compiler/rtm/locking/TestRTMDeoptOnLowAbortRatio.java b/hotspot/test/compiler/rtm/locking/TestRTMDeoptOnLowAbortRatio.java index de8e8a3519f..ded714888d6 100644 --- a/hotspot/test/compiler/rtm/locking/TestRTMDeoptOnLowAbortRatio.java +++ b/hotspot/test/compiler/rtm/locking/TestRTMDeoptOnLowAbortRatio.java @@ -26,12 +26,12 @@ * @test * @bug 8031320 * @summary Verify that on low abort ratio method will be recompiled. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRTMDeoptOnLowAbortRatio - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestRTMDeoptOnLowAbortRatio */ @@ -40,9 +40,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; import jdk.internal.misc.Unsafe; /** diff --git a/hotspot/test/compiler/rtm/locking/TestRTMLockingCalculationDelay.java b/hotspot/test/compiler/rtm/locking/TestRTMLockingCalculationDelay.java index 9cbcea733c8..8124d4107e0 100644 --- a/hotspot/test/compiler/rtm/locking/TestRTMLockingCalculationDelay.java +++ b/hotspot/test/compiler/rtm/locking/TestRTMLockingCalculationDelay.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify that RTMLockingCalculationDelay affect when * abort ratio calculation is started. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRTMLockingCalculationDelay - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestRTMLockingCalculationDelay */ @@ -40,9 +40,9 @@ import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Test verifies that abort ratio calculation could be delayed using diff --git a/hotspot/test/compiler/rtm/locking/TestRTMLockingThreshold.java b/hotspot/test/compiler/rtm/locking/TestRTMLockingThreshold.java index 7280fc21b81..415f872d43d 100644 --- a/hotspot/test/compiler/rtm/locking/TestRTMLockingThreshold.java +++ b/hotspot/test/compiler/rtm/locking/TestRTMLockingThreshold.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify that RTMLockingThreshold affects rtm state transition * ProfileRTM => UseRTM. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRTMLockingThreshold - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestRTMLockingThreshold */ @@ -41,9 +41,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; import jdk.internal.misc.Unsafe; /** diff --git a/hotspot/test/compiler/rtm/locking/TestRTMRetryCount.java b/hotspot/test/compiler/rtm/locking/TestRTMRetryCount.java index 35d5b62cc62..82c884b061f 100644 --- a/hotspot/test/compiler/rtm/locking/TestRTMRetryCount.java +++ b/hotspot/test/compiler/rtm/locking/TestRTMRetryCount.java @@ -26,12 +26,12 @@ * @test * @bug 8031320 * @summary Verify that RTMRetryCount affects actual amount of retries. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRTMRetryCount - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestRTMRetryCount */ @@ -41,9 +41,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Test verifies that RTMRetryCount option actually affects amount of diff --git a/hotspot/test/compiler/rtm/locking/TestRTMSpinLoopCount.java b/hotspot/test/compiler/rtm/locking/TestRTMSpinLoopCount.java index b3d15716630..47e89b079cd 100644 --- a/hotspot/test/compiler/rtm/locking/TestRTMSpinLoopCount.java +++ b/hotspot/test/compiler/rtm/locking/TestRTMSpinLoopCount.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify that RTMSpinLoopCount affects time spent * between locking attempts. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRTMSpinLoopCount - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestRTMSpinLoopCount */ @@ -41,9 +41,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Test verifies that RTMSpinLoopCount increase time spent between retries diff --git a/hotspot/test/compiler/rtm/locking/TestRTMTotalCountIncrRate.java b/hotspot/test/compiler/rtm/locking/TestRTMTotalCountIncrRate.java index 37920da4c1d..41aeddb71a3 100644 --- a/hotspot/test/compiler/rtm/locking/TestRTMTotalCountIncrRate.java +++ b/hotspot/test/compiler/rtm/locking/TestRTMTotalCountIncrRate.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify that RTMTotalCountIncrRate option affects * RTM locking statistics. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestRTMTotalCountIncrRate - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestRTMTotalCountIncrRate */ @@ -43,9 +43,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Test verifies that with RTMTotalCountIncrRate=1 RTM locking statistics diff --git a/hotspot/test/compiler/rtm/locking/TestUseRTMAfterLockInflation.java b/hotspot/test/compiler/rtm/locking/TestUseRTMAfterLockInflation.java index 4916d29bd1c..9bc68b458b4 100644 --- a/hotspot/test/compiler/rtm/locking/TestUseRTMAfterLockInflation.java +++ b/hotspot/test/compiler/rtm/locking/TestUseRTMAfterLockInflation.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify that rtm locking is used for stack locks before * inflation and after it used for inflated locks. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestUseRTMAfterLockInflation - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseRTMAfterLockInflation */ @@ -42,9 +42,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Test verifies that RTM is used after lock inflation by executing compiled diff --git a/hotspot/test/compiler/rtm/locking/TestUseRTMDeopt.java b/hotspot/test/compiler/rtm/locking/TestUseRTMDeopt.java index 93c630ce654..054d2f7eaa1 100644 --- a/hotspot/test/compiler/rtm/locking/TestUseRTMDeopt.java +++ b/hotspot/test/compiler/rtm/locking/TestUseRTMDeopt.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify that UseRTMDeopt affects uncommon trap installation in * copmpiled methods with synchronized block. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestUseRTMDeopt - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseRTMDeopt */ @@ -40,9 +40,9 @@ import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Test verifies that usage of UseRTMDeopt option affects uncommon traps usage diff --git a/hotspot/test/compiler/rtm/locking/TestUseRTMForInflatedLocks.java b/hotspot/test/compiler/rtm/locking/TestUseRTMForInflatedLocks.java index 9f433479b06..b9c23a43d44 100644 --- a/hotspot/test/compiler/rtm/locking/TestUseRTMForInflatedLocks.java +++ b/hotspot/test/compiler/rtm/locking/TestUseRTMForInflatedLocks.java @@ -26,12 +26,12 @@ * @test * @bug 8031320 * @summary Verify that rtm locking is used for inflated locks. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestUseRTMForInflatedLocks - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseRTMForInflatedLocks */ @@ -41,9 +41,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Test verifies that RTM-based lock elision could be used for inflated locks diff --git a/hotspot/test/compiler/rtm/locking/TestUseRTMForStackLocks.java b/hotspot/test/compiler/rtm/locking/TestUseRTMForStackLocks.java index 0f2cf7641e5..afede71949f 100644 --- a/hotspot/test/compiler/rtm/locking/TestUseRTMForStackLocks.java +++ b/hotspot/test/compiler/rtm/locking/TestUseRTMForStackLocks.java @@ -26,12 +26,12 @@ * @test * @bug 8031320 * @summary Verify that rtm locking is used for stack locks. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestUseRTMForStackLocks - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseRTMForStackLocks */ @@ -41,9 +41,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Test verifies that RTM-based lock elision could be used for stack locks diff --git a/hotspot/test/compiler/rtm/locking/TestUseRTMXendForLockBusy.java b/hotspot/test/compiler/rtm/locking/TestUseRTMXendForLockBusy.java index 4be6f198c7d..c61e6bcbb9a 100644 --- a/hotspot/test/compiler/rtm/locking/TestUseRTMXendForLockBusy.java +++ b/hotspot/test/compiler/rtm/locking/TestUseRTMXendForLockBusy.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify that UseRTMXendForLockBusy option affects * method behaviour if lock is busy. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestUseRTMXendForLockBusy - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseRTMXendForLockBusy */ @@ -42,9 +42,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Test verifies that with +UseRTMXendForLockBusy there will be no aborts diff --git a/hotspot/test/compiler/rtm/method_options/TestNoRTMLockElidingOption.java b/hotspot/test/compiler/rtm/method_options/TestNoRTMLockElidingOption.java index a63cc0f88f0..567ddd57cf7 100644 --- a/hotspot/test/compiler/rtm/method_options/TestNoRTMLockElidingOption.java +++ b/hotspot/test/compiler/rtm/method_options/TestNoRTMLockElidingOption.java @@ -27,12 +27,12 @@ * @bug 8031320 * @summary Verify that NoRTMLockEliding option could be applied to * specified method and that such method will not use rtm. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestNoRTMLockElidingOption - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestNoRTMLockElidingOption */ @@ -41,9 +41,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Test verifies that method tagged with option NoRTMLockElidingOption diff --git a/hotspot/test/compiler/rtm/method_options/TestUseRTMLockElidingOption.java b/hotspot/test/compiler/rtm/method_options/TestUseRTMLockElidingOption.java index c8edc9b053e..acb8bdd8bb6 100644 --- a/hotspot/test/compiler/rtm/method_options/TestUseRTMLockElidingOption.java +++ b/hotspot/test/compiler/rtm/method_options/TestUseRTMLockElidingOption.java @@ -28,12 +28,12 @@ * @summary Verify that UseRTMLockEliding option could be applied to * specified method and that such method will not be deoptimized * on high abort ratio. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestUseRTMLockElidingOption - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestUseRTMLockElidingOption */ @@ -42,9 +42,9 @@ import java.util.List; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Test verifies that method tagged with option UseRTMLockElidingOption diff --git a/hotspot/test/compiler/rtm/print/TestPrintPreciseRTMLockingStatistics.java b/hotspot/test/compiler/rtm/print/TestPrintPreciseRTMLockingStatistics.java index f94ed5ee8bc..40aa1a3c7af 100644 --- a/hotspot/test/compiler/rtm/print/TestPrintPreciseRTMLockingStatistics.java +++ b/hotspot/test/compiler/rtm/print/TestPrintPreciseRTMLockingStatistics.java @@ -29,12 +29,12 @@ * on overall aborts and locks count and count of aborts of * different types. Test also verify that VM output does not * contain rtm locking statistics when it should not. - * @library /testlibrary /test/lib /compiler/testlibrary + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TestPrintPreciseRTMLockingStatistics - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI TestPrintPreciseRTMLockingStatistics */ @@ -44,9 +44,9 @@ import java.util.*; import jdk.test.lib.*; import jdk.test.lib.cli.CommandLineOptionTest; import jdk.test.lib.cli.predicate.AndPredicate; -import rtm.*; -import rtm.predicate.SupportedCPU; -import rtm.predicate.SupportedVM; +import compiler.testlibrary.rtm.*; +import compiler.testlibrary.rtm.predicate.SupportedCPU; +import compiler.testlibrary.rtm.predicate.SupportedVM; /** * Test verifies that VM output does not contain RTM locking statistics when it diff --git a/hotspot/test/compiler/runtime/6865265/StackOverflowBug.java b/hotspot/test/compiler/runtime/6865265/StackOverflowBug.java index b8fe082fd94..c5d0f3b62e1 100644 --- a/hotspot/test/compiler/runtime/6865265/StackOverflowBug.java +++ b/hotspot/test/compiler/runtime/6865265/StackOverflowBug.java @@ -28,7 +28,7 @@ * @summary JVM crashes with "missing exception handler" error * @author volker.simonis@sap.com * - * @run main/othervm -XX:CompileThreshold=100 -Xbatch -Xss392k StackOverflowBug + * @run main/othervm -XX:CompileThreshold=100 -Xbatch -Xss512k StackOverflowBug */ diff --git a/hotspot/test/compiler/stable/TestStableBoolean.java b/hotspot/test/compiler/stable/TestStableBoolean.java index 0be8173a8ef..0e9f7bc396a 100644 --- a/hotspot/test/compiler/stable/TestStableBoolean.java +++ b/hotspot/test/compiler/stable/TestStableBoolean.java @@ -95,13 +95,12 @@ public class TestStableBoolean { /* ==================================================== */ static class DefaultValue { - public @Stable - boolean v; + public @Stable boolean v; public static final DefaultValue c = new DefaultValue(); public static boolean get() { return c.v; } public static void test() throws Exception { - boolean val1 = get(); + boolean val1 = get(); c.v = true; boolean val2 = get(); assertEquals(val1, false); assertEquals(val2, true); @@ -131,7 +130,7 @@ public class TestStableBoolean { public static final DefaultStaticValue c = new DefaultStaticValue(); public static boolean get() { return c.v; } public static void test() throws Exception { - boolean val1 = get(); + boolean val1 = get(); c.v = true; boolean val2 = get(); assertEquals(val1, false); assertEquals(val2, true); @@ -181,14 +180,14 @@ public class TestStableBoolean { public static void test() throws Exception { { c.v = new boolean[1]; c.v[0] = true; boolean val1 = get(); - c.v[0] = false; boolean val2 = get(); + c.v[0] = false; boolean val2 = get(); assertEquals(val1, true); assertEquals(val2, (isStableEnabled ? true : false)); } { c.v = new boolean[20]; c.v[10] = true; boolean val1 = get1(); - c.v[10] = false; boolean val2 = get1(); + c.v[10] = false; boolean val2 = get1(); assertEquals(val1, true); assertEquals(val2, (isStableEnabled ? true : false)); } @@ -213,7 +212,7 @@ public class TestStableBoolean { public static void test() throws Exception { { c.v = new boolean[1][1]; c.v[0][0] = true; boolean val1 = get(); - c.v[0][0] = false; boolean val2 = get(); + c.v[0][0] = false; boolean val2 = get(); assertEquals(val1, true); assertEquals(val2, (isStableEnabled ? true : false)); @@ -251,7 +250,7 @@ public class TestStableBoolean { public static void test() throws Exception { { c.v = new boolean[1][1][1]; c.v[0][0][0] = true; boolean val1 = get(); - c.v[0][0][0] = false; boolean val2 = get(); + c.v[0][0][0] = false; boolean val2 = get(); assertEquals(val1, true); assertEquals(val2, (isStableEnabled ? true : false)); @@ -299,7 +298,7 @@ public class TestStableBoolean { public static void test() throws Exception { { c.v = new boolean[1][1][1][1]; c.v[0][0][0][0] = true; boolean val1 = get(); - c.v[0][0][0][0] = false; boolean val2 = get(); + c.v[0][0][0][0] = false; boolean val2 = get(); assertEquals(val1, true); assertEquals(val2, (isStableEnabled ? true : false)); @@ -357,7 +356,7 @@ public class TestStableBoolean { public static void test() throws Exception { { c.v = new boolean[1]; ((boolean[])c.v)[0] = true; boolean val1 = get(); - ((boolean[])c.v)[0] = false; boolean val2 = get(); + ((boolean[])c.v)[0] = false; boolean val2 = get(); assertEquals(val1, true); assertEquals(val2, false); @@ -384,7 +383,7 @@ public class TestStableBoolean { public static void test() throws Exception { { c.v = new boolean[1][1]; ((boolean[][])c.v)[0][0] = true; boolean val1 = get(); - ((boolean[][])c.v)[0][0] = false; boolean val2 = get(); + ((boolean[][])c.v)[0][0] = false; boolean val2 = get(); assertEquals(val1, true); assertEquals(val2, false); @@ -392,7 +391,7 @@ public class TestStableBoolean { { c.v = new boolean[1][1]; c.v[0] = new boolean[0]; boolean[] val1 = get1(); - c.v[0] = new boolean[0]; boolean[] val2 = get1(); + c.v[0] = new boolean[0]; boolean[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -420,7 +419,7 @@ public class TestStableBoolean { public static void test() throws Exception { { c.v = new boolean[1][1][1]; ((boolean[][][])c.v)[0][0][0] = true; boolean val1 = get(); - ((boolean[][][])c.v)[0][0][0] = false; boolean val2 = get(); + ((boolean[][][])c.v)[0][0][0] = false; boolean val2 = get(); assertEquals(val1, true); assertEquals(val2, false); @@ -428,14 +427,14 @@ public class TestStableBoolean { { c.v = new boolean[1][1][1]; c.v[0][0] = new boolean[0]; boolean[] val1 = get1(); - c.v[0][0] = new boolean[0]; boolean[] val2 = get1(); + c.v[0][0] = new boolean[0]; boolean[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } { c.v = new boolean[1][1][1]; c.v[0] = new boolean[0][0]; boolean[][] val1 = get2(); - c.v[0] = new boolean[0][0]; boolean[][] val2 = get2(); + c.v[0] = new boolean[0][0]; boolean[][] val2 = get2(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -465,7 +464,7 @@ public class TestStableBoolean { public static void test() throws Exception { { c.v = new A(); c.v.a = true; A val1 = get(); - c.v.a = false; A val2 = get(); + c.v.a = false; A val2 = get(); assertEquals(val1.a, false); assertEquals(val2.a, false); @@ -473,7 +472,7 @@ public class TestStableBoolean { { c.v = new A(); c.v.a = true; boolean val1 = get1(); - c.v.a = false; boolean val2 = get1(); + c.v.a = false; boolean val2 = get1(); c.v = new A(); c.v.a = false; boolean val3 = get1(); assertEquals(val1, true); @@ -499,8 +498,8 @@ public class TestStableBoolean { public static void test() throws Exception { { c.v = new A(); c.v.next = new A(); c.v.next.next = c.v; - c.v.a = true; c.v.next.a = true; A val1 = get(); - c.v.a = false; c.v.next.a = false; A val2 = get(); + c.v.a = true; c.v.next.a = true; A val1 = get(); + c.v.a = false; c.v.next.a = false; A val2 = get(); assertEquals(val1.a, false); assertEquals(val2.a, false); @@ -508,10 +507,10 @@ public class TestStableBoolean { { c.v = new A(); c.v.next = c.v; - c.v.a = true; boolean val1 = get1(); - c.v.a = false; boolean val2 = get1(); + c.v.a = true; boolean val1 = get1(); + c.v.a = false; boolean val2 = get1(); c.v = new A(); c.v.next = c.v; - c.v.a = false; boolean val3 = get1(); + c.v.a = false; boolean val3 = get1(); assertEquals(val1, true); assertEquals(val2, (isStableEnabled ? true : false)); @@ -537,8 +536,8 @@ public class TestStableBoolean { public static void test() throws Exception { { c.v = new A(); c.v.left = c.v.right = c.v; - c.v.a = true; boolean val1 = get(); boolean val2 = get1(); - c.v.a = false; boolean val3 = get(); boolean val4 = get1(); + c.v.a = true; boolean val1 = get(); boolean val2 = get1(); + c.v.a = false; boolean val3 = get(); boolean val4 = get1(); assertEquals(val1, true); assertEquals(val3, (isStableEnabled ? true : false)); @@ -568,8 +567,8 @@ public class TestStableBoolean { { A elem = new A(); c.v = new A[] { elem, elem }; c.v[0].left = c.v[0].right = c.v; - elem.a = true; boolean val1 = get(); boolean val2 = get1(); - elem.a = false; boolean val3 = get(); boolean val4 = get1(); + elem.a = true; boolean val1 = get(); boolean val2 = get1(); + elem.a = false; boolean val3 = get(); boolean val4 = get1(); assertEquals(val1, true); assertEquals(val3, (isStableEnabled ? true : false)); @@ -606,5 +605,4 @@ public class TestStableBoolean { } } } - } diff --git a/hotspot/test/compiler/stable/TestStableByte.java b/hotspot/test/compiler/stable/TestStableByte.java index a983cfa814f..46f4711c19d 100644 --- a/hotspot/test/compiler/stable/TestStableByte.java +++ b/hotspot/test/compiler/stable/TestStableByte.java @@ -100,7 +100,7 @@ public class TestStableByte { public static final DefaultValue c = new DefaultValue(); public static byte get() { return c.v; } public static void test() throws Exception { - byte val1 = get(); + byte val1 = get(); c.v = 1; byte val2 = get(); assertEquals(val1, 0); assertEquals(val2, 1); @@ -130,7 +130,7 @@ public class TestStableByte { public static final DefaultStaticValue c = new DefaultStaticValue(); public static byte get() { return c.v; } public static void test() throws Exception { - byte val1 = get(); + byte val1 = get(); c.v = 1; byte val2 = get(); assertEquals(val1, 0); assertEquals(val2, 1); @@ -180,24 +180,24 @@ public class TestStableByte { public static void test() throws Exception { { c.v = new byte[1]; c.v[0] = 1; byte val1 = get(); - c.v[0] = 2; byte val2 = get(); + c.v[0] = 2; byte val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new byte[1]; c.v[0] = 3; byte val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); } { c.v = new byte[20]; c.v[10] = 1; byte val1 = get1(); - c.v[10] = 2; byte val2 = get1(); + c.v[10] = 2; byte val2 = get1(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new byte[20]; c.v[10] = 3; byte val3 = get1(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); } { @@ -220,17 +220,17 @@ public class TestStableByte { public static void test() throws Exception { { c.v = new byte[1][1]; c.v[0][0] = 1; byte val1 = get(); - c.v[0][0] = 2; byte val2 = get(); + c.v[0][0] = 2; byte val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new byte[1][1]; c.v[0][0] = 3; byte val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); c.v[0] = new byte[1]; c.v[0][0] = 4; byte val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 4)); + : 4)); } { @@ -260,21 +260,21 @@ public class TestStableByte { public static void test() throws Exception { { c.v = new byte[1][1][1]; c.v[0][0][0] = 1; byte val1 = get(); - c.v[0][0][0] = 2; byte val2 = get(); + c.v[0][0][0] = 2; byte val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new byte[1][1][1]; c.v[0][0][0] = 3; byte val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); c.v[0] = new byte[1][1]; c.v[0][0][0] = 4; byte val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 4)); + : 4)); c.v[0][0] = new byte[1]; c.v[0][0][0] = 5; byte val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 5)); + : 5)); } { @@ -311,25 +311,25 @@ public class TestStableByte { public static void test() throws Exception { { c.v = new byte[1][1][1][1]; c.v[0][0][0][0] = 1; byte val1 = get(); - c.v[0][0][0][0] = 2; byte val2 = get(); + c.v[0][0][0][0] = 2; byte val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new byte[1][1][1][1]; c.v[0][0][0][0] = 3; byte val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); c.v[0] = new byte[1][1][1]; c.v[0][0][0][0] = 4; byte val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 4)); + : 4)); c.v[0][0] = new byte[1][1]; c.v[0][0][0][0] = 5; byte val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 5)); + : 5)); c.v[0][0][0] = new byte[1]; c.v[0][0][0][0] = 6; byte val6 = get(); assertEquals(val6, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 6)); + : 6)); } { @@ -372,7 +372,7 @@ public class TestStableByte { public static void test() throws Exception { { c.v = new byte[1]; ((byte[])c.v)[0] = 1; byte val1 = get(); - ((byte[])c.v)[0] = 2; byte val2 = get(); + ((byte[])c.v)[0] = 2; byte val2 = get(); assertEquals(val1, 1); assertEquals(val2, 2); @@ -399,7 +399,7 @@ public class TestStableByte { public static void test() throws Exception { { c.v = new byte[1][1]; ((byte[][])c.v)[0][0] = 1; byte val1 = get(); - ((byte[][])c.v)[0][0] = 2; byte val2 = get(); + ((byte[][])c.v)[0][0] = 2; byte val2 = get(); assertEquals(val1, 1); assertEquals(val2, 2); @@ -407,7 +407,7 @@ public class TestStableByte { { c.v = new byte[1][1]; c.v[0] = new byte[0]; byte[] val1 = get1(); - c.v[0] = new byte[0]; byte[] val2 = get1(); + c.v[0] = new byte[0]; byte[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -434,8 +434,8 @@ public class TestStableByte { public static void test() throws Exception { { - c.v = new byte[1][1][1]; ((byte[][][])c.v)[0][0][0] = 1; byte val1 = get(); - ((byte[][][])c.v)[0][0][0] = 2; byte val2 = get(); + c.v = new byte[1][1][1]; ((byte[][][])c.v)[0][0][0] = 1; byte val1 = get(); + ((byte[][][])c.v)[0][0][0] = 2; byte val2 = get(); assertEquals(val1, 1); assertEquals(val2, 2); @@ -443,14 +443,14 @@ public class TestStableByte { { c.v = new byte[1][1][1]; c.v[0][0] = new byte[0]; byte[] val1 = get1(); - c.v[0][0] = new byte[0]; byte[] val2 = get1(); + c.v[0][0] = new byte[0]; byte[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } { c.v = new byte[1][1][1]; c.v[0] = new byte[0][0]; byte[][] val1 = get2(); - c.v[0] = new byte[0][0]; byte[][] val2 = get2(); + c.v[0] = new byte[0][0]; byte[][] val2 = get2(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -480,7 +480,7 @@ public class TestStableByte { public static void test() throws Exception { { c.v = new A(); c.v.a = 1; A val1 = get(); - c.v.a = 2; A val2 = get(); + c.v.a = 2; A val2 = get(); assertEquals(val1.a, 2); assertEquals(val2.a, 2); @@ -488,7 +488,7 @@ public class TestStableByte { { c.v = new A(); c.v.a = 1; byte val1 = get1(); - c.v.a = 2; byte val2 = get1(); + c.v.a = 2; byte val2 = get1(); c.v = new A(); c.v.a = 3; byte val3 = get1(); assertEquals(val1, 1); @@ -514,8 +514,8 @@ public class TestStableByte { public static void test() throws Exception { { c.v = new A(); c.v.next = new A(); c.v.next.next = c.v; - c.v.a = 1; c.v.next.a = 1; A val1 = get(); - c.v.a = 2; c.v.next.a = 2; A val2 = get(); + c.v.a = 1; c.v.next.a = 1; A val1 = get(); + c.v.a = 2; c.v.next.a = 2; A val2 = get(); assertEquals(val1.a, 2); assertEquals(val2.a, 2); @@ -523,10 +523,10 @@ public class TestStableByte { { c.v = new A(); c.v.next = c.v; - c.v.a = 1; byte val1 = get1(); - c.v.a = 2; byte val2 = get1(); + c.v.a = 1; byte val1 = get1(); + c.v.a = 2; byte val2 = get1(); c.v = new A(); c.v.next = c.v; - c.v.a = 3; byte val3 = get1(); + c.v.a = 3; byte val3 = get1(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); @@ -552,8 +552,8 @@ public class TestStableByte { public static void test() throws Exception { { c.v = new A(); c.v.left = c.v.right = c.v; - c.v.a = 1; byte val1 = get(); byte val2 = get1(); - c.v.a = 2; byte val3 = get(); byte val4 = get1(); + c.v.a = 1; byte val1 = get(); byte val2 = get1(); + c.v.a = 2; byte val3 = get(); byte val4 = get1(); assertEquals(val1, 1); assertEquals(val3, (isStableEnabled ? 1 : 2)); @@ -583,8 +583,8 @@ public class TestStableByte { { A elem = new A(); c.v = new A[] { elem, elem }; c.v[0].left = c.v[0].right = c.v; - elem.a = 1; byte val1 = get(); byte val2 = get1(); - elem.a = 2; byte val3 = get(); byte val4 = get1(); + elem.a = 1; byte val1 = get(); byte val2 = get1(); + elem.a = 2; byte val3 = get(); byte val4 = get1(); assertEquals(val1, 1); assertEquals(val3, (isStableEnabled ? 1 : 2)); diff --git a/hotspot/test/compiler/stable/TestStableChar.java b/hotspot/test/compiler/stable/TestStableChar.java index 6fcc407a7ac..95c95c1a1f7 100644 --- a/hotspot/test/compiler/stable/TestStableChar.java +++ b/hotspot/test/compiler/stable/TestStableChar.java @@ -100,7 +100,7 @@ public class TestStableChar { public static final DefaultValue c = new DefaultValue(); public static char get() { return c.v; } public static void test() throws Exception { - char val1 = get(); + char val1 = get(); c.v = 'a'; char val2 = get(); assertEquals(val1, 0); assertEquals(val2, 'a'); @@ -130,7 +130,7 @@ public class TestStableChar { public static final DefaultStaticValue c = new DefaultStaticValue(); public static char get() { return c.v; } public static void test() throws Exception { - char val1 = get(); + char val1 = get(); c.v = 'a'; char val2 = get(); assertEquals(val1, 0); assertEquals(val2, 'a'); @@ -180,24 +180,24 @@ public class TestStableChar { public static void test() throws Exception { { c.v = new char[1]; c.v[0] = 'a'; char val1 = get(); - c.v[0] = 'b'; char val2 = get(); + c.v[0] = 'b'; char val2 = get(); assertEquals(val1, 'a'); assertEquals(val2, (isStableEnabled ? 'a' : 'b')); c.v = new char[1]; c.v[0] = 'c'; char val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 'a' : 'b') - : 'c')); + : 'c')); } { c.v = new char[20]; c.v[10] = 'a'; char val1 = get1(); - c.v[10] = 'b'; char val2 = get1(); + c.v[10] = 'b'; char val2 = get1(); assertEquals(val1, 'a'); assertEquals(val2, (isStableEnabled ? 'a' : 'b')); c.v = new char[20]; c.v[10] = 'c'; char val3 = get1(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 'a' : 'b') - : 'c')); + : 'c')); } { @@ -220,17 +220,17 @@ public class TestStableChar { public static void test() throws Exception { { c.v = new char[1][1]; c.v[0][0] = 'a'; char val1 = get(); - c.v[0][0] = 'b'; char val2 = get(); + c.v[0][0] = 'b'; char val2 = get(); assertEquals(val1, 'a'); assertEquals(val2, (isStableEnabled ? 'a' : 'b')); c.v = new char[1][1]; c.v[0][0] = 'c'; char val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 'a' : 'b') - : 'c')); + : 'c')); c.v[0] = new char[1]; c.v[0][0] = 'd'; char val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 'a' : 'b') - : 'd')); + : 'd')); } { @@ -260,21 +260,21 @@ public class TestStableChar { public static void test() throws Exception { { c.v = new char[1][1][1]; c.v[0][0][0] = 'a'; char val1 = get(); - c.v[0][0][0] = 'b'; char val2 = get(); + c.v[0][0][0] = 'b'; char val2 = get(); assertEquals(val1, 'a'); assertEquals(val2, (isStableEnabled ? 'a' : 'b')); c.v = new char[1][1][1]; c.v[0][0][0] = 'c'; char val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 'a' : 'b') - : 'c')); + : 'c')); c.v[0] = new char[1][1]; c.v[0][0][0] = 'd'; char val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 'a' : 'b') - : 'd')); + : 'd')); c.v[0][0] = new char[1]; c.v[0][0][0] = 'e'; char val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? 'a' : 'b') - : 'e')); + : 'e')); } { @@ -311,25 +311,25 @@ public class TestStableChar { public static void test() throws Exception { { c.v = new char[1][1][1][1]; c.v[0][0][0][0] = 'a'; char val1 = get(); - c.v[0][0][0][0] = 'b'; char val2 = get(); + c.v[0][0][0][0] = 'b'; char val2 = get(); assertEquals(val1, 'a'); assertEquals(val2, (isStableEnabled ? 'a' : 'b')); c.v = new char[1][1][1][1]; c.v[0][0][0][0] = 'c'; char val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 'a' : 'b') - : 'c')); + : 'c')); c.v[0] = new char[1][1][1]; c.v[0][0][0][0] = 'd'; char val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 'a' : 'b') - : 'd')); + : 'd')); c.v[0][0] = new char[1][1]; c.v[0][0][0][0] = 'e'; char val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? 'a' : 'b') - : 'e')); + : 'e')); c.v[0][0][0] = new char[1]; c.v[0][0][0][0] = 'f'; char val6 = get(); assertEquals(val6, (isStableEnabled ? (isStableEnabled ? 'a' : 'b') - : 'f')); + : 'f')); } { @@ -370,7 +370,7 @@ public class TestStableChar { public static void test() throws Exception { { c.v = new char[1]; ((char[])c.v)[0] = 'a'; char val1 = get(); - ((char[])c.v)[0] = 'b'; char val2 = get(); + ((char[])c.v)[0] = 'b'; char val2 = get(); assertEquals(val1, 'a'); assertEquals(val2, 'b'); @@ -397,7 +397,7 @@ public class TestStableChar { public static void test() throws Exception { { c.v = new char[1][1]; ((char[][])c.v)[0][0] = 'a'; char val1 = get(); - ((char[][])c.v)[0][0] = 'b'; char val2 = get(); + ((char[][])c.v)[0][0] = 'b'; char val2 = get(); assertEquals(val1, 'a'); assertEquals(val2, 'b'); @@ -405,7 +405,7 @@ public class TestStableChar { { c.v = new char[1][1]; c.v[0] = new char[0]; char[] val1 = get1(); - c.v[0] = new char[0]; char[] val2 = get1(); + c.v[0] = new char[0]; char[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -432,8 +432,8 @@ public class TestStableChar { public static void test() throws Exception { { - c.v = new char[1][1][1]; ((char[][][])c.v)[0][0][0] = 'a'; char val1 = get(); - ((char[][][])c.v)[0][0][0] = 'b'; char val2 = get(); + c.v = new char[1][1][1]; ((char[][][])c.v)[0][0][0] = 'a'; char val1 = get(); + ((char[][][])c.v)[0][0][0] = 'b'; char val2 = get(); assertEquals(val1, 'a'); assertEquals(val2, 'b'); @@ -441,14 +441,14 @@ public class TestStableChar { { c.v = new char[1][1][1]; c.v[0][0] = new char[0]; char[] val1 = get1(); - c.v[0][0] = new char[0]; char[] val2 = get1(); + c.v[0][0] = new char[0]; char[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } { c.v = new char[1][1][1]; c.v[0] = new char[0][0]; char[][] val1 = get2(); - c.v[0] = new char[0][0]; char[][] val2 = get2(); + c.v[0] = new char[0][0]; char[][] val2 = get2(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -478,7 +478,7 @@ public class TestStableChar { public static void test() throws Exception { { c.v = new A(); c.v.a = 'a'; A val1 = get(); - c.v.a = 'b'; A val2 = get(); + c.v.a = 'b'; A val2 = get(); assertEquals(val1.a, 'b'); assertEquals(val2.a, 'b'); @@ -486,7 +486,7 @@ public class TestStableChar { { c.v = new A(); c.v.a = 'a'; char val1 = get1(); - c.v.a = 'b'; char val2 = get1(); + c.v.a = 'b'; char val2 = get1(); c.v = new A(); c.v.a = 'c'; char val3 = get1(); assertEquals(val1, 'a'); @@ -512,8 +512,8 @@ public class TestStableChar { public static void test() throws Exception { { c.v = new A(); c.v.next = new A(); c.v.next.next = c.v; - c.v.a = 'a'; c.v.next.a = 'a'; A val1 = get(); - c.v.a = 'b'; c.v.next.a = 'b'; A val2 = get(); + c.v.a = 'a'; c.v.next.a = 'a'; A val1 = get(); + c.v.a = 'b'; c.v.next.a = 'b'; A val2 = get(); assertEquals(val1.a, 'b'); assertEquals(val2.a, 'b'); @@ -521,10 +521,10 @@ public class TestStableChar { { c.v = new A(); c.v.next = c.v; - c.v.a = 'a'; char val1 = get1(); - c.v.a = 'b'; char val2 = get1(); + c.v.a = 'a'; char val1 = get1(); + c.v.a = 'b'; char val2 = get1(); c.v = new A(); c.v.next = c.v; - c.v.a = 'c'; char val3 = get1(); + c.v.a = 'c'; char val3 = get1(); assertEquals(val1, 'a'); assertEquals(val2, (isStableEnabled ? 'a' : 'b')); @@ -550,8 +550,8 @@ public class TestStableChar { public static void test() throws Exception { { c.v = new A(); c.v.left = c.v.right = c.v; - c.v.a = 'a'; char val1 = get(); char val2 = get1(); - c.v.a = 'b'; char val3 = get(); char val4 = get1(); + c.v.a = 'a'; char val1 = get(); char val2 = get1(); + c.v.a = 'b'; char val3 = get(); char val4 = get1(); assertEquals(val1, 'a'); assertEquals(val3, (isStableEnabled ? 'a' : 'b')); @@ -581,8 +581,8 @@ public class TestStableChar { { A elem = new A(); c.v = new A[] { elem, elem }; c.v[0].left = c.v[0].right = c.v; - elem.a = 'a'; char val1 = get(); char val2 = get1(); - elem.a = 'b'; char val3 = get(); char val4 = get1(); + elem.a = 'a'; char val1 = get(); char val2 = get1(); + elem.a = 'b'; char val3 = get(); char val4 = get1(); assertEquals(val1, 'a'); assertEquals(val3, (isStableEnabled ? 'a' : 'b')); diff --git a/hotspot/test/compiler/stable/TestStableDouble.java b/hotspot/test/compiler/stable/TestStableDouble.java index 09a388a99a8..34a3df697ea 100644 --- a/hotspot/test/compiler/stable/TestStableDouble.java +++ b/hotspot/test/compiler/stable/TestStableDouble.java @@ -100,7 +100,7 @@ public class TestStableDouble { public static final DefaultValue c = new DefaultValue(); public static double get() { return c.v; } public static void test() throws Exception { - double val1 = get(); + double val1 = get(); c.v = 1.0; double val2 = get(); assertEquals(val1, 0); assertEquals(val2, 1.0); @@ -130,7 +130,7 @@ public class TestStableDouble { public static final DefaultStaticValue c = new DefaultStaticValue(); public static double get() { return c.v; } public static void test() throws Exception { - double val1 = get(); + double val1 = get(); c.v = 1.0; double val2 = get(); assertEquals(val1, 0); assertEquals(val2, 1.0); @@ -180,24 +180,24 @@ public class TestStableDouble { public static void test() throws Exception { { c.v = new double[1]; c.v[0] = 1.0; double val1 = get(); - c.v[0] = 2.0; double val2 = get(); + c.v[0] = 2.0; double val2 = get(); assertEquals(val1, 1.0); assertEquals(val2, (isStableEnabled ? 1.0 : 2.0)); c.v = new double[1]; c.v[0] = 3.0; double val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1.0 : 2.0) - : 3.0)); + : 3.0)); } { c.v = new double[20]; c.v[10] = 1.0; double val1 = get1(); - c.v[10] = 2.0; double val2 = get1(); + c.v[10] = 2.0; double val2 = get1(); assertEquals(val1, 1.0); assertEquals(val2, (isStableEnabled ? 1.0 : 2.0)); c.v = new double[20]; c.v[10] = 3.0; double val3 = get1(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1.0 : 2.0) - : 3.0)); + : 3.0)); } { @@ -220,17 +220,17 @@ public class TestStableDouble { public static void test() throws Exception { { c.v = new double[1][1]; c.v[0][0] = 1.0; double val1 = get(); - c.v[0][0] = 2.0; double val2 = get(); + c.v[0][0] = 2.0; double val2 = get(); assertEquals(val1, 1.0); assertEquals(val2, (isStableEnabled ? 1.0 : 2.0)); c.v = new double[1][1]; c.v[0][0] = 3.0; double val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1.0 : 2.0) - : 3.0)); + : 3.0)); c.v[0] = new double[1]; c.v[0][0] = 4.0; double val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1.0 : 2.0) - : 4.0)); + : 4.0)); } { @@ -260,21 +260,21 @@ public class TestStableDouble { public static void test() throws Exception { { c.v = new double[1][1][1]; c.v[0][0][0] = 1.0; double val1 = get(); - c.v[0][0][0] = 2.0; double val2 = get(); + c.v[0][0][0] = 2.0; double val2 = get(); assertEquals(val1, 1.0); assertEquals(val2, (isStableEnabled ? 1.0 : 2.0)); c.v = new double[1][1][1]; c.v[0][0][0] = 3.0; double val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1.0 : 2.0) - : 3.0)); + : 3.0)); c.v[0] = new double[1][1]; c.v[0][0][0] = 4.0; double val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1.0 : 2.0) - : 4.0)); + : 4.0)); c.v[0][0] = new double[1]; c.v[0][0][0] = 5.0; double val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? 1.0 : 2.0) - : 5.0)); + : 5.0)); } { @@ -311,25 +311,25 @@ public class TestStableDouble { public static void test() throws Exception { { c.v = new double[1][1][1][1]; c.v[0][0][0][0] = 1.0; double val1 = get(); - c.v[0][0][0][0] = 2.0; double val2 = get(); + c.v[0][0][0][0] = 2.0; double val2 = get(); assertEquals(val1, 1.0); assertEquals(val2, (isStableEnabled ? 1.0 : 2.0)); c.v = new double[1][1][1][1]; c.v[0][0][0][0] = 3.0; double val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1.0 : 2.0) - : 3.0)); + : 3.0)); c.v[0] = new double[1][1][1]; c.v[0][0][0][0] = 4.0; double val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1.0 : 2.0) - : 4.0)); + : 4.0)); c.v[0][0] = new double[1][1]; c.v[0][0][0][0] = 5.0; double val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? 1.0 : 2.0) - : 5.0)); + : 5.0)); c.v[0][0][0] = new double[1]; c.v[0][0][0][0] = 6.0; double val6 = get(); assertEquals(val6, (isStableEnabled ? (isStableEnabled ? 1.0 : 2.0) - : 6.0)); + : 6.0)); } { @@ -370,7 +370,7 @@ public class TestStableDouble { public static void test() throws Exception { { c.v = new double[1]; ((double[])c.v)[0] = 1.0; double val1 = get(); - ((double[])c.v)[0] = 2.0; double val2 = get(); + ((double[])c.v)[0] = 2.0; double val2 = get(); assertEquals(val1, 1.0); assertEquals(val2, 2.0); @@ -397,7 +397,7 @@ public class TestStableDouble { public static void test() throws Exception { { c.v = new double[1][1]; ((double[][])c.v)[0][0] = 1.0; double val1 = get(); - ((double[][])c.v)[0][0] = 2.0; double val2 = get(); + ((double[][])c.v)[0][0] = 2.0; double val2 = get(); assertEquals(val1, 1.0); assertEquals(val2, 2.0); @@ -405,7 +405,7 @@ public class TestStableDouble { { c.v = new double[1][1]; c.v[0] = new double[0]; double[] val1 = get1(); - c.v[0] = new double[0]; double[] val2 = get1(); + c.v[0] = new double[0]; double[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -433,7 +433,7 @@ public class TestStableDouble { public static void test() throws Exception { { c.v = new double[1][1][1]; ((double[][][])c.v)[0][0][0] = 1.0; double val1 = get(); - ((double[][][])c.v)[0][0][0] = 2.0; double val2 = get(); + ((double[][][])c.v)[0][0][0] = 2.0; double val2 = get(); assertEquals(val1, 1.0); assertEquals(val2, 2.0); @@ -441,14 +441,14 @@ public class TestStableDouble { { c.v = new double[1][1][1]; c.v[0][0] = new double[0]; double[] val1 = get1(); - c.v[0][0] = new double[0]; double[] val2 = get1(); + c.v[0][0] = new double[0]; double[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } { c.v = new double[1][1][1]; c.v[0] = new double[0][0]; double[][] val1 = get2(); - c.v[0] = new double[0][0]; double[][] val2 = get2(); + c.v[0] = new double[0][0]; double[][] val2 = get2(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -478,7 +478,7 @@ public class TestStableDouble { public static void test() throws Exception { { c.v = new A(); c.v.a = 1.0; A val1 = get(); - c.v.a = 2.0; A val2 = get(); + c.v.a = 2.0; A val2 = get(); assertEquals(val1.a, 2.0); assertEquals(val2.a, 2.0); @@ -486,7 +486,7 @@ public class TestStableDouble { { c.v = new A(); c.v.a = 1.0; double val1 = get1(); - c.v.a = 2.0; double val2 = get1(); + c.v.a = 2.0; double val2 = get1(); c.v = new A(); c.v.a = 3.0; double val3 = get1(); assertEquals(val1, 1.0); @@ -512,8 +512,8 @@ public class TestStableDouble { public static void test() throws Exception { { c.v = new A(); c.v.next = new A(); c.v.next.next = c.v; - c.v.a = 1.0; c.v.next.a = 1.0; A val1 = get(); - c.v.a = 2.0; c.v.next.a = 2.0; A val2 = get(); + c.v.a = 1.0; c.v.next.a = 1.0; A val1 = get(); + c.v.a = 2.0; c.v.next.a = 2.0; A val2 = get(); assertEquals(val1.a, 2.0); assertEquals(val2.a, 2.0); @@ -521,10 +521,10 @@ public class TestStableDouble { { c.v = new A(); c.v.next = c.v; - c.v.a = 1.0; double val1 = get1(); - c.v.a = 2.0; double val2 = get1(); + c.v.a = 1.0; double val1 = get1(); + c.v.a = 2.0; double val2 = get1(); c.v = new A(); c.v.next = c.v; - c.v.a = 3.0; double val3 = get1(); + c.v.a = 3.0; double val3 = get1(); assertEquals(val1, 1.0); assertEquals(val2, (isStableEnabled ? 1.0 : 2.0)); @@ -550,8 +550,8 @@ public class TestStableDouble { public static void test() throws Exception { { c.v = new A(); c.v.left = c.v.right = c.v; - c.v.a = 1.0; double val1 = get(); double val2 = get1(); - c.v.a = 2.0; double val3 = get(); double val4 = get1(); + c.v.a = 1.0; double val1 = get(); double val2 = get1(); + c.v.a = 2.0; double val3 = get(); double val4 = get1(); assertEquals(val1, 1.0); assertEquals(val3, (isStableEnabled ? 1.0 : 2.0)); @@ -581,8 +581,8 @@ public class TestStableDouble { { A elem = new A(); c.v = new A[] { elem, elem }; c.v[0].left = c.v[0].right = c.v; - elem.a = 1.0; double val1 = get(); double val2 = get1(); - elem.a = 2.0; double val3 = get(); double val4 = get1(); + elem.a = 1.0; double val1 = get(); double val2 = get1(); + elem.a = 2.0; double val3 = get(); double val4 = get1(); assertEquals(val1, 1.0); assertEquals(val3, (isStableEnabled ? 1.0 : 2.0)); diff --git a/hotspot/test/compiler/stable/TestStableFloat.java b/hotspot/test/compiler/stable/TestStableFloat.java index 7053e671c85..0f9fc974269 100644 --- a/hotspot/test/compiler/stable/TestStableFloat.java +++ b/hotspot/test/compiler/stable/TestStableFloat.java @@ -100,7 +100,7 @@ public class TestStableFloat { public static final DefaultValue c = new DefaultValue(); public static float get() { return c.v; } public static void test() throws Exception { - float val1 = get(); + float val1 = get(); c.v = 1.0F; float val2 = get(); assertEquals(val1, 0F); assertEquals(val2, 1.0F); @@ -180,24 +180,24 @@ public class TestStableFloat { public static void test() throws Exception { { c.v = new float[1]; c.v[0] = 1.0F; float val1 = get(); - c.v[0] = 2.0F; float val2 = get(); + c.v[0] = 2.0F; float val2 = get(); assertEquals(val1, 1.0F); assertEquals(val2, (isStableEnabled ? 1.0F : 2.0F)); c.v = new float[1]; c.v[0] = 3.0F; float val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1.0F : 2.0F) - : 3.0F)); + : 3.0F)); } { c.v = new float[20]; c.v[10] = 1.0F; float val1 = get1(); - c.v[10] = 2.0F; float val2 = get1(); + c.v[10] = 2.0F; float val2 = get1(); assertEquals(val1, 1.0F); assertEquals(val2, (isStableEnabled ? 1.0F : 2.0F)); c.v = new float[20]; c.v[10] = 3.0F; float val3 = get1(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1.0F : 2.0F) - : 3.0F)); + : 3.0F)); } { @@ -220,17 +220,17 @@ public class TestStableFloat { public static void test() throws Exception { { c.v = new float[1][1]; c.v[0][0] = 1.0F; float val1 = get(); - c.v[0][0] = 2.0F; float val2 = get(); + c.v[0][0] = 2.0F; float val2 = get(); assertEquals(val1, 1.0F); assertEquals(val2, (isStableEnabled ? 1.0F : 2.0F)); c.v = new float[1][1]; c.v[0][0] = 3.0F; float val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1.0F : 2.0F) - : 3.0F)); + : 3.0F)); c.v[0] = new float[1]; c.v[0][0] = 4.0F; float val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1.0F : 2.0F) - : 4.0F)); + : 4.0F)); } { @@ -260,21 +260,21 @@ public class TestStableFloat { public static void test() throws Exception { { c.v = new float[1][1][1]; c.v[0][0][0] = 1.0F; float val1 = get(); - c.v[0][0][0] = 2.0F; float val2 = get(); + c.v[0][0][0] = 2.0F; float val2 = get(); assertEquals(val1, 1.0F); assertEquals(val2, (isStableEnabled ? 1.0F : 2.0F)); c.v = new float[1][1][1]; c.v[0][0][0] = 3.0F; float val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1.0F : 2.0F) - : 3.0F)); + : 3.0F)); c.v[0] = new float[1][1]; c.v[0][0][0] = 4.0F; float val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1.0F : 2.0F) - : 4.0F)); + : 4.0F)); c.v[0][0] = new float[1]; c.v[0][0][0] = 5.0F; float val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? 1.0F : 2.0F) - : 5.0F)); + : 5.0F)); } { @@ -311,25 +311,25 @@ public class TestStableFloat { public static void test() throws Exception { { c.v = new float[1][1][1][1]; c.v[0][0][0][0] = 1.0F; float val1 = get(); - c.v[0][0][0][0] = 2.0F; float val2 = get(); + c.v[0][0][0][0] = 2.0F; float val2 = get(); assertEquals(val1, 1.0F); assertEquals(val2, (isStableEnabled ? 1.0F : 2.0F)); c.v = new float[1][1][1][1]; c.v[0][0][0][0] = 3.0F; float val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1.0F : 2.0F) - : 3.0F)); + : 3.0F)); c.v[0] = new float[1][1][1]; c.v[0][0][0][0] = 4.0F; float val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1.0F : 2.0F) - : 4.0F)); + : 4.0F)); c.v[0][0] = new float[1][1]; c.v[0][0][0][0] = 5.0F; float val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? 1.0F : 2.0F) - : 5.0F)); + : 5.0F)); c.v[0][0][0] = new float[1]; c.v[0][0][0][0] = 6.0F; float val6 = get(); assertEquals(val6, (isStableEnabled ? (isStableEnabled ? 1.0F : 2.0F) - : 6.0F)); + : 6.0F)); } { @@ -370,7 +370,7 @@ public class TestStableFloat { public static void test() throws Exception { { c.v = new float[1]; ((float[])c.v)[0] = 1.0F; float val1 = get(); - ((float[])c.v)[0] = 2.0F; float val2 = get(); + ((float[])c.v)[0] = 2.0F; float val2 = get(); assertEquals(val1, 1.0F); assertEquals(val2, 2.0F); @@ -397,7 +397,7 @@ public class TestStableFloat { public static void test() throws Exception { { c.v = new float[1][1]; ((float[][])c.v)[0][0] = 1.0F; float val1 = get(); - ((float[][])c.v)[0][0] = 2.0F; float val2 = get(); + ((float[][])c.v)[0][0] = 2.0F; float val2 = get(); assertEquals(val1, 1.0F); assertEquals(val2, 2.0F); @@ -405,7 +405,7 @@ public class TestStableFloat { { c.v = new float[1][1]; c.v[0] = new float[0]; float[] val1 = get1(); - c.v[0] = new float[0]; float[] val2 = get1(); + c.v[0] = new float[0]; float[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -433,7 +433,7 @@ public class TestStableFloat { public static void test() throws Exception { { c.v = new float[1][1][1]; ((float[][][])c.v)[0][0][0] = 1.0F; float val1 = get(); - ((float[][][])c.v)[0][0][0] = 2.0F; float val2 = get(); + ((float[][][])c.v)[0][0][0] = 2.0F; float val2 = get(); assertEquals(val1, 1.0F); assertEquals(val2, 2.0F); @@ -441,14 +441,14 @@ public class TestStableFloat { { c.v = new float[1][1][1]; c.v[0][0] = new float[0]; float[] val1 = get1(); - c.v[0][0] = new float[0]; float[] val2 = get1(); + c.v[0][0] = new float[0]; float[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } { c.v = new float[1][1][1]; c.v[0] = new float[0][0]; float[][] val1 = get2(); - c.v[0] = new float[0][0]; float[][] val2 = get2(); + c.v[0] = new float[0][0]; float[][] val2 = get2(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -478,7 +478,7 @@ public class TestStableFloat { public static void test() throws Exception { { c.v = new A(); c.v.a = 1.0F; A val1 = get(); - c.v.a = 2.0F; A val2 = get(); + c.v.a = 2.0F; A val2 = get(); assertEquals(val1.a, 2.0F); assertEquals(val2.a, 2.0F); @@ -486,7 +486,7 @@ public class TestStableFloat { { c.v = new A(); c.v.a = 1.0F; float val1 = get1(); - c.v.a = 2.0F; float val2 = get1(); + c.v.a = 2.0F; float val2 = get1(); c.v = new A(); c.v.a = 3.0F; float val3 = get1(); assertEquals(val1, 1.0F); @@ -512,8 +512,8 @@ public class TestStableFloat { public static void test() throws Exception { { c.v = new A(); c.v.next = new A(); c.v.next.next = c.v; - c.v.a = 1.0F; c.v.next.a = 1.0F; A val1 = get(); - c.v.a = 2.0F; c.v.next.a = 2.0F; A val2 = get(); + c.v.a = 1.0F; c.v.next.a = 1.0F; A val1 = get(); + c.v.a = 2.0F; c.v.next.a = 2.0F; A val2 = get(); assertEquals(val1.a, 2.0F); assertEquals(val2.a, 2.0F); @@ -521,10 +521,10 @@ public class TestStableFloat { { c.v = new A(); c.v.next = c.v; - c.v.a = 1.0F; float val1 = get1(); - c.v.a = 2.0F; float val2 = get1(); + c.v.a = 1.0F; float val1 = get1(); + c.v.a = 2.0F; float val2 = get1(); c.v = new A(); c.v.next = c.v; - c.v.a = 3.0F; float val3 = get1(); + c.v.a = 3.0F; float val3 = get1(); assertEquals(val1, 1.0F); assertEquals(val2, (isStableEnabled ? 1.0F : 2.0F)); @@ -550,8 +550,8 @@ public class TestStableFloat { public static void test() throws Exception { { c.v = new A(); c.v.left = c.v.right = c.v; - c.v.a = 1.0F; float val1 = get(); float val2 = get1(); - c.v.a = 2.0F; float val3 = get(); float val4 = get1(); + c.v.a = 1.0F; float val1 = get(); float val2 = get1(); + c.v.a = 2.0F; float val3 = get(); float val4 = get1(); assertEquals(val1, 1.0F); assertEquals(val3, (isStableEnabled ? 1.0F : 2.0F)); @@ -581,8 +581,8 @@ public class TestStableFloat { { A elem = new A(); c.v = new A[] { elem, elem }; c.v[0].left = c.v[0].right = c.v; - elem.a = 1.0F; float val1 = get(); float val2 = get1(); - elem.a = 2.0F; float val3 = get(); float val4 = get1(); + elem.a = 1.0F; float val1 = get(); float val2 = get1(); + elem.a = 2.0F; float val3 = get(); float val4 = get1(); assertEquals(val1, 1.0F); assertEquals(val3, (isStableEnabled ? 1.0F : 2.0F)); diff --git a/hotspot/test/compiler/stable/TestStableInt.java b/hotspot/test/compiler/stable/TestStableInt.java index 1ebe5295592..4da1d89509e 100644 --- a/hotspot/test/compiler/stable/TestStableInt.java +++ b/hotspot/test/compiler/stable/TestStableInt.java @@ -100,7 +100,7 @@ public class TestStableInt { public static final DefaultValue c = new DefaultValue(); public static int get() { return c.v; } public static void test() throws Exception { - int val1 = get(); + int val1 = get(); c.v = 1; int val2 = get(); assertEquals(val1, 0); assertEquals(val2, 1); @@ -130,7 +130,7 @@ public class TestStableInt { public static final DefaultStaticValue c = new DefaultStaticValue(); public static int get() { return c.v; } public static void test() throws Exception { - int val1 = get(); + int val1 = get(); c.v = 1; int val2 = get(); assertEquals(val1, 0); assertEquals(val2, 1); @@ -180,24 +180,24 @@ public class TestStableInt { public static void test() throws Exception { { c.v = new int[1]; c.v[0] = 1; int val1 = get(); - c.v[0] = 2; int val2 = get(); + c.v[0] = 2; int val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new int[1]; c.v[0] = 3; int val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); } { c.v = new int[20]; c.v[10] = 1; int val1 = get1(); - c.v[10] = 2; int val2 = get1(); + c.v[10] = 2; int val2 = get1(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new int[20]; c.v[10] = 3; int val3 = get1(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); } { @@ -220,17 +220,17 @@ public class TestStableInt { public static void test() throws Exception { { c.v = new int[1][1]; c.v[0][0] = 1; int val1 = get(); - c.v[0][0] = 2; int val2 = get(); + c.v[0][0] = 2; int val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new int[1][1]; c.v[0][0] = 3; int val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); c.v[0] = new int[1]; c.v[0][0] = 4; int val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 4)); + : 4)); } { @@ -260,21 +260,21 @@ public class TestStableInt { public static void test() throws Exception { { c.v = new int[1][1][1]; c.v[0][0][0] = 1; int val1 = get(); - c.v[0][0][0] = 2; int val2 = get(); + c.v[0][0][0] = 2; int val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new int[1][1][1]; c.v[0][0][0] = 3; int val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); c.v[0] = new int[1][1]; c.v[0][0][0] = 4; int val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 4)); + : 4)); c.v[0][0] = new int[1]; c.v[0][0][0] = 5; int val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 5)); + : 5)); } { @@ -311,25 +311,25 @@ public class TestStableInt { public static void test() throws Exception { { c.v = new int[1][1][1][1]; c.v[0][0][0][0] = 1; int val1 = get(); - c.v[0][0][0][0] = 2; int val2 = get(); + c.v[0][0][0][0] = 2; int val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new int[1][1][1][1]; c.v[0][0][0][0] = 3; int val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); c.v[0] = new int[1][1][1]; c.v[0][0][0][0] = 4; int val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 4)); + : 4)); c.v[0][0] = new int[1][1]; c.v[0][0][0][0] = 5; int val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 5)); + : 5)); c.v[0][0][0] = new int[1]; c.v[0][0][0][0] = 6; int val6 = get(); assertEquals(val6, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 6)); + : 6)); } { @@ -370,7 +370,7 @@ public class TestStableInt { public static void test() throws Exception { { c.v = new int[1]; ((int[])c.v)[0] = 1; int val1 = get(); - ((int[])c.v)[0] = 2; int val2 = get(); + ((int[])c.v)[0] = 2; int val2 = get(); assertEquals(val1, 1); assertEquals(val2, 2); @@ -397,7 +397,7 @@ public class TestStableInt { public static void test() throws Exception { { c.v = new int[1][1]; ((int[][])c.v)[0][0] = 1; int val1 = get(); - ((int[][])c.v)[0][0] = 2; int val2 = get(); + ((int[][])c.v)[0][0] = 2; int val2 = get(); assertEquals(val1, 1); assertEquals(val2, 2); @@ -405,7 +405,7 @@ public class TestStableInt { { c.v = new int[1][1]; c.v[0] = new int[0]; int[] val1 = get1(); - c.v[0] = new int[0]; int[] val2 = get1(); + c.v[0] = new int[0]; int[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -433,7 +433,7 @@ public class TestStableInt { public static void test() throws Exception { { c.v = new int[1][1][1]; ((int[][][])c.v)[0][0][0] = 1; int val1 = get(); - ((int[][][])c.v)[0][0][0] = 2; int val2 = get(); + ((int[][][])c.v)[0][0][0] = 2; int val2 = get(); assertEquals(val1, 1); assertEquals(val2, 2); @@ -441,14 +441,14 @@ public class TestStableInt { { c.v = new int[1][1][1]; c.v[0][0] = new int[0]; int[] val1 = get1(); - c.v[0][0] = new int[0]; int[] val2 = get1(); + c.v[0][0] = new int[0]; int[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } { c.v = new int[1][1][1]; c.v[0] = new int[0][0]; int[][] val1 = get2(); - c.v[0] = new int[0][0]; int[][] val2 = get2(); + c.v[0] = new int[0][0]; int[][] val2 = get2(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -478,7 +478,7 @@ public class TestStableInt { public static void test() throws Exception { { c.v = new A(); c.v.a = 1; A val1 = get(); - c.v.a = 2; A val2 = get(); + c.v.a = 2; A val2 = get(); assertEquals(val1.a, 2); assertEquals(val2.a, 2); @@ -486,7 +486,7 @@ public class TestStableInt { { c.v = new A(); c.v.a = 1; int val1 = get1(); - c.v.a = 2; int val2 = get1(); + c.v.a = 2; int val2 = get1(); c.v = new A(); c.v.a = 3; int val3 = get1(); assertEquals(val1, 1); @@ -512,8 +512,8 @@ public class TestStableInt { public static void test() throws Exception { { c.v = new A(); c.v.next = new A(); c.v.next.next = c.v; - c.v.a = 1; c.v.next.a = 1; A val1 = get(); - c.v.a = 2; c.v.next.a = 2; A val2 = get(); + c.v.a = 1; c.v.next.a = 1; A val1 = get(); + c.v.a = 2; c.v.next.a = 2; A val2 = get(); assertEquals(val1.a, 2); assertEquals(val2.a, 2); @@ -521,10 +521,10 @@ public class TestStableInt { { c.v = new A(); c.v.next = c.v; - c.v.a = 1; int val1 = get1(); - c.v.a = 2; int val2 = get1(); + c.v.a = 1; int val1 = get1(); + c.v.a = 2; int val2 = get1(); c.v = new A(); c.v.next = c.v; - c.v.a = 3; int val3 = get1(); + c.v.a = 3; int val3 = get1(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); @@ -550,8 +550,8 @@ public class TestStableInt { public static void test() throws Exception { { c.v = new A(); c.v.left = c.v.right = c.v; - c.v.a = 1; int val1 = get(); int val2 = get1(); - c.v.a = 2; int val3 = get(); int val4 = get1(); + c.v.a = 1; int val1 = get(); int val2 = get1(); + c.v.a = 2; int val3 = get(); int val4 = get1(); assertEquals(val1, 1); assertEquals(val3, (isStableEnabled ? 1 : 2)); @@ -581,8 +581,8 @@ public class TestStableInt { { A elem = new A(); c.v = new A[] { elem, elem }; c.v[0].left = c.v[0].right = c.v; - elem.a = 1; int val1 = get(); int val2 = get1(); - elem.a = 2; int val3 = get(); int val4 = get1(); + elem.a = 1; int val1 = get(); int val2 = get1(); + elem.a = 2; int val3 = get(); int val4 = get1(); assertEquals(val1, 1); assertEquals(val3, (isStableEnabled ? 1 : 2)); diff --git a/hotspot/test/compiler/stable/TestStableLong.java b/hotspot/test/compiler/stable/TestStableLong.java index b70ea910d51..dfbf93b623f 100644 --- a/hotspot/test/compiler/stable/TestStableLong.java +++ b/hotspot/test/compiler/stable/TestStableLong.java @@ -100,7 +100,7 @@ public class TestStableLong { public static final DefaultValue c = new DefaultValue(); public static long get() { return c.v; } public static void test() throws Exception { - long val1 = get(); + long val1 = get(); c.v = 1L; long val2 = get(); assertEquals(val1, 0); assertEquals(val2, 1L); @@ -130,7 +130,7 @@ public class TestStableLong { public static final DefaultStaticValue c = new DefaultStaticValue(); public static long get() { return c.v; } public static void test() throws Exception { - long val1 = get(); + long val1 = get(); c.v = 1L; long val2 = get(); assertEquals(val1, 0); assertEquals(val2, 1L); @@ -180,24 +180,24 @@ public class TestStableLong { public static void test() throws Exception { { c.v = new long[1]; c.v[0] = 1; long val1 = get(); - c.v[0] = 2; long val2 = get(); + c.v[0] = 2; long val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new long[1]; c.v[0] = 3; long val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); } { c.v = new long[20]; c.v[10] = 1; long val1 = get1(); - c.v[10] = 2; long val2 = get1(); + c.v[10] = 2; long val2 = get1(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new long[20]; c.v[10] = 3; long val3 = get1(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); } { @@ -220,17 +220,17 @@ public class TestStableLong { public static void test() throws Exception { { c.v = new long[1][1]; c.v[0][0] = 1; long val1 = get(); - c.v[0][0] = 2; long val2 = get(); + c.v[0][0] = 2; long val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new long[1][1]; c.v[0][0] = 3; long val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); c.v[0] = new long[1]; c.v[0][0] = 4; long val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 4)); + : 4)); } { @@ -260,21 +260,21 @@ public class TestStableLong { public static void test() throws Exception { { c.v = new long[1][1][1]; c.v[0][0][0] = 1; long val1 = get(); - c.v[0][0][0] = 2; long val2 = get(); + c.v[0][0][0] = 2; long val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new long[1][1][1]; c.v[0][0][0] = 3; long val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); c.v[0] = new long[1][1]; c.v[0][0][0] = 4; long val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 4)); + : 4)); c.v[0][0] = new long[1]; c.v[0][0][0] = 5; long val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 5)); + : 5)); } { @@ -311,25 +311,25 @@ public class TestStableLong { public static void test() throws Exception { { c.v = new long[1][1][1][1]; c.v[0][0][0][0] = 1; long val1 = get(); - c.v[0][0][0][0] = 2; long val2 = get(); + c.v[0][0][0][0] = 2; long val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new long[1][1][1][1]; c.v[0][0][0][0] = 3; long val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); c.v[0] = new long[1][1][1]; c.v[0][0][0][0] = 4; long val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 4)); + : 4)); c.v[0][0] = new long[1][1]; c.v[0][0][0][0] = 5; long val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 5)); + : 5)); c.v[0][0][0] = new long[1]; c.v[0][0][0][0] = 6; long val6 = get(); assertEquals(val6, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 6)); + : 6)); } { @@ -370,7 +370,7 @@ public class TestStableLong { public static void test() throws Exception { { c.v = new long[1]; ((long[])c.v)[0] = 1; long val1 = get(); - ((long[])c.v)[0] = 2; long val2 = get(); + ((long[])c.v)[0] = 2; long val2 = get(); assertEquals(val1, 1); assertEquals(val2, 2); @@ -397,7 +397,7 @@ public class TestStableLong { public static void test() throws Exception { { c.v = new long[1][1]; ((long[][])c.v)[0][0] = 1; long val1 = get(); - ((long[][])c.v)[0][0] = 2; long val2 = get(); + ((long[][])c.v)[0][0] = 2; long val2 = get(); assertEquals(val1, 1); assertEquals(val2, 2); @@ -405,7 +405,7 @@ public class TestStableLong { { c.v = new long[1][1]; c.v[0] = new long[0]; long[] val1 = get1(); - c.v[0] = new long[0]; long[] val2 = get1(); + c.v[0] = new long[0]; long[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -433,7 +433,7 @@ public class TestStableLong { public static void test() throws Exception { { c.v = new long[1][1][1]; ((long[][][])c.v)[0][0][0] = 1L; long val1 = get(); - ((long[][][])c.v)[0][0][0] = 2L; long val2 = get(); + ((long[][][])c.v)[0][0][0] = 2L; long val2 = get(); assertEquals(val1, 1L); assertEquals(val2, 2L); @@ -441,14 +441,14 @@ public class TestStableLong { { c.v = new long[1][1][1]; c.v[0][0] = new long[0]; long[] val1 = get1(); - c.v[0][0] = new long[0]; long[] val2 = get1(); + c.v[0][0] = new long[0]; long[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } { c.v = new long[1][1][1]; c.v[0] = new long[0][0]; long[][] val1 = get2(); - c.v[0] = new long[0][0]; long[][] val2 = get2(); + c.v[0] = new long[0][0]; long[][] val2 = get2(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -478,7 +478,7 @@ public class TestStableLong { public static void test() throws Exception { { c.v = new A(); c.v.a = 1; A val1 = get(); - c.v.a = 2; A val2 = get(); + c.v.a = 2; A val2 = get(); assertEquals(val1.a, 2); assertEquals(val2.a, 2); @@ -486,7 +486,7 @@ public class TestStableLong { { c.v = new A(); c.v.a = 1; long val1 = get1(); - c.v.a = 2; long val2 = get1(); + c.v.a = 2; long val2 = get1(); c.v = new A(); c.v.a = 3; long val3 = get1(); assertEquals(val1, 1); @@ -512,8 +512,8 @@ public class TestStableLong { public static void test() throws Exception { { c.v = new A(); c.v.next = new A(); c.v.next.next = c.v; - c.v.a = 1; c.v.next.a = 1; A val1 = get(); - c.v.a = 2; c.v.next.a = 2; A val2 = get(); + c.v.a = 1; c.v.next.a = 1; A val1 = get(); + c.v.a = 2; c.v.next.a = 2; A val2 = get(); assertEquals(val1.a, 2); assertEquals(val2.a, 2); @@ -521,10 +521,10 @@ public class TestStableLong { { c.v = new A(); c.v.next = c.v; - c.v.a = 1; long val1 = get1(); - c.v.a = 2; long val2 = get1(); + c.v.a = 1; long val1 = get1(); + c.v.a = 2; long val2 = get1(); c.v = new A(); c.v.next = c.v; - c.v.a = 3; long val3 = get1(); + c.v.a = 3; long val3 = get1(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); @@ -550,8 +550,8 @@ public class TestStableLong { public static void test() throws Exception { { c.v = new A(); c.v.left = c.v.right = c.v; - c.v.a = 1; long val1 = get(); long val2 = get1(); - c.v.a = 2; long val3 = get(); long val4 = get1(); + c.v.a = 1; long val1 = get(); long val2 = get1(); + c.v.a = 2; long val3 = get(); long val4 = get1(); assertEquals(val1, 1); assertEquals(val3, (isStableEnabled ? 1 : 2)); @@ -581,8 +581,8 @@ public class TestStableLong { { A elem = new A(); c.v = new A[] { elem, elem }; c.v[0].left = c.v[0].right = c.v; - elem.a = 1; long val1 = get(); long val2 = get1(); - elem.a = 2; long val3 = get(); long val4 = get1(); + elem.a = 1; long val1 = get(); long val2 = get1(); + elem.a = 2; long val3 = get(); long val4 = get1(); assertEquals(val1, 1); assertEquals(val3, (isStableEnabled ? 1 : 2)); diff --git a/hotspot/test/compiler/stable/TestStableObject.java b/hotspot/test/compiler/stable/TestStableObject.java index cc0f89b4e06..1ad6b681a08 100644 --- a/hotspot/test/compiler/stable/TestStableObject.java +++ b/hotspot/test/compiler/stable/TestStableObject.java @@ -102,7 +102,7 @@ public class TestStableObject { public static final DefaultValue c = new DefaultValue(); public static Object get() { return c.v; } public static void test() throws Exception { - Object val1 = get(); + Object val1 = get(); c.v = Values.A; Object val2 = get(); assertEquals(val1, null); assertEquals(val2, Values.A); @@ -132,7 +132,7 @@ public class TestStableObject { public static final DefaultStaticValue c = new DefaultStaticValue(); public static Object get() { return c.v; } public static void test() throws Exception { - Object val1 = get(); + Object val1 = get(); c.v = Values.A; Object val2 = get(); assertEquals(val1, null); assertEquals(val2, Values.A); @@ -182,24 +182,24 @@ public class TestStableObject { public static void test() throws Exception { { c.v = new Object[1]; c.v[0] = Values.A; Object val1 = get(); - c.v[0] = Values.B; Object val2 = get(); + c.v[0] = Values.B; Object val2 = get(); assertEquals(val1, Values.A); assertEquals(val2, (isStableEnabled ? Values.A : Values.B)); c.v = new Object[1]; c.v[0] = Values.C; Object val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? Values.A : Values.B) - : Values.C)); + : Values.C)); } { c.v = new Object[20]; c.v[10] = Values.A; Object val1 = get1(); - c.v[10] = Values.B; Object val2 = get1(); + c.v[10] = Values.B; Object val2 = get1(); assertEquals(val1, Values.A); assertEquals(val2, (isStableEnabled ? Values.A : Values.B)); c.v = new Object[20]; c.v[10] = Values.C; Object val3 = get1(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? Values.A : Values.B) - : Values.C)); + : Values.C)); } { @@ -222,17 +222,17 @@ public class TestStableObject { public static void test() throws Exception { { c.v = new Object[1][1]; c.v[0][0] = Values.A; Object val1 = get(); - c.v[0][0] = Values.B; Object val2 = get(); + c.v[0][0] = Values.B; Object val2 = get(); assertEquals(val1, Values.A); assertEquals(val2, (isStableEnabled ? Values.A : Values.B)); c.v = new Object[1][1]; c.v[0][0] = Values.C; Object val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? Values.A : Values.B) - : Values.C)); + : Values.C)); c.v[0] = new Object[1]; c.v[0][0] = Values.D; Object val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? Values.A : Values.B) - : Values.D)); + : Values.D)); } { @@ -262,21 +262,21 @@ public class TestStableObject { public static void test() throws Exception { { c.v = new Object[1][1][1]; c.v[0][0][0] = Values.A; Object val1 = get(); - c.v[0][0][0] = Values.B; Object val2 = get(); + c.v[0][0][0] = Values.B; Object val2 = get(); assertEquals(val1, Values.A); assertEquals(val2, (isStableEnabled ? Values.A : Values.B)); c.v = new Object[1][1][1]; c.v[0][0][0] = Values.C; Object val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? Values.A : Values.B) - : Values.C)); + : Values.C)); c.v[0] = new Object[1][1]; c.v[0][0][0] = Values.D; Object val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? Values.A : Values.B) - : Values.D)); + : Values.D)); c.v[0][0] = new Object[1]; c.v[0][0][0] = Values.E; Object val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? Values.A : Values.B) - : Values.E)); + : Values.E)); } { @@ -313,25 +313,25 @@ public class TestStableObject { public static void test() throws Exception { { c.v = new Object[1][1][1][1]; c.v[0][0][0][0] = Values.A; Object val1 = get(); - c.v[0][0][0][0] = Values.B; Object val2 = get(); + c.v[0][0][0][0] = Values.B; Object val2 = get(); assertEquals(val1, Values.A); assertEquals(val2, (isStableEnabled ? Values.A : Values.B)); c.v = new Object[1][1][1][1]; c.v[0][0][0][0] = Values.C; Object val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? Values.A : Values.B) - : Values.C)); + : Values.C)); c.v[0] = new Object[1][1][1]; c.v[0][0][0][0] = Values.D; Object val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? Values.A : Values.B) - : Values.D)); + : Values.D)); c.v[0][0] = new Object[1][1]; c.v[0][0][0][0] = Values.E; Object val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? Values.A : Values.B) - : Values.E)); + : Values.E)); c.v[0][0][0] = new Object[1]; c.v[0][0][0][0] = Values.F; Object val6 = get(); assertEquals(val6, (isStableEnabled ? (isStableEnabled ? Values.A : Values.B) - : Values.F)); + : Values.F)); } { @@ -372,7 +372,7 @@ public class TestStableObject { public static void test() throws Exception { { c.v = new Object[1]; ((Object[])c.v)[0] = Values.A; Object val1 = get(); - ((Object[])c.v)[0] = Values.B; Object val2 = get(); + ((Object[])c.v)[0] = Values.B; Object val2 = get(); assertEquals(val1, Values.A); assertEquals(val2, Values.B); @@ -399,7 +399,7 @@ public class TestStableObject { public static void test() throws Exception { { c.v = new Object[1][1]; ((Object[][])c.v)[0][0] = Values.A; Object val1 = get(); - ((Object[][])c.v)[0][0] = Values.B; Object val2 = get(); + ((Object[][])c.v)[0][0] = Values.B; Object val2 = get(); assertEquals(val1, Values.A); assertEquals(val2, Values.B); @@ -407,7 +407,7 @@ public class TestStableObject { { c.v = new Object[1][1]; c.v[0] = new Object[0]; Object[] val1 = get1(); - c.v[0] = new Object[0]; Object[] val2 = get1(); + c.v[0] = new Object[0]; Object[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -435,7 +435,7 @@ public class TestStableObject { public static void test() throws Exception { { c.v = new Object[1][1][1]; ((Object[][][])c.v)[0][0][0] = Values.A; Object val1 = get(); - ((Object[][][])c.v)[0][0][0] = Values.B; Object val2 = get(); + ((Object[][][])c.v)[0][0][0] = Values.B; Object val2 = get(); assertEquals(val1, Values.A); assertEquals(val2, Values.B); @@ -443,14 +443,14 @@ public class TestStableObject { { c.v = new Object[1][1][1]; c.v[0][0] = new Object[0]; Object[] val1 = get1(); - c.v[0][0] = new Object[0]; Object[] val2 = get1(); + c.v[0][0] = new Object[0]; Object[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } { c.v = new Object[1][1][1]; c.v[0] = new Object[0][0]; Object[][] val1 = get2(); - c.v[0] = new Object[0][0]; Object[][] val2 = get2(); + c.v[0] = new Object[0][0]; Object[][] val2 = get2(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -480,7 +480,7 @@ public class TestStableObject { public static void test() throws Exception { { c.v = new A(); c.v.a = Values.A; A val1 = get(); - c.v.a = Values.B; A val2 = get(); + c.v.a = Values.B; A val2 = get(); assertEquals(val1.a, Values.B); assertEquals(val2.a, Values.B); @@ -488,7 +488,7 @@ public class TestStableObject { { c.v = new A(); c.v.a = Values.A; Object val1 = get1(); - c.v.a = Values.B; Object val2 = get1(); + c.v.a = Values.B; Object val2 = get1(); c.v = new A(); c.v.a = Values.C; Object val3 = get1(); assertEquals(val1, Values.A); @@ -514,8 +514,8 @@ public class TestStableObject { public static void test() throws Exception { { c.v = new A(); c.v.next = new A(); c.v.next.next = c.v; - c.v.a = Values.A; c.v.next.a = Values.A; A val1 = get(); - c.v.a = Values.B; c.v.next.a = Values.B; A val2 = get(); + c.v.a = Values.A; c.v.next.a = Values.A; A val1 = get(); + c.v.a = Values.B; c.v.next.a = Values.B; A val2 = get(); assertEquals(val1.a, Values.B); assertEquals(val2.a, Values.B); @@ -523,10 +523,10 @@ public class TestStableObject { { c.v = new A(); c.v.next = c.v; - c.v.a = Values.A; Object val1 = get1(); - c.v.a = Values.B; Object val2 = get1(); + c.v.a = Values.A; Object val1 = get1(); + c.v.a = Values.B; Object val2 = get1(); c.v = new A(); c.v.next = c.v; - c.v.a = Values.C; Object val3 = get1(); + c.v.a = Values.C; Object val3 = get1(); assertEquals(val1, Values.A); assertEquals(val2, (isStableEnabled ? Values.A : Values.B)); @@ -552,8 +552,8 @@ public class TestStableObject { public static void test() throws Exception { { c.v = new A(); c.v.left = c.v.right = c.v; - c.v.a = Values.A; Object val1 = get(); Object val2 = get1(); - c.v.a = Values.B; Object val3 = get(); Object val4 = get1(); + c.v.a = Values.A; Object val1 = get(); Object val2 = get1(); + c.v.a = Values.B; Object val3 = get(); Object val4 = get1(); assertEquals(val1, Values.A); assertEquals(val3, (isStableEnabled ? Values.A : Values.B)); @@ -583,8 +583,8 @@ public class TestStableObject { { A elem = new A(); c.v = new A[] { elem, elem }; c.v[0].left = c.v[0].right = c.v; - elem.a = Values.A; Object val1 = get(); Object val2 = get1(); - elem.a = Values.B; Object val3 = get(); Object val4 = get1(); + elem.a = Values.A; Object val1 = get(); Object val2 = get1(); + elem.a = Values.B; Object val3 = get(); Object val4 = get1(); assertEquals(val1, Values.A); assertEquals(val3, (isStableEnabled ? Values.A : Values.B)); diff --git a/hotspot/test/compiler/stable/TestStableShort.java b/hotspot/test/compiler/stable/TestStableShort.java index 15c71b4c0c8..acd8182f167 100644 --- a/hotspot/test/compiler/stable/TestStableShort.java +++ b/hotspot/test/compiler/stable/TestStableShort.java @@ -100,7 +100,7 @@ public class TestStableShort { public static final DefaultValue c = new DefaultValue(); public static short get() { return c.v; } public static void test() throws Exception { - short val1 = get(); + short val1 = get(); c.v = 1; short val2 = get(); assertEquals(val1, 0); assertEquals(val2, 1); @@ -130,7 +130,7 @@ public class TestStableShort { public static final DefaultStaticValue c = new DefaultStaticValue(); public static short get() { return c.v; } public static void test() throws Exception { - short val1 = get(); + short val1 = get(); c.v = 1; short val2 = get(); assertEquals(val1, 0); assertEquals(val2, 1); @@ -180,24 +180,24 @@ public class TestStableShort { public static void test() throws Exception { { c.v = new short[1]; c.v[0] = 1; short val1 = get(); - c.v[0] = 2; short val2 = get(); + c.v[0] = 2; short val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new short[1]; c.v[0] = 3; short val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); } { c.v = new short[20]; c.v[10] = 1; short val1 = get1(); - c.v[10] = 2; short val2 = get1(); + c.v[10] = 2; short val2 = get1(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new short[20]; c.v[10] = 3; short val3 = get1(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); } { @@ -220,17 +220,17 @@ public class TestStableShort { public static void test() throws Exception { { c.v = new short[1][1]; c.v[0][0] = 1; short val1 = get(); - c.v[0][0] = 2; short val2 = get(); + c.v[0][0] = 2; short val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new short[1][1]; c.v[0][0] = 3; short val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); c.v[0] = new short[1]; c.v[0][0] = 4; short val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 4)); + : 4)); } { @@ -260,21 +260,21 @@ public class TestStableShort { public static void test() throws Exception { { c.v = new short[1][1][1]; c.v[0][0][0] = 1; short val1 = get(); - c.v[0][0][0] = 2; short val2 = get(); + c.v[0][0][0] = 2; short val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new short[1][1][1]; c.v[0][0][0] = 3; short val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); c.v[0] = new short[1][1]; c.v[0][0][0] = 4; short val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 4)); + : 4)); c.v[0][0] = new short[1]; c.v[0][0][0] = 5; short val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 5)); + : 5)); } { @@ -311,25 +311,25 @@ public class TestStableShort { public static void test() throws Exception { { c.v = new short[1][1][1][1]; c.v[0][0][0][0] = 1; short val1 = get(); - c.v[0][0][0][0] = 2; short val2 = get(); + c.v[0][0][0][0] = 2; short val2 = get(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); c.v = new short[1][1][1][1]; c.v[0][0][0][0] = 3; short val3 = get(); assertEquals(val3, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 3)); + : 3)); c.v[0] = new short[1][1][1]; c.v[0][0][0][0] = 4; short val4 = get(); assertEquals(val4, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 4)); + : 4)); c.v[0][0] = new short[1][1]; c.v[0][0][0][0] = 5; short val5 = get(); assertEquals(val5, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 5)); + : 5)); c.v[0][0][0] = new short[1]; c.v[0][0][0][0] = 6; short val6 = get(); assertEquals(val6, (isStableEnabled ? (isStableEnabled ? 1 : 2) - : 6)); + : 6)); } { @@ -370,7 +370,7 @@ public class TestStableShort { public static void test() throws Exception { { c.v = new short[1]; ((short[])c.v)[0] = 1; short val1 = get(); - ((short[])c.v)[0] = 2; short val2 = get(); + ((short[])c.v)[0] = 2; short val2 = get(); assertEquals(val1, 1); assertEquals(val2, 2); @@ -397,7 +397,7 @@ public class TestStableShort { public static void test() throws Exception { { c.v = new short[1][1]; ((short[][])c.v)[0][0] = 1; short val1 = get(); - ((short[][])c.v)[0][0] = 2; short val2 = get(); + ((short[][])c.v)[0][0] = 2; short val2 = get(); assertEquals(val1, 1); assertEquals(val2, 2); @@ -405,7 +405,7 @@ public class TestStableShort { { c.v = new short[1][1]; c.v[0] = new short[0]; short[] val1 = get1(); - c.v[0] = new short[0]; short[] val2 = get1(); + c.v[0] = new short[0]; short[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -433,7 +433,7 @@ public class TestStableShort { public static void test() throws Exception { { c.v = new short[1][1][1]; ((short[][][])c.v)[0][0][0] = 1; short val1 = get(); - ((short[][][])c.v)[0][0][0] = 2; short val2 = get(); + ((short[][][])c.v)[0][0][0] = 2; short val2 = get(); assertEquals(val1, 1); assertEquals(val2, 2); @@ -441,14 +441,14 @@ public class TestStableShort { { c.v = new short[1][1][1]; c.v[0][0] = new short[0]; short[] val1 = get1(); - c.v[0][0] = new short[0]; short[] val2 = get1(); + c.v[0][0] = new short[0]; short[] val2 = get1(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } { c.v = new short[1][1][1]; c.v[0] = new short[0][0]; short[][] val1 = get2(); - c.v[0] = new short[0][0]; short[][] val2 = get2(); + c.v[0] = new short[0][0]; short[][] val2 = get2(); assertTrue((isStableEnabled ? (val1 == val2) : (val1 != val2))); } @@ -478,7 +478,7 @@ public class TestStableShort { public static void test() throws Exception { { c.v = new A(); c.v.a = 1; A val1 = get(); - c.v.a = 2; A val2 = get(); + c.v.a = 2; A val2 = get(); assertEquals(val1.a, 2); assertEquals(val2.a, 2); @@ -486,7 +486,7 @@ public class TestStableShort { { c.v = new A(); c.v.a = 1; short val1 = get1(); - c.v.a = 2; short val2 = get1(); + c.v.a = 2; short val2 = get1(); c.v = new A(); c.v.a = 3; short val3 = get1(); assertEquals(val1, 1); @@ -512,8 +512,8 @@ public class TestStableShort { public static void test() throws Exception { { c.v = new A(); c.v.next = new A(); c.v.next.next = c.v; - c.v.a = 1; c.v.next.a = 1; A val1 = get(); - c.v.a = 2; c.v.next.a = 2; A val2 = get(); + c.v.a = 1; c.v.next.a = 1; A val1 = get(); + c.v.a = 2; c.v.next.a = 2; A val2 = get(); assertEquals(val1.a, 2); assertEquals(val2.a, 2); @@ -521,10 +521,10 @@ public class TestStableShort { { c.v = new A(); c.v.next = c.v; - c.v.a = 1; short val1 = get1(); - c.v.a = 2; short val2 = get1(); + c.v.a = 1; short val1 = get1(); + c.v.a = 2; short val2 = get1(); c.v = new A(); c.v.next = c.v; - c.v.a = 3; short val3 = get1(); + c.v.a = 3; short val3 = get1(); assertEquals(val1, 1); assertEquals(val2, (isStableEnabled ? 1 : 2)); @@ -550,8 +550,8 @@ public class TestStableShort { public static void test() throws Exception { { c.v = new A(); c.v.left = c.v.right = c.v; - c.v.a = 1; short val1 = get(); short val2 = get1(); - c.v.a = 2; short val3 = get(); short val4 = get1(); + c.v.a = 1; short val1 = get(); short val2 = get1(); + c.v.a = 2; short val3 = get(); short val4 = get1(); assertEquals(val1, 1); assertEquals(val3, (isStableEnabled ? 1 : 2)); @@ -581,8 +581,8 @@ public class TestStableShort { { A elem = new A(); c.v = new A[] { elem, elem }; c.v[0].left = c.v[0].right = c.v; - elem.a = 1; short val1 = get(); short val2 = get1(); - elem.a = 2; short val3 = get(); short val4 = get1(); + elem.a = 1; short val1 = get(); short val2 = get1(); + elem.a = 2; short val3 = get(); short val4 = get1(); assertEquals(val1, 1); assertEquals(val3, (isStableEnabled ? 1 : 2)); diff --git a/hotspot/test/compiler/stringopts/TestStringObjectInitialization.java b/hotspot/test/compiler/stringopts/TestStringObjectInitialization.java new file mode 100644 index 00000000000..2d09be12714 --- /dev/null +++ b/hotspot/test/compiler/stringopts/TestStringObjectInitialization.java @@ -0,0 +1,78 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + + +import java.util.Arrays; + +/* + * @test + * @bug 8159244 + * @requires vm.gc == "Parallel" | vm.gc == "null" + * @summary Verifies that no partially initialized String object escapes from + * C2's String concat optimization in a highly concurrent setting. + * This test triggers the bug in about 1 out of 10 runs. + * @compile -XDstringConcat=inline TestStringObjectInitialization.java + * @run main/othervm/timeout=300 -XX:+IgnoreUnrecognizedVMOptions -XX:-UseCompressedOops -XX:-CompactStrings + * -XX:-UseG1GC -XX:+UseParallelGC TestStringObjectInitialization + */ +public class TestStringObjectInitialization { + + String myString; + + public static void main(String[] args) throws Exception { + TestStringObjectInitialization t = new TestStringObjectInitialization(); + // Create some threads that concurrently update 'myString' + for (int i = 0; i < 100; ++i) { + (new Thread(new Runner(t))).start(); + } + Thread last = new Thread(new Runner(t)); + last.start(); + last.join(); + } + + private void add(String message) { + // String escapes to other threads here + myString += message; + } + + public void run(String s, String[] sArray) { + // Trigger C2's string concatenation optimization + add(s + Arrays.toString(sArray) + " const "); + } +} + +class Runner implements Runnable { + private TestStringObjectInitialization test; + + public Runner(TestStringObjectInitialization t) { + test = t; + } + + public void run(){ + String[] array = {"a", "b", "c"}; + for (int i = 0; i < 10000; ++i) { + test.run("a", array); + } + } +} + diff --git a/hotspot/test/compiler/testlibrary/intrinsics/Verifier.java b/hotspot/test/compiler/testlibrary/intrinsics/Verifier.java index 595d3819f36..87102b885d4 100644 --- a/hotspot/test/compiler/testlibrary/intrinsics/Verifier.java +++ b/hotspot/test/compiler/testlibrary/intrinsics/Verifier.java @@ -20,7 +20,8 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ -package intrinsics; + +package compiler.testlibrary.intrinsics; import java.io.BufferedReader; import java.io.FileReader; diff --git a/hotspot/test/compiler/testlibrary/rtm/AbortProvoker.java b/hotspot/test/compiler/testlibrary/rtm/AbortProvoker.java index 9b99961c217..c7ae7f48b9c 100644 --- a/hotspot/test/compiler/testlibrary/rtm/AbortProvoker.java +++ b/hotspot/test/compiler/testlibrary/rtm/AbortProvoker.java @@ -22,7 +22,7 @@ * */ -package rtm; +package compiler.testlibrary.rtm; import java.util.Objects; import java.util.concurrent.BrokenBarrierException; diff --git a/hotspot/test/compiler/testlibrary/rtm/AbortType.java b/hotspot/test/compiler/testlibrary/rtm/AbortType.java index 269fc6e7465..b37d8b83b74 100644 --- a/hotspot/test/compiler/testlibrary/rtm/AbortType.java +++ b/hotspot/test/compiler/testlibrary/rtm/AbortType.java @@ -22,7 +22,7 @@ * */ -package rtm; +package compiler.testlibrary.rtm; import jdk.test.lib.Asserts; diff --git a/hotspot/test/compiler/testlibrary/rtm/BufferOverflowProvoker.java b/hotspot/test/compiler/testlibrary/rtm/BufferOverflowProvoker.java index 7dac0db5c9f..568f20810d7 100644 --- a/hotspot/test/compiler/testlibrary/rtm/BufferOverflowProvoker.java +++ b/hotspot/test/compiler/testlibrary/rtm/BufferOverflowProvoker.java @@ -22,7 +22,7 @@ * */ -package rtm; +package compiler.testlibrary.rtm; /** * In order to provoke transactional execution abort due to diff --git a/hotspot/test/compiler/testlibrary/rtm/BusyLock.java b/hotspot/test/compiler/testlibrary/rtm/BusyLock.java index 879edb830d6..3cba0ae1135 100644 --- a/hotspot/test/compiler/testlibrary/rtm/BusyLock.java +++ b/hotspot/test/compiler/testlibrary/rtm/BusyLock.java @@ -22,7 +22,7 @@ * */ -package rtm; +package compiler.testlibrary.rtm; import java.util.concurrent.BrokenBarrierException; import java.util.concurrent.CyclicBarrier; diff --git a/hotspot/test/compiler/testlibrary/rtm/CompilableTest.java b/hotspot/test/compiler/testlibrary/rtm/CompilableTest.java index 840e9568138..1b97c2eb795 100644 --- a/hotspot/test/compiler/testlibrary/rtm/CompilableTest.java +++ b/hotspot/test/compiler/testlibrary/rtm/CompilableTest.java @@ -22,7 +22,7 @@ * */ -package rtm; +package compiler.testlibrary.rtm; /** * Interface for test scenarios that contain methods diff --git a/hotspot/test/compiler/testlibrary/rtm/MemoryConflictProvoker.java b/hotspot/test/compiler/testlibrary/rtm/MemoryConflictProvoker.java index 670e97511e8..5fafe8f8c9d 100644 --- a/hotspot/test/compiler/testlibrary/rtm/MemoryConflictProvoker.java +++ b/hotspot/test/compiler/testlibrary/rtm/MemoryConflictProvoker.java @@ -22,7 +22,7 @@ * */ -package rtm; +package compiler.testlibrary.rtm; import java.util.concurrent.BrokenBarrierException; import java.util.concurrent.CyclicBarrier; diff --git a/hotspot/test/compiler/testlibrary/rtm/NestedAbortProvoker.java b/hotspot/test/compiler/testlibrary/rtm/NestedAbortProvoker.java index 8fae9e48959..9fb6e8da61b 100644 --- a/hotspot/test/compiler/testlibrary/rtm/NestedAbortProvoker.java +++ b/hotspot/test/compiler/testlibrary/rtm/NestedAbortProvoker.java @@ -22,7 +22,7 @@ * */ -package rtm; +package compiler.testlibrary.rtm; import java.util.Arrays; diff --git a/hotspot/test/compiler/testlibrary/rtm/RTMLockingStatistics.java b/hotspot/test/compiler/testlibrary/rtm/RTMLockingStatistics.java index 4c354bf5a49..bf8598da1ed 100644 --- a/hotspot/test/compiler/testlibrary/rtm/RTMLockingStatistics.java +++ b/hotspot/test/compiler/testlibrary/rtm/RTMLockingStatistics.java @@ -22,7 +22,7 @@ * */ -package rtm; +package compiler.testlibrary.rtm; import java.util.EnumMap; import java.util.LinkedList; diff --git a/hotspot/test/compiler/testlibrary/rtm/RTMTestBase.java b/hotspot/test/compiler/testlibrary/rtm/RTMTestBase.java index 9f9d8f4ba76..f608d00c163 100644 --- a/hotspot/test/compiler/testlibrary/rtm/RTMTestBase.java +++ b/hotspot/test/compiler/testlibrary/rtm/RTMTestBase.java @@ -22,7 +22,7 @@ * */ -package rtm; +package compiler.testlibrary.rtm; import java.io.IOException; import java.nio.file.Files; diff --git a/hotspot/test/compiler/testlibrary/rtm/XAbortProvoker.java b/hotspot/test/compiler/testlibrary/rtm/XAbortProvoker.java index 39916c516d8..6bab4cd6d36 100644 --- a/hotspot/test/compiler/testlibrary/rtm/XAbortProvoker.java +++ b/hotspot/test/compiler/testlibrary/rtm/XAbortProvoker.java @@ -22,7 +22,7 @@ * */ -package rtm; +package compiler.testlibrary.rtm; import jdk.test.lib.Utils; import jdk.internal.misc.Unsafe; diff --git a/hotspot/test/compiler/testlibrary/rtm/predicate/SupportedCPU.java b/hotspot/test/compiler/testlibrary/rtm/predicate/SupportedCPU.java index f8c7ce17a65..8796d79f4d0 100644 --- a/hotspot/test/compiler/testlibrary/rtm/predicate/SupportedCPU.java +++ b/hotspot/test/compiler/testlibrary/rtm/predicate/SupportedCPU.java @@ -22,7 +22,7 @@ * */ -package rtm.predicate; +package compiler.testlibrary.rtm.predicate; import sun.hotspot.cpuinfo.CPUInfo; diff --git a/hotspot/test/compiler/testlibrary/rtm/predicate/SupportedVM.java b/hotspot/test/compiler/testlibrary/rtm/predicate/SupportedVM.java index c8e88f1d9da..352b4e9f9c2 100644 --- a/hotspot/test/compiler/testlibrary/rtm/predicate/SupportedVM.java +++ b/hotspot/test/compiler/testlibrary/rtm/predicate/SupportedVM.java @@ -22,7 +22,7 @@ * */ -package rtm.predicate; +package compiler.testlibrary.rtm.predicate; import jdk.test.lib.Platform; diff --git a/hotspot/test/compiler/testlibrary/sha/predicate/IntrinsicPredicates.java b/hotspot/test/compiler/testlibrary/sha/predicate/IntrinsicPredicates.java index 8d33ad65e45..b9d959ec57a 100644 --- a/hotspot/test/compiler/testlibrary/sha/predicate/IntrinsicPredicates.java +++ b/hotspot/test/compiler/testlibrary/sha/predicate/IntrinsicPredicates.java @@ -21,7 +21,7 @@ * questions. */ -package sha.predicate; +package compiler.testlibrary.sha.predicate; import jdk.test.lib.Platform; import jdk.test.lib.cli.predicate.AndPredicate; diff --git a/hotspot/test/compiler/testlibrary/uncommontrap/Verifier.java b/hotspot/test/compiler/testlibrary/uncommontrap/Verifier.java index f9df6759ed1..c22db58e2a4 100644 --- a/hotspot/test/compiler/testlibrary/uncommontrap/Verifier.java +++ b/hotspot/test/compiler/testlibrary/uncommontrap/Verifier.java @@ -21,7 +21,7 @@ * questions. */ -package uncommontrap; +package compiler.testlibrary.uncommontrap; import java.io.FileReader; import java.io.IOException; @@ -34,6 +34,7 @@ import java.util.Properties; import java.util.regex.Pattern; import jdk.test.lib.Asserts; + /** * Utility tool aimed to verify presence or absence of specified uncommon trap * in compilation log. @@ -78,7 +79,9 @@ public class Verifier { PROPERTIES_FILE_SUFFIX); Properties properties = new Properties(); - properties.load(new FileReader(propertiesFile.toFile())); + try (FileReader reader = new FileReader(propertiesFile.toFile())) { + properties.load(reader); + } if (Boolean.valueOf(properties.getProperty( VERIFICATION_SHOULD_BE_SKIPPED, "false"))) { diff --git a/hotspot/test/compiler/tiered/ConstantGettersTransitionsTest.java b/hotspot/test/compiler/tiered/ConstantGettersTransitionsTest.java index d0cbbad9cf9..4c6e972e0c2 100644 --- a/hotspot/test/compiler/tiered/ConstantGettersTransitionsTest.java +++ b/hotspot/test/compiler/tiered/ConstantGettersTransitionsTest.java @@ -21,13 +21,9 @@ * questions. */ -import java.lang.reflect.Executable; -import java.util.concurrent.Callable; -import compiler.whitebox.CompilerWhiteBoxTest; - /** * @test ConstantGettersTransitionsTest - * @library /testlibrary /test/lib /compiler/whitebox / + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @build TransitionsTestExecutor ConstantGettersTransitionsTest @@ -38,6 +34,11 @@ import compiler.whitebox.CompilerWhiteBoxTest; * TransitionsTestExecutor ConstantGettersTransitionsTest * @summary Test the correctness of compilation level transitions for constant getters methods */ + +import java.lang.reflect.Executable; +import java.util.concurrent.Callable; +import compiler.whitebox.CompilerWhiteBoxTest; + public class ConstantGettersTransitionsTest extends LevelTransitionTest { public static void main(String[] args) { assert (!CompilerWhiteBoxTest.skipOnTieredCompilation(false)); diff --git a/hotspot/test/compiler/tiered/LevelTransitionTest.java b/hotspot/test/compiler/tiered/LevelTransitionTest.java index 62f1fc65e04..01220a2e5a2 100644 --- a/hotspot/test/compiler/tiered/LevelTransitionTest.java +++ b/hotspot/test/compiler/tiered/LevelTransitionTest.java @@ -21,21 +21,14 @@ * questions. */ -import java.lang.reflect.Executable; -import java.lang.reflect.Method; -import java.util.Objects; -import java.util.concurrent.Callable; -import compiler.whitebox.CompilerWhiteBoxTest; -import compiler.whitebox.SimpleTestCase; - /** * @test LevelTransitionTest - * @library /testlibrary /test/lib /compiler/whitebox / + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * java.management * @ignore 8067651 * @build TransitionsTestExecutor LevelTransitionTest - * @run main ClassFileInstaller sun.hotspot.WhiteBox sun.hotspot.WhiteBox$WhiteBoxPermission + * @run driver ClassFileInstaller sun.hotspot.WhiteBox sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm/timeout=240 -Xmixed -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI -XX:+TieredCompilation * -XX:CompileCommand=compileonly,compiler.whitebox.SimpleTestCaseHelper::* @@ -43,6 +36,14 @@ import compiler.whitebox.SimpleTestCase; * TransitionsTestExecutor LevelTransitionTest * @summary Test the correctness of compilation level transitions for different methods */ + +import java.lang.reflect.Executable; +import java.lang.reflect.Method; +import java.util.Objects; +import java.util.concurrent.Callable; +import compiler.whitebox.CompilerWhiteBoxTest; +import compiler.whitebox.SimpleTestCase; + public class LevelTransitionTest extends TieredLevelsTest { /** Shows if method was profiled by being executed on levels 2 or 3 */ protected boolean isMethodProfiled; diff --git a/hotspot/test/compiler/tiered/NonTieredLevelsTest.java b/hotspot/test/compiler/tiered/NonTieredLevelsTest.java index 98fad1ee0b4..96f52576b4f 100644 --- a/hotspot/test/compiler/tiered/NonTieredLevelsTest.java +++ b/hotspot/test/compiler/tiered/NonTieredLevelsTest.java @@ -21,12 +21,9 @@ * questions. */ -import java.util.function.IntPredicate; -import compiler.whitebox.CompilerWhiteBoxTest; - /** * @test NonTieredLevelsTest - * @library /testlibrary /test/lib /compiler/whitebox / + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * @modules java.management * @build NonTieredLevelsTest @@ -39,6 +36,10 @@ import compiler.whitebox.CompilerWhiteBoxTest; * @summary Verify that only one level can be used * @author igor.ignatyev@oracle.com */ + +import java.util.function.IntPredicate; +import compiler.whitebox.CompilerWhiteBoxTest; + public class NonTieredLevelsTest extends CompLevelsTest { private static final int AVAILABLE_COMP_LEVEL; private static final IntPredicate IS_AVAILABLE_COMPLEVEL; diff --git a/hotspot/test/compiler/tiered/TieredLevelsTest.java b/hotspot/test/compiler/tiered/TieredLevelsTest.java index bf1812128fc..2f36bd54713 100644 --- a/hotspot/test/compiler/tiered/TieredLevelsTest.java +++ b/hotspot/test/compiler/tiered/TieredLevelsTest.java @@ -21,16 +21,14 @@ * questions. */ -import compiler.whitebox.CompilerWhiteBoxTest; - /** * @test TieredLevelsTest - * @library /testlibrary /test/lib /compiler/whitebox / + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * @modules java.management * @build TieredLevelsTest * @run driver ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbootclasspath/a:. -XX:+TieredCompilation * -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -XX:-UseCounterDecay * -XX:CompileCommand=compileonly,compiler.whitebox.SimpleTestCaseHelper::* @@ -38,6 +36,9 @@ import compiler.whitebox.CompilerWhiteBoxTest; * @summary Verify that all levels < 'TieredStopAtLevel' can be used * @author igor.ignatyev@oracle.com */ + +import compiler.whitebox.CompilerWhiteBoxTest; + public class TieredLevelsTest extends CompLevelsTest { public static void main(String[] args) throws Exception, Throwable { if (CompilerWhiteBoxTest.skipOnTieredCompilation(false)) { diff --git a/hotspot/test/compiler/uncommontrap/8009761/Test8009761.java b/hotspot/test/compiler/uncommontrap/8009761/Test8009761.java index 7295581bf2a..91b58c651bb 100644 --- a/hotspot/test/compiler/uncommontrap/8009761/Test8009761.java +++ b/hotspot/test/compiler/uncommontrap/8009761/Test8009761.java @@ -33,7 +33,7 @@ import java.lang.reflect.Method; * @build Test8009761 * @run main ClassFileInstaller sun.hotspot.WhiteBox * sun.hotspot.WhiteBox$WhiteBoxPermission - * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -XX:CompileCommand=exclude,Test8009761::m2 -XX:-UseOnStackReplacement -XX:-BackgroundCompilation -Xss392K Test8009761 + * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -XX:CompileCommand=exclude,Test8009761::m2 -XX:-UseOnStackReplacement -XX:-BackgroundCompilation -Xss512K Test8009761 */ public class Test8009761 { diff --git a/hotspot/test/compiler/uncommontrap/StackOverflowGuardPagesOff.java b/hotspot/test/compiler/uncommontrap/StackOverflowGuardPagesOff.java index ba3b8795537..835283c0bd3 100644 --- a/hotspot/test/compiler/uncommontrap/StackOverflowGuardPagesOff.java +++ b/hotspot/test/compiler/uncommontrap/StackOverflowGuardPagesOff.java @@ -25,7 +25,7 @@ * @test * @bug 8029383 * @summary stack overflow if callee is marked for deoptimization causes crash - * @run main/othervm -XX:TieredStopAtLevel=1 -XX:-BackgroundCompilation -XX:CompileCommand=dontinline,StackOverflowGuardPagesOff::m1 -XX:CompileCommand=exclude,StackOverflowGuardPagesOff::m2 -Xss392K -XX:-UseOnStackReplacement StackOverflowGuardPagesOff + * @run main/othervm -XX:TieredStopAtLevel=1 -XX:-BackgroundCompilation -XX:CompileCommand=dontinline,StackOverflowGuardPagesOff::m1 -XX:CompileCommand=exclude,StackOverflowGuardPagesOff::m2 -Xss512K -XX:-UseOnStackReplacement StackOverflowGuardPagesOff * */ diff --git a/hotspot/test/compiler/uncommontrap/TestStackBangMonitorOwned.java b/hotspot/test/compiler/uncommontrap/TestStackBangMonitorOwned.java index 83345642f74..c07a995dd87 100644 --- a/hotspot/test/compiler/uncommontrap/TestStackBangMonitorOwned.java +++ b/hotspot/test/compiler/uncommontrap/TestStackBangMonitorOwned.java @@ -25,7 +25,7 @@ * @test * @bug 8032410 * @summary Stack overflow at deoptimization doesn't release owned monitors - * @run main/othervm -XX:-BackgroundCompilation -XX:CompileCommand=dontinline,TestStackBangMonitorOwned::m1 -XX:CompileCommand=exclude,TestStackBangMonitorOwned::m2 -Xss392K -XX:-UseOnStackReplacement TestStackBangMonitorOwned + * @run main/othervm -XX:-BackgroundCompilation -XX:CompileCommand=dontinline,TestStackBangMonitorOwned::m1 -XX:CompileCommand=exclude,TestStackBangMonitorOwned::m2 -Xss512K -XX:-UseOnStackReplacement TestStackBangMonitorOwned * */ public class TestStackBangMonitorOwned { diff --git a/hotspot/test/compiler/uncommontrap/TestStackBangRbp.java b/hotspot/test/compiler/uncommontrap/TestStackBangRbp.java index f242e6edd6b..9b96951a2a6 100644 --- a/hotspot/test/compiler/uncommontrap/TestStackBangRbp.java +++ b/hotspot/test/compiler/uncommontrap/TestStackBangRbp.java @@ -25,7 +25,7 @@ * @test * @bug 8028308 * @summary rbp not restored when stack overflow is thrown from deopt/uncommon trap blobs - * @run main/othervm -XX:-BackgroundCompilation -XX:CompileCommand=dontinline,TestStackBangRbp::m1 -XX:CompileCommand=exclude,TestStackBangRbp::m2 -Xss392K -XX:-UseOnStackReplacement TestStackBangRbp + * @run main/othervm -XX:-BackgroundCompilation -XX:CompileCommand=dontinline,TestStackBangRbp::m1 -XX:CompileCommand=exclude,TestStackBangRbp::m2 -Xss512K -XX:-UseOnStackReplacement TestStackBangRbp * */ public class TestStackBangRbp { diff --git a/hotspot/test/compiler/uncommontrap/TestUnstableIfTrap.java b/hotspot/test/compiler/uncommontrap/TestUnstableIfTrap.java index aaf4d33f91a..3de7157aab5 100644 --- a/hotspot/test/compiler/uncommontrap/TestUnstableIfTrap.java +++ b/hotspot/test/compiler/uncommontrap/TestUnstableIfTrap.java @@ -20,35 +20,19 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ -import java.io.File; -import java.io.FileWriter; -import java.io.IOException; -import java.lang.reflect.Method; -import java.util.Properties; - -import jdk.test.lib.ByteCodeLoader; -import jdk.test.lib.Platform; -import jdk.internal.org.objectweb.asm.ClassVisitor; -import jdk.internal.org.objectweb.asm.ClassWriter; -import jdk.internal.org.objectweb.asm.Label; -import jdk.internal.org.objectweb.asm.MethodVisitor; -import static jdk.internal.org.objectweb.asm.Opcodes.*; - -import sun.hotspot.WhiteBox; -import uncommontrap.Verifier; /* * @test * @bug 8030976 8059226 - * @library /testlibrary /compiler/testlibrary /test/lib + * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.org.objectweb.asm * java.base/jdk.internal.misc * java.compiler * java.management * jdk.jvmstat/sun.jvmstat.monitor - * @build TestUnstableIfTrap jdk.test.lib.* uncommontrap.Verifier - * @run main ClassFileInstaller sun.hotspot.WhiteBox - * sun.hotspot.WhiteBox$WhiteBoxPermission + * @build TestUnstableIfTrap jdk.test.lib.* compiler.testlibrary.uncommontrap.Verifier + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission * @run main/othervm -Xbatch -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI -XX:+LogCompilation * -XX:CompileCommand=compileonly,UnstableIfExecutable.test @@ -69,11 +53,29 @@ import uncommontrap.Verifier; * -XX:CompileCommand=compileonly,UnstableIfExecutable.test * -XX:LogFile=never_taken_fired.xml * TestUnstableIfTrap NEVER_TAKEN true - * @run main/othervm uncommontrap.Verifier always_taken_not_fired.xml - * always_taken_fired.xml - * never_taken_not_fired.xml - * never_taken_fired.xml + * @run driver compiler.testlibrary.uncommontrap.Verifier always_taken_not_fired.xml + * always_taken_fired.xml + * never_taken_not_fired.xml + * never_taken_fired.xml */ + +import java.io.File; +import java.io.FileWriter; +import java.io.IOException; +import java.lang.reflect.Method; +import java.util.Properties; + +import jdk.test.lib.ByteCodeLoader; +import jdk.test.lib.Platform; +import jdk.internal.org.objectweb.asm.ClassVisitor; +import jdk.internal.org.objectweb.asm.ClassWriter; +import jdk.internal.org.objectweb.asm.Label; +import jdk.internal.org.objectweb.asm.MethodVisitor; +import static jdk.internal.org.objectweb.asm.Opcodes.*; + +import sun.hotspot.WhiteBox; +import compiler.testlibrary.uncommontrap.Verifier; + public class TestUnstableIfTrap { private static final WhiteBox WB = WhiteBox.getWhiteBox(); private static final String CLASS_NAME = "UnstableIfExecutable"; diff --git a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestBoolean.java b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestBoolean.java index 96c1a82b971..816977dfb53 100644 --- a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestBoolean.java +++ b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestBoolean.java @@ -144,6 +144,115 @@ public class JdkInternalMiscUnsafeAccessTestBoolean { } + UNSAFE.putBoolean(base, offset, true); + + // Compare + { + boolean r = UNSAFE.compareAndSwapBoolean(base, offset, true, false); + assertEquals(r, true, "success compareAndSwap boolean"); + boolean x = UNSAFE.getBoolean(base, offset); + assertEquals(x, false, "success compareAndSwap boolean value"); + } + + { + boolean r = UNSAFE.compareAndSwapBoolean(base, offset, true, false); + assertEquals(r, false, "failing compareAndSwap boolean"); + boolean x = UNSAFE.getBoolean(base, offset); + assertEquals(x, false, "failing compareAndSwap boolean value"); + } + + // Advanced compare + { + boolean r = UNSAFE.compareAndExchangeBooleanVolatile(base, offset, false, true); + assertEquals(r, false, "success compareAndExchangeVolatile boolean"); + boolean x = UNSAFE.getBoolean(base, offset); + assertEquals(x, true, "success compareAndExchangeVolatile boolean value"); + } + + { + boolean r = UNSAFE.compareAndExchangeBooleanVolatile(base, offset, false, false); + assertEquals(r, true, "failing compareAndExchangeVolatile boolean"); + boolean x = UNSAFE.getBoolean(base, offset); + assertEquals(x, true, "failing compareAndExchangeVolatile boolean value"); + } + + { + boolean r = UNSAFE.compareAndExchangeBooleanAcquire(base, offset, true, false); + assertEquals(r, true, "success compareAndExchangeAcquire boolean"); + boolean x = UNSAFE.getBoolean(base, offset); + assertEquals(x, false, "success compareAndExchangeAcquire boolean value"); + } + + { + boolean r = UNSAFE.compareAndExchangeBooleanAcquire(base, offset, true, false); + assertEquals(r, false, "failing compareAndExchangeAcquire boolean"); + boolean x = UNSAFE.getBoolean(base, offset); + assertEquals(x, false, "failing compareAndExchangeAcquire boolean value"); + } + + { + boolean r = UNSAFE.compareAndExchangeBooleanRelease(base, offset, false, true); + assertEquals(r, false, "success compareAndExchangeRelease boolean"); + boolean x = UNSAFE.getBoolean(base, offset); + assertEquals(x, true, "success compareAndExchangeRelease boolean value"); + } + + { + boolean r = UNSAFE.compareAndExchangeBooleanRelease(base, offset, false, false); + assertEquals(r, true, "failing compareAndExchangeRelease boolean"); + boolean x = UNSAFE.getBoolean(base, offset); + assertEquals(x, true, "failing compareAndExchangeRelease boolean value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapBoolean(base, offset, true, false); + } + assertEquals(success, true, "weakCompareAndSwap boolean"); + boolean x = UNSAFE.getBoolean(base, offset); + assertEquals(x, false, "weakCompareAndSwap boolean value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapBooleanAcquire(base, offset, false, true); + } + assertEquals(success, true, "weakCompareAndSwapAcquire boolean"); + boolean x = UNSAFE.getBoolean(base, offset); + assertEquals(x, true, "weakCompareAndSwapAcquire boolean"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapBooleanRelease(base, offset, true, false); + } + assertEquals(success, true, "weakCompareAndSwapRelease boolean"); + boolean x = UNSAFE.getBoolean(base, offset); + assertEquals(x, false, "weakCompareAndSwapRelease boolean"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapBooleanVolatile(base, offset, false, true); + } + assertEquals(success, true, "weakCompareAndSwapVolatile boolean"); + boolean x = UNSAFE.getBoolean(base, offset); + assertEquals(x, true, "weakCompareAndSwapVolatile boolean"); + } + + UNSAFE.putBoolean(base, offset, false); + + // Compare set and get + { + boolean o = UNSAFE.getAndSetBoolean(base, offset, true); + assertEquals(o, false, "getAndSet boolean"); + boolean x = UNSAFE.getBoolean(base, offset); + assertEquals(x, true, "getAndSet boolean value"); + } } diff --git a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestByte.java b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestByte.java index 2b5438e7c30..9ce6f053fda 100644 --- a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestByte.java +++ b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestByte.java @@ -145,43 +145,161 @@ public class JdkInternalMiscUnsafeAccessTestByte { static void testAccess(Object base, long offset) { // Plain { - UNSAFE.putByte(base, offset, (byte)1); + UNSAFE.putByte(base, offset, (byte)0x01); byte x = UNSAFE.getByte(base, offset); - assertEquals(x, (byte)1, "set byte value"); + assertEquals(x, (byte)0x01, "set byte value"); } // Volatile { - UNSAFE.putByteVolatile(base, offset, (byte)2); + UNSAFE.putByteVolatile(base, offset, (byte)0x23); byte x = UNSAFE.getByteVolatile(base, offset); - assertEquals(x, (byte)2, "putVolatile byte value"); + assertEquals(x, (byte)0x23, "putVolatile byte value"); } // Lazy { - UNSAFE.putByteRelease(base, offset, (byte)1); + UNSAFE.putByteRelease(base, offset, (byte)0x01); byte x = UNSAFE.getByteAcquire(base, offset); - assertEquals(x, (byte)1, "putRelease byte value"); + assertEquals(x, (byte)0x01, "putRelease byte value"); } // Opaque { - UNSAFE.putByteOpaque(base, offset, (byte)2); + UNSAFE.putByteOpaque(base, offset, (byte)0x23); byte x = UNSAFE.getByteOpaque(base, offset); - assertEquals(x, (byte)2, "putOpaque byte value"); + assertEquals(x, (byte)0x23, "putOpaque byte value"); } + UNSAFE.putByte(base, offset, (byte)0x01); + // Compare + { + boolean r = UNSAFE.compareAndSwapByte(base, offset, (byte)0x01, (byte)0x23); + assertEquals(r, true, "success compareAndSwap byte"); + byte x = UNSAFE.getByte(base, offset); + assertEquals(x, (byte)0x23, "success compareAndSwap byte value"); + } + + { + boolean r = UNSAFE.compareAndSwapByte(base, offset, (byte)0x01, (byte)0x45); + assertEquals(r, false, "failing compareAndSwap byte"); + byte x = UNSAFE.getByte(base, offset); + assertEquals(x, (byte)0x23, "failing compareAndSwap byte value"); + } + + // Advanced compare + { + byte r = UNSAFE.compareAndExchangeByteVolatile(base, offset, (byte)0x23, (byte)0x01); + assertEquals(r, (byte)0x23, "success compareAndExchangeVolatile byte"); + byte x = UNSAFE.getByte(base, offset); + assertEquals(x, (byte)0x01, "success compareAndExchangeVolatile byte value"); + } + + { + byte r = UNSAFE.compareAndExchangeByteVolatile(base, offset, (byte)0x23, (byte)0x45); + assertEquals(r, (byte)0x01, "failing compareAndExchangeVolatile byte"); + byte x = UNSAFE.getByte(base, offset); + assertEquals(x, (byte)0x01, "failing compareAndExchangeVolatile byte value"); + } + + { + byte r = UNSAFE.compareAndExchangeByteAcquire(base, offset, (byte)0x01, (byte)0x23); + assertEquals(r, (byte)0x01, "success compareAndExchangeAcquire byte"); + byte x = UNSAFE.getByte(base, offset); + assertEquals(x, (byte)0x23, "success compareAndExchangeAcquire byte value"); + } + + { + byte r = UNSAFE.compareAndExchangeByteAcquire(base, offset, (byte)0x01, (byte)0x45); + assertEquals(r, (byte)0x23, "failing compareAndExchangeAcquire byte"); + byte x = UNSAFE.getByte(base, offset); + assertEquals(x, (byte)0x23, "failing compareAndExchangeAcquire byte value"); + } + + { + byte r = UNSAFE.compareAndExchangeByteRelease(base, offset, (byte)0x23, (byte)0x01); + assertEquals(r, (byte)0x23, "success compareAndExchangeRelease byte"); + byte x = UNSAFE.getByte(base, offset); + assertEquals(x, (byte)0x01, "success compareAndExchangeRelease byte value"); + } + + { + byte r = UNSAFE.compareAndExchangeByteRelease(base, offset, (byte)0x23, (byte)0x45); + assertEquals(r, (byte)0x01, "failing compareAndExchangeRelease byte"); + byte x = UNSAFE.getByte(base, offset); + assertEquals(x, (byte)0x01, "failing compareAndExchangeRelease byte value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapByte(base, offset, (byte)0x01, (byte)0x23); + } + assertEquals(success, true, "weakCompareAndSwap byte"); + byte x = UNSAFE.getByte(base, offset); + assertEquals(x, (byte)0x23, "weakCompareAndSwap byte value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapByteAcquire(base, offset, (byte)0x23, (byte)0x01); + } + assertEquals(success, true, "weakCompareAndSwapAcquire byte"); + byte x = UNSAFE.getByte(base, offset); + assertEquals(x, (byte)0x01, "weakCompareAndSwapAcquire byte"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapByteRelease(base, offset, (byte)0x01, (byte)0x23); + } + assertEquals(success, true, "weakCompareAndSwapRelease byte"); + byte x = UNSAFE.getByte(base, offset); + assertEquals(x, (byte)0x23, "weakCompareAndSwapRelease byte"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapByteVolatile(base, offset, (byte)0x23, (byte)0x01); + } + assertEquals(success, true, "weakCompareAndSwapVolatile byte"); + byte x = UNSAFE.getByte(base, offset); + assertEquals(x, (byte)0x01, "weakCompareAndSwapVolatile byte"); + } + + UNSAFE.putByte(base, offset, (byte)0x23); + + // Compare set and get + { + byte o = UNSAFE.getAndSetByte(base, offset, (byte)0x01); + assertEquals(o, (byte)0x23, "getAndSet byte"); + byte x = UNSAFE.getByte(base, offset); + assertEquals(x, (byte)0x01, "getAndSet byte value"); + } + + UNSAFE.putByte(base, offset, (byte)0x01); + + // get and add, add and get + { + byte o = UNSAFE.getAndAddByte(base, offset, (byte)0x23); + assertEquals(o, (byte)0x01, "getAndAdd byte"); + byte x = UNSAFE.getByte(base, offset); + assertEquals(x, (byte)((byte)0x01 + (byte)0x23), "getAndAdd byte"); + } } static void testAccess(long address) { // Plain { - UNSAFE.putByte(address, (byte)1); + UNSAFE.putByte(address, (byte)0x01); byte x = UNSAFE.getByte(address); - assertEquals(x, (byte)1, "set byte value"); + assertEquals(x, (byte)0x01, "set byte value"); } } } diff --git a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestChar.java b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestChar.java index 67f425826d3..df81a2fe941 100644 --- a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestChar.java +++ b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestChar.java @@ -145,61 +145,179 @@ public class JdkInternalMiscUnsafeAccessTestChar { static void testAccess(Object base, long offset) { // Plain { - UNSAFE.putChar(base, offset, 'a'); + UNSAFE.putChar(base, offset, '\u0123'); char x = UNSAFE.getChar(base, offset); - assertEquals(x, 'a', "set char value"); + assertEquals(x, '\u0123', "set char value"); } // Volatile { - UNSAFE.putCharVolatile(base, offset, 'b'); + UNSAFE.putCharVolatile(base, offset, '\u4567'); char x = UNSAFE.getCharVolatile(base, offset); - assertEquals(x, 'b', "putVolatile char value"); + assertEquals(x, '\u4567', "putVolatile char value"); } // Lazy { - UNSAFE.putCharRelease(base, offset, 'a'); + UNSAFE.putCharRelease(base, offset, '\u0123'); char x = UNSAFE.getCharAcquire(base, offset); - assertEquals(x, 'a', "putRelease char value"); + assertEquals(x, '\u0123', "putRelease char value"); } // Opaque { - UNSAFE.putCharOpaque(base, offset, 'b'); + UNSAFE.putCharOpaque(base, offset, '\u4567'); char x = UNSAFE.getCharOpaque(base, offset); - assertEquals(x, 'b', "putOpaque char value"); + assertEquals(x, '\u4567', "putOpaque char value"); } // Unaligned { - UNSAFE.putCharUnaligned(base, offset, 'b'); + UNSAFE.putCharUnaligned(base, offset, '\u4567'); char x = UNSAFE.getCharUnaligned(base, offset); - assertEquals(x, 'b', "putUnaligned char value"); + assertEquals(x, '\u4567', "putUnaligned char value"); } { - UNSAFE.putCharUnaligned(base, offset, 'a', true); + UNSAFE.putCharUnaligned(base, offset, '\u0123', true); char x = UNSAFE.getCharUnaligned(base, offset, true); - assertEquals(x, 'a', "putUnaligned big endian char value"); + assertEquals(x, '\u0123', "putUnaligned big endian char value"); } { - UNSAFE.putCharUnaligned(base, offset, 'b', false); + UNSAFE.putCharUnaligned(base, offset, '\u4567', false); char x = UNSAFE.getCharUnaligned(base, offset, false); - assertEquals(x, 'b', "putUnaligned little endian char value"); + assertEquals(x, '\u4567', "putUnaligned little endian char value"); } + UNSAFE.putChar(base, offset, '\u0123'); + // Compare + { + boolean r = UNSAFE.compareAndSwapChar(base, offset, '\u0123', '\u4567'); + assertEquals(r, true, "success compareAndSwap char"); + char x = UNSAFE.getChar(base, offset); + assertEquals(x, '\u4567', "success compareAndSwap char value"); + } + + { + boolean r = UNSAFE.compareAndSwapChar(base, offset, '\u0123', '\u89AB'); + assertEquals(r, false, "failing compareAndSwap char"); + char x = UNSAFE.getChar(base, offset); + assertEquals(x, '\u4567', "failing compareAndSwap char value"); + } + + // Advanced compare + { + char r = UNSAFE.compareAndExchangeCharVolatile(base, offset, '\u4567', '\u0123'); + assertEquals(r, '\u4567', "success compareAndExchangeVolatile char"); + char x = UNSAFE.getChar(base, offset); + assertEquals(x, '\u0123', "success compareAndExchangeVolatile char value"); + } + + { + char r = UNSAFE.compareAndExchangeCharVolatile(base, offset, '\u4567', '\u89AB'); + assertEquals(r, '\u0123', "failing compareAndExchangeVolatile char"); + char x = UNSAFE.getChar(base, offset); + assertEquals(x, '\u0123', "failing compareAndExchangeVolatile char value"); + } + + { + char r = UNSAFE.compareAndExchangeCharAcquire(base, offset, '\u0123', '\u4567'); + assertEquals(r, '\u0123', "success compareAndExchangeAcquire char"); + char x = UNSAFE.getChar(base, offset); + assertEquals(x, '\u4567', "success compareAndExchangeAcquire char value"); + } + + { + char r = UNSAFE.compareAndExchangeCharAcquire(base, offset, '\u0123', '\u89AB'); + assertEquals(r, '\u4567', "failing compareAndExchangeAcquire char"); + char x = UNSAFE.getChar(base, offset); + assertEquals(x, '\u4567', "failing compareAndExchangeAcquire char value"); + } + + { + char r = UNSAFE.compareAndExchangeCharRelease(base, offset, '\u4567', '\u0123'); + assertEquals(r, '\u4567', "success compareAndExchangeRelease char"); + char x = UNSAFE.getChar(base, offset); + assertEquals(x, '\u0123', "success compareAndExchangeRelease char value"); + } + + { + char r = UNSAFE.compareAndExchangeCharRelease(base, offset, '\u4567', '\u89AB'); + assertEquals(r, '\u0123', "failing compareAndExchangeRelease char"); + char x = UNSAFE.getChar(base, offset); + assertEquals(x, '\u0123', "failing compareAndExchangeRelease char value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapChar(base, offset, '\u0123', '\u4567'); + } + assertEquals(success, true, "weakCompareAndSwap char"); + char x = UNSAFE.getChar(base, offset); + assertEquals(x, '\u4567', "weakCompareAndSwap char value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapCharAcquire(base, offset, '\u4567', '\u0123'); + } + assertEquals(success, true, "weakCompareAndSwapAcquire char"); + char x = UNSAFE.getChar(base, offset); + assertEquals(x, '\u0123', "weakCompareAndSwapAcquire char"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapCharRelease(base, offset, '\u0123', '\u4567'); + } + assertEquals(success, true, "weakCompareAndSwapRelease char"); + char x = UNSAFE.getChar(base, offset); + assertEquals(x, '\u4567', "weakCompareAndSwapRelease char"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapCharVolatile(base, offset, '\u4567', '\u0123'); + } + assertEquals(success, true, "weakCompareAndSwapVolatile char"); + char x = UNSAFE.getChar(base, offset); + assertEquals(x, '\u0123', "weakCompareAndSwapVolatile char"); + } + + UNSAFE.putChar(base, offset, '\u4567'); + + // Compare set and get + { + char o = UNSAFE.getAndSetChar(base, offset, '\u0123'); + assertEquals(o, '\u4567', "getAndSet char"); + char x = UNSAFE.getChar(base, offset); + assertEquals(x, '\u0123', "getAndSet char value"); + } + + UNSAFE.putChar(base, offset, '\u0123'); + + // get and add, add and get + { + char o = UNSAFE.getAndAddChar(base, offset, '\u4567'); + assertEquals(o, '\u0123', "getAndAdd char"); + char x = UNSAFE.getChar(base, offset); + assertEquals(x, (char)('\u0123' + '\u4567'), "getAndAdd char"); + } } static void testAccess(long address) { // Plain { - UNSAFE.putChar(address, 'a'); + UNSAFE.putChar(address, '\u0123'); char x = UNSAFE.getChar(address); - assertEquals(x, 'a', "set char value"); + assertEquals(x, '\u0123', "set char value"); } } } diff --git a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestDouble.java b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestDouble.java index 5304bc2c900..83874a55504 100644 --- a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestDouble.java +++ b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestDouble.java @@ -173,7 +173,125 @@ public class JdkInternalMiscUnsafeAccessTestDouble { } + UNSAFE.putDouble(base, offset, 1.0d); + // Compare + { + boolean r = UNSAFE.compareAndSwapDouble(base, offset, 1.0d, 2.0d); + assertEquals(r, true, "success compareAndSwap double"); + double x = UNSAFE.getDouble(base, offset); + assertEquals(x, 2.0d, "success compareAndSwap double value"); + } + + { + boolean r = UNSAFE.compareAndSwapDouble(base, offset, 1.0d, 3.0d); + assertEquals(r, false, "failing compareAndSwap double"); + double x = UNSAFE.getDouble(base, offset); + assertEquals(x, 2.0d, "failing compareAndSwap double value"); + } + + // Advanced compare + { + double r = UNSAFE.compareAndExchangeDoubleVolatile(base, offset, 2.0d, 1.0d); + assertEquals(r, 2.0d, "success compareAndExchangeVolatile double"); + double x = UNSAFE.getDouble(base, offset); + assertEquals(x, 1.0d, "success compareAndExchangeVolatile double value"); + } + + { + double r = UNSAFE.compareAndExchangeDoubleVolatile(base, offset, 2.0d, 3.0d); + assertEquals(r, 1.0d, "failing compareAndExchangeVolatile double"); + double x = UNSAFE.getDouble(base, offset); + assertEquals(x, 1.0d, "failing compareAndExchangeVolatile double value"); + } + + { + double r = UNSAFE.compareAndExchangeDoubleAcquire(base, offset, 1.0d, 2.0d); + assertEquals(r, 1.0d, "success compareAndExchangeAcquire double"); + double x = UNSAFE.getDouble(base, offset); + assertEquals(x, 2.0d, "success compareAndExchangeAcquire double value"); + } + + { + double r = UNSAFE.compareAndExchangeDoubleAcquire(base, offset, 1.0d, 3.0d); + assertEquals(r, 2.0d, "failing compareAndExchangeAcquire double"); + double x = UNSAFE.getDouble(base, offset); + assertEquals(x, 2.0d, "failing compareAndExchangeAcquire double value"); + } + + { + double r = UNSAFE.compareAndExchangeDoubleRelease(base, offset, 2.0d, 1.0d); + assertEquals(r, 2.0d, "success compareAndExchangeRelease double"); + double x = UNSAFE.getDouble(base, offset); + assertEquals(x, 1.0d, "success compareAndExchangeRelease double value"); + } + + { + double r = UNSAFE.compareAndExchangeDoubleRelease(base, offset, 2.0d, 3.0d); + assertEquals(r, 1.0d, "failing compareAndExchangeRelease double"); + double x = UNSAFE.getDouble(base, offset); + assertEquals(x, 1.0d, "failing compareAndExchangeRelease double value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapDouble(base, offset, 1.0d, 2.0d); + } + assertEquals(success, true, "weakCompareAndSwap double"); + double x = UNSAFE.getDouble(base, offset); + assertEquals(x, 2.0d, "weakCompareAndSwap double value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapDoubleAcquire(base, offset, 2.0d, 1.0d); + } + assertEquals(success, true, "weakCompareAndSwapAcquire double"); + double x = UNSAFE.getDouble(base, offset); + assertEquals(x, 1.0d, "weakCompareAndSwapAcquire double"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapDoubleRelease(base, offset, 1.0d, 2.0d); + } + assertEquals(success, true, "weakCompareAndSwapRelease double"); + double x = UNSAFE.getDouble(base, offset); + assertEquals(x, 2.0d, "weakCompareAndSwapRelease double"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapDoubleVolatile(base, offset, 2.0d, 1.0d); + } + assertEquals(success, true, "weakCompareAndSwapVolatile double"); + double x = UNSAFE.getDouble(base, offset); + assertEquals(x, 1.0d, "weakCompareAndSwapVolatile double"); + } + + UNSAFE.putDouble(base, offset, 2.0d); + + // Compare set and get + { + double o = UNSAFE.getAndSetDouble(base, offset, 1.0d); + assertEquals(o, 2.0d, "getAndSet double"); + double x = UNSAFE.getDouble(base, offset); + assertEquals(x, 1.0d, "getAndSet double value"); + } + + UNSAFE.putDouble(base, offset, 1.0d); + + // get and add, add and get + { + double o = UNSAFE.getAndAddDouble(base, offset, 2.0d); + assertEquals(o, 1.0d, "getAndAdd double"); + double x = UNSAFE.getDouble(base, offset); + assertEquals(x, (double)(1.0d + 2.0d), "getAndAdd double"); + } } static void testAccess(long address) { diff --git a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestFloat.java b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestFloat.java index f7c542ebd6f..f5191f00af3 100644 --- a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestFloat.java +++ b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestFloat.java @@ -173,7 +173,125 @@ public class JdkInternalMiscUnsafeAccessTestFloat { } + UNSAFE.putFloat(base, offset, 1.0f); + // Compare + { + boolean r = UNSAFE.compareAndSwapFloat(base, offset, 1.0f, 2.0f); + assertEquals(r, true, "success compareAndSwap float"); + float x = UNSAFE.getFloat(base, offset); + assertEquals(x, 2.0f, "success compareAndSwap float value"); + } + + { + boolean r = UNSAFE.compareAndSwapFloat(base, offset, 1.0f, 3.0f); + assertEquals(r, false, "failing compareAndSwap float"); + float x = UNSAFE.getFloat(base, offset); + assertEquals(x, 2.0f, "failing compareAndSwap float value"); + } + + // Advanced compare + { + float r = UNSAFE.compareAndExchangeFloatVolatile(base, offset, 2.0f, 1.0f); + assertEquals(r, 2.0f, "success compareAndExchangeVolatile float"); + float x = UNSAFE.getFloat(base, offset); + assertEquals(x, 1.0f, "success compareAndExchangeVolatile float value"); + } + + { + float r = UNSAFE.compareAndExchangeFloatVolatile(base, offset, 2.0f, 3.0f); + assertEquals(r, 1.0f, "failing compareAndExchangeVolatile float"); + float x = UNSAFE.getFloat(base, offset); + assertEquals(x, 1.0f, "failing compareAndExchangeVolatile float value"); + } + + { + float r = UNSAFE.compareAndExchangeFloatAcquire(base, offset, 1.0f, 2.0f); + assertEquals(r, 1.0f, "success compareAndExchangeAcquire float"); + float x = UNSAFE.getFloat(base, offset); + assertEquals(x, 2.0f, "success compareAndExchangeAcquire float value"); + } + + { + float r = UNSAFE.compareAndExchangeFloatAcquire(base, offset, 1.0f, 3.0f); + assertEquals(r, 2.0f, "failing compareAndExchangeAcquire float"); + float x = UNSAFE.getFloat(base, offset); + assertEquals(x, 2.0f, "failing compareAndExchangeAcquire float value"); + } + + { + float r = UNSAFE.compareAndExchangeFloatRelease(base, offset, 2.0f, 1.0f); + assertEquals(r, 2.0f, "success compareAndExchangeRelease float"); + float x = UNSAFE.getFloat(base, offset); + assertEquals(x, 1.0f, "success compareAndExchangeRelease float value"); + } + + { + float r = UNSAFE.compareAndExchangeFloatRelease(base, offset, 2.0f, 3.0f); + assertEquals(r, 1.0f, "failing compareAndExchangeRelease float"); + float x = UNSAFE.getFloat(base, offset); + assertEquals(x, 1.0f, "failing compareAndExchangeRelease float value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapFloat(base, offset, 1.0f, 2.0f); + } + assertEquals(success, true, "weakCompareAndSwap float"); + float x = UNSAFE.getFloat(base, offset); + assertEquals(x, 2.0f, "weakCompareAndSwap float value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapFloatAcquire(base, offset, 2.0f, 1.0f); + } + assertEquals(success, true, "weakCompareAndSwapAcquire float"); + float x = UNSAFE.getFloat(base, offset); + assertEquals(x, 1.0f, "weakCompareAndSwapAcquire float"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapFloatRelease(base, offset, 1.0f, 2.0f); + } + assertEquals(success, true, "weakCompareAndSwapRelease float"); + float x = UNSAFE.getFloat(base, offset); + assertEquals(x, 2.0f, "weakCompareAndSwapRelease float"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapFloatVolatile(base, offset, 2.0f, 1.0f); + } + assertEquals(success, true, "weakCompareAndSwapVolatile float"); + float x = UNSAFE.getFloat(base, offset); + assertEquals(x, 1.0f, "weakCompareAndSwapVolatile float"); + } + + UNSAFE.putFloat(base, offset, 2.0f); + + // Compare set and get + { + float o = UNSAFE.getAndSetFloat(base, offset, 1.0f); + assertEquals(o, 2.0f, "getAndSet float"); + float x = UNSAFE.getFloat(base, offset); + assertEquals(x, 1.0f, "getAndSet float value"); + } + + UNSAFE.putFloat(base, offset, 1.0f); + + // get and add, add and get + { + float o = UNSAFE.getAndAddFloat(base, offset, 2.0f); + assertEquals(o, 1.0f, "getAndAdd float"); + float x = UNSAFE.getFloat(base, offset); + assertEquals(x, (float)(1.0f + 2.0f), "getAndAdd float"); + } } static void testAccess(long address) { diff --git a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestInt.java b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestInt.java index 817e78da0bd..6428c0d55e4 100644 --- a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestInt.java +++ b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestInt.java @@ -145,179 +145,179 @@ public class JdkInternalMiscUnsafeAccessTestInt { static void testAccess(Object base, long offset) { // Plain { - UNSAFE.putInt(base, offset, 1); + UNSAFE.putInt(base, offset, 0x01234567); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 1, "set int value"); + assertEquals(x, 0x01234567, "set int value"); } // Volatile { - UNSAFE.putIntVolatile(base, offset, 2); + UNSAFE.putIntVolatile(base, offset, 0x89ABCDEF); int x = UNSAFE.getIntVolatile(base, offset); - assertEquals(x, 2, "putVolatile int value"); + assertEquals(x, 0x89ABCDEF, "putVolatile int value"); } // Lazy { - UNSAFE.putIntRelease(base, offset, 1); + UNSAFE.putIntRelease(base, offset, 0x01234567); int x = UNSAFE.getIntAcquire(base, offset); - assertEquals(x, 1, "putRelease int value"); + assertEquals(x, 0x01234567, "putRelease int value"); } // Opaque { - UNSAFE.putIntOpaque(base, offset, 2); + UNSAFE.putIntOpaque(base, offset, 0x89ABCDEF); int x = UNSAFE.getIntOpaque(base, offset); - assertEquals(x, 2, "putOpaque int value"); + assertEquals(x, 0x89ABCDEF, "putOpaque int value"); } // Unaligned { - UNSAFE.putIntUnaligned(base, offset, 2); + UNSAFE.putIntUnaligned(base, offset, 0x89ABCDEF); int x = UNSAFE.getIntUnaligned(base, offset); - assertEquals(x, 2, "putUnaligned int value"); + assertEquals(x, 0x89ABCDEF, "putUnaligned int value"); } { - UNSAFE.putIntUnaligned(base, offset, 1, true); + UNSAFE.putIntUnaligned(base, offset, 0x01234567, true); int x = UNSAFE.getIntUnaligned(base, offset, true); - assertEquals(x, 1, "putUnaligned big endian int value"); + assertEquals(x, 0x01234567, "putUnaligned big endian int value"); } { - UNSAFE.putIntUnaligned(base, offset, 2, false); + UNSAFE.putIntUnaligned(base, offset, 0x89ABCDEF, false); int x = UNSAFE.getIntUnaligned(base, offset, false); - assertEquals(x, 2, "putUnaligned little endian int value"); + assertEquals(x, 0x89ABCDEF, "putUnaligned little endian int value"); } - UNSAFE.putInt(base, offset, 1); + UNSAFE.putInt(base, offset, 0x01234567); // Compare { - boolean r = UNSAFE.compareAndSwapInt(base, offset, 1, 2); + boolean r = UNSAFE.compareAndSwapInt(base, offset, 0x01234567, 0x89ABCDEF); assertEquals(r, true, "success compareAndSwap int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 2, "success compareAndSwap int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndSwap int value"); } { - boolean r = UNSAFE.compareAndSwapInt(base, offset, 1, 3); + boolean r = UNSAFE.compareAndSwapInt(base, offset, 0x01234567, 0xCAFEBABE); assertEquals(r, false, "failing compareAndSwap int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 2, "failing compareAndSwap int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndSwap int value"); } // Advanced compare { - int r = UNSAFE.compareAndExchangeIntVolatile(base, offset, 2, 1); - assertEquals(r, 2, "success compareAndExchangeVolatile int"); + int r = UNSAFE.compareAndExchangeIntVolatile(base, offset, 0x89ABCDEF, 0x01234567); + assertEquals(r, 0x89ABCDEF, "success compareAndExchangeVolatile int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 1, "success compareAndExchangeVolatile int value"); + assertEquals(x, 0x01234567, "success compareAndExchangeVolatile int value"); } { - int r = UNSAFE.compareAndExchangeIntVolatile(base, offset, 2, 3); - assertEquals(r, 1, "failing compareAndExchangeVolatile int"); + int r = UNSAFE.compareAndExchangeIntVolatile(base, offset, 0x89ABCDEF, 0xCAFEBABE); + assertEquals(r, 0x01234567, "failing compareAndExchangeVolatile int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 1, "failing compareAndExchangeVolatile int value"); + assertEquals(x, 0x01234567, "failing compareAndExchangeVolatile int value"); } { - int r = UNSAFE.compareAndExchangeIntAcquire(base, offset, 1, 2); - assertEquals(r, 1, "success compareAndExchangeAcquire int"); + int r = UNSAFE.compareAndExchangeIntAcquire(base, offset, 0x01234567, 0x89ABCDEF); + assertEquals(r, 0x01234567, "success compareAndExchangeAcquire int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 2, "success compareAndExchangeAcquire int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndExchangeAcquire int value"); } { - int r = UNSAFE.compareAndExchangeIntAcquire(base, offset, 1, 3); - assertEquals(r, 2, "failing compareAndExchangeAcquire int"); + int r = UNSAFE.compareAndExchangeIntAcquire(base, offset, 0x01234567, 0xCAFEBABE); + assertEquals(r, 0x89ABCDEF, "failing compareAndExchangeAcquire int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 2, "failing compareAndExchangeAcquire int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndExchangeAcquire int value"); } { - int r = UNSAFE.compareAndExchangeIntRelease(base, offset, 2, 1); - assertEquals(r, 2, "success compareAndExchangeRelease int"); + int r = UNSAFE.compareAndExchangeIntRelease(base, offset, 0x89ABCDEF, 0x01234567); + assertEquals(r, 0x89ABCDEF, "success compareAndExchangeRelease int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 1, "success compareAndExchangeRelease int value"); + assertEquals(x, 0x01234567, "success compareAndExchangeRelease int value"); } { - int r = UNSAFE.compareAndExchangeIntRelease(base, offset, 2, 3); - assertEquals(r, 1, "failing compareAndExchangeRelease int"); + int r = UNSAFE.compareAndExchangeIntRelease(base, offset, 0x89ABCDEF, 0xCAFEBABE); + assertEquals(r, 0x01234567, "failing compareAndExchangeRelease int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 1, "failing compareAndExchangeRelease int value"); + assertEquals(x, 0x01234567, "failing compareAndExchangeRelease int value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = UNSAFE.weakCompareAndSwapInt(base, offset, 1, 2); + success = UNSAFE.weakCompareAndSwapInt(base, offset, 0x01234567, 0x89ABCDEF); } assertEquals(success, true, "weakCompareAndSwap int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 2, "weakCompareAndSwap int value"); + assertEquals(x, 0x89ABCDEF, "weakCompareAndSwap int value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = UNSAFE.weakCompareAndSwapIntAcquire(base, offset, 2, 1); + success = UNSAFE.weakCompareAndSwapIntAcquire(base, offset, 0x89ABCDEF, 0x01234567); } assertEquals(success, true, "weakCompareAndSwapAcquire int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 1, "weakCompareAndSwapAcquire int"); + assertEquals(x, 0x01234567, "weakCompareAndSwapAcquire int"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = UNSAFE.weakCompareAndSwapIntRelease(base, offset, 1, 2); + success = UNSAFE.weakCompareAndSwapIntRelease(base, offset, 0x01234567, 0x89ABCDEF); } assertEquals(success, true, "weakCompareAndSwapRelease int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 2, "weakCompareAndSwapRelease int"); + assertEquals(x, 0x89ABCDEF, "weakCompareAndSwapRelease int"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = UNSAFE.weakCompareAndSwapIntVolatile(base, offset, 2, 1); + success = UNSAFE.weakCompareAndSwapIntVolatile(base, offset, 0x89ABCDEF, 0x01234567); } assertEquals(success, true, "weakCompareAndSwapVolatile int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 1, "weakCompareAndSwapVolatile int"); + assertEquals(x, 0x01234567, "weakCompareAndSwapVolatile int"); } - UNSAFE.putInt(base, offset, 2); + UNSAFE.putInt(base, offset, 0x89ABCDEF); // Compare set and get { - int o = UNSAFE.getAndSetInt(base, offset, 1); - assertEquals(o, 2, "getAndSet int"); + int o = UNSAFE.getAndSetInt(base, offset, 0x01234567); + assertEquals(o, 0x89ABCDEF, "getAndSet int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 1, "getAndSet int value"); + assertEquals(x, 0x01234567, "getAndSet int value"); } - UNSAFE.putInt(base, offset, 1); + UNSAFE.putInt(base, offset, 0x01234567); // get and add, add and get { - int o = UNSAFE.getAndAddInt(base, offset, 2); - assertEquals(o, 1, "getAndAdd int"); + int o = UNSAFE.getAndAddInt(base, offset, 0x89ABCDEF); + assertEquals(o, 0x01234567, "getAndAdd int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 1 + 2, "getAndAdd int"); + assertEquals(x, (int)(0x01234567 + 0x89ABCDEF), "getAndAdd int"); } } static void testAccess(long address) { // Plain { - UNSAFE.putInt(address, 1); + UNSAFE.putInt(address, 0x01234567); int x = UNSAFE.getInt(address); - assertEquals(x, 1, "set int value"); + assertEquals(x, 0x01234567, "set int value"); } } } diff --git a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestLong.java b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestLong.java index d4b88370a65..505681a43af 100644 --- a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestLong.java +++ b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestLong.java @@ -145,179 +145,179 @@ public class JdkInternalMiscUnsafeAccessTestLong { static void testAccess(Object base, long offset) { // Plain { - UNSAFE.putLong(base, offset, 1L); + UNSAFE.putLong(base, offset, 0x0123456789ABCDEFL); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 1L, "set long value"); + assertEquals(x, 0x0123456789ABCDEFL, "set long value"); } // Volatile { - UNSAFE.putLongVolatile(base, offset, 2L); + UNSAFE.putLongVolatile(base, offset, 0xCAFEBABECAFEBABEL); long x = UNSAFE.getLongVolatile(base, offset); - assertEquals(x, 2L, "putVolatile long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "putVolatile long value"); } // Lazy { - UNSAFE.putLongRelease(base, offset, 1L); + UNSAFE.putLongRelease(base, offset, 0x0123456789ABCDEFL); long x = UNSAFE.getLongAcquire(base, offset); - assertEquals(x, 1L, "putRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "putRelease long value"); } // Opaque { - UNSAFE.putLongOpaque(base, offset, 2L); + UNSAFE.putLongOpaque(base, offset, 0xCAFEBABECAFEBABEL); long x = UNSAFE.getLongOpaque(base, offset); - assertEquals(x, 2L, "putOpaque long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "putOpaque long value"); } // Unaligned { - UNSAFE.putLongUnaligned(base, offset, 2L); + UNSAFE.putLongUnaligned(base, offset, 0xCAFEBABECAFEBABEL); long x = UNSAFE.getLongUnaligned(base, offset); - assertEquals(x, 2L, "putUnaligned long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "putUnaligned long value"); } { - UNSAFE.putLongUnaligned(base, offset, 1L, true); + UNSAFE.putLongUnaligned(base, offset, 0x0123456789ABCDEFL, true); long x = UNSAFE.getLongUnaligned(base, offset, true); - assertEquals(x, 1L, "putUnaligned big endian long value"); + assertEquals(x, 0x0123456789ABCDEFL, "putUnaligned big endian long value"); } { - UNSAFE.putLongUnaligned(base, offset, 2L, false); + UNSAFE.putLongUnaligned(base, offset, 0xCAFEBABECAFEBABEL, false); long x = UNSAFE.getLongUnaligned(base, offset, false); - assertEquals(x, 2L, "putUnaligned little endian long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "putUnaligned little endian long value"); } - UNSAFE.putLong(base, offset, 1L); + UNSAFE.putLong(base, offset, 0x0123456789ABCDEFL); // Compare { - boolean r = UNSAFE.compareAndSwapLong(base, offset, 1L, 2L); + boolean r = UNSAFE.compareAndSwapLong(base, offset, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); assertEquals(r, true, "success compareAndSwap long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 2L, "success compareAndSwap long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndSwap long value"); } { - boolean r = UNSAFE.compareAndSwapLong(base, offset, 1L, 3L); + boolean r = UNSAFE.compareAndSwapLong(base, offset, 0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); assertEquals(r, false, "failing compareAndSwap long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 2L, "failing compareAndSwap long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndSwap long value"); } // Advanced compare { - long r = UNSAFE.compareAndExchangeLongVolatile(base, offset, 2L, 1L); - assertEquals(r, 2L, "success compareAndExchangeVolatile long"); + long r = UNSAFE.compareAndExchangeLongVolatile(base, offset, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "success compareAndExchangeVolatile long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 1L, "success compareAndExchangeVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "success compareAndExchangeVolatile long value"); } { - long r = UNSAFE.compareAndExchangeLongVolatile(base, offset, 2L, 3L); - assertEquals(r, 1L, "failing compareAndExchangeVolatile long"); + long r = UNSAFE.compareAndExchangeLongVolatile(base, offset, 0xCAFEBABECAFEBABEL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0x0123456789ABCDEFL, "failing compareAndExchangeVolatile long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 1L, "failing compareAndExchangeVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "failing compareAndExchangeVolatile long value"); } { - long r = UNSAFE.compareAndExchangeLongAcquire(base, offset, 1L, 2L); - assertEquals(r, 1L, "success compareAndExchangeAcquire long"); + long r = UNSAFE.compareAndExchangeLongAcquire(base, offset, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); + assertEquals(r, 0x0123456789ABCDEFL, "success compareAndExchangeAcquire long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 2L, "success compareAndExchangeAcquire long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndExchangeAcquire long value"); } { - long r = UNSAFE.compareAndExchangeLongAcquire(base, offset, 1L, 3L); - assertEquals(r, 2L, "failing compareAndExchangeAcquire long"); + long r = UNSAFE.compareAndExchangeLongAcquire(base, offset, 0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "failing compareAndExchangeAcquire long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 2L, "failing compareAndExchangeAcquire long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndExchangeAcquire long value"); } { - long r = UNSAFE.compareAndExchangeLongRelease(base, offset, 2L, 1L); - assertEquals(r, 2L, "success compareAndExchangeRelease long"); + long r = UNSAFE.compareAndExchangeLongRelease(base, offset, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "success compareAndExchangeRelease long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 1L, "success compareAndExchangeRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "success compareAndExchangeRelease long value"); } { - long r = UNSAFE.compareAndExchangeLongRelease(base, offset, 2L, 3L); - assertEquals(r, 1L, "failing compareAndExchangeRelease long"); + long r = UNSAFE.compareAndExchangeLongRelease(base, offset, 0xCAFEBABECAFEBABEL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0x0123456789ABCDEFL, "failing compareAndExchangeRelease long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 1L, "failing compareAndExchangeRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "failing compareAndExchangeRelease long value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = UNSAFE.weakCompareAndSwapLong(base, offset, 1L, 2L); + success = UNSAFE.weakCompareAndSwapLong(base, offset, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); } assertEquals(success, true, "weakCompareAndSwap long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 2L, "weakCompareAndSwap long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "weakCompareAndSwap long value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = UNSAFE.weakCompareAndSwapLongAcquire(base, offset, 2L, 1L); + success = UNSAFE.weakCompareAndSwapLongAcquire(base, offset, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); } assertEquals(success, true, "weakCompareAndSwapAcquire long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 1L, "weakCompareAndSwapAcquire long"); + assertEquals(x, 0x0123456789ABCDEFL, "weakCompareAndSwapAcquire long"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = UNSAFE.weakCompareAndSwapLongRelease(base, offset, 1L, 2L); + success = UNSAFE.weakCompareAndSwapLongRelease(base, offset, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); } assertEquals(success, true, "weakCompareAndSwapRelease long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 2L, "weakCompareAndSwapRelease long"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "weakCompareAndSwapRelease long"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = UNSAFE.weakCompareAndSwapLongVolatile(base, offset, 2L, 1L); + success = UNSAFE.weakCompareAndSwapLongVolatile(base, offset, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); } assertEquals(success, true, "weakCompareAndSwapVolatile long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 1L, "weakCompareAndSwapVolatile long"); + assertEquals(x, 0x0123456789ABCDEFL, "weakCompareAndSwapVolatile long"); } - UNSAFE.putLong(base, offset, 2L); + UNSAFE.putLong(base, offset, 0xCAFEBABECAFEBABEL); // Compare set and get { - long o = UNSAFE.getAndSetLong(base, offset, 1L); - assertEquals(o, 2L, "getAndSet long"); + long o = UNSAFE.getAndSetLong(base, offset, 0x0123456789ABCDEFL); + assertEquals(o, 0xCAFEBABECAFEBABEL, "getAndSet long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 1L, "getAndSet long value"); + assertEquals(x, 0x0123456789ABCDEFL, "getAndSet long value"); } - UNSAFE.putLong(base, offset, 1L); + UNSAFE.putLong(base, offset, 0x0123456789ABCDEFL); // get and add, add and get { - long o = UNSAFE.getAndAddLong(base, offset, 2L); - assertEquals(o, 1L, "getAndAdd long"); + long o = UNSAFE.getAndAddLong(base, offset, 0xCAFEBABECAFEBABEL); + assertEquals(o, 0x0123456789ABCDEFL, "getAndAdd long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 1L + 2L, "getAndAdd long"); + assertEquals(x, (long)(0x0123456789ABCDEFL + 0xCAFEBABECAFEBABEL), "getAndAdd long"); } } static void testAccess(long address) { // Plain { - UNSAFE.putLong(address, 1L); + UNSAFE.putLong(address, 0x0123456789ABCDEFL); long x = UNSAFE.getLong(address); - assertEquals(x, 1L, "set long value"); + assertEquals(x, 0x0123456789ABCDEFL, "set long value"); } } } diff --git a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestShort.java b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestShort.java index a9fab93740b..12ab68cfed7 100644 --- a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestShort.java +++ b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeAccessTestShort.java @@ -145,61 +145,179 @@ public class JdkInternalMiscUnsafeAccessTestShort { static void testAccess(Object base, long offset) { // Plain { - UNSAFE.putShort(base, offset, (short)1); + UNSAFE.putShort(base, offset, (short)0x0123); short x = UNSAFE.getShort(base, offset); - assertEquals(x, (short)1, "set short value"); + assertEquals(x, (short)0x0123, "set short value"); } // Volatile { - UNSAFE.putShortVolatile(base, offset, (short)2); + UNSAFE.putShortVolatile(base, offset, (short)0x4567); short x = UNSAFE.getShortVolatile(base, offset); - assertEquals(x, (short)2, "putVolatile short value"); + assertEquals(x, (short)0x4567, "putVolatile short value"); } // Lazy { - UNSAFE.putShortRelease(base, offset, (short)1); + UNSAFE.putShortRelease(base, offset, (short)0x0123); short x = UNSAFE.getShortAcquire(base, offset); - assertEquals(x, (short)1, "putRelease short value"); + assertEquals(x, (short)0x0123, "putRelease short value"); } // Opaque { - UNSAFE.putShortOpaque(base, offset, (short)2); + UNSAFE.putShortOpaque(base, offset, (short)0x4567); short x = UNSAFE.getShortOpaque(base, offset); - assertEquals(x, (short)2, "putOpaque short value"); + assertEquals(x, (short)0x4567, "putOpaque short value"); } // Unaligned { - UNSAFE.putShortUnaligned(base, offset, (short)2); + UNSAFE.putShortUnaligned(base, offset, (short)0x4567); short x = UNSAFE.getShortUnaligned(base, offset); - assertEquals(x, (short)2, "putUnaligned short value"); + assertEquals(x, (short)0x4567, "putUnaligned short value"); } { - UNSAFE.putShortUnaligned(base, offset, (short)1, true); + UNSAFE.putShortUnaligned(base, offset, (short)0x0123, true); short x = UNSAFE.getShortUnaligned(base, offset, true); - assertEquals(x, (short)1, "putUnaligned big endian short value"); + assertEquals(x, (short)0x0123, "putUnaligned big endian short value"); } { - UNSAFE.putShortUnaligned(base, offset, (short)2, false); + UNSAFE.putShortUnaligned(base, offset, (short)0x4567, false); short x = UNSAFE.getShortUnaligned(base, offset, false); - assertEquals(x, (short)2, "putUnaligned little endian short value"); + assertEquals(x, (short)0x4567, "putUnaligned little endian short value"); } + UNSAFE.putShort(base, offset, (short)0x0123); + // Compare + { + boolean r = UNSAFE.compareAndSwapShort(base, offset, (short)0x0123, (short)0x4567); + assertEquals(r, true, "success compareAndSwap short"); + short x = UNSAFE.getShort(base, offset); + assertEquals(x, (short)0x4567, "success compareAndSwap short value"); + } + + { + boolean r = UNSAFE.compareAndSwapShort(base, offset, (short)0x0123, (short)0x89AB); + assertEquals(r, false, "failing compareAndSwap short"); + short x = UNSAFE.getShort(base, offset); + assertEquals(x, (short)0x4567, "failing compareAndSwap short value"); + } + + // Advanced compare + { + short r = UNSAFE.compareAndExchangeShortVolatile(base, offset, (short)0x4567, (short)0x0123); + assertEquals(r, (short)0x4567, "success compareAndExchangeVolatile short"); + short x = UNSAFE.getShort(base, offset); + assertEquals(x, (short)0x0123, "success compareAndExchangeVolatile short value"); + } + + { + short r = UNSAFE.compareAndExchangeShortVolatile(base, offset, (short)0x4567, (short)0x89AB); + assertEquals(r, (short)0x0123, "failing compareAndExchangeVolatile short"); + short x = UNSAFE.getShort(base, offset); + assertEquals(x, (short)0x0123, "failing compareAndExchangeVolatile short value"); + } + + { + short r = UNSAFE.compareAndExchangeShortAcquire(base, offset, (short)0x0123, (short)0x4567); + assertEquals(r, (short)0x0123, "success compareAndExchangeAcquire short"); + short x = UNSAFE.getShort(base, offset); + assertEquals(x, (short)0x4567, "success compareAndExchangeAcquire short value"); + } + + { + short r = UNSAFE.compareAndExchangeShortAcquire(base, offset, (short)0x0123, (short)0x89AB); + assertEquals(r, (short)0x4567, "failing compareAndExchangeAcquire short"); + short x = UNSAFE.getShort(base, offset); + assertEquals(x, (short)0x4567, "failing compareAndExchangeAcquire short value"); + } + + { + short r = UNSAFE.compareAndExchangeShortRelease(base, offset, (short)0x4567, (short)0x0123); + assertEquals(r, (short)0x4567, "success compareAndExchangeRelease short"); + short x = UNSAFE.getShort(base, offset); + assertEquals(x, (short)0x0123, "success compareAndExchangeRelease short value"); + } + + { + short r = UNSAFE.compareAndExchangeShortRelease(base, offset, (short)0x4567, (short)0x89AB); + assertEquals(r, (short)0x0123, "failing compareAndExchangeRelease short"); + short x = UNSAFE.getShort(base, offset); + assertEquals(x, (short)0x0123, "failing compareAndExchangeRelease short value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapShort(base, offset, (short)0x0123, (short)0x4567); + } + assertEquals(success, true, "weakCompareAndSwap short"); + short x = UNSAFE.getShort(base, offset); + assertEquals(x, (short)0x4567, "weakCompareAndSwap short value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapShortAcquire(base, offset, (short)0x4567, (short)0x0123); + } + assertEquals(success, true, "weakCompareAndSwapAcquire short"); + short x = UNSAFE.getShort(base, offset); + assertEquals(x, (short)0x0123, "weakCompareAndSwapAcquire short"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapShortRelease(base, offset, (short)0x0123, (short)0x4567); + } + assertEquals(success, true, "weakCompareAndSwapRelease short"); + short x = UNSAFE.getShort(base, offset); + assertEquals(x, (short)0x4567, "weakCompareAndSwapRelease short"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = UNSAFE.weakCompareAndSwapShortVolatile(base, offset, (short)0x4567, (short)0x0123); + } + assertEquals(success, true, "weakCompareAndSwapVolatile short"); + short x = UNSAFE.getShort(base, offset); + assertEquals(x, (short)0x0123, "weakCompareAndSwapVolatile short"); + } + + UNSAFE.putShort(base, offset, (short)0x4567); + + // Compare set and get + { + short o = UNSAFE.getAndSetShort(base, offset, (short)0x0123); + assertEquals(o, (short)0x4567, "getAndSet short"); + short x = UNSAFE.getShort(base, offset); + assertEquals(x, (short)0x0123, "getAndSet short value"); + } + + UNSAFE.putShort(base, offset, (short)0x0123); + + // get and add, add and get + { + short o = UNSAFE.getAndAddShort(base, offset, (short)0x4567); + assertEquals(o, (short)0x0123, "getAndAdd short"); + short x = UNSAFE.getShort(base, offset); + assertEquals(x, (short)((short)0x0123 + (short)0x4567), "getAndAdd short"); + } } static void testAccess(long address) { // Plain { - UNSAFE.putShort(address, (short)1); + UNSAFE.putShort(address, (short)0x0123); short x = UNSAFE.getShort(address); - assertEquals(x, (short)1, "set short value"); + assertEquals(x, (short)0x0123, "set short value"); } } } diff --git a/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeUnalignedAccess.java b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeUnalignedAccess.java new file mode 100644 index 00000000000..45959f00cfa --- /dev/null +++ b/hotspot/test/compiler/unsafe/JdkInternalMiscUnsafeUnalignedAccess.java @@ -0,0 +1,315 @@ +/* + * Copyright (c) 2016 SAP SE. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @bug 8158260 + * @summary Test unaligned Unsafe accesses + * @modules java.base/jdk.internal.misc + * @run main/othervm -Diters=20000 -XX:-UseOnStackReplacement -XX:-BackgroundCompilation JdkInternalMiscUnsafeUnalignedAccess + * @author volker.simonis@gmail.com + */ + +import java.lang.reflect.Field; +import java.nio.ByteOrder; +import jdk.internal.misc.Unsafe; + +public class JdkInternalMiscUnsafeUnalignedAccess { + static final int ITERS = Integer.getInteger("iters", 20_000); + private static final boolean BIG_ENDIAN = ByteOrder.nativeOrder().equals(ByteOrder.BIG_ENDIAN); + private static final Unsafe UNSAFE; + private static final int SIZE = 1024; + private static long memory; + + static { + try { + Field unsafeField = Unsafe.class.getDeclaredField("theUnsafe"); + unsafeField.setAccessible(true); + UNSAFE = (Unsafe) unsafeField.get(null); + } + catch (Exception e) { + throw new RuntimeException("Unable to get Unsafe instance.", e); + } + } + + static int getInt_0() { + return UNSAFE.getInt(memory + 0); + } + static int getInt_1() { + return UNSAFE.getInt(memory + 1); + } + static int getInt_4() { + return UNSAFE.getInt(memory + 4); + } + static int getInt_17() { + return UNSAFE.getInt(memory + 17); + } + + static long getIntAsLong_0() { + return UNSAFE.getInt(memory + 0); + } + static long getIntAsLong_1() { + return UNSAFE.getInt(memory + 1); + } + static long getIntAsLong_4() { + return UNSAFE.getInt(memory + 4); + } + static long getIntAsLong_17() { + return UNSAFE.getInt(memory + 17); + } + + static long getLong_0() { + return UNSAFE.getLong(memory + 0); + } + static long getLong_1() { + return UNSAFE.getLong(memory + 1); + } + static long getLong_4() { + return UNSAFE.getLong(memory + 4); + } + static long getLong_8() { + return UNSAFE.getLong(memory + 8); + } + static long getLong_17() { + return UNSAFE.getLong(memory + 17); + } + + static void putInt_0(int i) { + UNSAFE.putInt(memory + 0, i); + } + static void putInt_1(int i) { + UNSAFE.putInt(memory + 1, i); + } + static void putInt_4(int i) { + UNSAFE.putInt(memory + 4, i); + } + static void putInt_17(int i) { + UNSAFE.putInt(memory + 17, i); + } + + static void putLong_0(long l) { + UNSAFE.putLong(memory + 0, l); + } + static void putLong_1(long l) { + UNSAFE.putLong(memory + 1, l); + } + static void putLong_4(long l) { + UNSAFE.putLong(memory + 4, l); + } + static void putLong_8(long l) { + UNSAFE.putLong(memory + 8, l); + } + static void putLong_17(long l) { + UNSAFE.putLong(memory + 17, l); + } + + public static void main(String[] args) throws Exception { + + if (!UNSAFE.unalignedAccess()) { + System.out.println("Platform is not supporting unaligned access - nothing to test."); + return; + } + + memory = UNSAFE.allocateMemory(SIZE); + + UNSAFE.putInt(memory + 0, 0x00112233); + UNSAFE.putInt(memory + 4, 0x44556677); + UNSAFE.putInt(memory + 8, 0x8899aabb); + UNSAFE.putInt(memory + 12, 0xccddeeff); + UNSAFE.putInt(memory + 16, 0x01234567); + UNSAFE.putInt(memory + 20, 0x89abcdef); + UNSAFE.putInt(memory + 24, 0x01234567); + + // Unsafe.getInt() + int res; + for (int i = 0; i < ITERS; i++) { + res = getInt_0(); + if (res != 0x00112233) { + throw new Exception(res + " != 0x00112233"); + } + } + + for (int i = 0; i < ITERS; i++) { + res = getInt_1(); + if (res != (BIG_ENDIAN ? 0x11223344 : 0x77001122)) { + throw new Exception(res + " != " + (BIG_ENDIAN ? 0x11223344 : 0x77001122)); + } + } + + for (int i = 0; i < ITERS; i++) { + res = getInt_4(); + if (res != 0x44556677) { + throw new Exception(res + " != 0x44556677"); + } + } + + for (int i = 0; i < ITERS; i++) { + res = getInt_17(); + if (res != (BIG_ENDIAN ? 0x23456789 : 0xef012345)) { + throw new Exception(res + " != " + (BIG_ENDIAN ? 0x23456789 : 0xef012345)); + } + } + + // (long)Unsafe.getInt() + long lres; + for (int i = 0; i < ITERS; i++) { + lres = getIntAsLong_0(); + if (lres != (long)0x00112233) { + throw new Exception(lres + " != 0x00112233"); + } + } + + for (int i = 0; i < ITERS; i++) { + lres = getIntAsLong_1(); + if (lres != (BIG_ENDIAN ? (long)0x11223344 : (long)0x77001122)) { + throw new Exception(lres + " != " + (BIG_ENDIAN ? (long)0x11223344 : (long)0x77001122)); + } + } + + for (int i = 0; i < ITERS; i++) { + lres = getIntAsLong_4(); + if (lres != (long)0x44556677) { + throw new Exception(lres + " != 0x44556677"); + } + } + + for (int i = 0; i < ITERS; i++) { + lres = getIntAsLong_17(); + if (lres != (BIG_ENDIAN ? (long)0x23456789 : (long)0xef012345)) { + throw new Exception(lres + " != " + (BIG_ENDIAN ? (long)0x23456789 : (long)0xef012345)); + } + } + + // Unsafe.getLong() + for (int i = 0; i < ITERS; i++) { + lres = getLong_0(); + if (lres != (BIG_ENDIAN ? 0x0011223344556677L : 0x4455667700112233L)) { + throw new Exception(lres + " != " + (BIG_ENDIAN ? 0x0011223344556677L : 0x4455667700112233L)); + } + } + + for (int i = 0; i < ITERS; i++) { + lres = getLong_1(); + if (lres != (BIG_ENDIAN ? 0x1122334455667788L : 0xbb44556677001122L)) { + throw new Exception(lres + " != " + (BIG_ENDIAN ? 0x1122334455667788L : 0xbb44556677001122L)); + } + } + + for (int i = 0; i < ITERS; i++) { + lres = getLong_4(); + if (lres != (BIG_ENDIAN ? 0x445566778899aabbL : 0x8899aabb44556677L)) { + throw new Exception(lres + " != " + (BIG_ENDIAN ? 0x445566778899aabbL : 0x8899aabb44556677L)); + } + } + + for (int i = 0; i < ITERS; i++) { + lres = getLong_8(); + if (lres != (BIG_ENDIAN ? 0x8899aabbccddeeffL : 0xccddeeff8899aabbL)) { + throw new Exception(lres + " != " + (BIG_ENDIAN ? 0x8899aabbccddeeffL : 0xccddeeff8899aabbL)); + } + } + + for (int i = 0; i < ITERS; i++) { + lres = getLong_17(); + if (lres != (BIG_ENDIAN ? 0x23456789abcdef01L : 0x6789abcdef012345L)) { + throw new Exception(lres + " != " + (BIG_ENDIAN ? 0x23456789abcdef01L : 0x6789abcdef012345L)); + } + } + + // Unsafe.putInt() + for (int i = 0; i < ITERS; i++) { + putInt_0(0x00112233); + res = getInt_0(); + if (res != 0x00112233) { + throw new Exception(res + " != 0x00112233"); + } + } + + for (int i = 0; i < ITERS; i++) { + putInt_1(BIG_ENDIAN ? 0x11223344 : 0x77001122); + res = getInt_1(); + if (res != (BIG_ENDIAN ? 0x11223344 : 0x77001122)) { + throw new Exception(res + " != " + (BIG_ENDIAN ? 0x11223344 : 0x77001122)); + } + } + + for (int i = 0; i < ITERS; i++) { + putInt_4(0x44556677); + res = getInt_4(); + if (res != 0x44556677) { + throw new Exception(res + " != 0x44556677"); + } + } + + for (int i = 0; i < ITERS; i++) { + putInt_17(BIG_ENDIAN ? 0x23456789 : 0xef012345); + res = getInt_17(); + if (res != (BIG_ENDIAN ? 0x23456789 : 0xef012345)) { + throw new Exception(res + " != " + (BIG_ENDIAN ? 0x23456789 : 0xef012345)); + } + } + + + // Unsafe.putLong() + for (int i = 0; i < ITERS; i++) { + putLong_0(BIG_ENDIAN ? 0x0011223344556677L : 0x4455667700112233L); + lres = getLong_0(); + if (lres != (BIG_ENDIAN ? 0x0011223344556677L : 0x4455667700112233L)) { + throw new Exception(lres + " != " + (BIG_ENDIAN ? 0x0011223344556677L : 0x4455667700112233L)); + } + } + + for (int i = 0; i < ITERS; i++) { + putLong_1(BIG_ENDIAN ? 0x1122334455667788L : 0xbb44556677001122L); + lres = getLong_1(); + if (lres != (BIG_ENDIAN ? 0x1122334455667788L : 0xbb44556677001122L)) { + throw new Exception(lres + " != " + (BIG_ENDIAN ? 0x1122334455667788L : 0xbb44556677001122L)); + } + } + + for (int i = 0; i < ITERS; i++) { + putLong_4(BIG_ENDIAN ? 0x445566778899aabbL : 0x8899aabb44556677L); + lres = getLong_4(); + if (lres != (BIG_ENDIAN ? 0x445566778899aabbL : 0x8899aabb44556677L)) { + throw new Exception(lres + " != " + (BIG_ENDIAN ? 0x445566778899aabbL : 0x8899aabb44556677L)); + } + } + + for (int i = 0; i < ITERS; i++) { + putLong_8(BIG_ENDIAN ? 0x8899aabbccddeeffL : 0xccddeeff8899aabbL); + lres = getLong_8(); + if (lres != (BIG_ENDIAN ? 0x8899aabbccddeeffL : 0xccddeeff8899aabbL)) { + throw new Exception(lres + " != " + (BIG_ENDIAN ? 0x8899aabbccddeeffL : 0xccddeeff8899aabbL)); + } + } + + for (int i = 0; i < ITERS; i++) { + putLong_17(BIG_ENDIAN ? 0x23456789abcdef01L : 0x6789abcdef012345L); + lres = getLong_17(); + if (lres != (BIG_ENDIAN ? 0x23456789abcdef01L : 0x6789abcdef012345L)) { + throw new Exception(lres + " != " + (BIG_ENDIAN ? 0x23456789abcdef01L : 0x6789abcdef012345L)); + } + } + } + +} diff --git a/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestByte.java b/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestByte.java index 24ab3f86ff9..e15bd64089d 100644 --- a/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestByte.java +++ b/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestByte.java @@ -145,16 +145,16 @@ public class SunMiscUnsafeAccessTestByte { static void testAccess(Object base, long offset) { // Plain { - UNSAFE.putByte(base, offset, (byte)1); + UNSAFE.putByte(base, offset, (byte)0x01); byte x = UNSAFE.getByte(base, offset); - assertEquals(x, (byte)1, "set byte value"); + assertEquals(x, (byte)0x01, "set byte value"); } // Volatile { - UNSAFE.putByteVolatile(base, offset, (byte)2); + UNSAFE.putByteVolatile(base, offset, (byte)0x23); byte x = UNSAFE.getByteVolatile(base, offset); - assertEquals(x, (byte)2, "putVolatile byte value"); + assertEquals(x, (byte)0x23, "putVolatile byte value"); } @@ -166,9 +166,9 @@ public class SunMiscUnsafeAccessTestByte { static void testAccess(long address) { // Plain { - UNSAFE.putByte(address, (byte)1); + UNSAFE.putByte(address, (byte)0x01); byte x = UNSAFE.getByte(address); - assertEquals(x, (byte)1, "set byte value"); + assertEquals(x, (byte)0x01, "set byte value"); } } } diff --git a/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestChar.java b/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestChar.java index 70004792886..3c349085127 100644 --- a/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestChar.java +++ b/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestChar.java @@ -145,16 +145,16 @@ public class SunMiscUnsafeAccessTestChar { static void testAccess(Object base, long offset) { // Plain { - UNSAFE.putChar(base, offset, 'a'); + UNSAFE.putChar(base, offset, '\u0123'); char x = UNSAFE.getChar(base, offset); - assertEquals(x, 'a', "set char value"); + assertEquals(x, '\u0123', "set char value"); } // Volatile { - UNSAFE.putCharVolatile(base, offset, 'b'); + UNSAFE.putCharVolatile(base, offset, '\u4567'); char x = UNSAFE.getCharVolatile(base, offset); - assertEquals(x, 'b', "putVolatile char value"); + assertEquals(x, '\u4567', "putVolatile char value"); } @@ -166,9 +166,9 @@ public class SunMiscUnsafeAccessTestChar { static void testAccess(long address) { // Plain { - UNSAFE.putChar(address, 'a'); + UNSAFE.putChar(address, '\u0123'); char x = UNSAFE.getChar(address); - assertEquals(x, 'a', "set char value"); + assertEquals(x, '\u0123', "set char value"); } } } diff --git a/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestInt.java b/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestInt.java index 4310a6e49ec..5b505ad3d05 100644 --- a/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestInt.java +++ b/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestInt.java @@ -145,71 +145,71 @@ public class SunMiscUnsafeAccessTestInt { static void testAccess(Object base, long offset) { // Plain { - UNSAFE.putInt(base, offset, 1); + UNSAFE.putInt(base, offset, 0x01234567); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 1, "set int value"); + assertEquals(x, 0x01234567, "set int value"); } // Volatile { - UNSAFE.putIntVolatile(base, offset, 2); + UNSAFE.putIntVolatile(base, offset, 0x89ABCDEF); int x = UNSAFE.getIntVolatile(base, offset); - assertEquals(x, 2, "putVolatile int value"); + assertEquals(x, 0x89ABCDEF, "putVolatile int value"); } // Lazy { - UNSAFE.putOrderedInt(base, offset, 1); + UNSAFE.putOrderedInt(base, offset, 0x01234567); int x = UNSAFE.getIntVolatile(base, offset); - assertEquals(x, 1, "putRelease int value"); + assertEquals(x, 0x01234567, "putRelease int value"); } - UNSAFE.putInt(base, offset, 1); + UNSAFE.putInt(base, offset, 0x01234567); // Compare { - boolean r = UNSAFE.compareAndSwapInt(base, offset, 1, 2); + boolean r = UNSAFE.compareAndSwapInt(base, offset, 0x01234567, 0x89ABCDEF); assertEquals(r, true, "success compareAndSwap int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 2, "success compareAndSwap int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndSwap int value"); } { - boolean r = UNSAFE.compareAndSwapInt(base, offset, 1, 3); + boolean r = UNSAFE.compareAndSwapInt(base, offset, 0x01234567, 0xCAFEBABE); assertEquals(r, false, "failing compareAndSwap int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 2, "failing compareAndSwap int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndSwap int value"); } - UNSAFE.putInt(base, offset, 2); + UNSAFE.putInt(base, offset, 0x89ABCDEF); // Compare set and get { - int o = UNSAFE.getAndSetInt(base, offset, 1); - assertEquals(o, 2, "getAndSet int"); + int o = UNSAFE.getAndSetInt(base, offset, 0x01234567); + assertEquals(o, 0x89ABCDEF, "getAndSet int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 1, "getAndSet int value"); + assertEquals(x, 0x01234567, "getAndSet int value"); } - UNSAFE.putInt(base, offset, 1); + UNSAFE.putInt(base, offset, 0x01234567); // get and add, add and get { - int o = UNSAFE.getAndAddInt(base, offset, 2); - assertEquals(o, 1, "getAndAdd int"); + int o = UNSAFE.getAndAddInt(base, offset, 0x89ABCDEF); + assertEquals(o, 0x01234567, "getAndAdd int"); int x = UNSAFE.getInt(base, offset); - assertEquals(x, 1 + 2, "getAndAdd int"); + assertEquals(x, (int)(0x01234567 + 0x89ABCDEF), "getAndAdd int"); } } static void testAccess(long address) { // Plain { - UNSAFE.putInt(address, 1); + UNSAFE.putInt(address, 0x01234567); int x = UNSAFE.getInt(address); - assertEquals(x, 1, "set int value"); + assertEquals(x, 0x01234567, "set int value"); } } } diff --git a/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestLong.java b/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestLong.java index 6dd6434c774..2864b042886 100644 --- a/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestLong.java +++ b/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestLong.java @@ -145,71 +145,71 @@ public class SunMiscUnsafeAccessTestLong { static void testAccess(Object base, long offset) { // Plain { - UNSAFE.putLong(base, offset, 1L); + UNSAFE.putLong(base, offset, 0x0123456789ABCDEFL); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 1L, "set long value"); + assertEquals(x, 0x0123456789ABCDEFL, "set long value"); } // Volatile { - UNSAFE.putLongVolatile(base, offset, 2L); + UNSAFE.putLongVolatile(base, offset, 0xCAFEBABECAFEBABEL); long x = UNSAFE.getLongVolatile(base, offset); - assertEquals(x, 2L, "putVolatile long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "putVolatile long value"); } // Lazy { - UNSAFE.putOrderedLong(base, offset, 1L); + UNSAFE.putOrderedLong(base, offset, 0x0123456789ABCDEFL); long x = UNSAFE.getLongVolatile(base, offset); - assertEquals(x, 1L, "putRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "putRelease long value"); } - UNSAFE.putLong(base, offset, 1L); + UNSAFE.putLong(base, offset, 0x0123456789ABCDEFL); // Compare { - boolean r = UNSAFE.compareAndSwapLong(base, offset, 1L, 2L); + boolean r = UNSAFE.compareAndSwapLong(base, offset, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); assertEquals(r, true, "success compareAndSwap long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 2L, "success compareAndSwap long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndSwap long value"); } { - boolean r = UNSAFE.compareAndSwapLong(base, offset, 1L, 3L); + boolean r = UNSAFE.compareAndSwapLong(base, offset, 0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); assertEquals(r, false, "failing compareAndSwap long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 2L, "failing compareAndSwap long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndSwap long value"); } - UNSAFE.putLong(base, offset, 2L); + UNSAFE.putLong(base, offset, 0xCAFEBABECAFEBABEL); // Compare set and get { - long o = UNSAFE.getAndSetLong(base, offset, 1L); - assertEquals(o, 2L, "getAndSet long"); + long o = UNSAFE.getAndSetLong(base, offset, 0x0123456789ABCDEFL); + assertEquals(o, 0xCAFEBABECAFEBABEL, "getAndSet long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 1L, "getAndSet long value"); + assertEquals(x, 0x0123456789ABCDEFL, "getAndSet long value"); } - UNSAFE.putLong(base, offset, 1L); + UNSAFE.putLong(base, offset, 0x0123456789ABCDEFL); // get and add, add and get { - long o = UNSAFE.getAndAddLong(base, offset, 2L); - assertEquals(o, 1L, "getAndAdd long"); + long o = UNSAFE.getAndAddLong(base, offset, 0xCAFEBABECAFEBABEL); + assertEquals(o, 0x0123456789ABCDEFL, "getAndAdd long"); long x = UNSAFE.getLong(base, offset); - assertEquals(x, 1L + 2L, "getAndAdd long"); + assertEquals(x, (long)(0x0123456789ABCDEFL + 0xCAFEBABECAFEBABEL), "getAndAdd long"); } } static void testAccess(long address) { // Plain { - UNSAFE.putLong(address, 1L); + UNSAFE.putLong(address, 0x0123456789ABCDEFL); long x = UNSAFE.getLong(address); - assertEquals(x, 1L, "set long value"); + assertEquals(x, 0x0123456789ABCDEFL, "set long value"); } } } diff --git a/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestShort.java b/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestShort.java index c8c7284e905..4d43464e312 100644 --- a/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestShort.java +++ b/hotspot/test/compiler/unsafe/SunMiscUnsafeAccessTestShort.java @@ -145,16 +145,16 @@ public class SunMiscUnsafeAccessTestShort { static void testAccess(Object base, long offset) { // Plain { - UNSAFE.putShort(base, offset, (short)1); + UNSAFE.putShort(base, offset, (short)0x0123); short x = UNSAFE.getShort(base, offset); - assertEquals(x, (short)1, "set short value"); + assertEquals(x, (short)0x0123, "set short value"); } // Volatile { - UNSAFE.putShortVolatile(base, offset, (short)2); + UNSAFE.putShortVolatile(base, offset, (short)0x4567); short x = UNSAFE.getShortVolatile(base, offset); - assertEquals(x, (short)2, "putVolatile short value"); + assertEquals(x, (short)0x4567, "putVolatile short value"); } @@ -166,9 +166,9 @@ public class SunMiscUnsafeAccessTestShort { static void testAccess(long address) { // Plain { - UNSAFE.putShort(address, (short)1); + UNSAFE.putShort(address, (short)0x0123); short x = UNSAFE.getShort(address); - assertEquals(x, (short)1, "set short value"); + assertEquals(x, (short)0x0123, "set short value"); } } } diff --git a/hotspot/test/compiler/unsafe/X-UnsafeAccessTest.java.template b/hotspot/test/compiler/unsafe/X-UnsafeAccessTest.java.template index 19c3bfa7ef0..2d1743ed607 100644 --- a/hotspot/test/compiler/unsafe/X-UnsafeAccessTest.java.template +++ b/hotspot/test/compiler/unsafe/X-UnsafeAccessTest.java.template @@ -333,7 +333,7 @@ public class $Qualifier$UnsafeAccessTest$Type$ { $type$ o = UNSAFE.getAndAdd$Type$(base, offset, $value2$); assertEquals(o, $value1$, "getAndAdd $type$"); $type$ x = UNSAFE.get$Type$(base, offset); - assertEquals(x, $value1$ + $value2$, "getAndAdd $type$"); + assertEquals(x, ($type$)($value1$ + $value2$), "getAndAdd $type$"); } #end[AtomicAdd] } diff --git a/hotspot/test/compiler/unsafe/generate-unsafe-access-tests.sh b/hotspot/test/compiler/unsafe/generate-unsafe-access-tests.sh index 100283f245b..ef75a79b8f3 100644 --- a/hotspot/test/compiler/unsafe/generate-unsafe-access-tests.sh +++ b/hotspot/test/compiler/unsafe/generate-unsafe-access-tests.sh @@ -53,6 +53,19 @@ function generate { ;; esac + if [ "$package" == "jdk.internal.misc" ]; then + case $type in + boolean|byte|char|short|float|double) + args="$args -KCAS" + ;; + esac + case $type in + byte|char|short|float|double) + args="$args -KAtomicAdd" + ;; + esac + fi + case $type in short|char|int|long) args="$args -KUnaligned" @@ -66,29 +79,29 @@ function generate { value3=false ;; byte) - value1=(byte)1 - value2=(byte)2 - value3=(byte)3 + value1=(byte)0x01 + value2=(byte)0x23 + value3=(byte)0x45 ;; short) - value1=(short)1 - value2=(short)2 - value3=(short)3 + value1=(short)0x0123 + value2=(short)0x4567 + value3=(short)0x89AB ;; char) - value1=\'a\' - value2=\'b\' - value3=\'c\' + value1=\'\\\\u0123\' + value2=\'\\\\u4567\' + value3=\'\\\\u89AB\' ;; int) - value1=1 - value2=2 - value3=3 + value1=0x01234567 + value2=0x89ABCDEF + value3=0xCAFEBABE ;; long) - value1=1L - value2=2L - value3=3L + value1=0x0123456789ABCDEFL + value2=0xCAFEBABECAFEBABEL + value3=0xDEADBEEFDEADBEEFL ;; float) value1=1.0f diff --git a/hotspot/test/gc/TestCardTablePageCommits.java b/hotspot/test/gc/TestCardTablePageCommits.java index b3b4e13a898..3577ebfe8fa 100644 --- a/hotspot/test/gc/TestCardTablePageCommits.java +++ b/hotspot/test/gc/TestCardTablePageCommits.java @@ -31,7 +31,7 @@ import jdk.test.lib.Platform; * @key gc * @bug 8059066 * @summary Tests that the card table does not commit the same page twice - * @requires vm.gc=="Parallel" | vm.gc=="null" + * @requires vm.gc.Parallel * @library /testlibrary * @modules java.base/jdk.internal.misc * java.management diff --git a/hotspot/test/gc/arguments/TestCMSHeapSizeFlags.java b/hotspot/test/gc/arguments/TestCMSHeapSizeFlags.java index 2e9e329f9d4..4e5fa74818c 100644 --- a/hotspot/test/gc/arguments/TestCMSHeapSizeFlags.java +++ b/hotspot/test/gc/arguments/TestCMSHeapSizeFlags.java @@ -25,7 +25,7 @@ * @test TestCMSHeapSizeFlags * @key gc * @bug 8006088 - * @requires vm.gc=="ConcMarkSweep" | vm.gc=="null" + * @requires vm.gc.ConcMarkSweep * @summary Tests argument processing for initial and maximum heap size for the CMS collector * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/arguments/TestG1ConcMarkStepDurationMillis.java b/hotspot/test/gc/arguments/TestG1ConcMarkStepDurationMillis.java index 9a1eb442905..bd9e73a6b49 100644 --- a/hotspot/test/gc/arguments/TestG1ConcMarkStepDurationMillis.java +++ b/hotspot/test/gc/arguments/TestG1ConcMarkStepDurationMillis.java @@ -1,5 +1,5 @@ /* -* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +* Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,7 +24,7 @@ /* * @test TestG1ConcMarkStepDurationMillis * @key gc - * @requires vm.gc=="null" | vm.gc=="G1" + * @requires vm.gc.G1 * @summary Tests argument processing for double type flag, G1ConcMarkStepDurationMillis * @library /testlibrary * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/arguments/TestG1ConcRefinementThreads.java b/hotspot/test/gc/arguments/TestG1ConcRefinementThreads.java index 25b8e34414a..fb91b9e4154 100644 --- a/hotspot/test/gc/arguments/TestG1ConcRefinementThreads.java +++ b/hotspot/test/gc/arguments/TestG1ConcRefinementThreads.java @@ -25,7 +25,7 @@ * @test TestG1ConcRefinementThreads * @key gc * @bug 8047976 - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @summary Tests argument processing for G1ConcRefinementThreads * @library /testlibrary * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/arguments/TestG1HeapRegionSize.java b/hotspot/test/gc/arguments/TestG1HeapRegionSize.java index 1864a472ea5..7dd0fc5aa54 100644 --- a/hotspot/test/gc/arguments/TestG1HeapRegionSize.java +++ b/hotspot/test/gc/arguments/TestG1HeapRegionSize.java @@ -1,5 +1,5 @@ /* -* Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved. +* Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,7 +25,7 @@ * @test TestG1HeapRegionSize * @key gc * @bug 8021879 - * @requires vm.gc=="null" | vm.gc=="G1" + * @requires vm.gc.G1 * @summary Verify that the flag G1HeapRegionSize is updated properly * @modules java.base/jdk.internal.misc * @modules java.management/sun.management diff --git a/hotspot/test/gc/arguments/TestG1HeapSizeFlags.java b/hotspot/test/gc/arguments/TestG1HeapSizeFlags.java index 440a963f318..034938862ec 100644 --- a/hotspot/test/gc/arguments/TestG1HeapSizeFlags.java +++ b/hotspot/test/gc/arguments/TestG1HeapSizeFlags.java @@ -25,7 +25,7 @@ * @test TestG1HeapSizeFlags * @key gc * @bug 8006088 - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @summary Tests argument processing for initial and maximum heap size for the G1 collector * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/arguments/TestG1PercentageOptions.java b/hotspot/test/gc/arguments/TestG1PercentageOptions.java index 27d1e0b9cf3..db193ef7184 100644 --- a/hotspot/test/gc/arguments/TestG1PercentageOptions.java +++ b/hotspot/test/gc/arguments/TestG1PercentageOptions.java @@ -25,7 +25,7 @@ * @test TestG1PercentageOptions * @key gc * @bug 8068942 - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @summary Test argument processing of various percentage options * @library /testlibrary * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/arguments/TestInitialTenuringThreshold.java b/hotspot/test/gc/arguments/TestInitialTenuringThreshold.java index 82a4dca1456..a25e19e88b1 100644 --- a/hotspot/test/gc/arguments/TestInitialTenuringThreshold.java +++ b/hotspot/test/gc/arguments/TestInitialTenuringThreshold.java @@ -25,7 +25,7 @@ * @test TestInitialTenuringThreshold * @key gc * @bug 8014765 - * @requires vm.gc=="Parallel" | vm.gc=="null" + * @requires vm.gc.Parallel * @summary Tests argument processing for initial tenuring threshold * @library /testlibrary * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/arguments/TestNewSizeThreadIncrease.java b/hotspot/test/gc/arguments/TestNewSizeThreadIncrease.java index ce5aa179e79..d10dcf69660 100644 --- a/hotspot/test/gc/arguments/TestNewSizeThreadIncrease.java +++ b/hotspot/test/gc/arguments/TestNewSizeThreadIncrease.java @@ -1,5 +1,5 @@ /* -* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +* Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -27,7 +27,7 @@ * @bug 8144527 * @summary Tests argument processing for NewSizeThreadIncrease * @library /testlibrary - * @requires vm.gc=="Serial" | vm.gc=="null" + * @requires vm.gc.Serial * @modules java.base/jdk.internal.misc * java.management */ diff --git a/hotspot/test/gc/arguments/TestObjectTenuringFlags.java b/hotspot/test/gc/arguments/TestObjectTenuringFlags.java index fde3e607177..b30b365b95d 100644 --- a/hotspot/test/gc/arguments/TestObjectTenuringFlags.java +++ b/hotspot/test/gc/arguments/TestObjectTenuringFlags.java @@ -25,7 +25,7 @@ * @test TestObjectTenuringFlags * @key gc * @bug 6521376 - * @requires vm.gc=="Parallel" | vm.gc=="null" + * @requires vm.gc.Parallel * @summary Tests argument processing for NeverTenure, AlwaysTenure, * and MaxTenuringThreshold * @library /testlibrary diff --git a/hotspot/test/gc/cms/DisableResizePLAB.java b/hotspot/test/gc/cms/DisableResizePLAB.java index d1e4e681eb1..c5509811262 100644 --- a/hotspot/test/gc/cms/DisableResizePLAB.java +++ b/hotspot/test/gc/cms/DisableResizePLAB.java @@ -1,5 +1,5 @@ /* -* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved. +* Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ * @key gc * @bug 8060467 * @author filipp.zhinkin@oracle.com, john.coomes@oracle.com - * @requires vm.gc=="ConcMarkSweep" | vm.gc=="null" + * @requires vm.gc.ConcMarkSweep * @summary Run CMS with PLAB resizing disabled and a small OldPLABSize * @run main/othervm -XX:+UseConcMarkSweepGC -XX:-ResizePLAB -XX:OldPLABSize=1k -Xmx256m -Xlog:gc=debug DisableResizePLAB */ diff --git a/hotspot/test/gc/cms/TestBubbleUpRef.java b/hotspot/test/gc/cms/TestBubbleUpRef.java index 58fdd710ebf..9cc5ffd2fd3 100644 --- a/hotspot/test/gc/cms/TestBubbleUpRef.java +++ b/hotspot/test/gc/cms/TestBubbleUpRef.java @@ -28,7 +28,7 @@ import java.util.ListIterator; /* * @test - * @requires vm.gc=="ConcMarkSweep" | vm.gc == "null" + * @requires vm.gc.ConcMarkSweep * @key cte_test * @bug 4950157 * @summary Stress the behavior of ergonomics when the heap is nearly full and diff --git a/hotspot/test/gc/cms/TestCMSScavengeBeforeRemark.java b/hotspot/test/gc/cms/TestCMSScavengeBeforeRemark.java index 91376c18ced..515a97a7f2e 100644 --- a/hotspot/test/gc/cms/TestCMSScavengeBeforeRemark.java +++ b/hotspot/test/gc/cms/TestCMSScavengeBeforeRemark.java @@ -1,5 +1,5 @@ /* -* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. +* Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,7 +25,7 @@ * @test TestCMSScavengeBeforeRemark * @key gc * @bug 8139868 - * @requires vm.gc=="ConcMarkSweep" | vm.gc=="null" + * @requires vm.gc.ConcMarkSweep * @summary Run CMS with CMSScavengeBeforeRemark * @run main/othervm -XX:+UseConcMarkSweepGC -XX:+CMSScavengeBeforeRemark -XX:+ExplicitGCInvokesConcurrent -Xmx256m -Xlog:gc=debug TestCMSScavengeBeforeRemark */ diff --git a/hotspot/test/gc/cms/TestMBeanCMS.java b/hotspot/test/gc/cms/TestMBeanCMS.java index 045ac3ce314..633c78a06ba 100644 --- a/hotspot/test/gc/cms/TestMBeanCMS.java +++ b/hotspot/test/gc/cms/TestMBeanCMS.java @@ -24,7 +24,7 @@ /* * @test TestMBeanCMS.java * @bug 6581734 - * @requires vm.gc=="ConcMarkSweep" | vm.gc=="null" + * @requires vm.gc.ConcMarkSweep * @summary CMS Old Gen's collection usage is zero after GC which is incorrect * @modules java.management * @run main/othervm -Xmx512m -verbose:gc -XX:+UseConcMarkSweepGC TestMBeanCMS diff --git a/hotspot/test/gc/g1/Test2GbHeap.java b/hotspot/test/gc/g1/Test2GbHeap.java index c81f69e4bd8..66bc2c74604 100644 --- a/hotspot/test/gc/g1/Test2GbHeap.java +++ b/hotspot/test/gc/g1/Test2GbHeap.java @@ -26,7 +26,7 @@ * @bug 8031686 * @summary Regression test to ensure we can start G1 with 2gb heap. * Skip test on 32 bit system: it typically does not support the many and large virtual memory reservations needed. - * @requires (vm.gc == "G1" | vm.gc == "null") + * @requires vm.gc.G1 * @requires vm.bits != "32" * @key gc * @key regression diff --git a/hotspot/test/gc/g1/TestGreyReclaimedHumongousObjects.java b/hotspot/test/gc/g1/TestGreyReclaimedHumongousObjects.java index f572ed0b757..3d5cea2457c 100644 --- a/hotspot/test/gc/g1/TestGreyReclaimedHumongousObjects.java +++ b/hotspot/test/gc/g1/TestGreyReclaimedHumongousObjects.java @@ -24,7 +24,7 @@ /* * @test TestGreyReclaimedHumongousObjects.java * @bug 8069367 - * @requires vm.gc == "G1" | vm.gc == "null" + * @requires vm.gc.G1 * @summary Test handling of marked but unscanned reclaimed humongous objects. * @key gc * @modules jdk.management diff --git a/hotspot/test/gc/g1/TestHumongousShrinkHeap.java b/hotspot/test/gc/g1/TestHumongousShrinkHeap.java index da1c08a1be8..62c452a715d 100644 --- a/hotspot/test/gc/g1/TestHumongousShrinkHeap.java +++ b/hotspot/test/gc/g1/TestHumongousShrinkHeap.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,7 +24,7 @@ /** * @test TestHumongousShrinkHeap * @bug 8036025 8056043 - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @summary Verify that heap shrinks after GC in the presence of fragmentation * due to humongous objects * @library /testlibrary diff --git a/hotspot/test/gc/g1/TestLargePageUseForAuxMemory.java b/hotspot/test/gc/g1/TestLargePageUseForAuxMemory.java index 463fadcbbb8..844e1524db5 100644 --- a/hotspot/test/gc/g1/TestLargePageUseForAuxMemory.java +++ b/hotspot/test/gc/g1/TestLargePageUseForAuxMemory.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -28,7 +28,7 @@ * @key gc * @modules java.base/jdk.internal.misc * @library /testlibrary /test/lib - * @requires (vm.gc=="G1" | vm.gc=="null") + * @requires vm.gc.G1 * @build jdk.test.lib.* sun.hotspot.WhiteBox * @build TestLargePageUseForAuxMemory * @run main ClassFileInstaller sun.hotspot.WhiteBox diff --git a/hotspot/test/gc/g1/TestNoEagerReclaimOfHumongousRegions.java b/hotspot/test/gc/g1/TestNoEagerReclaimOfHumongousRegions.java index 2fd5f6cba2f..5a1eefe7309 100644 --- a/hotspot/test/gc/g1/TestNoEagerReclaimOfHumongousRegions.java +++ b/hotspot/test/gc/g1/TestNoEagerReclaimOfHumongousRegions.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -27,7 +27,7 @@ * @summary Test to check that a live humongous object is not eagerly reclaimed. This is a regression test for * 8139424 and the test will crash if an eager reclaim occur. The test is not 100% deterministic and * might pass even if there are problems in the code, but it will never crash unless there is a problem. - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @key gc * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/TestPLABOutput.java b/hotspot/test/gc/g1/TestPLABOutput.java index f7d7cebf89c..2f53c5c8a8b 100644 --- a/hotspot/test/gc/g1/TestPLABOutput.java +++ b/hotspot/test/gc/g1/TestPLABOutput.java @@ -25,7 +25,7 @@ * @test TestPLABOutput * @bug 8140585 * @summary Check that G1 does not report empty PLAB statistics in the first evacuation. - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @key gc * @modules java.base/jdk.internal.misc * @library /testlibrary /test/lib diff --git a/hotspot/test/gc/g1/TestPLABSizeBounds.java b/hotspot/test/gc/g1/TestPLABSizeBounds.java index df1c05e8888..e4faca68e44 100644 --- a/hotspot/test/gc/g1/TestPLABSizeBounds.java +++ b/hotspot/test/gc/g1/TestPLABSizeBounds.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,7 +25,7 @@ * @test TestPLABSizeBounds * @bug 8134857 * @summary Regression test to ensure that G1 supports PLAB sizes of half a region size. - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @key gc * @library /testlibrary * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/TestRegionAlignment.java b/hotspot/test/gc/g1/TestRegionAlignment.java index 7c7600f8be1..dea1e90b50d 100644 --- a/hotspot/test/gc/g1/TestRegionAlignment.java +++ b/hotspot/test/gc/g1/TestRegionAlignment.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,7 +24,7 @@ /* * @test TestRegionAlignment.java * @bug 8013791 - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @summary Make sure that G1 ergonomics pick a heap size that is aligned with the region size * @run main/othervm -XX:+UseG1GC -XX:G1HeapRegionSize=32m -XX:MaxRAM=555m TestRegionAlignment * diff --git a/hotspot/test/gc/g1/TestRegionLivenessPrint.java b/hotspot/test/gc/g1/TestRegionLivenessPrint.java index 9abbe4c1570..8e79b1efe32 100644 --- a/hotspot/test/gc/g1/TestRegionLivenessPrint.java +++ b/hotspot/test/gc/g1/TestRegionLivenessPrint.java @@ -24,7 +24,7 @@ /* * @test TestRegionLivenessPrint.java * @bug 8151920 - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @summary Make sure that G1 does not assert when printing region liveness data on a humongous continues region. * @key gc * @library /testlibrary /test/lib diff --git a/hotspot/test/gc/g1/TestRemsetLogging.java b/hotspot/test/gc/g1/TestRemsetLogging.java index 77d8b492386..146a16f9a87 100644 --- a/hotspot/test/gc/g1/TestRemsetLogging.java +++ b/hotspot/test/gc/g1/TestRemsetLogging.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,7 +23,7 @@ /* * @test TestRemsetLogging.java - * @requires vm.gc=="G1" | vm.gc =="null" + * @requires vm.gc.G1 * @bug 8013895 8129977 8145534 * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/TestRemsetLoggingPerRegion.java b/hotspot/test/gc/g1/TestRemsetLoggingPerRegion.java index 7567caf8e44..e60d191940c 100644 --- a/hotspot/test/gc/g1/TestRemsetLoggingPerRegion.java +++ b/hotspot/test/gc/g1/TestRemsetLoggingPerRegion.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,7 +23,7 @@ /* * @test TestRemsetLoggingPerRegion.java - * @requires vm.gc=="G1" | vm.gc =="null" + * @requires vm.gc.G1 * @bug 8014078 8129977 8145534 * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/TestRemsetLoggingThreads.java b/hotspot/test/gc/g1/TestRemsetLoggingThreads.java index c26727f9d83..2f0c712a87c 100644 --- a/hotspot/test/gc/g1/TestRemsetLoggingThreads.java +++ b/hotspot/test/gc/g1/TestRemsetLoggingThreads.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,7 +23,7 @@ /* * @test TestRemsetLoggingThreads - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @bug 8025441 8145534 * @key gc * @library /testlibrary diff --git a/hotspot/test/gc/g1/TestShrinkAuxiliaryData00.java b/hotspot/test/gc/g1/TestShrinkAuxiliaryData00.java index c013c903121..baed161da93 100644 --- a/hotspot/test/gc/g1/TestShrinkAuxiliaryData00.java +++ b/hotspot/test/gc/g1/TestShrinkAuxiliaryData00.java @@ -26,7 +26,7 @@ * @bug 8038423 8061715 * @summary Checks that decommitment occurs for JVM with different * G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @requires vm.opt.AggressiveOpts=="false" | vm.opt.AggressiveOpts=="null" * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/TestShrinkAuxiliaryData05.java b/hotspot/test/gc/g1/TestShrinkAuxiliaryData05.java index d12dc31769a..846f91de654 100644 --- a/hotspot/test/gc/g1/TestShrinkAuxiliaryData05.java +++ b/hotspot/test/gc/g1/TestShrinkAuxiliaryData05.java @@ -26,7 +26,7 @@ * @bug 8038423 8061715 8078405 * @summary Checks that decommitment occurs for JVM with different * G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @requires vm.opt.AggressiveOpts=="false" | vm.opt.AggressiveOpts=="null" * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/TestShrinkAuxiliaryData10.java b/hotspot/test/gc/g1/TestShrinkAuxiliaryData10.java index e530a73186a..05b041da715 100644 --- a/hotspot/test/gc/g1/TestShrinkAuxiliaryData10.java +++ b/hotspot/test/gc/g1/TestShrinkAuxiliaryData10.java @@ -26,7 +26,7 @@ * @bug 8038423 8061715 8078405 * @summary Checks that decommitment occurs for JVM with different * G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @requires vm.opt.AggressiveOpts=="false" | vm.opt.AggressiveOpts=="null" * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/TestShrinkAuxiliaryData15.java b/hotspot/test/gc/g1/TestShrinkAuxiliaryData15.java index bae6d66da80..ec0623bdf58 100644 --- a/hotspot/test/gc/g1/TestShrinkAuxiliaryData15.java +++ b/hotspot/test/gc/g1/TestShrinkAuxiliaryData15.java @@ -26,7 +26,7 @@ * @bug 8038423 8061715 8078405 * @summary Checks that decommitment occurs for JVM with different * G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @requires vm.opt.AggressiveOpts=="false" | vm.opt.AggressiveOpts=="null" * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/TestShrinkAuxiliaryData20.java b/hotspot/test/gc/g1/TestShrinkAuxiliaryData20.java index b9f6834a271..a89eb284a9d 100644 --- a/hotspot/test/gc/g1/TestShrinkAuxiliaryData20.java +++ b/hotspot/test/gc/g1/TestShrinkAuxiliaryData20.java @@ -26,7 +26,7 @@ * @bug 8038423 8061715 8078405 * @summary Checks that decommitment occurs for JVM with different * G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @requires vm.opt.AggressiveOpts=="false" | vm.opt.AggressiveOpts=="null" * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/TestShrinkAuxiliaryData25.java b/hotspot/test/gc/g1/TestShrinkAuxiliaryData25.java index 3b5382af5c8..50d5d912169 100644 --- a/hotspot/test/gc/g1/TestShrinkAuxiliaryData25.java +++ b/hotspot/test/gc/g1/TestShrinkAuxiliaryData25.java @@ -26,7 +26,7 @@ * @bug 8038423 8061715 8078405 * @summary Checks that decommitment occurs for JVM with different * G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @requires vm.opt.AggressiveOpts=="false" | vm.opt.AggressiveOpts=="null" * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/TestShrinkAuxiliaryData30.java b/hotspot/test/gc/g1/TestShrinkAuxiliaryData30.java index 9007d909c0d..6432cdad2e0 100644 --- a/hotspot/test/gc/g1/TestShrinkAuxiliaryData30.java +++ b/hotspot/test/gc/g1/TestShrinkAuxiliaryData30.java @@ -26,7 +26,7 @@ * @bug 8038423 8061715 8078405 * @summary Checks that decommitment occurs for JVM with different * G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @requires vm.opt.AggressiveOpts=="false" | vm.opt.AggressiveOpts=="null" * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/TestShrinkToOneRegion.java b/hotspot/test/gc/g1/TestShrinkToOneRegion.java index 0821223c6c0..c5e3f38d146 100644 --- a/hotspot/test/gc/g1/TestShrinkToOneRegion.java +++ b/hotspot/test/gc/g1/TestShrinkToOneRegion.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,7 +24,7 @@ /* * @test TestShrinkToOneRegion.java * @bug 8013872 - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @summary Shrinking the heap down to one region used to hit an assert * @run main/othervm -XX:+UseG1GC -XX:G1HeapRegionSize=32m -Xmx256m TestShrinkToOneRegion * diff --git a/hotspot/test/gc/g1/humongousObjects/TestHeapCounters.java b/hotspot/test/gc/g1/humongousObjects/TestHeapCounters.java index 7fe5262b7f8..28bc484f4a2 100644 --- a/hotspot/test/gc/g1/humongousObjects/TestHeapCounters.java +++ b/hotspot/test/gc/g1/humongousObjects/TestHeapCounters.java @@ -37,7 +37,7 @@ import java.util.List; /** * @test TestHeapCounters * @summary Checks that heap counters work as expected after humongous allocations/deallocations - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * @modules java.management diff --git a/hotspot/test/gc/g1/humongousObjects/TestHumongousClassLoader.java b/hotspot/test/gc/g1/humongousObjects/TestHumongousClassLoader.java index 03952363fb4..86bc2d22c9f 100644 --- a/hotspot/test/gc/g1/humongousObjects/TestHumongousClassLoader.java +++ b/hotspot/test/gc/g1/humongousObjects/TestHumongousClassLoader.java @@ -38,7 +38,7 @@ import java.nio.file.Paths; /** * @test gc.g1.humongousObjects.TestHumongousClassLoader * @summary Checks that unreachable classes and unreachable humongous class loader are unloaded after GC - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @requires vm.opt.G1HeapRegionSize == "null" | vm.opt.G1HeapRegionSize == "1M" * @requires vm.opt.ExplicitGCInvokesConcurrent != true * @library /testlibrary /test/lib / diff --git a/hotspot/test/gc/g1/humongousObjects/TestHumongousMovement.java b/hotspot/test/gc/g1/humongousObjects/TestHumongousMovement.java index a7d1cc852e8..a90c98d6953 100644 --- a/hotspot/test/gc/g1/humongousObjects/TestHumongousMovement.java +++ b/hotspot/test/gc/g1/humongousObjects/TestHumongousMovement.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -39,7 +39,7 @@ import java.util.stream.Collectors; /** * @test TestHumongousMovement * @summary Checks that Humongous objects are not moved during GC - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * @modules java.management diff --git a/hotspot/test/gc/g1/humongousObjects/TestHumongousNonArrayAllocation.java b/hotspot/test/gc/g1/humongousObjects/TestHumongousNonArrayAllocation.java index e1ad30c56f0..fcc9d7dedd3 100644 --- a/hotspot/test/gc/g1/humongousObjects/TestHumongousNonArrayAllocation.java +++ b/hotspot/test/gc/g1/humongousObjects/TestHumongousNonArrayAllocation.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -37,7 +37,7 @@ import java.nio.file.Paths; /** * @test gc.g1.humongousObjects.TestHumongousNonArrayAllocation * @summary Checks that huge class' instances (ie with huge amount of fields) are allocated successfully - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @requires vm.opt.G1HeapRegionSize == "null" | vm.opt.G1HeapRegionSize == "1M" * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/humongousObjects/TestHumongousThreshold.java b/hotspot/test/gc/g1/humongousObjects/TestHumongousThreshold.java index 8ff4a568600..cc1660e540e 100644 --- a/hotspot/test/gc/g1/humongousObjects/TestHumongousThreshold.java +++ b/hotspot/test/gc/g1/humongousObjects/TestHumongousThreshold.java @@ -31,7 +31,7 @@ import sun.hotspot.WhiteBox; /** * @test TestHumongousThreshold * @summary Checks that objects larger than half a region are allocated as humongous - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * @modules java.management diff --git a/hotspot/test/gc/g1/humongousObjects/TestObjectCollected.java b/hotspot/test/gc/g1/humongousObjects/TestObjectCollected.java index f5f5484b946..0cf5e2ce8d3 100644 --- a/hotspot/test/gc/g1/humongousObjects/TestObjectCollected.java +++ b/hotspot/test/gc/g1/humongousObjects/TestObjectCollected.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -37,7 +37,7 @@ import java.lang.ref.WeakReference; * @test TestObjectCollected * @summary checks that after different type of GCs weak/soft references to humongous object behave correspondingly to * actual object behavior - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc * @modules java.management diff --git a/hotspot/test/gc/g1/humongousObjects/objectGraphTest/TestObjectGraphAfterGC.java b/hotspot/test/gc/g1/humongousObjects/objectGraphTest/TestObjectGraphAfterGC.java index 8e028973547..c7a4f2ff081 100644 --- a/hotspot/test/gc/g1/humongousObjects/objectGraphTest/TestObjectGraphAfterGC.java +++ b/hotspot/test/gc/g1/humongousObjects/objectGraphTest/TestObjectGraphAfterGC.java @@ -48,7 +48,7 @@ import java.util.stream.Collectors; /** * @test TestObjectGraphAfterGC * @summary Checks that objects' graph behave as expected after gc - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @requires vm.opt.ExplicitGCInvokesConcurrent != true * @library /testlibrary /test/lib / * @modules java.management java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/ihop/TestIHOPErgo.java b/hotspot/test/gc/g1/ihop/TestIHOPErgo.java index 0332844da07..f187d629842 100644 --- a/hotspot/test/gc/g1/ihop/TestIHOPErgo.java +++ b/hotspot/test/gc/g1/ihop/TestIHOPErgo.java @@ -25,7 +25,7 @@ * @test TestIHOPErgo * @bug 8148397 * @summary Test checks that behavior of Adaptive and Static IHOP at concurrent cycle initiation - * @requires vm.gc == "G1" | vm.gc == "null" + * @requires vm.gc.G1 * @requires !vm.flightRecorder * @requires vm.opt.ExplicitGCInvokesConcurrent != true * @requires vm.opt.MaxGCPauseMillis == "null" diff --git a/hotspot/test/gc/g1/ihop/TestIHOPStatic.java b/hotspot/test/gc/g1/ihop/TestIHOPStatic.java index 7fc78cf80fc..0529af84206 100644 --- a/hotspot/test/gc/g1/ihop/TestIHOPStatic.java +++ b/hotspot/test/gc/g1/ihop/TestIHOPStatic.java @@ -25,7 +25,7 @@ * @test TestIHOPStatic * @bug 8148397 * @summary Test checks concurrent cycle initiation which depends on IHOP value. - * @requires vm.gc == "G1" | vm.gc == "null" + * @requires vm.gc.G1 * @requires !vm.flightRecorder * @requires vm.opt.ExplicitGCInvokesConcurrent != true * @library /testlibrary / diff --git a/hotspot/test/gc/g1/mixedgc/TestLogging.java b/hotspot/test/gc/g1/mixedgc/TestLogging.java index 0e232a6f174..29fd37f3201 100644 --- a/hotspot/test/gc/g1/mixedgc/TestLogging.java +++ b/hotspot/test/gc/g1/mixedgc/TestLogging.java @@ -24,7 +24,7 @@ /* * @test TestLogging * @summary Check that a mixed GC is reflected in the gc logs - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @requires vm.opt.MaxGCPauseMillis == "null" * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/plab/TestPLABEvacuationFailure.java b/hotspot/test/gc/g1/plab/TestPLABEvacuationFailure.java index 6aa5834a79f..77f43d254a8 100644 --- a/hotspot/test/gc/g1/plab/TestPLABEvacuationFailure.java +++ b/hotspot/test/gc/g1/plab/TestPLABEvacuationFailure.java @@ -25,7 +25,7 @@ * @test TestPLABEvacuationFailure * @bug 8148376 * @summary Checks PLAB statistics on evacuation failure - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @library /testlibrary / * @modules java.base/jdk.internal.misc * @modules java.management diff --git a/hotspot/test/gc/g1/plab/TestPLABPromotion.java b/hotspot/test/gc/g1/plab/TestPLABPromotion.java index 0f4a84c5104..95177e8b876 100644 --- a/hotspot/test/gc/g1/plab/TestPLABPromotion.java +++ b/hotspot/test/gc/g1/plab/TestPLABPromotion.java @@ -25,7 +25,7 @@ * @test TestPLABPromotion * @bug 8141278 8141141 * @summary Test PLAB promotion - * @requires vm.gc == "G1" | vm.gc == "null" + * @requires vm.gc.G1 * @requires !vm.flightRecorder * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/g1/plab/TestPLABResize.java b/hotspot/test/gc/g1/plab/TestPLABResize.java index b065abb57e5..7b45914c1b9 100644 --- a/hotspot/test/gc/g1/plab/TestPLABResize.java +++ b/hotspot/test/gc/g1/plab/TestPLABResize.java @@ -25,7 +25,7 @@ * @test TestPLABResize * @bug 8141278 8141141 * @summary Test for PLAB resizing - * @requires vm.gc == "G1" | vm.gc == "null" + * @requires vm.gc.G1 * @requires !vm.flightRecorder * @library /testlibrary /test/lib / * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/metaspace/G1AddMetaspaceDependency.java b/hotspot/test/gc/metaspace/G1AddMetaspaceDependency.java index 5c6256290b7..544bc1c8a97 100644 --- a/hotspot/test/gc/metaspace/G1AddMetaspaceDependency.java +++ b/hotspot/test/gc/metaspace/G1AddMetaspaceDependency.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,7 +24,7 @@ /* * @test G1AddMetaspaceDependency * @bug 8010196 - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @summary Checks that we don't get locking problems when adding metaspace dependencies with the G1 update buffer monitor * @run main/othervm -XX:+UseG1GC -XX:G1UpdateBufferSize=1 G1AddMetaspaceDependency */ diff --git a/hotspot/test/gc/metaspace/TestPerfCountersAndMemoryPools.java b/hotspot/test/gc/metaspace/TestPerfCountersAndMemoryPools.java index 7a5e8c7da2c..d42e51afdd8 100644 --- a/hotspot/test/gc/metaspace/TestPerfCountersAndMemoryPools.java +++ b/hotspot/test/gc/metaspace/TestPerfCountersAndMemoryPools.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,7 +30,7 @@ import static jdk.test.lib.Asserts.*; /* @test TestPerfCountersAndMemoryPools * @bug 8023476 * @library /testlibrary - * @requires vm.gc=="Serial" | vm.gc=="null" + * @requires vm.gc.Serial * @summary Tests that a MemoryPoolMXBeans and PerfCounters for metaspace * report the same data. * @modules java.base/jdk.internal.misc diff --git a/hotspot/test/gc/parallel/TestDynShrinkHeap.java b/hotspot/test/gc/parallel/TestDynShrinkHeap.java index 809706f8e32..06534328c7c 100644 --- a/hotspot/test/gc/parallel/TestDynShrinkHeap.java +++ b/hotspot/test/gc/parallel/TestDynShrinkHeap.java @@ -24,7 +24,7 @@ /** * @test TestDynShrinkHeap * @bug 8016479 - * @requires vm.gc=="Parallel" | vm.gc=="null" + * @requires vm.gc.Parallel * @summary Verify that the heap shrinks after full GC according to the current values of the Min/MaxHeapFreeRatio flags * @modules java.base/jdk.internal.misc * @modules jdk.management diff --git a/hotspot/test/gc/parallel/TestPrintGCDetailsVerbose.java b/hotspot/test/gc/parallel/TestPrintGCDetailsVerbose.java index 17fd5ece8b2..e25e0cebc6b 100644 --- a/hotspot/test/gc/parallel/TestPrintGCDetailsVerbose.java +++ b/hotspot/test/gc/parallel/TestPrintGCDetailsVerbose.java @@ -26,7 +26,7 @@ * @bug 8016740 * @summary Tests that jvm with maximally verbose GC logging does not crash when ParOldGC has no memory * @key gc - * @requires vm.gc=="Parallel" | vm.gc=="null" + * @requires vm.gc.Parallel * @modules java.base/jdk.internal.misc * @library /testlibrary * @run main/othervm -Xmx50m -XX:+UseParallelGC -Xlog:gc*=trace TestPrintGCDetailsVerbose diff --git a/hotspot/test/gc/stress/TestMultiThreadStressRSet.java b/hotspot/test/gc/stress/TestMultiThreadStressRSet.java index 336b0614bd7..dcfdb6c29e8 100644 --- a/hotspot/test/gc/stress/TestMultiThreadStressRSet.java +++ b/hotspot/test/gc/stress/TestMultiThreadStressRSet.java @@ -31,7 +31,7 @@ import sun.hotspot.WhiteBox; /* * @test TestMultiThreadStressRSet.java * @key stress - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @requires os.maxMemory > 2G * @requires vm.opt.MaxGCPauseMillis == "null" * diff --git a/hotspot/test/gc/stress/TestStressG1Humongous.java b/hotspot/test/gc/stress/TestStressG1Humongous.java index de9e1be4555..6b507e40827 100644 --- a/hotspot/test/gc/stress/TestStressG1Humongous.java +++ b/hotspot/test/gc/stress/TestStressG1Humongous.java @@ -26,7 +26,7 @@ * @key gc * @key stress * @summary Stress G1 by humongous allocations in situation near OOM - * @requires vm.gc == "G1" | vm.gc == "null" + * @requires vm.gc.G1 * @requires !vm.flightRecorder * @run main/othervm/timeout=200 -Xlog:gc=debug -Xmx1g -XX:+UseG1GC -XX:G1HeapRegionSize=4m * -Dtimeout=120 -Dthreads=3 -Dhumongoussize=1.1 -Dregionsize=4 TestStressG1Humongous diff --git a/hotspot/test/gc/stress/TestStressIHOPMultiThread.java b/hotspot/test/gc/stress/TestStressIHOPMultiThread.java index b83422c0d7e..e0514b124f1 100644 --- a/hotspot/test/gc/stress/TestStressIHOPMultiThread.java +++ b/hotspot/test/gc/stress/TestStressIHOPMultiThread.java @@ -26,7 +26,7 @@ * @bug 8148397 * @key stress * @summary Stress test for IHOP - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @run main/othervm/timeout=200 -Xmx128m -XX:G1HeapWastePercent=0 -XX:G1MixedGCCountTarget=1 * -XX:+UseG1GC -XX:G1HeapRegionSize=1m -XX:+G1UseAdaptiveIHOP * -Xlog:gc+ihop=debug,gc+ihop+ergo=debug,gc+ergo=debug:TestStressIHOPMultiThread1.log diff --git a/hotspot/test/gc/stress/TestStressRSetCoarsening.java b/hotspot/test/gc/stress/TestStressRSetCoarsening.java index a0d581b0656..bb621bb28ff 100644 --- a/hotspot/test/gc/stress/TestStressRSetCoarsening.java +++ b/hotspot/test/gc/stress/TestStressRSetCoarsening.java @@ -28,7 +28,7 @@ import sun.hotspot.WhiteBox; * @test TestStressRSetCoarsening.java * @key stress * @bug 8146984 8147087 - * @requires vm.gc=="G1" | vm.gc=="null" + * @requires vm.gc.G1 * @requires os.maxMemory > 3G * @requires vm.opt.MaxGCPauseMillis == "null" * diff --git a/hotspot/test/gc/whitebox/TestConcMarkCycleWB.java b/hotspot/test/gc/whitebox/TestConcMarkCycleWB.java index 4c76852f25b..ea3b30af1b6 100644 --- a/hotspot/test/gc/whitebox/TestConcMarkCycleWB.java +++ b/hotspot/test/gc/whitebox/TestConcMarkCycleWB.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,7 +24,7 @@ /* * @test TestConMarkCycleWB * @bug 8065579 - * @requires vm.gc=="null" | vm.gc=="G1" + * @requires vm.gc.G1 * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc * java.compiler diff --git a/hotspot/test/native/runtime/test_classLoader.cpp b/hotspot/test/native/runtime/test_classLoader.cpp index 8ca5ba303d0..de37e59dbf5 100644 --- a/hotspot/test/native/runtime/test_classLoader.cpp +++ b/hotspot/test/native/runtime/test_classLoader.cpp @@ -22,6 +22,7 @@ * */ +#include "precompiled.hpp" #include "classfile/classLoader.hpp" #include "memory/resourceArea.hpp" #include "unittest.hpp" diff --git a/hotspot/test/native/runtime/test_globals.cpp b/hotspot/test/native/runtime/test_globals.cpp new file mode 100644 index 00000000000..3741b8edd8c --- /dev/null +++ b/hotspot/test/native/runtime/test_globals.cpp @@ -0,0 +1,74 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +#include "precompiled.hpp" +#include "runtime/globals.hpp" +#include "unittest.hpp" + +#define TEST_FLAG(f, type, value) \ + do { \ + ASSERT_TRUE(Flag::find_flag(#f)->is_ ## type()); \ + type original_value = f; \ + { \ + FLAG_GUARD(f); \ + f = value; \ + } \ + ASSERT_EQ(original_value, f); \ + } while (0) + +TEST_VM(FlagGuard, bool_flag) { + TEST_FLAG(AlwaysActAsServerClassMachine, bool, true); +} + +TEST_VM(FlagGuard, int_flag) { + TEST_FLAG(ParGCArrayScanChunk, int, 1337); +} + +TEST_VM(FlagGuard, intx_flag) { + TEST_FLAG(RefDiscoveryPolicy, intx, 1337); +} + +TEST_VM(FlagGuard, uint_flag) { + TEST_FLAG(ConcGCThreads, uint, 1337); +} + +TEST_VM(FlagGuard, uintx_flag) { + TEST_FLAG(GCTaskTimeStampEntries, uintx, 1337); +} + +TEST_VM(FlagGuard, size_t_flag) { + TEST_FLAG(HeapSizePerGCThread, size_t, 1337); +} + +TEST_VM(FlagGuard, uint64_t_flag) { + TEST_FLAG(MaxRAM, uint64_t, 1337); +} + +TEST_VM(FlagGuard, double_flag) { + TEST_FLAG(CompileThresholdScaling, double, 3.141569); +} + +TEST_VM(FlagGuard, ccstr_flag) { + TEST_FLAG(PerfDataSaveFile, ccstr, "/a/random/path"); +} diff --git a/hotspot/test/native/runtime/test_instanceKlass.cpp b/hotspot/test/native/runtime/test_instanceKlass.cpp index 179aae5b854..493a4e5d58c 100644 --- a/hotspot/test/native/runtime/test_instanceKlass.cpp +++ b/hotspot/test/native/runtime/test_instanceKlass.cpp @@ -22,6 +22,7 @@ * */ +#include "precompiled.hpp" #include "classfile/symbolTable.hpp" #include "memory/resourceArea.hpp" #include "oops/instanceKlass.hpp" diff --git a/hotspot/test/native/runtime/test_os.cpp b/hotspot/test/native/runtime/test_os.cpp index 734668501fb..d73879f3d5d 100644 --- a/hotspot/test/native/runtime/test_os.cpp +++ b/hotspot/test/native/runtime/test_os.cpp @@ -22,6 +22,7 @@ * */ +#include "precompiled.hpp" #include "runtime/os.hpp" #include "unittest.hpp" diff --git a/hotspot/test/native/unittest.hpp b/hotspot/test/native/unittest.hpp index 5f3f28eeecf..95ae7b9bb40 100644 --- a/hotspot/test/native/unittest.hpp +++ b/hotspot/test/native/unittest.hpp @@ -22,13 +22,25 @@ * */ +#ifndef UNITTEST_HPP +#define UNITTEST_HPP + #include #include #define GTEST_DONT_DEFINE_TEST 1 #include "gtest/gtest.h" + +// gtest/gtest.h includes assert.h which will define the assert macro, but hotspot has its +// own standards incompatible assert macro that takes two parameters. +// The workaround is to undef assert and then re-define it. The re-definition +// must unfortunately be copied since debug.hpp might already have been +// included and a second include wouldn't work due to the header guards in debug.hpp. #ifdef assert #undef assert + #ifdef vmassert + #define assert(p, ...) vmassert(p, __VA_ARGS__) + #endif #endif #define CONCAT(a, b) a ## b @@ -102,3 +114,5 @@ #define TEST_VM_ASSERT_MSG(...) \ TEST_VM_ASSERT_MSG is only available in debug builds #endif + +#endif // UNITTEST_HPP diff --git a/hotspot/test/native/utilities/test_quicksort.cpp b/hotspot/test/native/utilities/test_quicksort.cpp index 5a56c877786..323bbd968b0 100644 --- a/hotspot/test/native/utilities/test_quicksort.cpp +++ b/hotspot/test/native/utilities/test_quicksort.cpp @@ -22,6 +22,7 @@ * */ +#include "precompiled.hpp" #include "prims/jvm.h" #include "utilities/quickSort.hpp" #include "unittest.hpp" diff --git a/hotspot/test/runtime/ConstantPool/TestMethodHandleConstant.java b/hotspot/test/runtime/ConstantPool/TestMethodHandleConstant.java new file mode 100644 index 00000000000..0ed640992be --- /dev/null +++ b/hotspot/test/runtime/ConstantPool/TestMethodHandleConstant.java @@ -0,0 +1,45 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @bug 8159470 + * @summary Test that MethodHandle constants are checked + * @modules java.base/jdk.internal.misc + * @compile WithConfiguration.jcod + * @run main/othervm TestMethodHandleConstant + */ +public class TestMethodHandleConstant { + + public static void main(String[] args) { + try { + // This interface has bad constant pool entry for MethodHandle -> Method + String URI_DEFAULT + = WithConfiguration.autoDetect().getLocation(); + throw new RuntimeException("FAILED, ICCE not thrown"); + } catch (BootstrapMethodError icce) { + System.out.println("PASSED, expecting ICCE" + icce.getMessage()); + } + } +} + diff --git a/hotspot/test/runtime/ConstantPool/WithConfiguration.jcod b/hotspot/test/runtime/ConstantPool/WithConfiguration.jcod new file mode 100644 index 00000000000..7bb55bc1af1 --- /dev/null +++ b/hotspot/test/runtime/ConstantPool/WithConfiguration.jcod @@ -0,0 +1,170 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +// This class has a MethodHandle constant that points to an incompatible Methodref constant +// (should be InterfaceMethodref) +// Throws ICCE/BootstrapMethodError + +// public interface WithConfiguration { +// String getLocation(); +// static WithConfiguration autoDetect() { +// return () -> "$Default$"; +// } +// } + +class WithConfiguration { + 0xCAFEBABE; + 0; // minor version + 53; // version + [] { // Constant Pool + ; // first element is empty + InvokeDynamic 0s #18; // #1 + String #19; // #2 + class #20; // #3 + class #21; // #4 + Utf8 "getLocation"; // #5 + Utf8 "()Ljava/lang/String;"; // #6 + Utf8 "autoDetect"; // #7 + Utf8 "()LWithConfiguration;"; // #8 + Utf8 "Code"; // #9 + Utf8 "LineNumberTable"; // #10 + Utf8 "lambda$autoDetect$0"; // #11 + Utf8 "SourceFile"; // #12 + Utf8 "WithConfiguration.java"; // #13 + Utf8 "BootstrapMethods"; // #14 + MethodHandle 6b #22; // #15 + MethodType #6; // #16 + MethodHandle 6b #23; // #17 + NameAndType #5 #8; // #18 + Utf8 "$Default$"; // #19 + Utf8 "WithConfiguration"; // #20 + Utf8 "java/lang/Object"; // #21 + Method #24 #25; // #22 + Method #3 #26; // #23 THIS IS WRONG!! + class #27; // #24 + NameAndType #28 #32; // #25 + NameAndType #11 #6; // #26 + Utf8 "java/lang/invoke/LambdaMetafactory"; // #27 + Utf8 "metafactory"; // #28 + class #34; // #29 + Utf8 "Lookup"; // #30 + Utf8 "InnerClasses"; // #31 + Utf8 "(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;"; // #32 + class #35; // #33 + Utf8 "java/lang/invoke/MethodHandles$Lookup"; // #34 + Utf8 "java/lang/invoke/MethodHandles"; // #35 + } // Constant Pool + + 0x0601; // access + #3;// this_cpx + #4;// super_cpx + + [] { // Interfaces + } // Interfaces + + [] { // fields + } // fields + + [] { // methods + { // Member + 0x0401; // access + #5; // name_cpx + #6; // sig_cpx + [] { // Attributes + } // Attributes + } // Member + ; + { // Member + 0x0009; // access + #7; // name_cpx + #8; // sig_cpx + [] { // Attributes + Attr(#9) { // Code + 1; // max_stack + 0; // max_locals + Bytes[]{ + 0xBA00010000B0; + }; + [] { // Traps + } // end Traps + [] { // Attributes + Attr(#10) { // LineNumberTable + [] { // LineNumberTable + 0 26; + } + } // end LineNumberTable + } // Attributes + } // end Code + } // Attributes + } // Member + ; + { // Member + 0x100A; // access + #11; // name_cpx + #6; // sig_cpx + [] { // Attributes + Attr(#9) { // Code + 1; // max_stack + 0; // max_locals + Bytes[]{ + 0x1202B0; + }; + [] { // Traps + } // end Traps + [] { // Attributes + Attr(#10) { // LineNumberTable + [] { // LineNumberTable + 0 26; + } + } // end LineNumberTable + } // Attributes + } // end Code + } // Attributes + } // Member + } // methods + + [] { // Attributes + Attr(#12) { // SourceFile + #13; + } // end SourceFile + ; + Attr(#31) { // InnerClasses + [] { // InnerClasses + #29 #33 #30 25; + } + } // end InnerClasses + ; + Attr(#14) { // BootstrapMethods + [] { // bootstrap_methods + { // bootstrap_method + #15; // bootstrap_method_ref + [] { // bootstrap_arguments + #16; + #17; + #16; + } // bootstrap_arguments + } // bootstrap_method + } + } // end BootstrapMethods + } // Attributes +} // end class WithConfiguration diff --git a/hotspot/test/runtime/SharedArchiveFile/SharedStrings.java b/hotspot/test/runtime/SharedArchiveFile/SharedStrings.java index ec7bf3aaa1f..06feba0d586 100644 --- a/hotspot/test/runtime/SharedArchiveFile/SharedStrings.java +++ b/hotspot/test/runtime/SharedArchiveFile/SharedStrings.java @@ -28,7 +28,7 @@ * Feature support: G1GC only, compressed oops/kptrs, 64-bit os, not on windows * @requires (sun.arch.data.model != "32") & (os.family != "windows") * @requires (vm.opt.UseCompressedOops == null) | (vm.opt.UseCompressedOops == true) - * @requires (vm.gc=="G1" | vm.gc=="null") + * @requires vm.gc.G1 * @library /testlibrary /test/lib * @modules java.base/jdk.internal.misc * java.management diff --git a/hotspot/test/runtime/SharedArchiveFile/SharedStringsRunAuto.java b/hotspot/test/runtime/SharedArchiveFile/SharedStringsRunAuto.java index 1f90fd02931..d4290fe6568 100644 --- a/hotspot/test/runtime/SharedArchiveFile/SharedStringsRunAuto.java +++ b/hotspot/test/runtime/SharedArchiveFile/SharedStringsRunAuto.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -27,7 +27,7 @@ * Feature support: G1GC only, compressed oops/kptrs, 64-bit os, not on windows * @requires (sun.arch.data.model != "32") & (os.family != "windows") * @requires (vm.opt.UseCompressedOops == null) | (vm.opt.UseCompressedOops == true) - * @requires (vm.gc=="G1" | vm.gc=="null") + * @requires vm.gc.G1 * @library /testlibrary * @modules java.base/jdk.internal.misc * java.management diff --git a/hotspot/test/runtime/StackGuardPages/invoke.c b/hotspot/test/runtime/StackGuardPages/invoke.c index be09572e1c6..580e128bb22 100644 --- a/hotspot/test/runtime/StackGuardPages/invoke.c +++ b/hotspot/test/runtime/StackGuardPages/invoke.c @@ -221,7 +221,7 @@ int main (int argc, const char** argv) { printf("Test started with pid: %ld\n", (long) getpid()); options[0].optionString = "-Xint"; - options[1].optionString = "-Xss328k"; + options[1].optionString = "-Xss512k"; vm_args.version = JNI_VERSION_1_2; vm_args.ignoreUnrecognized = JNI_TRUE; diff --git a/hotspot/test/runtime/Throwable/StackTraceLogging.java b/hotspot/test/runtime/Throwable/StackTraceLogging.java index 9074ef4f709..053ab24511b 100644 --- a/hotspot/test/runtime/Throwable/StackTraceLogging.java +++ b/hotspot/test/runtime/Throwable/StackTraceLogging.java @@ -39,15 +39,10 @@ import jdk.test.lib.OutputAnalyzer; import jdk.test.lib.ProcessTools; public class StackTraceLogging { - static void updateEnvironment(ProcessBuilder pb, String environmentVariable, String value) { - Map env = pb.environment(); - env.put(environmentVariable, value); - } - static void analyzeOutputOn(ProcessBuilder pb) throws Exception { OutputAnalyzer output = new OutputAnalyzer(pb.start()); - // These depths match the ones in TestThrowable.java - int[] depths = {10, 34, 100, 1024}; + // These depths match the ones in TestThrowable.java, except the one greater than 1024 + int[] depths = {10, 34, 100, 1023, 1024}; for (int d : depths) { output.shouldContain("java.lang.RuntimeException, " + d); } diff --git a/hotspot/test/runtime/Throwable/TestThrowable.java b/hotspot/test/runtime/Throwable/TestThrowable.java index 9cdef2d4b89..052ed4604ed 100644 --- a/hotspot/test/runtime/Throwable/TestThrowable.java +++ b/hotspot/test/runtime/Throwable/TestThrowable.java @@ -38,7 +38,7 @@ public class TestThrowable { // Inner class that throws a lot of exceptions static class Thrower { static int MaxJavaStackTraceDepth = 1024; // as above - int[] depths = {10, 34, 100, 1024, 2042}; + int[] depths = {10, 34, 100, 1023, 1024, 1025}; int count = 0; int getDepth(Throwable t) throws Exception { diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/ByteCodeGenerator.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/ByteCodeGenerator.java index 94957ba3202..ef969bf0f55 100644 --- a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/ByteCodeGenerator.java +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/ByteCodeGenerator.java @@ -78,7 +78,7 @@ class ByteCodeGenerator extends TestsGenerator { } catch (Throwable t) { Path errFile = generatorDir.resolve(mainClassName + ".err"); try (PrintWriter pw = new PrintWriter(Files.newOutputStream(errFile, - StandardOpenOption.CREATE_NEW))) { + StandardOpenOption.CREATE, StandardOpenOption.WRITE))) { t.printStackTrace(pw); } catch (IOException e) { t.printStackTrace(); diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/IRNode.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/IRNode.java index 3ffa03e8669..c532d0cd3f8 100644 --- a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/IRNode.java +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/IRNode.java @@ -198,6 +198,31 @@ public abstract class IRNode { return result; } + public static long getModifiableNodesCount(List nodes) { + return nodes.stream() + .map(IRNode::getStackableLeaves) + .mapToInt(List::size) + .filter(i -> i > 0) + .count(); + } + + public static boolean tryToReduceNodesDepth(List nodes, int maxDepth) { + boolean allSucceed = true; + for (IRNode child : nodes) { + for (IRNode leaf : child.getDeviantBlocks(Math.max(child.countDepth(), maxDepth + 1))) { + if (child.countDepth() > maxDepth) { + // doesn't remove control deviation block. Just some parts. + leaf.removeSelf(); + boolean successfull = child.countDepth() > maxDepth; + allSucceed &= successfull; + } else { + break; + } + } + } + return allSucceed; + } + // TODO: add field instead this function public boolean isCFDeviation() { return this instanceof If || this instanceof Switch diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/factories/ClassDefinitionBlockFactory.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/factories/ClassDefinitionBlockFactory.java index 822c99fada8..f2c5af8ebc5 100644 --- a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/factories/ClassDefinitionBlockFactory.java +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/factories/ClassDefinitionBlockFactory.java @@ -102,11 +102,16 @@ class ClassDefinitionBlockFactory extends Factory { addMoreChildren(childs, content, minDepth); } - private void addMoreChildren(List childs, Collection content, int minDepth) - throws ProductionFailedException { - while (!childs.isEmpty() && IRNode.countDepth(content) < minDepth) { - PseudoRandom.shuffle(childs); - IRNode randomChild = childs.get(0); + private void addMoreChildren(List children, Collection content, int minDepth) + throws ProductionFailedException { + /* check situation when no stackable leaves available in all children */ + if (IRNode.getModifiableNodesCount(children) == 0L) { + return; + } + /* now let's try to add children */ + while (!children.isEmpty() && IRNode.countDepth(content) < minDepth) { + PseudoRandom.shuffle(children); + IRNode randomChild = children.get(0); List leaves = randomChild.getStackableLeaves(); if (!leaves.isEmpty()) { Block randomLeaf = (Block) leaves.get(PseudoRandom.randomNotNegative(leaves.size())); @@ -131,18 +136,11 @@ class ClassDefinitionBlockFactory extends Factory { private void ensureMaxDepth(Collection content) { int maxDepth = ProductionParams.maxCfgDepth.value(); - List childs = content.stream() + List childrenClasses = content.stream() .filter(c -> c instanceof Klass && c.countDepth() > maxDepth) .collect(Collectors.toList()); - for (IRNode ch : childs) { - List leaves; - do { - long depth = Math.max(ch.countDepth(), maxDepth + 1); - leaves = ch.getDeviantBlocks(depth); - if(leaves.size() > 0) { - leaves.get(0).removeSelf(); - } - } while (!leaves.isEmpty() && ch.countDepth() > maxDepth); - } + /* now attempt to reduce depth by removing optional parts of control deviation + blocks in case IRTree has oversized depth */ + IRNode.tryToReduceNodesDepth(childrenClasses, maxDepth); } } diff --git a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/factories/MainKlassFactory.java b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/factories/MainKlassFactory.java index 81a19675ca9..54237c5f1cc 100644 --- a/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/factories/MainKlassFactory.java +++ b/hotspot/test/testlibrary/jittester/src/jdk/test/lib/jittester/factories/MainKlassFactory.java @@ -112,19 +112,14 @@ class MainKlassFactory extends Factory { functionDefinitions, testFunction, printVariables); } - private void ensureMaxDepth(List childs) { + private void ensureMaxDepth(List children) { int maxDepth = ProductionParams.maxCfgDepth.value(); - List filtered = childs.stream() - .filter(c -> c.isCFDeviation() && c.countDepth() > maxDepth) - .collect(Collectors.toList()); - for (IRNode child : filtered) { - List leaves; - do { - long depth = Math.max(child.countDepth(), maxDepth + 1); - leaves = child.getDeviantBlocks(depth); - leaves.get(0).removeSelf(); - } while (!leaves.isEmpty() && child.countDepth() > maxDepth); - } + List filtered = children.stream() + .filter(c -> c.isCFDeviation() && c.countDepth() > maxDepth) + .collect(Collectors.toList()); + /* Now attempt to reduce depth by removing optional parts of control deviation + blocks in case IRTree has oversized depth */ + IRNode.tryToReduceNodesDepth(filtered, maxDepth); } private void ensureMinDepth(List childs, IRNodeBuilder builder) @@ -134,10 +129,15 @@ class MainKlassFactory extends Factory { addMoreChildren(filtered, minDepth, builder); } - private void addMoreChildren(List childs, int minDepth, IRNodeBuilder builder) + private void addMoreChildren(List children, int minDepth, IRNodeBuilder builder) throws ProductionFailedException { - while (!childs.isEmpty() && IRNode.countDepth(childs) < minDepth) { - IRNode randomChild = childs.get(PseudoRandom.randomNotNegative(childs.size())); + /* check situation when no stackable leaves available in all children */ + if (IRNode.getModifiableNodesCount(children) == 0L) { + return; + } + /* now let's try to add children */ + while (!children.isEmpty() && IRNode.countDepth(children) < minDepth) { + IRNode randomChild = children.get(PseudoRandom.randomNotNegative(children.size())); List leaves = randomChild.getStackableLeaves(); if (!leaves.isEmpty()) { Block randomLeaf = (Block) leaves.get(PseudoRandom.randomNotNegative(leaves.size())); diff --git a/jdk/.hgtags b/jdk/.hgtags index 0068e0865f6..5a0ef0ed7ad 100644 --- a/jdk/.hgtags +++ b/jdk/.hgtags @@ -368,3 +368,4 @@ ee29aaab5889555ea56e4c0ed690aabb7613529d jdk-9+121 c40c8739bcdc88892ff58ebee3fd8a3f287be94d jdk-9+123 7ff61c55b5c6c124592f09b18953222009a204a6 jdk-9+124 073ab1d4edf5590cf1af7b6d819350c14e425c1a jdk-9+125 +6fda66a5bdf2da8994032b9da2078a4137f4d954 jdk-9+126 diff --git a/jdk/make/gendata/GendataBlacklistedCerts.gmk b/jdk/make/gendata/GendataBlacklistedCerts.gmk index 4ed2763970f..c25fb525ced 100644 --- a/jdk/make/gendata/GendataBlacklistedCerts.gmk +++ b/jdk/make/gendata/GendataBlacklistedCerts.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -23,16 +23,14 @@ # questions. # -GENDATA_BLACKLISTED_CERTS_SRC := $(JDK_TOPDIR)/make/data/blacklistedcertsconverter/blacklisted.certs.pem +$(eval $(call IncludeCustomExtension, jdk, gendata/GendataBlacklistedCerts.gmk)) + +GENDATA_BLACKLISTED_CERTS_SRC += $(JDK_TOPDIR)/make/data/blacklistedcertsconverter/blacklisted.certs.pem GENDATA_BLACKLISTED_CERTS := $(SUPPORT_OUTPUTDIR)/modules_libs/$(MODULE)/security/blacklisted.certs -ifndef OPENJDK - GENDATA_BLACKLISTED_CERTS_SRC += $(wildcard $(JDK_TOPDIR)/make/closed/data/blacklistedcertsconverter/blacklisted.certs.pem) -endif - $(GENDATA_BLACKLISTED_CERTS): $(BUILD_TOOLS) $(GENDATA_BLACKLISTED_CERTS_SRC) - $(ECHO) "Generating blacklisted certs" - $(MKDIR) -p $(@D) + $(call LogInfo, Generating blacklisted certs) + $(call MakeDir, $(@D)) ($(CAT) $(GENDATA_BLACKLISTED_CERTS_SRC) | $(TOOL_BLACKLISTED_CERTS) > $@) || exit 1 TARGETS += $(GENDATA_BLACKLISTED_CERTS) diff --git a/jdk/make/gendata/GendataFontConfig.gmk b/jdk/make/gendata/GendataFontConfig.gmk index 32680470630..048c445d5f2 100644 --- a/jdk/make/gendata/GendataFontConfig.gmk +++ b/jdk/make/gendata/GendataFontConfig.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -23,14 +23,11 @@ # questions. # +$(eval $(call IncludeCustomExtension, jdk, gendata/GendataFontConfig.gmk)) + GENDATA_FONT_CONFIG_DST := $(SUPPORT_OUTPUTDIR)/modules_libs/$(MODULE) -GENDATA_FONT_CONFIG_DATA_DIR := $(JDK_TOPDIR)/make/data/fontconfig -ifndef OPENJDK - ifeq ($(OPENJDK_TARGET_OS), linux) - GENDATA_FONT_CONFIG_DATA_DIR := $(JDK_TOPDIR)/make/closed/data/fontconfig - endif -endif +GENDATA_FONT_CONFIG_DATA_DIR ?= $(JDK_TOPDIR)/make/data/fontconfig GENDATA_FONT_CONFIG_SRC_FILES := \ $(wildcard $(GENDATA_FONT_CONFIG_DATA_DIR)/$(OPENJDK_TARGET_OS).*) @@ -55,4 +52,3 @@ GENDATA_BFONT_CONFIGS := $(patsubst $(GENDATA_FONT_CONFIG_DATA_DIR)/$(OPENJDK_TA $(GENDATA_FONT_CONFIG_DST)/%.bfc, $(GENDATA_FONT_CONFIG_SRC_FILES)) TARGETS := $(GENDATA_FONT_CONFIGS) $(GENDATA_BFONT_CONFIGS) - diff --git a/jdk/make/gendata/GendataPolicyJars.gmk b/jdk/make/gendata/GendataPolicyJars.gmk index ffed629f011..57f80abe9f2 100644 --- a/jdk/make/gendata/GendataPolicyJars.gmk +++ b/jdk/make/gendata/GendataPolicyJars.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -40,22 +40,6 @@ US_EXPORT_POLICY_JAR_LIMITED := \ US_EXPORT_POLICY_JAR_UNLIMITED := \ $(SUPPORT_OUTPUTDIR)/jce/policy/unlimited/US_export_policy.jar -ifndef OPENJDK - # - # In past releases, Oracle JDK has had a separately downloadable set of - # policy files which has been a nightmare for deployment. - # - # Now if we're closed and limited (default for Oracle JDK), create - # an "unlimited_policy" directory that contains the unlimited policy - # files. It will be up to the user/deployer to make an informed choice - # as to whether they are legally entitled to use the unlimited policy - # file in their environment. Users/deployers simply need to overwrite - # the files. Consult README.txt (below) for more info. - # - UNLIMITED_POLICY_DIR := \ - $(SUPPORT_OUTPUTDIR)/modules_libs/java.base/security/unlimited_policy -endif - # # TODO fix so that SetupJarArchive does not write files into SRCS # then we don't need this extra copying @@ -100,15 +84,6 @@ else $(install-file) endif -ifndef OPENJDK - ifneq ($(UNLIMITED_CRYPTO), true) - $(UNLIMITED_POLICY_DIR)/US_export_policy.jar: \ - $(US_EXPORT_POLICY_JAR_UNLIMITED) - $(install-file) - TARGETS += $(UNLIMITED_POLICY_DIR)/US_export_policy.jar - endif -endif - POLICY_JARS += $(US_EXPORT_POLICY_JAR_DST) ################################################################################ @@ -159,31 +134,12 @@ $(eval $(call SetupJarArchive, BUILD_LOCAL_POLICY_JAR_UNLIMITED, \ TARGETS += $(LOCAL_POLICY_JAR_LIMITED) $(LOCAL_POLICY_JAR_UNLIMITED) -ifndef OPENJDK - ifneq ($(UNLIMITED_CRYPTO), true) - $(UNLIMITED_POLICY_DIR)/README.txt: \ - $(JDK_TOPDIR)/make/closed/data/cryptopolicy/README.txt - $(install-file) - - TARGETS += $(UNLIMITED_POLICY_DIR)/README.txt - endif -endif - ifeq ($(UNLIMITED_CRYPTO), true) $(LOCAL_POLICY_JAR_DST): $(LOCAL_POLICY_JAR_UNLIMITED) $(install-file) -else +else $(LOCAL_POLICY_JAR_DST): $(LOCAL_POLICY_JAR_LIMITED) $(install-file) -endif - -ifndef OPENJDK - ifneq ($(UNLIMITED_CRYPTO), true) - $(UNLIMITED_POLICY_DIR)/local_policy.jar: \ - $(LOCAL_POLICY_JAR_UNLIMITED) - $(install-file) - TARGETS += $(UNLIMITED_POLICY_DIR)/local_policy.jar - endif endif POLICY_JARS += $(LOCAL_POLICY_JAR_DST) @@ -191,3 +147,4 @@ TARGETS += $(POLICY_JARS) ################################################################################ +$(eval $(call IncludeCustomExtension, jdk, gendata/GendataPolicyJars.gmk)) diff --git a/jdk/make/gensrc/GensrcIcons.gmk b/jdk/make/gensrc/GensrcIcons.gmk index 32ab58a3137..1970f18866b 100644 --- a/jdk/make/gensrc/GensrcIcons.gmk +++ b/jdk/make/gensrc/GensrcIcons.gmk @@ -23,16 +23,15 @@ # questions. # +$(eval $(call IncludeCustomExtension, jdk, gensrc/GensrcIcons.gmk)) + GENSRC_AWT_ICONS := GENSRC_AWT_ICONS_SRC := GENSRC_AWT_ICONS_TMP := $(SUPPORT_OUTPUTDIR)/gensrc/java.desktop GENSRC_AWT_ICONS_DST := $(GENSRC_AWT_ICONS_TMP)/sun/awt/ -ifdef OPENJDK - X11_ICONS_PATH_PREFIX := $(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE) -else - X11_ICONS_PATH_PREFIX := $(JDK_TOPDIR)/src/closed/java.desktop/$(OPENJDK_TARGET_OS_TYPE) -endif +# Allow this to be overridden from a custom makefile +X11_ICONS_PATH_PREFIX ?= $(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE) GENSRC_AWT_ICONS_SRC += \ $(X11_ICONS_PATH_PREFIX)/classes/sun/awt/X11/java-icon16.png \ @@ -114,11 +113,8 @@ ifeq ($(OPENJDK_TARGET_OS), macosx) GENSRC_OSX_ICONS_DST := $(SUPPORT_OUTPUTDIR)/headers/java.desktop GENSRC_OSX_ICONS := $(GENSRC_OSX_ICONS_DST)/AWTIconData.h - ifdef OPENJDK - GENSRC_OSX_ICONS_SRC := $(JDK_TOPDIR)/make/data/macosxicons/JavaApp.icns - else - GENSRC_OSX_ICONS_SRC := $(JDK_TOPDIR)/make/closed/data/macosxicons/JavaApp.icns - endif + GENSRC_OSX_ICONS_SRC ?= $(JDK_TOPDIR)/make/data/macosxicons/JavaApp.icns + $(GENSRC_OSX_ICONS): $(GENSRC_OSX_ICONS_SRC) $(BUILD_TOOLS_JDK) $(call LogInfo, Generating $(patsubst $(OUTPUT_ROOT)/%, %, $@)) diff --git a/jdk/make/gensrc/GensrcVarHandles.gmk b/jdk/make/gensrc/GensrcVarHandles.gmk index 5d90deb1304..3ad7e630e9c 100644 --- a/jdk/make/gensrc/GensrcVarHandles.gmk +++ b/jdk/make/gensrc/GensrcVarHandles.gmk @@ -38,12 +38,14 @@ define GenerateVarHandle $1_FILENAME := $(VARHANDLES_GENSRC_DIR)/VarHandle$$($1_Type)s.java - ifneq ($$(findstring $$($1_Type), Object Int Long), ) - $1_ARGS += -KCAS + $1_ARGS += -KCAS + + ifneq ($$(findstring $$($1_Type), Byte Short Char Int Long Float Double), ) + $1_ARGS += -KAtomicAdd endif - ifneq ($$(findstring $$($1_Type), Int Long), ) - $1_ARGS += -KAtomicAdd + ifneq ($$(findstring $$($1_Type), Byte Short Char), ) + $1_ARGS += -KShorterThanInt endif $$($1_FILENAME): $(VARHANDLES_SRC_DIR)/X-VarHandle.java.template $(BUILD_TOOLS_JDK) diff --git a/jdk/make/launcher/Launcher-java.base.gmk b/jdk/make/launcher/Launcher-java.base.gmk index d5ded27b9ea..4d4b981c097 100644 --- a/jdk/make/launcher/Launcher-java.base.gmk +++ b/jdk/make/launcher/Launcher-java.base.gmk @@ -25,12 +25,10 @@ include LauncherCommon.gmk +$(eval $(call IncludeCustomExtension, jdk, launcher/Launcher-java.base.gmk)) + JAVA_RC_FLAGS += -I $(JDK_TOPDIR)/src/java.base/windows/native/common -ifdef OPENJDK - JAVA_RC_FLAGS += -I $(JDK_TOPDIR)/src/java.base/windows/native/launcher/icons -else - JAVA_RC_FLAGS += -I $(JDK_TOPDIR)/src/closed/java.base/windows/native/launcher/icons -endif +JAVA_RC_FLAGS += -I $(JDK_TOPDIR)/src/java.base/windows/native/launcher/icons ################################################################################ diff --git a/jdk/make/lib/Awt2dLibraries.gmk b/jdk/make/lib/Awt2dLibraries.gmk index c8fd1459afe..b692a733830 100644 --- a/jdk/make/lib/Awt2dLibraries.gmk +++ b/jdk/make/lib/Awt2dLibraries.gmk @@ -23,6 +23,8 @@ # questions. # +$(eval $(call IncludeCustomExtension, jdk, lib/Awt2dLibraries-pre.gmk)) + WIN_AWT_LIB := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libawt/awt.lib ################################################################################ @@ -212,11 +214,7 @@ ifeq ($(OPENJDK_TARGET_OS), windows) LIBAWT_CFLAGS += -DMLIB_OS64BIT endif - ifdef OPENJDK - LIBAWT_RC_FLAGS := -I $(JDK_TOPDIR)/src/java.base/windows/native/launcher/icons - else - LIBAWT_RC_FLAGS := -I $(JDK_TOPDIR)/src/closed/java.base/windows/native/launcher/icons - endif + LIBAWT_RC_FLAGS ?= -I $(JDK_TOPDIR)/src/java.base/windows/native/launcher/icons LIBAWT_VERSIONINFO_RESOURCE := $(JDK_TOPDIR)/src/java.desktop/windows/native/libawt/windows/awt.rc endif @@ -426,7 +424,7 @@ $(eval $(call SetupNativeCompilation,BUILD_LIBLCMS, \ $(LCMS_CFLAGS), \ CFLAGS_solaris := -xc99=no_lib, \ CFLAGS_windows := -DCMS_IS_WINDOWS_, \ - DISABLED_WARNINGS_gcc := format-nonliteral type-limits, \ + DISABLED_WARNINGS_gcc := format-nonliteral type-limits misleading-indentation, \ DISABLED_WARNINGS_clang := tautological-compare, \ DISABLED_WARNINGS_solstudio := E_STATEMENT_NOT_REACHED, \ MAPFILE := $(JDK_TOPDIR)/make/mapfiles/liblcms/mapfile-vers, \ @@ -454,13 +452,6 @@ $(BUILD_LIBLCMS): $(BUILD_LIBAWT) ################################################################################ -ifdef OPENJDK - BUILD_LIBJAVAJPEG_MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libjpeg/mapfile-vers -else - BUILD_LIBJAVAJPEG_MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libjpeg/mapfile-vers-closed - LIBJAVAJPEG_SRC += $(JDK_TOPDIR)/src/closed/java.desktop/share/native/libjavajpeg -endif - LIBJAVAJPEG_SRC += $(JDK_TOPDIR)/src/java.desktop/share/native/libjavajpeg BUILD_LIBJAVAJPEG_REORDER := @@ -507,10 +498,10 @@ $(eval $(call SetupNativeCompilation,BUILD_LIBJAVAJPEG, \ CFLAGS := $(CFLAGS_JDKLIB) $(BUILD_LIBJAVAJPEG_HEADERS) \ $(LIBJAVA_HEADER_FLAGS) \ -I$(SUPPORT_OUTPUTDIR)/headers/java.desktop, \ - DISABLED_WARNINGS_gcc := clobbered parentheses array-bounds, \ + DISABLED_WARNINGS_gcc := clobbered parentheses array-bounds shift-negative-value, \ DISABLED_WARNINGS_clang := logical-op-parentheses, \ DISABLED_WARNINGS_microsoft := 4267, \ - MAPFILE := $(BUILD_LIBJAVAJPEG_MAPFILE), \ + MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libjpeg/mapfile-vers, \ LDFLAGS := $(LDFLAGS_JDKLIB) \ $(call SET_SHARED_LIBRARY_ORIGIN), \ LIBS := $(LIBJPEG_LIBS) $(JDKLIB_LIBS), \ @@ -645,15 +636,10 @@ LIBFONTMANAGER_CFLAGS += $(HARFBUZZ_CFLAGS) #### End harfbuzz configuration -ifndef OPENJDK - LIBFONTMANAGER_CFLAGS += -I$(JDK_TOPDIR)/src/closed/java.desktop/share/native/libt2k - BUILD_LIBFONTMANAGER_MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libfontmanager/mapfile-vers - LIBFONTMANAGER_EXCLUDE_FILES += freetypeScaler.c -else - LIBFONTMANAGER_CFLAGS += $(FREETYPE_CFLAGS) - BUILD_LIBFONTMANAGER_MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libfontmanager/mapfile-vers.openjdk - BUILD_LIBFONTMANAGER_FONTLIB := $(FREETYPE_LIBS) -endif +LIBFONTMANAGER_CFLAGS += $(FREETYPE_CFLAGS) +# This may be overridden in a custom makefile +BUILD_LIBFONTMANAGER_MAPFILE ?= $(JDK_TOPDIR)/make/mapfiles/libfontmanager/mapfile-vers +BUILD_LIBFONTMANAGER_FONTLIB += $(FREETYPE_LIBS) LIBFONTMANAGER_OPTIMIZATION := HIGH @@ -943,7 +929,7 @@ ifndef BUILD_HEADLESS_ONLY OPTIMIZATION := LOW, \ CFLAGS := $(LIBSPLASHSCREEN_CFLAGS) $(CFLAGS_JDKLIB) \ $(GIFLIB_CFLAGS) $(LIBJPEG_CFLAGS) $(PNG_CFLAGS), \ - DISABLED_WARNINGS_gcc := sign-compare type-limits unused-result maybe-uninitialized, \ + DISABLED_WARNINGS_gcc := sign-compare type-limits unused-result maybe-uninitialized shift-negative-value, \ DISABLED_WARNINGS_clang := incompatible-pointer-types, \ DISABLED_WARNINGS_solstudio := E_NEWLINE_NOT_LAST E_DECLARATION_IN_CODE \ E_STATEMENT_NOT_REACHED, \ diff --git a/jdk/make/mapfiles/libdcpr/mapfile-vers b/jdk/make/mapfiles/libdcpr/mapfile-vers deleted file mode 100644 index 7ae88b30d60..00000000000 --- a/jdk/make/mapfiles/libdcpr/mapfile-vers +++ /dev/null @@ -1,93 +0,0 @@ -# -# Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# Define public interface. - -SUNWprivate_1.1 { - global: - Java_sun_dc_pr_PathDasher_beginPath; - Java_sun_dc_pr_PathFiller_getTileState; - Java_sun_dc_pr_PathStroker_setCaps; - Java_sun_dc_pr_PathStroker_setCorners; - Java_sun_dc_pr_PathFiller_writeAlpha16; - Java_sun_dc_pr_PathFiller_closedSubpath; - Java_sun_dc_pr_PathStroker_beginPath; - Java_sun_dc_pr_PathDasher_setDashT4; - Java_sun_dc_pr_PathFiller_dispose; - Java_sun_dc_pr_PathStroker_closedSubpath; - Java_sun_dc_pr_PathDasher_appendLine; - Java_sun_dc_pr_PathStroker_dispose; - Java_sun_dc_pr_PathDasher_setOutputConsumer; - Java_sun_dc_pr_PathStroker_reset; - Java_sun_dc_pr_PathFiller_beginSubpath; - Java_sun_dc_pr_PathFiller_writeAlpha8; - Java_sun_dc_pr_PathDasher_closedSubpath; - Java_sun_dc_pr_PathFiller_appendQuadratic; - Java_sun_dc_pr_PathDasher_setOutputT6; - Java_sun_dc_pr_PathStroker_setPenFitting; - Java_sun_dc_pr_PathStroker_endPath; - Java_sun_dc_pr_PathDasher_setDash; - Java_sun_dc_pr_PathFiller_nextTile; - Java_sun_dc_pr_PathStroker_setOutputConsumer; - Java_sun_dc_pr_PathFiller_setFillMode; - Java_sun_dc_pr_PathFiller_appendLine; - Java_sun_dc_pr_PathStroker_appendQuadratic; - Java_sun_dc_pr_PathFiller_endPath; - Java_sun_dc_pr_PathStroker_appendCubic; - Java_sun_dc_pr_PathDasher_appendCubic; - Java_sun_dc_pr_PathStroker_setPenDiameter; - Java_sun_dc_pr_PathFiller_setOutputArea; - Java_sun_dc_pr_PathFiller_getAlphaBox; - Java_sun_dc_pr_PathStroker_appendLine; - Java_sun_dc_pr_PathStroker_setOutputT6; - Java_sun_dc_pr_PathFiller_beginPath; - Java_sun_dc_pr_PathDasher_dispose; - Java_sun_dc_pr_PathDasher_reset; - Java_sun_dc_pr_PathFiller_reset; - Java_sun_dc_pr_PathDasher_endPath; - Java_sun_dc_pr_PathStroker_beginSubpath; - Java_sun_dc_pr_PathStroker_setPenT4; - Java_sun_dc_pr_PathDasher_appendQuadratic; - Java_sun_dc_pr_PathDasher_beginSubpath; - Java_sun_dc_pr_PathFiller_appendCubic; - - Java_sun_dc_pr_PathDasher_cClassFinalize; - Java_sun_dc_pr_PathDasher_cClassInitialize; - Java_sun_dc_pr_PathDasher_cInitialize; - Java_sun_dc_pr_PathFiller_cClassFinalize; - Java_sun_dc_pr_PathFiller_cClassInitialize; - Java_sun_dc_pr_PathFiller_cInitialize; - Java_sun_dc_pr_PathStroker_cClassFinalize; - Java_sun_dc_pr_PathStroker_cClassInitialize; - Java_sun_dc_pr_PathStroker_cInitialize; - Java_sun_dc_pr_PathStroker_cInitialize2D; - - Java_sun_dc_pr_PathDasher_getCPathConsumer; - Java_sun_dc_pr_PathFiller_getCPathConsumer; - Java_sun_dc_pr_PathStroker_getCPathConsumer; - - local: - *; -}; diff --git a/jdk/make/mapfiles/libfontmanager/mapfile-vers b/jdk/make/mapfiles/libfontmanager/mapfile-vers index f2acff6aa6d..21ecea99119 100644 --- a/jdk/make/mapfiles/libfontmanager/mapfile-vers +++ b/jdk/make/mapfiles/libfontmanager/mapfile-vers @@ -25,6 +25,8 @@ # Define public interface. +# In addition to regular symbols also include Freetype scaler + SUNWprivate_1.1 { global: getSunFontIDs; @@ -57,6 +59,23 @@ SUNWprivate_1.1 { Java_sun_font_NativeFont_getGlyphImage; Java_sun_font_NativeFont_getGlyphImageNoDefault; Java_sun_font_NativeFont_getFontMetrics; + Java_sun_font_FreetypeFontScaler_initIDs; + Java_sun_font_FreetypeFontScaler_createScalerContextNative; + Java_sun_font_FreetypeFontScaler_disposeNativeScaler; + Java_sun_font_FreetypeFontScaler_getFontMetricsNative; + Java_sun_font_FreetypeFontScaler_getGlyphAdvanceNative; + Java_sun_font_FreetypeFontScaler_getGlyphCodeNative; + Java_sun_font_FreetypeFontScaler_getGlyphImageNative; + Java_sun_font_FreetypeFontScaler_getGlyphMetricsNative; + Java_sun_font_FreetypeFontScaler_getGlyphOutlineBoundsNative; + Java_sun_font_FreetypeFontScaler_getGlyphOutlineNative; + Java_sun_font_FreetypeFontScaler_getGlyphVectorOutlineNative; + Java_sun_font_FreetypeFontScaler_getLayoutTableCacheNative; + Java_sun_font_FreetypeFontScaler_getMissingGlyphCodeNative; + Java_sun_font_FreetypeFontScaler_getNumGlyphsNative; + Java_sun_font_FreetypeFontScaler_getUnitsPerEMNative; + Java_sun_font_FreetypeFontScaler_initNativeScaler; + Java_sun_font_FreetypeFontScaler_getGlyphPointNative; local: *; }; diff --git a/jdk/make/mapfiles/libfontmanager/mapfile-vers.openjdk b/jdk/make/mapfiles/libfontmanager/mapfile-vers.openjdk deleted file mode 100644 index 21ecea99119..00000000000 --- a/jdk/make/mapfiles/libfontmanager/mapfile-vers.openjdk +++ /dev/null @@ -1,81 +0,0 @@ -# -# Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# Define public interface. - -# In addition to regular symbols also include Freetype scaler - -SUNWprivate_1.1 { - global: - getSunFontIDs; - newLayoutTableCache; - freeLayoutTableCache; - isNullScalerContext; - Java_sun_font_NullFontScaler_getNullScalerContext; - Java_sun_font_NullFontScaler_getGlyphImage; - Java_sun_font_SunFontManager_initIDs; - Java_sun_font_StrikeCache_getGlyphCacheDescription; - Java_sun_font_StrikeCache_freeIntPointer; - Java_sun_font_StrikeCache_freeLongPointer; - Java_sun_font_StrikeCache_freeIntMemory; - Java_sun_font_StrikeCache_freeLongMemory; - Java_sun_font_SunLayoutEngine_initGVIDs; - Java_sun_font_SunLayoutEngine_nativeLayout; - Java_sun_font_SunLayoutEngine_shape; - Java_sun_font_X11TextRenderer_doDrawGlyphList; - Java_sun_java2d_loops_DrawGlyphListAA_DrawGlyphListAA; - Java_sun_java2d_loops_DrawGlyphListLCD_DrawGlyphListLCD; - Java_sun_java2d_loops_DrawGlyphList_DrawGlyphList; - Java_sun_font_NativeStrikeDisposer_freeNativeScalerContext; - Java_sun_font_NativeStrike_createNullScalerContext; - Java_sun_font_NativeStrike_createScalerContext; - Java_sun_font_NativeStrike_getMaxGlyph; - Java_sun_font_NativeFont_fontExists; - Java_sun_font_NativeFont_haveBitmapFonts; - Java_sun_font_NativeFont_countGlyphs; - Java_sun_font_NativeFont_getGlyphAdvance; - Java_sun_font_NativeFont_getGlyphImage; - Java_sun_font_NativeFont_getGlyphImageNoDefault; - Java_sun_font_NativeFont_getFontMetrics; - Java_sun_font_FreetypeFontScaler_initIDs; - Java_sun_font_FreetypeFontScaler_createScalerContextNative; - Java_sun_font_FreetypeFontScaler_disposeNativeScaler; - Java_sun_font_FreetypeFontScaler_getFontMetricsNative; - Java_sun_font_FreetypeFontScaler_getGlyphAdvanceNative; - Java_sun_font_FreetypeFontScaler_getGlyphCodeNative; - Java_sun_font_FreetypeFontScaler_getGlyphImageNative; - Java_sun_font_FreetypeFontScaler_getGlyphMetricsNative; - Java_sun_font_FreetypeFontScaler_getGlyphOutlineBoundsNative; - Java_sun_font_FreetypeFontScaler_getGlyphOutlineNative; - Java_sun_font_FreetypeFontScaler_getGlyphVectorOutlineNative; - Java_sun_font_FreetypeFontScaler_getLayoutTableCacheNative; - Java_sun_font_FreetypeFontScaler_getMissingGlyphCodeNative; - Java_sun_font_FreetypeFontScaler_getNumGlyphsNative; - Java_sun_font_FreetypeFontScaler_getUnitsPerEMNative; - Java_sun_font_FreetypeFontScaler_initNativeScaler; - Java_sun_font_FreetypeFontScaler_getGlyphPointNative; - local: - *; -}; diff --git a/jdk/make/mapfiles/libjpeg/mapfile-vers-closed b/jdk/make/mapfiles/libjpeg/mapfile-vers-closed deleted file mode 100644 index 6f84d2da352..00000000000 --- a/jdk/make/mapfiles/libjpeg/mapfile-vers-closed +++ /dev/null @@ -1,55 +0,0 @@ -# -# Copyright (c) 2007, 2013, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# Define public interface. - -SUNWprivate_1.1 { - global: - JNI_OnLoad; - - Java_sun_awt_image_JPEGImageDecoder_initIDs; - Java_sun_awt_image_JPEGImageDecoder_readImage; - - Java_com_sun_imageio_plugins_jpeg_JPEGImageReader_initReaderIDs; - Java_com_sun_imageio_plugins_jpeg_JPEGImageReader_initJPEGImageReader; - Java_com_sun_imageio_plugins_jpeg_JPEGImageReader_setSource; - Java_com_sun_imageio_plugins_jpeg_JPEGImageReader_readImageHeader; - Java_com_sun_imageio_plugins_jpeg_JPEGImageReader_setOutColorSpace; - Java_com_sun_imageio_plugins_jpeg_JPEGImageReader_readImage; - Java_com_sun_imageio_plugins_jpeg_JPEGImageReader_abortRead; - Java_com_sun_imageio_plugins_jpeg_JPEGImageReader_resetReader; - Java_com_sun_imageio_plugins_jpeg_JPEGImageReader_disposeReader; - Java_com_sun_imageio_plugins_jpeg_JPEGImageReader_resetLibraryState; - Java_com_sun_imageio_plugins_jpeg_JPEGImageWriter_initWriterIDs; - Java_com_sun_imageio_plugins_jpeg_JPEGImageWriter_initJPEGImageWriter; - Java_com_sun_imageio_plugins_jpeg_JPEGImageWriter_setDest; - Java_com_sun_imageio_plugins_jpeg_JPEGImageWriter_writeTables; - Java_com_sun_imageio_plugins_jpeg_JPEGImageWriter_writeImage; - Java_com_sun_imageio_plugins_jpeg_JPEGImageWriter_abortWrite; - Java_com_sun_imageio_plugins_jpeg_JPEGImageWriter_resetWriter; - Java_com_sun_imageio_plugins_jpeg_JPEGImageWriter_disposeWriter; - local: - *; -}; diff --git a/jdk/make/mapfiles/libkcms/mapfile-vers b/jdk/make/mapfiles/libkcms/mapfile-vers deleted file mode 100644 index 267f99c9ac8..00000000000 --- a/jdk/make/mapfiles/libkcms/mapfile-vers +++ /dev/null @@ -1,47 +0,0 @@ -# -# Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# Define public interface. - -SUNWprivate_1.1 { - global: - Java_sun_java2d_cmm_kcms_CMM_cmmGetTagSize; - Java_sun_java2d_cmm_kcms_CMM_cmmGetNumComponents; - Java_sun_java2d_cmm_kcms_CMM_cmmColorConvert; - Java_sun_java2d_cmm_kcms_CMM_cmmInit; - Java_sun_java2d_cmm_kcms_CMM_cmmCombineTransforms; - Java_sun_java2d_cmm_kcms_CMM_cmmGetTagData; - Java_sun_java2d_cmm_kcms_CMM_cmmSetTagData; - Java_sun_java2d_cmm_kcms_CMM_cmmGetProfileData; - Java_sun_java2d_cmm_kcms_CMM_cmmFreeProfile; - Java_sun_java2d_cmm_kcms_CMM_cmmTerminate; - Java_sun_java2d_cmm_kcms_CMM_cmmLoadProfile; - Java_sun_java2d_cmm_kcms_CMM_cmmGetTransform; - Java_sun_java2d_cmm_kcms_CMM_cmmFreeTransform; - Java_sun_java2d_cmm_kcms_CMM_cmmGetProfileSize; - - local: - *; -}; diff --git a/jdk/make/mapfiles/libt2k/mapfile-vers b/jdk/make/mapfiles/libt2k/mapfile-vers deleted file mode 100644 index 4c01eb265da..00000000000 --- a/jdk/make/mapfiles/libt2k/mapfile-vers +++ /dev/null @@ -1,49 +0,0 @@ -# -# Copyright (c) 2007, 2013, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# Define public interface. - -SUNWprivate_1.1 { - global: - Java_sun_font_T2KFontScaler_createScalerContextNative; - Java_sun_font_T2KFontScaler_disposeNativeScaler; - Java_sun_font_T2KFontScaler_getFontMetricsNative; - Java_sun_font_T2KFontScaler_getGlyphAdvanceNative; - Java_sun_font_T2KFontScaler_getGlyphCodeNative; - Java_sun_font_T2KFontScaler_getGlyphImageNative; - Java_sun_font_T2KFontScaler_getGlyphMetricsNative; - Java_sun_font_T2KFontScaler_getGlyphOutlineBoundsNative; - Java_sun_font_T2KFontScaler_getGlyphOutlineNative; - Java_sun_font_T2KFontScaler_getGlyphVectorOutlineNative; - Java_sun_font_T2KFontScaler_getLayoutTableCacheNative; - Java_sun_font_T2KFontScaler_getMissingGlyphCodeNative; - Java_sun_font_T2KFontScaler_getNumGlyphsNative; - Java_sun_font_T2KFontScaler_getUnitsPerEMNative; - Java_sun_font_T2KFontScaler_initIDs; - Java_sun_font_T2KFontScaler_initNativeScaler; - Java_sun_font_T2KFontScaler_getGlyphPointNative; - local: - *; -}; diff --git a/jdk/src/java.base/linux/native/libnio/fs/GioFileTypeDetector.c b/jdk/src/java.base/linux/native/libnio/fs/GioFileTypeDetector.c index ad46a144fdf..61e9118af06 100644 --- a/jdk/src/java.base/linux/native/libnio/fs/GioFileTypeDetector.c +++ b/jdk/src/java.base/linux/native/libnio/fs/GioFileTypeDetector.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -91,7 +91,6 @@ Java_sun_nio_fs_GioFileTypeDetector_initializeGio } g_type_init = (g_type_init_func)dlsym(gio_handle, "g_type_init"); - (*g_type_init)(); g_object_unref = (g_object_unref_func)dlsym(gio_handle, "g_object_unref"); @@ -104,9 +103,7 @@ Java_sun_nio_fs_GioFileTypeDetector_initializeGio g_file_info_get_content_type = (g_file_info_get_content_type_func) dlsym(gio_handle, "g_file_info_get_content_type"); - - if (g_type_init == NULL || - g_object_unref == NULL || + if (g_object_unref == NULL || g_file_new_for_path == NULL || g_file_query_info == NULL || g_file_info_get_content_type == NULL) @@ -115,7 +112,10 @@ Java_sun_nio_fs_GioFileTypeDetector_initializeGio return JNI_FALSE; } - (*g_type_init)(); + if (g_type_init != NULL) { + (*g_type_init)(); + } + return JNI_TRUE; } diff --git a/jdk/src/java.base/macosx/classes/java/lang/ClassLoaderHelper.java b/jdk/src/java.base/macosx/classes/java/lang/ClassLoaderHelper.java index 6c2466c1f1e..505ca0814dc 100644 --- a/jdk/src/java.base/macosx/classes/java/lang/ClassLoaderHelper.java +++ b/jdk/src/java.base/macosx/classes/java/lang/ClassLoaderHelper.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2015 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it diff --git a/jdk/src/java.base/macosx/native/libjli/java_md_macosx.c b/jdk/src/java.base/macosx/native/libjli/java_md_macosx.c index 46a4a06beae..8205f12f5d4 100644 --- a/jdk/src/java.base/macosx/native/libjli/java_md_macosx.c +++ b/jdk/src/java.base/macosx/native/libjli/java_md_macosx.c @@ -1053,32 +1053,6 @@ SetXStartOnFirstThreadArg() setenv(envVar, "1", 1); } -/* This class is made for performSelectorOnMainThread when java main - * should be launched on main thread. - * We cannot use dispatch_sync here, because it blocks the main dispatch queue - * which is used inside Cocoa - */ -@interface JavaLaunchHelper : NSObject { - int _returnValue; -} -- (void) launchJava:(NSValue*)argsValue; -- (int) getReturnValue; -@end - -@implementation JavaLaunchHelper - -- (void) launchJava:(NSValue*)argsValue -{ - _returnValue = JavaMain([argsValue pointerValue]); -} - -- (int) getReturnValue -{ - return _returnValue; -} - -@end - // MacOSX we may continue in the same thread int JVMInit(InvocationFunctions* ifn, jlong threadStackSize, @@ -1088,20 +1062,26 @@ JVMInit(InvocationFunctions* ifn, jlong threadStackSize, JLI_TraceLauncher("In same thread\n"); // need to block this thread against the main thread // so signals get caught correctly - JavaMainArgs args; - args.argc = argc; - args.argv = argv; - args.mode = mode; - args.what = what; - args.ifn = *ifn; - int rslt; + __block int rslt = 0; NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; { - JavaLaunchHelper* launcher = [[[JavaLaunchHelper alloc] init] autorelease]; - [launcher performSelectorOnMainThread:@selector(launchJava:) - withObject:[NSValue valueWithPointer:(void*)&args] - waitUntilDone:YES]; - rslt = [launcher getReturnValue]; + NSBlockOperation *op = [NSBlockOperation blockOperationWithBlock: ^{ + JavaMainArgs args; + args.argc = argc; + args.argv = argv; + args.mode = mode; + args.what = what; + args.ifn = *ifn; + rslt = JavaMain(&args); + }]; + + /* + * We cannot use dispatch_sync here, because it blocks the main dispatch queue. + * Using the main NSRunLoop allows the dispatch queue to run properly once + * SWT (or whatever toolkit this is needed for) kicks off it's own NSRunLoop + * and starts running. + */ + [op performSelectorOnMainThread:@selector(start) withObject:nil waitUntilDone:YES]; } [pool drain]; return rslt; diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/HostnameVerifier.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/HostnameVerifier.java index 828c30a8bd6..1a78995ec01 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/HostnameVerifier.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/HostnameVerifier.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -38,8 +38,9 @@ package com.sun.net.ssl; * @deprecated As of JDK 1.4, this implementation-specific class was * replaced by {@link javax.net.ssl.HostnameVerifier} and * {@link javax.net.ssl.CertificateHostnameVerifier}. + * This class is subject to removal in a future version of JDK. */ -@Deprecated +@Deprecated(since="1.4", forRemoval=true) public interface HostnameVerifier { /** * Verify that the hostname from the URL is an acceptable diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/HttpsURLConnection.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/HttpsURLConnection.java index 0ddaa794efc..d376fc395fe 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/HttpsURLConnection.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/HttpsURLConnection.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -44,8 +44,9 @@ import javax.net.ssl.SSLPeerUnverifiedException; * * @deprecated As of JDK 1.4, this implementation-specific class was * replaced by {@link javax.net.ssl.HttpsURLConnection}. + * This class is subject to removal in a future version of JDK. */ -@Deprecated +@Deprecated(since="1.4", forRemoval=true) public abstract class HttpsURLConnection extends HttpURLConnection { diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManager.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManager.java index fb0b28f29c4..814d619db8d 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManager.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManager.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -36,7 +36,8 @@ package com.sun.net.ssl; * * @deprecated As of JDK 1.4, this implementation-specific class was * replaced by {@link javax.net.ssl.KeyManager}. + * This class is subject to removal in a future version of JDK. */ -@Deprecated +@Deprecated(since="1.4", forRemoval=true) public interface KeyManager { } diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManagerFactory.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManagerFactory.java index 620de110be2..8c0caed6b0e 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManagerFactory.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManagerFactory.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -39,8 +39,9 @@ import java.security.*; * * @deprecated As of JDK 1.4, this implementation-specific class was * replaced by {@link javax.net.ssl.KeyManagerFactory}. + * This class is subject to removal in a future version of JDK. */ -@Deprecated +@Deprecated(since="1.4", forRemoval=true) public class KeyManagerFactory { // The provider private Provider provider; diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManagerFactorySpi.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManagerFactorySpi.java index 917522fb491..19b2a68b6f5 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManagerFactorySpi.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManagerFactorySpi.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -41,8 +41,9 @@ import java.security.*; * * @deprecated As of JDK 1.4, this implementation-specific class was * replaced by {@link javax.net.ssl.KeyManagerFactorySpi}. + * This class is subject to removal in a future version of JDK. */ -@Deprecated +@Deprecated(since="1.4", forRemoval=true) public abstract class KeyManagerFactorySpi { /** * Initializes this factory with a source of key material. The diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/SSLContext.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/SSLContext.java index d917c056f98..6f0cbf9fd9b 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/SSLContext.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/SSLContext.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2007, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -44,8 +44,9 @@ import sun.security.ssl.SSLServerSocketFactoryImpl; * * @deprecated As of JDK 1.4, this implementation-specific class was * replaced by {@link javax.net.ssl.SSLContext}. + * This class is subject to removal in a future version of JDK. */ -@Deprecated +@Deprecated(since="1.4", forRemoval=true) public class SSLContext { private Provider provider; diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/SSLContextSpi.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/SSLContextSpi.java index 3f2e74e8236..0a663b8ff3f 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/SSLContextSpi.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/SSLContextSpi.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -43,8 +43,9 @@ import javax.net.ssl.*; * * @deprecated As of JDK 1.4, this implementation-specific class was * replaced by {@link javax.net.ssl.SSLContextSpi}. + * This class is subject to removal in a future version of JDK. */ -@Deprecated +@Deprecated(since="1.4", forRemoval=true) public abstract class SSLContextSpi { /** * Initializes this context. diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/SSLPermission.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/SSLPermission.java index 8f8c249d007..9fd480b93f3 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/SSLPermission.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/SSLPermission.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -97,8 +97,9 @@ import java.lang.SecurityManager; * * @deprecated As of JDK 1.4, this implementation-specific class was * replaced by {@link javax.net.ssl.SSLPermission}. + * This class is subject to removal in a future version of JDK. */ -@Deprecated +@Deprecated(since="1.4", forRemoval=true) public final class SSLPermission extends BasicPermission { private static final long serialVersionUID = -2583684302506167542L; diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManager.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManager.java index c7396b61b8d..2856e30be40 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManager.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManager.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -36,7 +36,8 @@ package com.sun.net.ssl; * * @deprecated As of JDK 1.4, this implementation-specific class was * replaced by {@link javax.net.ssl.TrustManager}. + * This class is subject to removal in a future version of JDK. */ -@Deprecated +@Deprecated(since="1.4", forRemoval=true) public interface TrustManager { } diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManagerFactory.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManagerFactory.java index 14c54d29a8b..934210c618b 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManagerFactory.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManagerFactory.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -39,8 +39,9 @@ import java.security.*; * * @deprecated As of JDK 1.4, this implementation-specific class was * replaced by {@link javax.net.ssl.TrustManagerFactory}. + * This class is subject to removal in a future version of JDK. */ -@Deprecated +@Deprecated(since="1.4", forRemoval=true) public class TrustManagerFactory { // The provider private Provider provider; diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManagerFactorySpi.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManagerFactorySpi.java index 627c97fd747..62698a42d32 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManagerFactorySpi.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManagerFactorySpi.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -41,8 +41,9 @@ import java.security.*; * * @deprecated As of JDK 1.4, this implementation-specific class was * replaced by {@link javax.net.ssl.TrustManagerFactorySpi}. + * This class is subject to removal in a future version of JDK. */ -@Deprecated +@Deprecated(since="1.4", forRemoval=true) public abstract class TrustManagerFactorySpi { /** * Initializes this factory with a source of certificate diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/X509KeyManager.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/X509KeyManager.java index 9bad0154019..cb4903171a7 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/X509KeyManager.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/X509KeyManager.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -41,8 +41,9 @@ import java.security.cert.X509Certificate; * * @deprecated As of JDK 1.4, this implementation-specific class was * replaced by {@link javax.net.ssl.X509KeyManager}. + * This class is subject to removal in a future version of JDK. */ -@Deprecated +@Deprecated(since="1.4", forRemoval=true) public interface X509KeyManager extends KeyManager { /** * Get the matching aliases for authenticating the client side of a secure diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/X509TrustManager.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/X509TrustManager.java index d1775a9df7f..024d33a16f5 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/X509TrustManager.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/X509TrustManager.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -40,8 +40,9 @@ import java.security.cert.X509Certificate; * * @deprecated As of JDK 1.4, this implementation-specific class was * replaced by {@link javax.net.ssl.X509TrustManager}. + * This class is subject to removal in a future version of JDK. */ -@Deprecated +@Deprecated(since="1.4", forRemoval=true) public interface X509TrustManager extends TrustManager { /** * Given the partial or complete certificate chain diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/ssl/Provider.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/ssl/Provider.java index 2f1d2b42ce9..f438e6401fd 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/ssl/Provider.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/ssl/Provider.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -31,7 +31,10 @@ import sun.security.ssl.SunJSSE; * Main class for the SunJSSE provider. The actual code was moved to the * class sun.security.ssl.SunJSSE, but for backward compatibility we * continue to use this class as the main Provider class. + * + * @deprecated This class is subject to removal in a future version of JDK. */ +@Deprecated(since="9", forRemoval=true) public final class Provider extends SunJSSE { private static final long serialVersionUID = 3231825739635378733L; diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/ssl/X509ExtendedTrustManager.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/ssl/X509ExtendedTrustManager.java index 9859f488a64..3db161b83e4 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/ssl/X509ExtendedTrustManager.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/ssl/X509ExtendedTrustManager.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2007, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -54,7 +54,9 @@ import java.security.cert.CertificateException; * * @since 1.6 * @author Xuelei Fan + * @deprecated This class is subject to removal in a future version of JDK. */ +@Deprecated(since="9", forRemoval=true) public abstract class X509ExtendedTrustManager implements X509TrustManager { /** * Constructor used by subclasses only. diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/www/protocol/https/DelegateHttpsURLConnection.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/www/protocol/https/DelegateHttpsURLConnection.java index 3c05c37a037..8cb1de2b22c 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/www/protocol/https/DelegateHttpsURLConnection.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/www/protocol/https/DelegateHttpsURLConnection.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -52,7 +52,9 @@ import sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection; * of protocol implementation (this one) * com.sun.net.ssl.HttpURLConnection is used in the com.sun version. * + * @deprecated This class is subject to removal in a future version of JDK. */ +@Deprecated(since="9", forRemoval=true) @SuppressWarnings("deprecation") // HttpsURLConnection is deprecated public class DelegateHttpsURLConnection extends AbstractDelegateHttpsURLConnection { diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/www/protocol/https/Handler.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/www/protocol/https/Handler.java index 43cf166ddc2..d52e972646e 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/www/protocol/https/Handler.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/www/protocol/https/Handler.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -34,7 +34,9 @@ import java.net.Proxy; * only. The HTTPS implementation can now be found in * sun.net.www.protocol.https. * + * @deprecated This class is subject to removal in a future version of JDK. */ +@Deprecated(since="9", forRemoval=true) public class Handler extends sun.net.www.protocol.https.Handler { public Handler() { diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/www/protocol/https/HttpsURLConnectionOldImpl.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/www/protocol/https/HttpsURLConnectionOldImpl.java index 07ff87ba85a..09b1060eab0 100644 --- a/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/www/protocol/https/HttpsURLConnectionOldImpl.java +++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/internal/www/protocol/https/HttpsURLConnectionOldImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -59,11 +59,13 @@ import sun.net.www.http.HttpClient; * needs to implement all public methods in it's super class and all * the way to Object. * + * @deprecated This class is subject to removal in a future version of JDK. */ // For both copies of the file, uncomment one line and comment the other // public class HttpsURLConnectionImpl // extends javax.net.ssl.HttpsURLConnection { +@Deprecated(since="9", forRemoval=true) @SuppressWarnings("deprecation") // HttpsURLConnection is deprecated public class HttpsURLConnectionOldImpl extends com.sun.net.ssl.HttpsURLConnection { diff --git a/jdk/src/java.base/share/classes/java/lang/ThreadGroup.java b/jdk/src/java.base/share/classes/java/lang/ThreadGroup.java index 0a97e4cad94..2315c202329 100644 --- a/jdk/src/java.base/share/classes/java/lang/ThreadGroup.java +++ b/jdk/src/java.base/share/classes/java/lang/ThreadGroup.java @@ -60,7 +60,6 @@ class ThreadGroup implements Thread.UncaughtExceptionHandler { int maxPriority; boolean destroyed; boolean daemon; - boolean vmAllowSuspension; int nUnstartedThreads = 0; int nthreads; @@ -121,7 +120,6 @@ class ThreadGroup implements Thread.UncaughtExceptionHandler { this.name = name; this.maxPriority = parent.maxPriority; this.daemon = parent.daemon; - this.vmAllowSuspension = parent.vmAllowSuspension; this.parent = parent; parent.add(this); } @@ -1075,10 +1073,6 @@ class ThreadGroup implements Thread.UncaughtExceptionHandler { */ @Deprecated(since="1.2") public boolean allowThreadSuspension(boolean b) { - this.vmAllowSuspension = b; - if (!b) { - VM.unsuspendSomeThreads(); - } return true; } diff --git a/jdk/src/java.base/share/classes/java/lang/annotation/AnnotationTypeMismatchException.java b/jdk/src/java.base/share/classes/java/lang/annotation/AnnotationTypeMismatchException.java index 5af586c4d52..5152da23b70 100644 --- a/jdk/src/java.base/share/classes/java/lang/annotation/AnnotationTypeMismatchException.java +++ b/jdk/src/java.base/share/classes/java/lang/annotation/AnnotationTypeMismatchException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2008, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -44,7 +44,7 @@ public class AnnotationTypeMismatchException extends RuntimeException { /** * The {@code Method} object for the annotation element. */ - private final Method element; + private final transient Method element; /** * The (erroneous) type of data found in the annotation. This string @@ -57,10 +57,12 @@ public class AnnotationTypeMismatchException extends RuntimeException { * Constructs an AnnotationTypeMismatchException for the specified * annotation type element and found data type. * - * @param element the {@code Method} object for the annotation element + * @param element the {@code Method} object for the annotation + * element, may be {@code null} * @param foundType the (erroneous) type of data found in the annotation. * This string may, but is not required to, contain the value - * as well. The exact format of the string is unspecified. + * as well. The exact format of the string is unspecified, + * may be {@code null}. */ public AnnotationTypeMismatchException(Method element, String foundType) { super("Incorrectly typed data found for annotation element " + element @@ -71,8 +73,11 @@ public class AnnotationTypeMismatchException extends RuntimeException { /** * Returns the {@code Method} object for the incorrectly typed element. + * The value may be unavailable if this exception has been + * serialized and then read back in. * - * @return the {@code Method} object for the incorrectly typed element + * @return the {@code Method} object for the incorrectly typed + * element, or {@code null} if unavailable */ public Method element() { return this.element; @@ -81,7 +86,8 @@ public class AnnotationTypeMismatchException extends RuntimeException { /** * Returns the type of data found in the incorrectly typed element. * The returned string may, but is not required to, contain the value - * as well. The exact format of the string is unspecified. + * as well. The exact format of the string is unspecified and the string + * may be {@code null}. * * @return the type of data found in the incorrectly typed element */ diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java b/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java index 2df4c9d1f57..d42bad62892 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java @@ -751,11 +751,25 @@ class InvokerBytecodeGenerator { classFileEpilogue(); bogusMethod(lambdaForm); - final byte[] classFile = cw.toByteArray(); + final byte[] classFile; + try { + classFile = cw.toByteArray(); + } catch (RuntimeException e) { + // ASM throws RuntimeException if something goes wrong - capture these and wrap them in a meaningful + // exception to support falling back to LambdaForm interpretation + throw new BytecodeGenerationException(e); + } maybeDump(className, classFile); return classFile; } + @SuppressWarnings("serial") + static final class BytecodeGenerationException extends RuntimeException { + BytecodeGenerationException(Exception cause) { + super(cause); + } + } + void emitArrayLoad(Name name) { emitArrayOp(name, Opcodes.AALOAD); } void emitArrayStore(Name name) { emitArrayOp(name, Opcodes.AASTORE); } void emitArrayLength(Name name) { emitArrayOp(name, Opcodes.ARRAYLENGTH); } diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java index 745c38df2de..a0a04559ff9 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java @@ -25,6 +25,7 @@ package java.lang.invoke; +import jdk.internal.perf.PerfCounter; import jdk.internal.vm.annotation.DontInline; import jdk.internal.vm.annotation.Stable; import sun.invoke.util.Wrapper; @@ -39,8 +40,7 @@ import java.util.HashMap; import static java.lang.invoke.LambdaForm.BasicType.*; import static java.lang.invoke.MethodHandleNatives.Constants.REF_invokeStatic; -import static java.lang.invoke.MethodHandleStatics.debugEnabled; -import static java.lang.invoke.MethodHandleStatics.newInternalError; +import static java.lang.invoke.MethodHandleStatics.*; /** * The symbolic, non-executable form of a method handle's invocation semantics. @@ -396,7 +396,7 @@ class LambdaForm { /** Customize LambdaForm for a particular MethodHandle */ LambdaForm customize(MethodHandle mh) { LambdaForm customForm = new LambdaForm(debugName, arity, names, result, forceInline, mh); - if (COMPILE_THRESHOLD > 0 && isCompiled) { + if (COMPILE_THRESHOLD >= 0 && isCompiled) { // If shared LambdaForm has been compiled, compile customized version as well. customForm.compileToBytecode(); } @@ -411,7 +411,7 @@ class LambdaForm { } assert(transformCache != null); // Customized LambdaForm should always has a link to uncustomized version. LambdaForm uncustomizedForm = (LambdaForm)transformCache; - if (COMPILE_THRESHOLD > 0 && isCompiled) { + if (COMPILE_THRESHOLD >= 0 && isCompiled) { // If customized LambdaForm has been compiled, compile uncustomized version as well. uncustomizedForm.compileToBytecode(); } @@ -717,7 +717,7 @@ class LambdaForm { * as a sort of pre-invocation linkage step.) */ public void prepare() { - if (COMPILE_THRESHOLD == 0 && !isCompiled) { + if (COMPILE_THRESHOLD == 0 && !forceInterpretation() && !isCompiled) { compileToBytecode(); } if (this.vmentry != null) { @@ -736,10 +736,22 @@ class LambdaForm { // TO DO: Maybe add invokeGeneric, invokeWithArguments } + private static @Stable PerfCounter LF_FAILED; + + private static PerfCounter failedCompilationCounter() { + if (LF_FAILED == null) { + LF_FAILED = PerfCounter.newPerfCounter("java.lang.invoke.failedLambdaFormCompilations"); + } + return LF_FAILED; + } + /** Generate optimizable bytecode for this form. */ - MemberName compileToBytecode() { + void compileToBytecode() { + if (forceInterpretation()) { + return; // this should not be compiled + } if (vmentry != null && isCompiled) { - return vmentry; // already compiled somehow + return; // already compiled somehow } MethodType invokerType = methodType(); assert(vmentry == null || vmentry.getMethodType().basicType().equals(invokerType)); @@ -748,9 +760,16 @@ class LambdaForm { if (TRACE_INTERPRETER) traceInterpreter("compileToBytecode", this); isCompiled = true; - return vmentry; - } catch (Error | Exception ex) { - throw newInternalError(this.toString(), ex); + } catch (InvokerBytecodeGenerator.BytecodeGenerationException bge) { + // bytecode generation failed - mark this LambdaForm as to be run in interpretation mode only + invocationCounter = -1; + failedCompilationCounter().increment(); + if (LOG_LF_COMPILATION_FAILURE) { + System.out.println("LambdaForm compilation failed: " + this); + bge.printStackTrace(System.out); + } + } catch (Error | Exception e) { + throw newInternalError(this.toString(), e); } } @@ -856,7 +875,11 @@ class LambdaForm { static { COMPILE_THRESHOLD = Math.max(-1, MethodHandleStatics.COMPILE_THRESHOLD); } - private int invocationCounter = 0; + private int invocationCounter = 0; // a value of -1 indicates LambdaForm interpretation mode forever + + private boolean forceInterpretation() { + return invocationCounter == -1; + } @Hidden @DontInline @@ -896,7 +919,7 @@ class LambdaForm { private void checkInvocationCounter() { if (COMPILE_THRESHOLD != 0 && - invocationCounter < COMPILE_THRESHOLD) { + !forceInterpretation() && invocationCounter < COMPILE_THRESHOLD) { invocationCounter++; // benign race if (invocationCounter >= COMPILE_THRESHOLD) { // Replace vmentry with a bytecode version of this LF. @@ -906,7 +929,7 @@ class LambdaForm { } Object interpretWithArgumentsTracing(Object... argumentValues) throws Throwable { traceInterpreter("[ interpretWithArguments", this, argumentValues); - if (invocationCounter < COMPILE_THRESHOLD) { + if (!forceInterpretation() && invocationCounter < COMPILE_THRESHOLD) { int ctr = invocationCounter++; // benign race traceInterpreter("| invocationCounter", ctr); if (invocationCounter >= COMPILE_THRESHOLD) { diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleStatics.java b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleStatics.java index bfaba660776..6d1ff4d297f 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleStatics.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleStatics.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,10 +25,11 @@ package java.lang.invoke; -import java.util.Properties; import jdk.internal.misc.Unsafe; import sun.security.action.GetPropertyAction; +import java.util.Properties; + /** * This class consists exclusively of static names internal to the * method handle implementation. @@ -46,6 +47,7 @@ import sun.security.action.GetPropertyAction; static final boolean TRACE_INTERPRETER; static final boolean TRACE_METHOD_LINKAGE; static final int COMPILE_THRESHOLD; + static final boolean LOG_LF_COMPILATION_FAILURE; static final int DONT_INLINE_THRESHOLD; static final int PROFILE_LEVEL; static final boolean PROFILE_GWT; @@ -64,6 +66,8 @@ import sun.security.action.GetPropertyAction; props.getProperty("java.lang.invoke.MethodHandle.TRACE_METHOD_LINKAGE")); COMPILE_THRESHOLD = Integer.parseInt( props.getProperty("java.lang.invoke.MethodHandle.COMPILE_THRESHOLD", "0")); + LOG_LF_COMPILATION_FAILURE = Boolean.parseBoolean( + props.getProperty("java.lang.invoke.MethodHandle.LOG_LF_COMPILATION_FAILURE", "false")); DONT_INLINE_THRESHOLD = Integer.parseInt( props.getProperty("java.lang.invoke.MethodHandle.DONT_INLINE_THRESHOLD", "30")); PROFILE_LEVEL = Integer.parseInt( @@ -87,7 +91,8 @@ import sun.security.action.GetPropertyAction; return (DEBUG_METHOD_HANDLE_NAMES | DUMP_CLASS_FILES | TRACE_INTERPRETER | - TRACE_METHOD_LINKAGE); + TRACE_METHOD_LINKAGE | + LOG_LF_COMPILATION_FAILURE); } // handy shared exception makers (they simplify the common case code) diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandles.java b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandles.java index 8b31f502c27..1150c188b8c 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandles.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandles.java @@ -1208,22 +1208,43 @@ assertEquals(""+l, (String) MH_this.invokeExact(subl)); // Listie method *
      *
    • if the field is declared {@code final}, then the write, atomic * update, and numeric atomic update access modes are unsupported. - *
    • if the field type is anything other than {@code int}, - * {@code long} or a reference type, then atomic update access modes - * are unsupported. (Future major platform releases of the JDK may - * support additional types for certain currently unsupported access - * modes.) - *
    • if the field type is anything other than {@code int} or - * {@code long}, then numeric atomic update access modes are - * unsupported. (Future major platform releases of the JDK may - * support additional numeric types for certain currently - * unsupported access modes.) + *
    • if the field type is anything other than {@code byte}, + * {@code short}, {@code char}, {@code int} or {@code long}, + * {@code float}, or {@code double} then numeric atomic update + * access modes are unsupported. *
    *

    * If the field is declared {@code volatile} then the returned VarHandle * will override access to the field (effectively ignore the * {@code volatile} declaration) in accordance to it's specified * access modes. + *

    + * If the field type is {@code float} or {@code double} then numeric + * and atomic update access modes compare values using their bitwise + * representation (see {@link Float#floatToRawIntBits} and + * {@link Double#doubleToRawLongBits}, respectively). + * @apiNote + * Bitwise comparison of {@code float} values or {@code double} values, + * as performed by the numeric and atomic update access modes, differ + * from the primitive {@code ==} operator and the {@link Float#equals} + * and {@link Double#equals} methods, specifically with respect to + * comparing NaN values or comparing {@code -0.0} with {@code +0.0}. + * Care should be taken when performing a compare and set or a compare + * and exchange operation with such values since the operation may + * unexpectedly fail. + * There are many possible NaN values that are considered to be + * {@code NaN} in Java, although no IEEE 754 floating-point operation + * provided by Java can distinguish between them. Operation failure can + * occur if the expected or witness value is a NaN value and it is + * transformed (perhaps in a platform specific manner) into another NaN + * value, and thus has a different bitwise representation (see + * {@link Float#intBitsToFloat} or {@link Double#longBitsToDouble} for more + * details). + * The values {@code -0.0} and {@code +0.0} have different bitwise + * representations but are considered equal when using the primitive + * {@code ==} operator. Operation failure can occur if, for example, a + * numeric algorithm computes an expected value to be say {@code -0.0} + * and previously computed the witness value to be say {@code +0.0}. * @param recv the receiver class, of type {@code R}, that declares the * non-static field * @param name the field's name @@ -1306,22 +1327,43 @@ assertEquals(""+l, (String) MH_this.invokeExact(subl)); // Listie method *

      *
    • if the field is declared {@code final}, then the write, atomic * update, and numeric atomic update access modes are unsupported. - *
    • if the field type is anything other than {@code int}, - * {@code long} or a reference type, then atomic update access modes - * are unsupported. (Future major platform releases of the JDK may - * support additional types for certain currently unsupported access - * modes.) - *
    • if the field type is anything other than {@code int} or - * {@code long}, then numeric atomic update access modes are - * unsupported. (Future major platform releases of the JDK may - * support additional numeric types for certain currently - * unsupported access modes.) + *
    • if the field type is anything other than {@code byte}, + * {@code short}, {@code char}, {@code int} or {@code long}, + * {@code float}, or {@code double}, then numeric atomic update + * access modes are unsupported. *
    *

    * If the field is declared {@code volatile} then the returned VarHandle * will override access to the field (effectively ignore the * {@code volatile} declaration) in accordance to it's specified * access modes. + *

    + * If the field type is {@code float} or {@code double} then numeric + * and atomic update access modes compare values using their bitwise + * representation (see {@link Float#floatToRawIntBits} and + * {@link Double#doubleToRawLongBits}, respectively). + * @apiNote + * Bitwise comparison of {@code float} values or {@code double} values, + * as performed by the numeric and atomic update access modes, differ + * from the primitive {@code ==} operator and the {@link Float#equals} + * and {@link Double#equals} methods, specifically with respect to + * comparing NaN values or comparing {@code -0.0} with {@code +0.0}. + * Care should be taken when performing a compare and set or a compare + * and exchange operation with such values since the operation may + * unexpectedly fail. + * There are many possible NaN values that are considered to be + * {@code NaN} in Java, although no IEEE 754 floating-point operation + * provided by Java can distinguish between them. Operation failure can + * occur if the expected or witness value is a NaN value and it is + * transformed (perhaps in a platform specific manner) into another NaN + * value, and thus has a different bitwise representation (see + * {@link Float#intBitsToFloat} or {@link Double#longBitsToDouble} for more + * details). + * The values {@code -0.0} and {@code +0.0} have different bitwise + * representations but are considered equal when using the primitive + * {@code ==} operator. Operation failure can occur if, for example, a + * numeric algorithm computes an expected value to be say {@code -0.0} + * and previously computed the witness value to be say {@code +0.0}. * @param decl the class that declares the static field * @param name the field's name * @param type the field's type, of type {@code T} @@ -1590,22 +1632,43 @@ return mh1; *

      *
    • if the field is declared {@code final}, then the write, atomic * update, and numeric atomic update access modes are unsupported. - *
    • if the field type is anything other than {@code int}, - * {@code long} or a reference type, then atomic update access modes - * are unsupported. (Future major platform releases of the JDK may - * support additional types for certain currently unsupported access - * modes.) - *
    • if the field type is anything other than {@code int} or - * {@code long}, then numeric atomic update access modes are - * unsupported. (Future major platform releases of the JDK may - * support additional numeric types for certain currently - * unsupported access modes.) + *
    • if the field type is anything other than {@code byte}, + * {@code short}, {@code char}, {@code int} or {@code long}, + * {@code float}, or {@code double} then numeric atomic update + * access modes are unsupported. *
    *

    * If the field is declared {@code volatile} then the returned VarHandle * will override access to the field (effectively ignore the * {@code volatile} declaration) in accordance to it's specified * access modes. + *

    + * If the field type is {@code float} or {@code double} then numeric + * and atomic update access modes compare values using their bitwise + * representation (see {@link Float#floatToRawIntBits} and + * {@link Double#doubleToRawLongBits}, respectively). + * @apiNote + * Bitwise comparison of {@code float} values or {@code double} values, + * as performed by the numeric and atomic update access modes, differ + * from the primitive {@code ==} operator and the {@link Float#equals} + * and {@link Double#equals} methods, specifically with respect to + * comparing NaN values or comparing {@code -0.0} with {@code +0.0}. + * Care should be taken when performing a compare and set or a compare + * and exchange operation with such values since the operation may + * unexpectedly fail. + * There are many possible NaN values that are considered to be + * {@code NaN} in Java, although no IEEE 754 floating-point operation + * provided by Java can distinguish between them. Operation failure can + * occur if the expected or witness value is a NaN value and it is + * transformed (perhaps in a platform specific manner) into another NaN + * value, and thus has a different bitwise representation (see + * {@link Float#intBitsToFloat} or {@link Double#longBitsToDouble} for more + * details). + * The values {@code -0.0} and {@code +0.0} have different bitwise + * representations but are considered equal when using the primitive + * {@code ==} operator. Operation failure can occur if, for example, a + * numeric algorithm computes an expected value to be say {@code -0.0} + * and previously computed the witness value to be say {@code +0.0}. * @param f the reflected field, with a field of type {@code T}, and * a declaring class of type {@code R} * @return a VarHandle giving access to non-static fields or a static @@ -2289,17 +2352,38 @@ return mh1; * Certain access modes of the returned VarHandle are unsupported under * the following conditions: *

      - *
    • if the component type is anything other than {@code int}, - * {@code long} or a reference type, then atomic update access modes - * are unsupported. (Future major platform releases of the JDK may - * support additional types for certain currently unsupported access - * modes.) - *
    • if the component type is anything other than {@code int} or - * {@code long}, then numeric atomic update access modes are - * unsupported. (Future major platform releases of the JDK may - * support additional numeric types for certain currently - * unsupported access modes.) + *
    • if the component type is anything other than {@code byte}, + * {@code short}, {@code char}, {@code int} or {@code long}, + * {@code float}, or {@code double} then numeric atomic update access + * modes are unsupported. *
    + *

    + * If the component type is {@code float} or {@code double} then numeric + * and atomic update access modes compare values using their bitwise + * representation (see {@link Float#floatToRawIntBits} and + * {@link Double#doubleToRawLongBits}, respectively). + * @apiNote + * Bitwise comparison of {@code float} values or {@code double} values, + * as performed by the numeric and atomic update access modes, differ + * from the primitive {@code ==} operator and the {@link Float#equals} + * and {@link Double#equals} methods, specifically with respect to + * comparing NaN values or comparing {@code -0.0} with {@code +0.0}. + * Care should be taken when performing a compare and set or a compare + * and exchange operation with such values since the operation may + * unexpectedly fail. + * There are many possible NaN values that are considered to be + * {@code NaN} in Java, although no IEEE 754 floating-point operation + * provided by Java can distinguish between them. Operation failure can + * occur if the expected or witness value is a NaN value and it is + * transformed (perhaps in a platform specific manner) into another NaN + * value, and thus has a different bitwise representation (see + * {@link Float#intBitsToFloat} or {@link Double#longBitsToDouble} for more + * details). + * The values {@code -0.0} and {@code +0.0} have different bitwise + * representations but are considered equal when using the primitive + * {@code ==} operator. Operation failure can occur if, for example, a + * numeric algorithm computes an expected value to be say {@code -0.0} + * and previously computed the witness value to be say {@code +0.0}. * @param arrayClass the class of an array, of type {@code T[]} * @return a VarHandle giving access to elements of an array * @throws NullPointerException if the arrayClass is null @@ -2363,16 +2447,11 @@ return mh1; * int misalignedAtIndex = (misalignedAtZeroIndex + index) % sizeOfT; * boolean isMisaligned = misalignedAtIndex != 0; * }

  • - * - * @implNote - * The variable types {@code float} and {@code double} are supported as if - * by transformation to and access with the variable types {@code int} and - * {@code long} respectively. For example, the transformation of a - * {@code double} value to a long value is performed as if using - * {@link Double#doubleToRawLongBits(double)}, and the reverse - * transformation is performed as if using - * {@link Double#longBitsToDouble(long)}. - * + *

    + * If the variable type is {@code float} or {@code double} then atomic + * update access modes compare values using their bitwise representation + * (see {@link Float#floatToRawIntBits} and + * {@link Double#doubleToRawLongBits}, respectively). * @param viewArrayClass the view array class, with a component type of * type {@code T} * @param byteOrder the endianness of the view array elements, as @@ -2449,16 +2528,11 @@ return mh1; * int misalignedAtIndex = bb.alignmentOffset(index, sizeOfT); * boolean isMisaligned = misalignedAtIndex != 0; * } - * - * @implNote - * The variable types {@code float} and {@code double} are supported as if - * by transformation to and access with the variable types {@code int} and - * {@code long} respectively. For example, the transformation of a - * {@code double} value to a long value is performed as if using - * {@link Double#doubleToRawLongBits(double)}, and the reverse - * transformation is performed as if using - * {@link Double#longBitsToDouble(long)}. - * + *

    + * If the variable type is {@code float} or {@code double} then atomic + * update access modes compare values using their bitwise representation + * (see {@link Float#floatToRawIntBits} and + * {@link Double#doubleToRawLongBits}, respectively). * @param viewArrayClass the view array class, with a component type of * type {@code T} * @param byteOrder the endianness of the view array elements, as @@ -3353,7 +3427,8 @@ assertEquals("xy", h3.invoke("x", "y", 1, "a", "b", "c")); * @return a possibly adapted method handle * @throws NullPointerException if either argument is null * @throws IllegalArgumentException if any element of {@code newTypes} is {@code void.class}, - * or if either index is out of range in its corresponding list, + * or if {@code skip} is negative or greater than the arity of the target, + * or if {@code pos} is negative or greater than the newTypes list size, * or if the non-skipped target parameter types match the new types at {@code pos} * @since 9 */ diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/VarHandle.java b/jdk/src/java.base/share/classes/java/lang/invoke/VarHandle.java index f55acf251e2..f8f60c3962a 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/VarHandle.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/VarHandle.java @@ -139,7 +139,7 @@ import static java.lang.invoke.MethodHandleStatics.newInternalError; * {@link #weakCompareAndSetAcquire weakCompareAndSetAcquire}, * {@link #weakCompareAndSetRelease weakCompareAndSetRelease}, * {@link #compareAndExchangeAcquire compareAndExchangeAcquire}, - * {@link #compareAndExchangeVolatile compareAndExchangeVolatile}, + * {@link #compareAndExchange compareAndExchange}, * {@link #compareAndExchangeRelease compareAndExchangeRelease}, * {@link #getAndSet getAndSet}. *

  • numeric atomic update access modes that, for example, atomically get and @@ -706,9 +706,9 @@ public abstract class VarHandle { *

    The method signature is of the form {@code (CT, T expectedValue, T newValue)T}. * *

    The symbolic type descriptor at the call site of {@code - * compareAndExchangeVolatile} + * compareAndExchange} * must match the access mode type that is the result of calling - * {@code accessModeType(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)} + * {@code accessModeType(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)} * on this VarHandle. * * @param args the signature-polymorphic parameter list of the form @@ -729,7 +729,7 @@ public abstract class VarHandle { public final native @MethodHandle.PolymorphicSignature @HotSpotIntrinsicCandidate - Object compareAndExchangeVolatile(Object... args); + Object compareAndExchange(Object... args); /** * Atomically sets the value of a variable to the {@code newValue} with the @@ -1199,9 +1199,9 @@ public abstract class VarHandle { /** * The access mode whose access is specified by the corresponding * method - * {@link VarHandle#compareAndExchangeVolatile VarHandle.compareAndExchangeVolatile} + * {@link VarHandle#compareAndExchange VarHandle.compareAndExchange} */ - COMPARE_AND_EXCHANGE_VOLATILE("compareAndExchangeVolatile", AccessType.COMPARE_AND_EXCHANGE), + COMPARE_AND_EXCHANGE("compareAndExchange", AccessType.COMPARE_AND_EXCHANGE), /** * The access mode whose access is specified by the corresponding * method diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/X-VarHandle.java.template b/jdk/src/java.base/share/classes/java/lang/invoke/X-VarHandle.java.template index ebb6dd31b79..d6f5aaa380c 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/X-VarHandle.java.template +++ b/jdk/src/java.base/share/classes/java/lang/invoke/X-VarHandle.java.template @@ -132,7 +132,7 @@ final class VarHandle$Type$s { } @ForceInline - static $type$ compareAndExchangeVolatile(FieldInstanceReadWrite handle, Object holder, $type$ expected, $type$ value) { + static $type$ compareAndExchange(FieldInstanceReadWrite handle, Object holder, $type$ expected, $type$ value) { return UNSAFE.compareAndExchange$Type$Volatile(Objects.requireNonNull(handle.receiverType.cast(holder)), handle.fieldOffset, {#if[Object]?handle.fieldType.cast(expected):expected}, @@ -205,9 +205,9 @@ final class VarHandle$Type$s { @ForceInline static $type$ addAndGet(FieldInstanceReadWrite handle, Object holder, $type$ value) { - return UNSAFE.getAndAdd$Type$(Objects.requireNonNull(handle.receiverType.cast(holder)), + return {#if[ShorterThanInt]?($type$)}(UNSAFE.getAndAdd$Type$(Objects.requireNonNull(handle.receiverType.cast(holder)), handle.fieldOffset, - value) + value; + value) + value); } #end[AtomicAdd] @@ -313,7 +313,7 @@ final class VarHandle$Type$s { @ForceInline - static $type$ compareAndExchangeVolatile(FieldStaticReadWrite handle, $type$ expected, $type$ value) { + static $type$ compareAndExchange(FieldStaticReadWrite handle, $type$ expected, $type$ value) { return UNSAFE.compareAndExchange$Type$Volatile(handle.base, handle.fieldOffset, {#if[Object]?handle.fieldType.cast(expected):expected}, @@ -386,9 +386,9 @@ final class VarHandle$Type$s { @ForceInline static $type$ addAndGet(FieldStaticReadWrite handle, $type$ value) { - return UNSAFE.getAndAdd$Type$(handle.base, + return {#if[ShorterThanInt]?($type$)}(UNSAFE.getAndAdd$Type$(handle.base, handle.fieldOffset, - value) + value; + value) + value); } #end[AtomicAdd] @@ -523,7 +523,7 @@ final class VarHandle$Type$s { } @ForceInline - static $type$ compareAndExchangeVolatile(Array handle, Object oarray, int index, $type$ expected, $type$ value) { + static $type$ compareAndExchange(Array handle, Object oarray, int index, $type$ expected, $type$ value) { #if[Object] Object[] array = (Object[]) handle.arrayType.cast(oarray); #else[Object] @@ -646,9 +646,9 @@ final class VarHandle$Type$s { #else[Object] $type$[] array = ($type$[]) oarray; #end[Object] - return UNSAFE.getAndAdd$Type$(array, + return {#if[ShorterThanInt]?($type$)}(UNSAFE.getAndAdd$Type$(array, (((long) Preconditions.checkIndex(index, array.length, AIOOBE_SUPPLIER)) << handle.ashift) + handle.abase, - value) + value; + value) + value); } #end[AtomicAdd] diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/X-VarHandleByteArrayView.java.template b/jdk/src/java.base/share/classes/java/lang/invoke/X-VarHandleByteArrayView.java.template index 66bf267476e..bb2f7f0ae10 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/X-VarHandleByteArrayView.java.template +++ b/jdk/src/java.base/share/classes/java/lang/invoke/X-VarHandleByteArrayView.java.template @@ -193,7 +193,7 @@ final class VarHandleByteArrayAs$Type$s extends VarHandleByteArrayBase { } @ForceInline - static $type$ compareAndExchangeVolatile(ArrayHandle handle, Object oba, int index, $type$ expected, $type$ value) { + static $type$ compareAndExchange(ArrayHandle handle, Object oba, int index, $type$ expected, $type$ value) { byte[] ba = (byte[]) oba; return convEndian(handle.be, UNSAFE.compareAndExchange$RawType$Volatile( @@ -436,7 +436,7 @@ final class VarHandleByteArrayAs$Type$s extends VarHandleByteArrayBase { } @ForceInline - static $type$ compareAndExchangeVolatile(ByteBufferHandle handle, Object obb, int index, $type$ expected, $type$ value) { + static $type$ compareAndExchange(ByteBufferHandle handle, Object obb, int index, $type$ expected, $type$ value) { ByteBuffer bb = (ByteBuffer) obb; return convEndian(handle.be, UNSAFE.compareAndExchange$RawType$Volatile( diff --git a/jdk/src/java.base/share/classes/java/security/CodeSource.java b/jdk/src/java.base/share/classes/java/security/CodeSource.java index 6c922aad441..f710fe31fc9 100644 --- a/jdk/src/java.base/share/classes/java/security/CodeSource.java +++ b/jdk/src/java.base/share/classes/java/security/CodeSource.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -86,10 +86,9 @@ public class CodeSource implements java.io.Serializable { * Constructs a CodeSource and associates it with the specified * location and set of certificates. * - * @param url the location (URL). - * - * @param certs the certificate(s). It may be null. The contents of the - * array are copied to protect against subsequent modification. + * @param url the location (URL). It may be {@code null}. + * @param certs the certificate(s). It may be {@code null}. The contents + * of the array are copied to protect against subsequent modification. */ public CodeSource(URL url, java.security.cert.Certificate[] certs) { this.location = url; @@ -107,9 +106,9 @@ public class CodeSource implements java.io.Serializable { * Constructs a CodeSource and associates it with the specified * location and set of code signers. * - * @param url the location (URL). - * @param signers the code signers. It may be null. The contents of the - * array are copied to protect against subsequent modification. + * @param url the location (URL). It may be {@code null}. + * @param signers the code signers. It may be {@code null}. The contents + * of the array are copied to protect against subsequent modification. * * @since 1.5 */ @@ -176,7 +175,8 @@ public class CodeSource implements java.io.Serializable { /** * Returns the location associated with this CodeSource. * - * @return the location (URL). + * @return the location (URL), or {@code null} if no URL was supplied + * during construction. */ public final URL getLocation() { /* since URL is practically immutable, returning itself is not @@ -203,7 +203,8 @@ public class CodeSource implements java.io.Serializable { * bottom-to-top (i.e., with the signer certificate first and the (root) * certificate authority last). * - * @return A copy of the certificates array, or null if there is none. + * @return a copy of the certificate array, or {@code null} if there + * is none. */ public final java.security.cert.Certificate[] getCertificates() { if (certs != null) { @@ -235,7 +236,8 @@ public class CodeSource implements java.io.Serializable { * create an array of CodeSigner objects. Note that only X.509 certificates * are examined - all other certificate types are ignored. * - * @return A copy of the code signer array, or null if there is none. + * @return a copy of the code signer array, or {@code null} if there + * is none. * * @since 1.5 */ @@ -322,7 +324,6 @@ public class CodeSource implements java.io.Serializable { * @return true if the specified codesource is implied by this codesource, * false if not. */ - public boolean implies(CodeSource codesource) { if (codesource == null) @@ -336,7 +337,7 @@ public class CodeSource implements java.io.Serializable { * CodeSource are also in that. * * @param that the CodeSource to check against. - * @param strict If true then a strict equality match is performed. + * @param strict if true then a strict equality match is performed. * Otherwise a subset match is performed. */ boolean matchCerts(CodeSource that, boolean strict) @@ -622,7 +623,7 @@ public class CodeSource implements java.io.Serializable { * The array of certificates is a concatenation of certificate chains * where the initial certificate in each chain is the end-entity cert. * - * @return An array of code signers or null if none are generated. + * @return an array of code signers or null if none are generated. */ private CodeSigner[] convertCertArrayToSignerArray( java.security.cert.Certificate[] certs) { diff --git a/jdk/src/java.base/share/classes/java/text/DateFormatSymbols.java b/jdk/src/java.base/share/classes/java/text/DateFormatSymbols.java index f94a94e252f..5284bcd3907 100644 --- a/jdk/src/java.base/share/classes/java/text/DateFormatSymbols.java +++ b/jdk/src/java.base/share/classes/java/text/DateFormatSymbols.java @@ -418,7 +418,7 @@ public class DateFormatSymbols implements Serializable, Cloneable { * Gets short month strings. For example: "Jan", "Feb", etc. * *

    If the language requires different forms for formatting and - * stand-alone usages, This method returns short month names in + * stand-alone usages, this method returns short month names in * the formatting form. For example, the preferred abbreviation * for January in the Catalan language is de gen. in the * formatting form, while it is gen. in the stand-alone diff --git a/jdk/src/java.base/share/classes/java/text/SimpleDateFormat.java b/jdk/src/java.base/share/classes/java/text/SimpleDateFormat.java index b464b6c71a4..d6d6787c72f 100644 --- a/jdk/src/java.base/share/classes/java/text/SimpleDateFormat.java +++ b/jdk/src/java.base/share/classes/java/text/SimpleDateFormat.java @@ -276,9 +276,16 @@ import sun.util.locale.provider.LocaleProviderAdapter; * it is interpreted as a number.
    *

      *
    • Letter M produces context-sensitive month names, such as the - * embedded form of names. If a {@code DateFormatSymbols} has been set - * explicitly with constructor {@link #SimpleDateFormat(String, - * DateFormatSymbols)} or method {@link + * embedded form of names. Letter M is context-sensitive in the + * sense that when it is used in the standalone pattern, for example, + * "MMMM", it gives the standalone form of a month name and when it is + * used in the pattern containing other field(s), for example, "d MMMM", + * it gives the format form of a month name. For example, January in the + * Catalan language is "de gener" in the format form while it is "gener" + * in the standalone form. In this case, "MMMM" will produce "gener" and + * the month part of the "d MMMM" will produce "de gener". If a + * {@code DateFormatSymbols} has been set explicitly with constructor + * {@link #SimpleDateFormat(String,DateFormatSymbols)} or method {@link * #setDateFormatSymbols(DateFormatSymbols)}, the month names given by * the {@code DateFormatSymbols} are used.
    • *
    • Letter L produces the standalone form of month names.
    • diff --git a/jdk/src/java.base/share/classes/java/util/AbstractList.java b/jdk/src/java.base/share/classes/java/util/AbstractList.java index 3168a738acc..c8c160de6a4 100644 --- a/jdk/src/java.base/share/classes/java/util/AbstractList.java +++ b/jdk/src/java.base/share/classes/java/util/AbstractList.java @@ -25,6 +25,8 @@ package java.util; +import java.util.function.Consumer; + /** * This class provides a skeletal implementation of the {@link List} * interface to minimize the effort required to implement this interface @@ -634,6 +636,115 @@ public abstract class AbstractList extends AbstractCollection implements L return "Index: "+index+", Size: "+size(); } + /** + * An index-based split-by-two, lazily initialized Spliterator covering + * a List that access elements via {@link List#get}. + * + * If access results in an IndexOutOfBoundsException then a + * ConcurrentModificationException is thrown instead (since the list has + * been structurally modified while traversing). + * + * If the List is an instance of AbstractList then concurrent modification + * checking is performed using the AbstractList's modCount field. + */ + static final class RandomAccessSpliterator implements Spliterator { + + private final List list; + private int index; // current index, modified on advance/split + private int fence; // -1 until used; then one past last index + + // The following fields are valid if covering an AbstractList + private final AbstractList alist; + private int expectedModCount; // initialized when fence set + + RandomAccessSpliterator(List list) { + assert list instanceof RandomAccess; + + this.list = list; + this.index = 0; + this.fence = -1; + + this.alist = list instanceof AbstractList ? (AbstractList) list : null; + this.expectedModCount = alist != null ? alist.modCount : 0; + } + + /** Create new spliterator covering the given range */ + private RandomAccessSpliterator(RandomAccessSpliterator parent, + int origin, int fence) { + this.list = parent.list; + this.index = origin; + this.fence = fence; + + this.alist = parent.alist; + this.expectedModCount = parent.expectedModCount; + } + + private int getFence() { // initialize fence to size on first use + int hi; + List lst = list; + if ((hi = fence) < 0) { + if (alist != null) { + expectedModCount = alist.modCount; + } + hi = fence = lst.size(); + } + return hi; + } + + public Spliterator trySplit() { + int hi = getFence(), lo = index, mid = (lo + hi) >>> 1; + return (lo >= mid) ? null : // divide range in half unless too small + new RandomAccessSpliterator<>(this, lo, index = mid); + } + + public boolean tryAdvance(Consumer action) { + if (action == null) + throw new NullPointerException(); + int hi = getFence(), i = index; + if (i < hi) { + index = i + 1; + action.accept(get(list, i)); + checkAbstractListModCount(alist, expectedModCount); + return true; + } + return false; + } + + public void forEachRemaining(Consumer action) { + Objects.requireNonNull(action); + List lst = list; + int hi = getFence(); + int i = index; + index = hi; + for (; i < hi; i++) { + action.accept(get(lst, i)); + } + checkAbstractListModCount(alist, expectedModCount); + } + + public long estimateSize() { + return (long) (getFence() - index); + } + + public int characteristics() { + return Spliterator.ORDERED | Spliterator.SIZED | Spliterator.SUBSIZED; + } + + private static E get(List list, int i) { + try { + return list.get(i); + } catch (IndexOutOfBoundsException ex) { + throw new ConcurrentModificationException(); + } + } + + static void checkAbstractListModCount(AbstractList alist, int expectedModCount) { + if (alist != null && alist.modCount != expectedModCount) { + throw new ConcurrentModificationException(); + } + } + } + private static class SubList extends AbstractList { private final AbstractList root; private final SubList parent; diff --git a/jdk/src/java.base/share/classes/java/util/List.java b/jdk/src/java.base/share/classes/java/util/List.java index d4af1a31d49..3819d94e831 100644 --- a/jdk/src/java.base/share/classes/java/util/List.java +++ b/jdk/src/java.base/share/classes/java/util/List.java @@ -741,9 +741,22 @@ public interface List extends Collection { * * @implSpec * The default implementation creates a - * late-binding spliterator - * from the list's {@code Iterator}. The spliterator inherits the - * fail-fast properties of the list's iterator. + * late-binding + * spliterator as follows: + *
        + *
      • If the list is an instance of {@link RandomAccess} then the default + * implementation creates a spliterator that traverses elements by + * invoking the method {@link List#get}. If such invocation results or + * would result in an {@code IndexOutOfBoundsException} then the + * spliterator will fail-fast and throw a + * {@code ConcurrentModificationException}. + * If the list is also an instance of {@link AbstractList} then the + * spliterator will use the list's {@link AbstractList#modCount modCount} + * field to provide additional fail-fast behavior. + *
      • Otherwise, the default implementation creates a spliterator from the + * list's {@code Iterator}. The spliterator inherits the + * fail-fast of the list's iterator. + *
      * * @implNote * The created {@code Spliterator} additionally reports @@ -754,7 +767,11 @@ public interface List extends Collection { */ @Override default Spliterator spliterator() { - return Spliterators.spliterator(this, Spliterator.ORDERED); + if (this instanceof RandomAccess) { + return new AbstractList.RandomAccessSpliterator<>(this); + } else { + return Spliterators.spliterator(this, Spliterator.ORDERED); + } } /** diff --git a/jdk/src/java.base/share/classes/java/util/zip/Deflater.java b/jdk/src/java.base/share/classes/java/util/zip/Deflater.java index 3e0089e079f..bf70f4dd8a1 100644 --- a/jdk/src/java.base/share/classes/java/util/zip/Deflater.java +++ b/jdk/src/java.base/share/classes/java/util/zip/Deflater.java @@ -417,7 +417,10 @@ class Deflater { *

      In the case of {@link #FULL_FLUSH} or {@link #SYNC_FLUSH}, if * the return value is {@code len}, the space available in output * buffer {@code b}, this method should be invoked again with the same - * {@code flush} parameter and more output space. + * {@code flush} parameter and more output space. Make sure that + * {@code len} is greater than 6 to avoid flush marker (5 bytes) being + * repeatedly output to the output buffer every time this method is + * invoked. * * @param b the buffer for the compressed data * @param off the start offset of the data diff --git a/jdk/src/java.base/share/classes/javax/crypto/ExemptionMechanism.java b/jdk/src/java.base/share/classes/javax/crypto/ExemptionMechanism.java index e6bbf825fa2..45d14027200 100644 --- a/jdk/src/java.base/share/classes/javax/crypto/ExemptionMechanism.java +++ b/jdk/src/java.base/share/classes/javax/crypto/ExemptionMechanism.java @@ -482,13 +482,4 @@ public class ExemptionMechanism { done = true; return n; } - - /** - * Ensures that the key stored away by this ExemptionMechanism - * object will be wiped out when there are no more references to it. - */ - protected void finalize() { - keyStored = null; - // Are there anything else we could do? - } } diff --git a/jdk/src/java.base/share/classes/javax/security/cert/Certificate.java b/jdk/src/java.base/share/classes/javax/security/cert/Certificate.java index 84fdefde609..9021a6244cb 100644 --- a/jdk/src/java.base/share/classes/javax/security/cert/Certificate.java +++ b/jdk/src/java.base/share/classes/javax/security/cert/Certificate.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -58,10 +58,11 @@ import java.security.SignatureException; * @since 1.4 * @see X509Certificate * @deprecated Use the classes in {@code java.security.cert} instead. + * This class is subject to removal in a future version of Java SE. * * @author Hemma Prafullchandra */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public abstract class Certificate { /** diff --git a/jdk/src/java.base/share/classes/javax/security/cert/CertificateEncodingException.java b/jdk/src/java.base/share/classes/javax/security/cert/CertificateEncodingException.java index 95fbcfbeb1e..dfbf56bfcfa 100644 --- a/jdk/src/java.base/share/classes/javax/security/cert/CertificateEncodingException.java +++ b/jdk/src/java.base/share/classes/javax/security/cert/CertificateEncodingException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -39,8 +39,9 @@ package javax.security.cert; * @since 1.4 * @author Hemma Prafullchandra * @deprecated Use the classes in {@code java.security.cert} instead. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public class CertificateEncodingException extends CertificateException { private static final long serialVersionUID = -8187642723048403470L; diff --git a/jdk/src/java.base/share/classes/javax/security/cert/CertificateException.java b/jdk/src/java.base/share/classes/javax/security/cert/CertificateException.java index 144bb97fe6a..f26efb87172 100644 --- a/jdk/src/java.base/share/classes/javax/security/cert/CertificateException.java +++ b/jdk/src/java.base/share/classes/javax/security/cert/CertificateException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -39,8 +39,9 @@ package javax.security.cert; * @since 1.4 * @see Certificate * @deprecated Use the classes in {@code java.security.cert} instead. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public class CertificateException extends Exception { private static final long serialVersionUID = -5757213374030785290L; diff --git a/jdk/src/java.base/share/classes/javax/security/cert/CertificateExpiredException.java b/jdk/src/java.base/share/classes/javax/security/cert/CertificateExpiredException.java index 9f4eb7d4aed..c3303009c8f 100644 --- a/jdk/src/java.base/share/classes/javax/security/cert/CertificateExpiredException.java +++ b/jdk/src/java.base/share/classes/javax/security/cert/CertificateExpiredException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -41,8 +41,9 @@ package javax.security.cert; * @since 1.4 * @author Hemma Prafullchandra * @deprecated Use the classes in {@code java.security.cert} instead. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public class CertificateExpiredException extends CertificateException { private static final long serialVersionUID = 5091601212177261883L; diff --git a/jdk/src/java.base/share/classes/javax/security/cert/CertificateNotYetValidException.java b/jdk/src/java.base/share/classes/javax/security/cert/CertificateNotYetValidException.java index c5c67c7f61e..be076e09c86 100644 --- a/jdk/src/java.base/share/classes/javax/security/cert/CertificateNotYetValidException.java +++ b/jdk/src/java.base/share/classes/javax/security/cert/CertificateNotYetValidException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -41,8 +41,9 @@ package javax.security.cert; * @since 1.4 * @author Hemma Prafullchandra * @deprecated Use the classes in {@code java.security.cert} instead. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public class CertificateNotYetValidException extends CertificateException { private static final long serialVersionUID = -8976172474266822818L; diff --git a/jdk/src/java.base/share/classes/javax/security/cert/CertificateParsingException.java b/jdk/src/java.base/share/classes/javax/security/cert/CertificateParsingException.java index cd1f6ac507c..b099673277a 100644 --- a/jdk/src/java.base/share/classes/javax/security/cert/CertificateParsingException.java +++ b/jdk/src/java.base/share/classes/javax/security/cert/CertificateParsingException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -40,8 +40,9 @@ package javax.security.cert; * @since 1.4 * @author Hemma Prafullchandra * @deprecated Use the classes in {@code java.security.cert} instead. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public class CertificateParsingException extends CertificateException { private static final long serialVersionUID = -8449352422951136229L; diff --git a/jdk/src/java.base/share/classes/javax/security/cert/X509Certificate.java b/jdk/src/java.base/share/classes/javax/security/cert/X509Certificate.java index 511d6ef601b..83587e233b6 100644 --- a/jdk/src/java.base/share/classes/javax/security/cert/X509Certificate.java +++ b/jdk/src/java.base/share/classes/javax/security/cert/X509Certificate.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -125,8 +125,9 @@ import java.util.Date; * @see java.security.cert.X509Extension * @see java.security.Security security properties * @deprecated Use the classes in {@code java.security.cert} instead. + * This class is subject to removal in a future version of Java SE. */ -@Deprecated +@Deprecated(since="9", forRemoval=true) public abstract class X509Certificate extends Certificate { /* diff --git a/jdk/src/java.base/share/classes/jdk/internal/misc/Unsafe.java b/jdk/src/java.base/share/classes/jdk/internal/misc/Unsafe.java index 77bdf2db106..2324323c0f1 100644 --- a/jdk/src/java.base/share/classes/jdk/internal/misc/Unsafe.java +++ b/jdk/src/java.base/share/classes/jdk/internal/misc/Unsafe.java @@ -25,16 +25,14 @@ package jdk.internal.misc; -import java.lang.reflect.Field; -import java.security.ProtectionDomain; - +import jdk.internal.HotSpotIntrinsicCandidate; import jdk.internal.reflect.CallerSensitive; import jdk.internal.reflect.Reflection; -import jdk.internal.misc.VM; - -import jdk.internal.HotSpotIntrinsicCandidate; import jdk.internal.vm.annotation.ForceInline; +import java.lang.reflect.Field; +import java.security.ProtectionDomain; + /** * A collection of methods for performing low-level, unsafe operations. @@ -1400,6 +1398,453 @@ public final class Unsafe { return compareAndSwapInt(o, offset, expected, x); } + @HotSpotIntrinsicCandidate + public final byte compareAndExchangeByteVolatile(Object o, long offset, + byte expected, + byte x) { + long wordOffset = offset & ~3; + int shift = (int) (offset & 3) << 3; + if (BE) { + shift = 24 - shift; + } + int mask = 0xFF << shift; + int maskedExpected = (expected & 0xFF) << shift; + int maskedX = (x & 0xFF) << shift; + int fullWord; + do { + fullWord = getIntVolatile(o, wordOffset); + if ((fullWord & mask) != maskedExpected) + return (byte) ((fullWord & mask) >> shift); + } while (!weakCompareAndSwapIntVolatile(o, wordOffset, + fullWord, (fullWord & ~mask) | maskedX)); + return expected; + } + + @HotSpotIntrinsicCandidate + public final boolean compareAndSwapByte(Object o, long offset, + byte expected, + byte x) { + return compareAndExchangeByteVolatile(o, offset, expected, x) == expected; + } + + @HotSpotIntrinsicCandidate + public final boolean weakCompareAndSwapByteVolatile(Object o, long offset, + byte expected, + byte x) { + return compareAndSwapByte(o, offset, expected, x); + } + + @HotSpotIntrinsicCandidate + public final boolean weakCompareAndSwapByteAcquire(Object o, long offset, + byte expected, + byte x) { + return weakCompareAndSwapByteVolatile(o, offset, expected, x); + } + + @HotSpotIntrinsicCandidate + public final boolean weakCompareAndSwapByteRelease(Object o, long offset, + byte expected, + byte x) { + return weakCompareAndSwapByteVolatile(o, offset, expected, x); + } + + @HotSpotIntrinsicCandidate + public final boolean weakCompareAndSwapByte(Object o, long offset, + byte expected, + byte x) { + return weakCompareAndSwapByteVolatile(o, offset, expected, x); + } + + @HotSpotIntrinsicCandidate + public final byte compareAndExchangeByteAcquire(Object o, long offset, + byte expected, + byte x) { + return compareAndExchangeByteVolatile(o, offset, expected, x); + } + + @HotSpotIntrinsicCandidate + public final byte compareAndExchangeByteRelease(Object o, long offset, + byte expected, + byte x) { + return compareAndExchangeByteVolatile(o, offset, expected, x); + } + + @HotSpotIntrinsicCandidate + public final short compareAndExchangeShortVolatile(Object o, long offset, + short expected, + short x) { + if ((offset & 3) == 3) { + throw new IllegalArgumentException("Update spans the word, not supported"); + } + long wordOffset = offset & ~3; + int shift = (int) (offset & 3) << 3; + if (BE) { + shift = 16 - shift; + } + int mask = 0xFFFF << shift; + int maskedExpected = (expected & 0xFFFF) << shift; + int maskedX = (x & 0xFFFF) << shift; + int fullWord; + do { + fullWord = getIntVolatile(o, wordOffset); + if ((fullWord & mask) != maskedExpected) { + return (short) ((fullWord & mask) >> shift); + } + } while (!weakCompareAndSwapIntVolatile(o, wordOffset, + fullWord, (fullWord & ~mask) | maskedX)); + return expected; + } + + @HotSpotIntrinsicCandidate + public final boolean compareAndSwapShort(Object o, long offset, + short expected, + short x) { + return compareAndExchangeShortVolatile(o, offset, expected, x) == expected; + } + + @HotSpotIntrinsicCandidate + public final boolean weakCompareAndSwapShortVolatile(Object o, long offset, + short expected, + short x) { + return compareAndSwapShort(o, offset, expected, x); + } + + @HotSpotIntrinsicCandidate + public final boolean weakCompareAndSwapShortAcquire(Object o, long offset, + short expected, + short x) { + return weakCompareAndSwapShortVolatile(o, offset, expected, x); + } + + @HotSpotIntrinsicCandidate + public final boolean weakCompareAndSwapShortRelease(Object o, long offset, + short expected, + short x) { + return weakCompareAndSwapShortVolatile(o, offset, expected, x); + } + + @HotSpotIntrinsicCandidate + public final boolean weakCompareAndSwapShort(Object o, long offset, + short expected, + short x) { + return weakCompareAndSwapShortVolatile(o, offset, expected, x); + } + + + @HotSpotIntrinsicCandidate + public final short compareAndExchangeShortAcquire(Object o, long offset, + short expected, + short x) { + return compareAndExchangeShortVolatile(o, offset, expected, x); + } + + @HotSpotIntrinsicCandidate + public final short compareAndExchangeShortRelease(Object o, long offset, + short expected, + short x) { + return compareAndExchangeShortVolatile(o, offset, expected, x); + } + + @ForceInline + private char s2c(short s) { + return (char) s; + } + + @ForceInline + private short c2s(char s) { + return (short) s; + } + + @ForceInline + public final boolean compareAndSwapChar(Object o, long offset, + char expected, + char x) { + return compareAndSwapShort(o, offset, c2s(expected), c2s(x)); + } + + @ForceInline + public final char compareAndExchangeCharVolatile(Object o, long offset, + char expected, + char x) { + return s2c(compareAndExchangeShortVolatile(o, offset, c2s(expected), c2s(x))); + } + + @ForceInline + public final char compareAndExchangeCharAcquire(Object o, long offset, + char expected, + char x) { + return s2c(compareAndExchangeShortAcquire(o, offset, c2s(expected), c2s(x))); + } + + @ForceInline + public final char compareAndExchangeCharRelease(Object o, long offset, + char expected, + char x) { + return s2c(compareAndExchangeShortRelease(o, offset, c2s(expected), c2s(x))); + } + + @ForceInline + public final boolean weakCompareAndSwapCharVolatile(Object o, long offset, + char expected, + char x) { + return weakCompareAndSwapShortVolatile(o, offset, c2s(expected), c2s(x)); + } + + @ForceInline + public final boolean weakCompareAndSwapCharAcquire(Object o, long offset, + char expected, + char x) { + return weakCompareAndSwapShortAcquire(o, offset, c2s(expected), c2s(x)); + } + + @ForceInline + public final boolean weakCompareAndSwapCharRelease(Object o, long offset, + char expected, + char x) { + return weakCompareAndSwapShortRelease(o, offset, c2s(expected), c2s(x)); + } + + @ForceInline + public final boolean weakCompareAndSwapChar(Object o, long offset, + char expected, + char x) { + return weakCompareAndSwapShort(o, offset, c2s(expected), c2s(x)); + } + + @ForceInline + private boolean byte2bool(byte b) { + return b > 0; + } + + @ForceInline + private byte bool2byte(boolean b) { + return b ? (byte)1 : (byte)0; + } + + @ForceInline + public final boolean compareAndSwapBoolean(Object o, long offset, + boolean expected, + boolean x) { + return compareAndSwapByte(o, offset, bool2byte(expected), bool2byte(x)); + } + + @ForceInline + public final boolean compareAndExchangeBooleanVolatile(Object o, long offset, + boolean expected, + boolean x) { + return byte2bool(compareAndExchangeByteVolatile(o, offset, bool2byte(expected), bool2byte(x))); + } + + @ForceInline + public final boolean compareAndExchangeBooleanAcquire(Object o, long offset, + boolean expected, + boolean x) { + return byte2bool(compareAndExchangeByteAcquire(o, offset, bool2byte(expected), bool2byte(x))); + } + + @ForceInline + public final boolean compareAndExchangeBooleanRelease(Object o, long offset, + boolean expected, + boolean x) { + return byte2bool(compareAndExchangeByteRelease(o, offset, bool2byte(expected), bool2byte(x))); + } + + @ForceInline + public final boolean weakCompareAndSwapBooleanVolatile(Object o, long offset, + boolean expected, + boolean x) { + return weakCompareAndSwapByteVolatile(o, offset, bool2byte(expected), bool2byte(x)); + } + + @ForceInline + public final boolean weakCompareAndSwapBooleanAcquire(Object o, long offset, + boolean expected, + boolean x) { + return weakCompareAndSwapByteAcquire(o, offset, bool2byte(expected), bool2byte(x)); + } + + @ForceInline + public final boolean weakCompareAndSwapBooleanRelease(Object o, long offset, + boolean expected, + boolean x) { + return weakCompareAndSwapByteRelease(o, offset, bool2byte(expected), bool2byte(x)); + } + + @ForceInline + public final boolean weakCompareAndSwapBoolean(Object o, long offset, + boolean expected, + boolean x) { + return weakCompareAndSwapByte(o, offset, bool2byte(expected), bool2byte(x)); + } + + /** + * Atomically updates Java variable to {@code x} if it is currently + * holding {@code expected}. + * + *

      This operation has memory semantics of a {@code volatile} read + * and write. Corresponds to C11 atomic_compare_exchange_strong. + * + * @return {@code true} if successful + */ + @ForceInline + public final boolean compareAndSwapFloat(Object o, long offset, + float expected, + float x) { + return compareAndSwapInt(o, offset, + Float.floatToRawIntBits(expected), + Float.floatToRawIntBits(x)); + } + + @ForceInline + public final float compareAndExchangeFloatVolatile(Object o, long offset, + float expected, + float x) { + int w = compareAndExchangeIntVolatile(o, offset, + Float.floatToRawIntBits(expected), + Float.floatToRawIntBits(x)); + return Float.intBitsToFloat(w); + } + + @ForceInline + public final float compareAndExchangeFloatAcquire(Object o, long offset, + float expected, + float x) { + int w = compareAndExchangeIntAcquire(o, offset, + Float.floatToRawIntBits(expected), + Float.floatToRawIntBits(x)); + return Float.intBitsToFloat(w); + } + + @ForceInline + public final float compareAndExchangeFloatRelease(Object o, long offset, + float expected, + float x) { + int w = compareAndExchangeIntRelease(o, offset, + Float.floatToRawIntBits(expected), + Float.floatToRawIntBits(x)); + return Float.intBitsToFloat(w); + } + + @ForceInline + public final boolean weakCompareAndSwapFloat(Object o, long offset, + float expected, + float x) { + return weakCompareAndSwapInt(o, offset, + Float.floatToRawIntBits(expected), + Float.floatToRawIntBits(x)); + } + + @ForceInline + public final boolean weakCompareAndSwapFloatAcquire(Object o, long offset, + float expected, + float x) { + return weakCompareAndSwapIntAcquire(o, offset, + Float.floatToRawIntBits(expected), + Float.floatToRawIntBits(x)); + } + + @ForceInline + public final boolean weakCompareAndSwapFloatRelease(Object o, long offset, + float expected, + float x) { + return weakCompareAndSwapIntRelease(o, offset, + Float.floatToRawIntBits(expected), + Float.floatToRawIntBits(x)); + } + + @ForceInline + public final boolean weakCompareAndSwapFloatVolatile(Object o, long offset, + float expected, + float x) { + return weakCompareAndSwapIntVolatile(o, offset, + Float.floatToRawIntBits(expected), + Float.floatToRawIntBits(x)); + } + + /** + * Atomically updates Java variable to {@code x} if it is currently + * holding {@code expected}. + * + *

      This operation has memory semantics of a {@code volatile} read + * and write. Corresponds to C11 atomic_compare_exchange_strong. + * + * @return {@code true} if successful + */ + @ForceInline + public final boolean compareAndSwapDouble(Object o, long offset, + double expected, + double x) { + return compareAndSwapLong(o, offset, + Double.doubleToRawLongBits(expected), + Double.doubleToRawLongBits(x)); + } + + @ForceInline + public final double compareAndExchangeDoubleVolatile(Object o, long offset, + double expected, + double x) { + long w = compareAndExchangeLongVolatile(o, offset, + Double.doubleToRawLongBits(expected), + Double.doubleToRawLongBits(x)); + return Double.longBitsToDouble(w); + } + + @ForceInline + public final double compareAndExchangeDoubleAcquire(Object o, long offset, + double expected, + double x) { + long w = compareAndExchangeLongAcquire(o, offset, + Double.doubleToRawLongBits(expected), + Double.doubleToRawLongBits(x)); + return Double.longBitsToDouble(w); + } + + @ForceInline + public final double compareAndExchangeDoubleRelease(Object o, long offset, + double expected, + double x) { + long w = compareAndExchangeLongRelease(o, offset, + Double.doubleToRawLongBits(expected), + Double.doubleToRawLongBits(x)); + return Double.longBitsToDouble(w); + } + + @ForceInline + public final boolean weakCompareAndSwapDouble(Object o, long offset, + double expected, + double x) { + return weakCompareAndSwapLong(o, offset, + Double.doubleToRawLongBits(expected), + Double.doubleToRawLongBits(x)); + } + + @ForceInline + public final boolean weakCompareAndSwapDoubleAcquire(Object o, long offset, + double expected, + double x) { + return weakCompareAndSwapLongAcquire(o, offset, + Double.doubleToRawLongBits(expected), + Double.doubleToRawLongBits(x)); + } + + @ForceInline + public final boolean weakCompareAndSwapDoubleRelease(Object o, long offset, + double expected, + double x) { + return weakCompareAndSwapLongRelease(o, offset, + Double.doubleToRawLongBits(expected), + Double.doubleToRawLongBits(x)); + } + + @ForceInline + public final boolean weakCompareAndSwapDoubleVolatile(Object o, long offset, + double expected, + double x) { + return weakCompareAndSwapLongVolatile(o, offset, + Double.doubleToRawLongBits(expected), + Double.doubleToRawLongBits(x)); + } + /** * Atomically updates Java variable to {@code x} if it is currently * holding {@code expected}. @@ -1840,7 +2285,7 @@ public final class Unsafe { int v; do { v = getIntVolatile(o, offset); - } while (!compareAndSwapInt(o, offset, v, v + delta)); + } while (!weakCompareAndSwapIntVolatile(o, offset, v, v + delta)); return v; } @@ -1860,7 +2305,60 @@ public final class Unsafe { long v; do { v = getLongVolatile(o, offset); - } while (!compareAndSwapLong(o, offset, v, v + delta)); + } while (!weakCompareAndSwapLongVolatile(o, offset, v, v + delta)); + return v; + } + + @HotSpotIntrinsicCandidate + public final byte getAndAddByte(Object o, long offset, byte delta) { + byte v; + do { + v = getByteVolatile(o, offset); + } while (!weakCompareAndSwapByteVolatile(o, offset, v, (byte) (v + delta))); + return v; + } + + @HotSpotIntrinsicCandidate + public final short getAndAddShort(Object o, long offset, short delta) { + short v; + do { + v = getShortVolatile(o, offset); + } while (!weakCompareAndSwapShortVolatile(o, offset, v, (short) (v + delta))); + return v; + } + + @ForceInline + public final char getAndAddChar(Object o, long offset, char delta) { + return (char) getAndAddShort(o, offset, (short) delta); + } + + @ForceInline + public final float getAndAddFloat(Object o, long offset, float delta) { + int expectedBits; + float v; + do { + // Load and CAS with the raw bits to avoid issues with NaNs and + // possible bit conversion from signaling NaNs to quiet NaNs that + // may result in the loop not terminating. + expectedBits = getIntVolatile(o, offset); + v = Float.intBitsToFloat(expectedBits); + } while (!weakCompareAndSwapIntVolatile(o, offset, + expectedBits, Float.floatToRawIntBits(v + delta))); + return v; + } + + @ForceInline + public final double getAndAddDouble(Object o, long offset, double delta) { + long expectedBits; + double v; + do { + // Load and CAS with the raw bits to avoid issues with NaNs and + // possible bit conversion from signaling NaNs to quiet NaNs that + // may result in the loop not terminating. + expectedBits = getLongVolatile(o, offset); + v = Double.longBitsToDouble(expectedBits); + } while (!weakCompareAndSwapLongVolatile(o, offset, + expectedBits, Double.doubleToRawLongBits(v + delta))); return v; } @@ -1880,7 +2378,7 @@ public final class Unsafe { int v; do { v = getIntVolatile(o, offset); - } while (!compareAndSwapInt(o, offset, v, newValue)); + } while (!weakCompareAndSwapIntVolatile(o, offset, v, newValue)); return v; } @@ -1900,7 +2398,7 @@ public final class Unsafe { long v; do { v = getLongVolatile(o, offset); - } while (!compareAndSwapLong(o, offset, v, newValue)); + } while (!weakCompareAndSwapLongVolatile(o, offset, v, newValue)); return v; } @@ -1920,10 +2418,49 @@ public final class Unsafe { Object v; do { v = getObjectVolatile(o, offset); - } while (!compareAndSwapObject(o, offset, v, newValue)); + } while (!weakCompareAndSwapObjectVolatile(o, offset, v, newValue)); return v; } + @HotSpotIntrinsicCandidate + public final byte getAndSetByte(Object o, long offset, byte newValue) { + byte v; + do { + v = getByteVolatile(o, offset); + } while (!weakCompareAndSwapByteVolatile(o, offset, v, newValue)); + return v; + } + + @ForceInline + public final boolean getAndSetBoolean(Object o, long offset, boolean newValue) { + return byte2bool(getAndSetByte(o, offset, bool2byte(newValue))); + } + + @HotSpotIntrinsicCandidate + public final short getAndSetShort(Object o, long offset, short newValue) { + short v; + do { + v = getShortVolatile(o, offset); + } while (!weakCompareAndSwapShortVolatile(o, offset, v, newValue)); + return v; + } + + @ForceInline + public final char getAndSetChar(Object o, long offset, char newValue) { + return s2c(getAndSetShort(o, offset, c2s(newValue))); + } + + @ForceInline + public final float getAndSetFloat(Object o, long offset, float newValue) { + int v = getAndSetInt(o, offset, Float.floatToRawIntBits(newValue)); + return Float.intBitsToFloat(v); + } + + @ForceInline + public final double getAndSetDouble(Object o, long offset, double newValue) { + long v = getAndSetLong(o, offset, Double.doubleToRawLongBits(newValue)); + return Double.longBitsToDouble(v); + } /** * Ensures that loads before the fence will not be reordered with loads and diff --git a/jdk/src/java.base/share/classes/jdk/internal/misc/VM.java b/jdk/src/java.base/share/classes/jdk/internal/misc/VM.java index 82df6e93b85..9fe63d56e5e 100644 --- a/jdk/src/java.base/share/classes/jdk/internal/misc/VM.java +++ b/jdk/src/java.base/share/classes/jdk/internal/misc/VM.java @@ -30,120 +30,6 @@ import java.util.Properties; public class VM { - /* The following methods used to be native methods that instruct - * the VM to selectively suspend certain threads in low-memory - * situations. They are inherently dangerous and not implementable - * on native threads. We removed them in JDK 1.2. The skeletons - * remain so that existing applications that use these methods - * will still work. - */ - private static boolean suspended = false; - - /** @deprecated */ - @Deprecated - public static boolean threadsSuspended() { - return suspended; - } - - @SuppressWarnings("deprecation") - public static boolean allowThreadSuspension(ThreadGroup g, boolean b) { - return g.allowThreadSuspension(b); - } - - /** @deprecated */ - @Deprecated - public static boolean suspendThreads() { - suspended = true; - return true; - } - - // Causes any suspended threadgroups to be resumed. - /** @deprecated */ - @Deprecated - public static void unsuspendThreads() { - suspended = false; - } - - // Causes threadgroups no longer marked suspendable to be resumed. - /** @deprecated */ - @Deprecated - public static void unsuspendSomeThreads() { - } - - /* Deprecated fields and methods -- Memory advice not supported in 1.2 */ - - /** @deprecated */ - @Deprecated - public static final int STATE_GREEN = 1; - - /** @deprecated */ - @Deprecated - public static final int STATE_YELLOW = 2; - - /** @deprecated */ - @Deprecated - public static final int STATE_RED = 3; - - /** @deprecated */ - @Deprecated - public static final int getState() { - return STATE_GREEN; - } - - /** @deprecated */ - @Deprecated - public static void registerVMNotification(VMNotification n) { } - - /** @deprecated */ - @Deprecated - public static void asChange(int as_old, int as_new) { } - - /** @deprecated */ - @Deprecated - public static void asChange_otherthread(int as_old, int as_new) { } - - /* - * Not supported in 1.2 because these will have to be exported as - * JVM functions, and we are not sure we want do that. Leaving - * here so it can be easily resurrected -- just remove the // - * comments. - */ - - /** - * Resume Java profiling. All profiling data is added to any - * earlier profiling, unless resetJavaProfiler is - * called in between. If profiling was not started from the - * command line, resumeJavaProfiler will start it. - *

      - * - * NOTE: Profiling must be enabled from the command line for a - * java.prof report to be automatically generated on exit; if not, - * writeJavaProfilerReport must be invoked to write a report. - * - * @see resetJavaProfiler - * @see writeJavaProfilerReport - */ - - // public native static void resumeJavaProfiler(); - - /** - * Suspend Java profiling. - */ - // public native static void suspendJavaProfiler(); - - /** - * Initialize Java profiling. Any accumulated profiling - * information is discarded. - */ - // public native static void resetJavaProfiler(); - - /** - * Write the current profiling contents to the file "java.prof". - * If the file already exists, it will be overwritten. - */ - // public native static void writeJavaProfilerReport(); - - // the init level when the VM is fully initialized private static final int JAVA_LANG_SYSTEM_INITED = 1; private static final int MODULE_SYSTEM_INITED = 2; diff --git a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_de.properties b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_de.properties index 13436be51c3..83aded15d1a 100644 --- a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_de.properties +++ b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_de.properties @@ -24,7 +24,7 @@ # # Translators please note do not translate the options themselves -java.launcher.opt.header = Verwendung: {0} [options] class [args...]\n (zur Ausf\u00FChrung einer Klasse)\n oder {0} [options] -jar jarfile [args...]\n (zur Ausf\u00FChrung einer JAR-Datei)\n oder {0} [-options] -mp -m | /\n (zur Ausf\u00FChrung der Hauptklasse in einem Modul)\nwobei "options" Folgendes umfasst:\n +java.launcher.opt.header = Verwendung: {0} [options] class [args...]\n (zur Ausf\u00FChrung einer Klasse)\n oder {0} [options] -jar jarfile [args...]\n (zur Ausf\u00FChrung einer JAR-Datei)\n oder {0} [options] -mp -m [/] [args...]\n (zur Ausf\u00FChrung der Hauptklasse in einem Modul)\nwobei "options" Folgendes umfasst:\n java.launcher.opt.datamodel =\ -d{0}\t Verwendet ein {0}-Bit-Datenmodell, sofern verf\u00FCgbar\n java.launcher.opt.vmselect =\ {0}\t zur Auswahl der "{1}" VM\n @@ -34,7 +34,7 @@ java.launcher.ergo.message1 =\ Die Standard-VM ist {0} java.launcher.ergo.message2 =\ weil die Ausf\u00FChrung auf einem Server-Class-Rechner erfolgt.\n # Translators please note do not translate the options themselves -java.launcher.opt.footer =\ -cp \n -classpath \n Eine durch {0} getrennte Liste mit Verzeichnissen, JAR-Archiven\n und ZIP-Archiven zur Suche nach Klassendateien.\n -mp \n -modulepath ...\n Eine durch {0} getrennte Liste mit Verzeichnissen, in der jedes Verzeichnis\n ein Modulverzeichnis darstellt.\n -upgrademodulepath ...\n Eine durch {0} getrennte Liste mit Verzeichnissen, in der jedes Verzeichnis\n ein Verzeichnis von Modulen darstellt, die upgradef\u00E4hige\n Module im Laufzeitimage ersetzen\n -m | /\n das anf\u00E4ngliche oder Hauptmodul, das aufgel\u00F6st werden soll\n -addmods [,...]\n Root-Module, die zus\u00E4tzlich zum anf\u00E4nglichen Modul aufgel\u00F6st werden sollen\n -limitmods [,...]\n Schr\u00E4nkt die Gesamtzahl der beachtbaren Module ein\n -listmods[:[,...]]\n Listet die beachtbaren Module auf und beendet den Vorgang\n -D=\n Legt eine Systemeigenschaft fest\n -verbose:[class|gc|jni]\n Aktiviert die Verbose-Ausgabe\n -version Druckt Produktversion und beendet das Programm\n -showversion Druckt Produktversion und f\u00E4hrt fort\n -? -help Druckt diese Hilfemeldung\n -X Druckt Hilfe zu Nicht-Standardoptionen\n -ea[:...|:]\n -enableassertions[:...|:]\n Aktiviert Assertions mit angegebener Granularit\u00E4t\n -da[:...|:]\n -disableassertions[:...|:]\n Deaktiviert Assertions mit angegebener Granularit\u00E4t\n -esa | -enablesystemassertions\n Aktiviert System-Assertions\n -dsa | -disablesystemassertions\n Deaktiviert System-Assertions\n -agentlib:[=]\n L\u00E4dt native Agent Library , z.B. -agentlib:jdwp\n siehe auch -agentlib:jdwp=help\n -agentpath:[=]\n L\u00E4dt native Agent Library nach vollem Pfadnamen\n -javaagent:[=]\n L\u00E4dt Java-Programmiersprachen-Agent, siehe java.lang.instrument\n -splash:\n Zeigt Startbildschirm mit angegebenem Bild an\n @ Liest Optionen aus der angegebenen Datei\n +java.launcher.opt.footer =\ -cp \n -classpath \n Eine durch {0} getrennte Liste mit Verzeichnissen, JAR-Archiven\n und ZIP-Archiven zur Suche nach Klassendateien.\n -mp \n -modulepath ...\n Eine durch {0} getrennte Liste mit Verzeichnissen, in der jedes Verzeichnis\n ein Modulverzeichnis darstellt.\n -upgrademodulepath ...\n Eine durch {0} getrennte Liste mit Verzeichnissen, in der jedes Verzeichnis\n ein Verzeichnis von Modulen darstellt, die upgradef\u00E4hige\n Module im Laufzeitimage ersetzen\n -m [/]\n Das anf\u00E4ngliche Modul, das aufgel\u00F6st werden soll, und der Name der Hauptklasse,\n die ausgef\u00FChrt werden soll, wenn keine Angabe durch das Modul erfolgt\n -addmods [,...]\n Root-Module, die zus\u00E4tzlich zum anf\u00E4nglichen Modul aufgel\u00F6st werden sollen\n -limitmods [,...]\n Schr\u00E4nkt die Gesamtzahl der beobachtbaren Module ein\n -listmods[:[,...]]\n Listet die beobachtbaren Module auf und beendet den Vorgang\n -D=\n Legt eine Systemeigenschaft fest\n -verbose:[class|gc|jni]\n Aktiviert die Verbose-Ausgabe\n -version Druckt Produktversion und beendet das Programm\n -showversion Druckt Produktversion und f\u00E4hrt fort\n -? -help Druckt diese Hilfemeldung\n -X Druckt Hilfe zu Nicht-Standardoptionen\n -ea[:...|:]\n -enableassertions[:...|:]\n Aktiviert Assertions mit angegebener Granularit\u00E4t\n -da[:...|:]\n -disableassertions[:...|:]\n Deaktiviert Assertions mit angegebener Granularit\u00E4t\n -esa | -enablesystemassertions\n Aktiviert System-Assertions\n -dsa | -disablesystemassertions\n Deaktiviert System-Assertions\n -agentlib:[=]\n L\u00E4dt native Agent Library , z.B. -agentlib:jdwp\n siehe auch -agentlib:jdwp=help\n -agentpath:[=]\n L\u00E4dt native Agent Library nach vollem Pfadnamen\n -javaagent:[=]\n L\u00E4dt Java-Programmiersprachen-Agent, siehe java.lang.instrument\n -splash:\n Zeigt Startbildschirm mit angegebenem Bild an\n @ Liest Optionen aus der angegebenen Datei\n See Weitere Einzelheiten finden Sie unter http://www.oracle.com/technetwork/java/javase/documentation/index.html. # Translators please note do not translate the options themselves diff --git a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_es.properties b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_es.properties index 1b91747f392..7e150a57e53 100644 --- a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_es.properties +++ b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_es.properties @@ -24,7 +24,7 @@ # # Translators please note do not translate the options themselves -java.launcher.opt.header = Sintaxis: {0} [opciones] class [args...]\n (para ejecutar una clase)\n or {0} [opciones] -jar jarfile [args...]\n (para ejecutar un archivo jar)\n or {0} [-options] -mp -m | /\n (para ejecutar una clase principal en un m\u00F3dulo)\ndonde opciones incluye:\n +java.launcher.opt.header = Sintaxis: {0} [opciones] class [args...]\n (para ejecutar una clase)\n o {0} [opciones] -jar jarfile [args...]\n (para ejecutar un archivo jar)\n o {0} [opciones] -mp -m [/] [args...]\n (para ejecutar una clase principal en un m\u00F3dulo)\ndonde las opciones incluyen:\n java.launcher.opt.datamodel =\ -d{0}\t usar un modelo de datos de {0} bits, si est\u00E1 disponible\n java.launcher.opt.vmselect =\ {0}\t para seleccionar la VM "{1}"\n @@ -34,11 +34,11 @@ java.launcher.ergo.message1 =\ La VM por defecto es {0} java.launcher.ergo.message2 =\ porque la ejecuci\u00F3n se est\u00E1 llevando a cabo en una m\u00E1quina de clase de servidor.\n # Translators please note do not translate the options themselves -java.launcher.opt.footer =\ -cp \n -classpath \n Lista separada por {0} de directorios, archivos JAR\n y archivos ZIP para buscar archivos de clase.\n -mp \n -modulepath ...\n Lista de directorios separados por {0}, cada directorio\n es un directorio de m\u00F3dulos.\n -upgrademodulepath ...\n Lista de directorios separados por {0}, cada directorio\n es un directorio de m\u00F3dulos que sustituye a los m\u00F3dulos\n actualizables en la imagen de tiempo de ejecuci\u00F3n\n -m | /\n m\u00F3dulo principal o inicial que resolver\n -addmods [,...]\n m\u00F3dulos ra\u00EDz que resolver, adem\u00E1s del m\u00F3dulo inicial\n -limitmods [,...]\n limita el universo de los m\u00F3dulos observables\n -listmods[:[,...]]\n muestra los m\u00F3dulos observables y sale\n -D=\n define una propiedad del sistema\n -verbose:[class|gc|jni]\n activa la salida verbose\n -version imprime la versi\u00F3n del producto y sale\n -showversion imprime la versi\u00F3n del producto y sale\n -? -help imprime este mensaje de ayuda\n -X imprime la ayuda de opciones no est\u00E1ndar\n -ea[:...|:]\n -enableassertions[:...|:]\n activar afirmaciones con la granularidad especificada\n -da[:...|:]\n -disableassertions[:...|:]\n desactivar afirmaciones con la granularidad especificada\n -esa | -enablesystemassertions\n activar afirmaciones del sistema\n -dsa | -disablesystemassertions\n desactivar afirmaciones del sistema\n -agentlib:[=]\n cargar biblioteca de agentes nativos , p. ej,. -agentlib:jdwp\n ver tambi\u00E9n -agentlib:jdwp=help\n -agentpath:[=]\n cargar biblioteca de agentes nativos por ruta completa\n -javaagent:[=]\n cargar agente de lenguaje de programaci\u00F3n Java, ver java.lang.instrument\n -splash:\n mostrar pantalla de bienvenida con la imagen especificada\n @ leer opciones del archivo especificado\n +java.launcher.opt.footer =\ -cp \n -classpath \n Lista separada por {0} de directorios, archivos JAR\n y archivos ZIP para buscar archivos de clase.\n -mp \n -modulepath ...\n Lista separada por {0} de directorios, cada directorio\n es un directorio de m\u00F3dulos.\n -upgrademodulepath ...\n Lista separada por {0} de directorios, cada directorio\n es un directorio de m\u00F3dulos que sustituye a los m\u00F3dulos\n actualizables en la imagen de tiempo de ejecuci\u00F3n\n -m [/]\n m\u00F3dulo inicial que resolver y nombre de la clase principal\n que ejecutar si el m\u00F3dulo no la especifica\n -addmods [,...]\n m\u00F3dulos ra\u00EDz que resolver, adem\u00E1s del m\u00F3dulo inicial\n -limitmods [,...]\n limitar el universo de los m\u00F3dulos observables\n -listmods[:[,...]]\n mostrar los m\u00F3dulos observables y sale\n -D=\n definir una propiedad del sistema\n -verbose:[class|gc|jni]\n activar la salida verbose\n -version imprimir la versi\u00F3n del producto y sale\n -showversion imprimir la versi\u00F3n del producto y sale\n -? -help imprimir este mensaje de ayuda\n -X imprimir la ayuda de opciones no est\u00E1ndar\n -ea[:...|:]\n -enableassertions[:...|:]\n activar afirmaciones con la granularidad especificada\n -da[:...|:]\n -disableassertions[:...|:]\n desactivar afirmaciones con la granularidad especificada\n -esa | -enablesystemassertions\n activar afirmaciones del sistema\n -dsa | -disablesystemassertions\n desactivar afirmaciones del sistema\n -agentlib:[=]\n cargar biblioteca de agentes nativos , por ejemplo, -agentlib:jdwp\n ver tambi\u00E9n -agentlib:jdwp=help\n -agentpath:[=]\n cargar biblioteca de agentes nativos por ruta completa\n -javaagent:[=]\n cargar agente de lenguaje de programaci\u00F3n Java, ver java.lang.instrument\n -splash:\n mostrar pantalla de bienvenida con la imagen especificada\n @ leer opciones del archivo especificado\n See http://www.oracle.com/technetwork/java/javase/documentation/index.html para obtener m\u00E1s informaci\u00F3n. # Translators please note do not translate the options themselves -java.launcher.X.usage=\ -Xmixed ejecuci\u00F3n de modo mixto (por defecto)\n -Xint solo ejecuci\u00F3n de modo interpretado\n -Xbootclasspath/a:\n agregar al final de la ruta de la clase de inicializaci\u00F3n de datos\n -Xdiag mostrar mensajes de diagn\u00F3stico adicionales\n -Xdiag:resolver mostrar mensajes de diagn\u00F3stico de resoluci\u00F3n\n -Xnoclassgc desactivar la recopilaci\u00F3n de basura de clases\n -Xincgc activar la recopilaci\u00F3n de basura de clases\n -Xloggc: registrar el estado de GC en un archivo con registros de hora\n -Xbatch desactivar compilaci\u00F3n en segundo plano\n -Xms definir tama\u00F1o de pila Java inicial\n -Xmx definir tama\u00F1o de pila Java m\u00E1ximo\n -Xss definir tama\u00F1o de la pila del thread de Java\n -Xfuture activar las comprobaciones m\u00E1s estrictas, anticip\u00E1ndose al futuro valor por defecto\n -Xrs reducir el uso de se\u00F1ales de sistema operativo por parte de Java/VM (consulte la documentaci\u00F3n)\n -Xcheck:jni realizar comprobaciones adicionales para las funciones de JNI\n -Xshare:off no intentar usar datos de clase compartidos\n -Xshare:auto usar datos de clase compartidos si es posible (valor por defecto)\n -Xshare:on es obligatorio el uso de datos de clase compartidos, de lo contrario se emitir\u00E1 un fallo.\n -XshowSettings mostrar todos los valores y continuar\n -XshowSettings:all\n mostrar todos los valores y continuar\n -XshowSettings:vm mostrar todos los valores de la VM y continuar\n -XshowSettings:properties\n mostrar todos los valores de las propiedades y continuar\n -XshowSettings:locale\n mostrar todos los valores relacionados con la configuraci\u00F3n regional y continuar\n -XaddReads:=(,)*\n lee otros m\u00F3dulos,\n independientemente de su declaraci\u00F3n\n -XaddExports:/=(,)*\n exporta a otros m\u00F3dulos,\n independientemente de su declaraci\u00F3n\n -Xpatch:=({0})*\n Sustituye o aumenta un m\u00F3dulo con clases y recursos\n en directorios o archivos JAR\n -Xdisable-@files desactiva la ampliaci\u00F3n de archivos de argumentos\n\nLas opciones -X no son est\u00E1ndar, por lo que podr\u00EDan cambiarse sin previo aviso.\n +java.launcher.X.usage=\ -Xmixed ejecuci\u00F3n de modo mixto (por defecto)\n -Xint solo ejecuci\u00F3n de modo interpretado\n -Xbootclasspath/a:\n agregar al final de la ruta de acceso de la clase de inicializaci\u00F3n de datos\n -Xdiag mostrar mensajes de diagn\u00F3stico adicionales\n -Xdiag:resolver mostrar mensajes de diagn\u00F3stico de resoluci\u00F3n\n -Xnoclassgc desactivar la recolecci\u00F3n de basura de clases\n -Xloggc: registrar el estado de GC en un archivo con registros de hora\n -Xbatch desactivar compilaci\u00F3n en segundo plano\n -Xms definir tama\u00F1o de pila Java inicial\n -Xmx definir tama\u00F1o de pila Java m\u00E1ximo\n -Xss definir tama\u00F1o de la pila del thread de Java\n -Xprof datos de salida de creaci\u00F3n de perfil de CPU\n -Xfuture activar las comprobaciones m\u00E1s estrictas, anticip\u00E1ndose al futuro valor por defecto\n -Xrs reducir el uso de se\u00F1ales de sistema operativo por parte de Java/VM (consulte la documentaci\u00F3n)\n -Xcheck:jni realizar comprobaciones adicionales para las funciones de JNI\n -Xshare:off no intentar usar datos de clase compartidos\n -Xshare:auto usar datos de clase compartidos si es posible (valor por defecto)\n -Xshare:on es obligatorio el uso de datos de clase compartidos, de lo contrario se emitir\u00E1 un fallo.\n -XshowSettings show all settings and continue\n -XshowSettings:all\n mostrar todos los valores y continuar\n -XshowSettings:vm show all vm related settings and continue\n -XshowSettings:properties\n mostrar todos los valores y continuar\n -XshowSettings:locale\n mostrar todos los valores relacionados con la configuraci\u00F3n regional y continuar\n -XaddReads:=(,)*\n lee otros m\u00F3dulos,\n independientemente de la declaraci\u00F3n del m\u00F3dulo\n -XaddExports:/=(,)*\n exporta a otros m\u00F3dulos,\n independientemente de la declaraci\u00F3n del m\u00F3dulo\n -Xpatch:=({0})*\n Anular o aumentar un m\u00F3dulo con clases y recursos\n en directorios o archivos JAR\n -Xdisable-@files desactivar la ampliaci\u00F3n de archivos de argumentos\n\nLas opciones -X no son est\u00E1ndar y est\u00E1n sujetas a cambios sin previo aviso.\n # Translators please note do not translate the options themselves java.launcher.X.macosx.usage=\nLas siguientes opciones son espec\u00EDficas para Mac OS X:\n -XstartOnFirstThread\n ejecuta el m\u00E9todo main() del primer thread (AppKit)\n -Xdock:name="\n sustituye al nombre por defecto de la aplicaci\u00F3n que se muestra en el Dock\n -Xdock:icon=\n sustituye al icono por defecto que se muestra en el Dock\n\n diff --git a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_fr.properties b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_fr.properties index b050b87724f..474fcf59a29 100644 --- a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_fr.properties +++ b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_fr.properties @@ -24,7 +24,7 @@ # # Translators please note do not translate the options themselves -java.launcher.opt.header = Syntaxe : {0} [options] class [args...]\n (pour l''ex\u00E9cution d''une classe)\n ou {0} [options] -jar jarfile [args...]\n (pour l''ex\u00E9cution d''un fichier JAR)\n ou {0} [-options] -mp -m | /\n (pour l''ex\u00E9cution de la classe principale dans un module)\no\u00F9 les options incluent :\n +java.launcher.opt.header = Syntaxe : {0} [options] class [args...]\n (pour l''ex\u00E9cution d''une classe)\n ou {0} [options] -jar jarfile [args...]\n (pour l''ex\u00E9cution d''un fichier JAR)\n ou {0} [options] -mp -m [/] [args...]\n (pour l''ex\u00E9cution de la classe principale dans un module)\no\u00F9 options comprend les \u00E9l\u00E9ments suivants :\n java.launcher.opt.datamodel =\ -d{0}\t utilisez le mod\u00E8le de donn\u00E9es {0} bits s''il est disponible\n java.launcher.opt.vmselect =\ {0}\t pour s\u00E9lectionner la machine virtuelle "{1}"\n @@ -34,11 +34,11 @@ java.launcher.ergo.message1 =\ La machine virtuelle par d\u00E java.launcher.ergo.message2 =\ car vous ex\u00E9cutez une machine de classe de serveur.\n # Translators please note do not translate the options themselves -java.launcher.opt.footer =\ -cp \n -classpath \n Liste de r\u00E9pertoires, d''archives JAR et\n d''archives ZIP s\u00E9par\u00E9s par des {0}, dans laquelle rechercher des fichiers de classe.\n -mp \n -modulepath ...\n Liste de r\u00E9pertoires s\u00E9par\u00E9s par des {0}, chaque r\u00E9pertoire\n est un r\u00E9pertoire de modules.\n -upgrademodulepath ...\n Liste de r\u00E9pertoires s\u00E9par\u00E9s par des {0}, chaque r\u00E9pertoire\n est un r\u00E9pertoire de modules qui remplace des modules\n pouvant \u00EAtre mis \u00E0 niveau dans l''image d''ex\u00E9cution\n -m | /\n modules racines \u00E0 r\u00E9soudre en plus du module initial\n -addmods [,...]\n modules racines \u00E0 r\u00E9soudre en plus du module initial\n -limitmods [,...]\n limitation de l''univers de modules observables\n -listmods[:[,...]]\n \u00E9num\u00E9ration des modules observables et fin de l''op\u00E9ration\n -D=\n d\u00E9finition d''une propri\u00E9t\u00E9 syst\u00E8me\n -verbose:[class|gc|jni]\n activation de la sortie en mode verbose\n -version impression de la version du produit et fin de l''op\u00E9ration\n -showversion impression de la version du produit et poursuite de l''op\u00E9ration\n -? -help impression du message d''aide\n -X impression de l''aide sur les options non standard\n -ea[:...|:]\n -enableassertions[:...|:]\n activation des assertions avec la granularit\u00E9* sp\u00E9cifi\u00E9e\n -da[:...|:]\n -disableassertions[:...|:]\n d\u00E9sactivation des assertions avec la granularit\u00E9 sp\u00E9cifi\u00E9e\n -esa | -enablesystemassertions\n activation des assertions syst\u00E8me\n -dsa | -disablesystemassertions\n d\u00E9sactivation des assertions syst\u00E8me\n -agentlib:[=]\n chargement de la biblioth\u00E8que d''agent natif , par exemple -agentlib:jdwp\n voir aussi, -agentlib:jdwp=help\n -agentpath:[=]\n chargement de la biblioth\u00E8que d''agent natif via le chemin d''acc\u00E8s complet\n -javaagent:[=]\n chargement de l''agent du langage de programmation Java, voir java.lang.instrument\n -splash:\n affichage de l''\u00E9cran d''accueil avec l''image indiqu\u00E9e\n @ lire les options \u00E0 partir du fichier indiqu\u00E9\n +java.launcher.opt.footer =\ -cp \n -classpath \n Liste de r\u00E9pertoires, d''archives JAR\n et d''archives ZIP s\u00E9par\u00E9s par des {0} dans laquelle rechercher les fichiers de classe.\n -mp \n -modulepath ...\n Liste de r\u00E9pertoires s\u00E9par\u00E9s par des {0}, chaque r\u00E9pertoire\n est un r\u00E9pertoire de modules.\n -upgrademodulepath ...\n Liste de r\u00E9pertoires s\u00E9par\u00E9s par des {0}, chaque r\u00E9pertoire\n est un r\u00E9pertoire de modules qui remplace des modules\n pouvant \u00EAtre mis \u00E0 niveau dans l''image d''ex\u00E9cution\n -m [/]\n module initial \u00E0 r\u00E9soudre et nom de la classe principale\n \u00E0 ex\u00E9cuter si elle n''est pas indiqu\u00E9e par le module\n -addmods [,...]\n modules racines \u00E0 r\u00E9soudre en plus du module initial\n -limitmods [,...]\n limitation de l''univers de modules observables\n -listmods[:[,...]]\n \u00E9num\u00E9ration des modules observables et fin de l''op\u00E9ration\n -D=\n d\u00E9finition d''une propri\u00E9t\u00E9 syst\u00E8me\n -verbose:[class|gc|jni]\n activation de la sortie en mode verbose\n -version impression de la version du produit et fin de l''op\u00E9ration\n -showversion impression de la version du produit et poursuite de l''op\u00E9ration\n -? -help impression du message d''aide\n -X impression de l''aide sur les options non standard\n -ea[:...|:]\n -enableassertions[:...|:]\n activation des assertions avec la granularit\u00E9 sp\u00E9cifi\u00E9e\n -da[:...|:]\n -disableassertions[:...|:]\n d\u00E9sactivation des assertions avec la granularit\u00E9 sp\u00E9cifi\u00E9e\n -esa | -enablesystemassertions\n activation des assertions syst\u00E8me\n -dsa | -disablesystemassertions\n d\u00E9sactivation des assertions syst\u00E8me\n -agentlib:[=]\n chargement de la biblioth\u00E8que d''agent natif , par exemple : -agentlib:jdwp\n voir aussi -agentlib:jdwp=help\n -agentpath:[=]\n chargement de la biblioth\u00E8que d''agent natif via le chemin d''acc\u00E8s complet\n -javaagent:[=]\n chargement de l''agent du langage de programmation Java, voir java.lang.instrument\n -splash:\n affichage de l''\u00E9cran d''accueil avec l''image indiqu\u00E9e\n @ lire les options \u00E0 partir du fichier indiqu\u00E9\n See http://www.oracle.com/technetwork/java/javase/documentation/index.html pour plus de d\u00E9tails. # Translators please note do not translate the options themselves -java.launcher.X.usage=\ -Xmixed ex\u00E9cution en mode mixte (valeur par d\u00E9faut)\n -Xint ex\u00E9cution en mode interpr\u00E9t\u00E9 uniquement\n -Xbootclasspath/a:\n ajout \u00E0 la fin du chemin de classe bootstrap\n -Xdiag affichage de messages de diagnostic suppl\u00E9mentaires\n -Xdiag:resolver affichage de messages de diagnostic du r\u00E9solveur\n -Xnoclassgc d\u00E9sactivation du nettoyage de la m\u00E9moire de la classe\n -Xincgc activation du nettoyage de la m\u00E9moire incr\u00E9mentiel\n -Xloggc: journalisation du statut de nettoyage de la m\u00E9moire dans un fichier avec horodatage\n -Xbatch d\u00E9sactivation de la compilation en arri\u00E8re-plan\n -Xms d\u00E9finition de la taille initiale des portions de m\u00E9moire Java\n -Xmx d\u00E9finition de la taille maximale des portions de m\u00E9moire Java\n -Xss d\u00E9finition de la taille de pile de threads Java\n -Xprof sortie des donn\u00E9es de profilage d''UC\n -Xfuture activation des contr\u00F4les les plus stricts en vue d''anticiper la future valeur par d\u00E9faut\n -Xrs r\u00E9duction de l''utilisation des signaux d''OS par Java/la machine virtuelle (voir documentation)\n -Xcheck:jni ex\u00E9cution de contr\u00F4les suppl\u00E9mentaires pour les fonctions JNI\n -Xshare:off aucune tentative d''utilisation des donn\u00E9es de classe partag\u00E9e\n -Xshare:auto utilisation des donn\u00E9es de classe partag\u00E9e si possible (valeur par d\u00E9faut)\n -Xshare:on utilisation des donn\u00E9es de classe partag\u00E9e obligatoire ou \u00E9chec de l''op\u00E9ration\n -XshowSettings affichage de tous les param\u00E8tres et poursuite de l''op\u00E9ration\n -XshowSettings:all\n affichage de tous les param\u00E8tres et poursuite de l''op\u00E9ration\n -XshowSettings:vm affichage de tous les param\u00E8tres de machine virtuelle et poursuite de l''op\u00E9ration\n -XshowSettings:properties\n affichage de tous les param\u00E8tres de propri\u00E9t\u00E9 et poursuite de l''op\u00E9ration\n -XshowSettings:locale\n affichage de tous les param\u00E8tres d''environnement local et poursuite de l''op\u00E9ration\n -XaddReads:=(,)*\n lecture de tous les modules,\n quelle que soit la d\u00E9claration de module\n -XaddExports:/=(,)*\n exporte vers d''autres modules,\n quelle que soit la d\u00E9claration de module\n -Xpatch:=({0})*\n Remplacement ou augmentation d''un module avec des classes et des ressources\n dans des fichiers ou r\u00E9pertoires JAR\n -Xdisable-@files d\u00E9sactivation d''autres d\u00E9veloppements de fichier d''argument\n\nLes options -X ne sont pas standard et sont susceptibles de modification sans pr\u00E9avis.\n +java.launcher.X.usage=\ -Xmixed ex\u00E9cution en mode mixte (valeur par d\u00E9faut)\n -Xint ex\u00E9cution en mode interpr\u00E9t\u00E9 uniquement\n -Xbootclasspath/a:\n ajout \u00E0 la fin du chemin de classe bootstrap\n -Xdiag affichage de messages de diagnostic suppl\u00E9mentaires\n -Xdiag:resolver affichage de messages de diagnostic du r\u00E9solveur\n -Xnoclassgc d\u00E9sactivation du nettoyage de la m\u00E9moire de la classe\n -Xloggc: journalisation du statut de nettoyage de la m\u00E9moire dans un fichier avec horodatage\n -Xbatch d\u00E9sactivation de la compilation en arri\u00E8re-plan\n -Xms d\u00E9finition de la taille initiale des portions de m\u00E9moire Java\n -Xmx d\u00E9finition de la taille maximale des portions de m\u00E9moire Java\n -Xss d\u00E9finition de la taille de pile de threads Java\n -Xprof sortie des donn\u00E9es de profilage d''UC\n -Xfuture activation des contr\u00F4les les plus stricts en vue d''anticiper la future valeur par d\u00E9faut\n -Xrs r\u00E9duction de l''utilisation des signaux d''OS par Java/la machine virtuelle (voir documentation)\n -Xcheck:jni ex\u00E9cution de contr\u00F4les suppl\u00E9mentaires pour les fonctions JNI\n -Xshare:off aucune tentative d''utilisation des donn\u00E9es de classe partag\u00E9e\n -Xshare:auto utilisation des donn\u00E9es de classe partag\u00E9e si possible (valeur par d\u00E9faut)\n -Xshare:on utilisation des donn\u00E9es de classe partag\u00E9e obligatoire ou \u00E9chec de l''op\u00E9ration\n -XshowSettings affichage de tous les param\u00E8tres et poursuite de l''op\u00E9ration\n -XshowSettings:all\n affichage de tous les param\u00E8tres et poursuite de l''op\u00E9ration\n -XshowSettings:vm affichage de tous les param\u00E8tres de machine virtuelle et poursuite de l''op\u00E9ration\n -XshowSettings:properties\n affichage de tous les param\u00E8tres de propri\u00E9t\u00E9 et poursuite de l''op\u00E9ration\n -XshowSettings:locale\n affichage de tous les param\u00E8tres d''environnement local et poursuite de l''op\u00E9ration\n -XaddReads:=(,)*\n lecture de tous les modules,\n quelle que soit la d\u00E9claration de module\n -XaddExports:/=(,)*\n exporte vers d''autres modules,\n quelle que soit la d\u00E9claration de module\n -Xpatch:=({0})*\n Remplacement ou augmentation d''un module avec des classes et des ressources\n dans des fichiers ou r\u00E9pertoires JAR\n -Xdisable-@files d\u00E9sactivation d''autres d\u00E9veloppements de fichier d''argument\n\nLes options -X ne sont pas standard et sont susceptibles de modification sans pr\u00E9avis.\n # Translators please note do not translate the options themselves java.launcher.X.macosx.usage=\nLes options suivantes sont propres \u00E0 Mac OS X :\n -XstartOnFirstThread\n ex\u00E9cute la m\u00E9thode main() sur le premier thread (AppKit)\n -Xdock:name="\n remplace le nom d'application par d\u00E9faut affich\u00E9 dans l'ancrage\n -Xdock:icon=\n remplace l'ic\u00F4ne par d\u00E9faut affich\u00E9e dans l'ancrage\n\n diff --git a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_it.properties b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_it.properties index af3b15c4e75..fe6c89304a6 100644 --- a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_it.properties +++ b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_it.properties @@ -24,7 +24,7 @@ # # Translators please note do not translate the options themselves -java.launcher.opt.header = Uso: {0} [options] class [args...]\n (per eseguire una classe)\n oppure {0} [options] -jar jarfile [args...]\n (per eseguire un file jar)\n oppure {0} [-options] -mp -m | /\n (per eseguire la classe principale in un modulo)\nin cui options include:\n +java.launcher.opt.header = Uso: {0} [options] class [args...]\n (per eseguire una classe)\n oppure {0} [options] -jar jarfile [args...]\n (per eseguire un file jar)\n oppure {0} [options] -mp -m [/] [args...]\n (per eseguire la classe principale in un modulo)\nin cui options include:\n java.launcher.opt.datamodel =\ -d{0}\t usare un modello di dati {0}-bit se disponibile\n java.launcher.opt.vmselect =\ {0}\t per selezionare la VM "{1}"\n @@ -34,11 +34,11 @@ java.launcher.ergo.message1 =\ La VM predefinita \u00E8 {0} java.launcher.ergo.message2 =\ perch\u00E9 si utilizza un computer di classe server.\n # Translators please note do not translate the options themselves -java.launcher.opt.footer =\ -cp \n -classpath \n Una lista separata da {0} di directory, archivi JAR\n e ZIP utilizzata per la ricerca di file di classe.\n -mp \n -modulepath ...\n Una lista separata da {0} di directory; ciascuna directory\n \u00E8 una directory di moduli.\n -upgrademodulepath ...\n Una lista separata da {0} di directory; ciascuna directory\n \u00E8 una directory dei moduli che sostituiscono i moduli\n aggiornabili nell''immagine in fase di esecuzione\n -m | /\n il modulo iniziale o principale da risolvere\n -addmods [,...]\n moduli root da risolvere in aggiunta al modulo iniziale\n -limitmods [,...]\n limita l''universe dei moduli osservabili\n -listmods[:[,...]]\n elenca i moduli osservabili ed esce\n -D=\n imposta una propriet\u00E0 di sistema\n -verbose:[class|gc|jni]\n abilita l''output descrittivo\n -version stampa la versione del prodotto ed esce\n -showversion stampa la versione del prodotto e continua\n -? -help stampa questo messaggio della Guida\n -X stampa la Guida sulle opzioni non standard\n -ea[:...|:]\n -enableassertions[:...|:]\n abilita le asserzioni con la granularit\u00E0 specificata\n -da[:...|:]\n -disableassertions[:...|:]\n disabilita le asserzioni con la granularit\u00E0 specificata\n -esa | -enablesystemassertions\n abilita le asserzioni di sistema\n -dsa | -disablesystemassertions\n disabilita le asserzioni di sistema\n -agentlib:[=]\n load native agent library , ad esempio -agentlib:jdwp\n vedere anche -agentlib:jdwp=help\n -agentpath:[=]\n carica la libreria agenti nativa con il percorso completo\n -javaagent:[=]\n carica l''agente del linguaggio di programmazione Java. Vedere java.lang.instrument\n -splash:\n mostra la schermata iniziale con l''immagine specificata\n @ legge le opzioni dal file specificato\n +java.launcher.opt.footer =\ -cp \n -classpath \n Una lista separata da {0} di directory, archivi JAR\n e ZIP utilizzata per la ricerca di file di classe.\n -mp \n -modulepath ...\n Una lista separata da {0} di directory; ciascuna directory\n \u00E8 una directory di moduli.\n -upgrademodulepath ...\n Una lista separata da {0} di directory; ciascuna directory\n \u00E8 una directory dei moduli che sostituiscono i moduli\n aggiornabili nell''immagine in fase di esecuzione\n -m [/]\n il modulo iniziale da risolvere e il nome della classe principale\n da eseguire se non viene specificata dal modulo\n -addmods [,...]\n moduli root da risolvere in aggiunta al modulo iniziale\n -limitmods [,...]\n limita l''universe dei moduli osservabili\n -listmods[:[,...]]\n elenca i moduli osservabili ed esce\n -D=\n imposta una propriet\u00E0 di sistema\n -verbose:[class|gc|jni]\n abilita l''output descrittivo\n -version stampa la versione del prodotto ed esce\n -showversion stampa la versione del prodotto e continua\n -? -help stampa questo messaggio della Guida\n -X stampa la Guida sulle opzioni non standard\n -ea[:...|:]\n -enableassertions[:...|:]\n abilita le asserzioni con la granularit\u00E0 specificata\n -da[:...|:]\n -disableassertions[:...|:]\n disabilita le asserzioni con la granularit\u00E0 specificata\n -esa | -enablesystemassertions\n abilita le asserzioni di sistema\n -dsa | -disablesystemassertions\n disabilita le asserzioni di sistema\n -agentlib:[=]\n load native agent library , ad esempio -agentlib:jdwp\n vedere anche -agentlib:jdwp=help\n -agentpath:[=]\n carica la libreria agenti nativa con il percorso completo\n -javaagent:[=]\n carica l''agente del linguaggio di programmazione Java. Vedere java.lang.instrument\n -splash:\n mostra la schermata iniziale con l''immagine specificata\n @ legge le opzioni dal file specificato\n See Per ulteriori dettagli, vedere http://www.oracle.com/technetwork/java/javase/documentation/index.html. # Translators please note do not translate the options themselves -java.launcher.X.usage=\ -Xmixed esecuzione in modalit\u00E0 mista (impostazione predefinita)\n -Xint esecuzione solo in modalit\u00E0 convertita\n -Xbootclasspath/a:\n aggiunge alla fine del classpath di bootstrap\n -Xdiag mostra messaggi di diagnostica aggiuntivi\n -Xdiag:resolver mostra i messaggi di diagnostica del resolver\n -Xnoclassgc disabilita la garbage collection della classe\n -Xincgc abilita la garbage collection incrementale\n -Xloggc: registra lo stato GC in un file con indicatori orari\n -Xbatch disabilita la compilazione in background\n -Xms imposta la dimensione heap Java iniziale\n -Xmx imposta la dimensione heap Java massima\n -Xss imposta la dimensione dello stack di thread Java\n -Xprof visualizza i dati di profilo della CPU\n -Xfuture abilita i controlli pi\u00F9 limitativi anticipando le impostazioni predefinite future\n -Xrs riduce l''uso di segnali del sistema operativo da Java/VM (vedere la documentazione)\n -Xcheck:jni esegue controlli aggiuntivi per le funzioni JNI\n -Xshare:off non tenta di utilizzare i dati della classe condivisi\n -Xshare:auto utilizza i dati di classe condivisi se possibile (impostazione predefinita)\n -Xshare:on richiede l''uso dei dati di classe condivisi, altrimenti l''esecuzione non riesce.\n -XshowSettings mostra tutte le impostazioni e continua\n -XshowSettings:all\n mostra tutte le impostazioni e continua\n -XshowSettings:vm mostra tutte le impostazioni correlate alla VM e continua\n -XshowSettings:properties\n mostra tutte le impostazioni delle propriet\u00E0 e continua\n -XshowSettings:locale\n mostra tutte le impostazioni correlate alle impostazioni nazionali e continua\n -XaddReads:=(,)*\n legge altri moduli,\n indipendentemente dalla dichiarazione del modulo\n -XaddExports:/=(,)*\n esporta il in altri moduli,\n indipendentemente dalla dichiarazione del modulo\n -Xpatch:=({0})*\n sostituisce o migliora un modulo con classi e risorse\n in file JAR o directory\n -Xdisable-@files disabilita l''ulteriore espansione del file di argomenti\n\nLe opzioni -X non sono opzioni standard e sono soggette a modifiche senza preavviso.\n +java.launcher.X.usage=\ -Xmixed esecuzione in modalit\u00E0 mista (impostazione predefinita)\n -Xint esecuzione solo in modalit\u00E0 convertita\n -Xbootclasspath/a:\n aggiunge alla fine del classpath di bootstrap\n -Xdiag mostra messaggi di diagnostica aggiuntivi\n -Xdiag:resolver mostra i messaggi di diagnostica del resolver\n -Xnoclassgc disabilita la garbage collection della classe\n -Xloggc: registra lo stato GC in un file con indicatori orari\n -Xbatch disabilita la compilazione in background\n -Xms imposta la dimensione heap Java iniziale\n -Xmx imposta la dimensione heap Java massima\n -Xss imposta la dimensione dello stack di thread Java\n -Xprof visualizza i dati di profilo della CPU\n -Xfuture abilita i controlli pi\u00F9 limitativi anticipando le impostazioni predefinite future\n -Xrs riduce l''uso di segnali del sistema operativo da Java/VM (vedere la documentazione)\n -Xcheck:jni esegue controlli aggiuntivi per le funzioni JNI\n -Xshare:off non tenta di utilizzare i dati della classe condivisi\n -Xshare:auto utilizza i dati di classe condivisi se possibile (impostazione predefinita)\n -Xshare:on richiede l''uso dei dati di classe condivisi, altrimenti l''esecuzione non riesce.\n -XshowSettings mostra tutte le impostazioni e continua\n -XshowSettings:all\n mostra tutte le impostazioni e continua\n -XshowSettings:vm mostra tutte le impostazioni correlate alla VM e continua\n -XshowSettings:properties\n mostra tutte le impostazioni delle propriet\u00E0 e continua\n -XshowSettings:locale\n mostra tutte le impostazioni correlate alle impostazioni nazionali e continua\n -XaddReads:=(,)*\n legge altri moduli,\n indipendentemente dalla dichiarazione del modulo\n -XaddExports:/=(,)*\n esporta il in altri moduli,\n indipendentemente dalla dichiarazione del modulo\n -Xpatch:=({0})*\n sostituisce o migliora un modulo con classi e risorse\n in file JAR o directory\n -Xdisable-@files disabilita l''ulteriore espansione del file di argomenti\n\nLe opzioni -X non sono opzioni standard e sono soggette a modifiche senza preavviso.\n # Translators please note do not translate the options themselves java.launcher.X.macosx.usage=\nLe opzioni riportate di seguito sono specifiche del sistema operativo Mac OS X:\n -XstartOnFirstThread\n Esegue il metodo main() sul primo thread (AppKit).\n -Xdock:name="\n Sostituisce il nome applicazione predefinito visualizzato nel dock\n -Xdock:icon=\n Sostituisce l'icona predefinita visualizzata nel dock\n\n diff --git a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_ja.properties b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_ja.properties index 6f428ce1234..22fd3179a93 100644 --- a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_ja.properties +++ b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_ja.properties @@ -24,7 +24,7 @@ # # Translators please note do not translate the options themselves -java.launcher.opt.header = \u4F7F\u7528\u65B9\u6CD5: {0} [options] class [args...]\n (\u30AF\u30E9\u30B9\u3092\u5B9F\u884C\u3059\u308B\u5834\u5408)\n \u307E\u305F\u306F {0} [options] -jar jarfile [args...]\n (jar\u30D5\u30A1\u30A4\u30EB\u3092\u5B9F\u884C\u3059\u308B\u5834\u5408)\n \u307E\u305F\u306F {0} [-options] -mp -m | /\n (\u30E2\u30B8\u30E5\u30FC\u30EB\u306E\u30E1\u30A4\u30F3\u30FB\u30AF\u30E9\u30B9\u3092\u5B9F\u884C\u3059\u308B\u5834\u5408)\noptions\u306B\u306F\u6B21\u306E\u3082\u306E\u304C\u3042\u308A\u307E\u3059\u3002\n +java.launcher.opt.header = \u4F7F\u7528\u65B9\u6CD5: {0} [options] class [args...]\n (\u30AF\u30E9\u30B9\u3092\u5B9F\u884C\u3059\u308B\u5834\u5408)\n \u307E\u305F\u306F {0} [options] -jar jarfile [args...]\n (jar\u30D5\u30A1\u30A4\u30EB\u3092\u5B9F\u884C\u3059\u308B\u5834\u5408)\n \u307E\u305F\u306F {0} [options] -mp -m [/] [args...]\n (\u30E2\u30B8\u30E5\u30FC\u30EB\u306E\u30E1\u30A4\u30F3\u30FB\u30AF\u30E9\u30B9\u3092\u5B9F\u884C\u3059\u308B\u5834\u5408)\n\u30AA\u30D7\u30B7\u30E7\u30F3\u306F\u6B21\u306E\u3068\u304A\u308A\u3067\u3059:\n java.launcher.opt.datamodel =\ -d{0}\t \u4F7F\u7528\u53EF\u80FD\u306A\u5834\u5408\u306F{0}\u30D3\u30C3\u30C8\u306E\u30C7\u30FC\u30BF\u30FB\u30E2\u30C7\u30EB\u3092\u4F7F\u7528\u3059\u308B\n java.launcher.opt.vmselect =\ {0}\t "{1}" VM\u3092\u9078\u629E\u3059\u308B\u5834\u5408\n @@ -34,13 +34,13 @@ java.launcher.ergo.message1 =\ \u30C7\u30D5\u30A9\u30EB\u30C8V java.launcher.ergo.message2 =\ \u3053\u308C\u306F\u30B5\u30FC\u30D0\u30FC\u30AF\u30E9\u30B9\u306E\u30DE\u30B7\u30F3\u3067\u5B9F\u884C\u3057\u3066\u3044\u308B\u305F\u3081\u3067\u3059\u3002\n # Translators please note do not translate the options themselves -java.launcher.opt.footer =\ -cp \n -classpath \n \u30AF\u30E9\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u3092\u691C\u7D22\u3059\u308B\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u3001\n JAR\u30A2\u30FC\u30AB\u30A4\u30D6\u304A\u3088\u3073ZIP\u30A2\u30FC\u30AB\u30A4\u30D6\u306E{0}\u3067\u533A\u5207\u3089\u308C\u305F\u30EA\u30B9\u30C8\u3002\n -mp \n -modulepath ...\n \u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u306E{0}\u3067\u533A\u5207\u3089\u308C\u305F\u30EA\u30B9\u30C8\u3002\u5404\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u306F\n \u30E2\u30B8\u30E5\u30FC\u30EB\u306E\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u3067\u3059\u3002\n -upgrademodulepath ...\n \u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u306E{0}\u3067\u533A\u5207\u3089\u308C\u305F\u30EA\u30B9\u30C8\u3002\u5404\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u306F\n \u30E9\u30F3\u30BF\u30A4\u30E0\u30FB\u30A4\u30E1\u30FC\u30B8\u3067\u30A2\u30C3\u30D7\u30B0\u30EC\u30FC\u30C9\u53EF\u80FD\u306A\u30E2\u30B8\u30E5\u30FC\u30EB\u3092\u7F6E\u63DB\u3059\u308B\n \u30E2\u30B8\u30E5\u30FC\u30EB\u306E\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u3067\u3059\n -m | /\n \u89E3\u6C7A\u3059\u308B\u521D\u671F\u307E\u305F\u306F\u30E1\u30A4\u30F3\u30FB\u30E2\u30B8\u30E5\u30FC\u30EB\n -addmods [,...]\n \u521D\u671F\u30E2\u30B8\u30E5\u30FC\u30EB\u306B\u52A0\u3048\u3066\u89E3\u6C7A\u3059\u308B\u30EB\u30FC\u30C8\u30FB\u30E2\u30B8\u30E5\u30FC\u30EB\n -limitmods [,...]\n \u76E3\u8996\u53EF\u80FD\u306A\u30E2\u30B8\u30E5\u30FC\u30EB\u306E\u30E6\u30CB\u30D0\u30FC\u30B9\u3092\u5236\u9650\u3059\u308B\n -listmods[:[,...]]\n \u76E3\u8996\u53EF\u80FD\u306A\u30E2\u30B8\u30E5\u30FC\u30EB\u3092\u30EA\u30B9\u30C8\u3057\u3066\u7D42\u4E86\u3059\u308B\n -D=\n \u30B7\u30B9\u30C6\u30E0\u30FB\u30D7\u30ED\u30D1\u30C6\u30A3\u3092\u8A2D\u5B9A\u3059\u308B\n -verbose:[class|gc|jni]\n \u8A73\u7D30\u306A\u51FA\u529B\u3092\u884C\u3046\n -version \u88FD\u54C1\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u51FA\u529B\u3057\u3066\u7D42\u4E86\u3059\u308B\n -showversion \u88FD\u54C1\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u51FA\u529B\u3057\u3066\u7D9A\u884C\u3059\u308B\n -? -help \u3053\u306E\u30D8\u30EB\u30D7\u30FB\u30E1\u30C3\u30BB\u30FC\u30B8\u3092\u51FA\u529B\u3059\u308B\n -X \u975E\u6A19\u6E96\u30AA\u30D7\u30B7\u30E7\u30F3\u306B\u95A2\u3059\u308B\u30D8\u30EB\u30D7\u3092\u51FA\u529B\u3059\u308B\n -ea[:...|:]\n -enableassertions[:...|:]\n \u6307\u5B9A\u3057\u305F\u7C92\u5EA6\u3067\u30A2\u30B5\u30FC\u30B7\u30E7\u30F3\u3092\u6709\u52B9\u306B\u3059\u308B\n -da[:...|:]\n -disableassertions[:...|:]\n \u6307\u5B9A\u3057\u305F\u7C92\u5EA6\u3067\u30A2\u30B5\u30FC\u30B7\u30E7\u30F3\u3092\u7121\u52B9\u306B\u3059\u308B\n -esa | -enablesystemassertions\n \u30B7\u30B9\u30C6\u30E0\u30FB\u30A2\u30B5\u30FC\u30B7\u30E7\u30F3\u3092\u6709\u52B9\u306B\u3059\u308B\n -dsa | -disablesystemassertions\n \u30B7\u30B9\u30C6\u30E0\u30FB\u30A2\u30B5\u30FC\u30B7\u30E7\u30F3\u3092\u7121\u52B9\u306B\u3059\u308B\n -agentlib:[=]\n \u30CD\u30A4\u30C6\u30A3\u30D6\u30FB\u30A8\u30FC\u30B8\u30A7\u30F3\u30C8\u30FB\u30E9\u30A4\u30D6\u30E9\u30EA\u3092\u30ED\u30FC\u30C9\u3059\u308B\u3002\u4F8B: -agentlib:jdwp\n -agentlib:jdwp=help\u3082\u53C2\u7167\n -agentpath:[=]\n \ -\u30D5\u30EB\u30D1\u30B9\u540D\u3067\u30CD\u30A4\u30C6\u30A3\u30D6\u30FB\u30A8\u30FC\u30B8\u30A7\u30F3\u30C8\u30FB\u30E9\u30A4\u30D6\u30E9\u30EA\u3092\u30ED\u30FC\u30C9\u3059\u308B\n -javaagent:[=]\n Java\u30D7\u30ED\u30B0\u30E9\u30DF\u30F3\u30B0\u8A00\u8A9E\u30A8\u30FC\u30B8\u30A7\u30F3\u30C8\u3092\u30ED\u30FC\u30C9\u3059\u308B\u3002java.lang.instrument\u3092\u53C2\u7167\n -splash:\n \u6307\u5B9A\u3057\u305F\u30A4\u30E1\u30FC\u30B8\u3067\u30B9\u30D7\u30E9\u30C3\u30B7\u30E5\u753B\u9762\u3092\u8868\u793A\u3059\u308B\n @ \u6307\u5B9A\u3057\u305F\u30D5\u30A1\u30A4\u30EB\u304B\u3089\u30AA\u30D7\u30B7\u30E7\u30F3\u3092\u8AAD\u307F\u53D6\u308B\n +java.launcher.opt.footer =\ -cp \n -classpath \n \u30AF\u30E9\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u3092\u691C\u7D22\u3059\u308B\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u3001\n JAR\u30A2\u30FC\u30AB\u30A4\u30D6\u304A\u3088\u3073ZIP\u30A2\u30FC\u30AB\u30A4\u30D6\u306E{0}\u3067\u533A\u5207\u3089\u308C\u305F\u30EA\u30B9\u30C8\u3002\n -mp \n -modulepath ...\n \u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u306E{0}\u3067\u533A\u5207\u3089\u308C\u305F\u30EA\u30B9\u30C8\u3002\u5404\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u306F\n \u30E2\u30B8\u30E5\u30FC\u30EB\u306E\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u3067\u3059\u3002\n -upgrademodulepath ...\n \u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u306E{0}\u3067\u533A\u5207\u3089\u308C\u305F\u30EA\u30B9\u30C8\u3002\u5404\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u306F\n \u30E9\u30F3\u30BF\u30A4\u30E0\u30FB\u30A4\u30E1\u30FC\u30B8\u3067\u30A2\u30C3\u30D7\u30B0\u30EC\u30FC\u30C9\u53EF\u80FD\u306A\u30E2\u30B8\u30E5\u30FC\u30EB\u3092\u7F6E\u63DB\u3059\u308B\n \u30E2\u30B8\u30E5\u30FC\u30EB\u306E\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u3067\u3059\n -m [/]\n \u89E3\u6C7A\u3059\u308B\u521D\u671F\u30E2\u30B8\u30E5\u30FC\u30EB\u304A\u3088\u3073\u30E2\u30B8\u30E5\u30FC\u30EB\u3067\u6307\u5B9A\u3055\u308C\u3066\u3044\u306A\u3044\u5834\u5408\u306B\n \u5B9F\u884C\u3059\u308B\u30E1\u30A4\u30F3\u30FB\u30AF\u30E9\u30B9\u306E\u540D\u524D\n -addmods [,...]\n \u521D\u671F\u30E2\u30B8\u30E5\u30FC\u30EB\u306B\u52A0\u3048\u3066\u89E3\u6C7A\u3059\u308B\u30EB\u30FC\u30C8\u30FB\u30E2\u30B8\u30E5\u30FC\u30EB\n -limitmods [,...]\n \u76E3\u8996\u53EF\u80FD\u306A\u30E2\u30B8\u30E5\u30FC\u30EB\u306E\u30E6\u30CB\u30D0\u30FC\u30B9\u3092\u5236\u9650\u3059\u308B\n -listmods[:[,...]]\n \u76E3\u8996\u53EF\u80FD\u306A\u30E2\u30B8\u30E5\u30FC\u30EB\u3092\u30EA\u30B9\u30C8\u3057\u3066\u7D42\u4E86\u3059\u308B\n -D=\n \u30B7\u30B9\u30C6\u30E0\u30FB\u30D7\u30ED\u30D1\u30C6\u30A3\u3092\u8A2D\u5B9A\u3059\u308B\n -verbose:[class|gc|jni]\n \u8A73\u7D30\u306A\u51FA\u529B\u3092\u884C\u3046\n -version \u88FD\u54C1\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u51FA\u529B\u3057\u3066\u7D42\u4E86\u3059\u308B\n -showversion \u88FD\u54C1\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u51FA\u529B\u3057\u3066\u7D9A\u884C\u3059\u308B\n -? -help \u3053\u306E\u30D8\u30EB\u30D7\u30FB\u30E1\u30C3\u30BB\u30FC\u30B8\u3092\u51FA\u529B\u3059\u308B\n -X \u975E\u6A19\u6E96\u30AA\u30D7\u30B7\u30E7\u30F3\u306B\u95A2\u3059\u308B\u30D8\u30EB\u30D7\u3092\u51FA\u529B\u3059\u308B\n -ea[:...|:]\n -enableassertions[:...|:]\n \u6307\u5B9A\u3057\u305F\u7C92\u5EA6\u3067\u30A2\u30B5\u30FC\u30B7\u30E7\u30F3\u3092\u6709\u52B9\u306B\u3059\u308B\n -da[:...|:]\n -disableassertions[:...|:]\n \u6307\u5B9A\u3057\u305F\u7C92\u5EA6\u3067\u30A2\u30B5\u30FC\u30B7\u30E7\u30F3\u3092\u7121\u52B9\u306B\u3059\u308B\n -esa | -enablesystemassertions\n \u30B7\u30B9\u30C6\u30E0\u30FB\u30A2\u30B5\u30FC\u30B7\u30E7\u30F3\u3092\u6709\u52B9\u306B\u3059\u308B\n -dsa | -disablesystemassertions\n \u30B7\u30B9\u30C6\u30E0\u30FB\u30A2\u30B5\u30FC\u30B7\u30E7\u30F3\u3092\u7121\u52B9\u306B\u3059\u308B\n -agentlib:[=]\n \u30CD\u30A4\u30C6\u30A3\u30D6\u30FB\u30A8\u30FC\u30B8\u30A7\u30F3\u30C8\u30FB\u30E9\u30A4\u30D6\u30E9\u30EA\u3092\u30ED\u30FC\u30C9\u3059\u308B\u3002\u4F8B: \ +-agentlib:jdwp\n -agentlib:jdwp=help\u3082\u53C2\u7167\n -agentpath:[=]\n \u30D5\u30EB\u30D1\u30B9\u540D\u3067\u30CD\u30A4\u30C6\u30A3\u30D6\u30FB\u30A8\u30FC\u30B8\u30A7\u30F3\u30C8\u30FB\u30E9\u30A4\u30D6\u30E9\u30EA\u3092\u30ED\u30FC\u30C9\u3059\u308B\n -javaagent:[=]\n Java\u30D7\u30ED\u30B0\u30E9\u30DF\u30F3\u30B0\u8A00\u8A9E\u30A8\u30FC\u30B8\u30A7\u30F3\u30C8\u3092\u30ED\u30FC\u30C9\u3059\u308B\u3002java.lang.instrument\u3092\u53C2\u7167\n -splash:\n \u6307\u5B9A\u3057\u305F\u30A4\u30E1\u30FC\u30B8\u3067\u30B9\u30D7\u30E9\u30C3\u30B7\u30E5\u753B\u9762\u3092\u8868\u793A\u3059\u308B\n @ \u6307\u5B9A\u3057\u305F\u30D5\u30A1\u30A4\u30EB\u304B\u3089\u30AA\u30D7\u30B7\u30E7\u30F3\u3092\u8AAD\u307F\u53D6\u308B\n See \u8A73\u7D30\u306F\u3001http://www.oracle.com/technetwork/java/javase/documentation/index.html\u3092\u53C2\u7167\u3057\u3066\u304F\u3060\u3055\u3044\u3002 # Translators please note do not translate the options themselves -java.launcher.X.usage=\ -Xmixed \u6DF7\u5408\u30E2\u30FC\u30C9\u306E\u5B9F\u884C(\u30C7\u30D5\u30A9\u30EB\u30C8)\n -Xint \u30A4\u30F3\u30BF\u30D7\u30EA\u30BF\u30FB\u30E2\u30FC\u30C9\u306E\u5B9F\u884C\u306E\u307F\n -Xbootclasspath/a:<{0}\u3067\u533A\u5207\u3089\u308C\u305F\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u304A\u3088\u3073zip/jar\u30D5\u30A1\u30A4\u30EB>\n \u30D6\u30FC\u30C8\u30B9\u30C8\u30E9\u30C3\u30D7\u30FB\u30AF\u30E9\u30B9\u30FB\u30D1\u30B9\u306E\u6700\u5F8C\u306B\u8FFD\u52A0\u3059\u308B\n -Xdiag \u8FFD\u52A0\u306E\u8A3A\u65AD\u30E1\u30C3\u30BB\u30FC\u30B8\u3092\u8868\u793A\u3059\u308B\n -Xdiag:resolver \u30EA\u30BE\u30EB\u30D0\u8A3A\u65AD\u30E1\u30C3\u30BB\u30FC\u30B8\u3092\u8868\u793A\u3059\u308B\n -Xnoclassgc \u30AF\u30E9\u30B9\u306E\u30AC\u30D9\u30FC\u30B8\u30FB\u30B3\u30EC\u30AF\u30B7\u30E7\u30F3\u3092\u7121\u52B9\u306B\u3059\u308B\n -Xincgc \u5897\u5206\u30AC\u30D9\u30FC\u30B8\u30FB\u30B3\u30EC\u30AF\u30B7\u30E7\u30F3\u3092\u6709\u52B9\u306B\u3059\u308B\n -Xloggc: \u30BF\u30A4\u30E0\u30B9\u30BF\u30F3\u30D7\u304C\u4ED8\u3044\u305F\u30D5\u30A1\u30A4\u30EB\u306BGC\u30B9\u30C6\u30FC\u30BF\u30B9\u306E\u30ED\u30B0\u3092\u8A18\u9332\u3059\u308B\n -Xbatch \u30D0\u30C3\u30AF\u30B0\u30E9\u30A6\u30F3\u30C9\u306E\u30B3\u30F3\u30D1\u30A4\u30EB\u3092\u7121\u52B9\u306B\u3059\u308B\n -Xms Java\u306E\u521D\u671F\u30D2\u30FC\u30D7\u30FB\u30B5\u30A4\u30BA\u3092\u8A2D\u5B9A\u3059\u308B\n -Xmx Java\u306E\u6700\u5927\u30D2\u30FC\u30D7\u30FB\u30B5\u30A4\u30BA\u3092\u8A2D\u5B9A\u3059\u308B\n -Xss Java\u306E\u30B9\u30EC\u30C3\u30C9\u30FB\u30B9\u30BF\u30C3\u30AF\u30FB\u30B5\u30A4\u30BA\u3092\u8A2D\u5B9A\u3059\u308B\n -Xprof CPU\u30D7\u30ED\u30D5\u30A1\u30A4\u30EB\u30FB\u30C7\u30FC\u30BF\u3092\u51FA\u529B\u3059\u308B\n -Xfuture \u5C06\u6765\u306E\u30C7\u30D5\u30A9\u30EB\u30C8\u3092\u898B\u8D8A\u3057\u3066\u3001\u6700\u3082\u53B3\u5BC6\u306A\u30C1\u30A7\u30C3\u30AF\u3092\u6709\u52B9\u306B\u3059\u308B\n -Xrs Java/VM\u306B\u3088\u308BOS\u30B7\u30B0\u30CA\u30EB\u306E\u4F7F\u7528\u3092\u524A\u6E1B\u3059\u308B(\u30C9\u30AD\u30E5\u30E1\u30F3\u30C8\u3092\u53C2\u7167)\n -Xcheck:jni JNI\u95A2\u6570\u306B\u5BFE\u3059\u308B\u8FFD\u52A0\u306E\u30C1\u30A7\u30C3\u30AF\u3092\u5B9F\u884C\u3059\u308B\n -Xshare:off \u5171\u6709\u30AF\u30E9\u30B9\u306E\u30C7\u30FC\u30BF\u3092\u4F7F\u7528\u3057\u3088\u3046\u3068\u3057\u306A\u3044\n -Xshare:auto \u53EF\u80FD\u3067\u3042\u308C\u3070\u5171\u6709\u30AF\u30E9\u30B9\u306E\u30C7\u30FC\u30BF\u3092\u4F7F\u7528\u3059\u308B(\u30C7\u30D5\u30A9\u30EB\u30C8)\n -Xshare:on \u5171\u6709\u30AF\u30E9\u30B9\u30FB\u30C7\u30FC\u30BF\u306E\u4F7F\u7528\u3092\u5FC5\u9808\u306B\u3057\u3001\u3067\u304D\u306A\u3051\u308C\u3070\u5931\u6557\u3059\u308B\u3002\n -XshowSettings \u3059\u3079\u3066\u306E\u8A2D\u5B9A\u3092\u8868\u793A\u3057\u3066\u7D9A\u884C\u3059\u308B\n -XshowSettings:all\n \u3059\u3079\u3066\u306E\u8A2D\u5B9A\u3092\u8868\u793A\u3057\u3066\u7D9A\u884C\u3059\u308B\n -XshowSettings:vm \u3059\u3079\u3066\u306EVM\u95A2\u9023\u306E\u8A2D\u5B9A\u3092\u8868\u793A\u3057\u3066\u7D9A\u884C\u3059\u308B\n -XshowSettings:properties\n \u3059\u3079\u3066\u306E\u30D7\u30ED\u30D1\u30C6\u30A3\u8A2D\u5B9A\u3092\u8868\u793A\u3057\u3066\u7D9A\u884C\u3059\u308B\n -XshowSettings:locale\n \u3059\u3079\u3066\u306E\u30ED\u30B1\u30FC\u30EB\u95A2\u9023\u306E\u8A2D\u5B9A\u3092\u8868\u793A\u3057\u3066\u7D9A\u884C\u3059\u308B\n -XaddReads:=(,)*\n \u30E2\u30B8\u30E5\u30FC\u30EB\u5BA3\u8A00\u306B\u95A2\u4FC2\u306A\u304F\u3001\n \u306F\u4ED6\u306E\u30E2\u30B8\u30E5\u30FC\u30EB\u3092\u8AAD\u307F\u53D6\u308B\n \ --XaddExports:/=(,)*\n \u30E2\u30B8\u30E5\u30FC\u30EB\u5BA3\u8A00\u306B\u95A2\u4FC2\u306A\u304F\u3001\n \u306F\u3092\u4ED6\u306E\u30E2\u30B8\u30E5\u30FC\u30EB\u306B\u30A8\u30AF\u30B9\u30DD\u30FC\u30C8\u3059\u308B\n -Xpatch:=({0})*\n JAR\u30D5\u30A1\u30A4\u30EB\u307E\u305F\u306F\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u306E\u30AF\u30E9\u30B9\u304A\u3088\u3073\u30EA\u30BD\u30FC\u30B9\u3067\u30E2\u30B8\u30E5\u30FC\u30EB\u3092\n \u30AA\u30FC\u30D0\u30FC\u30E9\u30A4\u30C9\u307E\u305F\u306F\u62E1\u5F35\u3059\u308B\n -Xdisable-@files \u3055\u3089\u306A\u308B\u30D5\u30A1\u30A4\u30EB\u62E1\u5F35\u3092\u7121\u52B9\u306B\u3059\u308B\n\n-X\u30AA\u30D7\u30B7\u30E7\u30F3\u306F\u975E\u6A19\u6E96\u306A\u306E\u3067\u3001\u4E88\u544A\u306A\u304F\u5909\u66F4\u3055\u308C\u308B\u5834\u5408\u304C\u3042\u308A\u307E\u3059\u3002\n +java.launcher.X.usage=\ -Xmixed \u6DF7\u5408\u30E2\u30FC\u30C9\u306E\u5B9F\u884C(\u30C7\u30D5\u30A9\u30EB\u30C8)\n -Xint \u30A4\u30F3\u30BF\u30D7\u30EA\u30BF\u30FB\u30E2\u30FC\u30C9\u306E\u5B9F\u884C\u306E\u307F\n -Xbootclasspath/a:<{0}\u3067\u533A\u5207\u3089\u308C\u305F\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u304A\u3088\u3073zip/jar\u30D5\u30A1\u30A4\u30EB>\n \u30D6\u30FC\u30C8\u30B9\u30C8\u30E9\u30C3\u30D7\u30FB\u30AF\u30E9\u30B9\u30FB\u30D1\u30B9\u306E\u6700\u5F8C\u306B\u8FFD\u52A0\u3059\u308B\n -Xdiag \u8FFD\u52A0\u306E\u8A3A\u65AD\u30E1\u30C3\u30BB\u30FC\u30B8\u3092\u8868\u793A\u3059\u308B\n -Xdiag:resolver \u30EA\u30BE\u30EB\u30D0\u8A3A\u65AD\u30E1\u30C3\u30BB\u30FC\u30B8\u3092\u8868\u793A\u3059\u308B\n -Xnoclassgc \u30AF\u30E9\u30B9\u306E\u30AC\u30D9\u30FC\u30B8\u30FB\u30B3\u30EC\u30AF\u30B7\u30E7\u30F3\u3092\u7121\u52B9\u306B\u3059\u308B\n -Xloggc: \u30BF\u30A4\u30E0\u30B9\u30BF\u30F3\u30D7\u304C\u4ED8\u3044\u305F\u30D5\u30A1\u30A4\u30EB\u306BGC\u30B9\u30C6\u30FC\u30BF\u30B9\u306E\u30ED\u30B0\u3092\u8A18\u9332\u3059\u308B\n -Xbatch \u30D0\u30C3\u30AF\u30B0\u30E9\u30A6\u30F3\u30C9\u306E\u30B3\u30F3\u30D1\u30A4\u30EB\u3092\u7121\u52B9\u306B\u3059\u308B\n -Xms Java\u306E\u521D\u671F\u30D2\u30FC\u30D7\u30FB\u30B5\u30A4\u30BA\u3092\u8A2D\u5B9A\u3059\u308B\n -Xmx Java\u306E\u6700\u5927\u30D2\u30FC\u30D7\u30FB\u30B5\u30A4\u30BA\u3092\u8A2D\u5B9A\u3059\u308B\n -Xss Java\u306E\u30B9\u30EC\u30C3\u30C9\u30FB\u30B9\u30BF\u30C3\u30AF\u30FB\u30B5\u30A4\u30BA\u3092\u8A2D\u5B9A\u3059\u308B\n -Xprof CPU\u30D7\u30ED\u30D5\u30A1\u30A4\u30EB\u30FB\u30C7\u30FC\u30BF\u3092\u51FA\u529B\u3059\u308B\n -Xfuture \u5C06\u6765\u306E\u30C7\u30D5\u30A9\u30EB\u30C8\u3092\u898B\u8D8A\u3057\u3066\u3001\u6700\u3082\u53B3\u5BC6\u306A\u30C1\u30A7\u30C3\u30AF\u3092\u6709\u52B9\u306B\u3059\u308B\n -Xrs Java/VM\u306B\u3088\u308BOS\u30B7\u30B0\u30CA\u30EB\u306E\u4F7F\u7528\u3092\u524A\u6E1B\u3059\u308B(\u30C9\u30AD\u30E5\u30E1\u30F3\u30C8\u3092\u53C2\u7167)\n -Xcheck:jni JNI\u95A2\u6570\u306B\u5BFE\u3059\u308B\u8FFD\u52A0\u306E\u30C1\u30A7\u30C3\u30AF\u3092\u5B9F\u884C\u3059\u308B\n -Xshare:off \u5171\u6709\u30AF\u30E9\u30B9\u306E\u30C7\u30FC\u30BF\u3092\u4F7F\u7528\u3057\u3088\u3046\u3068\u3057\u306A\u3044\n -Xshare:auto \u53EF\u80FD\u3067\u3042\u308C\u3070\u5171\u6709\u30AF\u30E9\u30B9\u306E\u30C7\u30FC\u30BF\u3092\u4F7F\u7528\u3059\u308B(\u30C7\u30D5\u30A9\u30EB\u30C8)\n -Xshare:on \u5171\u6709\u30AF\u30E9\u30B9\u30FB\u30C7\u30FC\u30BF\u306E\u4F7F\u7528\u3092\u5FC5\u9808\u306B\u3057\u3001\u3067\u304D\u306A\u3051\u308C\u3070\u5931\u6557\u3059\u308B\u3002\n -XshowSettings \u3059\u3079\u3066\u306E\u8A2D\u5B9A\u3092\u8868\u793A\u3057\u3066\u7D9A\u884C\u3059\u308B\n -XshowSettings:all\n \u3059\u3079\u3066\u306E\u8A2D\u5B9A\u3092\u8868\u793A\u3057\u3066\u7D9A\u884C\u3059\u308B\n -XshowSettings:vm \u3059\u3079\u3066\u306EVM\u95A2\u9023\u306E\u8A2D\u5B9A\u3092\u8868\u793A\u3057\u3066\u7D9A\u884C\u3059\u308B\n -XshowSettings:properties\n \u3059\u3079\u3066\u306E\u30D7\u30ED\u30D1\u30C6\u30A3\u8A2D\u5B9A\u3092\u8868\u793A\u3057\u3066\u7D9A\u884C\u3059\u308B\n -XshowSettings:locale\n \u3059\u3079\u3066\u306E\u30ED\u30B1\u30FC\u30EB\u95A2\u9023\u306E\u8A2D\u5B9A\u3092\u8868\u793A\u3057\u3066\u7D9A\u884C\u3059\u308B\n -XaddReads:=(,)*\n \u30E2\u30B8\u30E5\u30FC\u30EB\u5BA3\u8A00\u306B\u95A2\u4FC2\u306A\u304F\u3001\n \u306F\u4ED6\u306E\u30E2\u30B8\u30E5\u30FC\u30EB\u3092\u8AAD\u307F\u53D6\u308B\n -XaddExports:/=(,)*\n \u30E2\u30B8\u30E5\u30FC\u30EB\u5BA3\u8A00\u306B\u95A2\u4FC2\u306A\u304F\u3001\n \ + \u306F\u3092\u4ED6\u306E\u30E2\u30B8\u30E5\u30FC\u30EB\u306B\u30A8\u30AF\u30B9\u30DD\u30FC\u30C8\u3059\u308B\n -Xpatch:=({0})*\n JAR\u30D5\u30A1\u30A4\u30EB\u307E\u305F\u306F\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u306E\u30AF\u30E9\u30B9\u304A\u3088\u3073\u30EA\u30BD\u30FC\u30B9\u3067\u30E2\u30B8\u30E5\u30FC\u30EB\u3092\n \u30AA\u30FC\u30D0\u30FC\u30E9\u30A4\u30C9\u307E\u305F\u306F\u62E1\u5F35\u3059\u308B\n -Xdisable-@files \u3055\u3089\u306A\u308B\u30D5\u30A1\u30A4\u30EB\u62E1\u5F35\u3092\u7121\u52B9\u306B\u3059\u308B\n\n-X\u30AA\u30D7\u30B7\u30E7\u30F3\u306F\u975E\u6A19\u6E96\u306A\u306E\u3067\u3001\u4E88\u544A\u306A\u304F\u5909\u66F4\u3055\u308C\u308B\u5834\u5408\u304C\u3042\u308A\u307E\u3059\u3002\n # Translators please note do not translate the options themselves java.launcher.X.macosx.usage=\n\u6B21\u306E\u30AA\u30D7\u30B7\u30E7\u30F3\u306FMac OS X\u56FA\u6709\u3067\u3059\u3002\n -XstartOnFirstThread\n main()\u30E1\u30BD\u30C3\u30C9\u3092\u6700\u521D(AppKit)\u306E\u30B9\u30EC\u30C3\u30C9\u3067\u5B9F\u884C\u3059\u308B\n -Xdock:name="\n Dock\u306B\u8868\u793A\u3055\u308C\u308B\u30C7\u30D5\u30A9\u30EB\u30C8\u30FB\u30A2\u30D7\u30EA\u30B1\u30FC\u30B7\u30E7\u30F3\u540D\u3092\u30AA\u30FC\u30D0\u30FC\u30E9\u30A4\u30C9\u3059\u308B\n -Xdock:icon=\n Dock\u306B\u8868\u793A\u3055\u308C\u308B\u30C7\u30D5\u30A9\u30EB\u30C8\u30FB\u30A2\u30A4\u30B3\u30F3\u3092\u30AA\u30FC\u30D0\u30FC\u30E9\u30A4\u30C9\u3059\u308B\n\n diff --git a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_ko.properties b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_ko.properties index ac055e3cb61..28aa2f57ffb 100644 --- a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_ko.properties +++ b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_ko.properties @@ -24,7 +24,7 @@ # # Translators please note do not translate the options themselves -java.launcher.opt.header = \uC0AC\uC6A9\uBC95: {0} [options] class [args...]\n (\uD074\uB798\uC2A4 \uC2E4\uD589)\n \uB610\uB294 {0} [options] -jar jarfile [args...]\n (jar \uD30C\uC77C \uC2E4\uD589)\n \uB610\uB294 {0} [-options] -mp -m | /\n (\uBAA8\uB4C8\uC758 \uAE30\uBCF8 \uD074\uB798\uC2A4 \uC2E4\uD589)\n\uC5EC\uAE30\uC11C options\uB294 \uB2E4\uC74C\uACFC \uAC19\uC2B5\uB2C8\uB2E4.\n +java.launcher.opt.header = \uC0AC\uC6A9\uBC95: {0} [options] class [args...]\n (\uD074\uB798\uC2A4 \uC2E4\uD589)\n \uB610\uB294 {0} [options] -jar jarfile [args...]\n (jar \uD30C\uC77C \uC2E4\uD589)\n \uB610\uB294 {0} [options] -mp -m [/] [args...]\n (\uBAA8\uB4C8\uC758 \uAE30\uBCF8 \uD074\uB798\uC2A4 \uC2E4\uD589)\n\uC5EC\uAE30\uC11C options\uB294 \uB2E4\uC74C\uACFC \uAC19\uC2B5\uB2C8\uB2E4.\n java.launcher.opt.datamodel =\ -d{0}\t \uC0AC\uC6A9 \uAC00\uB2A5\uD55C \uACBD\uC6B0 {0}\uBE44\uD2B8 \uB370\uC774\uD130 \uBAA8\uB378\uC744 \uC0AC\uC6A9\uD569\uB2C8\uB2E4.\n java.launcher.opt.vmselect =\ {0}\t "{1}" VM\uC744 \uC120\uD0DD\uD569\uB2C8\uB2E4.\n @@ -34,13 +34,13 @@ java.launcher.ergo.message1 =\ \uAE30\uBCF8 VM\uC740 {0}\uC785 java.launcher.ergo.message2 =\ \uC11C\uBC84\uAE09 \uC2DC\uC2A4\uD15C\uC5D0\uC11C \uC2E4\uD589 \uC911\uC774\uAE30 \uB54C\uBB38\uC785\uB2C8\uB2E4.\n # Translators please note do not translate the options themselves -java.launcher.opt.footer =\ -cp <\uB514\uB809\uD1A0\uB9AC \uBC0F zip/jar \uD30C\uC77C\uC758 \uD074\uB798\uC2A4 \uAC80\uC0C9 \uACBD\uB85C>\n -classpath <\uB514\uB809\uD1A0\uB9AC \uBC0F zip/jar \uD30C\uC77C\uC758 \uD074\uB798\uC2A4 \uAC80\uC0C9 \uACBD\uB85C>\n \uD074\uB798\uC2A4 \uD30C\uC77C\uC744 \uAC80\uC0C9\uD560 {0}(\uC73C)\uB85C \uAD6C\uBD84\uB41C \uB514\uB809\uD1A0\uB9AC,\n JAR \uC544\uCE74\uC774\uBE0C \uBC0F ZIP \uC544\uCE74\uC774\uBE0C \uBAA9\uB85D\uC785\uB2C8\uB2E4.\n -mp <\uBAA8\uB4C8 \uACBD\uB85C>\n -modulepath <\uBAA8\uB4C8 \uACBD\uB85C>...\n {0}(\uC73C)\uB85C \uAD6C\uBD84\uB41C \uB514\uB809\uD1A0\uB9AC \uBAA9\uB85D\uC785\uB2C8\uB2E4. \uAC01 \uB514\uB809\uD1A0\uB9AC\uB294\n \uBAA8\uB4C8\uC758 \uB514\uB809\uD1A0\uB9AC\uC785\uB2C8\uB2E4.\n -upgrademodulepath <\uBAA8\uB4C8 \uACBD\uB85C>...\n {0}(\uC73C)\uB85C \uAD6C\uBD84\uB41C \uB514\uB809\uD1A0\uB9AC \uBAA9\uB85D\uC785\uB2C8\uB2E4. \uAC01 \uB514\uB809\uD1A0\uB9AC\uB294\n \uBAA8\uB4C8\uC758 \uB514\uB809\uD1A0\uB9AC\uB85C, \uB7F0\uD0C0\uC784 \uC774\uBBF8\uC9C0\uC5D0\uC11C \uC5C5\uADF8\uB808\uC774\uB4DC\n \uAC00\uB2A5\uD55C \uBAA8\uB4C8\uC744 \uB300\uCCB4\uD569\uB2C8\uB2E4.\n -m | /\n \uBD84\uC11D\uD560 \uCD08\uAE30 \uB610\uB294 \uAE30\uBCF8 \uBAA8\uB4C8\uC785\uB2C8\uB2E4.\n -addmods [,...]\n \uCD08\uAE30 \uBAA8\uB4C8 \uC678\uC5D0 \uBD84\uC11D\uD560 \uB8E8\uD2B8 \uBAA8\uB4C8\uC785\uB2C8\uB2E4.\n -limitmods [,...]\n \uAD00\uCC30 \uAC00\uB2A5\uD55C \uBAA8\uB4C8\uC758 \uBC94\uC704\uB97C \uC81C\uD55C\uD569\uB2C8\uB2E4.\n -listmods[:[,...]]\n \uAD00\uCC30 \uAC00\uB2A5\uD55C \uBAA8\uB4C8\uC744 \uB098\uC5F4\uD55C \uD6C4 \uC885\uB8CC\uD569\uB2C8\uB2E4.\n -D=\n \uC2DC\uC2A4\uD15C \uC18D\uC131\uC744 \uC124\uC815\uD569\uB2C8\uB2E4.\n -verbose:[class|gc|jni]\n \uC0C1\uC138 \uC815\uBCF4 \uCD9C\uB825\uC744 \uC0AC\uC6A9\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -version \uC81C\uD488 \uBC84\uC804\uC744 \uC778\uC1C4\uD55C \uD6C4 \uC885\uB8CC\uD569\uB2C8\uB2E4.\n -showversion \uC81C\uD488 \uBC84\uC804\uC744 \uC778\uC1C4\uD55C \uD6C4 \uACC4\uC18D\uD569\uB2C8\uB2E4.\n -? -help \uC774 \uB3C4\uC6C0\uB9D0 \uBA54\uC2DC\uC9C0\uB97C \uC778\uC1C4\uD569\uB2C8\uB2E4.\n -X \uBE44\uD45C\uC900 \uC635\uC158\uC5D0 \uB300\uD55C \uB3C4\uC6C0\uB9D0\uC744 \uC778\uC1C4\uD569\uB2C8\uB2E4.\n -ea[:...|:]\n -enableassertions[:...|:]\n \uC138\uBD84\uC131\uC774 \uC9C0\uC815\uB41C \uAC80\uC99D\uC744 \uC0AC\uC6A9\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -da[:...|:]\n -disableassertions[:...|:]\n \uC138\uBD84\uC131\uC774 \uC9C0\uC815\uB41C \uAC80\uC99D\uC744 \uC0AC\uC6A9 \uC548\uD568\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -esa | -enablesystemassertions\n \uC2DC\uC2A4\uD15C \uAC80\uC99D\uC744 \uC0AC\uC6A9\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -dsa | -disablesystemassertions\n \uC2DC\uC2A4\uD15C \uAC80\uC99D\uC744 \uC0AC\uC6A9 \uC548\uD568\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -agentlib:[=]\n \uACE0\uC720 \uC5D0\uC774\uC804\uD2B8 \uB77C\uC774\uBE0C\uB7EC\uB9AC \uC744 \uB85C\uB4DC\uD569\uB2C8\uB2E4(\uC608: -agentlib:jdwp).\n -agentlib:jdwp=help\uB3C4 \uCC38\uC870\uD558\uC2ED\uC2DC\uC624.\n -agentpath:[=]\n \uC804\uCCB4 \uACBD\uB85C\uBA85\uC744 \uC0AC\uC6A9\uD558\uC5EC \uACE0\uC720 \uC5D0\uC774\uC804\uD2B8 \uB77C\uC774\uBE0C\uB7EC\uB9AC\uB97C \uB85C\uB4DC\uD569\uB2C8\uB2E4.\n \ --javaagent:[=]\n Java \uD504\uB85C\uADF8\uB798\uBC0D \uC5B8\uC5B4 \uC5D0\uC774\uC804\uD2B8\uB97C \uB85C\uB4DC\uD569\uB2C8\uB2E4. java.lang.instrument\uB97C \uCC38\uC870\uD558\uC2ED\uC2DC\uC624.\n -splash:\n \uC774\uBBF8\uC9C0\uAC00 \uC9C0\uC815\uB41C \uC2A4\uD50C\uB798\uC2DC \uD654\uBA74\uC744 \uD45C\uC2DC\uD569\uB2C8\uB2E4.\n @ \uC9C0\uC815\uB41C \uD30C\uC77C\uC5D0\uC11C \uC635\uC158\uC744 \uC77D\uC2B5\uB2C8\uB2E4.\n +java.launcher.opt.footer =\ -cp \n -classpath \n \uD074\uB798\uC2A4 \uD30C\uC77C\uC744 \uAC80\uC0C9\uD560 {0}(\uC73C)\uB85C \uAD6C\uBD84\uB41C \uB514\uB809\uD1A0\uB9AC,\n JAR \uC544\uCE74\uC774\uBE0C \uBC0F ZIP \uC544\uCE74\uC774\uBE0C \uBAA9\uB85D\uC785\uB2C8\uB2E4.\n -mp \n -modulepath ...\n {0}(\uC73C)\uB85C \uAD6C\uBD84\uB41C \uB514\uB809\uD1A0\uB9AC \uBAA9\uB85D\uC785\uB2C8\uB2E4. \uAC01 \uB514\uB809\uD1A0\uB9AC\uB294\n \uBAA8\uB4C8\uC758 \uB514\uB809\uD1A0\uB9AC\uC785\uB2C8\uB2E4.\n -upgrademodulepath ...\n {0}(\uC73C)\uB85C \uAD6C\uBD84\uB41C \uB514\uB809\uD1A0\uB9AC \uBAA9\uB85D\uC785\uB2C8\uB2E4. \uAC01 \uB514\uB809\uD1A0\uB9AC\uB294\n \uB7F0\uD0C0\uC784 \uC774\uBBF8\uC9C0\uC5D0\uC11C \uC5C5\uADF8\uB808\uC774\uB4DC \uAC00\uB2A5\uD55C \uBAA8\uB4C8\uC744\n \uB300\uCCB4\uD558\uB294 \uBAA8\uB4C8\uC758 \uB514\uB809\uD1A0\uB9AC\uC785\uB2C8\uB2E4.\n -m [/]\n \uBD84\uC11D\uD560 \uCD08\uAE30 \uBAA8\uB4C8 \uBC0F \uBAA8\uB4C8\uC5D0\uC11C \uC9C0\uC815\uB418\uC9C0 \uC54A\uC740 \uACBD\uC6B0 \uC2E4\uD589\uD560\n \uAE30\uBCF8 \uD074\uB798\uC2A4\uC758 \uC774\uB984\uC785\uB2C8\uB2E4.\n -addmods [,...]\n \uCD08\uAE30 \uBAA8\uB4C8 \uC678\uC5D0 \uBD84\uC11D\uD560 \uB8E8\uD2B8 \uBAA8\uB4C8\uC785\uB2C8\uB2E4.\n -limitmods [,...]\n \uAD00\uCC30 \uAC00\uB2A5\uD55C \uBAA8\uB4C8\uC758 \uBC94\uC704\uB97C \uC81C\uD55C\uD569\uB2C8\uB2E4.\n -listmods[:[,...]]\n \uAD00\uCC30 \uAC00\uB2A5\uD55C \uBAA8\uB4C8\uC744 \uB098\uC5F4\uD558\uACE0 \uC885\uB8CC\uD569\uB2C8\uB2E4.\n -D=\n \uC2DC\uC2A4\uD15C \uC18D\uC131\uC744 \uC124\uC815\uD569\uB2C8\uB2E4.\n -verbose:[class|gc|jni]\n \uC0C1\uC138 \uC815\uBCF4 \uCD9C\uB825\uC744 \uC0AC\uC6A9\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -version \uC81C\uD488 \uBC84\uC804\uC744 \uC778\uC1C4\uD558\uACE0 \uC885\uB8CC\uD569\uB2C8\uB2E4.\n -showversion \uC81C\uD488 \uBC84\uC804\uC744 \uC778\uC1C4\uD558\uACE0 \uACC4\uC18D\uD569\uB2C8\uB2E4.\n -? -help \uC774 \uB3C4\uC6C0\uB9D0 \uBA54\uC2DC\uC9C0\uB97C \uC778\uC1C4\uD569\uB2C8\uB2E4.\n -X \uBE44\uD45C\uC900 \uC635\uC158\uC5D0 \uB300\uD55C \uB3C4\uC6C0\uB9D0\uC744 \uC778\uC1C4\uD569\uB2C8\uB2E4.\n -ea[:...|:]\n -enableassertions[:...|:]\n \uC138\uBD84\uC131\uC774 \uC9C0\uC815\uB41C \uAC80\uC99D\uC744 \uC0AC\uC6A9\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -da[:...|:]\n -disableassertions[:...|:]\n \uC138\uBD84\uC131\uC774 \uC9C0\uC815\uB41C \uAC80\uC99D\uC744 \uC0AC\uC6A9 \uC548\uD568\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -esa | -enablesystemassertions\n \uC2DC\uC2A4\uD15C \uAC80\uC99D\uC744 \uC0AC\uC6A9\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -dsa | -disablesystemassertions\n \uC2DC\uC2A4\uD15C \uAC80\uC99D\uC744 \uC0AC\uC6A9 \uC548\uD568\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -agentlib:[=]\n \uACE0\uC720 \uC5D0\uC774\uC804\uD2B8 \uB77C\uC774\uBE0C\uB7EC\uB9AC \uC744 \uB85C\uB4DC\uD569\uB2C8\uB2E4(\uC608: -agentlib:jdwp)\n -agentlib:jdwp=help\uB3C4 \uCC38\uC870\uD558\uC2ED\uC2DC\uC624.\n -agentpath:[=]\n \uC804\uCCB4 \uACBD\uB85C \uC774\uB984\uC744 \uC0AC\uC6A9\uD574\uC11C \uACE0\uC720 \uC5D0\uC774\uC804\uD2B8 \uB77C\uC774\uBE0C\uB7EC\uB9AC\uB97C \uB85C\uB4DC\uD569\uB2C8\uB2E4.\n -javaagent:[=]\n \ + Java \uD504\uB85C\uADF8\uB798\uBC0D \uC5B8\uC5B4 \uC5D0\uC774\uC804\uD2B8\uB97C \uB85C\uB4DC\uD569\uB2C8\uB2E4. java.lang.instrument\uB97C \uCC38\uC870\uD558\uC2ED\uC2DC\uC624.\n -splash:\n \uC9C0\uC815\uB41C \uC774\uBBF8\uC9C0\uB85C \uC2A4\uD50C\uB798\uC2DC \uD654\uBA74\uC744 \uD45C\uC2DC\uD569\uB2C8\uB2E4.\n @ \uC9C0\uC815\uB41C \uD30C\uC77C\uC5D0\uC11C \uC635\uC158\uC744 \uC77D\uC2B5\uB2C8\uB2E4.\n See \uC790\uC138\uD55C \uB0B4\uC6A9\uC740 http://www.oracle.com/technetwork/java/javase/documentation/index.html\uC744 \uCC38\uC870\uD558\uC2ED\uC2DC\uC624. # Translators please note do not translate the options themselves -java.launcher.X.usage=\ -Xmixed \uD63C\uD569 \uBAA8\uB4DC\uB97C \uC2E4\uD589\uD569\uB2C8\uB2E4(\uAE30\uBCF8\uAC12).\n -Xint \uD574\uC11D\uB41C \uBAA8\uB4DC\uB9CC \uC2E4\uD589\uD569\uB2C8\uB2E4.\n -Xbootclasspath/a:<{0}(\uC73C)\uB85C \uAD6C\uBD84\uB41C \uB514\uB809\uD1A0\uB9AC \uBC0F zip/jar \uD30C\uC77C>\n \uBD80\uD2B8\uC2A4\uD2B8\uB7A9 \uD074\uB798\uC2A4 \uACBD\uB85C \uB05D\uC5D0 \uCD94\uAC00\uD569\uB2C8\uB2E4.\n -Xdiag \uCD94\uAC00 \uC9C4\uB2E8 \uBA54\uC2DC\uC9C0\uB97C \uD45C\uC2DC\uD569\uB2C8\uB2E4.\n -Xdiag:resolver \uBD84\uC11D\uAE30 \uC9C4\uB2E8 \uBA54\uC2DC\uC9C0\uB97C \uD45C\uC2DC\uD569\uB2C8\uB2E4.\n -Xnoclassgc \uD074\uB798\uC2A4\uC758 \uBD88\uD544\uC694\uD55C \uC815\uBCF4 \uBAA8\uC74C\uC744 \uC0AC\uC6A9 \uC548\uD568\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -Xincgc \uC99D\uBD84\uC801\uC778 \uBD88\uD544\uC694\uD55C \uC815\uBCF4 \uBAA8\uC74C\uC744 \uC0AC\uC6A9\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -Xloggc: \uC2DC\uAC04 \uAE30\uB85D\uACFC \uD568\uAED8 \uD30C\uC77C\uC5D0 GC \uC0C1\uD0DC\uB97C \uAE30\uB85D\uD569\uB2C8\uB2E4.\n -Xbatch \uBC31\uADF8\uB77C\uC6B4\uB4DC \uCEF4\uD30C\uC77C\uC744 \uC0AC\uC6A9 \uC548\uD568\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -Xms \uCD08\uAE30 Java \uD799 \uD06C\uAE30\uB97C \uC124\uC815\uD569\uB2C8\uB2E4.\n -Xmx \uCD5C\uB300 Java \uD799 \uD06C\uAE30\uB97C \uC124\uC815\uD569\uB2C8\uB2E4.\n -Xss Java \uC2A4\uB808\uB4DC \uC2A4\uD0DD \uD06C\uAE30\uB97C \uC124\uC815\uD569\uB2C8\uB2E4.\n -Xprof CPU \uD504\uB85C\uD30C\uC77C \uC791\uC131 \uB370\uC774\uD130\uB97C \uCD9C\uB825\uD569\uB2C8\uB2E4.\n -Xfuture \uBBF8\uB798 \uAE30\uBCF8\uAC12\uC744 \uC608\uCE21\uD558\uC5EC \uAC00\uC7A5 \uC5C4\uACA9\uD55C \uAC80\uC0AC\uB97C \uC0AC\uC6A9\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -Xrs Java/VM\uC5D0 \uC758\uD55C OS \uC2E0\uD638 \uC0AC\uC6A9\uC744 \uC904\uC785\uB2C8\uB2E4(\uC124\uBA85\uC11C \uCC38\uC870).\n -Xcheck:jni JNI \uD568\uC218\uC5D0 \uB300\uD55C \uCD94\uAC00 \uAC80\uC0AC\uB97C \uC218\uD589\uD569\uB2C8\uB2E4.\n -Xshare:off \uACF5\uC720 \uD074\uB798\uC2A4 \uB370\uC774\uD130 \uC0AC\uC6A9\uC744 \uC2DC\uB3C4\uD558\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4.\n -Xshare:auto \uAC00\uB2A5\uD55C \uACBD\uC6B0 \uACF5\uC720 \uD074\uB798\uC2A4 \uB370\uC774\uD130\uB97C \uC0AC\uC6A9\uD569\uB2C8\uB2E4(\uAE30\uBCF8\uAC12).\n -Xshare:on \uACF5\uC720 \uD074\uB798\uC2A4 \uB370\uC774\uD130\uB97C \uC0AC\uC6A9\uD574\uC57C \uD569\uB2C8\uB2E4. \uADF8\uB807\uC9C0 \uC54A\uC744 \uACBD\uC6B0 \uC2E4\uD328\uD569\uB2C8\uB2E4.\n -XshowSettings \uBAA8\uB4E0 \uC124\uC815\uC744 \uD45C\uC2DC\uD55C \uD6C4 \uACC4\uC18D\uD569\uB2C8\uB2E4.\n -XshowSettings:all\n \uBAA8\uB4E0 \uC124\uC815\uC744 \uD45C\uC2DC\uD55C \uD6C4 \uACC4\uC18D\uD569\uB2C8\uB2E4.\n -XshowSettings:vm\n \uBAA8\uB4E0 VM \uAD00\uB828 \uC124\uC815\uC744 \uD45C\uC2DC\uD55C \uD6C4 \uACC4\uC18D\uD569\uB2C8\uB2E4.\n -XshowSettings:properties\n \uBAA8\uB4E0 \uC18D\uC131 \uC124\uC815\uC744 \uD45C\uC2DC\uD55C \uD6C4 \uACC4\uC18D\uD569\uB2C8\uB2E4.\n -XshowSettings:locale\n \uBAA8\uB4E0 \uB85C\uCF00\uC77C \uAD00\uB828 \uC124\uC815\uC744 \uD45C\uC2DC\uD55C \uD6C4 \uACC4\uC18D\uD569\uB2C8\uB2E4.\n -XaddReads:=(,)*\n \uC740 \uBAA8\uB4C8 \uC120\uC5B8\uC5D0 \uAD00\uACC4\uC5C6\uC774\n \uB2E4\uB978 \uBAA8\uB4C8\uC744 \uC77D\uC2B5\uB2C8\uB2E4.\n -XaddExports:/=(,)*\n \uC740 \uBAA8\uB4C8 \uC120\uC5B8\uC5D0 \uAD00\uACC4\uC5C6\uC774\n \uB97C \uB2E4\uB978 \uBAA8\uB4C8\uB85C \uC775\uC2A4\uD3EC\uD2B8\uD569\uB2C8\uB2E4.\n \ --Xpatch:=({0})*\n JAR \uD30C\uC77C/\uB514\uB809\uD1A0\uB9AC\uC758 \uD074\uB798\uC2A4\uC640 \uB9AC\uC18C\uC2A4\uB85C\n \uBAA8\uB4C8\uC744 \uBB34\uD6A8\uD654\uD558\uAC70\uB098 \uC778\uC218\uD654\uD569\uB2C8\uB2E4.\n -Xdisable-@files \uCD94\uAC00 \uC778\uC218 \uD30C\uC77C \uD655\uC7A5\uC744 \uC0AC\uC6A9 \uC548\uD568\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n\n-X \uC635\uC158\uC740 \uBE44\uD45C\uC900 \uC635\uC158\uC774\uBBC0\uB85C \uD1B5\uC9C0 \uC5C6\uC774 \uBCC0\uACBD\uB420 \uC218 \uC788\uC2B5\uB2C8\uB2E4.\n +java.launcher.X.usage=\ -Xmixed \uD63C\uD569 \uBAA8\uB4DC\uB97C \uC2E4\uD589\uD569\uB2C8\uB2E4(\uAE30\uBCF8\uAC12).\n -Xint \uD574\uC11D\uB41C \uBAA8\uB4DC\uB9CC \uC2E4\uD589\uD569\uB2C8\uB2E4.\n -Xbootclasspath/a:<{0}(\uC73C)\uB85C \uAD6C\uBD84\uB41C \uB514\uB809\uD1A0\uB9AC \uBC0F zip/jar \uD30C\uC77C>\n \uBD80\uD2B8\uC2A4\uD2B8\uB7A9 \uD074\uB798\uC2A4 \uACBD\uB85C \uB05D\uC5D0 \uCD94\uAC00\uD569\uB2C8\uB2E4.\n -Xdiag \uCD94\uAC00 \uC9C4\uB2E8 \uBA54\uC2DC\uC9C0\uB97C \uD45C\uC2DC\uD569\uB2C8\uB2E4.\n -Xdiag:resolver \uBD84\uC11D\uAE30 \uC9C4\uB2E8 \uBA54\uC2DC\uC9C0\uB97C \uD45C\uC2DC\uD569\uB2C8\uB2E4.\n -Xnoclassgc \uD074\uB798\uC2A4\uC758 \uBD88\uD544\uC694\uD55C \uC815\uBCF4 \uBAA8\uC74C\uC744 \uC0AC\uC6A9 \uC548\uD568\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -Xloggc: \uC2DC\uAC04 \uAE30\uB85D\uACFC \uD568\uAED8 \uD30C\uC77C\uC5D0 GC \uC0C1\uD0DC\uB97C \uAE30\uB85D\uD569\uB2C8\uB2E4.\n -Xbatch \uBC31\uADF8\uB77C\uC6B4\uB4DC \uCEF4\uD30C\uC77C\uC744 \uC0AC\uC6A9 \uC548\uD568\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -Xms \uCD08\uAE30 Java \uD799 \uD06C\uAE30\uB97C \uC124\uC815\uD569\uB2C8\uB2E4.\n -Xmx \uCD5C\uB300 Java \uD799 \uD06C\uAE30\uB97C \uC124\uC815\uD569\uB2C8\uB2E4.\n -Xss Java \uC2A4\uB808\uB4DC \uC2A4\uD0DD \uD06C\uAE30\uB97C \uC124\uC815\uD569\uB2C8\uB2E4.\n -Xprof CPU \uD504\uB85C\uD30C\uC77C \uC791\uC131 \uB370\uC774\uD130\uB97C \uCD9C\uB825\uD569\uB2C8\uB2E4.\n -Xfuture \uBBF8\uB798 \uAE30\uBCF8\uAC12\uC744 \uC608\uCE21\uD558\uC5EC \uAC00\uC7A5 \uC5C4\uACA9\uD55C \uAC80\uC0AC\uB97C \uC0AC\uC6A9\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n -Xrs Java/VM\uC5D0 \uC758\uD55C OS \uC2E0\uD638 \uC0AC\uC6A9\uC744 \uC904\uC785\uB2C8\uB2E4(\uC124\uBA85\uC11C \uCC38\uC870).\n -Xcheck:jni JNI \uD568\uC218\uC5D0 \uB300\uD55C \uCD94\uAC00 \uAC80\uC0AC\uB97C \uC218\uD589\uD569\uB2C8\uB2E4.\n -Xshare:off \uACF5\uC720 \uD074\uB798\uC2A4 \uB370\uC774\uD130 \uC0AC\uC6A9\uC744 \uC2DC\uB3C4\uD558\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4.\n -Xshare:auto \uAC00\uB2A5\uD55C \uACBD\uC6B0 \uACF5\uC720 \uD074\uB798\uC2A4 \uB370\uC774\uD130\uB97C \uC0AC\uC6A9\uD569\uB2C8\uB2E4(\uAE30\uBCF8\uAC12).\n -Xshare:on \uACF5\uC720 \uD074\uB798\uC2A4 \uB370\uC774\uD130\uB97C \uC0AC\uC6A9\uD574\uC57C \uD569\uB2C8\uB2E4. \uADF8\uB807\uC9C0 \uC54A\uC744 \uACBD\uC6B0 \uC2E4\uD328\uD569\uB2C8\uB2E4.\n -XshowSettings \uBAA8\uB4E0 \uC124\uC815\uC744 \uD45C\uC2DC\uD55C \uD6C4 \uACC4\uC18D\uD569\uB2C8\uB2E4.\n -XshowSettings:all\n \uBAA8\uB4E0 \uC124\uC815\uC744 \uD45C\uC2DC\uD55C \uD6C4 \uACC4\uC18D\uD569\uB2C8\uB2E4.\n -XshowSettings:vm \uBAA8\uB4E0 VM \uAD00\uB828 \uC124\uC815\uC744 \uD45C\uC2DC\uD55C \uD6C4 \uACC4\uC18D\uD569\uB2C8\uB2E4.\n -XshowSettings:properties\n \uBAA8\uB4E0 \uC18D\uC131 \uC124\uC815\uC744 \uD45C\uC2DC\uD55C \uD6C4 \uACC4\uC18D\uD569\uB2C8\uB2E4.\n -XshowSettings:locale\n \uBAA8\uB4E0 \uB85C\uCF00\uC77C \uAD00\uB828 \uC124\uC815\uC744 \uD45C\uC2DC\uD55C \uD6C4 \uACC4\uC18D\uD569\uB2C8\uB2E4.\n -XaddReads:=(,)*\n \uC740 \uBAA8\uB4C8 \uC120\uC5B8\uC5D0 \uAD00\uACC4\uC5C6\uC774\n \uB2E4\uB978 \uBAA8\uB4C8\uC744 \uC77D\uC2B5\uB2C8\uB2E4.\n -XaddExports:/=(,)*\n \uC740 \uBAA8\uB4C8 \uC120\uC5B8\uC5D0 \uAD00\uACC4\uC5C6\uC774\n \uB97C \uB2E4\uB978 \uBAA8\uB4C8\uB85C \uC775\uC2A4\uD3EC\uD2B8\uD569\uB2C8\uB2E4.\n -Xpatch:=({0})*\n JAR \uD30C\uC77C/\uB514\uB809\uD1A0\uB9AC\uC758 \uD074\uB798\uC2A4\uC640 \uB9AC\uC18C\uC2A4\uB85C\n \uBAA8\uB4C8\uC744 \ +\uBB34\uD6A8\uD654\uD558\uAC70\uB098 \uC778\uC218\uD654\uD569\uB2C8\uB2E4.\n -Xdisable-@files \uCD94\uAC00 \uC778\uC218 \uD30C\uC77C \uD655\uC7A5\uC744 \uC0AC\uC6A9 \uC548\uD568\uC73C\uB85C \uC124\uC815\uD569\uB2C8\uB2E4.\n\n-X \uC635\uC158\uC740 \uBE44\uD45C\uC900 \uC635\uC158\uC774\uBBC0\uB85C \uD1B5\uC9C0 \uC5C6\uC774 \uBCC0\uACBD\uB420 \uC218 \uC788\uC2B5\uB2C8\uB2E4.\n # Translators please note do not translate the options themselves java.launcher.X.macosx.usage=\n\uB2E4\uC74C\uC740 Mac OS X\uC5D0 \uD2B9\uC815\uB41C \uC635\uC158\uC785\uB2C8\uB2E4.\n -XstartOnFirstThread\n \uCCAB\uBC88\uC9F8 (AppKit) \uC2A4\uB808\uB4DC\uC5D0 main() \uBA54\uC18C\uB4DC\uB97C \uC2E4\uD589\uD569\uB2C8\uB2E4.\n -Xdock:name="\n \uACE0\uC815\uC73C\uB85C \uD45C\uC2DC\uB41C \uAE30\uBCF8 \uC560\uD50C\uB9AC\uCF00\uC774\uC158 \uC774\uB984\uC744 \uBB34\uD6A8\uD654\uD569\uB2C8\uB2E4.\n -Xdock:icon=\n \uACE0\uC815\uC73C\uB85C \uD45C\uC2DC\uB41C \uAE30\uBCF8 \uC544\uC774\uCF58\uC744 \uBB34\uD6A8\uD654\uD569\uB2C8\uB2E4.\n\n diff --git a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_pt_BR.properties b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_pt_BR.properties index 77edb358eac..9fde21b9479 100644 --- a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_pt_BR.properties +++ b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_pt_BR.properties @@ -24,7 +24,7 @@ # # Translators please note do not translate the options themselves -java.launcher.opt.header = Uso: {0} [options] class [args...]\n (para executar uma classe)\n ou {0} [options] -jar jarfile [args...]\n (para executar um arquivo jar)\n ou {0} [-options] -mp -m | /\n (para executar a classe principal em um m\u00F3dulo class in a module)\nem que as op\u00E7\u00F5es incluem:\n +java.launcher.opt.header = Uso: {0} [options] class [args...]\n (para executar uma classe)\n ou {0} [options] -jar jarfile [args...]\n (para executar um arquivo jar)\n ou {0} [options] -mp -m [/] [args...]\n (para executar a classe principal em um m\u00F3dulo)\nem que as op\u00E7\u00F5es incluem:\n java.launcher.opt.datamodel =\ -d{0}\t usar um modelo de dados de {0} bits, se estiver dispon\u00EDvel\n java.launcher.opt.vmselect =\ {0}\t para selecionar a VM "{1}"\n @@ -34,11 +34,11 @@ java.launcher.ergo.message1 =\ A VM padr\u00E3o \u00E9 {0} java.launcher.ergo.message2 =\ porque a execu\u00E7\u00E3o est\u00E1 sendo feita em uma m\u00E1quina de classe de servidor.\n # Translators please note do not translate the options themselves -java.launcher.opt.footer =\ -cp \n -classpath \n Uma lista separada por {0} de diret\u00F3rios, arquivos compactados JAR,\n e arquivos compactados ZIP para procurar arquivos de classe.\n -mp \n -modulepath ...\n Uma lista separada por {0} de diret\u00F3rios, cada um\n sendo um diret\u00F3rio de m\u00F3dulos.\n -upgrademodulepath ...\n Uma lista separada por {0} de diret\u00F3rios, cada um\n sendo um diret\u00F3rio de m\u00F3dulos que substituem m\u00F3dulos\n pass\u00EDveis de upgrade na imagem de runtime\n -m | /\n o m\u00F3dulo inicial ou principal a ser resolvido\n -addmods [,...]\n m\u00F3dulos raiz a serem resolvidos al\u00E9m do m\u00F3dulo inicial\n -limitmods [,...]\n limita o universo de m\u00F3dulos observ\u00E1veis\n -listmods[:[,...]]\n lista os m\u00F3dulos observ\u00E1veis e sai\n -D=\n define uma propriedade de sistema\n -verbose:[class|gc|jni]\n ativa sa\u00EDda detalhada\n -version imprime a vers\u00E3o do produto e sai\n -showversion imprime a vers\u00E3o do produto e continua\n -? -help imprime esta mensagem de ajuda\n -X imprime a ajuda em op\u00E7\u00F5es n\u00E3o padronizadas\n -ea[:...|:]\n -enableassertions[:...|:]\n ativa asser\u00E7\u00F5es com granularidade especificada\n -da[:...|:]\n -disableassertions[:...|:]\n desativa asser\u00E7\u00F5es com granularidade especificada\n -esa | -enablesystemassertions\n ativa asser\u00E7\u00F5es do sistema\n -dsa | -disablesystemassertions\n desativa asser\u00E7\u00F5es do sistema\n -agentlib:[=]\n carrega a biblioteca de agente nativo , por exemplo, -agentlib:jdwp\n consulte tamb\u00E9m -agentlib:jdwp=help\n -agentpath:[=]\n carrega a biblioteca de agente nativo por nome do caminho completo\n -javaagent:[=]\n carrega o agente de linguagem de programa\u00E7\u00E3o Java; consulte java.lang.instrument\n -splash:\n mostra a tela inicial com a imagem especificada\n @ op\u00E7\u00F5es de leitura do arquivo especificado\n +java.launcher.opt.footer =\ -cp \n -classpath \n Uma lista separada por {0} de diret\u00F3rios, arquivos compactados JAR\n e arquivos compactados ZIP para procurar arquivos de classe.\n -mp \n -modulepath ...\n Uma lista separada por {0} de diret\u00F3rios, cada um\n sendo um diret\u00F3rio de m\u00F3dulos.\n -upgrademodulepath ...\n Uma lista separada por {0} de diret\u00F3rios, cada um\n sendo um diret\u00F3rio de m\u00F3dulos que substituem m\u00F3dulos\n pass\u00EDveis de upgrade na imagem de runtime\n -m [/]\n o m\u00F3dulo inicial ou principal a ser resolvido e o nome da classe principal\n a ser executada se n\u00E3o for especificada pelo m\u00F3dulo\n -addmods [,...]\n m\u00F3dulos raiz a serem resolvidos al\u00E9m do m\u00F3dulo inicial\n -limitmods [,...]\n limita o universo de m\u00F3dulos observ\u00E1veis\n -listmods[:[,...]]\n lista os m\u00F3dulos observ\u00E1veis e sai\n -D=\n define uma propriedade de sistema\n -verbose:[class|gc|jni]\n ativa sa\u00EDda detalhada\n -version imprime a vers\u00E3o do produto e sai\n -showversion imprime a vers\u00E3o do produto e continua\n -? -help imprime esta mensagem de ajuda\n -X imprime a ajuda em op\u00E7\u00F5es n\u00E3o padronizadas\n -ea[:...|:]\n -enableassertions[:...|:]\n ativa asser\u00E7\u00F5es com granularidade especificada\n -da[:...|:]\n -disableassertions[:...|:]\n desativa asser\u00E7\u00F5es com granularidade especificada\n -esa | -enablesystemassertions\n ativa asser\u00E7\u00F5es do sistema\n -dsa | -disablesystemassertions\n desativa asser\u00E7\u00F5es do sistema\n -agentlib:[=]\n carrega a biblioteca de agente nativo , por exemplo, -agentlib:jdwp\n consulte tamb\u00E9m -agentlib:jdwp=help\n -agentpath:[=]\n carrega a biblioteca de agente nativo por nome do caminho completo\n -javaagent:[=]\n carrega o agente de linguagem de programa\u00E7\u00E3o Java; consulte java.lang.instrument\n -splash:\n mostra a tela inicial com a imagem especificada\n @ op\u00E7\u00F5es de leitura do arquivo especificado\n See http://www.oracle.com/technetwork/java/javase/documentation/index.html para obter mais detalhes. # Translators please note do not translate the options themselves -java.launcher.X.usage=\ -Xmixed execu\u00E7\u00E3o no modo misto (padr\u00E3o)\n -Xint execu\u00E7\u00E3o somente no modo interpretado\n -Xbootclasspath:\n anexos ao final do caminho de classe de inicializa\u00E7\u00E3o\n -Xdiag mostra mensagens de diagn\u00F3stico adicionais\n -Xdiag:resolver mostra mensagens de diagn\u00F3stico do resolvedor\n -Xnoclassgc desativa a coleta de lixo da classe\n -Xincgc ativa a coleta de lixo incremental\n -Xloggc: registra o status do GC status em um arquivo com marca\u00E7\u00F5es de data e hor\u00E1rio\n -Xbatch desativa a compila\u00E7\u00E3o em segundo plano\n -Xms define o tamanho inicial do heap Java\n -Xmx define o tamanho m\u00E1ximo do heap Java\n -Xss define o tamanho da pilha de threads java\n -Xprof produz dados de perfil da cpu\n -Xfuture ativa verifica\u00E7\u00F5es de n\u00EDvel m\u00E1ximo de exig\u00EAncia, prevendo o valor padr\u00E3o futuro\n -Xrs reduz o uso de sinais do SO pelo(a) Java/VM (consulte a documenta\u00E7\u00E3o)\n -Xcheck:jni executa verifica\u00E7\u00F5es adicionais de fun\u00E7\u00F5es da JNI\n -Xshare:off n\u00E3o tenta usar dados da classe compartilhada\n -Xshare:auto se poss\u00EDvel, usa dados da classe compartilhada (padr\u00E3o)\n -Xshare:on requer o uso de dados da classe compartilhada, caso contr\u00E1rio haver\u00E1 falha.\n -XshowSettings mostra todas as defini\u00E7\u00F5es e continua\n -XshowSettings:all\n mostra todas as defini\u00E7\u00F5es e continua\n -XshowSettings:vm mostra todas as defini\u00E7\u00F5es relacionadas \u00E0 vm e continua\n -XshowSettings:properties\n mostra todas as defini\u00E7\u00F5es da propriedade e continua\n -XshowSettings:locale\n mostra todas as defini\u00E7\u00F5es relativas \u00E0s configura\u00E7\u00F5es regionais e continua\n -XaddReads:=(,)*\n l\u00EA outros m\u00F3dulos,\n n\u00E3o importando a declara\u00E7\u00E3o do m\u00F3dulo\n -XaddExports:/=(,)*\n exports para outros m\u00F3dulos,\n n\u00E3o importando a declara\u00E7\u00E3o do m\u00F3dulo\n -Xpatch:=({0})*\n Substitui ou aumenta um m\u00F3dulo com classes e recursos\n em arquivos JAR ou diret\u00F3rios\n -Xdisable-@files desativa uma expans\u00E3o adicional de arquivo de argumentos\n\nAs op\u00E7\u00F5es -X n\u00E3o s\u00E3o padronizadas e est\u00E3o sujeitas a altera\u00E7\u00F5es sem aviso.\n +java.launcher.X.usage=\ -Xmixed execu\u00E7\u00E3o no modo misto (padr\u00E3o)\n -Xint execu\u00E7\u00E3o somente no modo interpretado\n -Xbootclasspath:\n anexos ao final do caminho de classe de inicializa\u00E7\u00E3o\n -Xdiag mostra mensagens de diagn\u00F3stico adicionais\n -Xdiag:resolver mostra mensagens de diagn\u00F3stico do resolvedor\n -Xnoclassgc desativa a coleta de lixo da classe\n -Xloggc: registra o status do GC status em um arquivo com marca\u00E7\u00F5es de data e hor\u00E1rio\n -Xbatch desativa a compila\u00E7\u00E3o em segundo plano\n -Xms define o tamanho inicial do heap Java\n -Xmx define o tamanho m\u00E1ximo do heap Java\n -Xss define o tamanho da pilha de threads java\n -Xprof produz dados de perfil da cpu\n -Xfuture ativa verifica\u00E7\u00F5es de n\u00EDvel m\u00E1ximo de exig\u00EAncia, prevendo o valor padr\u00E3o futuro\n -Xrs reduz o uso de sinais do SO pelo(a) Java/VM (consulte a documenta\u00E7\u00E3o)\n -Xcheck:jni executa verifica\u00E7\u00F5es adicionais de fun\u00E7\u00F5es da JNI\n -Xshare:off n\u00E3o tenta usar dados da classe compartilhada\n -Xshare:auto se poss\u00EDvel, usa dados da classe compartilhada (padr\u00E3o)\n -Xshare:on requer o uso de dados da classe compartilhada, caso contr\u00E1rio haver\u00E1 falha.\n -XshowSettings mostra todas as defini\u00E7\u00F5es e continua\n -XshowSettings:all\n mostra todas as defini\u00E7\u00F5es e continua\n -XshowSettings:vm mostra todas as defini\u00E7\u00F5es relacionadas \u00E0 vm e continua\n -XshowSettings:properties\n mostra todas as defini\u00E7\u00F5es da propriedade e continua\n -XshowSettings:locale\n mostra todas as defini\u00E7\u00F5es relativas \u00E0s configura\u00E7\u00F5es regionais e continua\n -XaddReads:=(,)*\n l\u00EA outros m\u00F3dulos,\n n\u00E3o importando a declara\u00E7\u00E3o do m\u00F3dulo\n -XaddExports:/=(,)*\n exporta para outros m\u00F3dulos,\n n\u00E3o importando a declara\u00E7\u00E3o do m\u00F3dulo\n -Xpatch:=({0})*\n Substitui ou aumenta um m\u00F3dulo com classes e recursos\n em arquivos JAR ou diret\u00F3rios\n -Xdisable-@files desativa uma expans\u00E3o adicional de arquivo de argumentos\n\nAs op\u00E7\u00F5es -X n\u00E3o s\u00E3o padronizadas e est\u00E3o sujeitas a altera\u00E7\u00F5es sem aviso.\n # Translators please note do not translate the options themselves java.launcher.X.macosx.usage=\nAs op\u00E7\u00F5es a seguir s\u00E3o espec\u00EDficas para o Mac OS X:\n -XstartOnFirstThread\n executa o m\u00E9todo main() no primeiro thread (AppKit)\n -Xdock:name="\n substitui o nome do aplicativo padr\u00E3o exibido no encaixe\n -Xdock:icon=\n substitui o \u00EDcone exibido no encaixe\n\n diff --git a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_sv.properties b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_sv.properties index 902f6604062..21a90e98c1f 100644 --- a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_sv.properties +++ b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_sv.properties @@ -24,7 +24,7 @@ # # Translators please note do not translate the options themselves -java.launcher.opt.header = Syntax: {0} [options] class [args...]\n (f\u00F6r att k\u00F6ra en klass)\n eller {0} [options] -jar jarfile [args...]\n (f\u00F6r att k\u00F6ra en jar-fil)\n eller {0} [-options] -mp -m | /\n (f\u00F6r att k\u00F6ra huvudklassen i en modul)\nmed alternativen:\n +java.launcher.opt.header = Syntax: {0} [options] class [args...]\n (f\u00F6r att k\u00F6ra en klass)\n eller {0} [options] -jar jarfile [args...]\n (f\u00F6r att k\u00F6ra en jar-fil)\n eller {0} [options] -mp -m [/] [args...]\n (f\u00F6r att k\u00F6ra huvudklassen i en modul)\nmed alternativen:\n java.launcher.opt.datamodel =\ -d{0}\t anv\u00E4nd en {0}-bitsdatamodell om det finns\n java.launcher.opt.vmselect =\ {0}\t f\u00F6r att v\u00E4lja "{1}" VM\n @@ -34,11 +34,11 @@ java.launcher.ergo.message1 =\ Standard-VM \u00E4r {0} java.launcher.ergo.message2 =\ eftersom du k\u00F6r en serverklassmaskin.\n # Translators please note do not translate the options themselves -java.launcher.opt.footer =\ -cp \n -classpath \n En {0}-avgr\u00E4nsad lista \u00F6ver kataloger, JAR-arkiv\n och ZIP-arkiv att s\u00F6ka efter klassfiler i.\n -mp \n -modulepath ...\n En {0}-avgr\u00E4nsad lista \u00F6ver kataloger, d\u00E4r varje\n katalog \u00E4r en katalog med moduler.\n -upgrademodulepath ...\n En {0}-avgr\u00E4nsad lista \u00F6ver kataloger, d\u00E4r varje\n katalog \u00E4r en katalog med moduler som ers\u00E4tter\n uppgraderingsbara moduler i exekveringsavbilden\n -m | /\n den ursprungliga modulen eller huvudmodulen att l\u00F6sa\n -addmods [,...]\n rotmoduler att l\u00F6sa f\u00F6rutom den ursprungliga modulen\n -limitmods [,...]\n begr\u00E4nsar universumet med observerbara moduler\n -listmods[:[,...]]\n lista observerbara moduler och avsluta\n -D=\n ange en systemegenskap\n -verbose:[class|gc|jni]\n aktivera utf\u00F6rliga utdata\n -version skriv ut produktversion och avsluta\n -showversion skriv ut produktversion och forts\u00E4tt\n -? -help skriv ut det h\u00E4r hj\u00E4lpmeddelandet\n -X skriv ut f\u00F6r icke-standardalternativ\n -ea[:...|:]\n -enableassertions[:...|:]\n aktivera verifieringar med den angivna detaljgraden\n -da[:...|:]\n -disableassertions[:...|:]\n avaktivera verifieringar med den angivna detaljgraden\n -esa | -enablesystemassertions\n aktivera systemverifieringar\n -dsa | -disablesystemassertions\n avaktivera systemverifieringar\n -agentlib:[=]\n ladda det ursprungliga agentbiblioteket , exempel: -agentlib:jdwp\n se \u00E4ven -agentlib:jdwp=help\n -agentpath:[=]\n ladda det ursprungliga agentbiblioteket med fullst\u00E4ndigt s\u00F6kv\u00E4gsnamn\n -javaagent:[=]\n ladda agenten f\u00F6r programmeringsspr\u00E5ket Java, se java.lang.instrument\n -splash:\n visa v\u00E4lkomstsk\u00E4rmen med den angivna bilden\n @ l\u00E4s alternativ fr\u00E5n den angivna filen\n +java.launcher.opt.footer =\ -cp \n -classpath \n En {0}-avgr\u00E4nsad lista \u00F6ver kataloger, JAR-arkiv\n och ZIP-arkiv att s\u00F6ka efter klassfiler i.\n -mp \n -modulepath ...\n En {0}-avgr\u00E4nsad lista \u00F6ver kataloger, d\u00E4r varje\n katalog \u00E4r en katalog med moduler.\n -upgrademodulepath ...\n En {0}-avgr\u00E4nsad lista \u00F6ver kataloger, d\u00E4r varje\n katalog \u00E4r en katalog med moduler som ers\u00E4tter\n uppgraderingsbara moduler i exekveringsavbilden\n -m [/]\n den ursprungliga modulen att k\u00F6ra, och namnet p\u00E5\n huvudklassen att k\u00F6ra om den inte anges av modulen\n -addmods [,...]\n rotmoduler att l\u00F6sa f\u00F6rutom den ursprungliga modulen\n -limitmods [,...]\n begr\u00E4nsar universumet med observerbara moduler\n -listmods[:[,...]]\n lista observerbara moduler och avsluta\n -D=\n ange en systemegenskap\n -verbose:[class|gc|jni]\n aktivera utf\u00F6rliga utdata\n -version skriv ut produktversion och avsluta\n -showversion skriv ut produktversion och forts\u00E4tt\n -? -help skriv ut det h\u00E4r hj\u00E4lpmeddelandet\n -X skriv ut hj\u00E4lp f\u00F6r icke-standardalternativ\n -ea[:...|:]\n -enableassertions[:...|:]\n aktivera verifieringar med den angivna detaljgraden\n -da[:...|:]\n -disableassertions[:...|:]\n avaktivera verifieringar med den angivna detaljgraden\n -esa | -enablesystemassertions\n aktivera systemverifieringar\n -dsa | -disablesystemassertions\n avaktivera systemverifieringar\n -agentlib:[=]\n ladda det ursprungliga agentbiblioteket , exempel: -agentlib:jdwp\n se \u00E4ven -agentlib:jdwp=help\n -agentpath:[=]\n ladda det ursprungliga agentbiblioteket med fullst\u00E4ndigt s\u00F6kv\u00E4gsnamn\n -javaagent:[=]\n ladda agenten f\u00F6r programmeringsspr\u00E5ket Java, se java.lang.instrument\n -splash:\n visa v\u00E4lkomstsk\u00E4rmen med den angivna bilden\n @ l\u00E4s alternativ fr\u00E5n den angivna filen\n See Se http://www.oracle.com/technetwork/java/javase/documentation/index.html f\u00F6r mer information. # Translators please note do not translate the options themselves -java.launcher.X.usage=\ -Xmixed exekvering i blandat l\u00E4ge (standard)\n -Xint endast exekvering i tolkat l\u00E4ge\n -Xbootclasspath/a:\n l\u00E4gg till sist i klass\u00F6kv\u00E4gen f\u00F6r programladdning\n -Xdiag visa fler diagnostiska meddelanden\n -Xdiag:resolver visa diagnostiska meddelanden f\u00F6r matchning\n -Xnoclassgc avaktivera klasskr\u00E4pinsamling\n -Xincgc aktivera inkrementell skr\u00E4pinsamling\n -Xloggc: logga GC-status till en fil med tidsst\u00E4mplar\n -Xbatch avaktivera bakgrundskompilering\n -Xms ange ursprunglig storlek f\u00F6r Java-heap-utrymmet\n -Xmx ange st\u00F6rsta storlek f\u00F6r Java-heap-utrymmet\n -Xss ange storlek f\u00F6r java-tr\u00E5dsstacken\n -Xprof utdata f\u00F6r processorprofilering\n -Xfuture aktivera str\u00E4ngaste kontroller, f\u00F6rv\u00E4ntad framtida standard\n -Xrs minska operativsystemssignalanv\u00E4ndning f\u00F6r Java/VM (se dokumentationen)\n -Xcheck:jni utf\u00F6r fler kontroller f\u00F6r JNI-funktioner\n -Xshare:off f\u00F6rs\u00F6k inte anv\u00E4nda delade klassdata\n -Xshare:auto anv\u00E4nd delade klassdata om m\u00F6jligt (standard)\n -Xshare:on kr\u00E4v anv\u00E4ndning av delade klassdata, utf\u00F6r inte i annat fall.\n -XshowSettings visa alla inst\u00E4llningar och forts\u00E4tt\n -XshowSettings:all\n visa alla inst\u00E4llningar och forts\u00E4tt\n -XshowSettings:vm visa alla vm-relaterade inst\u00E4llningar och forts\u00E4tt\n -XshowSettings:properties\n visa alla vm-relaterade inst\u00E4llningar och forts\u00E4tt\n -XshowSettings:locale\n visa alla spr\u00E5kkonventionsrelaterade inst\u00E4llningar och forts\u00E4tt\n -XaddReads:=(,)*\n l\u00E4ser andra moduler,\n oavsett moduldeklarationen\n -XaddExports:/=(,)*\n exporterar till andra moduler,\n oavsett moduldeklarationen\n -Xpatch:=({0})*\n \u00C5sidos\u00E4tt eller ut\u00F6ka en modul med klasser och resurser\n i JAR-filer eller kataloger\n -Xdisable-@files avaktivera framtida argumentfilsut\u00F6kning\n\n-X-alternativen \u00E4r inte standard och kan \u00E4ndras utan f\u00F6reg\u00E5ende meddelande.\n +java.launcher.X.usage=\ -Xmixed exekvering i blandat l\u00E4ge (standard)\n -Xint endast exekvering i tolkat l\u00E4ge\n -Xbootclasspath/a:\n l\u00E4gg till sist i klass\u00F6kv\u00E4gen f\u00F6r programladdning\n -Xdiag visa fler diagnostiska meddelanden\n -Xdiag:resolver visa diagnostiska meddelanden f\u00F6r matchning\n -Xnoclassgc avaktivera klasskr\u00E4pinsamling\n -Xloggc: logga GC-status till en fil med tidsst\u00E4mplar\n -Xbatch avaktivera bakgrundskompilering\n -Xms ange ursprunglig storlek f\u00F6r Java-heap-utrymmet\n -Xmx ange st\u00F6rsta storlek f\u00F6r Java-heap-utrymmet\n -Xss ange storlek f\u00F6r java-tr\u00E5dsstacken\n -Xprof utdata f\u00F6r processorprofilering\n -Xfuture aktivera str\u00E4ngaste kontroller, f\u00F6rv\u00E4ntad framtida standard\n -Xrs minska operativsystemssignalanv\u00E4ndning f\u00F6r Java/VM (se dokumentationen)\n -Xcheck:jni utf\u00F6r fler kontroller f\u00F6r JNI-funktioner\n -Xshare:off f\u00F6rs\u00F6k inte anv\u00E4nda delade klassdata\n -Xshare:auto anv\u00E4nd delade klassdata om m\u00F6jligt (standard)\n -Xshare:on kr\u00E4v anv\u00E4ndning av delade klassdata, utf\u00F6r inte i annat fall.\n -XshowSettings visa alla inst\u00E4llningar och forts\u00E4tt\n -XshowSettings:all\n visa alla inst\u00E4llningar och forts\u00E4tt\n -XshowSettings:vm visa alla vm-relaterade inst\u00E4llningar och forts\u00E4tt\n -XshowSettings:properties\n visa alla egenskapsinst\u00E4llningar och forts\u00E4tt\n -XshowSettings:locale\n visa alla spr\u00E5kkonventionsrelaterade inst\u00E4llningar och forts\u00E4tt\n -XaddReads:=(,)*\n l\u00E4ser andra moduler,\n oavsett moduldeklarationen\n -XaddExports:/=(,)*\n exporterar till andra moduler,\n oavsett moduldeklarationen\n -Xpatch:=({0})*\n \u00C5sidos\u00E4tt eller ut\u00F6ka en modul med klasser och resurser\n i JAR-filer eller kataloger\n -Xdisable-@files avaktivera framtida argumentfilsut\u00F6kning\n\n-X-alternativen \u00E4r inte standard och kan \u00E4ndras utan f\u00F6reg\u00E5ende meddelande.\n # Translators please note do not translate the options themselves java.launcher.X.macosx.usage=\nF\u00F6ljande alternativ \u00E4r specifika f\u00F6r Mac OS X:\n -XstartOnFirstThread\n k\u00F6r huvudmetoden() p\u00E5 den f\u00F6rsta (AppKit) tr\u00E5den\n -Xdock:name="\n \u00E5sidosatt standardapplikationsnamn visas i docka\n -Xdock:icon=\n \u00E5sidosatt standardikon visas i docka\n\n diff --git a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_zh_CN.properties b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_zh_CN.properties index 1296fe984af..c7c01655ea3 100644 --- a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_zh_CN.properties +++ b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_zh_CN.properties @@ -24,7 +24,7 @@ # # Translators please note do not translate the options themselves -java.launcher.opt.header = \u7528\u6CD5: {0} [options] class [args...]\n (\u6267\u884C\u7C7B)\n or {0} [options] -jar jarfile [args...]\n (\u6267\u884C jar \u6587\u4EF6)\n or {0} [-options] -mp -m | /\n (\u6267\u884C\u6A21\u5757\u4E2D\u7684\u4E3B\u7C7B)\n\u5176\u4E2D options \u5305\u62EC:\n +java.launcher.opt.header = \u7528\u6CD5: {0} [options] class [args...]\n (\u6267\u884C\u7C7B)\n \u6216 {0} [options] -jar jarfile [args...]\n (\u6267\u884C jar \u6587\u4EF6)\n \u6216 {0} [options] -mp <\u6A21\u5757\u8DEF\u5F84> -m <\u6A21\u5757\u540D\u79F0>[/<\u4E3B\u7C7B>] [args...]\n (\u6267\u884C\u6A21\u5757\u4E2D\u7684\u4E3B\u7C7B)\n\u5176\u4E2D\u9009\u9879\u5305\u62EC:\n java.launcher.opt.datamodel =\ -d{0}\t \u4F7F\u7528 {0} \u4F4D\u6570\u636E\u6A21\u578B (\u5982\u679C\u53EF\u7528)\n java.launcher.opt.vmselect =\ {0}\t \u9009\u62E9 "{1}" VM\n @@ -34,11 +34,11 @@ java.launcher.ergo.message1 =\ \u9ED8\u8BA4 VM \u662F {0} java.launcher.ergo.message2 =\ \u56E0\u4E3A\u60A8\u662F\u5728\u670D\u52A1\u5668\u7C7B\u8BA1\u7B97\u673A\u4E0A\u8FD0\u884C\u3002\n # Translators please note do not translate the options themselves -java.launcher.opt.footer =\ -cp <\u76EE\u5F55\u548C zip/jar \u6587\u4EF6\u7684\u7C7B\u641C\u7D22\u8DEF\u5F84>\n -classpath <\u76EE\u5F55\u548C zip/jar \u6587\u4EF6\u7684\u7C7B\u641C\u7D22\u8DEF\u5F84>\n \u7528\u4E8E\u641C\u7D22\u7C7B\u6587\u4EF6\u7684\u76EE\u5F55, JAR \u6863\u6848\n \u548C ZIP \u6863\u6848\u7684\u5217\u8868, \u4F7F\u7528 {0} \u5206\u9694\u3002\n -mp <\u6A21\u5757\u8DEF\u5F84>\n -modulepath <\u6A21\u5757\u8DEF\u5F84>...\n \u7528 {0} \u5206\u9694\u7684\u76EE\u5F55\u5217\u8868, \u6BCF\u4E2A\u76EE\u5F55\n \u90FD\u662F\u4E00\u4E2A\u5305\u542B\u6A21\u5757\u7684\u76EE\u5F55\u3002\n -upgrademodulepath ...\n \u7528 {0} \u5206\u9694\u7684\u76EE\u5F55\u5217\u8868, \u6BCF\u4E2A\u76EE\u5F55\n \u90FD\u662F\u4E00\u4E2A\u5305\u542B\u6A21\u5757\u7684\u76EE\u5F55, \u8FD9\u4E9B\u6A21\u5757\n \u7528\u4E8E\u66FF\u6362\u8FD0\u884C\u65F6\u6620\u50CF\u4E2D\u7684\u53EF\u5347\u7EA7\u6A21\u5757\n -m | /\n \u8981\u89E3\u6790\u7684\u521D\u59CB\u6A21\u5757\u6216\u4E3B\u6A21\u5757\n -addmods [,...]\n \u9664\u4E86\u521D\u59CB\u6A21\u5757\u4E4B\u5916\u8981\u89E3\u6790\u7684\u6839\u6A21\u5757\n -limitmods [,...]\n \u9650\u5236\u53EF\u89C2\u5BDF\u6A21\u5757\u7684\u9886\u57DF\n -listmods[:[,...]]\n \u5217\u51FA\u53EF\u89C2\u5BDF\u6A21\u5757\u5E76\u9000\u51FA\n -D=\n \u8BBE\u7F6E\u7CFB\u7EDF\u5C5E\u6027\n -verbose:[class|gc|jni]\n \u542F\u7528\u8BE6\u7EC6\u8F93\u51FA\n -version \u8F93\u51FA\u4EA7\u54C1\u7248\u672C\u5E76\u9000\u51FA\n -showversion \u8F93\u51FA\u4EA7\u54C1\u7248\u672C\u5E76\u7EE7\u7EED\n -? -help \u8F93\u51FA\u6B64\u5E2E\u52A9\u6D88\u606F\n -X \u8F93\u51FA\u975E\u6807\u51C6\u9009\u9879\u7684\u5E2E\u52A9\n -ea[:...|:]\n -enableassertions[:...|:]\n \u6309\u6307\u5B9A\u7684\u7C92\u5EA6\u542F\u7528\u65AD\u8A00\n -da[:...|:]\n -disableassertions[:...|:]\n \u7981\u7528\u5177\u6709\u6307\u5B9A\u7C92\u5EA6\u7684\u65AD\u8A00\n -esa | -enablesystemassertions\n \u542F\u7528\u7CFB\u7EDF\u65AD\u8A00\n -dsa | -disablesystemassertions\n \u7981\u7528\u7CFB\u7EDF\u65AD\u8A00\n -agentlib:[=]\n \u52A0\u8F7D\u672C\u673A\u4EE3\u7406\u5E93 , \u4F8B\u5982 -agentlib:jdwp\n \u53E6\u8BF7\u53C2\u9605 -agentlib:jdwp=help\n -agentpath:[=]\n \u6309\u5B8C\u6574\u8DEF\u5F84\u540D\u52A0\u8F7D\u672C\u673A\u4EE3\u7406\u5E93\n -javaagent:[=]\n \u52A0\u8F7D Java \u7F16\u7A0B\u8BED\u8A00\u4EE3\u7406, \u8BF7\u53C2\u9605 java.lang.instrument\n -splash:\n \u4F7F\u7528\u6307\u5B9A\u7684\u56FE\u50CF\u663E\u793A\u542F\u52A8\u5C4F\u5E55\n @ \u4ECE\u6307\u5B9A\u6587\u4EF6\u4E2D\u8BFB\u53D6\u9009\u9879\n +java.launcher.opt.footer =\ -cp <\u76EE\u5F55\u548C zip/jar \u6587\u4EF6\u7684\u7C7B\u641C\u7D22\u8DEF\u5F84>\n -classpath <\u76EE\u5F55\u548C zip/jar \u6587\u4EF6\u7684\u7C7B\u641C\u7D22\u8DEF\u5F84>\n \u7528\u4E8E\u641C\u7D22\u7C7B\u6587\u4EF6\u7684\u76EE\u5F55, JAR \u6863\u6848\n \u548C ZIP \u6863\u6848\u7684\u5217\u8868, \u4F7F\u7528 {0} \u5206\u9694\u3002\n -mp <\u6A21\u5757\u8DEF\u5F84>\n -modulepath <\u6A21\u5757\u8DEF\u5F84>...\n \u7528 {0} \u5206\u9694\u7684\u76EE\u5F55\u5217\u8868, \u6BCF\u4E2A\u76EE\u5F55\n \u90FD\u662F\u4E00\u4E2A\u5305\u542B\u6A21\u5757\u7684\u76EE\u5F55\u3002\n -upgrademodulepath <\u6A21\u5757\u8DEF\u5F84>...\n \u7528 {0} \u5206\u9694\u7684\u76EE\u5F55\u5217\u8868, \u6BCF\u4E2A\u76EE\u5F55\n \u90FD\u662F\u4E00\u4E2A\u5305\u542B\u6A21\u5757\u7684\u76EE\u5F55, \u8FD9\u4E9B\u6A21\u5757\n \u7528\u4E8E\u66FF\u6362\u8FD0\u884C\u65F6\u6620\u50CF\u4E2D\u7684\u53EF\u5347\u7EA7\u6A21\u5757\n -m <\u6A21\u5757\u540D\u79F0>[/<\u4E3B\u7C7B>]\n \u8981\u89E3\u6790\u7684\u521D\u59CB\u6A21\u5757, \u4EE5\u53CA\u5728\u672A\u7531\u6A21\u5757\u6307\u5B9A\u65F6\n \u8981\u6267\u884C\u7684\u4E3B\u7C7B\u540D\u79F0\n -addmods <\u6A21\u5757\u540D\u79F0>[,<\u6A21\u5757\u540D\u79F0>...]\n \u9664\u4E86\u521D\u59CB\u6A21\u5757\u4E4B\u5916\u8981\u89E3\u6790\u7684\u6839\u6A21\u5757\n -limitmods <\u6A21\u5757\u540D\u79F0>[,<\u6A21\u5757\u540D\u79F0>...]\n \u9650\u5236\u53EF\u89C2\u5BDF\u6A21\u5757\u7684\u9886\u57DF\n -listmods[:<\u6A21\u5757\u540D\u79F0>[,<\u6A21\u5757\u540D\u79F0>...]]\n \u5217\u51FA\u53EF\u89C2\u5BDF\u6A21\u5757\u5E76\u9000\u51FA\n -D<\u540D\u79F0>=<\u503C>\n \u8BBE\u7F6E\u7CFB\u7EDF\u5C5E\u6027\n -verbose:[class|gc|jni]\n \u542F\u7528\u8BE6\u7EC6\u8F93\u51FA\n -version \u8F93\u51FA\u4EA7\u54C1\u7248\u672C\u5E76\u9000\u51FA\n -showversion \u8F93\u51FA\u4EA7\u54C1\u7248\u672C\u5E76\u7EE7\u7EED\n -? -help \u8F93\u51FA\u6B64\u5E2E\u52A9\u6D88\u606F\n -X \u8F93\u51FA\u975E\u6807\u51C6\u9009\u9879\u7684\u5E2E\u52A9\n -ea[:<\u7A0B\u5E8F\u5305\u540D\u79F0>...|:<\u7C7B\u540D>]\n -enableassertions[:<\u7A0B\u5E8F\u5305\u540D\u79F0>...|:<\u7C7B\u540D>]\n \u6309\u6307\u5B9A\u7684\u7C92\u5EA6\u542F\u7528\u65AD\u8A00\n -da[:<\u7A0B\u5E8F\u5305\u540D\u79F0>...|:<\u7A0B\u5E8F\u5305\u540D\u79F0>]\n -disableassertions[:<\u7A0B\u5E8F\u5305\u540D\u79F0>...|:<\u7C7B\u540D>]\n \u7981\u7528\u5177\u6709\u6307\u5B9A\u7C92\u5EA6\u7684\u65AD\u8A00\n -esa | -enablesystemassertions\n \u542F\u7528\u7CFB\u7EDF\u65AD\u8A00\n -dsa | -disablesystemassertions\n \u7981\u7528\u7CFB\u7EDF\u65AD\u8A00\n -agentlib:<\u5E93\u540D>[=<\u9009\u9879>]\n \u52A0\u8F7D\u672C\u673A\u4EE3\u7406\u5E93 <\u5E93\u540D>, \u4F8B\u5982 -agentlib:jdwp\n \u53E6\u8BF7\u53C2\u9605 -agentlib:jdwp=help\n -agentpath:<\u8DEF\u5F84\u540D>[=<\u9009\u9879>]\n \u6309\u5B8C\u6574\u8DEF\u5F84\u540D\u52A0\u8F7D\u672C\u673A\u4EE3\u7406\u5E93\n -javaagent:[=<\u9009\u9879>]\n \u52A0\u8F7D Java \u7F16\u7A0B\u8BED\u8A00\u4EE3\u7406, \u8BF7\u53C2\u9605 java.lang.instrument\n -splash:<\u56FE\u50CF\u8DEF\u5F84>\n \u4F7F\u7528\u6307\u5B9A\u7684\u56FE\u50CF\u663E\u793A\u542F\u52A8\u5C4F\u5E55\n @<\u6587\u4EF6\u8DEF\u5F84> \u4ECE\u6307\u5B9A\u6587\u4EF6\u4E2D\u8BFB\u53D6\u9009\u9879\n See \u6709\u5173\u8BE6\u7EC6\u4FE1\u606F, \u8BF7\u53C2\u9605 http://www.oracle.com/technetwork/java/javase/documentation/index.html\u3002 # Translators please note do not translate the options themselves -java.launcher.X.usage=\ -Xmixed \u6DF7\u5408\u6A21\u5F0F\u6267\u884C (\u9ED8\u8BA4\u503C)\n -Xint \u4EC5\u89E3\u91CA\u6A21\u5F0F\u6267\u884C\n -Xbootclasspath/a:<\u7528 {0} \u5206\u9694\u7684\u76EE\u5F55\u548C zip/jar \u6587\u4EF6>\n \u9644\u52A0\u5728\u5F15\u5BFC\u7C7B\u8DEF\u5F84\u672B\u5C3E\n -Xdiag \u663E\u793A\u9644\u52A0\u8BCA\u65AD\u6D88\u606F\n -Xdiag:resolver \u663E\u793A\u89E3\u6790\u5668\u8BCA\u65AD\u6D88\u606F\n -Xnoclassgc \u7981\u7528\u7C7B\u5783\u573E\u6536\u96C6\n -Xincgc \u542F\u7528\u589E\u91CF\u5783\u573E\u6536\u96C6\n -Xloggc: \u5C06 GC \u72B6\u6001\u8BB0\u5F55\u5728\u6587\u4EF6\u4E2D (\u5E26\u65F6\u95F4\u6233)\n -Xbatch \u7981\u7528\u540E\u53F0\u7F16\u8BD1\n -Xms \u8BBE\u7F6E\u521D\u59CB Java \u5806\u5927\u5C0F\n -Xmx \u8BBE\u7F6E\u6700\u5927 Java \u5806\u5927\u5C0F\n -Xss \u8BBE\u7F6E Java \u7EBF\u7A0B\u5806\u6808\u5927\u5C0F\n -Xprof \u8F93\u51FA cpu \u5206\u6790\u6570\u636E\n -Xfuture \u542F\u7528\u6700\u4E25\u683C\u7684\u68C0\u67E5, \u9884\u671F\u5C06\u6765\u7684\u9ED8\u8BA4\u503C\n -Xrs \u51CF\u5C11 Java/VM \u5BF9\u64CD\u4F5C\u7CFB\u7EDF\u4FE1\u53F7\u7684\u4F7F\u7528 (\u8BF7\u53C2\u9605\u6587\u6863)\n -Xcheck:jni \u5BF9 JNI \u51FD\u6570\u6267\u884C\u5176\u4ED6\u68C0\u67E5\n -Xshare:off \u4E0D\u5C1D\u8BD5\u4F7F\u7528\u5171\u4EAB\u7C7B\u6570\u636E\n -Xshare:auto \u5728\u53EF\u80FD\u7684\u60C5\u51B5\u4E0B\u4F7F\u7528\u5171\u4EAB\u7C7B\u6570\u636E (\u9ED8\u8BA4\u503C)\n -Xshare:on \u8981\u6C42\u4F7F\u7528\u5171\u4EAB\u7C7B\u6570\u636E, \u5426\u5219\u5C06\u5931\u8D25\u3002\n -XshowSettings \u663E\u793A\u6240\u6709\u8BBE\u7F6E\u5E76\u7EE7\u7EED\n -XshowSettings:all\n \u663E\u793A\u6240\u6709\u8BBE\u7F6E\u5E76\u7EE7\u7EED\n -XshowSettings:vm \u663E\u793A\u6240\u6709\u4E0E vm \u76F8\u5173\u7684\u8BBE\u7F6E\u5E76\u7EE7\u7EED\n -XshowSettings:properties\n \u663E\u793A\u6240\u6709\u5C5E\u6027\u8BBE\u7F6E\u5E76\u7EE7\u7EED\n -XshowSettings:locale\n \u663E\u793A\u6240\u6709\u4E0E\u533A\u57DF\u8BBE\u7F6E\u76F8\u5173\u7684\u8BBE\u7F6E\u5E76\u7EE7\u7EED\n -XaddReads:=(,)*\n \u8BFB\u53D6\u5176\u4ED6\u6A21\u5757,\n \u800C\u65E0\u8BBA\u6A21\u5757\u58F0\u660E\u5982\u4F55\n -XaddExports:/=(,)*\n \u5C06 \u5BFC\u51FA\u5230\u5176\u4ED6\u6A21\u5757,\n \u800C\u65E0\u8BBA\u6A21\u5757\u58F0\u660E\u5982\u4F55\n -Xpatch:=({0})*\n \u4F7F\u7528 JAR \u6587\u4EF6\u6216\u76EE\u5F55\u4E2D\u7684\u7C7B\u548C\u8D44\u6E90\n \u8986\u76D6\u6216\u589E\u5F3A\u6A21\u5757\n -Xdisable-@files \u7981\u6B62\u8FDB\u4E00\u6B65\u6269\u5C55\u53C2\u6570\u6587\u4EF6\n\n-X \u9009\u9879\u662F\u975E\u6807\u51C6\u9009\u9879, \u5982\u6709\u66F4\u6539, \u6055\u4E0D\u53E6\u884C\u901A\u77E5\u3002\n +java.launcher.X.usage=\ -Xmixed \u6DF7\u5408\u6A21\u5F0F\u6267\u884C (\u9ED8\u8BA4\u503C)\n -Xint \u4EC5\u89E3\u91CA\u6A21\u5F0F\u6267\u884C\n -Xbootclasspath/a:<\u7528 {0} \u5206\u9694\u7684\u76EE\u5F55\u548C zip/jar \u6587\u4EF6>\n \u9644\u52A0\u5728\u5F15\u5BFC\u7C7B\u8DEF\u5F84\u672B\u5C3E\n -Xdiag \u663E\u793A\u9644\u52A0\u8BCA\u65AD\u6D88\u606F\n -Xdiag:resolver \u663E\u793A\u89E3\u6790\u5668\u8BCA\u65AD\u6D88\u606F\n -Xnoclassgc \u7981\u7528\u7C7B\u5783\u573E\u6536\u96C6\n -Xloggc:<\u6587\u4EF6> \u5C06 GC \u72B6\u6001\u8BB0\u5F55\u5728\u6587\u4EF6\u4E2D (\u5E26\u65F6\u95F4\u6233)\n -Xbatch \u7981\u7528\u540E\u53F0\u7F16\u8BD1\n -Xms<\u5927\u5C0F> \u8BBE\u7F6E\u521D\u59CB Java \u5806\u5927\u5C0F\n -Xmx<\u5927\u5C0F> \u8BBE\u7F6E\u6700\u5927 Java \u5806\u5927\u5C0F\n -Xss<\u5927\u5C0F> \u8BBE\u7F6E Java \u7EBF\u7A0B\u5806\u6808\u5927\u5C0F\n -Xprof \u8F93\u51FA cpu \u5206\u6790\u6570\u636E\n -Xfuture \u542F\u7528\u6700\u4E25\u683C\u7684\u68C0\u67E5, \u9884\u671F\u5C06\u6765\u7684\u9ED8\u8BA4\u503C\n -Xrs \u51CF\u5C11 Java/VM \u5BF9\u64CD\u4F5C\u7CFB\u7EDF\u4FE1\u53F7\u7684\u4F7F\u7528 (\u8BF7\u53C2\u9605\u6587\u6863)\n -Xcheck:jni \u5BF9 JNI \u51FD\u6570\u6267\u884C\u5176\u4ED6\u68C0\u67E5\n -Xshare:off \u4E0D\u5C1D\u8BD5\u4F7F\u7528\u5171\u4EAB\u7C7B\u6570\u636E\n -Xshare:auto \u5728\u53EF\u80FD\u7684\u60C5\u51B5\u4E0B\u4F7F\u7528\u5171\u4EAB\u7C7B\u6570\u636E (\u9ED8\u8BA4\u503C)\n -Xshare:on \u8981\u6C42\u4F7F\u7528\u5171\u4EAB\u7C7B\u6570\u636E, \u5426\u5219\u5C06\u5931\u8D25\u3002\n -XshowSettings \u663E\u793A\u6240\u6709\u8BBE\u7F6E\u5E76\u7EE7\u7EED\n -XshowSettings:all\n \u663E\u793A\u6240\u6709\u8BBE\u7F6E\u5E76\u7EE7\u7EED\n -XshowSettings:vm \u663E\u793A\u6240\u6709\u4E0E vm \u76F8\u5173\u7684\u8BBE\u7F6E\u5E76\u7EE7\u7EED\n -XshowSettings:properties\n \u663E\u793A\u6240\u6709\u5C5E\u6027\u8BBE\u7F6E\u5E76\u7EE7\u7EED\n -XshowSettings:locale\n \u663E\u793A\u6240\u6709\u4E0E\u533A\u57DF\u8BBE\u7F6E\u76F8\u5173\u7684\u8BBE\u7F6E\u5E76\u7EE7\u7EED\n -XaddReads:<\u6A21\u5757>=<\u5176\u4ED6\u6A21\u5757>(,<\u5176\u4ED6\u6A21\u5757>)*\n <\u6A21\u5757> \u8BFB\u53D6\u5176\u4ED6\u6A21\u5757,\n \u800C\u65E0\u8BBA\u6A21\u5757\u58F0\u660E\u5982\u4F55\n -XaddExports:<\u6A21\u5757>/<\u7A0B\u5E8F\u5305>=<\u5176\u4ED6\u6A21\u5757>(,<\u5176\u4ED6\u6A21\u5757>)*\n <\u6A21\u5757> \u5C06 <\u7A0B\u5E8F\u5305> \u5BFC\u51FA\u5230\u5176\u4ED6\u6A21\u5757,\n \u800C\u65E0\u8BBA\u6A21\u5757\u58F0\u660E\u5982\u4F55\n -Xpatch:<\u6A21\u5757>=<\u6587\u4EF6>({0}<\u6587\u4EF6>)*\n \u4F7F\u7528 JAR \u6587\u4EF6\u6216\u76EE\u5F55\u4E2D\u7684\u7C7B\u548C\u8D44\u6E90\n \u8986\u76D6\u6216\u589E\u5F3A\u6A21\u5757\n -Xdisable-@files \u7981\u6B62\u8FDB\u4E00\u6B65\u6269\u5C55\u53C2\u6570\u6587\u4EF6\n\n-X \u9009\u9879\u662F\u975E\u6807\u51C6\u9009\u9879, \u5982\u6709\u66F4\u6539, \u6055\u4E0D\u53E6\u884C\u901A\u77E5\u3002\n # Translators please note do not translate the options themselves java.launcher.X.macosx.usage=\n\u4EE5\u4E0B\u9009\u9879\u4E3A Mac OS X \u7279\u5B9A\u7684\u9009\u9879:\n -XstartOnFirstThread\n \u5728\u7B2C\u4E00\u4E2A (AppKit) \u7EBF\u7A0B\u4E0A\u8FD0\u884C main() \u65B9\u6CD5\n -Xdock:name=<\u5E94\u7528\u7A0B\u5E8F\u540D\u79F0>"\n \u8986\u76D6\u505C\u9760\u680F\u4E2D\u663E\u793A\u7684\u9ED8\u8BA4\u5E94\u7528\u7A0B\u5E8F\u540D\u79F0\n -Xdock:icon=<\u56FE\u6807\u6587\u4EF6\u7684\u8DEF\u5F84>\n \u8986\u76D6\u505C\u9760\u680F\u4E2D\u663E\u793A\u7684\u9ED8\u8BA4\u56FE\u6807\n\n diff --git a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_zh_TW.properties b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_zh_TW.properties index 122419b0df4..f6e359fb844 100644 --- a/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_zh_TW.properties +++ b/jdk/src/java.base/share/classes/sun/launcher/resources/launcher_zh_TW.properties @@ -24,7 +24,7 @@ # # Translators please note do not translate the options themselves -java.launcher.opt.header = \u7528\u6CD5: {0} [options] class [args...]\n (\u7528\u65BC\u57F7\u884C\u985E\u5225)\n \u6216 {0} [options] -jar jarfile [args...]\n (\u7528\u65BC\u57F7\u884C jar \u6A94\u6848)\n \u6216 {0} [-options] -mp -m | /\n (\u7528\u65BC\u57F7\u884C\u6A21\u7D44\u4E2D\u7684\u4E3B\u8981\u985E\u5225)\n\u5176\u4E2D\u7684\u9078\u9805\u5305\u62EC:\n +java.launcher.opt.header = \u7528\u6CD5: {0} [options] class [args...]\n (\u7528\u65BC\u57F7\u884C\u985E\u5225)\n \u6216 {0} [options] -jar jarfile [args...]\n (\u7528\u65BC\u57F7\u884C jar \u6A94\u6848)\n \u6216 {0} [options] -mp -m [/] [args...]\n (\u7528\u65BC\u57F7\u884C\u6A21\u7D44\u4E2D\u7684\u4E3B\u8981\u985E\u5225)\n\u5176\u4E2D\u7684\u9078\u9805\u5305\u62EC:\n java.launcher.opt.datamodel =\ -d{0}\t \u4F7F\u7528 {0} \u4F4D\u5143\u8CC7\u6599\u6A21\u578B (\u5982\u679C\u6709\u7684\u8A71)\n java.launcher.opt.vmselect =\ {0}\t \u9078\u53D6 "{1}" VM\n @@ -34,11 +34,11 @@ java.launcher.ergo.message1 =\ \u9810\u8A2D\u7684 VM \u70BA {0 java.launcher.ergo.message2 =\ \u56E0\u70BA\u60A8\u6B63\u5728\u4F3A\u670D\u5668\u985E\u5225\u6A5F\u5668\u4E0A\u57F7\u884C\u3002\n # Translators please note do not translate the options themselves -java.launcher.opt.footer =\ -cp \n -classpath \n \u4F7F\u7528\u4EE5 {0} \u5340\u9694\u7684\u76EE\u9304\u3001JAR \u5B58\u6A94\u4EE5\u53CA\n ZIP \u5B58\u6A94\u6E05\u55AE\u4F86\u641C\u5C0B\u985E\u5225\u6A94\u6848\u3002\n -mp \n -modulepath ...\n \u4EE5 {0} \u5340\u9694\u7684\u76EE\u9304\u6E05\u55AE\uFF0C\u6BCF\u500B\u76EE\u9304\n \u5747\u70BA\u6A21\u7D44\u76EE\u9304\u3002\n -upgrademodulepath ...\n \u4EE5 {0} \u5340\u9694\u7684\u76EE\u9304\u6E05\u55AE\uFF0C\u6BCF\u500B\u76EE\u9304\n \u5747\u70BA\u6A21\u7D44\u76EE\u9304\uFF0C\u4E14\u7576\u4E2D\u7684\u6A21\u7D44\u53EF\u53D6\u4EE3\n \u7A0B\u5F0F\u5BE6\u969B\u57F7\u884C\u5F71\u50CF\u4E2D\u7684\u53EF\u5347\u7D1A\u6A21\u7D44\n -m | /\n \u8981\u89E3\u6790\u7684\u8D77\u59CB\u6216\u4E3B\u8981\u6A21\u7D44\n -addmods [,...]\n \u9664\u4E86\u8D77\u59CB\u6A21\u7D44\u5916\uFF0C\u8981\u89E3\u6790\u7684\u6839\u6A21\u7D44\n -limitmods [,...]\n \u9650\u5236\u53EF\u76E3\u6E2C\u6A21\u7D44\u7684\u7BC4\u570D\n -listmods[:[,...]]\n \u5217\u51FA\u53EF\u76E3\u6E2C\u6A21\u7D44\u4E26\u7D50\u675F\n -D=\n \u8A2D\u5B9A\u7CFB\u7D71\u5C6C\u6027\n -verbose:[class|gc|jni]\n \u555F\u7528\u8A73\u7D30\u8CC7\u8A0A\u8F38\u51FA\n -version \u5217\u5370\u7522\u54C1\u7248\u672C\u4E26\u7D50\u675F\n -showversion \u5217\u5370\u7522\u54C1\u7248\u672C\u4E26\u7E7C\u7E8C\n -? -help \u5217\u5370\u6B64\u8AAA\u660E\u8A0A\u606F\n -X \u5217\u5370\u975E\u6A19\u6E96\u9078\u9805\u7684\u8AAA\u660E\n -ea[:...|:]\n -enableassertions[:...|:]\n \u555F\u7528\u542B\u6307\u5B9A\u8A73\u7D30\u7A0B\u5EA6\u7684\u5BA3\u544A\n -da[:...|:]\n -disableassertions[:...|:]\n \u505C\u7528\u542B\u6307\u5B9A\u8A73\u7D30\u7A0B\u5EA6\u7684\u5BA3\u544A\n -esa | -enablesystemassertions\n \u555F\u7528\u7CFB\u7D71\u5BA3\u544A\n -dsa | -disablesystemassertions\n \u505C\u7528\u7CFB\u7D71\u5BA3\u544A\n -agentlib:[=]\n \u8F09\u5165\u539F\u751F\u4EE3\u7406\u7A0B\u5F0F\u7A0B\u5F0F\u5EAB \uFF0C\u4F8B\u5982 -agentlib:jdwp\n \u53E6\u8ACB\u53C3\u95B1 -agentlib:jdwp=help\n -agentpath:[=]\n \u4F7F\u7528\u5B8C\u6574\u8DEF\u5F91\u540D\u7A31\u8F09\u5165\u539F\u751F\u4EE3\u7406\u7A0B\u5F0F\u7A0B\u5F0F\u5EAB\n -javaagent:[=]\n \u8F09\u5165 Java \u7A0B\u5F0F\u8A9E\u8A00\u4EE3\u7406\u7A0B\u5F0F\uFF0C\u8ACB\u53C3\u95B1 java.lang.instrument\n -splash:\n \u4EE5\u6307\u5B9A\u5F71\u50CF\u986F\u793A\u8EDF\u9AD4\u8CC7\u8A0A\u756B\u9762\n @ \u5F9E\u6307\u5B9A\u6A94\u6848\u8B80\u53D6\u9078\u9805\n +java.launcher.opt.footer =\ -cp \n -classpath \n \u7528\u4F86\u641C\u5C0B\u985E\u5225\u6A94\u6848\u4E4B\u4EE5 {0} \u5340\u9694\u7684\u76EE\u9304\u3001\n JAR \u5B58\u6A94\u4EE5\u53CA ZIP \u5B58\u6A94\u6E05\u55AE\u3002\n -mp \n -modulepath ...\n \u4EE5 {0} \u5340\u9694\u7684\u76EE\u9304\u6E05\u55AE\uFF0C\u6BCF\u500B\u76EE\u9304\n \u5747\u70BA\u6A21\u7D44\u76EE\u9304\u3002\n -upgrademodulepath ...\n \u4EE5 {0} \u5340\u9694\u7684\u76EE\u9304\u6E05\u55AE\uFF0C\u6BCF\u500B\u76EE\u9304\n \u5747\u70BA\u6A21\u7D44\u76EE\u9304\uFF0C\u4E14\u7576\u4E2D\u7684\u6A21\u7D44\u53EF\u53D6\u4EE3\n \u7A0B\u5F0F\u5BE6\u969B\u57F7\u884C\u5F71\u50CF\u4E2D\u7684\u53EF\u5347\u7D1A\u6A21\u7D44\n -m [/]\n \u8981\u89E3\u6790\u7684\u8D77\u59CB\u6A21\u7D44, \u4EE5\u53CA\u6A21\u7D44\u672A\u6307\u5B9A\u6642\n \u6240\u8981\u57F7\u884C\u7684\u4E3B\u8981\u985E\u5225\u540D\u7A31\n -addmods [,...]\n \u9664\u4E86\u8D77\u59CB\u6A21\u7D44\u5916\uFF0C\u8981\u89E3\u6790\u7684\u6839\u6A21\u7D44\n -limitmods [,...]\n \u9650\u5236\u53EF\u76E3\u6E2C\u6A21\u7D44\u7684\u7BC4\u570D\n -listmods[:[,...]]\n \u5217\u51FA\u53EF\u76E3\u6E2C\u6A21\u7D44\u4E26\u7D50\u675F\n -D=\n \u8A2D\u5B9A\u7CFB\u7D71\u5C6C\u6027\n -verbose:[class|gc|jni]\n \u555F\u7528\u8A73\u7D30\u8CC7\u8A0A\u8F38\u51FA\n -version \u5217\u5370\u7522\u54C1\u7248\u672C\u4E26\u7D50\u675F\n -showversion \u5217\u5370\u7522\u54C1\u7248\u672C\u4E26\u7E7C\u7E8C\n -? -help \u5217\u5370\u6B64\u8AAA\u660E\u8A0A\u606F\n -X \u5217\u5370\u975E\u6A19\u6E96\u9078\u9805\u7684\u8AAA\u660E\n -ea[:...|:]\n -enableassertions[:...|:]\n \u555F\u7528\u542B\u6307\u5B9A\u8A73\u7D30\u7A0B\u5EA6\u7684\u5BA3\u544A\n -da[:...|:]\n -disableassertions[:...|:]\n \u505C\u7528\u542B\u6307\u5B9A\u8A73\u7D30\u7A0B\u5EA6\u7684\u5BA3\u544A\n -esa | -enablesystemassertions\n \u555F\u7528\u7CFB\u7D71\u5BA3\u544A\n -dsa | -disablesystemassertions\n \u505C\u7528\u7CFB\u7D71\u5BA3\u544A\n -agentlib:[=]\n \u8F09\u5165\u539F\u751F\u4EE3\u7406\u7A0B\u5F0F\u7A0B\u5F0F\u5EAB \uFF0C\u4F8B\u5982 -agentlib:jdwp\n \u53E6\u8ACB\u53C3\u95B1 -agentlib:jdwp=help\n -agentpath:[=]\n \u4F7F\u7528\u5B8C\u6574\u8DEF\u5F91\u540D\u7A31\u8F09\u5165\u539F\u751F\u4EE3\u7406\u7A0B\u5F0F\u7A0B\u5F0F\u5EAB\n -javaagent:[=]\n \u8F09\u5165 Java \u7A0B\u5F0F\u8A9E\u8A00\u4EE3\u7406\u7A0B\u5F0F\uFF0C\u8ACB\u53C3\u95B1 java.lang.instrument\n -splash:\n \u4EE5\u6307\u5B9A\u5F71\u50CF\u986F\u793A\u8EDF\u9AD4\u8CC7\u8A0A\u756B\u9762\n @ \u5F9E\u6307\u5B9A\u6A94\u6848\u8B80\u53D6\u9078\u9805\n See \u8ACB\u53C3\u95B1 http://www.oracle.com/technetwork/java/javase/documentation/index.html \u66B8\u89E3\u8A73\u7D30\u8CC7\u8A0A\u3002 # Translators please note do not translate the options themselves -java.launcher.X.usage=\ -Xmixed \u6DF7\u5408\u6A21\u5F0F\u57F7\u884C (\u9810\u8A2D)\n -Xint \u50C5\u9650\u89E3\u8B6F\u6A21\u5F0F\u57F7\u884C\n -Xbootclasspath/a:<\u4EE5 {0} \u5206\u9694\u7684\u76EE\u9304\u548C zip/jar \u6A94\u6848>\n \u9644\u52A0\u5728\u555F\u52D5\u5B89\u88DD\u985E\u5225\u8DEF\u5F91\u7684\u7D50\u5C3E\n -Xdiag \u986F\u793A\u5176\u4ED6\u7684\u8A3A\u65B7\u8A0A\u606F\n -Xdiag:resolver \u986F\u793A\u89E3\u6790\u5668\u8A3A\u65B7\u8A0A\u606F\n -Xnoclassgc \u505C\u7528\u985E\u5225\u8CC7\u6E90\u56DE\u6536\n -Xincgc \u555F\u7528\u6F38\u9032\u8CC7\u6E90\u56DE\u6536\n -Xloggc: \u5C07 GC \u72C0\u614B\u548C\u6642\u6233\u8A18\u9304\u81F3\u6A94\u6848\n -Xbatch \u505C\u7528\u80CC\u666F\u7DE8\u8B6F\n -Xms \u8A2D\u5B9A\u8D77\u59CB Java \u5806\u96C6\u5927\u5C0F\n -Xmx \u8A2D\u5B9A Java \u5806\u96C6\u5927\u5C0F\u4E0A\u9650\n -Xss \u8A2D\u5B9A Java \u57F7\u884C\u7DD2\u5806\u758A\u5927\u5C0F\n -Xprof \u8F38\u51FA CPU \u5206\u6790\u8CC7\u6599\n -Xfuture \u555F\u7528\u6700\u56B4\u683C\u7684\u6AA2\u67E5\uFF0C\u9810\u5148\u4F5C\u70BA\u5C07\u4F86\u7684\u9810\u8A2D\n -Xrs \u6E1B\u5C11 Java/VM \u4F7F\u7528\u4F5C\u696D\u7CFB\u7D71\u4FE1\u865F (\u8ACB\u53C3\u95B1\u6587\u4EF6)\n -Xcheck:jni \u57F7\u884C\u5176\u4ED6\u7684 JNI \u51FD\u6578\u6AA2\u67E5\n -Xshare:off \u4E0D\u5617\u8A66\u4F7F\u7528\u5171\u7528\u985E\u5225\u8CC7\u6599\n -Xshare:auto \u5118\u53EF\u80FD\u4F7F\u7528\u5171\u7528\u985E\u5225\u8CC7\u6599 (\u9810\u8A2D)\n -Xshare:on \u9700\u8981\u4F7F\u7528\u5171\u7528\u985E\u5225\u8CC7\u6599\uFF0C\u5426\u5247\u5931\u6557\u3002\n -XshowSettings \u986F\u793A\u6240\u6709\u8A2D\u5B9A\u503C\u4E26\u7E7C\u7E8C\n -XshowSettings:all\n \u986F\u793A\u6240\u6709\u8A2D\u5B9A\u503C\u4E26\u7E7C\u7E8C\n -XshowSettings:vm \u986F\u793A\u6240\u6709 VM \u76F8\u95DC\u8A2D\u5B9A\u503C\u4E26\u7E7C\u7E8C\n -XshowSettings:properties\n \u986F\u793A\u6240\u6709\u5C6C\u6027\u8A2D\u5B9A\u503C\u4E26\u7E7C\u7E8C\n -XshowSettings:locale\n \u986F\u793A\u6240\u6709\u5730\u5340\u8A2D\u5B9A\u76F8\u95DC\u8A2D\u5B9A\u503C\u4E26\u7E7C\u7E8C\n -XaddReads:=(,)*\n \u7121\u8AD6\u6A21\u7D44\u5BA3\u544A\u70BA\u4F55\uFF0C\n \u6703\u8B80\u53D6\u5176\u4ED6\u6A21\u7D44\n -XaddExports:/=(,)*\n \u7121\u8AD6\u6A21\u7D44\u5BA3\u544A\u70BA\u4F55\uFF0C \u6703\u5C07 \n \u532F\u51FA\u81F3\u5176\u4ED6\u6A21\u7D44\n -Xpatch:=({0})*\n \u8986\u5BEB\u6216\u52A0\u5F37 JAR \u6A94\u6848\u6216\u76EE\u9304\u4E2D\u7684\n \u6A21\u7D44\u985E\u578B\u548C\u8CC7\u6E90\n -Xdisable-@files \u505C\u7528\u9032\u4E00\u6B65\u7684\u5F15\u6578\u6A94\u6848\u64F4\u5145\n\n-X \u9078\u9805\u4E0D\u662F\u6A19\u6E96\u9078\u9805\uFF0C\u82E5\u6709\u8B8A\u66F4\u4E0D\u53E6\u884C\u901A\u77E5\u3002\n +java.launcher.X.usage=\ -Xmixed \u6DF7\u5408\u6A21\u5F0F\u57F7\u884C (\u9810\u8A2D)\n -Xint \u50C5\u9650\u89E3\u8B6F\u6A21\u5F0F\u57F7\u884C\n -Xbootclasspath/a:<\u4EE5 {0} \u5206\u9694\u7684\u76EE\u9304\u548C zip/jar \u6A94\u6848>\n \u9644\u52A0\u5728\u555F\u52D5\u5B89\u88DD\u985E\u5225\u8DEF\u5F91\u7684\u7D50\u5C3E\n -Xdiag \u986F\u793A\u5176\u4ED6\u7684\u8A3A\u65B7\u8A0A\u606F\n -Xdiag:resolver \u986F\u793A\u89E3\u6790\u5668\u8A3A\u65B7\u8A0A\u606F\n -Xnoclassgc \u505C\u7528\u985E\u5225\u8CC7\u6E90\u56DE\u6536\n -Xloggc: \u5C07 GC \u72C0\u614B\u548C\u6642\u6233\u8A18\u9304\u81F3\u6A94\u6848\n -Xbatch \u505C\u7528\u80CC\u666F\u7DE8\u8B6F\n -Xms \u8A2D\u5B9A\u8D77\u59CB Java \u5806\u96C6\u5927\u5C0F\n -Xmx \u8A2D\u5B9A Java \u5806\u96C6\u5927\u5C0F\u4E0A\u9650\n -Xss \u8A2D\u5B9A Java \u57F7\u884C\u7DD2\u5806\u758A\u5927\u5C0F\n -Xprof \u8F38\u51FA CPU \u5206\u6790\u8CC7\u6599\n -Xfuture \u555F\u7528\u6700\u56B4\u683C\u7684\u6AA2\u67E5\uFF0C\u9810\u5148\u4F5C\u70BA\u5C07\u4F86\u7684\u9810\u8A2D\n -Xrs \u6E1B\u5C11 Java/VM \u4F7F\u7528\u4F5C\u696D\u7CFB\u7D71\u4FE1\u865F (\u8ACB\u53C3\u95B1\u6587\u4EF6)\n -Xcheck:jni \u57F7\u884C\u5176\u4ED6\u7684 JNI \u51FD\u6578\u6AA2\u67E5\n -Xshare:off \u4E0D\u5617\u8A66\u4F7F\u7528\u5171\u7528\u985E\u5225\u8CC7\u6599\n -Xshare:auto \u5118\u53EF\u80FD\u4F7F\u7528\u5171\u7528\u985E\u5225\u8CC7\u6599 (\u9810\u8A2D)\n -Xshare:on \u9700\u8981\u4F7F\u7528\u5171\u7528\u985E\u5225\u8CC7\u6599\uFF0C\u5426\u5247\u5931\u6557\u3002\n -XshowSettings \u986F\u793A\u6240\u6709\u8A2D\u5B9A\u503C\u4E26\u7E7C\u7E8C\n -XshowSettings:all\n \u986F\u793A\u6240\u6709\u8A2D\u5B9A\u503C\u4E26\u7E7C\u7E8C\n -XshowSettings:vm \u986F\u793A\u6240\u6709 VM \u76F8\u95DC\u8A2D\u5B9A\u503C\u4E26\u7E7C\u7E8C\n -XshowSettings:properties\n \u986F\u793A\u6240\u6709\u5C6C\u6027\u8A2D\u5B9A\u503C\u4E26\u7E7C\u7E8C\n -XshowSettings:locale\n \u986F\u793A\u6240\u6709\u5730\u5340\u8A2D\u5B9A\u76F8\u95DC\u8A2D\u5B9A\u503C\u4E26\u7E7C\u7E8C\n -XaddReads:=(,)*\n \u7121\u8AD6\u6A21\u7D44\u5BA3\u544A\u70BA\u4F55\uFF0C\n \u6703\u8B80\u53D6\u5176\u4ED6\u6A21\u7D44\n -XaddExports:/=(,)*\n \u7121\u8AD6\u6A21\u7D44\u5BA3\u544A\u70BA\u4F55\uFF0C \u6703\u5C07 \n \u532F\u51FA\u81F3\u5176\u4ED6\u6A21\u7D44\n -Xpatch:=({0})*\n \u8986\u5BEB\u6216\u52A0\u5F37 JAR \u6A94\u6848\u6216\u76EE\u9304\u4E2D\u7684\n \u6A21\u7D44\u985E\u578B\u548C\u8CC7\u6E90\n -Xdisable-@files \u505C\u7528\u9032\u4E00\u6B65\u7684\u5F15\u6578\u6A94\u6848\u64F4\u5145\n\n-X \u9078\u9805\u4E0D\u662F\u6A19\u6E96\u9078\u9805\uFF0C\u82E5\u6709\u8B8A\u66F4\u4E0D\u53E6\u884C\u901A\u77E5\u3002\n # Translators please note do not translate the options themselves java.launcher.X.macosx.usage=\n\u4E0B\u5217\u662F Mac OS X \u7279\u5B9A\u9078\u9805:\n -XstartOnFirstThread\n \u5728\u7B2C\u4E00\u500B (AppKit) \u57F7\u884C\u7DD2\u57F7\u884C main() \u65B9\u6CD5\n -Xdock:name="\n \u8986\u5BEB\u7D50\u5408\u8AAA\u660E\u756B\u9762\u4E2D\u986F\u793A\u7684\u9810\u8A2D\u61C9\u7528\u7A0B\u5F0F\u540D\u7A31\n -Xdock:icon=\n \u8986\u5BEB\u7D50\u5408\u8AAA\u660E\u756B\u9762\u4E2D\u986F\u793A\u7684\u9810\u8A2D\u5716\u793A\n\n diff --git a/jdk/src/java.base/share/classes/sun/reflect/annotation/TypeAnnotationParser.java b/jdk/src/java.base/share/classes/sun/reflect/annotation/TypeAnnotationParser.java index 2873db8e1b3..3744002e5a8 100644 --- a/jdk/src/java.base/share/classes/sun/reflect/annotation/TypeAnnotationParser.java +++ b/jdk/src/java.base/share/classes/sun/reflect/annotation/TypeAnnotationParser.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -351,11 +351,14 @@ public final class TypeAnnotationParser { new LinkedHashMap<>(); for (TypeAnnotation t : typeAnnos) { Annotation a = t.getAnnotation(); - Class klass = a.annotationType(); - AnnotationType type = AnnotationType.getInstance(klass); - if (type.retention() == RetentionPolicy.RUNTIME) - if (result.put(klass, a) != null) + if (a != null) { + Class klass = a.annotationType(); + AnnotationType type = AnnotationType.getInstance(klass); + if (type.retention() == RetentionPolicy.RUNTIME && + result.put(klass, a) != null) { throw new AnnotationFormatError("Duplicate annotation for class: "+klass+": " + a); + } + } } return result; } diff --git a/jdk/src/java.base/share/classes/sun/security/jca/ProviderConfig.java b/jdk/src/java.base/share/classes/sun/security/jca/ProviderConfig.java index c12f7f3bc5f..2f52c8b2ca8 100644 --- a/jdk/src/java.base/share/classes/sun/security/jca/ProviderConfig.java +++ b/jdk/src/java.base/share/classes/sun/security/jca/ProviderConfig.java @@ -159,6 +159,8 @@ final class ProviderConfig { /** * Get the provider object. Loads the provider if it is not already loaded. */ + // com.sun.net.ssl.internal.ssl.Provider has been deprecated since JDK 9 + @SuppressWarnings("deprecation") synchronized Provider getProvider() { // volatile variable load Provider p = provider; diff --git a/jdk/src/java.base/share/classes/sun/security/provider/AbstractDrbg.java b/jdk/src/java.base/share/classes/sun/security/provider/AbstractDrbg.java index ca2119ca7f9..9fec8762111 100644 --- a/jdk/src/java.base/share/classes/sun/security/provider/AbstractDrbg.java +++ b/jdk/src/java.base/share/classes/sun/security/provider/AbstractDrbg.java @@ -377,11 +377,12 @@ public abstract class AbstractDrbg { instantiateIfNecessary(null); - // Step 7: Auto reseed + // Step 7: Auto reseed (reseedCounter might overflow) // Double checked locking, safe because reseedCounter is volatile - if (reseedCounter > reseedInterval || pr) { + if (reseedCounter < 0 || reseedCounter > reseedInterval || pr) { synchronized (this) { - if (reseedCounter > reseedInterval || pr) { + if (reseedCounter < 0 || reseedCounter > reseedInterval + || pr) { reseedAlgorithm(getEntropyInput(pr), ai); ai = null; } diff --git a/jdk/src/java.base/share/classes/sun/security/provider/AbstractHashDrbg.java b/jdk/src/java.base/share/classes/sun/security/provider/AbstractHashDrbg.java index e49f1349bf8..ce93ec41bd7 100644 --- a/jdk/src/java.base/share/classes/sun/security/provider/AbstractHashDrbg.java +++ b/jdk/src/java.base/share/classes/sun/security/provider/AbstractHashDrbg.java @@ -27,7 +27,8 @@ package sun.security.provider; import sun.security.util.HexDumpEncoder; -import java.util.Arrays; +import java.util.ArrayList; +import java.util.List; import java.util.Locale; public abstract class AbstractHashDrbg extends AbstractDrbg { @@ -113,16 +114,13 @@ public abstract class AbstractHashDrbg extends AbstractDrbg { // 800-90Ar1 10.1.2.3: Hmac_DRBG Instantiate Process. // Step 1: entropy_input || nonce || personalization_string. - byte[] seed = Arrays.copyOf(entropy, entropy.length + nonce.length + - ((personalizationString == null) ? 0 - : personalizationString.length)); - System.arraycopy(nonce, 0, seed, entropy.length, nonce.length); + List inputs = new ArrayList<>(3); + inputs.add(entropy); + inputs.add(nonce); if (personalizationString != null) { - System.arraycopy(personalizationString, 0, - seed, entropy.length + nonce.length, - personalizationString.length); + inputs.add(personalizationString); } - hashReseedInternal(seed); + hashReseedInternal(inputs); } @Override @@ -140,13 +138,17 @@ public abstract class AbstractHashDrbg extends AbstractDrbg { // 800-90Ar1 10.1.2.4: Hmac_DRBG Reseed Process. // Step 1: entropy_input || additional_input. + List inputs = new ArrayList<>(2); + inputs.add(ei); if (additionalInput != null) { - ei = Arrays.copyOf(ei, ei.length + additionalInput.length); - System.arraycopy(additionalInput, 0, ei, - ei.length - additionalInput.length, additionalInput.length); + inputs.add(additionalInput); } - hashReseedInternal(ei); + hashReseedInternal(inputs); } - protected abstract void hashReseedInternal(byte[] seed); + /** + * Operates on multiple inputs. + * @param inputs not null, each element neither null + */ + protected abstract void hashReseedInternal(List inputs); } diff --git a/jdk/src/java.base/share/classes/sun/security/provider/CtrDrbg.java b/jdk/src/java.base/share/classes/sun/security/provider/CtrDrbg.java index 683f5941c45..d595dd46e95 100644 --- a/jdk/src/java.base/share/classes/sun/security/provider/CtrDrbg.java +++ b/jdk/src/java.base/share/classes/sun/security/provider/CtrDrbg.java @@ -242,6 +242,11 @@ public class CtrDrbg extends AbstractDrbg { if (personalizationString == null) { more = nonce; } else { + if (nonce.length + personalizationString.length < 0) { + // Length must be represented as a 32 bit integer in df() + throw new IllegalArgumentException( + "nonce plus personalization string is too long"); + } more = Arrays.copyOf( nonce, nonce.length + personalizationString.length); System.arraycopy(personalizationString, 0, more, nonce.length, @@ -256,50 +261,73 @@ public class CtrDrbg extends AbstractDrbg { reseedAlgorithm(ei, more); } + /** + * Block_cipher_df in 10.3.2 + * + * @param input the input string + * @return the output block (always of seedLen) + */ private byte[] df(byte[] input) { + // 800-90Ar1 10.3.2 + // 2. L = len (input_string)/8 int l = input.length; + // 3. N = number_of_bits_to_return/8 int n = seedLen; - int slen = 4 + 4 + l + 1; - byte[] s = new byte[(slen + blockLen - 1) / blockLen * blockLen]; - s[0] = (byte)(l >> 24); - s[1] = (byte)(l >> 16); - s[2] = (byte)(l >> 8); - s[3] = (byte)(l); - s[4] = (byte)(n >> 24); - s[5] = (byte)(n >> 16); - s[6] = (byte)(n >> 8); - s[7] = (byte)(n); - System.arraycopy(input, 0, s, 8, l); - s[8+l] = (byte)0x80; + // 4. S = L || N || input_string || 0x80 + byte[] ln = new byte[8]; + ln[0] = (byte)(l >> 24); + ln[1] = (byte)(l >> 16); + ln[2] = (byte)(l >> 8); + ln[3] = (byte)(l); + ln[4] = (byte)(n >> 24); + ln[5] = (byte)(n >> 16); + ln[6] = (byte)(n >> 8); + ln[7] = (byte)(n); + // 5. Zero padding of S + // Not necessary, see bcc + + // 8. K = leftmost (0x00010203...1D1E1F, keylen). byte[] k = new byte[keyLen]; for (int i = 0; i < k.length; i++) { k[i] = (byte)i; } + // 6. temp = the Null String byte[] temp = new byte[seedLen]; + // 7. i = 0 for (int i = 0; i * blockLen < temp.length; i++) { - byte[] iv = new byte[blockLen + s.length]; + // 9.1 IV = i || 0^(outlen - len (i)). outLen is blockLen + byte[] iv = new byte[blockLen]; iv[0] = (byte)(i >> 24); iv[1] = (byte)(i >> 16); iv[2] = (byte)(i >> 8); iv[3] = (byte)(i); - System.arraycopy(s, 0, iv, blockLen, s.length); + int tailLen = temp.length - blockLen*i; if (tailLen > blockLen) { tailLen = blockLen; } - System.arraycopy(bcc(k, iv), 0, temp, blockLen*i, tailLen); + // 9.2 temp = temp || BCC (K, (IV || S)). + System.arraycopy(bcc(k, iv, ln, input, new byte[]{(byte)0x80}), + 0, temp, blockLen*i, tailLen); } + // 10. K = leftmost(temp, keylen) k = Arrays.copyOf(temp, keyLen); + + // 11. x = select(temp, keylen+1, keylen+outlen) byte[] x = Arrays.copyOfRange(temp, keyLen, temp.length); + // 12. temp = the Null string + // No need to clean up, temp will be overwritten + for (int i = 0; i * blockLen < seedLen; i++) { try { cipher.init(Cipher.ENCRYPT_MODE, new SecretKeySpec(k, keyAlg)); int tailLen = temp.length - blockLen*i; + // 14. requested_bits = leftmost(temp, nuumber_of_bits_to_return) if (tailLen > blockLen) { tailLen = blockLen; } @@ -309,21 +337,45 @@ public class CtrDrbg extends AbstractDrbg { throw new InternalError(e); } } + + // 15. Return return temp; } - private byte[] bcc(byte[] k, byte[] data) { + /** + * Block_Encrypt in 10.3.3 + * + * @param k the key + * @param data after concatenated, the data to be operated upon. This is + * a series of byte[], each with an arbitrary length. Note + * that the full length is not necessarily a multiple of + * outlen. XOR with zero is no-op. + * @return the result + */ + private byte[] bcc(byte[] k, byte[]... data) { byte[] chain = new byte[blockLen]; - int n = data.length / blockLen; - for (int i = 0; i < n; i++) { - byte[] inputBlock = Arrays.copyOfRange( - data, i * blockLen, i * blockLen + blockLen); - for (int j = 0; j < blockLen; j++) { - inputBlock[j] ^= chain[j]; + int n1 = 0; // index in data + int n2 = 0; // index in data[n1] + // pack blockLen of bytes into chain from data[][], again and again + while (n1 < data.length) { + int j; + out: for (j = 0; j < blockLen; j++) { + while (n2 >= data[n1].length) { + n1++; + if (n1 >= data.length) { + break out; + } + n2 = 0; + } + chain[j] ^= data[n1][n2]; + n2++; + } + if (j == 0) { // all data happens to be consumed in the last loop + break; } try { cipher.init(Cipher.ENCRYPT_MODE, new SecretKeySpec(k, keyAlg)); - chain = cipher.doFinal(inputBlock); + chain = cipher.doFinal(chain); } catch (GeneralSecurityException e) { throw new InternalError(e); } @@ -341,6 +393,11 @@ public class CtrDrbg extends AbstractDrbg { // Step 1: cat bytes if (additionalInput != null) { + if (ei.length + additionalInput.length < 0) { + // Length must be represented as a 32 bit integer in df() + throw new IllegalArgumentException( + "entropy plus additional input is too long"); + } byte[] temp = Arrays.copyOf( ei, ei.length + additionalInput.length); System.arraycopy(additionalInput, 0, temp, ei.length, @@ -430,10 +487,10 @@ public class CtrDrbg extends AbstractDrbg { // Step 3. temp = Null int pos = 0; + int len = result.length; // Step 4. Loop - while (pos < result.length) { - int tailLen = result.length - pos; + while (len > 0) { // Step 4.1. Increment addOne(v, ctrLen); try { @@ -443,10 +500,15 @@ public class CtrDrbg extends AbstractDrbg { // Step 4.3 and 5. Cat bytes and leftmost System.arraycopy(out, 0, result, pos, - (tailLen > blockLen) ? blockLen : tailLen); + (len > blockLen) ? blockLen : len); } catch (GeneralSecurityException e) { throw new InternalError(e); } + len -= blockLen; + if (len <= 0) { + // shortcut, so that pos needn't be updated + break; + } pos += blockLen; } diff --git a/jdk/src/java.base/share/classes/sun/security/provider/HashDrbg.java b/jdk/src/java.base/share/classes/sun/security/provider/HashDrbg.java index bf641227e85..10300015987 100644 --- a/jdk/src/java.base/share/classes/sun/security/provider/HashDrbg.java +++ b/jdk/src/java.base/share/classes/sun/security/provider/HashDrbg.java @@ -31,7 +31,9 @@ import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.security.NoSuchProviderException; import java.security.SecureRandomParameters; +import java.util.ArrayList; import java.util.Arrays; +import java.util.List; public class HashDrbg extends AbstractHashDrbg { @@ -70,7 +72,7 @@ public class HashDrbg extends AbstractHashDrbg { } } - private byte[] hashDf(int requested, byte[]... inputs) { + private byte[] hashDf(int requested, List inputs) { return hashDf(digest, outLen, requested, inputs); } @@ -79,6 +81,9 @@ public class HashDrbg extends AbstractHashDrbg { * The function is used inside Hash_DRBG, and can also be used as an * approved conditioning function as described in 800-90B 6.4.2.2. * + * Note: In each current call, requested is seedLen, therefore small, + * no need to worry about overflow. + * * @param digest a {@code MessageDigest} object in reset state * @param outLen {@link MessageDigest#getDigestLength} of {@code digest} * @param requested requested output length, in bytes @@ -86,12 +91,18 @@ public class HashDrbg extends AbstractHashDrbg { * @return the condensed/expanded output */ public static byte[] hashDf(MessageDigest digest, int outLen, - int requested, byte[]... inputs) { + int requested, List inputs) { + // 1. temp = the Null string. + // 2. len = upper_int(no_of_bits_to_return / outLen) int len = (requested + outLen - 1) / outLen; byte[] temp = new byte[len * outLen]; + // 3. counter = 0x01 int counter = 1; + // 4. For i = 1 to len do for (int i=0; i> 21)); // requested*8 as int32 digest.update((byte)(requested >> 13)); @@ -105,14 +116,17 @@ public class HashDrbg extends AbstractHashDrbg { } catch (DigestException e) { throw new AssertionError("will not happen", e); } + // 4.2 counter = counter + 1 counter++; } + // 5. requested_bits = leftmost (temp, no_of_bits_to_return). return temp.length == requested? temp: Arrays.copyOf(temp, requested); + // 6. Return } // This method is used by both instantiation and reseeding. @Override - protected final synchronized void hashReseedInternal(byte[] input) { + protected final synchronized void hashReseedInternal(List inputs) { // 800-90Ar1 10.1.1.2: Instantiate Process. // 800-90Ar1 10.1.1.3: Reseed Process. @@ -121,16 +135,21 @@ public class HashDrbg extends AbstractHashDrbg { // Step 2: seed = Hash_df (seed_material, seedlen). if (v != null) { // Step 1 of 10.1.1.3: Prepend 0x01 || V - seed = hashDf(seedLen, ONE, v, input); + inputs.add(0, ONE); + inputs.add(1, v); + seed = hashDf(seedLen, inputs); } else { - seed = hashDf(seedLen, input); + seed = hashDf(seedLen, inputs); } // Step 3. V = seed. v = seed; // Step 4. C = Hash_df ((0x00 || V), seedlen). - c = hashDf(seedLen, ZERO, v); + inputs = new ArrayList<>(2); + inputs.add(ZERO); + inputs.add(v); + c = hashDf(seedLen, inputs); // Step 5. reseed_counter = 1. reseedCounter = 1; @@ -197,7 +216,7 @@ public class HashDrbg extends AbstractHashDrbg { } // Step 3. Hashgen (requested_number_of_bits, V). - hashGen(result, result.length, v); + hashGen(result, v); // Step 4. H = Hash (0x03 || V). digest.update((byte)3); @@ -222,10 +241,7 @@ public class HashDrbg extends AbstractHashDrbg { } // 800-90Ar1 10.1.1.4: Hashgen - private void hashGen(byte[] output, int len, byte[] v) { - - // Step 1. m - int m = (len + outLen - 1) / outLen; + private void hashGen(byte[] output, byte[] v) { // Step 2. data = V byte[] data = v; @@ -233,32 +249,36 @@ public class HashDrbg extends AbstractHashDrbg { // Step 3: W is output not filled // Step 4: For i = 1 to m - for (int i = 0; i < m; i++) { - int tailLen = len - i * outLen; - if (tailLen < outLen) { + int pos = 0; + int len = output.length; + + while (len > 0) { + if (len < outLen) { // Step 4.1 w = Hash (data). // Step 4.2 W = W || w. - System.arraycopy(digest.digest(data), 0, output, i * outLen, - tailLen); + System.arraycopy(digest.digest(data), 0, output, pos, + len); } else { try { // Step 4.1 w = Hash (data). digest.update(data); // Step 4.2 digest into right position, no need to cat - digest.digest(output, i*outLen, outLen); + digest.digest(output, pos, outLen); } catch (DigestException e) { throw new AssertionError("will not happen", e); } } - // Unless this is the last around, we will need to increment data. - // but we cannot change v, so a copy is made. - if (i != m - 1) { - if (data == v) { - data = Arrays.copyOf(v, v.length); - } - // Step 4.3 data = (data + 1) mod 2^seedlen. - addBytes(data, seedLen, ONE); + len -= outLen; + if (len <= 0) { + // shortcut, so that data and pos needn't be updated + break; } + // Step 4.3 data = (data + 1) mod 2^seedlen. + if (data == v) { + data = Arrays.copyOf(v, v.length); + } + addBytes(data, seedLen, ONE); + pos += outLen; } // Step 5: No need to truncate diff --git a/jdk/src/java.base/share/classes/sun/security/provider/HmacDrbg.java b/jdk/src/java.base/share/classes/sun/security/provider/HmacDrbg.java index 40b43b00e6f..ea1542ef375 100644 --- a/jdk/src/java.base/share/classes/sun/security/provider/HmacDrbg.java +++ b/jdk/src/java.base/share/classes/sun/security/provider/HmacDrbg.java @@ -32,6 +32,8 @@ import java.security.NoSuchAlgorithmException; import java.security.NoSuchProviderException; import java.security.SecureRandomParameters; import java.util.Arrays; +import java.util.Collections; +import java.util.List; public class HmacDrbg extends AbstractHashDrbg { @@ -56,7 +58,7 @@ public class HmacDrbg extends AbstractHashDrbg { } // 800-90Ar1 10.1.2.2: HMAC_DRBG Update Process - private void update(byte[]... inputs) { + private void update(List inputs) { try { // Step 1. K = HMAC (K, V || 0x00 || provided_data). mac.init(new SecretKeySpec(k, macAlg)); @@ -71,7 +73,7 @@ public class HmacDrbg extends AbstractHashDrbg { mac.init(new SecretKeySpec(k, macAlg)); v = mac.doFinal(v); - if (inputs.length != 0) { + if (!inputs.isEmpty()) { // Step 4. K = HMAC (K, V || 0x01 || provided_data). mac.update(v); mac.update((byte) 1); @@ -116,7 +118,7 @@ public class HmacDrbg extends AbstractHashDrbg { // This method is used by both instantiation and reseeding. @Override - protected final synchronized void hashReseedInternal(byte[] input) { + protected final synchronized void hashReseedInternal(List input) { // 800-90Ar1 10.1.2.3: Instantiate Process. // 800-90Ar1 10.1.2.4: Reseed Process. @@ -156,16 +158,15 @@ public class HmacDrbg extends AbstractHashDrbg { // Step 2. HMAC_DRBG_Update if (additionalInput != null) { - update(additionalInput); + update(Collections.singletonList(additionalInput)); } // Step 3. temp = Null. int pos = 0; + int len = result.length; // Step 4. Loop - while (pos < result.length) { - int tailLen = result.length - pos; - + while (len > 0) { // Step 4.1 V = HMAC (Key, V). try { mac.init(new SecretKeySpec(k, macAlg)); @@ -175,7 +176,13 @@ public class HmacDrbg extends AbstractHashDrbg { v = mac.doFinal(v); // Step 4.2 temp = temp || V. System.arraycopy(v, 0, result, pos, - tailLen > outLen ? outLen : tailLen); + len > outLen ? outLen : len); + + len -= outLen; + if (len <= 0) { + // shortcut, so that pos needn't be updated + break; + } pos += outLen; } @@ -183,9 +190,9 @@ public class HmacDrbg extends AbstractHashDrbg { // Step 6. HMAC_DRBG_Update (additional_input, Key, V). if (additionalInput != null) { - update(additionalInput); + update(Collections.singletonList(additionalInput)); } else { - update(); + update(Collections.emptyList()); } // Step 7. reseed_counter = reseed_counter + 1. diff --git a/jdk/src/java.base/share/classes/sun/security/provider/certpath/AlgorithmChecker.java b/jdk/src/java.base/share/classes/sun/security/provider/certpath/AlgorithmChecker.java index 4562f4d0250..d8f64cb7897 100644 --- a/jdk/src/java.base/share/classes/sun/security/provider/certpath/AlgorithmChecker.java +++ b/jdk/src/java.base/share/classes/sun/security/provider/certpath/AlgorithmChecker.java @@ -27,6 +27,7 @@ package sun.security.provider.certpath; import java.security.AlgorithmConstraints; import java.security.CryptoPrimitive; +import java.security.Timestamp; import java.util.Collection; import java.util.Collections; import java.util.Date; @@ -77,6 +78,7 @@ public final class AlgorithmChecker extends PKIXCertPathChecker { private final PublicKey trustedPubKey; private final Date pkixdate; private PublicKey prevPubKey; + private final Timestamp jarTimestamp; private static final Set SIGNATURE_PRIMITIVE_SET = Collections.unmodifiableSet(EnumSet.of(CryptoPrimitive.SIGNATURE)); @@ -142,6 +144,29 @@ public final class AlgorithmChecker extends PKIXCertPathChecker { this.trustedPubKey = null; this.constraints = constraints; this.pkixdate = null; + this.jarTimestamp = null; + } + + /** + * Create a new {@code AlgorithmChecker} with the given + * {@code Timestamp}. + *

      + * Note that this constructor will be used to check a certification + * path for signed JAR files that are timestamped. + * + * @param jarTimestamp Timestamp passed for JAR timestamp constraint + * checking. Set to null if not applicable. + */ + public AlgorithmChecker(Timestamp jarTimestamp) { + this.prevPubKey = null; + this.trustedPubKey = null; + this.constraints = certPathDefaultConstraints; + if (jarTimestamp == null) { + throw new IllegalArgumentException( + "Timestamp cannot be null"); + } + this.pkixdate = jarTimestamp.getTimestamp(); + this.jarTimestamp = jarTimestamp; } /** @@ -162,7 +187,7 @@ public final class AlgorithmChecker extends PKIXCertPathChecker { if (anchor == null) { throw new IllegalArgumentException( - "The trust anchor cannot be null"); + "The trust anchor cannot be null"); } if (anchor.getTrustedCert() != null) { @@ -179,6 +204,7 @@ public final class AlgorithmChecker extends PKIXCertPathChecker { this.prevPubKey = trustedPubKey; this.constraints = constraints; this.pkixdate = pkixdate; + this.jarTimestamp = null; } /** @@ -209,6 +235,10 @@ public final class AlgorithmChecker extends PKIXCertPathChecker { return AnchorCertificates.contains(cert); } + Timestamp getJarTimestamp() { + return jarTimestamp; + } + @Override public void init(boolean forward) throws CertPathValidatorException { // Note that this class does not support forward mode. @@ -296,8 +326,7 @@ public final class AlgorithmChecker extends PKIXCertPathChecker { // permits() will throw exception on failure. certPathDefaultConstraints.permits(primitives, new CertConstraintParameters((X509Certificate)cert, - trustedMatch, pkixdate)); - // new CertConstraintParameters(x509Cert, trustedMatch)); + trustedMatch, pkixdate, jarTimestamp)); // If there is no previous key, set one and exit if (prevPubKey == null) { prevPubKey = currPubKey; @@ -442,7 +471,7 @@ public final class AlgorithmChecker extends PKIXCertPathChecker { * Check the signature algorithm with the specified public key. * * @param key the public key to verify the CRL signature - * @param crl the target CRL + * @param algorithmId signature algorithm Algorithm ID */ static void check(PublicKey key, AlgorithmId algorithmId) throws CertPathValidatorException { diff --git a/jdk/src/java.base/share/classes/sun/security/provider/certpath/PKIX.java b/jdk/src/java.base/share/classes/sun/security/provider/certpath/PKIX.java index e33d4a21a5c..f6b0b2ed6f3 100644 --- a/jdk/src/java.base/share/classes/sun/security/provider/certpath/PKIX.java +++ b/jdk/src/java.base/share/classes/sun/security/provider/certpath/PKIX.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,6 +26,7 @@ package sun.security.provider.certpath; import java.security.InvalidAlgorithmParameterException; import java.security.PublicKey; +import java.security.Timestamp; import java.security.cert.*; import java.security.interfaces.DSAPublicKey; import java.util.*; @@ -85,6 +86,7 @@ class PKIX { private CertSelector constraints; private Set anchors; private List certs; + private Timestamp timestamp; ValidatorParams(CertPath cp, PKIXParameters params) throws InvalidAlgorithmParameterException @@ -100,6 +102,10 @@ class PKIX { ValidatorParams(PKIXParameters params) throws InvalidAlgorithmParameterException { + if (params instanceof PKIXTimestampParameters) { + timestamp = ((PKIXTimestampParameters) params).getTimestamp(); + } + this.anchors = params.getTrustAnchors(); // Make sure that none of the trust anchors include name constraints // (not supported). @@ -189,6 +195,10 @@ class PKIX { PKIXParameters getPKIXParameters() { return params; } + + Timestamp timestamp() { + return timestamp; + } } static class BuilderParams extends ValidatorParams { diff --git a/jdk/src/java.base/share/classes/sun/security/provider/certpath/PKIXCertPathValidator.java b/jdk/src/java.base/share/classes/sun/security/provider/certpath/PKIXCertPathValidator.java index 934fc10b560..ac12fab75ab 100644 --- a/jdk/src/java.base/share/classes/sun/security/provider/certpath/PKIXCertPathValidator.java +++ b/jdk/src/java.base/share/classes/sun/security/provider/certpath/PKIXCertPathValidator.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -172,7 +172,11 @@ public final class PKIXCertPathValidator extends CertPathValidatorSpi { List certPathCheckers = new ArrayList<>(); // add standard checkers that we will be using certPathCheckers.add(untrustedChecker); - certPathCheckers.add(new AlgorithmChecker(anchor, params.date())); + if (params.timestamp() == null) { + certPathCheckers.add(new AlgorithmChecker(anchor, params.date())); + } else { + certPathCheckers.add(new AlgorithmChecker(params.timestamp())); + } certPathCheckers.add(new KeyChecker(certPathLen, params.targetCertConstraints())); certPathCheckers.add(new ConstraintsChecker(certPathLen)); @@ -189,8 +193,14 @@ public final class PKIXCertPathValidator extends CertPathValidatorSpi { rootNode); certPathCheckers.add(pc); // default value for date is current time - BasicChecker bc = new BasicChecker(anchor, params.date(), - params.sigProvider(), false); + BasicChecker bc; + if (params.timestamp() == null) { + bc = new BasicChecker(anchor, params.date(), params.sigProvider(), + false); + } else { + bc = new BasicChecker(anchor, params.timestamp().getTimestamp(), + params.sigProvider(), false); + } certPathCheckers.add(bc); boolean revCheckerAdded = false; diff --git a/jdk/src/java.base/share/classes/sun/security/provider/certpath/PKIXTimestampParameters.java b/jdk/src/java.base/share/classes/sun/security/provider/certpath/PKIXTimestampParameters.java new file mode 100644 index 00000000000..34b497188e0 --- /dev/null +++ b/jdk/src/java.base/share/classes/sun/security/provider/certpath/PKIXTimestampParameters.java @@ -0,0 +1,218 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + + +package sun.security.provider.certpath; + +import java.security.InvalidAlgorithmParameterException; +import java.security.Timestamp; +import java.security.cert.CertSelector; +import java.security.cert.CertStore; +import java.security.cert.PKIXBuilderParameters; +import java.security.cert.PKIXCertPathChecker; +import java.security.cert.TrustAnchor; +import java.util.Date; +import java.util.List; +import java.util.Set; + +/** + * This class is a wrapper for PKIXBuilderParameters so that a Timestamp object + * can be passed alone when PKIXCertPath is checking signed jar files. + */ + +public class PKIXTimestampParameters extends PKIXBuilderParameters { + + private final PKIXBuilderParameters p; + private Timestamp jarTimestamp; + + public PKIXTimestampParameters(PKIXBuilderParameters params, + Timestamp timestamp) throws InvalidAlgorithmParameterException { + super(params.getTrustAnchors(), null); + p = params; + jarTimestamp = timestamp; + } + + public Timestamp getTimestamp() { + return jarTimestamp; + } + public void setTimestamp(Timestamp t) { + jarTimestamp = t; + } + + @Override + public void setDate(Date d) { + p.setDate(d); + } + + @Override + public void addCertPathChecker(PKIXCertPathChecker c) { + p.addCertPathChecker(c); + } + + @Override + public void setMaxPathLength(int maxPathLength) { + p.setMaxPathLength(maxPathLength); + } + + @Override + public int getMaxPathLength() { + return p.getMaxPathLength(); + } + + @Override + public String toString() { + return p.toString(); + } + + @Override + public Set getTrustAnchors() { + return p.getTrustAnchors(); + } + + @Override + public void setTrustAnchors(Set trustAnchors) + throws InvalidAlgorithmParameterException { + // To avoid problems with PKIXBuilderParameter's constructors + if (p == null) { + return; + } + p.setTrustAnchors(trustAnchors); + } + + @Override + public Set getInitialPolicies() { + return p.getInitialPolicies(); + } + + @Override + public void setInitialPolicies(Set initialPolicies) { + p.setInitialPolicies(initialPolicies); + } + + @Override + public void setCertStores(List stores) { + p.setCertStores(stores); + } + + @Override + public void addCertStore(CertStore store) { + p.addCertStore(store); + } + + @Override + public List getCertStores() { + return p.getCertStores(); + } + + @Override + public void setRevocationEnabled(boolean val) { + p.setRevocationEnabled(val); + } + + @Override + public boolean isRevocationEnabled() { + return p.isRevocationEnabled(); + } + + @Override + public void setExplicitPolicyRequired(boolean val) { + p.setExplicitPolicyRequired(val); + } + + @Override + public boolean isExplicitPolicyRequired() { + return p.isExplicitPolicyRequired(); + } + + @Override + public void setPolicyMappingInhibited(boolean val) { + p.setPolicyMappingInhibited(val); + } + + @Override + public boolean isPolicyMappingInhibited() { + return p.isPolicyMappingInhibited(); + } + + @Override + public void setAnyPolicyInhibited(boolean val) { + p.setAnyPolicyInhibited(val); + } + + @Override + public boolean isAnyPolicyInhibited() { + return p.isAnyPolicyInhibited(); + } + + @Override + public void setPolicyQualifiersRejected(boolean qualifiersRejected) { + p.setPolicyQualifiersRejected(qualifiersRejected); + } + + @Override + public boolean getPolicyQualifiersRejected() { + return p.getPolicyQualifiersRejected(); + } + + @Override + public Date getDate() { + return p.getDate(); + } + + @Override + public void setCertPathCheckers(List checkers) { + p.setCertPathCheckers(checkers); + } + + @Override + public List getCertPathCheckers() { + return p.getCertPathCheckers(); + } + + @Override + public String getSigProvider() { + return p.getSigProvider(); + } + + @Override + public void setSigProvider(String sigProvider) { + p.setSigProvider(sigProvider); + } + + @Override + public CertSelector getTargetCertConstraints() { + return p.getTargetCertConstraints(); + } + + @Override + public void setTargetCertConstraints(CertSelector selector) { + // To avoid problems with PKIXBuilderParameter's constructors + if (p == null) { + return; + } + p.setTargetCertConstraints(selector); + } + +} diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/CipherSuite.java b/jdk/src/java.base/share/classes/sun/security/ssl/CipherSuite.java index fa6c5ad34bb..2ffb5f32b4b 100644 --- a/jdk/src/java.base/share/classes/sun/security/ssl/CipherSuite.java +++ b/jdk/src/java.base/share/classes/sun/security/ssl/CipherSuite.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -376,36 +376,38 @@ final class CipherSuite implements Comparable { static enum KeyExchange { // key exchange algorithms - K_NULL ("NULL", false), - K_RSA ("RSA", true), - K_RSA_EXPORT ("RSA_EXPORT", true), - K_DH_RSA ("DH_RSA", false), - K_DH_DSS ("DH_DSS", false), - K_DHE_DSS ("DHE_DSS", true), - K_DHE_RSA ("DHE_RSA", true), - K_DH_ANON ("DH_anon", true), + K_NULL ("NULL", false, false), + K_RSA ("RSA", true, false), + K_RSA_EXPORT ("RSA_EXPORT", true, false), + K_DH_RSA ("DH_RSA", false, false), + K_DH_DSS ("DH_DSS", false, false), + K_DHE_DSS ("DHE_DSS", true, false), + K_DHE_RSA ("DHE_RSA", true, false), + K_DH_ANON ("DH_anon", true, false), - K_ECDH_ECDSA ("ECDH_ECDSA", ALLOW_ECC), - K_ECDH_RSA ("ECDH_RSA", ALLOW_ECC), - K_ECDHE_ECDSA("ECDHE_ECDSA", ALLOW_ECC), - K_ECDHE_RSA ("ECDHE_RSA", ALLOW_ECC), - K_ECDH_ANON ("ECDH_anon", ALLOW_ECC), + K_ECDH_ECDSA ("ECDH_ECDSA", ALLOW_ECC, true), + K_ECDH_RSA ("ECDH_RSA", ALLOW_ECC, true), + K_ECDHE_ECDSA("ECDHE_ECDSA", ALLOW_ECC, true), + K_ECDHE_RSA ("ECDHE_RSA", ALLOW_ECC, true), + K_ECDH_ANON ("ECDH_anon", ALLOW_ECC, true), // Kerberos cipher suites - K_KRB5 ("KRB5", true), - K_KRB5_EXPORT("KRB5_EXPORT", true), + K_KRB5 ("KRB5", true, false), + K_KRB5_EXPORT("KRB5_EXPORT", true, false), // renegotiation protection request signaling cipher suite - K_SCSV ("SCSV", true); + K_SCSV ("SCSV", true, false); // name of the key exchange algorithm, e.g. DHE_DSS final String name; final boolean allowed; + final boolean isEC; private final boolean alwaysAvailable; - KeyExchange(String name, boolean allowed) { + KeyExchange(String name, boolean allowed, boolean isEC) { this.name = name; this.allowed = allowed; + this.isEC = isEC; this.alwaysAvailable = allowed && (!name.startsWith("EC")) && (!name.startsWith("KRB")); } @@ -415,7 +417,7 @@ final class CipherSuite implements Comparable { return true; } - if (name.startsWith("EC")) { + if (isEC) { return (allowed && JsseJce.isEcAvailable()); } else if (name.startsWith("KRB")) { return (allowed && JsseJce.isKerberosAvailable()); diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/CipherSuiteList.java b/jdk/src/java.base/share/classes/sun/security/ssl/CipherSuiteList.java index 491bffa85ba..a114f4acb83 100644 --- a/jdk/src/java.base/share/classes/sun/security/ssl/CipherSuiteList.java +++ b/jdk/src/java.base/share/classes/sun/security/ssl/CipherSuiteList.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -112,20 +112,15 @@ final class CipherSuiteList { boolean containsEC() { if (containsEC == null) { for (CipherSuite c : cipherSuites) { - switch (c.keyExchange) { - case K_ECDH_ECDSA: - case K_ECDH_RSA: - case K_ECDHE_ECDSA: - case K_ECDHE_RSA: - case K_ECDH_ANON: + if (c.keyExchange.isEC) { containsEC = true; return true; - default: - break; } } + containsEC = false; } + return containsEC; } diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/ClientHandshaker.java b/jdk/src/java.base/share/classes/sun/security/ssl/ClientHandshaker.java index 649bfd7be2b..6119be94727 100644 --- a/jdk/src/java.base/share/classes/sun/security/ssl/ClientHandshaker.java +++ b/jdk/src/java.base/share/classes/sun/security/ssl/ClientHandshaker.java @@ -877,30 +877,33 @@ final class ClientHandshaker extends Handshaker { String typeName; switch (certRequest.types[i]) { - case CertificateRequest.cct_rsa_sign: - typeName = "RSA"; - break; + case CertificateRequest.cct_rsa_sign: + typeName = "RSA"; + break; - case CertificateRequest.cct_dss_sign: - typeName = "DSA"; - break; + case CertificateRequest.cct_dss_sign: + typeName = "DSA"; + break; - case CertificateRequest.cct_ecdsa_sign: - // ignore if we do not have EC crypto available - typeName = JsseJce.isEcAvailable() ? "EC" : null; - break; + case CertificateRequest.cct_ecdsa_sign: + // ignore if we do not have EC crypto available + typeName = JsseJce.isEcAvailable() ? "EC" : null; + break; - // Fixed DH/ECDH client authentication not supported - case CertificateRequest.cct_rsa_fixed_dh: - case CertificateRequest.cct_dss_fixed_dh: - case CertificateRequest.cct_rsa_fixed_ecdh: - case CertificateRequest.cct_ecdsa_fixed_ecdh: - // Any other values (currently not used in TLS) - case CertificateRequest.cct_rsa_ephemeral_dh: - case CertificateRequest.cct_dss_ephemeral_dh: - default: - typeName = null; - break; + // Fixed DH/ECDH client authentication not supported + // + // case CertificateRequest.cct_rsa_fixed_dh: + // case CertificateRequest.cct_dss_fixed_dh: + // case CertificateRequest.cct_rsa_fixed_ecdh: + // case CertificateRequest.cct_ecdsa_fixed_ecdh: + // + // Any other values (currently not used in TLS) + // + // case CertificateRequest.cct_rsa_ephemeral_dh: + // case CertificateRequest.cct_dss_ephemeral_dh: + default: + typeName = null; + break; } if ((typeName != null) && (!keytypesTmp.contains(typeName))) { @@ -928,16 +931,6 @@ final class ClientHandshaker extends Handshaker { X509Certificate[] certs = km.getCertificateChain(alias); if ((certs != null) && (certs.length != 0)) { PublicKey publicKey = certs[0].getPublicKey(); - // for EC, make sure we use a supported named curve - if (publicKey instanceof ECPublicKey) { - ECParameterSpec params = - ((ECPublicKey)publicKey).getParams(); - int index = - EllipticCurvesExtension.getCurveIndex(params); - if (!EllipticCurvesExtension.isSupported(index)) { - publicKey = null; - } - } if (publicKey != null) { m1 = new CertificateMsg(certs); signingKey = km.getPrivateKey(alias); @@ -1499,6 +1492,17 @@ final class ClientHandshaker extends Handshaker { sslContext.getSecureRandom(), maxProtocolVersion, sessionId, cipherSuites, isDTLS); + // add elliptic curves and point format extensions + if (cipherSuites.containsEC()) { + EllipticCurvesExtension ece = + EllipticCurvesExtension.createExtension(algorithmConstraints); + if (ece != null) { + clientHelloMessage.extensions.add(ece); + clientHelloMessage.extensions.add( + EllipticPointFormatsExtension.DEFAULT); + } + } + // add signature_algorithm extension if (maxProtocolVersion.useTLS12PlusSpec()) { // we will always send the signature_algorithm extension diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/ECDHCrypt.java b/jdk/src/java.base/share/classes/sun/security/ssl/ECDHCrypt.java index b85c4c5dfae..929c592d698 100644 --- a/jdk/src/java.base/share/classes/sun/security/ssl/ECDHCrypt.java +++ b/jdk/src/java.base/share/classes/sun/security/ssl/ECDHCrypt.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2006, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2006, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -56,10 +56,11 @@ final class ECDHCrypt { } // Called by ServerHandshaker for ephemeral ECDH - ECDHCrypt(String curveName, SecureRandom random) { + ECDHCrypt(int curveId, SecureRandom random) { try { KeyPairGenerator kpg = JsseJce.getKeyPairGenerator("EC"); - ECGenParameterSpec params = new ECGenParameterSpec(curveName); + ECGenParameterSpec params = + EllipticCurvesExtension.getECGenParamSpec(curveId); kpg.initialize(params, random); KeyPair kp = kpg.generateKeyPair(); privateKey = kp.getPrivate(); diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/EllipticCurvesExtension.java b/jdk/src/java.base/share/classes/sun/security/ssl/EllipticCurvesExtension.java index 1e38fb6bd94..632d0da18f1 100644 --- a/jdk/src/java.base/share/classes/sun/security/ssl/EllipticCurvesExtension.java +++ b/jdk/src/java.base/share/classes/sun/security/ssl/EllipticCurvesExtension.java @@ -27,58 +27,271 @@ package sun.security.ssl; import java.io.IOException; import java.security.spec.ECParameterSpec; +import java.security.spec.ECGenParameterSpec; +import java.security.spec.InvalidParameterSpecException; +import java.security.AlgorithmParameters; +import java.security.AlgorithmConstraints; +import java.security.CryptoPrimitive; +import java.security.AccessController; +import java.util.EnumSet; import java.util.HashMap; import java.util.Map; - +import java.util.ArrayList; import javax.net.ssl.SSLProtocolException; +import sun.security.action.GetPropertyAction; + final class EllipticCurvesExtension extends HelloExtension { - // the extension value to send in the ClientHello message - static final EllipticCurvesExtension DEFAULT; + private static final int ARBITRARY_PRIME = 0xff01; + private static final int ARBITRARY_CHAR2 = 0xff02; - private static final boolean fips; + // speed up the searching + private static final Map oidToIdMap = new HashMap<>(); + private static final Map idToOidMap = new HashMap<>(); - static { - int[] ids; - fips = SunJSSE.isFIPS(); - if (fips == false) { - ids = new int[] { - // NIST curves first - // prefer NIST P-256, rest in order of increasing key length - 23, 1, 3, 19, 21, 6, 7, 9, 10, 24, 11, 12, 25, 13, 14, - // non-NIST curves - 15, 16, 17, 2, 18, 4, 5, 20, 8, 22, - }; - } else { - ids = new int[] { - // same as above, but allow only NIST curves in FIPS mode - 23, 1, 3, 19, 21, 6, 7, 9, 10, 24, 11, 12, 25, 13, 14, - }; + // speed up the parameters construction + private static final Map idToParams = new HashMap<>(); + + // the supported elliptic curves + private static final int[] supportedCurveIds; + + // the curves of the extension + private final int[] curveIds; + + // See sun.security.util.CurveDB for the OIDs + private static enum NamedEllipticCurve { + T163_K1(1, "sect163k1", "1.3.132.0.1", true), // NIST K-163 + T163_R1(2, "sect163r1", "1.3.132.0.2", false), + T163_R2(3, "sect163r2", "1.3.132.0.15", true), // NIST B-163 + T193_R1(4, "sect193r1", "1.3.132.0.24", false), + T193_R2(5, "sect193r2", "1.3.132.0.25", false), + T233_K1(6, "sect233k1", "1.3.132.0.26", true), // NIST K-233 + T233_R1(7, "sect233r1", "1.3.132.0.27", true), // NIST B-233 + T239_K1(8, "sect239k1", "1.3.132.0.3", false), + T283_K1(9, "sect283k1", "1.3.132.0.16", true), // NIST K-283 + T283_R1(10, "sect283r1", "1.3.132.0.17", true), // NIST B-283 + T409_K1(11, "sect409k1", "1.3.132.0.36", true), // NIST K-409 + T409_R1(12, "sect409r1", "1.3.132.0.37", true), // NIST B-409 + T571_K1(13, "sect571k1", "1.3.132.0.38", true), // NIST K-571 + T571_R1(14, "sect571r1", "1.3.132.0.39", true), // NIST B-571 + + P160_K1(15, "secp160k1", "1.3.132.0.9", false), + P160_R1(16, "secp160r1", "1.3.132.0.8", false), + P160_R2(17, "secp160r2", "1.3.132.0.30", false), + P192_K1(18, "secp192k1", "1.3.132.0.31", false), + P192_R1(19, "secp192r1", "1.2.840.10045.3.1.1", true), // NIST P-192 + P224_K1(20, "secp224k1", "1.3.132.0.32", false), + P224_R1(21, "secp224r1", "1.3.132.0.33", true), // NIST P-224 + P256_K1(22, "secp256k1", "1.3.132.0.10", false), + P256_R1(23, "secp256r1", "1.2.840.10045.3.1.7", true), // NIST P-256 + P384_R1(24, "secp384r1", "1.3.132.0.34", true), // NIST P-384 + P521_R1(25, "secp521r1", "1.3.132.0.35", true); // NIST P-521 + + int id; + String name; + String oid; + boolean isFips; + + NamedEllipticCurve(int id, String name, String oid, boolean isFips) { + this.id = id; + this.name = name; + this.oid = oid; + this.isFips = isFips; + + if (oidToIdMap.put(oid, id) != null || + idToOidMap.put(id, oid) != null) { + + throw new RuntimeException( + "Duplicate named elliptic curve definition: " + name); + } + } + + static NamedEllipticCurve getCurve(String name, boolean requireFips) { + for (NamedEllipticCurve curve : NamedEllipticCurve.values()) { + if (curve.name.equals(name) && (!requireFips || curve.isFips)) { + return curve; + } + } + + return null; } - DEFAULT = new EllipticCurvesExtension(ids); } - private final int[] curveIds; + static { + boolean requireFips = SunJSSE.isFIPS(); + + // hack code to initialize NamedEllipticCurve + NamedEllipticCurve nec = + NamedEllipticCurve.getCurve("secp256r1", false); + + // The value of the System Property defines a list of enabled named + // curves in preference order, separated with comma. For example: + // + // jdk.tls.namedGroups="secp521r1, secp256r1, secp384r1" + // + // If the System Property is not defined or the value is empty, the + // default curves and preferences will be used. + String property = AccessController.doPrivileged( + new GetPropertyAction("jdk.tls.namedGroups")); + if (property != null && property.length() != 0) { + // remove double quote marks from beginning/end of the property + if (property.length() > 1 && property.charAt(0) == '"' && + property.charAt(property.length() - 1) == '"') { + property = property.substring(1, property.length() - 1); + } + } + + ArrayList idList; + if (property != null && property.length() != 0) { // customized curves + String[] curves = property.split(","); + idList = new ArrayList<>(curves.length); + for (String curve : curves) { + curve = curve.trim(); + if (!curve.isEmpty()) { + NamedEllipticCurve namedCurve = + NamedEllipticCurve.getCurve(curve, requireFips); + if (namedCurve != null) { + if (isAvailableCurve(namedCurve.id)) { + idList.add(namedCurve.id); + } + } // ignore unknown curves + } + } + } else { // default curves + int[] ids; + if (requireFips) { + ids = new int[] { + // only NIST curves in FIPS mode + 23, 24, 25, 9, 10, 11, 12, 13, 14, + }; + } else { + ids = new int[] { + // NIST curves first + 23, 24, 25, 9, 10, 11, 12, 13, 14, + // non-NIST curves + 22, + }; + } + + idList = new ArrayList<>(ids.length); + for (int curveId : ids) { + if (isAvailableCurve(curveId)) { + idList.add(curveId); + } + } + } + + if (idList.isEmpty()) { + throw new IllegalArgumentException( + "System property jdk.tls.namedGroups(" + property + ") " + + "contains no supported elliptic curves"); + } else { + supportedCurveIds = new int[idList.size()]; + int i = 0; + for (Integer id : idList) { + supportedCurveIds[i++] = id; + } + } + } + + // check whether the curve is supported by the underlying providers + private static boolean isAvailableCurve(int curveId) { + String oid = idToOidMap.get(curveId); + if (oid != null) { + AlgorithmParameters params = null; + try { + params = JsseJce.getAlgorithmParameters("EC"); + params.init(new ECGenParameterSpec(oid)); + } catch (Exception e) { + return false; + } + + // cache the parameters + idToParams.put(curveId, params); + + return true; + } + + return false; + } private EllipticCurvesExtension(int[] curveIds) { super(ExtensionType.EXT_ELLIPTIC_CURVES); + this.curveIds = curveIds; } EllipticCurvesExtension(HandshakeInStream s, int len) throws IOException { super(ExtensionType.EXT_ELLIPTIC_CURVES); + int k = s.getInt16(); if (((len & 1) != 0) || (k + 2 != len)) { throw new SSLProtocolException("Invalid " + type + " extension"); } + + // Note: unknown curves will be ignored later. curveIds = new int[k >> 1]; for (int i = 0; i < curveIds.length; i++) { curveIds[i] = s.getInt16(); } } + // get the preferred active curve + static int getActiveCurves(AlgorithmConstraints constraints) { + return getPreferredCurve(supportedCurveIds, constraints); + } + + static boolean hasActiveCurves(AlgorithmConstraints constraints) { + return getActiveCurves(constraints) >= 0; + } + + static EllipticCurvesExtension createExtension( + AlgorithmConstraints constraints) { + + ArrayList idList = new ArrayList<>(supportedCurveIds.length); + for (int curveId : supportedCurveIds) { + if (constraints.permits( + EnumSet.of(CryptoPrimitive.KEY_AGREEMENT), + "EC", idToParams.get(curveId))) { + idList.add(curveId); + } + } + + if (!idList.isEmpty()) { + int[] ids = new int[idList.size()]; + int i = 0; + for (Integer id : idList) { + ids[i++] = id; + } + + return new EllipticCurvesExtension(ids); + } + + return null; + } + + // get the preferred activated curve + int getPreferredCurve(AlgorithmConstraints constraints) { + return getPreferredCurve(curveIds, constraints); + } + + // get a preferred activated curve + private static int getPreferredCurve(int[] curves, + AlgorithmConstraints constraints) { + for (int curveId : curves) { + if (constraints.permits( + EnumSet.of(CryptoPrimitive.KEY_AGREEMENT), + "EC", idToParams.get(curveId))) { + return curveId; + } + } + + return -1; + } + boolean contains(int index) { for (int curveId : curveIds) { if (index == curveId) { @@ -88,12 +301,6 @@ final class EllipticCurvesExtension extends HelloExtension { return false; } - // Return a reference to the internal curveIds array. - // The caller must NOT modify the contents. - int[] curveIds() { - return curveIds; - } - @Override int length() { return 6 + (curveIds.length << 1); @@ -122,17 +329,9 @@ final class EllipticCurvesExtension extends HelloExtension { sb.append(", "); } // first check if it is a known named curve, then try other cases. - String oid = getCurveOid(curveId); - if (oid != null) { - ECParameterSpec spec = JsseJce.getECParameterSpec(oid); - // this toString() output will look nice for the current - // implementation of the ECParameterSpec class in the Sun - // provider, but may not look good for other implementations. - if (spec != null) { - sb.append(spec.toString().split(" ")[0]); - } else { - sb.append(oid); - } + String curveName = getCurveName(curveId); + if (curveName != null) { + sb.append(curveName); } else if (curveId == ARBITRARY_PRIME) { sb.append("arbitrary_explicit_prime_curves"); } else if (curveId == ARBITRARY_CHAR2) { @@ -145,16 +344,15 @@ final class EllipticCurvesExtension extends HelloExtension { return sb.toString(); } - // Test whether we support the curve with the given index. + // Test whether the given curve is supported. static boolean isSupported(int index) { - if ((index <= 0) || (index >= NAMED_CURVE_OID_TABLE.length)) { - return false; + for (int curveId : supportedCurveIds) { + if (index == curveId) { + return true; + } } - if (fips == false) { - // in non-FIPS mode, we support all valid indices - return true; - } - return DEFAULT.contains(index); + + return false; } static int getCurveIndex(ECParameterSpec params) { @@ -162,57 +360,32 @@ final class EllipticCurvesExtension extends HelloExtension { if (oid == null) { return -1; } - Integer n = curveIndices.get(oid); + Integer n = oidToIdMap.get(oid); return (n == null) ? -1 : n; } static String getCurveOid(int index) { - if ((index > 0) && (index < NAMED_CURVE_OID_TABLE.length)) { - return NAMED_CURVE_OID_TABLE[index]; + return idToOidMap.get(index); + } + + static ECGenParameterSpec getECGenParamSpec(int index) { + AlgorithmParameters params = idToParams.get(index); + try { + return params.getParameterSpec(ECGenParameterSpec.class); + } catch (InvalidParameterSpecException ipse) { + // should be unlikely + String curveOid = getCurveOid(index); + return new ECGenParameterSpec(curveOid); } + } + + private static String getCurveName(int index) { + for (NamedEllipticCurve namedCurve : NamedEllipticCurve.values()) { + if (namedCurve.id == index) { + return namedCurve.name; + } + } + return null; } - - private static final int ARBITRARY_PRIME = 0xff01; - private static final int ARBITRARY_CHAR2 = 0xff02; - - // See sun.security.util.NamedCurve for the OIDs - private static final String[] NAMED_CURVE_OID_TABLE = new String[] { - null, // (0) unused - "1.3.132.0.1", // (1) sect163k1, NIST K-163 - "1.3.132.0.2", // (2) sect163r1 - "1.3.132.0.15", // (3) sect163r2, NIST B-163 - "1.3.132.0.24", // (4) sect193r1 - "1.3.132.0.25", // (5) sect193r2 - "1.3.132.0.26", // (6) sect233k1, NIST K-233 - "1.3.132.0.27", // (7) sect233r1, NIST B-233 - "1.3.132.0.3", // (8) sect239k1 - "1.3.132.0.16", // (9) sect283k1, NIST K-283 - "1.3.132.0.17", // (10) sect283r1, NIST B-283 - "1.3.132.0.36", // (11) sect409k1, NIST K-409 - "1.3.132.0.37", // (12) sect409r1, NIST B-409 - "1.3.132.0.38", // (13) sect571k1, NIST K-571 - "1.3.132.0.39", // (14) sect571r1, NIST B-571 - "1.3.132.0.9", // (15) secp160k1 - "1.3.132.0.8", // (16) secp160r1 - "1.3.132.0.30", // (17) secp160r2 - "1.3.132.0.31", // (18) secp192k1 - "1.2.840.10045.3.1.1", // (19) secp192r1, NIST P-192 - "1.3.132.0.32", // (20) secp224k1 - "1.3.132.0.33", // (21) secp224r1, NIST P-224 - "1.3.132.0.10", // (22) secp256k1 - "1.2.840.10045.3.1.7", // (23) secp256r1, NIST P-256 - "1.3.132.0.34", // (24) secp384r1, NIST P-384 - "1.3.132.0.35", // (25) secp521r1, NIST P-521 - }; - - private static final Map curveIndices; - - static { - curveIndices = new HashMap(); - for (int i = 1; i < NAMED_CURVE_OID_TABLE.length; i++) { - curveIndices.put(NAMED_CURVE_OID_TABLE[i], i); - } - } - } diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/HandshakeMessage.java b/jdk/src/java.base/share/classes/sun/security/ssl/HandshakeMessage.java index 2ef416964ef..b3740cfcd86 100644 --- a/jdk/src/java.base/share/classes/sun/security/ssl/HandshakeMessage.java +++ b/jdk/src/java.base/share/classes/sun/security/ssl/HandshakeMessage.java @@ -313,11 +313,6 @@ static final class ClientHello extends HandshakeMessage { this.cookie = null; } - if (cipherSuites.containsEC()) { - extensions.add(EllipticCurvesExtension.DEFAULT); - extensions.add(EllipticPointFormatsExtension.DEFAULT); - } - clnt_random = new RandomCookie(generator); compression_methods = NULL_COMPRESSION; } diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/Handshaker.java b/jdk/src/java.base/share/classes/sun/security/ssl/Handshaker.java index d9441526400..2e309dc8bb5 100644 --- a/jdk/src/java.base/share/classes/sun/security/ssl/Handshaker.java +++ b/jdk/src/java.base/share/classes/sun/security/ssl/Handshaker.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -660,13 +660,42 @@ abstract class Handshaker { ArrayList suites = new ArrayList<>(); if (!(activeProtocols.collection().isEmpty()) && activeProtocols.min.v != ProtocolVersion.NONE.v) { + boolean checkedCurves = false; + boolean hasCurves = false; for (CipherSuite suite : enabledCipherSuites.collection()) { if (!activeProtocols.min.obsoletes(suite) && activeProtocols.max.supports(suite)) { if (algorithmConstraints.permits( EnumSet.of(CryptoPrimitive.KEY_AGREEMENT), suite.name, null)) { - suites.add(suite); + + boolean available = true; + if (suite.keyExchange.isEC) { + if (!checkedCurves) { + hasCurves = EllipticCurvesExtension + .hasActiveCurves(algorithmConstraints); + checkedCurves = true; + + if (!hasCurves && debug != null && + Debug.isOn("verbose")) { + System.out.println( + "No available elliptic curves"); + } + } + + available = hasCurves; + + if (!available && debug != null && + Debug.isOn("verbose")) { + System.out.println( + "No active elliptic curves, ignore " + + suite); + } + } + + if (available) { + suites.add(suite); + } } } else if (debug != null && Debug.isOn("verbose")) { if (activeProtocols.min.obsoletes(suite)) { @@ -703,6 +732,8 @@ abstract class Handshaker { ProtocolList getActiveProtocols() { if (activeProtocols == null) { boolean enabledSSL20Hello = false; + boolean checkedCurves = false; + boolean hasCurves = false; ArrayList protocols = new ArrayList<>(4); for (ProtocolVersion protocol : enabledProtocols.collection()) { // Need not to check the SSL20Hello protocol. @@ -729,9 +760,36 @@ abstract class Handshaker { if (algorithmConstraints.permits( EnumSet.of(CryptoPrimitive.KEY_AGREEMENT), suite.name, null)) { - protocols.add(protocol); - found = true; - break; + + boolean available = true; + if (suite.keyExchange.isEC) { + if (!checkedCurves) { + hasCurves = EllipticCurvesExtension + .hasActiveCurves(algorithmConstraints); + checkedCurves = true; + + if (!hasCurves && debug != null && + Debug.isOn("verbose")) { + System.out.println( + "No activated elliptic curves"); + } + } + + available = hasCurves; + + if (!available && debug != null && + Debug.isOn("verbose")) { + System.out.println( + "No active elliptic curves, ignore " + + suite + " for " + protocol); + } + } + + if (available) { + protocols.add(protocol); + found = true; + break; + } } else if (debug != null && Debug.isOn("verbose")) { System.out.println( "Ignoring disabled cipher suite: " + suite + diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/JsseJce.java b/jdk/src/java.base/share/classes/sun/security/ssl/JsseJce.java index aebc7c09c08..76b9da5973c 100644 --- a/jdk/src/java.base/share/classes/sun/security/ssl/JsseJce.java +++ b/jdk/src/java.base/share/classes/sun/security/ssl/JsseJce.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -275,6 +275,15 @@ final class JsseJce { } } + static AlgorithmParameters getAlgorithmParameters(String algorithm) + throws NoSuchAlgorithmException { + if (cryptoProvider == null) { + return AlgorithmParameters.getInstance(algorithm); + } else { + return AlgorithmParameters.getInstance(algorithm, cryptoProvider); + } + } + static SecureRandom getSecureRandom() throws KeyManagementException { if (cryptoProvider == null) { return new SecureRandom(); @@ -394,6 +403,7 @@ final class JsseJce { JsseJce.getKeyAgreement("ECDH"); JsseJce.getKeyFactory("EC"); JsseJce.getKeyPairGenerator("EC"); + JsseJce.getAlgorithmParameters("EC"); } catch (Exception e) { mediator = false; } diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/ServerHandshaker.java b/jdk/src/java.base/share/classes/sun/security/ssl/ServerHandshaker.java index 72fc39cf24f..10df67d2eaa 100644 --- a/jdk/src/java.base/share/classes/sun/security/ssl/ServerHandshaker.java +++ b/jdk/src/java.base/share/classes/sun/security/ssl/ServerHandshaker.java @@ -94,7 +94,8 @@ final class ServerHandshaker extends Handshaker { // we remember it for the RSA premaster secret version check private ProtocolVersion clientRequestedVersion; - private EllipticCurvesExtension supportedCurves; + // client supported elliptic curves + private EllipticCurvesExtension requestedCurves; // the preferable signature algorithm used by ServerKeyExchange message SignatureAndHashAlgorithm preferableSignatureAlgorithm; @@ -741,7 +742,7 @@ final class ServerHandshaker extends Handshaker { throw new SSLException("Client did not resume a session"); } - supportedCurves = (EllipticCurvesExtension) + requestedCurves = (EllipticCurvesExtension) mesg.extensions.get(ExtensionType.EXT_ELLIPTIC_CURVES); // We only need to handle the "signature_algorithm" extension @@ -1572,26 +1573,15 @@ final class ServerHandshaker extends Handshaker { // If we cannot continue because we do not support any of the curves that // the client requested, return false. Otherwise (all is well), return true. private boolean setupEphemeralECDHKeys() { - int index = -1; - if (supportedCurves != null) { - // if the client sent the supported curves extension, pick the - // first one that we support; - for (int curveId : supportedCurves.curveIds()) { - if (EllipticCurvesExtension.isSupported(curveId)) { - index = curveId; - break; - } - } - if (index < 0) { - // no match found, cannot use this ciphersuite - return false; - } - } else { - // pick our preference - index = EllipticCurvesExtension.DEFAULT.curveIds()[0]; + int index = (requestedCurves != null) ? + requestedCurves.getPreferredCurve(algorithmConstraints) : + EllipticCurvesExtension.getActiveCurves(algorithmConstraints); + if (index < 0) { + // no match found, cannot use this ciphersuite + return false; } - String oid = EllipticCurvesExtension.getCurveOid(index); - ecdh = new ECDHCrypt(oid, sslContext.getSecureRandom()); + + ecdh = new ECDHCrypt(index, sslContext.getSecureRandom()); return true; } @@ -1633,18 +1623,16 @@ final class ServerHandshaker extends Handshaker { return false; } // For ECC certs, check whether we support the EC domain parameters. - // If the client sent a EllipticCurves ClientHello extension, + // If the client sent a SupportedEllipticCurves ClientHello extension, // check against that too. if (keyAlgorithm.equals("EC")) { if (publicKey instanceof ECPublicKey == false) { return false; } ECParameterSpec params = ((ECPublicKey)publicKey).getParams(); - int index = EllipticCurvesExtension.getCurveIndex(params); - if (!EllipticCurvesExtension.isSupported(index)) { - return false; - } - if ((supportedCurves != null) && !supportedCurves.contains(index)) { + int id = EllipticCurvesExtension.getCurveIndex(params); + if ((id <= 0) || !EllipticCurvesExtension.isSupported(id) || + ((requestedCurves != null) && !requestedCurves.contains(id))) { return false; } } diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/SunJSSE.java b/jdk/src/java.base/share/classes/sun/security/ssl/SunJSSE.java index 6e4a1a76f82..6e66c00e2af 100644 --- a/jdk/src/java.base/share/classes/sun/security/ssl/SunJSSE.java +++ b/jdk/src/java.base/share/classes/sun/security/ssl/SunJSSE.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -237,6 +237,8 @@ public abstract class SunJSSE extends java.security.Provider { "sun.security.pkcs12.PKCS12KeyStore"); } + // com.sun.net.ssl.internal.ssl.Provider has been deprecated since JDK 9 + @SuppressWarnings("deprecation") private void subclassCheck() { if (getClass() != com.sun.net.ssl.internal.ssl.Provider.class) { throw new AssertionError("Illegal subclass: " + getClass()); diff --git a/jdk/src/java.base/share/classes/sun/security/util/CertConstraintParameters.java b/jdk/src/java.base/share/classes/sun/security/util/CertConstraintParameters.java index 00a94c53950..23880f7c6aa 100644 --- a/jdk/src/java.base/share/classes/sun/security/util/CertConstraintParameters.java +++ b/jdk/src/java.base/share/classes/sun/security/util/CertConstraintParameters.java @@ -25,6 +25,7 @@ package sun.security.util; +import java.security.Timestamp; import java.security.cert.X509Certificate; import java.util.Date; @@ -40,16 +41,19 @@ public class CertConstraintParameters { private final boolean trustedMatch; // PKIXParameter date private final Date pkixDate; + // Timestamp of the signed JAR file + private final Timestamp jarTimestamp; public CertConstraintParameters(X509Certificate c, boolean match, - Date pkixdate) { + Date pkixdate, Timestamp jarTime) { cert = c; trustedMatch = match; pkixDate = pkixdate; + jarTimestamp = jarTime; } public CertConstraintParameters(X509Certificate c) { - this(c, false, null); + this(c, false, null, null); } // Returns if the trust anchor has a match if anchor checking is enabled. @@ -65,4 +69,8 @@ public class CertConstraintParameters { return pkixDate; } + public Timestamp getJARTimestamp() { + return jarTimestamp; + } + } diff --git a/jdk/src/java.base/share/classes/sun/security/util/DisabledAlgorithmConstraints.java b/jdk/src/java.base/share/classes/sun/security/util/DisabledAlgorithmConstraints.java index f0b89564094..6f8d6d4757f 100644 --- a/jdk/src/java.base/share/classes/sun/security/util/DisabledAlgorithmConstraints.java +++ b/jdk/src/java.base/share/classes/sun/security/util/DisabledAlgorithmConstraints.java @@ -594,7 +594,9 @@ public class DisabledAlgorithmConstraints extends AbstractAlgorithmConstraints { throws CertPathValidatorException { Date currentDate; - if (cp.getPKIXParamDate() != null) { + if (cp.getJARTimestamp() != null) { + currentDate = cp.getJARTimestamp().getTimestamp(); + } else if (cp.getPKIXParamDate() != null) { currentDate = cp.getPKIXParamDate(); } else { currentDate = new Date(); diff --git a/jdk/src/java.base/share/classes/sun/security/validator/PKIXValidator.java b/jdk/src/java.base/share/classes/sun/security/validator/PKIXValidator.java index 2846b2234d0..8d63ea2b8f5 100644 --- a/jdk/src/java.base/share/classes/sun/security/validator/PKIXValidator.java +++ b/jdk/src/java.base/share/classes/sun/security/validator/PKIXValidator.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -33,6 +33,7 @@ import java.security.cert.*; import javax.security.auth.x500.X500Principal; import sun.security.action.GetBooleanAction; import sun.security.provider.certpath.AlgorithmChecker; +import sun.security.provider.certpath.PKIXTimestampParameters; /** * Validator implementation built on the PKIX CertPath API. This @@ -194,13 +195,23 @@ public final class PKIXValidator extends Validator { ("null or zero-length certificate chain"); } + // Check if 'parameter' affects 'pkixParameters' + PKIXBuilderParameters pkixParameters = null; + if (parameter instanceof Timestamp && plugin) { + try { + pkixParameters = new PKIXTimestampParameters( + (PKIXBuilderParameters) parameterTemplate.clone(), + (Timestamp) parameter); + } catch (InvalidAlgorithmParameterException e) { + // ignore exception + } + } else { + pkixParameters = (PKIXBuilderParameters) parameterTemplate.clone(); + } + // add new algorithm constraints checker - PKIXBuilderParameters pkixParameters = - (PKIXBuilderParameters) parameterTemplate.clone(); - AlgorithmChecker algorithmChecker = null; if (constraints != null) { - algorithmChecker = new AlgorithmChecker(constraints); - pkixParameters.addCertPathChecker(algorithmChecker); + pkixParameters.addCertPathChecker(new AlgorithmChecker(constraints)); } // attach it to the PKIXBuilderParameters. diff --git a/jdk/src/java.base/share/classes/sun/security/validator/Validator.java b/jdk/src/java.base/share/classes/sun/security/validator/Validator.java index c6b43aba837..c57c9711bea 100644 --- a/jdk/src/java.base/share/classes/sun/security/validator/Validator.java +++ b/jdk/src/java.base/share/classes/sun/security/validator/Validator.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -221,13 +221,6 @@ public abstract class Validator { * Validate the given certificate chain. If otherCerts is non-null, it is * a Collection of additional X509Certificates that could be helpful for * path building. - *

      - * Parameter is an additional parameter with variant specific meaning. - * Currently, it is only defined for TLS_SERVER variant validators, where - * it must be non null and the name of the TLS key exchange algorithm being - * used (see JSSE X509TrustManager specification). In the future, it - * could be used to pass in a PKCS#7 object for code signing to check time - * stamps. * * @return a non-empty chain that was used to validate the path. The * end entity cert is at index 0, the trust anchor at index n-1. @@ -254,12 +247,12 @@ public abstract class Validator { * represented with a zero-length byte array. * @param constraints algorithm constraints for certification path * processing - * @param parameter an additional parameter with variant specific meaning. - * Currently, it is only defined for TLS_SERVER variant validators, - * where it must be non null and the name of the TLS key exchange - * algorithm being used (see JSSE X509TrustManager specification). - * In the future, it could be used to pass in a PKCS#7 object for - * code signing to check time stamps. + * @param parameter an additional parameter object to pass specific data. + * This parameter object maybe one of the two below: + * 1) TLS_SERVER variant validators, where it must be non null and + * the name of the TLS key exchange algorithm being used + * (see JSSE X509TrustManager specification). + * 2) {@code Timestamp} object from a signed JAR file. * @return a non-empty chain that was used to validate the path. The * end entity cert is at index 0, the trust anchor at index n-1. */ diff --git a/jdk/src/java.base/share/conf/security/java.security b/jdk/src/java.base/share/conf/security/java.security index 269a8cb0198..4f2628cc04c 100644 --- a/jdk/src/java.base/share/conf/security/java.security +++ b/jdk/src/java.base/share/conf/security/java.security @@ -653,7 +653,7 @@ krb5.kdc.bad.policy = tryLast # # jdk.certpath.disabledAlgorithms=MD2, MD5, RSA keySize < 1024, \ - DSA keySize < 1024 + DSA keySize < 1024, EC keySize < 224 # Algorithm restrictions for Secure Socket Layer/Transport Layer Security # (SSL/TLS/DTLS) processing @@ -681,7 +681,8 @@ jdk.certpath.disabledAlgorithms=MD2, MD5, RSA keySize < 1024, \ # # Example: # jdk.tls.disabledAlgorithms=MD5, SSLv3, DSA, RSA keySize < 2048 -jdk.tls.disabledAlgorithms=SSLv3, RC4, MD5withRSA, DH keySize < 1024 +jdk.tls.disabledAlgorithms=SSLv3, RC4, MD5withRSA, DH keySize < 1024, \ + EC keySize < 224 # Legacy algorithms for Secure Socket Layer/Transport Layer Security (SSL/TLS) # processing in JSSE implementation. diff --git a/jdk/src/java.base/unix/classes/java/lang/ClassLoaderHelper.java b/jdk/src/java.base/unix/classes/java/lang/ClassLoaderHelper.java index 8edd60ef360..40aeba7357a 100644 --- a/jdk/src/java.base/unix/classes/java/lang/ClassLoaderHelper.java +++ b/jdk/src/java.base/unix/classes/java/lang/ClassLoaderHelper.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2015 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it diff --git a/jdk/src/java.base/windows/classes/java/lang/ClassLoaderHelper.java b/jdk/src/java.base/windows/classes/java/lang/ClassLoaderHelper.java index d99f5fff14c..4dbf03565c5 100644 --- a/jdk/src/java.base/windows/classes/java/lang/ClassLoaderHelper.java +++ b/jdk/src/java.base/windows/classes/java/lang/ClassLoaderHelper.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2015 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it diff --git a/jdk/src/java.desktop/macosx/classes/com/apple/laf/ScreenMenu.java b/jdk/src/java.desktop/macosx/classes/com/apple/laf/ScreenMenu.java index 5ad93e40555..a1e408fa808 100644 --- a/jdk/src/java.desktop/macosx/classes/com/apple/laf/ScreenMenu.java +++ b/jdk/src/java.desktop/macosx/classes/com/apple/laf/ScreenMenu.java @@ -110,6 +110,7 @@ final class ScreenMenu extends Menu final Component[] items = fInvoker.getMenuComponents(); if (needsUpdate(items, childHashArray)) { removeAll(); + fItems.clear(); if (count <= 0) return; childHashArray = new int[count]; @@ -246,7 +247,7 @@ final class ScreenMenu extends Menu synchronized (getTreeLock()) { super.addNotify(); if (fModelPtr == 0) { - fInvoker.addContainerListener(this); + fInvoker.getPopupMenu().addContainerListener(this); fInvoker.addComponentListener(this); fPropertyListener = new ScreenMenuPropertyListener(this); fInvoker.addPropertyChangeListener(fPropertyListener); @@ -281,7 +282,7 @@ final class ScreenMenu extends Menu if (fModelPtr != 0) { removeMenuListeners(fModelPtr); fModelPtr = 0; - fInvoker.removeContainerListener(this); + fInvoker.getPopupMenu().removeContainerListener(this); fInvoker.removeComponentListener(this); fInvoker.removePropertyChangeListener(fPropertyListener); } @@ -302,11 +303,10 @@ final class ScreenMenu extends Menu @Override public void componentRemoved(final ContainerEvent e) { final Component child = e.getChild(); - final MenuItem sm = fItems.get(child); + final MenuItem sm = fItems.remove(child); if (sm == null) return; remove(sm); - fItems.remove(sm); } /** diff --git a/jdk/src/java.desktop/macosx/classes/sun/lwawt/macosx/CPlatformResponder.java b/jdk/src/java.desktop/macosx/classes/sun/lwawt/macosx/CPlatformResponder.java index 8d8c00b6a19..67896a59521 100644 --- a/jdk/src/java.desktop/macosx/classes/sun/lwawt/macosx/CPlatformResponder.java +++ b/jdk/src/java.desktop/macosx/classes/sun/lwawt/macosx/CPlatformResponder.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -34,6 +34,7 @@ import java.awt.event.MouseEvent; import java.awt.event.InputEvent; import java.awt.event.MouseWheelEvent; import java.awt.event.KeyEvent; +import java.util.Locale; /** * Translates NSEvents/NPCocoaEvents into AWT events. @@ -170,6 +171,16 @@ final class CPlatformResponder { } } + // If Pinyin Simplified input method is selected, CAPS_LOCK key is supposed to switch + // input to latin letters. + // It is necessary to use testCharIgnoringModifiers instead of testChar for event + // generation in such case to avoid uppercase letters in text components. + LWCToolkit lwcToolkit = (LWCToolkit)Toolkit.getDefaultToolkit(); + if (lwcToolkit.getLockingKeyState(KeyEvent.VK_CAPS_LOCK) && + Locale.SIMPLIFIED_CHINESE.equals(lwcToolkit.getDefaultKeyboardLocale())) { + testChar = testCharIgnoringModifiers; + } + jkeyCode = out[0]; jkeyLocation = out[1]; jeventType = isNpapiCallback ? NSEvent.npToJavaEventType(eventType) : diff --git a/jdk/src/java.desktop/macosx/classes/sun/lwawt/macosx/CPlatformWindow.java b/jdk/src/java.desktop/macosx/classes/sun/lwawt/macosx/CPlatformWindow.java index 5fcc2384e3c..2842e02fd1e 100644 --- a/jdk/src/java.desktop/macosx/classes/sun/lwawt/macosx/CPlatformWindow.java +++ b/jdk/src/java.desktop/macosx/classes/sun/lwawt/macosx/CPlatformWindow.java @@ -51,6 +51,7 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo private static native void nativeSetNSWindowMenuBar(long nsWindowPtr, long menuBarPtr); private static native Insets nativeGetNSWindowInsets(long nsWindowPtr); private static native void nativeSetNSWindowBounds(long nsWindowPtr, double x, double y, double w, double h); + private static native void nativeSetNSWindowLocationByPlatform(long nsWindowPtr); private static native void nativeSetNSWindowStandardFrame(long nsWindowPtr, double x, double y, double w, double h); private static native void nativeSetNSWindowMinMax(long nsWindowPtr, double minW, double minH, double maxW, double maxH); @@ -530,6 +531,10 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo boolean wasMaximized = isMaximized(); + if (visible && target.isLocationByPlatform()) { + nativeSetNSWindowLocationByPlatform(getNSWindowPtr()); + } + // Actually show or hide the window LWWindowPeer blocker = (peer == null)? null : peer.getBlocker(); if (blocker == null || !visible) { diff --git a/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTEvent.m b/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTEvent.m index e57074ee74c..1c2e14d931c 100644 --- a/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTEvent.m +++ b/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTEvent.m @@ -131,7 +131,7 @@ const keyTable[] = {0x3A, NO, KL_UNKNOWN, java_awt_event_KeyEvent_VK_ALT}, // **** {0x3B, NO, KL_UNKNOWN, java_awt_event_KeyEvent_VK_CONTROL}, // **** {0x3C, NO, KL_UNKNOWN, java_awt_event_KeyEvent_VK_UNDEFINED}, - {0x3D, NO, KL_UNKNOWN, java_awt_event_KeyEvent_VK_UNDEFINED}, + {0x3D, NO, KL_UNKNOWN, java_awt_event_KeyEvent_VK_ALT_GRAPH}, {0x3E, NO, KL_UNKNOWN, java_awt_event_KeyEvent_VK_UNDEFINED}, {0x3F, NO, KL_UNKNOWN, java_awt_event_KeyEvent_VK_UNDEFINED}, // the 'fn' key on PowerBooks {0x40, NO, KL_STANDARD, java_awt_event_KeyEvent_VK_F17}, @@ -293,18 +293,18 @@ const nsKeyToJavaModifierTable[] = 61, java_awt_event_InputEvent_ALT_DOWN_MASK | java_awt_event_InputEvent_ALT_GRAPH_DOWN_MASK, java_awt_event_InputEvent_ALT_MASK | java_awt_event_InputEvent_ALT_GRAPH_MASK, - java_awt_event_KeyEvent_VK_ALT - }, - { - NSCommandKeyMask, - //kCGSFlagsMaskAppleLeftCommandKey, - //kCGSFlagsMaskAppleRightCommandKey, - 55, - 54, - java_awt_event_InputEvent_META_DOWN_MASK, - java_awt_event_InputEvent_META_MASK, - java_awt_event_KeyEvent_VK_META + java_awt_event_KeyEvent_VK_ALT | java_awt_event_KeyEvent_VK_ALT_GRAPH }, + { + NSCommandKeyMask, + //kCGSFlagsMaskAppleLeftCommandKey, + //kCGSFlagsMaskAppleRightCommandKey, + 55, + 54, + java_awt_event_InputEvent_META_DOWN_MASK, + java_awt_event_InputEvent_META_MASK, + java_awt_event_KeyEvent_VK_META + }, // NSNumericPadKeyMask { NSHelpKeyMask, @@ -554,20 +554,20 @@ NsKeyModifiersToJavaKeyInfo(NSUInteger nsFlags, unsigned short eventKeyCode, */ jint NsKeyModifiersToJavaModifiers(NSUInteger nsFlags, BOOL isExtMods) { - jint javaModifiers = 0; - const struct _nsKeyToJavaModifier* cur; + jint javaModifiers = 0; + const struct _nsKeyToJavaModifier* cur; + + for (cur = nsKeyToJavaModifierTable; cur->nsMask != 0; ++cur) { + if ((cur->nsMask & nsFlags) != 0) { + javaModifiers |= isExtMods ? cur->javaExtMask : cur->javaMask; + if (cur->nsMask == NSAlternateKeyMask && leftAltKeyPressed == NO) { + continue; + } + break; + } + } - for (cur = nsKeyToJavaModifierTable; cur->nsMask != 0; ++cur) { - if ((cur->nsMask & nsFlags) != 0) { - javaModifiers |= isExtMods ? cur->javaExtMask : cur->javaMask; - if (cur->nsMask == NSAlternateKeyMask && leftAltKeyPressed == NO) { - continue; - } - break; - } - } - - return javaModifiers; + return javaModifiers; } /* diff --git a/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTView.m b/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTView.m index 119056ed562..dfe3906bf90 100644 --- a/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTView.m +++ b/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTView.m @@ -529,8 +529,10 @@ static BOOL shouldUsePressAndHold() { } -(BOOL) isCodePointInUnicodeBlockNeedingIMEvent: (unichar) codePoint { - if ((codePoint >= 0x3000) && (codePoint <= 0x303F)) { - // Code point is in 'CJK Symbols and Punctuation' Unicode block. + if (((codePoint >= 0x3000) && (codePoint <= 0x303F)) || + ((codePoint >= 0xFF00) && (codePoint <= 0xFFEF))) { + // Code point is in 'CJK Symbols and Punctuation' or + // 'Halfwidth and Fullwidth Forms' Unicode block. return YES; } return NO; diff --git a/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTWindow.m b/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTWindow.m index bc15d9bfaed..7a385a65adb 100644 --- a/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTWindow.m +++ b/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTWindow.m @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -55,6 +55,11 @@ static JNF_CLASS_CACHE(jc_CPlatformWindow, "sun/lwawt/macosx/CPlatformWindow"); // window or the app currently has no key window. static AWTWindow* lastKeyWindow = nil; +// This variable contains coordinates of a window's top left +// which was positioned via java.awt.Window.setLocationByPlatform. +// It would be NSZeroPoint if 'Location by Platform' is not used. +static NSPoint lastTopLeftPoint; + // -------------------------------------------------------------- // NSWindow/NSPanel descendants implementation #define AWT_NS_WINDOW_IMPLEMENTATION \ @@ -1082,6 +1087,31 @@ JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativeSetNSWindowSt JNF_COCOA_EXIT(env); } +/* + * Class: sun_lwawt_macosx_CPlatformWindow + * Method: nativeSetNSWindowLocationByPlatform + * Signature: (J)V + */ +JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CPlatformWindow_nativeSetNSWindowLocationByPlatform +(JNIEnv *env, jclass clazz, jlong windowPtr) +{ + JNF_COCOA_ENTER(env); + + NSWindow *nsWindow = OBJC(windowPtr); + [ThreadUtilities performOnMainThreadWaiting:NO block:^(){ + + if (NSEqualPoints(lastTopLeftPoint, NSZeroPoint)) { + // This is the first usage of lastTopLeftPoint. So invoke cascadeTopLeftFromPoint + // twice to avoid positioning the window's top left to zero-point, since it may + // cause negative user experience. + lastTopLeftPoint = [nsWindow cascadeTopLeftFromPoint:lastTopLeftPoint]; + } + lastTopLeftPoint = [nsWindow cascadeTopLeftFromPoint:lastTopLeftPoint]; + }]; + + JNF_COCOA_EXIT(env); +} + /* * Class: sun_lwawt_macosx_CPlatformWindow * Method: nativeSetNSWindowMinMax diff --git a/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/CRobot.m b/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/CRobot.m index c8bcc573b03..0de49711215 100644 --- a/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/CRobot.m +++ b/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/CRobot.m @@ -33,6 +33,7 @@ #import "LWCToolkit.h" #import "sun_lwawt_macosx_CRobot.h" #import "java_awt_event_InputEvent.h" +#import "java_awt_event_KeyEvent.h" #import "sizecalc.h" // Starting number for event numbers generated by Robot. @@ -258,26 +259,30 @@ JNIEXPORT void JNICALL Java_sun_lwawt_macosx_CRobot_keyEvent (JNIEnv *env, jobject peer, jint javaKeyCode, jboolean keyPressed) { - /* - * Well, using CGEventCreateKeyboardEvent/CGEventPost would have been - * a better solution, however, it gives me all kinds of trouble and I have - * no idea how to solve them without inserting delays between simulated - * events. So, I've ended up disabling it and opted for another approach - * that uses Accessibility API instead. - */ CGKeyCode keyCode = GetCGKeyCode(javaKeyCode); - AXUIElementRef elem = AXUIElementCreateSystemWide(); - AXUIElementPostKeyboardEvent(elem, (CGCharCode)0, keyCode, keyPressed); - CFRelease(elem); - -#if 0 - CGEventRef event = CGEventCreateKeyboardEvent(NULL, keyCode, keyPressed); - if (event != NULL) { - CGEventPost(kCGSessionEventTap, event); - CFRelease(event); + if ((javaKeyCode >= java_awt_event_KeyEvent_VK_0) && + (javaKeyCode <= java_awt_event_KeyEvent_VK_9)) + { + AXUIElementRef elem = AXUIElementCreateSystemWide(); + AXUIElementPostKeyboardEvent(elem, (CGCharCode)0, keyCode, keyPressed); + CFRelease(elem); + } else { + /* + * JDK-8155740: AXUIElementPostKeyboardEvent posts correct key codes for + * number keys whereas CGEventPost posts Numpad keys for corresponding + * number key. Hence AXUIElementPostKeyboardEvent is used for posting + * numbers and CGEventCreateKeyboardEvent/CGEventPost is used for other + * keys. + * Key code for modifier key is required to distinguish between ALT and + * ALT-GR key for fixing issue 8155740. + */ + CGEventRef event = CGEventCreateKeyboardEvent(NULL, keyCode, keyPressed); + if (event != NULL) { + CGEventPost(kCGSessionEventTap, event); + CFRelease(event); + } } -#endif } /* diff --git a/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/CRobotKeyCode.m b/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/CRobotKeyCode.m index eb19f00d922..e75648d18b8 100644 --- a/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/CRobotKeyCode.m +++ b/jdk/src/java.desktop/macosx/native/libawt_lwawt/awt/CRobotKeyCode.m @@ -53,6 +53,7 @@ [NSNumber numberWithInt : OSX_Shift], [NSNumber numberWithInt : java_awt_event_KeyEvent_VK_SHIFT], [NSNumber numberWithInt : OSX_Control], [NSNumber numberWithInt : java_awt_event_KeyEvent_VK_CONTROL], [NSNumber numberWithInt : OSX_Option], [NSNumber numberWithInt : java_awt_event_KeyEvent_VK_ALT], + [NSNumber numberWithInt : OSX_RightOption], [NSNumber numberWithInt : java_awt_event_KeyEvent_VK_ALT_GRAPH], [NSNumber numberWithInt : OSX_CapsLock], [NSNumber numberWithInt : java_awt_event_KeyEvent_VK_CAPS_LOCK], [NSNumber numberWithInt : OSX_Escape], [NSNumber numberWithInt : java_awt_event_KeyEvent_VK_ESCAPE], [NSNumber numberWithInt : OSX_kVK_Space], [NSNumber numberWithInt : java_awt_event_KeyEvent_VK_SPACE], diff --git a/jdk/src/java.desktop/macosx/native/libosxui/JRSUIConstantSync.m b/jdk/src/java.desktop/macosx/native/libosxui/JRSUIConstantSync.m index 96c9860bbb7..b3fc9f1e3e3 100644 --- a/jdk/src/java.desktop/macosx/native/libosxui/JRSUIConstantSync.m +++ b/jdk/src/java.desktop/macosx/native/libosxui/JRSUIConstantSync.m @@ -90,7 +90,7 @@ static CFTypeRef animationTimeKey = NULL; apple_laf_JRSUIConstants_ ## clazz ## __ ## constant #define CONSTANT_CHECK(clazz, constant) \ - JRS_CONSTANT(clazz, constant) == JNI_CONSTANT(clazz, constant) + ( JRS_CONSTANT(clazz, constant) == JNI_CONSTANT(clazz, constant) ) #define CONSISTENCY_CHECK(clazz, constant) \ if ( !CONSTANT_CHECK(clazz, constant) ) return NO; diff --git a/jdk/src/java.desktop/share/classes/com/sun/accessibility/internal/resources/accessibility_ko.properties b/jdk/src/java.desktop/share/classes/com/sun/accessibility/internal/resources/accessibility_ko.properties index 530caa68999..d08ac60e4b9 100644 --- a/jdk/src/java.desktop/share/classes/com/sun/accessibility/internal/resources/accessibility_ko.properties +++ b/jdk/src/java.desktop/share/classes/com/sun/accessibility/internal/resources/accessibility_ko.properties @@ -20,8 +20,8 @@ colorchooser=\uC0C9\uC0C1 \uC120\uD0DD\uAE30 columnheader=\uC5F4 \uBA38\uB9AC\uAE00 combobox=\uCF64\uBCF4 \uC0C1\uC790 canvas=\uCE94\uBC84\uC2A4 -desktopicon=\uBC14\uD0D5 \uD654\uBA74 \uC544\uC774\uCF58 -desktoppane=\uBC14\uD0D5 \uD654\uBA74 \uCC3D +desktopicon=\uBC14\uD0D5\uD654\uBA74 \uC544\uC774\uCF58 +desktoppane=\uBC14\uD0D5\uD654\uBA74 \uCC3D dialog=\uB300\uD654\uC0C1\uC790 directorypane=\uB514\uB809\uD1A0\uB9AC \uCC3D glasspane=\uAE00\uB798\uC2A4 \uCC3D diff --git a/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/bmp/BMPImageReader.java b/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/bmp/BMPImageReader.java index 5809fff5f25..2134f4b888d 100644 --- a/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/bmp/BMPImageReader.java +++ b/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/bmp/BMPImageReader.java @@ -1655,7 +1655,7 @@ public class BMPImageReader extends ImageReader implements BMPConstants { // Whenever end pixels can fit into odd number of bytes, // an extra padding byte will be present, so skip that. - if ((((int)Math.ceil(end/2)) & 1) ==1 ) { + if ((((end + 1) / 2) & 1) == 1) { count++; } break; diff --git a/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageReader.java b/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageReader.java index 1773b200f65..e7911bbea81 100644 --- a/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageReader.java +++ b/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageReader.java @@ -519,28 +519,129 @@ public class JPEGImageReader extends ImageReader { /** * Skip over a complete image in the stream, leaving the stream * positioned such that the next byte to be read is the first - * byte of the next image. For JPEG, this means that we read + * byte of the next image. For JPEG, this means that we read * until we encounter an EOI marker or until the end of the stream. - * If the stream ends before an EOI marker is encountered, an - * IndexOutOfBoundsException is thrown. + * We can find data same as EOI marker in some headers + * or comments, so we have to skip bytes related to these headers. + * If the stream ends before an EOI marker is encountered, + * an IndexOutOfBoundsException is thrown. */ private void skipImage() throws IOException { if (debug) { System.out.println("skipImage called"); } + // verify if image starts with an SOI marker + int initialFF = iis.read(); + if (initialFF == 0xff) { + int soiMarker = iis.read(); + if (soiMarker != JPEG.SOI) { + throw new IOException("skipImage : Invalid image doesn't " + + "start with SOI marker"); + } + } else { + throw new IOException("skipImage : Invalid image doesn't start " + + "with 0xff"); + } boolean foundFF = false; + String IOOBE = "skipImage : Reached EOF before we got EOI marker"; + int markerLength = 2; for (int byteval = iis.read(); byteval != -1; byteval = iis.read()) { if (foundFF == true) { - if (byteval == JPEG.EOI) { - return; + switch (byteval) { + case JPEG.EOI: + if (debug) { + System.out.println("skipImage : Found EOI at " + + (iis.getStreamPosition() - markerLength)); + } + return; + case JPEG.SOI: + throw new IOException("skipImage : Found extra SOI" + + " marker before getting to EOI"); + case 0: + // markers which doesn't contain length data + case JPEG.RST0: + case JPEG.RST1: + case JPEG.RST2: + case JPEG.RST3: + case JPEG.RST4: + case JPEG.RST5: + case JPEG.RST6: + case JPEG.RST7: + case JPEG.TEM: + break; + // markers which contains length data + case JPEG.SOF0: + case JPEG.SOF1: + case JPEG.SOF2: + case JPEG.SOF3: + case JPEG.DHT: + case JPEG.SOF5: + case JPEG.SOF6: + case JPEG.SOF7: + case JPEG.JPG: + case JPEG.SOF9: + case JPEG.SOF10: + case JPEG.SOF11: + case JPEG.DAC: + case JPEG.SOF13: + case JPEG.SOF14: + case JPEG.SOF15: + case JPEG.SOS: + case JPEG.DQT: + case JPEG.DNL: + case JPEG.DRI: + case JPEG.DHP: + case JPEG.EXP: + case JPEG.APP0: + case JPEG.APP1: + case JPEG.APP2: + case JPEG.APP3: + case JPEG.APP4: + case JPEG.APP5: + case JPEG.APP6: + case JPEG.APP7: + case JPEG.APP8: + case JPEG.APP9: + case JPEG.APP10: + case JPEG.APP11: + case JPEG.APP12: + case JPEG.APP13: + case JPEG.APP14: + case JPEG.APP15: + case JPEG.COM: + // read length of header from next 2 bytes + int lengthHigherBits, lengthLowerBits, length; + lengthHigherBits = iis.read(); + if (lengthHigherBits != (-1)) { + lengthLowerBits = iis.read(); + if (lengthLowerBits != (-1)) { + length = (lengthHigherBits << 8) | + lengthLowerBits; + // length contains already read 2 bytes + length -= 2; + } else { + throw new IndexOutOfBoundsException(IOOBE); + } + } else { + throw new IndexOutOfBoundsException(IOOBE); + } + // skip the length specified in marker + iis.skipBytes(length); + break; + case (-1): + throw new IndexOutOfBoundsException(IOOBE); + default: + throw new IOException("skipImage : Invalid marker " + + "starting with ff " + + Integer.toHexString(byteval)); } } - foundFF = (byteval == 0xff) ? true : false; + foundFF = (byteval == 0xff); } - throw new IndexOutOfBoundsException(); + throw new IndexOutOfBoundsException(IOOBE); } /** diff --git a/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/motif/MotifCheckBoxMenuItemUI.java b/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/motif/MotifCheckBoxMenuItemUI.java index 7aa206b1fc5..d377dab7344 100644 --- a/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/motif/MotifCheckBoxMenuItemUI.java +++ b/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/motif/MotifCheckBoxMenuItemUI.java @@ -89,7 +89,9 @@ public class MotifCheckBoxMenuItemUI extends BasicCheckBoxMenuItemUI Point p = e.getPoint(); if(p.x >= 0 && p.x < menuItem.getWidth() && p.y >= 0 && p.y < menuItem.getHeight()) { - manager.clearSelectedPath(); + if (UIManager.getBoolean("CheckBoxMenuItem.closeOnMouseClick")) { + manager.clearSelectedPath(); + } menuItem.doClick(0); } else { manager.processMouseEvent(e); diff --git a/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/motif/MotifRadioButtonMenuItemUI.java b/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/motif/MotifRadioButtonMenuItemUI.java index 5065b0309d8..2aa3a514309 100644 --- a/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/motif/MotifRadioButtonMenuItemUI.java +++ b/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/motif/MotifRadioButtonMenuItemUI.java @@ -97,7 +97,10 @@ public class MotifRadioButtonMenuItemUI extends BasicRadioButtonMenuItemUI Point p = e.getPoint(); if(p.x >= 0 && p.x < menuItem.getWidth() && p.y >= 0 && p.y < menuItem.getHeight()) { - manager.clearSelectedPath(); + String property = "RadioButtonMenuItem.closeOnMouseClick"; + if (UIManager.getBoolean(property)) { + manager.clearSelectedPath(); + } menuItem.doClick(0); } else { manager.processMouseEvent(e); diff --git a/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/windows/resources/windows_ko.properties b/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/windows/resources/windows_ko.properties index 75ba84419f0..f5e08f5355d 100644 --- a/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/windows/resources/windows_ko.properties +++ b/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/windows/resources/windows_ko.properties @@ -38,7 +38,7 @@ FileChooser.detailsViewButtonAccessibleName=\uC138\uBD80\uC815\uBCF4 FileChooser.viewMenuButtonToolTipText = \uBCF4\uAE30 \uBA54\uB274 FileChooser.viewMenuButtonAccessibleName = \uBCF4\uAE30 \uBA54\uB274 FileChooser.detailsViewActionLabel.textAndMnemonic=\uC138\uBD80\uC815\uBCF4 -FileChooser.refreshActionLabel.textAndMnemonic=\uC0C8\uB85C \uACE0\uCE68 +FileChooser.refreshActionLabel.textAndMnemonic=\uC0C8\uB85C\uACE0\uCE68 FileChooser.viewMenuLabel.textAndMnemonic=\uBCF4\uAE30 FileChooser.fileNameHeader.textAndMnemonic=\uC774\uB984 FileChooser.fileSizeHeader.textAndMnemonic=\uD06C\uAE30 diff --git a/jdk/src/java.desktop/share/classes/com/sun/swing/internal/plaf/metal/resources/metal_ko.properties b/jdk/src/java.desktop/share/classes/com/sun/swing/internal/plaf/metal/resources/metal_ko.properties index 06bedaa27b6..765ad3f0f73 100644 --- a/jdk/src/java.desktop/share/classes/com/sun/swing/internal/plaf/metal/resources/metal_ko.properties +++ b/jdk/src/java.desktop/share/classes/com/sun/swing/internal/plaf/metal/resources/metal_ko.properties @@ -36,7 +36,7 @@ FileChooser.listViewActionLabel.textAndMnemonic=\uBAA9\uB85D FileChooser.detailsViewButtonToolTip.textAndMnemonic=\uC138\uBD80\uC815\uBCF4 FileChooser.detailsViewButtonAccessibleName=\uC138\uBD80\uC815\uBCF4 FileChooser.detailsViewActionLabel.textAndMnemonic=\uC138\uBD80\uC815\uBCF4 -FileChooser.refreshActionLabel.textAndMnemonic=\uC0C8\uB85C \uACE0\uCE68 +FileChooser.refreshActionLabel.textAndMnemonic=\uC0C8\uB85C\uACE0\uCE68 FileChooser.viewMenuLabel.textAndMnemonic=\uBCF4\uAE30 FileChooser.fileNameHeader.textAndMnemonic=\uC774\uB984 FileChooser.fileSizeHeader.textAndMnemonic=\uD06C\uAE30 diff --git a/jdk/src/java.desktop/share/classes/com/sun/swing/internal/plaf/synth/resources/synth_ko.properties b/jdk/src/java.desktop/share/classes/com/sun/swing/internal/plaf/synth/resources/synth_ko.properties index 9c1e35cb477..9fe28ca5f65 100644 --- a/jdk/src/java.desktop/share/classes/com/sun/swing/internal/plaf/synth/resources/synth_ko.properties +++ b/jdk/src/java.desktop/share/classes/com/sun/swing/internal/plaf/synth/resources/synth_ko.properties @@ -36,7 +36,7 @@ FileChooser.listViewActionLabel.textAndMnemonic=\uBAA9\uB85D FileChooser.detailsViewButtonToolTip.textAndMnemonic=\uC138\uBD80\uC815\uBCF4 FileChooser.detailsViewButtonAccessibleName=\uC138\uBD80\uC815\uBCF4 FileChooser.detailsViewActionLabel.textAndMnemonic=\uC138\uBD80\uC815\uBCF4 -FileChooser.refreshActionLabel.textAndMnemonic=\uC0C8\uB85C \uACE0\uCE68 +FileChooser.refreshActionLabel.textAndMnemonic=\uC0C8\uB85C\uACE0\uCE68 FileChooser.viewMenuLabel.textAndMnemonic=\uBCF4\uAE30 FileChooser.fileNameHeader.textAndMnemonic=\uC774\uB984 FileChooser.fileSizeHeader.textAndMnemonic=\uD06C\uAE30 diff --git a/jdk/src/java.desktop/share/classes/java/awt/font/TextLayout.java b/jdk/src/java.desktop/share/classes/java/awt/font/TextLayout.java index 3c23f47dfcb..1793bc73a48 100644 --- a/jdk/src/java.desktop/share/classes/java/awt/font/TextLayout.java +++ b/jdk/src/java.desktop/share/classes/java/awt/font/TextLayout.java @@ -248,7 +248,6 @@ public final class TextLayout implements Cloneable { // all are recomputed from scratch in buildCache() private TextLine.TextLineMetrics lineMetrics = null; private float visibleAdvance; - private int hashCodeCache; /* * TextLayouts are supposedly immutable. If you mutate a TextLayout under @@ -722,9 +721,6 @@ public final class TextLayout implements Cloneable { naturalBounds = null; boundsRect = null; - // hashCode will be regenerated on demand - hashCodeCache = 0; - cacheIsValid = true; } @@ -2568,34 +2564,9 @@ public final class TextLayout implements Cloneable { return hitTestChar(x, y, getNaturalBounds()); } - /** - * Returns the hash code of this {@code TextLayout}. - * @return the hash code of this {@code TextLayout}. - */ - public int hashCode() { - if (hashCodeCache == 0) { - ensureCache(); - hashCodeCache = textLine.hashCode(); - } - return hashCodeCache; - } - - /** - * Returns {@code true} if the specified {@code Object} is a - * {@code TextLayout} object and if the specified {@code Object} - * equals this {@code TextLayout}. - * @param obj an {@code Object} to test for equality - * @return {@code true} if the specified {@code Object} - * equals this {@code TextLayout}; {@code false} - * otherwise. - */ - public boolean equals(Object obj) { - return (obj instanceof TextLayout) && equals((TextLayout)obj); - } - /** * Returns {@code true} if the two layouts are equal. - * Two layouts are equal if they contain equal glyphvectors in the same order. + * Obeys the general contract of {@link java.lang.Object equals(Object)}. * @param rhs the {@code TextLayout} to compare to this * {@code TextLayout} * @return {@code true} if the specified {@code TextLayout} @@ -2603,16 +2574,7 @@ public final class TextLayout implements Cloneable { * */ public boolean equals(TextLayout rhs) { - - if (rhs == null) { - return false; - } - if (rhs == this) { - return true; - } - - ensureCache(); - return textLine.equals(rhs.textLine); + return equals((Object)rhs); } /** diff --git a/jdk/src/java.desktop/share/classes/java/awt/font/TextLine.java b/jdk/src/java.desktop/share/classes/java/awt/font/TextLine.java index c1c4e899997..bb19ae1678f 100644 --- a/jdk/src/java.desktop/share/classes/java/awt/font/TextLine.java +++ b/jdk/src/java.desktop/share/classes/java/awt/font/TextLine.java @@ -880,11 +880,6 @@ final class TextLine { return dstShape; } - public int hashCode() { - return (fComponents.length << 16) ^ - (fComponents[0].hashCode() << 3) ^ (fCharsLimit-fCharsStart); - } - public String toString() { StringBuilder buf = new StringBuilder(); diff --git a/jdk/src/java.desktop/share/classes/javax/swing/DefaultDesktopManager.java b/jdk/src/java.desktop/share/classes/javax/swing/DefaultDesktopManager.java index 0a41c36d9a0..8046037e471 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/DefaultDesktopManager.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/DefaultDesktopManager.java @@ -194,17 +194,15 @@ public class DefaultDesktopManager implements DesktopManager, java.io.Serializab int layer = JLayeredPane.getLayer(f); JLayeredPane.putLayer(desktopIcon, layer); } - + d.setComponentOrderCheckingEnabled(true); + c.remove(f); + c.add(desktopIcon); if (findNext) { if (d.selectFrame(true) == null) { // The icon is the last frame. f.restoreSubcomponentFocus(); } } - d.setComponentOrderCheckingEnabled(false); - c.remove(f); - c.add(desktopIcon); - d.setComponentOrderCheckingEnabled(true); c.repaint(f.getX(), f.getY(), f.getWidth(), f.getHeight()); } diff --git a/jdk/src/java.desktop/share/classes/javax/swing/JCheckBoxMenuItem.java b/jdk/src/java.desktop/share/classes/javax/swing/JCheckBoxMenuItem.java index f37a6db0083..39757f4a9dd 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/JCheckBoxMenuItem.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/JCheckBoxMenuItem.java @@ -56,6 +56,15 @@ import javax.accessibility.*; * href="http://docs.oracle.com/javase/tutorial/uiswing/misc/action.html">How * to Use Actions, a section in The Java Tutorial. *

      + * Some times it is required to select several check box menu items from a menu. + * In this case it is useful that clicking on one check box menu item does not + * close the menu. Such behavior can be controlled by the Look and Feel property + * named {@code "CheckBoxMenuItem.closeOnMouseClick"}. The default value is + * {@code true}. Setting the property to {@code false} prevents the menu from + * closing when it is clicked by the mouse. + * Note: some {@code L&F}s may ignore this property. All built-in {@code L&F}s + * inherit this behaviour. + *

      * For further information and examples of using check box menu items, * see How to Use Menus, diff --git a/jdk/src/java.desktop/share/classes/javax/swing/JComboBox.java b/jdk/src/java.desktop/share/classes/javax/swing/JComboBox.java index 17d9e64d91f..2faca04ad50 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/JComboBox.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/JComboBox.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -1240,19 +1240,22 @@ implements ItemSelectable,ListDataListener,ActionListener, Accessible { } else if (currentEvent instanceof ActionEvent) { modifiers = ((ActionEvent)currentEvent).getModifiers(); } - // Process the listeners last to first, notifying - // those that are interested in this event - for ( int i = listeners.length-2; i>=0; i-=2 ) { - if ( listeners[i]==ActionListener.class ) { - // Lazily create the event: - if ( e == null ) - e = new ActionEvent(this,ActionEvent.ACTION_PERFORMED, - getActionCommand(), - mostRecentEventTime, modifiers); - ((ActionListener)listeners[i+1]).actionPerformed(e); + try { + // Process the listeners last to first, notifying + // those that are interested in this event + for ( int i = listeners.length-2; i>=0; i-=2 ) { + if ( listeners[i]==ActionListener.class ) { + // Lazily create the event: + if ( e == null ) + e = new ActionEvent(this,ActionEvent.ACTION_PERFORMED, + getActionCommand(), + mostRecentEventTime, modifiers); + ((ActionListener)listeners[i+1]).actionPerformed(e); + } } + } finally { + firingActionEvent = false; } - firingActionEvent = false; } } diff --git a/jdk/src/java.desktop/share/classes/javax/swing/JComponent.java b/jdk/src/java.desktop/share/classes/javax/swing/JComponent.java index f6c3486d077..3d6025407d9 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/JComponent.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/JComponent.java @@ -844,9 +844,10 @@ public abstract class JComponent extends Container implements Serializable, Rectangle cr; cr = comp.getBounds(tmpRect); - - boolean hitClip = g.hitClip(cr.x, cr.y, cr.width, - cr.height); + Shape clip = g.getClip(); + boolean hitClip = (clip != null) + ? clip.intersects(cr.x, cr.y, cr.width, cr.height) + : true; if (hitClip) { if (checkSiblings && i > 0) { diff --git a/jdk/src/java.desktop/share/classes/javax/swing/JEditorPane.java b/jdk/src/java.desktop/share/classes/javax/swing/JEditorPane.java index 1829f16e39a..c8aad16e84e 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/JEditorPane.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/JEditorPane.java @@ -1185,7 +1185,7 @@ public class JEditorPane extends JTextComponent { if (k == null) { // try to dynamically load the support String classname = getKitTypeRegistry().get(type); - ClassLoader loader = getKitLoaderRegistry().get(type).orElse(null); + ClassLoader loader = getKitLoaderRegistry().get(type); try { Class c; if (loader != null) { @@ -1242,7 +1242,11 @@ public class JEditorPane extends JTextComponent { */ public static void registerEditorKitForContentType(String type, String classname, ClassLoader loader) { getKitTypeRegistry().put(type, classname); - getKitLoaderRegistry().put(type, Optional.ofNullable(loader)); + if (loader != null) { + getKitLoaderRegistry().put(type, loader); + } else { + getKitLoaderRegistry().remove(type); + } getKitRegisty().remove(type); } @@ -1267,10 +1271,10 @@ public class JEditorPane extends JTextComponent { return tmp; } - private static Hashtable> getKitLoaderRegistry() { + private static Hashtable getKitLoaderRegistry() { loadDefaultKitsIfNecessary(); @SuppressWarnings("unchecked") - Hashtable> tmp = + Hashtable tmp = (Hashtable)SwingUtilities.appContextGet(kitLoaderRegistryKey); return tmp; } diff --git a/jdk/src/java.desktop/share/classes/javax/swing/JRadioButtonMenuItem.java b/jdk/src/java.desktop/share/classes/javax/swing/JRadioButtonMenuItem.java index 34a6cb7e0e5..f73ee417d5e 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/JRadioButtonMenuItem.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/JRadioButtonMenuItem.java @@ -50,6 +50,15 @@ import javax.accessibility.*; * href="http://docs.oracle.com/javase/tutorial/uiswing/misc/action.html">How * to Use Actions, a section in The Java Tutorial. *

      + * Some menus can have several button groups with radio button menu items. In + * this case it is useful that clicking on one radio button menu item does not + * close the menu. Such behavior can be controlled by the Look and Feel property + * named {@code "RadioButtonMenuItem.closeOnMouseClick"}. The default value is + * {@code true}. Setting the property to {@code false} prevents the menu from + * closing when it is clicked by the mouse. + * Note: some {@code L&F}s may ignore this property. All built-in {@code L&F}s + * inherit this behaviour. + *

      * For further documentation and examples see * How to Use Menus, diff --git a/jdk/src/java.desktop/share/classes/javax/swing/ProgressMonitor.java b/jdk/src/java.desktop/share/classes/javax/swing/ProgressMonitor.java index c1fb3a24d50..7ba435075b5 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/ProgressMonitor.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/ProgressMonitor.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -369,16 +369,24 @@ public class ProgressMonitor implements Accessible /** - * Returns true if the user hits the Cancel button in the progress dialog. + * Returns true if the user hits the Cancel button or closes + * the progress dialog. * - * @return true if the user hits the Cancel button in the progress dialog + * @return true if the user hits the Cancel button or closes + * the progress dialog */ public boolean isCanceled() { - if (pane == null) return false; + if (pane == null) { + return false; + } + Object v = pane.getValue(); - return ((v != null) && - (cancelOption.length == 1) && - (v.equals(cancelOption[0]))); + if (v == null) { + return false; + } + + return (((cancelOption.length == 1) && v.equals(cancelOption[0])) || + v.equals(Integer.valueOf(JOptionPane.CLOSED_OPTION))); } diff --git a/jdk/src/java.desktop/share/classes/javax/swing/ToolTipManager.java b/jdk/src/java.desktop/share/classes/javax/swing/ToolTipManager.java index b25c877cc94..b9a602b44ba 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/ToolTipManager.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/ToolTipManager.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -231,12 +231,10 @@ public class ToolTipManager extends MouseAdapter implements MouseMotionListener GraphicsEnvironment env = GraphicsEnvironment.getLocalGraphicsEnvironment(); GraphicsDevice devices[] = env.getScreenDevices(); for (GraphicsDevice device : devices) { - GraphicsConfiguration configs[] = device.getConfigurations(); - for (GraphicsConfiguration config : configs) { - Rectangle rect = config.getBounds(); - if (rect.contains(toFind)) { - return config; - } + GraphicsConfiguration config = device.getDefaultConfiguration(); + Rectangle rect = config.getBounds(); + if (rect.contains(toFind)) { + return config; } } diff --git a/jdk/src/java.desktop/share/classes/javax/swing/colorchooser/DiagramComponent.java b/jdk/src/java.desktop/share/classes/javax/swing/colorchooser/DiagramComponent.java index 61f8047f746..1a25dd8c4c2 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/colorchooser/DiagramComponent.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/colorchooser/DiagramComponent.java @@ -60,7 +60,8 @@ final class DiagramComponent extends JComponent implements MouseListener, MouseM getInsets(this.insets); this.width = getWidth() - this.insets.left - this.insets.right; this.height = getHeight() - this.insets.top - this.insets.bottom; - + if ((this.width <= 0) || (this.height <= 0)) + return; boolean update = (this.image == null) || (this.width != this.image.getWidth()) || (this.height != this.image.getHeight()); diff --git a/jdk/src/java.desktop/share/classes/javax/swing/plaf/TextUI.java b/jdk/src/java.desktop/share/classes/javax/swing/plaf/TextUI.java index 6332d1ddc23..3ce2e8925f9 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/plaf/TextUI.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/plaf/TextUI.java @@ -24,11 +24,10 @@ */ package javax.swing.plaf; -import javax.swing.Action; -import javax.swing.BoundedRangeModel; import java.awt.Point; import java.awt.Rectangle; -import java.awt.Insets; +import java.awt.geom.Point2D; +import java.awt.geom.Rectangle2D; import javax.swing.text.*; /** @@ -63,6 +62,27 @@ public abstract class TextUI extends ComponentUI */ public abstract Rectangle modelToView(JTextComponent t, int pos, Position.Bias bias) throws BadLocationException; + /** + * Converts the given location in the model to a place in + * the view coordinate system. + * + * @implSpec This implementation calls + * {@link #modelToView(JTextComponent, int, Position.Bias) modelToView(t, pos, bias)}. + * + * @param t the text component for which this UI is installed + * @param pos the local location in the model to translate {@code >= 0} + * @param bias the bias for the position + * @return the coordinates as a {@code Rectangle2D} + * @exception BadLocationException if the given position does not + * represent a valid location in the associated document + * + * @since 9 + */ + public Rectangle2D modelToView2D(JTextComponent t, int pos, Position.Bias bias) + throws BadLocationException { + return modelToView(t, pos, bias); + } + /** * Converts the given place in the view coordinate system * to the nearest representative location in the model. @@ -94,6 +114,33 @@ public abstract class TextUI extends ComponentUI public abstract int viewToModel(JTextComponent t, Point pt, Position.Bias[] biasReturn); + /** + * Provides a mapping from the view coordinate space to the logical + * coordinate space of the model. + * + * @implSpec This implementation calls + * {@link #viewToModel(JTextComponent, Point, Position.Bias[]) + * viewToModel(t, new Point((int) pt.getX(), (int) pt.getY()), + * biasReturn)}. + * + * @param t the text component for which this UI is installed + * @param pt the location in the view to translate. + * @param biasReturn + * filled in by this method to indicate whether + * the point given is closer to the previous or the next + * character in the model + * + * @return the location within the model that best represents the + * given point in the view {@code >= 0} + * + * @since 9 + */ + public int viewToModel2D(JTextComponent t, Point2D pt, + Position.Bias[] biasReturn) { + return viewToModel(t, new Point((int) pt.getX(), (int) pt.getY()), + biasReturn); + } + /** * Provides a way to determine the next visually represented model * location that one might place a caret. Some views may not be visible, @@ -179,4 +226,22 @@ public abstract class TextUI extends ComponentUI public String getToolTipText(JTextComponent t, Point pt) { return null; } + /** + * Returns the string to be used as the tooltip at the passed in location. + * + * @implSpec This implementation calls + * {@link #getToolTipText(JTextComponent, Point) + * getToolTipText(t, new Point((int) pt.getX(), (int) pt.getY())))}. + * + * @param t the text component for which this UI is installed + * @param pt a {@code Point} specifying location for which to get a tooltip + * @return a {@code String} containing the tooltip + * + * @see javax.swing.text.JTextComponent#getToolTipText + * + * @since 9 + */ + public String getToolTipText2D(JTextComponent t, Point2D pt) { + return getToolTipText(t, new Point((int) pt.getX(), (int) pt.getY())); + } } diff --git a/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicComboPopup.java b/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicComboPopup.java index 63a54b7caa7..f2b72e006b8 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicComboPopup.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicComboPopup.java @@ -1049,6 +1049,8 @@ public class BasicComboPopup extends JPopupMenu implements ComboPopup { @SuppressWarnings("unchecked") JComboBox comboBox = (JComboBox)e.getSource(); setListSelection(comboBox.getSelectedIndex()); + } else { + setListSelection(-1); } } diff --git a/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicGraphicsUtils.java b/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicGraphicsUtils.java index 941f09b28fb..fa6c0c9c61a 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicGraphicsUtils.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicGraphicsUtils.java @@ -31,10 +31,10 @@ import java.awt.Dimension; import java.awt.Font; import java.awt.FontMetrics; import java.awt.Graphics; +import java.awt.Graphics2D; import java.awt.Insets; import java.awt.Rectangle; import java.awt.Toolkit; -import java.awt.event.KeyEvent; import java.awt.event.InputEvent; import sun.swing.SwingUtilities2; @@ -386,4 +386,102 @@ public class BasicGraphicsUtils return (event.getModifiers() & Toolkit.getDefaultToolkit().getMenuShortcutKeyMask()) != 0; } + + /** + * Draws the given string at the specified location using text properties + * and anti-aliasing hints from the provided component. + * Nothing is drawn for the null string. + * + * @param c the component that will display the string, may be null + * @param g the graphics context, must not be null + * @param string the string to display, may be null + * @param x the x coordinate to draw the text at + * @param y the y coordinate to draw the text at + * @throws NullPointerException if the specified {@code g} is {@code null} + * + * @since 9 + */ + public static void drawString(JComponent c, Graphics2D g, String string, + float x, float y) { + SwingUtilities2.drawString(c, g, string, (int) x, (int) y); + } + + /** + * Draws the given string at the specified location underlining + * the specified character. The provided component is used to query text + * properties and anti-aliasing hints. + *

      + * The {@code underlinedIndex} parameter points to a char value + * (Unicode code unit) in the given string. + * If the char value specified at the underlined index is in + * the high-surrogate range and the char value at the following index is in + * the low-surrogate range then the supplementary character corresponding + * to this surrogate pair is underlined. + *

      + * No character is underlined if the index is negative or greater + * than the string length {@code (index < 0 || index >= string.length())} + * or if the char value specified at the given index + * is in the low-surrogate range. + * + * @param c the component that will display the string, may be null + * @param g the graphics context, must not be null + * @param string the string to display, may be null + * @param underlinedIndex index of a a char value (Unicode code unit) + * in the string to underline + * @param x the x coordinate to draw the text at + * @param y the y coordinate to draw the text at + * @throws NullPointerException if the specified {@code g} is {@code null} + * + * @see #getStringWidth + * + * @since 9 + */ + public static void drawStringUnderlineCharAt(JComponent c, Graphics2D g, + String string, int underlinedIndex, float x, float y) { + SwingUtilities2.drawStringUnderlineCharAt(c, g, string, underlinedIndex, + (int) x, (int) y); + } + + /** + * Clips the passed in string to the space provided. + * The provided component is used to query text properties and anti-aliasing hints. + * The unchanged string is returned if the space provided is greater than + * the string width. + * + * @param c the component, may be null + * @param fm the FontMetrics used to measure the string width, must be + * obtained from the correct font and graphics. Must not be null. + * @param string the string to clip, may be null + * @param availTextWidth the amount of space that the string can be drawn in + * @return the clipped string that fits in the provided space, an empty + * string if the given string argument is {@code null} or empty + * @throws NullPointerException if the specified {@code fm} is {@code null} + * + * @see #getStringWidth + * + * @since 9 + */ + public static String getClippedString(JComponent c, FontMetrics fm, + String string, int availTextWidth) { + return SwingUtilities2.clipStringIfNecessary(c, fm, string, availTextWidth); + } + + /** + * Returns the width of the passed in string using text properties + * and anti-aliasing hints from the provided component. + * If the passed string is {@code null}, returns zero. + * + * @param c the component, may be null + * @param fm the FontMetrics used to measure the advance string width, must + * be obtained from the correct font and graphics. Must not be null. + * @param string the string to get the advance width of, may be null + * @return the advance width of the specified string, zero is returned for + * {@code null} string + * @throws NullPointerException if the specified {@code fm} is {@code null} + * + * @since 9 + */ + public static float getStringWidth(JComponent c, FontMetrics fm, String string) { + return SwingUtilities2.stringWidth(c, fm, string); + } } diff --git a/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicLookAndFeel.java b/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicLookAndFeel.java index 6b8beeeafe3..ffbcd89fa85 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicLookAndFeel.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicLookAndFeel.java @@ -1055,6 +1055,7 @@ public abstract class BasicLookAndFeel extends LookAndFeel implements Serializab "RadioButtonMenuItem.checkIcon", radioButtonMenuItemIcon, "RadioButtonMenuItem.arrowIcon", menuItemArrowIcon, "RadioButtonMenuItem.commandSound", null, + "RadioButtonMenuItem.closeOnMouseClick", Boolean.TRUE, "CheckBoxMenuItem.font", dialogPlain12, "CheckBoxMenuItem.acceleratorFont", dialogPlain12, @@ -1071,6 +1072,7 @@ public abstract class BasicLookAndFeel extends LookAndFeel implements Serializab "CheckBoxMenuItem.checkIcon", checkBoxMenuItemIcon, "CheckBoxMenuItem.arrowIcon", menuItemArrowIcon, "CheckBoxMenuItem.commandSound", null, + "CheckBoxMenuItem.closeOnMouseClick", Boolean.TRUE, "Menu.font", dialogPlain12, "Menu.acceleratorFont", dialogPlain12, diff --git a/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuItemUI.java b/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuItemUI.java index 718fadc9070..27bcb103e3f 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuItemUI.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuItemUI.java @@ -936,6 +936,15 @@ public class BasicMenuItemUI extends MenuItemUI } } + boolean closeOnMouseClick() { + if (menuItem instanceof JCheckBoxMenuItem) { + return UIManager.getBoolean("CheckBoxMenuItem.closeOnMouseClick"); + } else if (menuItem instanceof JRadioButtonMenuItem) { + return UIManager.getBoolean("RadioButtonMenuItem.closeOnMouseClick"); + } + return true; + } + /** * Call this method when a menu item is to be activated. * This method handles some of the details of menu item activation @@ -958,11 +967,14 @@ public class BasicMenuItemUI extends MenuItemUI BasicLookAndFeel.playSound(menuItem, getPropertyPrefix() + ".commandSound"); } - // Visual feedback - if (msm == null) { - msm = MenuSelectionManager.defaultManager(); + if (closeOnMouseClick()) { + // Visual feedback + if (msm == null) { + msm = MenuSelectionManager.defaultManager(); + } + + msm.clearSelectedPath(); } - msm.clearSelectedPath(); menuItem.doClick(0); } diff --git a/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicTableUI.java b/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicTableUI.java index e6a3d0eb9b5..ffa4e603950 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicTableUI.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicTableUI.java @@ -1856,7 +1856,9 @@ public class BasicTableUI extends TableUI // otherwise 1 extra row is printed per page than that are displayed // when there is no scrollPane and we do printing of table // but not when rmax is already pointing to index of last row - if (rMax != (table.getRowCount() - 1)) { + // and if there is any selected rows + if (rMax != (table.getRowCount() - 1) && + (table.getSelectedRow() == -1)) { rMax = rMax - 1; } } diff --git a/jdk/src/java.desktop/share/classes/javax/swing/plaf/nimbus/skin.laf b/jdk/src/java.desktop/share/classes/javax/swing/plaf/nimbus/skin.laf index 208a3b03301..da41a8ba051 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/plaf/nimbus/skin.laf +++ b/jdk/src/java.desktop/share/classes/javax/swing/plaf/nimbus/skin.laf @@ -13407,7 +13407,7 @@ false NO_CACHING - + @@ -13513,10 +13513,10 @@ - + + + + 2 + + + 1.0 + 1.0 + NORMAL + false + true + + + + + + + + + + 2 + + + 1.0 + 1.0 + NORMAL + false + true + + + + + diff --git a/jdk/src/java.desktop/share/classes/javax/swing/text/PasswordView.java b/jdk/src/java.desktop/share/classes/javax/swing/text/PasswordView.java index 61dfbf997eb..c5a4fed9146 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/text/PasswordView.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/text/PasswordView.java @@ -138,6 +138,26 @@ public class PasswordView extends FieldView { return x + g.getFontMetrics().charWidth(c); } + /** + * Renders the echo character, or whatever graphic should be used + * to display the password characters. The color in the Graphics + * object is set to the appropriate foreground color for selected + * or unselected text. + * + * @implSpec This implementation calls + * {@link #drawEchoCharacter(Graphics, int, int, char) + * drawEchoCharacter((Graphics) g, (int) x, (int) y, c)}. + * + * @param g the graphics context + * @param x the starting X coordinate {@code >= 0} + * @param y the starting Y coordinate {@code >= 0} + * @param c the echo character + * @return the updated X position {@code >= 0} + */ + protected float drawEchoCharacter(Graphics2D g, float x, float y, char c) { + return drawEchoCharacter((Graphics) g, (int) x, (int) y, c); + } + /** * Provides a mapping from the document model coordinate space * to the coordinate space of the view mapped to it. diff --git a/jdk/src/java.desktop/share/classes/javax/swing/text/PlainView.java b/jdk/src/java.desktop/share/classes/javax/swing/text/PlainView.java index bf1a933aa4e..a4efd018508 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/text/PlainView.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/text/PlainView.java @@ -27,6 +27,7 @@ package javax.swing.text; import java.util.Vector; import java.util.Properties; import java.awt.*; +import java.util.Objects; import javax.swing.event.*; /** @@ -59,6 +60,17 @@ public class PlainView extends View implements TabExpander { return size; } + /** + * Returns the tab size set for the document, defaulting to 8. + * + * @implSpec This implementation calls {@link #getTabSize() getTabSize()}. + * + * @return the tab size + */ + protected float getFractionalTabSize() { + return getTabSize(); + } + /** * Renders a line of text, suppressing whitespace at the end * and expanding any tabs. This is implemented to make calls @@ -93,6 +105,28 @@ public class PlainView extends View implements TabExpander { } } + /** + * Renders a line of text, suppressing whitespace at the end + * and expanding any tabs. This is implemented to make calls + * to the methods {@code drawUnselectedText} and + * {@code drawSelectedText} so that the way selected and + * unselected text are rendered can be customized. + * + * @implSpec This implementation calls + * {@link #drawLine(int, Graphics, int, int) + * drawLine(lineIndex, (Graphics)g, (int) x, (int) y)}. + * + * @param lineIndex the line to draw {@code >= 0} + * @param g the {@code Graphics} context + * @param x the starting X position {@code >= 0} + * @param y the starting Y position {@code >= 0} + * @see #drawUnselectedText + * @see #drawSelectedText + */ + protected void drawLine(int lineIndex, Graphics2D g, float x, float y) { + drawLine(lineIndex, (Graphics)g, (int) x, (int) y); + } + private int drawElement(int lineIndex, Element elem, Graphics g, int x, int y) throws BadLocationException { int p0 = elem.getStartOffset(); int p1 = elem.getEndOffset(); @@ -156,6 +190,27 @@ public class PlainView extends View implements TabExpander { return ret; } + /** + * Renders the given range in the model as normal unselected + * text. Uses the foreground or disabled color to render the text. + * + * @implSpec This implementation calls + * {@link #drawUnselectedText(Graphics, int, int, int, int) + * drawUnselectedText((Graphics)g, (int) x, (int) y, p0, p1)}. + * + * @param g the graphics context + * @param x the starting X coordinate {@code >= 0} + * @param y the starting Y coordinate {@code >= 0} + * @param p0 the beginning position in the model {@code >= 0} + * @param p1 the ending position in the model {@code >= 0} + * @return the X location of the end of the range {@code >= 0} + * @exception BadLocationException if the range is invalid + */ + protected float drawUnselectedText(Graphics2D g, float x, float y, + int p0, int p1) throws BadLocationException { + return drawUnselectedText((Graphics)g, (int) x, (int) y, p0, p1); + } + /** * Renders the given range in the model as selected text. This * is implemented to render the text in the color specified in @@ -181,6 +236,30 @@ public class PlainView extends View implements TabExpander { return ret; } + /** + * Renders the given range in the model as selected text. This + * is implemented to render the text in the color specified in + * the hosting component. It assumes the highlighter will render + * the selected background. + * + * @implSpec This implementation calls + * {@link #drawSelectedText(Graphics, int, int, int, int) + * drawSelectedText((Graphics)g, (int) x, (int) y, p0, p1)}. + * + * @param g the graphics context + * @param x the starting X coordinate {@code >= 0} + * @param y the starting Y coordinate {@code >= 0} + * @param p0 the beginning position in the model {@code >= 0} + * @param p1 the ending position in the model {@code >= 0} + * @return the location of the end of the range + * @exception BadLocationException if the range is invalid + */ + + protected float drawSelectedText(Graphics2D g, float x, + float y, int p0, int p1) throws BadLocationException { + return drawSelectedText((Graphics)g, (int) x, (int) y, p0, p1); + } + /** * Gives access to a buffer that can be used to fetch * text from the associated document. @@ -203,7 +282,8 @@ public class PlainView extends View implements TabExpander { protected void updateMetrics() { Component host = getContainer(); Font f = host.getFont(); - if (font != f) { + FontMetrics fm = (font == null) ? null : host.getFontMetrics(font); + if (font != f || !Objects.equals(metrics, fm)) { // The font changed, we need to recalculate the // longest line. calculateLongestLine(); diff --git a/jdk/src/java.desktop/share/classes/javax/swing/text/Utilities.java b/jdk/src/java.desktop/share/classes/javax/swing/text/Utilities.java index eca184ef174..bf26227ed87 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/text/Utilities.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/text/Utilities.java @@ -84,6 +84,27 @@ public class Utilities { return drawTabbedText(null, s, x, y, g, e, startOffset); } + /** + * Draws the given text, expanding any tabs that are contained + * using the given tab expansion technique. + * + * @param s the source of the text + * @param x the X origin {@code >= 0} + * @param y the Y origin {@code >= 0} + * @param g the graphics context + * @param e how to expand the tabs. If this value is null, + * tabs will be expanded as a space character. + * @param startOffset starting offset of the text in the document {@code >= 0} + * @return the X location at the end of the rendered text + */ + public static final float drawTabbedText(Segment s, float x, float y, + Graphics2D g, + TabExpander e, + int startOffset) + { + return drawTabbedText(s, (int) x, (int) y, (Graphics) g, e, startOffset); + } + /** * Draws the given text, expanding any tabs that are contained * using the given tab expansion technique. This particular @@ -208,6 +229,23 @@ public class Utilities { return getTabbedTextWidth(null, s, metrics, x, e, startOffset, null); } + /** + * Determines the width of the given segment of text taking tabs + * into consideration. + * + * @param s the source of the text + * @param metrics the font metrics to use for the calculation + * @param x the X origin {@code >= 0} + * @param e how to expand the tabs. If this value is null, + * tabs will be expanded as a space character. + * @param startOffset starting offset of the text in the document {@code >= 0} + * @return the width of the text + */ + public static final float getTabbedTextWidth(Segment s, FontMetrics metrics, + float x, TabExpander e, + int startOffset) { + return getTabbedTextWidth(s, metrics, (int) x, e, startOffset); + } // In addition to the previous method it can extend spaces for // justification. @@ -336,6 +374,34 @@ public class Utilities { return getTabbedTextOffset(null, s, metrics, x0, x, e, startOffset, round, null); } + /** + * Determines the relative offset into the given text that + * best represents the given span in the view coordinate + * system. + * + * @param s the source of the text + * @param metrics the font metrics to use for the calculation + * @param x0 the starting view location representing the start + * of the given text {@code >= 0}. + * @param x the target view location to translate to an + * offset into the text {@code >= 0}. + * @param e how to expand the tabs. If this value is null, + * tabs will be expanded as a space character. + * @param startOffset starting offset of the text in the document {@code >= 0} + * @param round whether or not to round + * @return the offset into the text {@code >= 0} + */ + public static final int getTabbedTextOffset(Segment s, + FontMetrics metrics, + float x0, float x, + TabExpander e, + int startOffset, + boolean round) + { + return getTabbedTextOffset(null, s, metrics, (int) x0, (int) x, e, + startOffset, round, null); + } + // In addition to the previous method it can extend spaces for // justification. // @@ -498,6 +564,26 @@ public class Utilities { return index; } + /** + * Determine where to break the given text to fit + * within the given span. This tries to find a word boundary. + * @param s the source of the text + * @param metrics the font metrics to use for the calculation + * @param x0 the starting view location representing the start + * of the given text. + * @param x the target view location to translate to an + * offset into the text. + * @param e how to expand the tabs. If this value is null, + * tabs will be expanded as a space character. + * @param startOffset starting offset in the document of the text + * @return the offset into the given text + */ + public static final int getBreakLocation(Segment s, FontMetrics metrics, + float x0, float x, TabExpander e, + int startOffset) { + return getBreakLocation(s, metrics, (int) x0, (int) x, e, startOffset); + } + /** * Determines the starting row model position of the row that contains * the specified model position. The component given must have a @@ -596,6 +682,24 @@ public class Utilities { return offs; } + /** + * Determines the position in the model that is closest to the given + * view location in the row above. The component given must have a + * size to compute the result. If the component doesn't have a size + * a value of -1 will be returned. + * + * @param c the editor + * @param offs the offset in the document {@code >= 0} + * @param x the X coordinate {@code >= 0} + * @return the position {@code >= 0} if the request can be computed, otherwise + * a value of -1 will be returned. + * @exception BadLocationException if the offset is out of range + */ + public static final int getPositionAbove(JTextComponent c, int offs, float x) + throws BadLocationException { + return getPositionAbove(c, offs, (int) x); + } + /** * Determines the position in the model that is closest to the given * view location in the row below. The component given must have a @@ -634,6 +738,24 @@ public class Utilities { return offs; } + /** + * Determines the position in the model that is closest to the given + * view location in the row below. The component given must have a + * size to compute the result. If the component doesn't have a size + * a value of -1 will be returned. + * + * @param c the editor + * @param offs the offset in the document {@code >= 0} + * @param x the X coordinate {@code >= 0} + * @return the position {@code >= 0} if the request can be computed, otherwise + * a value of -1 will be returned. + * @exception BadLocationException if the offset is out of range + */ + public static final int getPositionBelow(JTextComponent c, int offs, float x) + throws BadLocationException { + return getPositionBelow(c, offs, (int) x); + } + /** * Determines the start of a word for the given model location. * Uses BreakIterator.getWordInstance() to actually get the words. diff --git a/jdk/src/java.desktop/share/classes/javax/swing/text/WrappedPlainView.java b/jdk/src/java.desktop/share/classes/javax/swing/text/WrappedPlainView.java index 97ef0fe06eb..dbcc5fdd207 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/text/WrappedPlainView.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/text/WrappedPlainView.java @@ -86,6 +86,17 @@ public class WrappedPlainView extends BoxView implements TabExpander { return size; } + /** + * Returns the tab size set for the document, defaulting to 8. + * + * @implSpec This implementation calls {@link #getTabSize() getTabSize()}. + * + * @return the tab size + */ + protected float getFractionalTabSize() { + return getTabSize(); + } + /** * Renders a line of text, suppressing whitespace at the end * and expanding any tabs. This is implemented to make calls @@ -125,6 +136,29 @@ public class WrappedPlainView extends BoxView implements TabExpander { } } + /** + * Renders a line of text, suppressing whitespace at the end + * and expanding any tabs. This is implemented to make calls + * to the methods drawUnselectedText and + * drawSelectedText so that the way selected and + * unselected text are rendered can be customized. + * + * @implSpec This implementation calls + * {@link #drawLine(int, int, Graphics, int, int) + * drawLine(p0, p1, (Graphics) g, (int) x, (int) y)}. + * + * @param p0 the starting document location to use >= 0 + * @param p1 the ending document location to use >= p1 + * @param g the graphics context + * @param x the starting X position >= 0 + * @param y the starting Y position >= 0 + * @see #drawUnselectedText + * @see #drawSelectedText + */ + protected void drawLine(int p0, int p1, Graphics2D g, float x, float y) { + drawLine(p0, p1, (Graphics) g, (int) x, (int) y); + } + private int drawText(Element elem, int p0, int p1, Graphics g, int x, int y) throws BadLocationException { p1 = Math.min(getDocument().getLength(), p1); AttributeSet attr = elem.getAttributes(); @@ -183,6 +217,26 @@ public class WrappedPlainView extends BoxView implements TabExpander { return ret; } + /** + * Renders the given range in the model as normal unselected + * text. + * + * @implSpec This implementation calls + * {@link #drawUnselectedText(Graphics, int, int, int, int) + * drawUnselectedText((Graphics)g, (int) x, (int) y, p0, p1)}. + * + * @param g the graphics context + * @param x the starting X coordinate >= 0 + * @param y the starting Y coordinate >= 0 + * @param p0 the beginning position in the model >= 0 + * @param p1 the ending position in the model >= p0 + * @return the X location of the end of the range >= 0 + * @exception BadLocationException if the range is invalid + */ + protected float drawUnselectedText(Graphics2D g, float x, float y, + int p0, int p1) throws BadLocationException { + return drawUnselectedText((Graphics) g, (int) x, (int) y, p0, p1); + } /** * Renders the given range in the model as selected text. This * is implemented to render the text in the color specified in @@ -208,6 +262,28 @@ public class WrappedPlainView extends BoxView implements TabExpander { return ret; } + /** + * Renders the given range in the model as selected text. This + * is implemented to render the text in the color specified in + * the hosting component. It assumes the highlighter will render + * the selected background. + * + * @implSpec This implementation calls + * {@link #drawSelectedText(Graphics, int, int, int, int) + * drawSelectedText((Graphics)g, (int) x, (int) y, p0, p1)}. + * + * @param g the graphics context + * @param x the starting X coordinate >= 0 + * @param y the starting Y coordinate >= 0 + * @param p0 the beginning position in the model >= 0 + * @param p1 the ending position in the model >= p0 + * @return the location of the end of the range. + * @exception BadLocationException if the range is invalid + */ + protected float drawSelectedText(Graphics2D g, float x, float y, + int p0, int p1) throws BadLocationException { + return drawSelectedText((Graphics) g, (int) x, (int) y, p0, p1); + } /** * Gives access to a buffer that can be used to fetch * text from the associated document. diff --git a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_de.java b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_de.java index a89a8a04b37..b13bbdd182e 100644 --- a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_de.java +++ b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_de.java @@ -73,7 +73,7 @@ public class MsgAppletViewer_de extends ListResourceBundle { {"appletviewer.parse.warning.embed.requiresheight", "Warnung: F\u00FCr -Tag ist ein \"height\"-Attribut erforderlich."}, {"appletviewer.parse.warning.embed.requireswidth", "Warnung: F\u00FCr -Tag ist ein \"width\"-Attribut erforderlich."}, {"appletviewer.parse.warning.appnotLongersupported", "Warnung: -Tag wird nicht mehr unterst\u00FCtzt. Verwenden Sie stattdessen :"}, - {"appletviewer.deprecated", "AppletViewer ist veraltet."}, + {"appletviewer.deprecated", "Warnung: Applet-API und AppletViewer sind veraltet."}, {"appletviewer.usage", "Verwendung: appletviewer url(s)\n\nwobei die Folgendes umfassen:\n -encoding Zeichencodierung f\u00FCr HTML-Dateien angeben\n -J Argument an den Java-Interpreter \u00FCbergeben\n\nDie Option \"-J\" ist nicht standardm\u00E4\u00DFig und kann ohne vorherige Ank\u00FCndigung ge\u00E4ndert werden."}, {"appletviewer.main.err.unsupportedopt", "Nicht unterst\u00FCtzte Option: {0}"}, {"appletviewer.main.err.unrecognizedarg", "Unbekanntes Argument: {0}"}, diff --git a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_es.java b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_es.java index 579e67a48e6..330a98986e4 100644 --- a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_es.java +++ b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_es.java @@ -73,7 +73,7 @@ public class MsgAppletViewer_es extends ListResourceBundle { {"appletviewer.parse.warning.embed.requiresheight", "Advertencia: la etiqueta requiere el atributo height."}, {"appletviewer.parse.warning.embed.requireswidth", "Advertencia: la etiqueta requiere el atributo width."}, {"appletviewer.parse.warning.appnotLongersupported", "Advertencia: la etiqueta ya no est\u00E1 soportada, utilice en su lugar:"}, - {"appletviewer.deprecated", "AppletViewer est\u00E1 anticuado."}, + {"appletviewer.deprecated", "Advertencia: la API de applet y AppletViewer est\u00E1n anticuados."}, {"appletviewer.usage", "Sintaxis: appletviewer url(s)\n\ndonde incluye:\n -encoding Especificar la codificaci\u00F3n de caracteres utilizada por los archivos HTML\n -J Transferir argumento al int\u00E9rprete de Java\n\nLa opci\u00F3n -J es no est\u00E1ndar y est\u00E1 sujeta a cambios sin previo aviso."}, {"appletviewer.main.err.unsupportedopt", "Opci\u00F3n no soportada: {0}"}, {"appletviewer.main.err.unrecognizedarg", "Argumento no reconocido: {0}"}, diff --git a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_fr.java b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_fr.java index 0c86e5afd93..da7e9b201a0 100644 --- a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_fr.java +++ b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_fr.java @@ -73,7 +73,7 @@ public class MsgAppletViewer_fr extends ListResourceBundle { {"appletviewer.parse.warning.embed.requiresheight", "Avertissement : la balise requiert un attribut de hauteur."}, {"appletviewer.parse.warning.embed.requireswidth", "Avertissement : la balise requiert un attribut de largeur."}, {"appletviewer.parse.warning.appnotLongersupported", "Avertissement : la balise n'est plus prise en charge, utilisez \u00E0 la place :"}, - {"appletviewer.deprecated", "AppletViewer est en phase d'abandon."}, + {"appletviewer.deprecated", "Avertissement : l'API d'applet et AppletViewer sont en phase d'abandon."}, {"appletviewer.usage", "Syntaxe : appletviewer url(s)\n\no\u00F9 inclut :\n -encoding Indiquer l'encodage de caract\u00E8res utilis\u00E9 par les fichiers HTML\n -J Transmettre l'argument \u00E0 l'interpr\u00E9teur Java\n\nL'option -J n'est pas standard et elle peut \u00EAtre modifi\u00E9e sans pr\u00E9avis."}, {"appletviewer.main.err.unsupportedopt", "Option non prise en charge : {0}"}, {"appletviewer.main.err.unrecognizedarg", "Argument non reconnu : {0}"}, diff --git a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_it.java b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_it.java index 423b005a1d2..f0ecbaf33e8 100644 --- a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_it.java +++ b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_it.java @@ -73,7 +73,7 @@ public class MsgAppletViewer_it extends ListResourceBundle { {"appletviewer.parse.warning.embed.requiresheight", "Avvertenza: la tag richiede un attributo height."}, {"appletviewer.parse.warning.embed.requireswidth", "Avvertenza: la tag richiede un attributo width."}, {"appletviewer.parse.warning.appnotLongersupported", "Avvertenza: la tag non \u00E8 pi\u00F9 supportata. Utilizzare :"}, - {"appletviewer.deprecated", "AppletViewer non pi\u00F9 valido."}, + {"appletviewer.deprecated", "Avvertenza: l'API dell'applet e AppletViewer non sono pi\u00F9 validi."}, {"appletviewer.usage", "Uso: appletviewer url(s)\n\ndove includono:\n -encoding Specifica la codifica dei caratteri utilizzata dai file HTML\n -J Passa l'argomento all'interpreter Java\n\nL'opzione -J non \u00E8 standard ed \u00E8 soggetta a modifica senza preavviso."}, {"appletviewer.main.err.unsupportedopt", "Opzione non supportata: {0}"}, {"appletviewer.main.err.unrecognizedarg", "Argomento non riconosciuto: {0}"}, diff --git a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_ja.java b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_ja.java index 2c35c2e6406..03a02508497 100644 --- a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_ja.java +++ b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_ja.java @@ -73,7 +73,7 @@ public class MsgAppletViewer_ja extends ListResourceBundle { {"appletviewer.parse.warning.embed.requiresheight", "\u8B66\u544A: \u30BF\u30B0\u306Bheight\u5C5E\u6027\u304C\u5FC5\u8981\u3067\u3059\u3002"}, {"appletviewer.parse.warning.embed.requireswidth", "\u8B66\u544A: \u30BF\u30B0\u306Bwidth\u5C5E\u6027\u304C\u5FC5\u8981\u3067\u3059\u3002"}, {"appletviewer.parse.warning.appnotLongersupported", "\u8B66\u544A: \u30BF\u30B0\u306F\u73FE\u5728\u306F\u30B5\u30DD\u30FC\u30C8\u3055\u308C\u3066\u3044\u307E\u305B\u3093\u3002\u304B\u308F\u308A\u306B\u3092\u4F7F\u7528\u3057\u3066\u304F\u3060\u3055\u3044\u3002"}, - {"appletviewer.deprecated", "AppletViewer\u306F\u975E\u63A8\u5968\u3067\u3059\u3002"}, + {"appletviewer.deprecated", "\u8B66\u544A: \u30A2\u30D7\u30EC\u30C3\u30C8API\u304A\u3088\u3073AppletViewer\u306F\u975E\u63A8\u5968\u3067\u3059\u3002"}, {"appletviewer.usage", "\u4F7F\u7528\u65B9\u6CD5: appletviewer url(s)\n\n\u306B\u306F\u6B21\u306E\u3082\u306E\u304C\u3042\u308A\u307E\u3059:\n -encoding HTML\u30D5\u30A1\u30A4\u30EB\u306B\u3088\u3063\u3066\u4F7F\u7528\u3055\u308C\u308B\u6587\u5B57\u30A8\u30F3\u30B3\u30FC\u30C7\u30A3\u30F3\u30B0\u3092\u6307\u5B9A\u3059\u308B\n -J \u5F15\u6570\u3092Java\u30A4\u30F3\u30BF\u30D7\u30EA\u30BF\u306B\u6E21\u3059\n\n-J\u306F\u975E\u6A19\u6E96\u30AA\u30D7\u30B7\u30E7\u30F3\u3067\u3042\u308A\u3001\u4E88\u544A\u306A\u3057\u306B\u5909\u66F4\u3055\u308C\u308B\u53EF\u80FD\u6027\u304C\u3042\u308A\u307E\u3059\u3002"}, {"appletviewer.main.err.unsupportedopt", "\u30B5\u30DD\u30FC\u30C8\u3055\u308C\u3066\u3044\u306A\u3044\u30AA\u30D7\u30B7\u30E7\u30F3: {0}"}, {"appletviewer.main.err.unrecognizedarg", "\u8A8D\u8B58\u3055\u308C\u306A\u3044\u5F15\u6570: {0}"}, diff --git a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_ko.java b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_ko.java index d2db1b038ca..2705f8dea7d 100644 --- a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_ko.java +++ b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_ko.java @@ -73,7 +73,7 @@ public class MsgAppletViewer_ko extends ListResourceBundle { {"appletviewer.parse.warning.embed.requiresheight", "\uACBD\uACE0: \uD0DC\uADF8\uC5D0\uB294 height \uC18D\uC131\uC774 \uD544\uC694\uD569\uB2C8\uB2E4."}, {"appletviewer.parse.warning.embed.requireswidth", "\uACBD\uACE0: \uD0DC\uADF8\uC5D0\uB294 width \uC18D\uC131\uC774 \uD544\uC694\uD569\uB2C8\uB2E4."}, {"appletviewer.parse.warning.appnotLongersupported", "\uACBD\uACE0: \uD0DC\uADF8\uB294 \uB354 \uC774\uC0C1 \uC9C0\uC6D0\uB418\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4. \uB300\uC2E0 \uC744 \uC0AC\uC6A9\uD558\uC2ED\uC2DC\uC624."}, - {"appletviewer.deprecated", "AppletViewer\uB294 \uB354 \uC774\uC0C1 \uC0AC\uC6A9\uB418\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4."}, + {"appletviewer.deprecated", "\uACBD\uACE0: \uC560\uD50C\uB9BF API \uBC0F AppletViewer\uAC00 \uC0AC\uC6A9\uB418\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4."}, {"appletviewer.usage", "\uC0AC\uC6A9\uBC95: appletviewer url(s)\n\n\uC5EC\uAE30\uC11C \uB294 \uB2E4\uC74C\uACFC \uAC19\uC2B5\uB2C8\uB2E4.\n -encoding HTML \uD30C\uC77C\uC5D0 \uC0AC\uC6A9\uB420 \uBB38\uC790 \uC778\uCF54\uB529\uC744 \uC9C0\uC815\uD569\uB2C8\uB2E4.\n -J Java \uC778\uD130\uD504\uB9AC\uD130\uB85C \uC778\uC218\uB97C \uC804\uB2EC\uD569\uB2C8\uB2E4.\n\n-J \uC635\uC158\uC740 \uD45C\uC900\uC774 \uC544\uB2C8\uBA70 \uC608\uACE0 \uC5C6\uC774 \uBCC0\uACBD\uB420 \uC218 \uC788\uC2B5\uB2C8\uB2E4."}, {"appletviewer.main.err.unsupportedopt", "\uC9C0\uC6D0\uB418\uC9C0 \uC54A\uB294 \uC635\uC158: {0}"}, {"appletviewer.main.err.unrecognizedarg", "\uC54C \uC218 \uC5C6\uB294 \uC778\uC218: {0}"}, diff --git a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_pt_BR.java b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_pt_BR.java index 0bf46370169..ce91b3a1b51 100644 --- a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_pt_BR.java +++ b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_pt_BR.java @@ -73,7 +73,7 @@ public class MsgAppletViewer_pt_BR extends ListResourceBundle { {"appletviewer.parse.warning.embed.requiresheight", "Advert\u00EAncia: a tag requer um atributo de altura."}, {"appletviewer.parse.warning.embed.requireswidth", "Advert\u00EAncia: a tag requer um atributo de largura."}, {"appletviewer.parse.warning.appnotLongersupported", "Advert\u00EAncia: a tag n\u00E3o \u00E9 mais suportada; use :"}, - {"appletviewer.deprecated", "O AppletViewer est\u00E1 obsoleto."}, + {"appletviewer.deprecated", "Advert\u00EAncia: A API do e o AppletViewer est\u00E3o obsoletos."}, {"appletviewer.usage", "Uso: appletviewer url(s)\n\nem que as incluem:\n -encoding Especifica a codifica\u00E7\u00E3o de caractere usada pelos arquivos HTML\n -J Informa o argumento ao intepretador java\n\nA op\u00E7\u00E3o -J n\u00E3o \u00E9 padr\u00E3o e est\u00E1 sujeita \u00E0 altera\u00E7\u00E3o sem notifica\u00E7\u00E3o."}, {"appletviewer.main.err.unsupportedopt", "Op\u00E7\u00E3o n\u00E3o suportada: {0}"}, {"appletviewer.main.err.unrecognizedarg", "Argumento n\u00E3o reconhecido: {0}"}, diff --git a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_sv.java b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_sv.java index f21af43cbb9..f4b6eb38bd3 100644 --- a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_sv.java +++ b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_sv.java @@ -73,7 +73,7 @@ public class MsgAppletViewer_sv extends ListResourceBundle { {"appletviewer.parse.warning.embed.requiresheight", "Varning: -taggen kr\u00E4ver ett h\u00F6jdattribut."}, {"appletviewer.parse.warning.embed.requireswidth", "Varning: -taggen kr\u00E4ver ett breddattribut."}, {"appletviewer.parse.warning.appnotLongersupported", "Varning: -taggen st\u00F6ds inte l\u00E4ngre, anv\u00E4nd ist\u00E4llet:"}, - {"appletviewer.deprecated", "AppletViewer \u00E4r inaktuellt."}, + {"appletviewer.deprecated", "Varning: Applet-API:t och AppletViewer \u00E4r inaktuella."}, {"appletviewer.usage", "Syntax: appletviewer url(s)\n\nd\u00E4r \u00E4r:\n -encoding Ange teckenkodning som anv\u00E4nds av HTML-filer\n -J \u00D6verf\u00F6r argument till java-tolken\n\nAlternativet -J \u00E4r inte standard och kan \u00E4ndras utan f\u00F6reg\u00E5ende meddelande."}, {"appletviewer.main.err.unsupportedopt", "Alternativ som inte st\u00F6ds: {0}"}, {"appletviewer.main.err.unrecognizedarg", "Ok\u00E4nt argument: {0}"}, diff --git a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_zh_CN.java b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_zh_CN.java index f7c8c4f4f4d..392513f57dd 100644 --- a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_zh_CN.java +++ b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_zh_CN.java @@ -73,7 +73,7 @@ public class MsgAppletViewer_zh_CN extends ListResourceBundle { {"appletviewer.parse.warning.embed.requiresheight", "\u8B66\u544A: \u6807\u8BB0\u9700\u8981\u9AD8\u5EA6\u5C5E\u6027\u3002"}, {"appletviewer.parse.warning.embed.requireswidth", "\u8B66\u544A: \u6807\u8BB0\u9700\u8981\u5BBD\u5EA6\u5C5E\u6027\u3002"}, {"appletviewer.parse.warning.appnotLongersupported", "\u8B66\u544A: \u4E0D\u518D\u652F\u6301 \u6807\u8BB0, \u8BF7\u6539\u7528 :"}, - {"appletviewer.deprecated", "AppletViewer \u5DF2\u8FC7\u65F6\u3002"}, + {"appletviewer.deprecated", "\u8B66\u544A: \u5C0F\u5E94\u7528\u7A0B\u5E8F API \u548C AppletViewer \u5DF2\u8FC7\u65F6\u3002"}, {"appletviewer.usage", "\u7528\u6CD5: appletviewer url(s)\n\n\u5176\u4E2D \u5305\u62EC:\n -encoding \u6307\u5B9A HTML \u6587\u4EF6\u4F7F\u7528\u7684\u5B57\u7B26\u7F16\u7801\n -J \u5C06\u53C2\u6570\u4F20\u9012\u5230 java \u89E3\u91CA\u5668\n\n-J \u9009\u9879\u662F\u975E\u6807\u51C6\u9009\u9879, \u5982\u6709\u66F4\u6539, \u6055\u4E0D\u53E6\u884C\u901A\u77E5\u3002"}, {"appletviewer.main.err.unsupportedopt", "\u4E0D\u652F\u6301\u7684\u9009\u9879: {0}"}, {"appletviewer.main.err.unrecognizedarg", "\u65E0\u6CD5\u8BC6\u522B\u7684\u53C2\u6570: {0}"}, diff --git a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_zh_TW.java b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_zh_TW.java index 8ceeed399b2..d52195c2168 100644 --- a/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_zh_TW.java +++ b/jdk/src/java.desktop/share/classes/sun/applet/resources/MsgAppletViewer_zh_TW.java @@ -73,7 +73,7 @@ public class MsgAppletViewer_zh_TW extends ListResourceBundle { {"appletviewer.parse.warning.embed.requiresheight", "\u8B66\u544A: \u6A19\u8A18\u9700\u8981\u9AD8\u5EA6\u5C6C\u6027\u3002"}, {"appletviewer.parse.warning.embed.requireswidth", "\u8B66\u544A: \u6A19\u8A18\u9700\u8981\u5BEC\u5EA6\u5C6C\u6027\u3002"}, {"appletviewer.parse.warning.appnotLongersupported", "\u8B66\u544A: \u4E0D\u518D\u652F\u63F4 \u6A19\u8A18\uFF0C\u8ACB\u6539\u7528 :"}, - {"appletviewer.deprecated", "AppletViewer \u5DF2\u4E0D\u518D\u4F7F\u7528\u3002"}, + {"appletviewer.deprecated", "\u8B66\u544A: \u5DF2\u4E0D\u518D\u4F7F\u7528 Applet API \u548C AppletViewer\u3002"}, {"appletviewer.usage", "\u7528\u6CD5: appletviewer url(s)\n\n\u5176\u4E2D\u7684 \u5305\u62EC:\n -encoding \u6307\u5B9A HTML \u6A94\u6848\u4F7F\u7528\u7684\u5B57\u5143\u7DE8\u78BC\n -J \u5C07\u5F15\u6578\u50B3\u9001\u81F3 Java \u89E3\u8B6F\u5668\n\n-J \u9078\u9805\u4E0D\u662F\u6A19\u6E96\u9078\u9805\uFF0C\u82E5\u6709\u8B8A\u66F4\u4E0D\u53E6\u884C\u901A\u77E5\u3002"}, {"appletviewer.main.err.unsupportedopt", "\u4E0D\u652F\u63F4\u7684\u9078\u9805: {0}"}, {"appletviewer.main.err.unrecognizedarg", "\u7121\u6CD5\u8FA8\u8B58\u7684\u5F15\u6578: {0}"}, diff --git a/jdk/src/java.desktop/share/classes/sun/dc/DuctusRenderingEngine.java b/jdk/src/java.desktop/share/classes/sun/dc/DuctusRenderingEngine.java deleted file mode 100644 index 0355813d92d..00000000000 --- a/jdk/src/java.desktop/share/classes/sun/dc/DuctusRenderingEngine.java +++ /dev/null @@ -1,836 +0,0 @@ -/* - * Copyright (c) 2007, 2013, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package sun.dc; - -import java.awt.Shape; -import java.awt.BasicStroke; -import java.awt.geom.Path2D; -import java.awt.geom.PathIterator; -import java.awt.geom.AffineTransform; - -import sun.awt.geom.PathConsumer2D; -import sun.java2d.pipe.Region; -import sun.java2d.pipe.AATileGenerator; -import sun.java2d.pipe.RenderingEngine; - -import sun.dc.pr.Rasterizer; -import sun.dc.pr.PathStroker; -import sun.dc.pr.PathDasher; -import sun.dc.pr.PRException; -import sun.dc.path.PathConsumer; -import sun.dc.path.PathException; -import sun.dc.path.FastPathProducer; - -public class DuctusRenderingEngine extends RenderingEngine { - static final float PenUnits = 0.01f; - static final int MinPenUnits = 100; - static final int MinPenUnitsAA = 20; - static final float MinPenSizeAA = PenUnits * MinPenUnitsAA; - - static final float UPPER_BND = Float.MAX_VALUE / 2.0f; - static final float LOWER_BND = -UPPER_BND; - - private static final int RasterizerCaps[] = { - Rasterizer.BUTT, Rasterizer.ROUND, Rasterizer.SQUARE - }; - - private static final int RasterizerCorners[] = { - Rasterizer.MITER, Rasterizer.ROUND, Rasterizer.BEVEL - }; - - static float[] getTransformMatrix(AffineTransform transform) { - float matrix[] = new float[4]; - double dmatrix[] = new double[6]; - transform.getMatrix(dmatrix); - for (int i = 0; i < 4; i++) { - matrix[i] = (float) dmatrix[i]; - } - return matrix; - } - - /** - * {@inheritDoc} - */ - @Override - public Shape createStrokedShape(Shape src, - float width, - int caps, - int join, - float miterlimit, - float dashes[], - float dashphase) - { - FillAdapter filler = new FillAdapter(); - PathStroker stroker = new PathStroker(filler); - PathDasher dasher = null; - - try { - PathConsumer consumer; - - stroker.setPenDiameter(width); - stroker.setPenT4(null); - stroker.setCaps(RasterizerCaps[caps]); - stroker.setCorners(RasterizerCorners[join], miterlimit); - if (dashes != null) { - dasher = new PathDasher(stroker); - dasher.setDash(dashes, dashphase); - dasher.setDashT4(null); - consumer = dasher; - } else { - consumer = stroker; - } - - feedConsumer(consumer, src.getPathIterator(null)); - } finally { - stroker.dispose(); - if (dasher != null) { - dasher.dispose(); - } - } - - return filler.getShape(); - } - - /** - * {@inheritDoc} - */ - @Override - public void strokeTo(Shape src, - AffineTransform transform, - BasicStroke bs, - boolean thin, - boolean normalize, - boolean antialias, - PathConsumer2D sr) - { - PathStroker stroker = new PathStroker(sr); - PathConsumer consumer = stroker; - - float matrix[] = null; - if (!thin) { - stroker.setPenDiameter(bs.getLineWidth()); - if (transform != null) { - matrix = getTransformMatrix(transform); - } - stroker.setPenT4(matrix); - stroker.setPenFitting(PenUnits, MinPenUnits); - } - stroker.setCaps(RasterizerCaps[bs.getEndCap()]); - stroker.setCorners(RasterizerCorners[bs.getLineJoin()], - bs.getMiterLimit()); - float[] dashes = bs.getDashArray(); - if (dashes != null) { - PathDasher dasher = new PathDasher(stroker); - dasher.setDash(dashes, bs.getDashPhase()); - if (transform != null && matrix == null) { - matrix = getTransformMatrix(transform); - } - dasher.setDashT4(matrix); - consumer = dasher; - } - - try { - PathIterator pi = src.getPathIterator(transform); - - feedConsumer(pi, consumer, normalize, 0.25f); - } catch (PathException e) { - throw new InternalError("Unable to Stroke shape ("+ - e.getMessage()+")", e); - } finally { - while (consumer != null && consumer != sr) { - PathConsumer next = consumer.getConsumer(); - consumer.dispose(); - consumer = next; - } - } - } - - /* - * Feed a path from a PathIterator to a Ductus PathConsumer. - */ - public static void feedConsumer(PathIterator pi, PathConsumer consumer, - boolean normalize, float norm) - throws PathException - { - consumer.beginPath(); - boolean pathClosed = false; - boolean skip = false; - boolean subpathStarted = false; - float mx = 0.0f; - float my = 0.0f; - float point[] = new float[6]; - float rnd = (0.5f - norm); - float ax = 0.0f; - float ay = 0.0f; - - while (!pi.isDone()) { - int type = pi.currentSegment(point); - if (pathClosed == true) { - pathClosed = false; - if (type != PathIterator.SEG_MOVETO) { - // Force current point back to last moveto point - consumer.beginSubpath(mx, my); - subpathStarted = true; - } - } - if (normalize) { - int index; - switch (type) { - case PathIterator.SEG_CUBICTO: - index = 4; - break; - case PathIterator.SEG_QUADTO: - index = 2; - break; - case PathIterator.SEG_MOVETO: - case PathIterator.SEG_LINETO: - index = 0; - break; - case PathIterator.SEG_CLOSE: - default: - index = -1; - break; - } - if (index >= 0) { - float ox = point[index]; - float oy = point[index+1]; - float newax = (float) Math.floor(ox + rnd) + norm; - float neway = (float) Math.floor(oy + rnd) + norm; - point[index] = newax; - point[index+1] = neway; - newax -= ox; - neway -= oy; - switch (type) { - case PathIterator.SEG_CUBICTO: - point[0] += ax; - point[1] += ay; - point[2] += newax; - point[3] += neway; - break; - case PathIterator.SEG_QUADTO: - point[0] += (newax + ax) / 2; - point[1] += (neway + ay) / 2; - break; - case PathIterator.SEG_MOVETO: - case PathIterator.SEG_LINETO: - case PathIterator.SEG_CLOSE: - break; - } - ax = newax; - ay = neway; - } - } - switch (type) { - case PathIterator.SEG_MOVETO: - - /* Checking SEG_MOVETO coordinates if they are out of the - * [LOWER_BND, UPPER_BND] range. This check also handles NaN - * and Infinity values. Skipping next path segment in case of - * invalid data. - */ - if (point[0] < UPPER_BND && point[0] > LOWER_BND && - point[1] < UPPER_BND && point[1] > LOWER_BND) - { - mx = point[0]; - my = point[1]; - consumer.beginSubpath(mx, my); - subpathStarted = true; - skip = false; - } else { - skip = true; - } - break; - case PathIterator.SEG_LINETO: - /* Checking SEG_LINETO coordinates if they are out of the - * [LOWER_BND, UPPER_BND] range. This check also handles NaN - * and Infinity values. Ignoring current path segment in case - * of invalid data. If segment is skipped its endpoint - * (if valid) is used to begin new subpath. - */ - if (point[0] < UPPER_BND && point[0] > LOWER_BND && - point[1] < UPPER_BND && point[1] > LOWER_BND) - { - if (skip) { - consumer.beginSubpath(point[0], point[1]); - subpathStarted = true; - skip = false; - } else { - consumer.appendLine(point[0], point[1]); - } - } - break; - case PathIterator.SEG_QUADTO: - // Quadratic curves take two points - - /* Checking SEG_QUADTO coordinates if they are out of the - * [LOWER_BND, UPPER_BND] range. This check also handles NaN - * and Infinity values. Ignoring current path segment in case - * of invalid endpoints's data. Equivalent to the SEG_LINETO - * if endpoint coordinates are valid but there are invalid data - * among other coordinates - */ - if (point[2] < UPPER_BND && point[2] > LOWER_BND && - point[3] < UPPER_BND && point[3] > LOWER_BND) - { - if (skip) { - consumer.beginSubpath(point[2], point[3]); - subpathStarted = true; - skip = false; - } else { - if (point[0] < UPPER_BND && point[0] > LOWER_BND && - point[1] < UPPER_BND && point[1] > LOWER_BND) - { - consumer.appendQuadratic(point[0], point[1], - point[2], point[3]); - } else { - consumer.appendLine(point[2], point[3]); - } - } - } - break; - case PathIterator.SEG_CUBICTO: - // Cubic curves take three points - - /* Checking SEG_CUBICTO coordinates if they are out of the - * [LOWER_BND, UPPER_BND] range. This check also handles NaN - * and Infinity values. Ignoring current path segment in case - * of invalid endpoints's data. Equivalent to the SEG_LINETO - * if endpoint coordinates are valid but there are invalid data - * among other coordinates - */ - if (point[4] < UPPER_BND && point[4] > LOWER_BND && - point[5] < UPPER_BND && point[5] > LOWER_BND) - { - if (skip) { - consumer.beginSubpath(point[4], point[5]); - subpathStarted = true; - skip = false; - } else { - if (point[0] < UPPER_BND && point[0] > LOWER_BND && - point[1] < UPPER_BND && point[1] > LOWER_BND && - point[2] < UPPER_BND && point[2] > LOWER_BND && - point[3] < UPPER_BND && point[3] > LOWER_BND) - { - consumer.appendCubic(point[0], point[1], - point[2], point[3], - point[4], point[5]); - } else { - consumer.appendLine(point[4], point[5]); - } - } - } - break; - case PathIterator.SEG_CLOSE: - if (subpathStarted) { - consumer.closedSubpath(); - subpathStarted = false; - pathClosed = true; - } - break; - } - pi.next(); - } - - consumer.endPath(); - } - - private static Rasterizer theRasterizer; - - public static synchronized Rasterizer getRasterizer() { - Rasterizer r = theRasterizer; - if (r == null) { - r = new Rasterizer(); - } else { - theRasterizer = null; - } - return r; - } - - public static synchronized void dropRasterizer(Rasterizer r) { - r.reset(); - theRasterizer = r; - } - - /** - * {@inheritDoc} - */ - @Override - public float getMinimumAAPenSize() { - return MinPenSizeAA; - } - - /** - * {@inheritDoc} - */ - @Override - public AATileGenerator getAATileGenerator(Shape s, - AffineTransform at, - Region clip, - BasicStroke bs, - boolean thin, - boolean normalize, - int bbox[]) - { - Rasterizer r = getRasterizer(); - PathIterator pi = s.getPathIterator(at); - - if (bs != null) { - float matrix[] = null; - r.setUsage(Rasterizer.STROKE); - if (thin) { - r.setPenDiameter(MinPenSizeAA); - } else { - r.setPenDiameter(bs.getLineWidth()); - if (at != null) { - matrix = getTransformMatrix(at); - r.setPenT4(matrix); - } - r.setPenFitting(PenUnits, MinPenUnitsAA); - } - r.setCaps(RasterizerCaps[bs.getEndCap()]); - r.setCorners(RasterizerCorners[bs.getLineJoin()], - bs.getMiterLimit()); - float[] dashes = bs.getDashArray(); - if (dashes != null) { - r.setDash(dashes, bs.getDashPhase()); - if (at != null && matrix == null) { - matrix = getTransformMatrix(at); - } - r.setDashT4(matrix); - } - } else { - r.setUsage(pi.getWindingRule() == PathIterator.WIND_EVEN_ODD - ? Rasterizer.EOFILL - : Rasterizer.NZFILL); - } - - r.beginPath(); - { - boolean pathClosed = false; - boolean skip = false; - boolean subpathStarted = false; - float mx = 0.0f; - float my = 0.0f; - float point[] = new float[6]; - float ax = 0.0f; - float ay = 0.0f; - - while (!pi.isDone()) { - int type = pi.currentSegment(point); - if (pathClosed == true) { - pathClosed = false; - if (type != PathIterator.SEG_MOVETO) { - // Force current point back to last moveto point - r.beginSubpath(mx, my); - subpathStarted = true; - } - } - if (normalize) { - int index; - switch (type) { - case PathIterator.SEG_CUBICTO: - index = 4; - break; - case PathIterator.SEG_QUADTO: - index = 2; - break; - case PathIterator.SEG_MOVETO: - case PathIterator.SEG_LINETO: - index = 0; - break; - case PathIterator.SEG_CLOSE: - default: - index = -1; - break; - } - if (index >= 0) { - float ox = point[index]; - float oy = point[index+1]; - float newax = (float) Math.floor(ox) + 0.5f; - float neway = (float) Math.floor(oy) + 0.5f; - point[index] = newax; - point[index+1] = neway; - newax -= ox; - neway -= oy; - switch (type) { - case PathIterator.SEG_CUBICTO: - point[0] += ax; - point[1] += ay; - point[2] += newax; - point[3] += neway; - break; - case PathIterator.SEG_QUADTO: - point[0] += (newax + ax) / 2; - point[1] += (neway + ay) / 2; - break; - case PathIterator.SEG_MOVETO: - case PathIterator.SEG_LINETO: - case PathIterator.SEG_CLOSE: - break; - } - ax = newax; - ay = neway; - } - } - switch (type) { - case PathIterator.SEG_MOVETO: - - /* Checking SEG_MOVETO coordinates if they are out of the - * [LOWER_BND, UPPER_BND] range. This check also handles NaN - * and Infinity values. Skipping next path segment in case - * of invalid data. - */ - - if (point[0] < UPPER_BND && point[0] > LOWER_BND && - point[1] < UPPER_BND && point[1] > LOWER_BND) - { - mx = point[0]; - my = point[1]; - r.beginSubpath(mx, my); - subpathStarted = true; - skip = false; - } else { - skip = true; - } - break; - - case PathIterator.SEG_LINETO: - /* Checking SEG_LINETO coordinates if they are out of the - * [LOWER_BND, UPPER_BND] range. This check also handles - * NaN and Infinity values. Ignoring current path segment - * in case of invalid data. If segment is skipped its - * endpoint (if valid) is used to begin new subpath. - */ - if (point[0] < UPPER_BND && point[0] > LOWER_BND && - point[1] < UPPER_BND && point[1] > LOWER_BND) - { - if (skip) { - r.beginSubpath(point[0], point[1]); - subpathStarted = true; - skip = false; - } else { - r.appendLine(point[0], point[1]); - } - } - break; - - case PathIterator.SEG_QUADTO: - // Quadratic curves take two points - - /* Checking SEG_QUADTO coordinates if they are out of the - * [LOWER_BND, UPPER_BND] range. This check also handles - * NaN and Infinity values. Ignoring current path segment - * in case of invalid endpoints's data. Equivalent to the - * SEG_LINETO if endpoint coordinates are valid but there - * are invalid data among other coordinates - */ - if (point[2] < UPPER_BND && point[2] > LOWER_BND && - point[3] < UPPER_BND && point[3] > LOWER_BND) - { - if (skip) { - r.beginSubpath(point[2], point[3]); - subpathStarted = true; - skip = false; - } else { - if (point[0] < UPPER_BND && point[0] > LOWER_BND && - point[1] < UPPER_BND && point[1] > LOWER_BND) - { - r.appendQuadratic(point[0], point[1], - point[2], point[3]); - } else { - r.appendLine(point[2], point[3]); - } - } - } - break; - case PathIterator.SEG_CUBICTO: - // Cubic curves take three points - - /* Checking SEG_CUBICTO coordinates if they are out of the - * [LOWER_BND, UPPER_BND] range. This check also handles - * NaN and Infinity values. Ignoring current path segment - * in case of invalid endpoints's data. Equivalent to the - * SEG_LINETO if endpoint coordinates are valid but there - * are invalid data among other coordinates - */ - - if (point[4] < UPPER_BND && point[4] > LOWER_BND && - point[5] < UPPER_BND && point[5] > LOWER_BND) - { - if (skip) { - r.beginSubpath(point[4], point[5]); - subpathStarted = true; - skip = false; - } else { - if (point[0] < UPPER_BND && point[0] > LOWER_BND && - point[1] < UPPER_BND && point[1] > LOWER_BND && - point[2] < UPPER_BND && point[2] > LOWER_BND && - point[3] < UPPER_BND && point[3] > LOWER_BND) - { - r.appendCubic(point[0], point[1], - point[2], point[3], - point[4], point[5]); - } else { - r.appendLine(point[4], point[5]); - } - } - } - break; - case PathIterator.SEG_CLOSE: - if (subpathStarted) { - r.closedSubpath(); - subpathStarted = false; - pathClosed = true; - } - break; - } - pi.next(); - } - } - - try { - r.endPath(); - r.getAlphaBox(bbox); - clip.clipBoxToBounds(bbox); - if (bbox[0] >= bbox[2] || bbox[1] >= bbox[3]) { - dropRasterizer(r); - return null; - } - r.setOutputArea(bbox[0], bbox[1], - bbox[2] - bbox[0], - bbox[3] - bbox[1]); - } catch (PRException e) { - /* - * This exeption is thrown from the native part of the Ductus - * (only in case of a debug build) to indicate that some - * segments of the path have very large coordinates. - * See 4485298 for more info. - */ - System.err.println("DuctusRenderingEngine.getAATileGenerator: "+e); - } - - return r; - } - - /** - * {@inheritDoc} - */ - @Override - public AATileGenerator getAATileGenerator(double x, double y, - double dx1, double dy1, - double dx2, double dy2, - double lw1, double lw2, - Region clip, - int bbox[]) - { - // REMIND: Deal with large coordinates! - double ldx1, ldy1, ldx2, ldy2; - boolean innerpgram = (lw1 > 0 && lw2 > 0); - - if (innerpgram) { - ldx1 = dx1 * lw1; - ldy1 = dy1 * lw1; - ldx2 = dx2 * lw2; - ldy2 = dy2 * lw2; - x -= (ldx1 + ldx2) / 2.0; - y -= (ldy1 + ldy2) / 2.0; - dx1 += ldx1; - dy1 += ldy1; - dx2 += ldx2; - dy2 += ldy2; - if (lw1 > 1 && lw2 > 1) { - // Inner parallelogram was entirely consumed by stroke... - innerpgram = false; - } - } else { - ldx1 = ldy1 = ldx2 = ldy2 = 0; - } - - Rasterizer r = getRasterizer(); - - r.setUsage(Rasterizer.EOFILL); - - r.beginPath(); - r.beginSubpath((float) x, (float) y); - r.appendLine((float) (x+dx1), (float) (y+dy1)); - r.appendLine((float) (x+dx1+dx2), (float) (y+dy1+dy2)); - r.appendLine((float) (x+dx2), (float) (y+dy2)); - r.closedSubpath(); - if (innerpgram) { - x += ldx1 + ldx2; - y += ldy1 + ldy2; - dx1 -= 2.0 * ldx1; - dy1 -= 2.0 * ldy1; - dx2 -= 2.0 * ldx2; - dy2 -= 2.0 * ldy2; - r.beginSubpath((float) x, (float) y); - r.appendLine((float) (x+dx1), (float) (y+dy1)); - r.appendLine((float) (x+dx1+dx2), (float) (y+dy1+dy2)); - r.appendLine((float) (x+dx2), (float) (y+dy2)); - r.closedSubpath(); - } - - try { - r.endPath(); - r.getAlphaBox(bbox); - clip.clipBoxToBounds(bbox); - if (bbox[0] >= bbox[2] || bbox[1] >= bbox[3]) { - dropRasterizer(r); - return null; - } - r.setOutputArea(bbox[0], bbox[1], - bbox[2] - bbox[0], - bbox[3] - bbox[1]); - } catch (PRException e) { - /* - * This exeption is thrown from the native part of the Ductus - * (only in case of a debug build) to indicate that some - * segments of the path have very large coordinates. - * See 4485298 for more info. - */ - System.err.println("DuctusRenderingEngine.getAATileGenerator: "+e); - } - - return r; - } - - private void feedConsumer(PathConsumer consumer, PathIterator pi) { - try { - consumer.beginPath(); - boolean pathClosed = false; - float mx = 0.0f; - float my = 0.0f; - float point[] = new float[6]; - - while (!pi.isDone()) { - int type = pi.currentSegment(point); - if (pathClosed == true) { - pathClosed = false; - if (type != PathIterator.SEG_MOVETO) { - // Force current point back to last moveto point - consumer.beginSubpath(mx, my); - } - } - switch (type) { - case PathIterator.SEG_MOVETO: - mx = point[0]; - my = point[1]; - consumer.beginSubpath(point[0], point[1]); - break; - case PathIterator.SEG_LINETO: - consumer.appendLine(point[0], point[1]); - break; - case PathIterator.SEG_QUADTO: - consumer.appendQuadratic(point[0], point[1], - point[2], point[3]); - break; - case PathIterator.SEG_CUBICTO: - consumer.appendCubic(point[0], point[1], - point[2], point[3], - point[4], point[5]); - break; - case PathIterator.SEG_CLOSE: - consumer.closedSubpath(); - pathClosed = true; - break; - } - pi.next(); - } - - consumer.endPath(); - } catch (PathException e) { - throw new InternalError("Unable to Stroke shape ("+ - e.getMessage()+")", e); - } - } - - private class FillAdapter implements PathConsumer { - boolean closed; - Path2D.Float path; - - public FillAdapter() { - // Ductus only supplies float coordinates so - // Path2D.Double is not necessary here. - path = new Path2D.Float(Path2D.WIND_NON_ZERO); - } - - public Shape getShape() { - return path; - } - - public void dispose() { - } - - public PathConsumer getConsumer() { - return null; - } - - public void beginPath() {} - - public void beginSubpath(float x0, float y0) { - if (closed) { - path.closePath(); - closed = false; - } - path.moveTo(x0, y0); - } - - public void appendLine(float x1, float y1) { - path.lineTo(x1, y1); - } - - public void appendQuadratic(float xm, float ym, float x1, float y1) { - path.quadTo(xm, ym, x1, y1); - } - - public void appendCubic(float xm, float ym, - float xn, float yn, - float x1, float y1) { - path.curveTo(xm, ym, xn, yn, x1, y1); - } - - public void closedSubpath() { - closed = true; - } - - public void endPath() { - if (closed) { - path.closePath(); - closed = false; - } - } - - public void useProxy(FastPathProducer proxy) - throws PathException - { - proxy.sendTo(this); - } - - public long getCPathConsumer() { - return 0; - } - } -} diff --git a/jdk/src/java.desktop/share/classes/sun/font/CompositeFont.java b/jdk/src/java.desktop/share/classes/sun/font/CompositeFont.java index 177570b9638..622a04d472e 100644 --- a/jdk/src/java.desktop/share/classes/sun/font/CompositeFont.java +++ b/jdk/src/java.desktop/share/classes/sun/font/CompositeFont.java @@ -289,10 +289,21 @@ public final class CompositeFont extends Font2D { if (componentNames[slot] == null) { componentNames[slot] = name; } else if (!componentNames[slot].equalsIgnoreCase(name)) { - components[slot] = - (PhysicalFont) fm.findFont2D(componentNames[slot], - style, + /* If a component specifies the file with a bad font, + * the corresponding slot will be initialized by + * default physical font. In such case findFont2D may + * return composite font which cannot be casted to + * physical font. + */ + try { + components[slot] = + (PhysicalFont) fm.findFont2D(componentNames[slot], + style, FontManager.PHYSICAL_FALLBACK); + } catch (ClassCastException cce) { + /* Assign default physical font to the slot */ + components[slot] = fm.getDefaultPhysicalFont(); + } } } deferredInitialisation[slot] = false; diff --git a/jdk/src/java.desktop/share/classes/sun/font/ScriptRunData.java b/jdk/src/java.desktop/share/classes/sun/font/ScriptRunData.java index 14ae9f43bad..1f1f6b44d59 100644 --- a/jdk/src/java.desktop/share/classes/sun/font/ScriptRunData.java +++ b/jdk/src/java.desktop/share/classes/sun/font/ScriptRunData.java @@ -44,7 +44,7 @@ public final class ScriptRunData { if (cp >= data[cache] && cp < data[cache+2]) { return data[cache+1]; } - if (cp >= CHAR_START & cp < CHAR_LIMIT) { + if ((cp >= CHAR_START) && (cp < CHAR_LIMIT)) { int probe = dataPower; int index = 0; diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/ArrayCache.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/ArrayCache.java index e518c4d2261..5f36e0d7ce5 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/ArrayCache.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/ArrayCache.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -58,7 +58,7 @@ public final class ArrayCache implements MarlinConst { for (int i = 0; i < BUCKETS; i++, arraySize <<= 2) { ARRAY_SIZES[i] = arraySize; - if (doTrace) { + if (DO_TRACE) { logInfo("arraySize[" + i + "]: " + arraySize); } } @@ -71,7 +71,7 @@ public final class ArrayCache implements MarlinConst { for (int i = 0; i < BUCKETS; i++, arraySize <<= 1) { DIRTY_BYTE_ARRAY_SIZES[i] = arraySize; - if (doTrace) { + if (DO_TRACE) { logInfo("dirty arraySize[" + i + "]: " + arraySize); } } @@ -83,7 +83,7 @@ public final class ArrayCache implements MarlinConst { THRESHOLD_LARGE_ARRAY_SIZE = 8L * THRESHOLD_ARRAY_SIZE; // 16M THRESHOLD_HUGE_ARRAY_SIZE = 8L * THRESHOLD_LARGE_ARRAY_SIZE; // 128M - if (doStats || doMonitors) { + if (DO_STATS || DO_MONITORS) { logInfo("ArrayCache.BUCKETS = " + BUCKETS); logInfo("ArrayCache.MIN_ARRAY_SIZE = " + MIN_ARRAY_SIZE); logInfo("ArrayCache.MAX_ARRAY_SIZE = " + MAX_ARRAY_SIZE); diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/ByteArrayCache.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/ByteArrayCache.java index 6e8da24453e..7854795dfd3 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/ByteArrayCache.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/ByteArrayCache.java @@ -54,7 +54,7 @@ final class ByteArrayCache implements MarlinConst { } byte[] getArray() { - if (doStats) { + if (DO_STATS) { getOp++; } @@ -64,7 +64,7 @@ final class ByteArrayCache implements MarlinConst { return array; } - if (doStats) { + if (DO_STATS) { createOp++; } @@ -73,18 +73,18 @@ final class ByteArrayCache implements MarlinConst { void putDirtyArray(final byte[] array, final int length) { if (length != arraySize) { - if (doChecks) { + if (DO_CHECKS) { MarlinUtils.logInfo("ArrayCache: bad length = " + length); } return; } - if (doStats) { + if (DO_STATS) { returnOp++; } // NO clean-up of array data = DIRTY ARRAY - if (doCleanDirty) { + if (DO_CLEAN_DIRTY) { // Force zero-fill dirty arrays: Arrays.fill(array, 0, array.length, BYTE_0); } @@ -97,12 +97,12 @@ final class ByteArrayCache implements MarlinConst { final int fromIndex, final int toIndex) { if (length != arraySize) { - if (doChecks) { + if (DO_CHECKS) { MarlinUtils.logInfo("ArrayCache: bad length = " + length); } return; } - if (doStats) { + if (DO_STATS) { returnOp++; } @@ -125,7 +125,7 @@ final class ByteArrayCache implements MarlinConst { Arrays.fill(array, fromIndex, toIndex, value); } - if (doChecks) { + if (DO_CHECKS) { check(array, fromIndex, toIndex, value); } } @@ -133,7 +133,7 @@ final class ByteArrayCache implements MarlinConst { static void check(final byte[] array, final int fromIndex, final int toIndex, final byte value) { - if (doChecks) { + if (DO_CHECKS) { // check zero on full array: for (int i = 0; i < array.length; i++) { if (array[i] != value) { diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Curve.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Curve.java index 2d61d9157f6..092a38ef1cc 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Curve.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Curve.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,8 +25,6 @@ package sun.java2d.marlin; -import java.util.Iterator; - final class Curve { float ax, ay, bx, by, cx, cy, dx, dy; diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Dasher.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Dasher.java index a7da2102287..890bbf5dd48 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Dasher.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Dasher.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -41,9 +41,9 @@ import sun.awt.geom.PathConsumer2D; */ final class Dasher implements sun.awt.geom.PathConsumer2D, MarlinConst { - static final int recLimit = 4; + static final int REC_LIMIT = 4; static final float ERR = 0.01f; - static final float minTincrement = 1f / (1 << recLimit); + static final float MIN_T_INC = 1f / (1 << REC_LIMIT); private PathConsumer2D out; private float[] dash; @@ -139,7 +139,7 @@ final class Dasher implements sun.awt.geom.PathConsumer2D, MarlinConst { * clean up before reusing this instance */ void dispose() { - if (doCleanDirty) { + if (DO_CLEAN_DIRTY) { // Force zero-fill dirty arrays: Arrays.fill(curCurvepts, 0f); Arrays.fill(firstSegmentsBuffer, 0f); @@ -217,8 +217,8 @@ final class Dasher implements sun.awt.geom.PathConsumer2D, MarlinConst { int segIdx = firstSegidx; float[] buf = firstSegmentsBuffer; if (segIdx + len > buf.length) { - if (doStats) { - RendererContext.stats.stat_array_dasher_firstSegmentsBuffer + if (DO_STATS) { + rdrCtx.stats.stat_array_dasher_firstSegmentsBuffer .add(segIdx + len); } firstSegmentsBuffer = buf @@ -403,8 +403,8 @@ final class Dasher implements sun.awt.geom.PathConsumer2D, MarlinConst { private final float[] curLeafCtrlPolyLengths = new float[3]; LengthIterator() { - this.recCurveStack = new float[recLimit + 1][8]; - this.sides = new Side[recLimit]; + this.recCurveStack = new float[REC_LIMIT + 1][8]; + this.sides = new Side[REC_LIMIT]; // if any methods are called without first initializing this object // on a curve, we want it to fail ASAP. this.nextT = Float.MAX_VALUE; @@ -421,7 +421,7 @@ final class Dasher implements sun.awt.geom.PathConsumer2D, MarlinConst { void reset() { // keep data dirty // as it appears not useful to reset data: - if (doCleanDirty) { + if (DO_CLEAN_DIRTY) { final int recLimit = recCurveStack.length - 1; for (int i = recLimit; i >= 0; i--) { Arrays.fill(recCurveStack[i], 0f); @@ -607,7 +607,7 @@ final class Dasher implements sun.awt.geom.PathConsumer2D, MarlinConst { if (len >= 0f) { lastT = nextT; lenAtLastT = lenAtNextT; - nextT += (1 << (recLimit - recLevel)) * minTincrement; + nextT += (1 << (REC_LIMIT - recLevel)) * MIN_T_INC; lenAtNextT += len; // invalidate caches flatLeafCoefCache[2] = -1f; @@ -641,7 +641,7 @@ final class Dasher implements sun.awt.geom.PathConsumer2D, MarlinConst { final float lineLen = Helpers.linelen(curve[0], curve[1], curve[curveType-2], curve[curveType-1]); - if ((polyLen - lineLen) < ERR || recLevel == recLimit) { + if ((polyLen - lineLen) < ERR || recLevel == REC_LIMIT) { return (polyLen + lineLen) / 2f; } return -1f; diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/FloatArrayCache.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/FloatArrayCache.java index 681c75d4ceb..87876b8c3e9 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/FloatArrayCache.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/FloatArrayCache.java @@ -54,7 +54,7 @@ final class FloatArrayCache implements MarlinConst { } float[] getArray() { - if (doStats) { + if (DO_STATS) { getOp++; } @@ -65,7 +65,7 @@ final class FloatArrayCache implements MarlinConst { return array; } - if (doStats) { + if (DO_STATS) { createOp++; } @@ -74,18 +74,18 @@ final class FloatArrayCache implements MarlinConst { void putDirtyArray(final float[] array, final int length) { if (length != arraySize) { - if (doChecks) { + if (DO_CHECKS) { MarlinUtils.logInfo("ArrayCache: bad length = " + length); } return; } - if (doStats) { + if (DO_STATS) { returnOp++; } // NO clean-up of array data = DIRTY ARRAY - if (doCleanDirty) { + if (DO_CLEAN_DIRTY) { // Force zero-fill dirty arrays: Arrays.fill(array, 0, array.length, 0f); } @@ -98,12 +98,12 @@ final class FloatArrayCache implements MarlinConst { final int fromIndex, final int toIndex) { if (length != arraySize) { - if (doChecks) { + if (DO_CHECKS) { MarlinUtils.logInfo("ArrayCache: bad length = " + length); } return; } - if (doStats) { + if (DO_STATS) { returnOp++; } @@ -126,7 +126,7 @@ final class FloatArrayCache implements MarlinConst { Arrays.fill(array, fromIndex, toIndex, value); } - if (doChecks) { + if (DO_CHECKS) { check(array, fromIndex, toIndex, value); } } @@ -134,7 +134,7 @@ final class FloatArrayCache implements MarlinConst { static void check(final float[] array, final int fromIndex, final int toIndex, final float value) { - if (doChecks) { + if (DO_CHECKS) { // check zero on full array: for (int i = 0; i < array.length; i++) { if (array[i] != value) { diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Helpers.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Helpers.java index 40599f1142a..0b0277dc24f 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Helpers.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Helpers.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -248,9 +248,9 @@ final class Helpers implements MarlinConst { * the 6 right coordinates * @since 1.7 */ - static void subdivideCubic(float src[], int srcoff, - float left[], int leftoff, - float right[], int rightoff) + static void subdivideCubic(float[] src, int srcoff, + float[] left, int leftoff, + float[] right, int rightoff) { float x1 = src[srcoff + 0]; float y1 = src[srcoff + 1]; @@ -299,9 +299,9 @@ final class Helpers implements MarlinConst { } - static void subdivideCubicAt(float t, float src[], int srcoff, - float left[], int leftoff, - float right[], int rightoff) + static void subdivideCubicAt(float t, float[] src, int srcoff, + float[] left, int leftoff, + float[] right, int rightoff) { float x1 = src[srcoff + 0]; float y1 = src[srcoff + 1]; @@ -349,9 +349,9 @@ final class Helpers implements MarlinConst { } } - static void subdivideQuad(float src[], int srcoff, - float left[], int leftoff, - float right[], int rightoff) + static void subdivideQuad(float[] src, int srcoff, + float[] left, int leftoff, + float[] right, int rightoff) { float x1 = src[srcoff + 0]; float y1 = src[srcoff + 1]; @@ -387,9 +387,9 @@ final class Helpers implements MarlinConst { } } - static void subdivideQuadAt(float t, float src[], int srcoff, - float left[], int leftoff, - float right[], int rightoff) + static void subdivideQuadAt(float t, float[] src, int srcoff, + float[] left, int leftoff, + float[] right, int rightoff) { float x1 = src[srcoff + 0]; float y1 = src[srcoff + 1]; @@ -425,9 +425,9 @@ final class Helpers implements MarlinConst { } } - static void subdivideAt(float t, float src[], int srcoff, - float left[], int leftoff, - float right[], int rightoff, int size) + static void subdivideAt(float t, float[] src, int srcoff, + float[] left, int leftoff, + float[] right, int rightoff, int size) { switch(size) { case 8: diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/IntArrayCache.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/IntArrayCache.java index af4d0b69529..917e9928137 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/IntArrayCache.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/IntArrayCache.java @@ -54,7 +54,7 @@ final class IntArrayCache implements MarlinConst { } int[] getArray() { - if (doStats) { + if (DO_STATS) { getOp++; } @@ -64,7 +64,7 @@ final class IntArrayCache implements MarlinConst { return array; } - if (doStats) { + if (DO_STATS) { createOp++; } @@ -73,18 +73,18 @@ final class IntArrayCache implements MarlinConst { void putDirtyArray(final int[] array, final int length) { if (length != arraySize) { - if (doChecks) { + if (DO_CHECKS) { MarlinUtils.logInfo("ArrayCache: bad length = " + length); } return; } - if (doStats) { + if (DO_STATS) { returnOp++; } // NO clean-up of array data = DIRTY ARRAY - if (doCleanDirty) { + if (DO_CLEAN_DIRTY) { // Force zero-fill dirty arrays: Arrays.fill(array, 0, array.length, 0); } @@ -97,12 +97,12 @@ final class IntArrayCache implements MarlinConst { final int fromIndex, final int toIndex) { if (length != arraySize) { - if (doChecks) { + if (DO_CHECKS) { MarlinUtils.logInfo("ArrayCache: bad length = " + length); } return; } - if (doStats) { + if (DO_STATS) { returnOp++; } @@ -125,7 +125,7 @@ final class IntArrayCache implements MarlinConst { Arrays.fill(array, fromIndex, toIndex, value); } - if (doChecks) { + if (DO_CHECKS) { check(array, fromIndex, toIndex, value); } } @@ -133,7 +133,7 @@ final class IntArrayCache implements MarlinConst { static void check(final int[] array, final int fromIndex, final int toIndex, final int value) { - if (doChecks) { + if (DO_CHECKS) { // check zero on full array: for (int i = 0; i < array.length; i++) { if (array[i] != value) { diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinCache.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinCache.java index 40afc7fe9a6..043b74ecd6b 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinCache.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinCache.java @@ -60,7 +60,7 @@ public final class MarlinCache implements MarlinConst { ALPHA_MAP_UNSAFE = new OffHeapArray(_ALPHA_MAP, _ALPHA_MAP.length); // 1K ALPHA_MAP =_ALPHA_MAP; - final Unsafe _unsafe = OffHeapArray.unsafe; + final Unsafe _unsafe = OffHeapArray.UNSAFE; final long addr = ALPHA_MAP_UNSAFE.address; for (int i = 0; i < _ALPHA_MAP.length; i++) { @@ -157,7 +157,7 @@ public final class MarlinCache implements MarlinConst { || (width * heightSubPixel) > ((edgeSumDeltaY - heightSubPixel) << BLOCK_SIZE_LG); - if (doTrace && !useRLE) { + if (DO_TRACE && !useRLE) { final float meanCrossings = ((float) edgeSumDeltaY) / heightSubPixel; final float meanDist = width / (meanCrossings - 1); @@ -180,8 +180,8 @@ public final class MarlinCache implements MarlinConst { final int nxTiles = (width + TILE_SIZE) >> TILE_SIZE_LG; if (nxTiles > INITIAL_ARRAY) { - if (doStats) { - RendererContext.stats.stat_array_marlincache_touchedTile + if (DO_STATS) { + rdrCtx.stats.stat_array_marlincache_touchedTile .add(nxTiles); } touchedTile = rdrCtx.getIntArray(nxTiles); @@ -206,7 +206,7 @@ public final class MarlinCache implements MarlinConst { // note: may throw OOME: rowAAChunk.resize(INITIAL_CHUNK_ARRAY); } - if (doCleanDirty) { + if (DO_CLEAN_DIRTY) { // Force zero-fill dirty arrays: rowAAChunk.fill(BYTE_0); } @@ -217,15 +217,15 @@ public final class MarlinCache implements MarlinConst { bboxY0 = pminY; // reset current pos - if (doStats) { - RendererContext.stats.stat_cache_rowAAChunk.add(rowAAChunkPos); + if (DO_STATS) { + rdrCtx.stats.stat_cache_rowAAChunk.add(rowAAChunkPos); } rowAAChunkPos = 0L; // Reset touchedTile: if (tileMin != Integer.MAX_VALUE) { - if (doStats) { - RendererContext.stats.stat_cache_tiles.add(tileMax - tileMin); + if (DO_STATS) { + rdrCtx.stats.stat_cache_tiles.add(tileMax - tileMin); } // clean only dirty touchedTile: if (tileMax == 1) { @@ -238,7 +238,7 @@ public final class MarlinCache implements MarlinConst { tileMax = Integer.MIN_VALUE; } - if (doCleanDirty) { + if (DO_CLEAN_DIRTY) { // Force zero-fill dirty arrays: rowAAChunk.fill(BYTE_0); } @@ -267,14 +267,14 @@ public final class MarlinCache implements MarlinConst { void copyAARowNoRLE(final int[] alphaRow, final int y, final int px0, final int px1) { - if (doMonitors) { - RendererContext.stats.mon_rdr_copyAARow.start(); + if (DO_MONITORS) { + rdrCtx.stats.mon_rdr_copyAARow.start(); } // skip useless pixels above boundary final int px_bbox1 = FloatMath.min(px1, bboxX1); - if (doLogBounds) { + if (DO_LOG_BOUNDS) { MarlinUtils.logInfo("row = [" + px0 + " ... " + px_bbox1 + " (" + px1 + ") [ for y=" + y); } @@ -305,8 +305,8 @@ public final class MarlinCache implements MarlinConst { if (_rowAAChunk.length < needSize) { expandRowAAChunk(needSize); } - if (doStats) { - RendererContext.stats.stat_cache_rowAA.add(px_bbox1 - px0); + if (DO_STATS) { + rdrCtx.stats.stat_cache_rowAA.add(px_bbox1 - px0); } // rowAA contains only alpha values for range[x0; x1[ @@ -316,7 +316,7 @@ public final class MarlinCache implements MarlinConst { final int from = px0 - bboxX0; // first pixel inclusive final int to = px_bbox1 - bboxX0; // last pixel exclusive - final Unsafe _unsafe = OffHeapArray.unsafe; + final Unsafe _unsafe = OffHeapArray.UNSAFE; final long SIZE_BYTE = 1L; final long addr_alpha = ALPHA_MAP_UNSAFE.address; long addr_off = _rowAAChunk.address + pos; @@ -361,23 +361,23 @@ public final class MarlinCache implements MarlinConst { tileMax = tx; } - if (doLogBounds) { + if (DO_LOG_BOUNDS) { MarlinUtils.logInfo("clear = [" + from + " ... " + to + "["); } // Clear alpha row for reuse: IntArrayCache.fill(alphaRow, from, px1 - bboxX0, 0); - if (doMonitors) { - RendererContext.stats.mon_rdr_copyAARow.stop(); + if (DO_MONITORS) { + rdrCtx.stats.mon_rdr_copyAARow.stop(); } } void copyAARowRLE_WithBlockFlags(final int[] blkFlags, final int[] alphaRow, final int y, final int px0, final int px1) { - if (doMonitors) { - RendererContext.stats.mon_rdr_copyAARow.start(); + if (DO_MONITORS) { + rdrCtx.stats.mon_rdr_copyAARow.start(); } // Copy rowAA data into the piscesCache if one is present @@ -391,7 +391,7 @@ public final class MarlinCache implements MarlinConst { final int px_bbox1 = FloatMath.min(px1, bboxX1); final int to = px_bbox1 - _bboxX0; // last pixel exclusive - if (doLogBounds) { + if (DO_LOG_BOUNDS) { MarlinUtils.logInfo("row = [" + px0 + " ... " + px_bbox1 + " (" + px1 + ") [ for y=" + y); } @@ -410,7 +410,7 @@ public final class MarlinCache implements MarlinConst { expandRowAAChunk(needSize); } - final Unsafe _unsafe = OffHeapArray.unsafe; + final Unsafe _unsafe = OffHeapArray.UNSAFE; final long SIZE_INT = 4L; final long addr_alpha = ALPHA_MAP_UNSAFE.address; long addr_off = _rowAAChunk.address + initialPos; @@ -465,7 +465,7 @@ public final class MarlinCache implements MarlinConst { // note: it should check X is smaller than 23bits (overflow)! // check address alignment to 4 bytes: - if (doCheckUnsafe) { + if (DO_CHECK_UNSAFE) { if ((addr_off & 3) != 0) { MarlinUtils.logInfo("Misaligned Unsafe address: " + addr_off); } @@ -490,8 +490,8 @@ public final class MarlinCache implements MarlinConst { } addr_off += SIZE_INT; - if (doStats) { - RendererContext.stats.hist_tile_generator_encoding_runLen + if (DO_STATS) { + rdrCtx.stats.hist_tile_generator_encoding_runLen .add(runLen); } cx0 = cx; @@ -513,7 +513,7 @@ public final class MarlinCache implements MarlinConst { } } } - } else if (doStats) { + } else if (DO_STATS) { skip++; } } @@ -528,7 +528,7 @@ public final class MarlinCache implements MarlinConst { // note: it should check X is smaller than 23bits (overflow)! // check address alignment to 4 bytes: - if (doCheckUnsafe) { + if (DO_CHECK_UNSAFE) { if ((addr_off & 3) != 0) { MarlinUtils.logInfo("Misaligned Unsafe address: " + addr_off); } @@ -553,8 +553,8 @@ public final class MarlinCache implements MarlinConst { } addr_off += SIZE_INT; - if (doStats) { - RendererContext.stats.hist_tile_generator_encoding_runLen + if (DO_STATS) { + rdrCtx.stats.hist_tile_generator_encoding_runLen .add(runLen); } @@ -566,9 +566,9 @@ public final class MarlinCache implements MarlinConst { // update current position: rowAAChunkPos = len; - if (doStats) { - RendererContext.stats.stat_cache_rowAA.add(rowAALen[row]); - RendererContext.stats.hist_tile_generator_encoding_ratio.add( + if (DO_STATS) { + rdrCtx.stats.stat_cache_rowAA.add(rowAALen[row]); + rdrCtx.stats.hist_tile_generator_encoding_ratio.add( (100 * skip) / (blkE - blkW) ); } @@ -589,13 +589,13 @@ public final class MarlinCache implements MarlinConst { alphaRow[to ] = 0; alphaRow[to + 1] = 0; } - if (doChecks) { + if (DO_CHECKS) { IntArrayCache.check(blkFlags, blkW, blkE, 0); IntArrayCache.check(alphaRow, from, px1 - bboxX0, 0); } - if (doMonitors) { - RendererContext.stats.mon_rdr_copyAARow.stop(); + if (DO_MONITORS) { + rdrCtx.stats.mon_rdr_copyAARow.stop(); } } @@ -611,8 +611,8 @@ public final class MarlinCache implements MarlinConst { } private void expandRowAAChunk(final long needSize) { - if (doStats) { - RendererContext.stats.stat_array_marlincache_rowAAChunk + if (DO_STATS) { + rdrCtx.stats.stat_array_marlincache_rowAAChunk .add(needSize); } diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinConst.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinConst.java index 72993ebfd7c..22bf86d66c0 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinConst.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinConst.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,54 +30,55 @@ package sun.java2d.marlin; */ interface MarlinConst { // enable Logs (logger or stdout) - static final boolean enableLogs = MarlinProperties.isLoggingEnabled(); + static final boolean ENABLE_LOGS = MarlinProperties.isLoggingEnabled(); // use Logger instead of stdout - static final boolean useLogger = enableLogs && MarlinProperties.isUseLogger(); + static final boolean USE_LOGGER = ENABLE_LOGS && MarlinProperties.isUseLogger(); // log new RendererContext - static final boolean logCreateContext = enableLogs + static final boolean LOG_CREATE_CONTEXT = ENABLE_LOGS && MarlinProperties.isLogCreateContext(); // log misc.Unsafe alloc/realloc/free - static final boolean logUnsafeMalloc = enableLogs + static final boolean LOG_UNSAFE_MALLOC = ENABLE_LOGS && MarlinProperties.isLogUnsafeMalloc(); // do check unsafe alignment: - static final boolean doCheckUnsafe = false; + static final boolean DO_CHECK_UNSAFE = false; // do statistics - static final boolean doStats = enableLogs && MarlinProperties.isDoStats(); + static final boolean DO_STATS = ENABLE_LOGS && MarlinProperties.isDoStats(); // do monitors // disabled to reduce byte-code size a bit... - static final boolean doMonitors = false; -// static final boolean doMonitors = enableLogs && MarlinProperties.isDoMonitors(); + static final boolean DO_MONITORS = false; +// static final boolean DO_MONITORS = ENABLE_LOGS && MarlinProperties.isDoMonitors(); // do checks - static final boolean doChecks = enableLogs && MarlinProperties.isDoChecks(); + static final boolean DO_CHECKS = ENABLE_LOGS && MarlinProperties.isDoChecks(); // do AA range checks: disable when algorithm / code is stable static final boolean DO_AA_RANGE_CHECK = false; // enable logs - static final boolean doLogWidenArray = enableLogs && false; + static final boolean DO_LOG_WIDEN_ARRAY = ENABLE_LOGS && false; // enable oversize logs - static final boolean doLogOverSize = enableLogs && false; + static final boolean DO_LOG_OVERSIZE = ENABLE_LOGS && false; // enable traces - static final boolean doTrace = enableLogs && false; + static final boolean DO_TRACE = ENABLE_LOGS && false; + // do flush monitors - static final boolean doFlushMonitors = true; + static final boolean DO_FLUSH_MONITORS = true; // use one polling thread to dump statistics/monitors - static final boolean useDumpThread = false; + static final boolean USE_DUMP_THREAD = false; // thread dump interval (ms) - static final long statDump = 5000L; + static final long DUMP_INTERVAL = 5000L; // do clean dirty array - static final boolean doCleanDirty = false; + static final boolean DO_CLEAN_DIRTY = false; // flag to use line simplifier - static final boolean useSimplifier = MarlinProperties.isUseSimplifier(); + static final boolean USE_SIMPLIFIER = MarlinProperties.isUseSimplifier(); // flag to enable logs related bounds checks - static final boolean doLogBounds = enableLogs && false; + static final boolean DO_LOG_BOUNDS = ENABLE_LOGS && false; - // Initial Array sizing (initial context capacity) ~ 512K + // Initial Array sizing (initial context capacity) ~ 350K // 2048 pixel (width x height) for initial capacity static final int INITIAL_PIXEL_DIM @@ -88,8 +89,6 @@ interface MarlinConst { static final int INITIAL_SMALL_ARRAY = 1024; static final int INITIAL_MEDIUM_ARRAY = 4096; static final int INITIAL_LARGE_ARRAY = 8192; - static final int INITIAL_ARRAY_16K = 16384; - static final int INITIAL_ARRAY_32K = 32768; // alpha row dimension static final int INITIAL_AA_ARRAY = INITIAL_PIXEL_DIM; diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinRenderingEngine.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinRenderingEngine.java index b794d8c6004..b7d3af4159d 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinRenderingEngine.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinRenderingEngine.java @@ -85,7 +85,7 @@ public class MarlinRenderingEngine extends RenderingEngine int caps, int join, float miterlimit, - float dashes[], + float[] dashes, float dashphase) { final RendererContext rdrCtx = getRendererContext(); @@ -278,7 +278,7 @@ public class MarlinRenderingEngine extends RenderingEngine int caps, int join, float miterlimit, - float dashes[], + float[] dashes, float dashphase, PathConsumer2D pc2d) { @@ -340,8 +340,8 @@ public class MarlinRenderingEngine extends RenderingEngine if (dashLen <= INITIAL_ARRAY) { newDashes = rdrCtx.dasher.dashes_initial; } else { - if (doStats) { - RendererContext.stats.stat_array_dasher_dasher + if (DO_STATS) { + rdrCtx.stats.stat_array_dasher_dasher .add(dashLen); } newDashes = rdrCtx.getDirtyFloatArray(dashLen); @@ -380,7 +380,7 @@ public class MarlinRenderingEngine extends RenderingEngine at = null; } - if (useSimplifier) { + if (USE_SIMPLIFIER) { // Use simplifier after stroker before Renderer // to remove collinear segments (notably due to cap square) pc2d = rdrCtx.simplifier.init(pc2d); @@ -474,9 +474,6 @@ public class MarlinRenderingEngine extends RenderingEngine @Override public final int currentSegment(final float[] coords) { - if (doMonitors) { - RendererContext.stats.mon_npi_currentSegment.start(); - } int lastCoord; final int type = src.currentSegment(coords); @@ -495,17 +492,11 @@ public class MarlinRenderingEngine extends RenderingEngine // we don't want to deal with this case later. We just exit now curx_adjust = movx_adjust; cury_adjust = movy_adjust; - - if (doMonitors) { - RendererContext.stats.mon_npi_currentSegment.stop(); - } return type; default: throw new InternalError("Unrecognized curve type"); } - // TODO: handle NaN, Inf and overflow - // normalize endpoint float coord, x_adjust, y_adjust; @@ -543,10 +534,6 @@ public class MarlinRenderingEngine extends RenderingEngine } curx_adjust = x_adjust; cury_adjust = y_adjust; - - if (doMonitors) { - RendererContext.stats.mon_npi_currentSegment.stop(); - } return type; } @@ -790,7 +777,7 @@ public class MarlinRenderingEngine extends RenderingEngine BasicStroke bs, boolean thin, boolean normalize, - int bbox[]) + int[] bbox) { MarlinTileGenerator ptg = null; Renderer r = null; @@ -808,6 +795,7 @@ public class MarlinRenderingEngine extends RenderingEngine final PathIterator pi = getNormalizingPathIterator(rdrCtx, norm, s.getPathIterator(_at)); + // note: Winding rule may be EvenOdd ONLY for fill operations ! r = rdrCtx.renderer.init(clip.getLoX(), clip.getLoY(), clip.getWidth(), clip.getHeight(), pi.getWindingRule()); @@ -848,7 +836,7 @@ public class MarlinRenderingEngine extends RenderingEngine double dx2, double dy2, double lw1, double lw2, Region clip, - int bbox[]) + int[] bbox) { // REMIND: Deal with large coordinates! double ldx1, ldy1, ldx2, ldy2; @@ -949,17 +937,17 @@ public class MarlinRenderingEngine extends RenderingEngine // --- RendererContext handling --- // use ThreadLocal or ConcurrentLinkedQueue to get one RendererContext - private static final boolean useThreadLocal; + private static final boolean USE_THREAD_LOCAL; // reference type stored in either TL or CLQ static final int REF_TYPE; // Per-thread RendererContext - private static final ReentrantContextProvider rdrCtxProvider; + private static final ReentrantContextProvider RDR_CTX_PROVIDER; // Static initializer to use TL or CLQ mode static { - useThreadLocal = MarlinProperties.isUseThreadLocal(); + USE_THREAD_LOCAL = MarlinProperties.isUseThreadLocal(); // Soft reference by default: final String refType = AccessController.doPrivileged( @@ -978,8 +966,8 @@ public class MarlinRenderingEngine extends RenderingEngine break; } - if (useThreadLocal) { - rdrCtxProvider = new ReentrantContextProviderTL(REF_TYPE) + if (USE_THREAD_LOCAL) { + RDR_CTX_PROVIDER = new ReentrantContextProviderTL(REF_TYPE) { @Override protected RendererContext newContext() { @@ -987,7 +975,7 @@ public class MarlinRenderingEngine extends RenderingEngine } }; } else { - rdrCtxProvider = new ReentrantContextProviderCLQ(REF_TYPE) + RDR_CTX_PROVIDER = new ReentrantContextProviderCLQ(REF_TYPE) { @Override protected RendererContext newContext() { @@ -997,14 +985,14 @@ public class MarlinRenderingEngine extends RenderingEngine } } - private static boolean settingsLogged = !enableLogs; + private static boolean SETTINGS_LOGGED = !ENABLE_LOGS; private static void logSettings(final String reClass) { // log information at startup - if (settingsLogged) { + if (SETTINGS_LOGGED) { return; } - settingsLogged = true; + SETTINGS_LOGGED = true; String refType; switch (REF_TYPE) { @@ -1029,7 +1017,7 @@ public class MarlinRenderingEngine extends RenderingEngine logInfo("sun.java2d.renderer = " + reClass); logInfo("sun.java2d.renderer.useThreadLocal = " - + useThreadLocal); + + USE_THREAD_LOCAL); logInfo("sun.java2d.renderer.useRef = " + refType); @@ -1063,23 +1051,23 @@ public class MarlinRenderingEngine extends RenderingEngine // optimisation parameters logInfo("sun.java2d.renderer.useSimplifier = " - + MarlinConst.useSimplifier); + + MarlinConst.USE_SIMPLIFIER); // debugging parameters logInfo("sun.java2d.renderer.doStats = " - + MarlinConst.doStats); + + MarlinConst.DO_STATS); logInfo("sun.java2d.renderer.doMonitors = " - + MarlinConst.doMonitors); + + MarlinConst.DO_MONITORS); logInfo("sun.java2d.renderer.doChecks = " - + MarlinConst.doChecks); + + MarlinConst.DO_CHECKS); // logging parameters logInfo("sun.java2d.renderer.useLogger = " - + MarlinConst.useLogger); + + MarlinConst.USE_LOGGER); logInfo("sun.java2d.renderer.logCreateContext = " - + MarlinConst.logCreateContext); + + MarlinConst.LOG_CREATE_CONTEXT); logInfo("sun.java2d.renderer.logUnsafeMalloc = " - + MarlinConst.logUnsafeMalloc); + + MarlinConst.LOG_UNSAFE_MALLOC); // quality settings logInfo("Renderer settings:"); @@ -1098,9 +1086,9 @@ public class MarlinRenderingEngine extends RenderingEngine */ @SuppressWarnings({"unchecked"}) static RendererContext getRendererContext() { - final RendererContext rdrCtx = rdrCtxProvider.acquire(); - if (doMonitors) { - RendererContext.stats.mon_pre_getAATileGenerator.start(); + final RendererContext rdrCtx = RDR_CTX_PROVIDER.acquire(); + if (DO_MONITORS) { + rdrCtx.stats.mon_pre_getAATileGenerator.start(); } return rdrCtx; } @@ -1112,9 +1100,9 @@ public class MarlinRenderingEngine extends RenderingEngine static void returnRendererContext(final RendererContext rdrCtx) { rdrCtx.dispose(); - if (doMonitors) { - RendererContext.stats.mon_pre_getAATileGenerator.stop(); + if (DO_MONITORS) { + rdrCtx.stats.mon_pre_getAATileGenerator.stop(); } - rdrCtxProvider.release(rdrCtx); + RDR_CTX_PROVIDER.release(rdrCtx); } } diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinTileGenerator.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinTileGenerator.java index 9c6451c4278..f623d507987 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinTileGenerator.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinTileGenerator.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -37,9 +37,13 @@ final class MarlinTileGenerator implements AATileGenerator, MarlinConst { private final MarlinCache cache; private int x, y; + // per-thread renderer context + final RendererContext rdrCtx; + MarlinTileGenerator(Renderer r) { this.rdr = r; this.cache = r.cache; + this.rdrCtx = r.rdrCtx; } MarlinTileGenerator init() { @@ -55,19 +59,19 @@ final class MarlinTileGenerator implements AATileGenerator, MarlinConst { */ @Override public void dispose() { - if (doMonitors) { + if (DO_MONITORS) { // called from AAShapePipe.renderTiles() (render tiles end): - RendererContext.stats.mon_pipe_renderTiles.stop(); + rdrCtx.stats.mon_pipe_renderTiles.stop(); } // dispose cache: cache.dispose(); // dispose renderer: rdr.dispose(); // recycle the RendererContext instance - MarlinRenderingEngine.returnRendererContext(rdr.rdrCtx); + MarlinRenderingEngine.returnRendererContext(rdrCtx); } - void getBbox(int bbox[]) { + void getBbox(int[] bbox) { bbox[0] = cache.bboxX0; bbox[1] = cache.bboxY0; bbox[2] = cache.bboxX1; @@ -80,9 +84,9 @@ final class MarlinTileGenerator implements AATileGenerator, MarlinConst { */ @Override public int getTileWidth() { - if (doMonitors) { + if (DO_MONITORS) { // called from AAShapePipe.renderTiles() (render tiles start): - RendererContext.stats.mon_pipe_renderTiles.start(); + rdrCtx.stats.mon_pipe_renderTiles.start(); } return TILE_SIZE; } @@ -126,8 +130,8 @@ final class MarlinTileGenerator implements AATileGenerator, MarlinConst { // values anyway. final int alpha = (al == 0x00 ? 0x00 : (al == MAX_TILE_ALPHA_SUM ? 0xff : 0x80)); - if (doStats) { - RendererContext.stats.hist_tile_generator_alpha.add(alpha); + if (DO_STATS) { + rdrCtx.stats.hist_tile_generator_alpha.add(alpha); } return alpha; } @@ -157,7 +161,7 @@ final class MarlinTileGenerator implements AATileGenerator, MarlinConst { * once per tile, but not both. */ @Override - public void getAlpha(final byte tile[], final int offset, + public void getAlpha(final byte[] tile, final int offset, final int rowstride) { if (cache.useRLE) { @@ -172,11 +176,11 @@ final class MarlinTileGenerator implements AATileGenerator, MarlinConst { * Either this method, or the nextTile() method should be called * once per tile, but not both. */ - private void getAlphaNoRLE(final byte tile[], final int offset, + private void getAlphaNoRLE(final byte[] tile, final int offset, final int rowstride) { - if (doMonitors) { - RendererContext.stats.mon_ptg_getAlpha.start(); + if (DO_MONITORS) { + rdrCtx.stats.mon_ptg_getAlpha.start(); } // local vars for performance: @@ -192,12 +196,12 @@ final class MarlinTileGenerator implements AATileGenerator, MarlinConst { final int y0 = 0; final int y1 = FloatMath.min(this.y + TILE_SIZE, _cache.bboxY1) - this.y; - if (doLogBounds) { + if (DO_LOG_BOUNDS) { MarlinUtils.logInfo("getAlpha = [" + x0 + " ... " + x1 + "[ [" + y0 + " ... " + y1 + "["); } - final Unsafe _unsafe = OffHeapArray.unsafe; + final Unsafe _unsafe = OffHeapArray.UNSAFE; final long SIZE = 1L; final long addr_rowAA = _cache.rowAAChunk.address; long addr; @@ -252,7 +256,7 @@ final class MarlinTileGenerator implements AATileGenerator, MarlinConst { cx++; } - if (doTrace) { + if (DO_TRACE) { for (int i = idx - (x1 - x0); i < idx; i++) { System.out.print(hex(tile[i], 2)); } @@ -264,8 +268,8 @@ final class MarlinTileGenerator implements AATileGenerator, MarlinConst { nextTile(); - if (doMonitors) { - RendererContext.stats.mon_ptg_getAlpha.stop(); + if (DO_MONITORS) { + rdrCtx.stats.mon_ptg_getAlpha.stop(); } } @@ -274,11 +278,11 @@ final class MarlinTileGenerator implements AATileGenerator, MarlinConst { * Either this method, or the nextTile() method should be called * once per tile, but not both. */ - private void getAlphaRLE(final byte tile[], final int offset, + private void getAlphaRLE(final byte[] tile, final int offset, final int rowstride) { - if (doMonitors) { - RendererContext.stats.mon_ptg_getAlpha.start(); + if (DO_MONITORS) { + rdrCtx.stats.mon_ptg_getAlpha.start(); } // Decode run-length encoded alpha mask data @@ -302,12 +306,12 @@ final class MarlinTileGenerator implements AATileGenerator, MarlinConst { final int y0 = 0; final int y1 = FloatMath.min(this.y + TILE_SIZE, _cache.bboxY1) - this.y; - if (doLogBounds) { + if (DO_LOG_BOUNDS) { MarlinUtils.logInfo("getAlpha = [" + x0 + " ... " + x1 + "[ [" + y0 + " ... " + y1 + "["); } - final Unsafe _unsafe = OffHeapArray.unsafe; + final Unsafe _unsafe = OffHeapArray.UNSAFE; final long SIZE_BYTE = 1L; final long SIZE_INT = 4L; final long addr_rowAA = _cache.rowAAChunk.address; @@ -438,7 +442,7 @@ final class MarlinTileGenerator implements AATileGenerator, MarlinConst { cx++; } - if (doTrace) { + if (DO_TRACE) { for (int i = idx - (x1 - x0); i < idx; i++) { System.out.print(hex(tile[i], 2)); } @@ -450,8 +454,8 @@ final class MarlinTileGenerator implements AATileGenerator, MarlinConst { nextTile(); - if (doMonitors) { - RendererContext.stats.mon_ptg_getAlpha.stop(); + if (DO_MONITORS) { + rdrCtx.stats.mon_ptg_getAlpha.stop(); } } diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinUtils.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinUtils.java index aeeacca57bd..5645e706b2e 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinUtils.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/MarlinUtils.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -28,13 +28,13 @@ package sun.java2d.marlin; public final class MarlinUtils { // Marlin logger - private static final sun.util.logging.PlatformLogger log; + private static final sun.util.logging.PlatformLogger LOG; static { - if (MarlinConst.useLogger) { - log = sun.util.logging.PlatformLogger.getLogger("sun.java2d.marlin"); + if (MarlinConst.USE_LOGGER) { + LOG = sun.util.logging.PlatformLogger.getLogger("sun.java2d.marlin"); } else { - log = null; + LOG = null; } } @@ -43,18 +43,18 @@ public final class MarlinUtils { } public static void logInfo(final String msg) { - if (MarlinConst.useLogger) { - log.info(msg); - } else if (MarlinConst.enableLogs) { + if (MarlinConst.USE_LOGGER) { + LOG.info(msg); + } else if (MarlinConst.ENABLE_LOGS) { System.out.print("INFO: "); System.out.println(msg); } } public static void logException(final String msg, final Throwable th) { - if (MarlinConst.useLogger) { - log.warning(msg, th); - } else if (MarlinConst.enableLogs) { + if (MarlinConst.USE_LOGGER) { + LOG.warning(msg, th); + } else if (MarlinConst.ENABLE_LOGS) { System.out.print("WARNING: "); System.out.println(msg); th.printStackTrace(System.err); diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/OffHeapArray.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/OffHeapArray.java index 96437cd2f56..d4b1ed28819 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/OffHeapArray.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/OffHeapArray.java @@ -25,7 +25,7 @@ package sun.java2d.marlin; -import static sun.java2d.marlin.MarlinConst.logUnsafeMalloc; +import static sun.java2d.marlin.MarlinConst.LOG_UNSAFE_MALLOC; import jdk.internal.misc.Unsafe; import jdk.internal.ref.CleanerFactory; @@ -36,12 +36,12 @@ import jdk.internal.ref.CleanerFactory; final class OffHeapArray { // unsafe reference - static final Unsafe unsafe; + static final Unsafe UNSAFE; // size of int / float static final int SIZE_INT; static { - unsafe = Unsafe.getUnsafe(); + UNSAFE = Unsafe.getUnsafe(); SIZE_INT = Unsafe.ARRAY_INT_INDEX_SCALE; } @@ -52,10 +52,10 @@ final class OffHeapArray { OffHeapArray(final Object parent, final long len) { // note: may throw OOME: - this.address = unsafe.allocateMemory(len); + this.address = UNSAFE.allocateMemory(len); this.length = len; this.used = 0; - if (logUnsafeMalloc) { + if (LOG_UNSAFE_MALLOC) { MarlinUtils.logInfo(System.currentTimeMillis() + ": OffHeapArray.allocateMemory = " + len + " to addr = " + this.address); @@ -72,9 +72,9 @@ final class OffHeapArray { */ void resize(final long len) { // note: may throw OOME: - this.address = unsafe.reallocateMemory(address, len); + this.address = UNSAFE.reallocateMemory(address, len); this.length = len; - if (logUnsafeMalloc) { + if (LOG_UNSAFE_MALLOC) { MarlinUtils.logInfo(System.currentTimeMillis() + ": OffHeapArray.reallocateMemory = " + len + " to addr = " + this.address); @@ -82,8 +82,8 @@ final class OffHeapArray { } void free() { - unsafe.freeMemory(this.address); - if (logUnsafeMalloc) { + UNSAFE.freeMemory(this.address); + if (LOG_UNSAFE_MALLOC) { MarlinUtils.logInfo(System.currentTimeMillis() + ": OffHeapArray.freeMemory = " + this.length @@ -92,6 +92,6 @@ final class OffHeapArray { } void fill(final byte val) { - unsafe.setMemory(this.address, this.length, val); + UNSAFE.setMemory(this.address, this.length, val); } } diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Renderer.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Renderer.java index f9b5e081785..ec499a9ff29 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Renderer.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Renderer.java @@ -189,8 +189,8 @@ final class Renderer implements PathConsumer2D, MarlinConst { maxDD /= 4f; // error divided by 2^2 = 4 count <<= 1; - if (doStats) { - RendererContext.stats.stat_rdr_quadBreak_dec.add(count); + if (DO_STATS) { + rdrCtx.stats.stat_rdr_quadBreak_dec.add(count); } } @@ -214,15 +214,15 @@ final class Renderer implements PathConsumer2D, MarlinConst { addLine(x0, y0, x1, y1); - if (doStats) { nL++; } + if (DO_STATS) { nL++; } x0 = x1; y0 = y1; } } addLine(x0, y0, x2, y2); - if (doStats) { - RendererContext.stats.stat_rdr_quadBreak.add(nL + 1); + if (DO_STATS) { + rdrCtx.stats.stat_rdr_quadBreak.add(nL + 1); } } @@ -268,8 +268,8 @@ final class Renderer implements PathConsumer2D, MarlinConst { dy = (dy - ddy) / 2f; count <<= 1; - if (doStats) { - RendererContext.stats.stat_rdr_curveBreak_dec.add(count); + if (DO_STATS) { + rdrCtx.stats.stat_rdr_curveBreak_dec.add(count); } } @@ -289,8 +289,8 @@ final class Renderer implements PathConsumer2D, MarlinConst { dddy *= 8f; count >>= 1; - if (doStats) { - RendererContext.stats.stat_rdr_curveBreak_inc.add(count); + if (DO_STATS) { + rdrCtx.stats.stat_rdr_curveBreak_inc.add(count); } } if (--count > 0) { @@ -307,21 +307,21 @@ final class Renderer implements PathConsumer2D, MarlinConst { addLine(x0, y0, x1, y1); - if (doStats) { nL++; } + if (DO_STATS) { nL++; } x0 = x1; y0 = y1; } - if (doStats) { - RendererContext.stats.stat_rdr_curveBreak.add(nL); + if (DO_STATS) { + rdrCtx.stats.stat_rdr_curveBreak.add(nL); } } private void addLine(float x1, float y1, float x2, float y2) { - if (doMonitors) { - RendererContext.stats.mon_rdr_addLine.start(); + if (DO_MONITORS) { + rdrCtx.stats.mon_rdr_addLine.start(); } - if (doStats) { - RendererContext.stats.stat_rdr_addLine.add(1); + if (DO_STATS) { + rdrCtx.stats.stat_rdr_addLine.add(1); } int or = 1; // orientation of the line. 1 if y increases, 0 otherwise. if (y2 < y1) { @@ -349,11 +349,11 @@ final class Renderer implements PathConsumer2D, MarlinConst { /* skip horizontal lines in pixel space and clip edges out of y range [boundsMinY; boundsMaxY] */ if (firstCrossing >= lastCrossing) { - if (doMonitors) { - RendererContext.stats.mon_rdr_addLine.stop(); + if (DO_MONITORS) { + rdrCtx.stats.mon_rdr_addLine.stop(); } - if (doStats) { - RendererContext.stats.stat_rdr_addLine_skip.add(1); + if (DO_STATS) { + rdrCtx.stats.stat_rdr_addLine_skip.add(1); } return; } @@ -405,14 +405,14 @@ final class Renderer implements PathConsumer2D, MarlinConst { final long edgeNewSize = ArrayCache.getNewLargeSize(_edges.length, edgePtr + _SIZEOF_EDGE_BYTES); - if (doStats) { - RendererContext.stats.stat_rdr_edges_resizes.add(edgeNewSize); + if (DO_STATS) { + rdrCtx.stats.stat_rdr_edges_resizes.add(edgeNewSize); } _edges.resize(edgeNewSize); } - final Unsafe _unsafe = OffHeapArray.unsafe; + final Unsafe _unsafe = OffHeapArray.UNSAFE; final long SIZE_INT = 4L; long addr = _edges.address + edgePtr; @@ -486,8 +486,8 @@ final class Renderer implements PathConsumer2D, MarlinConst { // update free pointer (ie length in bytes) _edges.used += _SIZEOF_EDGE_BYTES; - if (doMonitors) { - RendererContext.stats.mon_rdr_addLine.stop(); + if (DO_MONITORS) { + rdrCtx.stats.mon_rdr_addLine.stop(); } } @@ -552,7 +552,7 @@ final class Renderer implements PathConsumer2D, MarlinConst { this.boundsMaxY = (pix_boundsY + pix_boundsHeight) << SUBPIXEL_LG_POSITIONS_Y; - if (doLogBounds) { + if (DO_LOG_BOUNDS) { MarlinUtils.logInfo("boundsXY = [" + boundsMinX + " ... " + boundsMaxX + "[ [" + boundsMinY + " ... " + boundsMaxY + "["); @@ -563,10 +563,10 @@ final class Renderer implements PathConsumer2D, MarlinConst { final int edgeBucketsLength = (boundsMaxY - boundsMinY) + 1; if (edgeBucketsLength > INITIAL_BUCKET_ARRAY) { - if (doStats) { - RendererContext.stats.stat_array_renderer_edgeBuckets + if (DO_STATS) { + rdrCtx.stats.stat_array_renderer_edgeBuckets .add(edgeBucketsLength); - RendererContext.stats.stat_array_renderer_edgeBucketCounts + rdrCtx.stats.stat_array_renderer_edgeBucketCounts .add(edgeBucketsLength); } edgeBuckets = rdrCtx.getIntArray(edgeBucketsLength); @@ -592,13 +592,13 @@ final class Renderer implements PathConsumer2D, MarlinConst { * Disposes this renderer and recycle it clean up before reusing this instance */ void dispose() { - if (doStats) { - RendererContext.stats.stat_rdr_activeEdges.add(activeEdgeMaxUsed); - RendererContext.stats.stat_rdr_edges.add(edges.used); - RendererContext.stats.stat_rdr_edges_count + if (DO_STATS) { + rdrCtx.stats.stat_rdr_activeEdges.add(activeEdgeMaxUsed); + rdrCtx.stats.stat_rdr_edges.add(edges.used); + rdrCtx.stats.stat_rdr_edges_count .add(edges.used / SIZEOF_EDGE_BYTES); } - if (doCleanDirty) { + if (DO_CLEAN_DIRTY) { // Force zero-fill dirty arrays: Arrays.fill(crossings, 0); Arrays.fill(aux_crossings, 0); @@ -670,12 +670,12 @@ final class Renderer implements PathConsumer2D, MarlinConst { // note: may throw OOME: edges.resize(INITIAL_EDGES_CAPACITY); } - if (doCleanDirty) { + if (DO_CLEAN_DIRTY) { // Force zero-fill dirty arrays: edges.fill(BYTE_0); } - if (doMonitors) { - RendererContext.stats.mon_rdr_endRendering.stop(); + if (DO_MONITORS) { + rdrCtx.stats.mon_rdr_endRendering.stop(); } } @@ -793,7 +793,7 @@ final class Renderer implements PathConsumer2D, MarlinConst { final int _ERR_STEP_MAX = ERR_STEP_MAX; // unsafe I/O: - final Unsafe _unsafe = OffHeapArray.unsafe; + final Unsafe _unsafe = OffHeapArray.UNSAFE; final long addr0 = _edges.address; long addr; final int _SUBPIXEL_LG_POSITIONS_X = SUBPIXEL_LG_POSITIONS_X; @@ -856,8 +856,8 @@ final class Renderer implements PathConsumer2D, MarlinConst { // bucketCount indicates new edge / edge end: if (bucketcount != 0) { - if (doStats) { - RendererContext.stats.stat_rdr_activeEdges_updates + if (DO_STATS) { + rdrCtx.stats.stat_rdr_activeEdges_updates .add(numCrossings); } @@ -882,19 +882,19 @@ final class Renderer implements PathConsumer2D, MarlinConst { ptrLen = bucketcount >> 1; // number of new edge if (ptrLen != 0) { - if (doStats) { - RendererContext.stats.stat_rdr_activeEdges_adds + if (DO_STATS) { + rdrCtx.stats.stat_rdr_activeEdges_adds .add(ptrLen); if (ptrLen > 10) { - RendererContext.stats.stat_rdr_activeEdges_adds_high + rdrCtx.stats.stat_rdr_activeEdges_adds_high .add(ptrLen); } } ptrEnd = numCrossings + ptrLen; if (edgePtrsLen < ptrEnd) { - if (doStats) { - RendererContext.stats.stat_array_renderer_edgePtrs + if (DO_STATS) { + rdrCtx.stats.stat_array_renderer_edgePtrs .add(ptrEnd); } this.edgePtrs = _edgePtrs @@ -908,8 +908,8 @@ final class Renderer implements PathConsumer2D, MarlinConst { } // use ArrayCache.getNewSize() to use the same growing // factor than widenDirtyIntArray(): - if (doStats) { - RendererContext.stats.stat_array_renderer_aux_edgePtrs + if (DO_STATS) { + rdrCtx.stats.stat_array_renderer_aux_edgePtrs .add(ptrEnd); } this.aux_edgePtrs = _aux_edgePtrs @@ -936,8 +936,8 @@ final class Renderer implements PathConsumer2D, MarlinConst { if (_crossings != crossings_initial) { rdrCtx.putDirtyIntArray(_crossings); } - if (doStats) { - RendererContext.stats.stat_array_renderer_crossings + if (DO_STATS) { + rdrCtx.stats.stat_array_renderer_crossings .add(numCrossings); } this.crossings = _crossings @@ -947,8 +947,8 @@ final class Renderer implements PathConsumer2D, MarlinConst { if (_aux_crossings != aux_crossings_initial) { rdrCtx.putDirtyIntArray(_aux_crossings); } - if (doStats) { - RendererContext.stats.stat_array_renderer_aux_crossings + if (DO_STATS) { + rdrCtx.stats.stat_array_renderer_aux_crossings .add(numCrossings); } this.aux_crossings = _aux_crossings @@ -956,7 +956,7 @@ final class Renderer implements PathConsumer2D, MarlinConst { crossingsLen = _crossings.length; } - if (doStats) { + if (DO_STATS) { // update max used mark if (numCrossings > _arrayMaxUsed) { _arrayMaxUsed = numCrossings; @@ -972,10 +972,10 @@ final class Renderer implements PathConsumer2D, MarlinConst { * for newly added edges + final merge pass. */ if ((ptrLen < 10) || (numCrossings < 40)) { - if (doStats) { - RendererContext.stats.hist_rdr_crossings + if (DO_STATS) { + rdrCtx.stats.hist_rdr_crossings .add(numCrossings); - RendererContext.stats.hist_rdr_crossings_adds + rdrCtx.stats.hist_rdr_crossings_adds .add(ptrLen); } @@ -1018,23 +1018,23 @@ final class Renderer implements PathConsumer2D, MarlinConst { _unsafe.putInt(addr, curx - ((err >> 30) & _ALL_BUT_LSB)); _unsafe.putInt(addr + _OFF_ERROR, (err & _ERR_STEP_MAX)); - if (doStats) { - RendererContext.stats.stat_rdr_crossings_updates + if (DO_STATS) { + rdrCtx.stats.stat_rdr_crossings_updates .add(numCrossings); } // insertion sort of crossings: if (cross < lastCross) { - if (doStats) { - RendererContext.stats.stat_rdr_crossings_sorts + if (DO_STATS) { + rdrCtx.stats.stat_rdr_crossings_sorts .add(i); } /* use binary search for newly added edges in crossings if arrays are large enough */ if (useBinarySearch && (i >= prevNumCrossings)) { - if (doStats) { - RendererContext.stats. + if (DO_STATS) { + rdrCtx.stats. stat_rdr_crossings_bsearch.add(i); } low = 0; @@ -1077,14 +1077,14 @@ final class Renderer implements PathConsumer2D, MarlinConst { } } } else { - if (doStats) { - RendererContext.stats.stat_rdr_crossings_msorts + if (DO_STATS) { + rdrCtx.stats.stat_rdr_crossings_msorts .add(numCrossings); - RendererContext.stats.hist_rdr_crossings_ratio + rdrCtx.stats.hist_rdr_crossings_ratio .add((1000 * ptrLen) / numCrossings); - RendererContext.stats.hist_rdr_crossings_msorts + rdrCtx.stats.hist_rdr_crossings_msorts .add(numCrossings); - RendererContext.stats.hist_rdr_crossings_msorts_adds + rdrCtx.stats.hist_rdr_crossings_msorts_adds .add(ptrLen); } @@ -1124,8 +1124,8 @@ final class Renderer implements PathConsumer2D, MarlinConst { _unsafe.putInt(addr, curx - ((err >> 30) & _ALL_BUT_LSB)); _unsafe.putInt(addr + _OFF_ERROR, (err & _ERR_STEP_MAX)); - if (doStats) { - RendererContext.stats.stat_rdr_crossings_updates + if (DO_STATS) { + rdrCtx.stats.stat_rdr_crossings_updates .add(numCrossings); } @@ -1135,8 +1135,8 @@ final class Renderer implements PathConsumer2D, MarlinConst { _crossings[i] = cross; } else if (cross < lastCross) { - if (doStats) { - RendererContext.stats.stat_rdr_crossings_sorts + if (DO_STATS) { + rdrCtx.stats.stat_rdr_crossings_sorts .add(i); } @@ -1356,10 +1356,10 @@ final class Renderer implements PathConsumer2D, MarlinConst { useBlkFlags = (maxX > _BLK_SIZE) && (maxX > (((numCrossings >> stroking) - 1) << _BLK_SIZE_LG)); - if (doStats) { + if (DO_STATS) { tmp = FloatMath.max(1, ((numCrossings >> stroking) - 1)); - RendererContext.stats.hist_tile_generator_encoding_dist + rdrCtx.stats.hist_tile_generator_encoding_dist .add(maxX / tmp); } } @@ -1392,15 +1392,15 @@ final class Renderer implements PathConsumer2D, MarlinConst { edgeCount = numCrossings; prevUseBlkFlags = useBlkFlags; - if (doStats) { + if (DO_STATS) { // update max used mark activeEdgeMaxUsed = _arrayMaxUsed; } } boolean endRendering() { - if (doMonitors) { - RendererContext.stats.mon_rdr_endRendering.start(); + if (DO_MONITORS) { + rdrCtx.stats.mon_rdr_endRendering.start(); } if (edgeMinY == Integer.MAX_VALUE) { return false; // undefined edges bounds @@ -1427,7 +1427,7 @@ final class Renderer implements PathConsumer2D, MarlinConst { buckets_minY = spminY - _boundsMinY; buckets_maxY = maxY - _boundsMinY; - if (doLogBounds) { + if (DO_LOG_BOUNDS) { MarlinUtils.logInfo("edgesXY = [" + edgeMinX + " ... " + edgeMaxX + "][" + edgeMinY + " ... " + edgeMaxY + "]"); MarlinUtils.logInfo("spXY = [" + spminX + " ... " + spmaxX @@ -1479,7 +1479,7 @@ final class Renderer implements PathConsumer2D, MarlinConst { // exclusive: bbox_spmaxY = FloatMath.min(spmaxY + 1, pmaxY << SUBPIXEL_LG_POSITIONS_Y); - if (doLogBounds) { + if (DO_LOG_BOUNDS) { MarlinUtils.logInfo("pXY = [" + pminX + " ... " + pmaxX + "[ [" + pminY + " ... " + pmaxY + "["); MarlinUtils.logInfo("bbox_spXY = [" + bbox_spminX + " ... " @@ -1493,8 +1493,8 @@ final class Renderer implements PathConsumer2D, MarlinConst { // Useful when processing tile line by tile line if (width > INITIAL_AA_ARRAY) { - if (doStats) { - RendererContext.stats.stat_array_renderer_alphaline + if (DO_STATS) { + rdrCtx.stats.stat_array_renderer_alphaline .add(width); } alphaLine = rdrCtx.getIntArray(width); @@ -1509,8 +1509,8 @@ final class Renderer implements PathConsumer2D, MarlinConst { private int bbox_spminX, bbox_spmaxX, bbox_spminY, bbox_spmaxY; void endRendering(final int pminY) { - if (doMonitors) { - RendererContext.stats.mon_rdr_endRendering_Y.start(); + if (DO_MONITORS) { + rdrCtx.stats.mon_rdr_endRendering_Y.start(); } final int spminY = pminY << SUBPIXEL_LG_POSITIONS_Y; @@ -1527,8 +1527,8 @@ final class Renderer implements PathConsumer2D, MarlinConst { // Process only one tile line: _endRendering(fixed_spminY, spmaxY); } - if (doMonitors) { - RendererContext.stats.mon_rdr_endRendering_Y.stop(); + if (DO_MONITORS) { + rdrCtx.stats.mon_rdr_endRendering_Y.stop(); } } @@ -1544,13 +1544,13 @@ final class Renderer implements PathConsumer2D, MarlinConst { final boolean useBlockFlags) { if (useBlockFlags) { - if (doStats) { - RendererContext.stats.hist_tile_generator_encoding.add(1); + if (DO_STATS) { + rdrCtx.stats.hist_tile_generator_encoding.add(1); } cache.copyAARowRLE_WithBlockFlags(blkFlags, alphaRow, pix_y, pix_from, pix_to); } else { - if (doStats) { - RendererContext.stats.hist_tile_generator_encoding.add(0); + if (DO_STATS) { + rdrCtx.stats.hist_tile_generator_encoding.add(0); } cache.copyAARowNoRLE(alphaRow, pix_y, pix_from, pix_to); } diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/RendererContext.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/RendererContext.java index 60de2c31570..a11a1e829d6 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/RendererContext.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/RendererContext.java @@ -40,12 +40,12 @@ import static sun.java2d.marlin.MarlinUtils.logInfo; final class RendererContext extends ReentrantContext implements MarlinConst { // RendererContext creation counter - private static final AtomicInteger contextCount = new AtomicInteger(1); + private static final AtomicInteger CTX_COUNT = new AtomicInteger(1); // RendererContext statistics - static final RendererStats stats = (doStats || doMonitors) + final RendererStats stats = (DO_STATS || DO_MONITORS) ? RendererStats.getInstance(): null; - private static final boolean USE_CACHE_HARD_REF = doStats + private static final boolean USE_CACHE_HARD_REF = DO_STATS || (MarlinRenderingEngine.REF_TYPE == ReentrantContextProvider.REF_WEAK); /** @@ -55,10 +55,10 @@ final class RendererContext extends ReentrantContext implements MarlinConst { */ static RendererContext createContext() { final RendererContext newCtx = new RendererContext("ctx" - + Integer.toString(contextCount.getAndIncrement())); + + Integer.toString(CTX_COUNT.getAndIncrement())); - if (RendererContext.stats != null) { - RendererContext.stats.allContexts.add(newCtx); + if (DO_STATS || DO_MONITORS) { + RendererStats.ALL_CONTEXTS.add(newCtx); } return newCtx; } @@ -101,7 +101,7 @@ final class RendererContext extends ReentrantContext implements MarlinConst { * @param name context name (debugging) */ RendererContext(final String name) { - if (logCreateContext) { + if (LOG_CREATE_CONTEXT) { MarlinUtils.logInfo("new RendererContext = " + name); } @@ -162,7 +162,7 @@ final class RendererContext extends ReentrantContext implements MarlinConst { : null; // create a new ArrayCachesHolder if none is available if (holder == null) { - if (logCreateContext) { + if (LOG_CREATE_CONTEXT) { MarlinUtils.logInfo("new ArrayCachesHolder for " + "RendererContext = " + name); } @@ -192,11 +192,11 @@ final class RendererContext extends ReentrantContext implements MarlinConst { return getDirtyByteArrayCache(length).getArray(); } - if (doStats) { + if (DO_STATS) { incOversize(); } - if (doLogOverSize) { + if (DO_LOG_OVERSIZE) { logInfo("getDirtyByteArray[oversize]: length=\t" + length); } @@ -216,10 +216,10 @@ final class RendererContext extends ReentrantContext implements MarlinConst { final int usedSize, final int needSize) { final int length = in.length; - if (doChecks && length >= needSize) { + if (DO_CHECKS && length >= needSize) { return in; } - if (doStats) { + if (DO_STATS) { incResizeDirtyByte(); } @@ -233,7 +233,7 @@ final class RendererContext extends ReentrantContext implements MarlinConst { // NO clean-up of array data = DIRTY ARRAY putDirtyByteArray(in); - if (doLogWidenArray) { + if (DO_LOG_WIDEN_ARRAY) { logInfo("widenDirtyByteArray[" + res.length + "]: usedSize=\t" + usedSize + "\tlength=\t" + length + "\tneeded length=\t" + needSize); @@ -252,11 +252,11 @@ final class RendererContext extends ReentrantContext implements MarlinConst { return getIntArrayCache(length).getArray(); } - if (doStats) { + if (DO_STATS) { incOversize(); } - if (doLogOverSize) { + if (DO_LOG_OVERSIZE) { logInfo("getIntArray[oversize]: length=\t" + length); } @@ -268,10 +268,10 @@ final class RendererContext extends ReentrantContext implements MarlinConst { final int needSize, final int clearTo) { final int length = in.length; - if (doChecks && length >= needSize) { + if (DO_CHECKS && length >= needSize) { return in; } - if (doStats) { + if (DO_STATS) { incResizeInt(); } @@ -284,7 +284,7 @@ final class RendererContext extends ReentrantContext implements MarlinConst { // maybe return current array: putIntArray(in, 0, clearTo); // ensure all array is cleared (grow-reduce algo) - if (doLogWidenArray) { + if (DO_LOG_WIDEN_ARRAY) { logInfo("widenIntArray[" + res.length + "]: usedSize=\t" + usedSize + "\tlength=\t" + length + "\tneeded length=\t" + needSize); @@ -314,11 +314,11 @@ final class RendererContext extends ReentrantContext implements MarlinConst { return getDirtyIntArrayCache(length).getArray(); } - if (doStats) { + if (DO_STATS) { incOversize(); } - if (doLogOverSize) { + if (DO_LOG_OVERSIZE) { logInfo("getDirtyIntArray[oversize]: length=\t" + length); } @@ -329,10 +329,10 @@ final class RendererContext extends ReentrantContext implements MarlinConst { final int usedSize, final int needSize) { final int length = in.length; - if (doChecks && length >= needSize) { + if (DO_CHECKS && length >= needSize) { return in; } - if (doStats) { + if (DO_STATS) { incResizeDirtyInt(); } @@ -346,7 +346,7 @@ final class RendererContext extends ReentrantContext implements MarlinConst { // NO clean-up of array data = DIRTY ARRAY putDirtyIntArray(in); - if (doLogWidenArray) { + if (DO_LOG_WIDEN_ARRAY) { logInfo("widenDirtyIntArray[" + res.length + "]: usedSize=\t" + usedSize + "\tlength=\t" + length + "\tneeded length=\t" + needSize); @@ -374,11 +374,11 @@ final class RendererContext extends ReentrantContext implements MarlinConst { return getDirtyFloatArrayCache(length).getArray(); } - if (doStats) { + if (DO_STATS) { incOversize(); } - if (doLogOverSize) { + if (DO_LOG_OVERSIZE) { logInfo("getDirtyFloatArray[oversize]: length=\t" + length); } @@ -389,10 +389,10 @@ final class RendererContext extends ReentrantContext implements MarlinConst { final int usedSize, final int needSize) { final int length = in.length; - if (doChecks && length >= needSize) { + if (DO_CHECKS && length >= needSize) { return in; } - if (doStats) { + if (DO_STATS) { incResizeDirtyFloat(); } @@ -406,7 +406,7 @@ final class RendererContext extends ReentrantContext implements MarlinConst { // NO clean-up of array data = DIRTY ARRAY putDirtyFloatArray(in); - if (doLogWidenArray) { + if (DO_LOG_WIDEN_ARRAY) { logInfo("widenDirtyFloatArray[" + res.length + "]: usedSize=\t" + usedSize + "\tlength=\t" + length + "\tneeded length=\t" + needSize); diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/RendererStats.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/RendererStats.java index 4588bf270b3..0ed91854331 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/RendererStats.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/RendererStats.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -42,24 +42,24 @@ import sun.awt.util.ThreadGroupUtils; public final class RendererStats implements MarlinConst { // singleton - private static volatile RendererStats singleton = null; + private static volatile RendererStats SINGLETON = null; static RendererStats getInstance() { - if (singleton == null) { - singleton = new RendererStats(); + if (SINGLETON == null) { + SINGLETON = new RendererStats(); } - return singleton; + return SINGLETON; } public static void dumpStats() { - if (singleton != null) { - singleton.dump(); + if (SINGLETON != null) { + SINGLETON.dump(); } } /* RendererContext collection as hard references (only used for debugging purposes) */ - final ConcurrentLinkedQueue allContexts + static final ConcurrentLinkedQueue ALL_CONTEXTS = new ConcurrentLinkedQueue(); // stats final StatLong stat_cache_rowAA @@ -208,8 +208,6 @@ public final class RendererStats implements MarlinConst { // monitors final Monitor mon_pre_getAATileGenerator = new Monitor("MarlinRenderingEngine.getAATileGenerator()"); - final Monitor mon_npi_currentSegment - = new Monitor("NormalizingPathIterator.currentSegment()"); final Monitor mon_rdr_addLine = new Monitor("Renderer.addLine()"); final Monitor mon_rdr_endRendering @@ -227,7 +225,6 @@ public final class RendererStats implements MarlinConst { // all monitors final Monitor[] monitors = new Monitor[]{ mon_pre_getAATileGenerator, - mon_npi_currentSegment, mon_rdr_addLine, mon_rdr_endRendering, mon_rdr_endRendering_Y, @@ -255,14 +252,14 @@ public final class RendererStats implements MarlinConst { hook.setContextClassLoader(null); Runtime.getRuntime().addShutdownHook(hook); - if (useDumpThread) { + if (USE_DUMP_THREAD) { final Timer statTimer = new Timer("RendererStats"); statTimer.scheduleAtFixedRate(new TimerTask() { @Override public void run() { dump(); } - }, statDump, statDump); + }, DUMP_INTERVAL, DUMP_INTERVAL); } return null; } @@ -270,15 +267,13 @@ public final class RendererStats implements MarlinConst { } void dump() { - if (doStats) { + if (DO_STATS) { ArrayCache.dumpStats(); } - final RendererContext[] all = allContexts.toArray( - new RendererContext[allContexts.size()]); - for (RendererContext rdrCtx : all) { + for (RendererContext rdrCtx : ALL_CONTEXTS) { logInfo("RendererContext: " + rdrCtx.name); - if (doMonitors) { + if (DO_MONITORS) { for (Monitor monitor : monitors) { if (monitor.count != 0) { logInfo(monitor.toString()); @@ -292,14 +287,14 @@ public final class RendererStats implements MarlinConst { + ((100d * monitor.sum) / total) + " %"); } } - if (doFlushMonitors) { + if (DO_FLUSH_MONITORS) { for (Monitor m : monitors) { m.reset(); } } } - if (doStats) { + if (DO_STATS) { for (StatLong stat : statistics) { if (stat.count != 0) { logInfo(stat.toString()); diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Stroker.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Stroker.java index 54c7ec32300..f25993b29ee 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Stroker.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Stroker.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -180,7 +180,7 @@ final class Stroker implements PathConsumer2D, MarlinConst { void dispose() { reverse.dispose(); - if (doCleanDirty) { + if (DO_CLEAN_DIRTY) { // Force zero-fill dirty arrays: Arrays.fill(offset0, 0f); Arrays.fill(offset1, 0f); @@ -226,7 +226,7 @@ final class Stroker implements PathConsumer2D, MarlinConst { boolean rev, float threshold) { - if ((omx == 0 && omy == 0) || (mx == 0 && my == 0)) { + if ((omx == 0f && omy == 0f) || (mx == 0f && my == 0f)) { return; } @@ -338,12 +338,14 @@ final class Stroker implements PathConsumer2D, MarlinConst { } private void drawRoundCap(float cx, float cy, float mx, float my) { - emitCurveTo(cx+mx-C*my, cy+my+C*mx, - cx-my+C*mx, cy+mx+C*my, - cx-my, cy+mx); - emitCurveTo(cx-my-C*mx, cy+mx-C*my, - cx-mx-C*my, cy-my+C*mx, - cx-mx, cy-my); + final float Cmx = C * mx; + final float Cmy = C * my; + emitCurveTo(cx + mx - Cmy, cy + my + Cmx, + cx - my + Cmx, cy + mx + Cmy, + cx - my, cy + mx); + emitCurveTo(cx - my - Cmx, cy + mx - Cmy, + cx - mx - Cmy, cy - my + Cmx, + cx - mx, cy - my); } // Put the intersection point of the lines (x0, y0) -> (x1, y1) @@ -412,8 +414,8 @@ final class Stroker implements PathConsumer2D, MarlinConst { } this.sx0 = this.cx0 = x0; this.sy0 = this.cy0 = y0; - this.cdx = this.sdx = 1; - this.cdy = this.sdy = 0; + this.cdx = this.sdx = 1f; + this.cdy = this.sdy = 0f; this.prev = MOVE_TO; } @@ -452,10 +454,10 @@ final class Stroker implements PathConsumer2D, MarlinConst { return; } emitMoveTo(cx0, cy0 - lineWidth2); - this.cmx = this.smx = 0; + this.cmx = this.smx = 0f; this.cmy = this.smy = -lineWidth2; - this.cdx = this.sdx = 1; - this.cdy = this.sdy = 0; + this.cdx = this.sdx = 1f; + this.cdy = this.sdy = 0f; finish(); return; } @@ -1232,7 +1234,7 @@ final class Stroker implements PathConsumer2D, MarlinConst { end = 0; numCurves = 0; - if (doStats) { + if (DO_STATS) { curveTypesUseMark = 0; curvesUseMark = 0; } @@ -1246,10 +1248,10 @@ final class Stroker implements PathConsumer2D, MarlinConst { end = 0; numCurves = 0; - if (doStats) { - RendererContext.stats.stat_rdr_poly_stack_types + if (DO_STATS) { + rdrCtx.stats.stat_rdr_poly_stack_types .add(curveTypesUseMark); - RendererContext.stats.stat_rdr_poly_stack_curves + rdrCtx.stats.stat_rdr_poly_stack_curves .add(curvesUseMark); // reset marks curveTypesUseMark = 0; @@ -1272,15 +1274,15 @@ final class Stroker implements PathConsumer2D, MarlinConst { private void ensureSpace(final int n) { // use substraction to avoid integer overflow: if (curves.length - end < n) { - if (doStats) { - RendererContext.stats.stat_array_stroker_polystack_curves + if (DO_STATS) { + rdrCtx.stats.stat_array_stroker_polystack_curves .add(end + n); } curves = rdrCtx.widenDirtyFloatArray(curves, end, end + n); } if (curveTypes.length <= numCurves) { - if (doStats) { - RendererContext.stats.stat_array_stroker_polystack_curveTypes + if (DO_STATS) { + rdrCtx.stats.stat_array_stroker_polystack_curveTypes .add(numCurves + 1); } curveTypes = rdrCtx.widenDirtyByteArray(curveTypes, @@ -1323,7 +1325,7 @@ final class Stroker implements PathConsumer2D, MarlinConst { } void popAll(PathConsumer2D io) { - if (doStats) { + if (DO_STATS) { // update used marks: if (numCurves > curveTypesUseMark) { curveTypesUseMark = numCurves; diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Version.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Version.java index 9bd0498f7da..dc0a9255975 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Version.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/Version.java @@ -27,10 +27,10 @@ package sun.java2d.marlin; public final class Version { - private static final String version = "marlin-0.7.3.3-Unsafe-OpenJDK"; + private static final String VERSION = "marlin-0.7.3.4-Unsafe-OpenJDK"; public static String getVersion() { - return version; + return VERSION; } private Version() { diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/stats/Histogram.java b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/stats/Histogram.java index 324e9ff4af6..92865cbf3f4 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/marlin/stats/Histogram.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/marlin/stats/Histogram.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,8 +25,6 @@ package sun.java2d.marlin.stats; -import java.util.Arrays; - /** * Generic histogram based on long statistics */ diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/pipe/AAShapePipe.java b/jdk/src/java.desktop/share/classes/sun/java2d/pipe/AAShapePipe.java index 0aa5e54195f..2a796b91115 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/pipe/AAShapePipe.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/pipe/AAShapePipe.java @@ -44,10 +44,10 @@ import sun.java2d.SunGraphics2D; public final class AAShapePipe implements ShapeDrawPipe, ParallelogramPipe { - static final RenderingEngine renderengine = RenderingEngine.getInstance(); + static final RenderingEngine RDR_ENGINE = RenderingEngine.getInstance(); // Per-thread TileState (~1K very small so do not use any Weak Reference) - private static final ReentrantContextProvider tileStateProvider = + private static final ReentrantContextProvider TILE_STATE_PROVIDER = new ReentrantContextProviderTL( ReentrantContextProvider.REF_HARD) { @@ -90,19 +90,19 @@ public final class AAShapePipe double dx1, double dy1, double dx2, double dy2) { - final TileState ts = tileStateProvider.acquire(); + final TileState ts = TILE_STATE_PROVIDER.acquire(); try { final int[] abox = ts.abox; final AATileGenerator aatg = - renderengine.getAATileGenerator(x, y, dx1, dy1, dx2, dy2, 0, 0, + RDR_ENGINE.getAATileGenerator(x, y, dx1, dy1, dx2, dy2, 0, 0, sg.getCompClip(), abox); if (aatg != null) { renderTiles(sg, ts.computeBBox(ux1, uy1, ux2, uy2), aatg, abox, ts); } } finally { - tileStateProvider.release(ts); + TILE_STATE_PROVIDER.release(ts); } } @@ -115,12 +115,12 @@ public final class AAShapePipe double dx2, double dy2, double lw1, double lw2) { - final TileState ts = tileStateProvider.acquire(); + final TileState ts = TILE_STATE_PROVIDER.acquire(); try { final int[] abox = ts.abox; final AATileGenerator aatg = - renderengine.getAATileGenerator(x, y, dx1, dy1, dx2, dy2, lw1, + RDR_ENGINE.getAATileGenerator(x, y, dx1, dy1, dx2, dy2, lw1, lw2, sg.getCompClip(), abox); if (aatg != null) { // Note that bbox is of the original shape, not the wide path. @@ -129,7 +129,7 @@ public final class AAShapePipe aatg, abox, ts); } } finally { - tileStateProvider.release(ts); + TILE_STATE_PROVIDER.release(ts); } } @@ -138,18 +138,18 @@ public final class AAShapePipe sg.strokeHint != SunHints.INTVAL_STROKE_PURE); final boolean thin = (sg.strokeState <= SunGraphics2D.STROKE_THINDASHED); - final TileState ts = tileStateProvider.acquire(); + final TileState ts = TILE_STATE_PROVIDER.acquire(); try { final int[] abox = ts.abox; final AATileGenerator aatg = - renderengine.getAATileGenerator(s, sg.transform, sg.getCompClip(), + RDR_ENGINE.getAATileGenerator(s, sg.transform, sg.getCompClip(), bs, thin, adjust, abox); if (aatg != null) { renderTiles(sg, s, aatg, abox, ts); } } finally { - tileStateProvider.release(ts); + TILE_STATE_PROVIDER.release(ts); } } diff --git a/jdk/src/java.desktop/share/classes/sun/print/PSPrinterJob.java b/jdk/src/java.desktop/share/classes/sun/print/PSPrinterJob.java index deada0605ce..511fd3a6195 100644 --- a/jdk/src/java.desktop/share/classes/sun/print/PSPrinterJob.java +++ b/jdk/src/java.desktop/share/classes/sun/print/PSPrinterJob.java @@ -501,7 +501,7 @@ public class PSPrinterJob extends RasterPrinterJob { // Note that we only open a file if it has been nominated by // the end-user in a dialog that we ouselves put up. - OutputStream output; + OutputStream output = null; if (epsPrinter == null) { if (getPrintService() instanceof PSStreamPrintService) { @@ -526,6 +526,7 @@ public class PSPrinterJob extends RasterPrinterJob { spoolFile = new File(mDestination); output = new FileOutputStream(spoolFile); } catch (IOException ex) { + abortDoc(); throw new PrinterIOException(ex); } } else { @@ -771,6 +772,10 @@ public class PSPrinterJob extends RasterPrinterJob { if (mPSStream != null) { mPSStream.println(EOF_COMMENT); mPSStream.flush(); + if (mPSStream.checkError()) { + abortDoc(); + throw new PrinterException("Error while writing to file"); + } if (mDestType != RasterPrinterJob.STREAM) { mPSStream.close(); } diff --git a/jdk/src/java.desktop/share/classes/sun/print/RasterPrinterJob.java b/jdk/src/java.desktop/share/classes/sun/print/RasterPrinterJob.java index 638e01488e6..cd6793a8786 100644 --- a/jdk/src/java.desktop/share/classes/sun/print/RasterPrinterJob.java +++ b/jdk/src/java.desktop/share/classes/sun/print/RasterPrinterJob.java @@ -683,7 +683,21 @@ public abstract class RasterPrinterJob extends PrinterJob { float iw = (float)(page.getPaper().getImageableWidth()/DPI); float iy = (float)(page.getPaper().getImageableY()/DPI); float ih = (float)(page.getPaper().getImageableHeight()/DPI); - if (ix < 0) ix = 0f; if (iy < 0) iy = 0f; + + if (ix < 0) ix = 0; if (iy < 0) iy = 0; + if (iw <= 0) iw = (float)(page.getPaper().getWidth()/DPI) - (ix*2); + + // If iw is still negative, it means ix is too large to print + // anything inside printable area if we have to leave the same margin + // in the right side of paper so we go back to default mpa values + if (iw < 0) iw = 0; + + if (ih <= 0) ih = (float)(page.getPaper().getHeight()/DPI) - (iy*2); + + // If ih is still negative, it means iy is too large to print + // anything inside printable area if we have to leave the same margin + // in the bottom side of paper so we go back to default mpa values + if (ih < 0) ih = 0; try { pageAttributes.add(new MediaPrintableArea(ix, iy, iw, ih, MediaPrintableArea.INCH)); @@ -1613,6 +1627,9 @@ public abstract class RasterPrinterJob extends PrinterJob { (!f.isFile() || !f.canWrite())) || ((pFile != null) && (!pFile.exists() || (pFile.exists() && !pFile.canWrite())))) { + if (f.exists()) { + f.delete(); + } throw new PrinterException("Cannot write to file:"+ dest); } diff --git a/jdk/src/java.desktop/share/classes/sun/swing/SwingUtilities2.java b/jdk/src/java.desktop/share/classes/sun/swing/SwingUtilities2.java index 0b9104a826a..6f4c5f7045b 100644 --- a/jdk/src/java.desktop/share/classes/sun/swing/SwingUtilities2.java +++ b/jdk/src/java.desktop/share/classes/sun/swing/SwingUtilities2.java @@ -30,6 +30,7 @@ import java.awt.*; import static java.awt.RenderingHints.*; import java.awt.event.*; import java.awt.font.*; +import java.awt.geom.AffineTransform; import java.awt.print.PrinterGraphics; import java.text.BreakIterator; import java.text.CharacterIterator; @@ -1060,17 +1061,23 @@ public class SwingUtilities2 { */ private static FontRenderContext getFRCProperty(JComponent c) { if (c != null) { + + GraphicsConfiguration gc = c.getGraphicsConfiguration(); + AffineTransform tx = (gc == null) ? null : gc.getDefaultTransform(); Object aaHint = c.getClientProperty(KEY_TEXT_ANTIALIASING); - if (aaHint != null) { - return getFRCFromCache(aaHint); - } + return getFRCFromCache(tx, aaHint); } return null; } private static final Object APP_CONTEXT_FRC_CACHE_KEY = new Object(); - private static FontRenderContext getFRCFromCache(Object aaHint) { + private static FontRenderContext getFRCFromCache(AffineTransform tx, + Object aaHint) { + if (tx == null && aaHint == null) { + return null; + } + @SuppressWarnings("unchecked") Map cache = (Map) AppContext.getAppContext().get(APP_CONTEXT_FRC_CACHE_KEY); @@ -1080,15 +1087,45 @@ public class SwingUtilities2 { AppContext.getAppContext().put(APP_CONTEXT_FRC_CACHE_KEY, cache); } - FontRenderContext frc = cache.get(aaHint); + Object key = (tx == null) + ? aaHint + : (aaHint == null ? tx : new KeyPair(tx, aaHint)); + + FontRenderContext frc = cache.get(key); if (frc == null) { - frc = new FontRenderContext(null, aaHint, - VALUE_FRACTIONALMETRICS_DEFAULT); - cache.put(aaHint, frc); + aaHint = (aaHint == null) ? VALUE_TEXT_ANTIALIAS_OFF : aaHint; + frc = new FontRenderContext(tx, aaHint, + VALUE_FRACTIONALMETRICS_DEFAULT); + cache.put(key, frc); } return frc; } + private static class KeyPair { + + private final Object key1; + private final Object key2; + + public KeyPair(Object key1, Object key2) { + this.key1 = key1; + this.key2 = key2; + } + + @Override + public boolean equals(Object obj) { + if (!(obj instanceof KeyPair)) { + return false; + } + KeyPair that = (KeyPair) obj; + return this.key1.equals(that.key1) && this.key2.equals(that.key2); + } + + @Override + public int hashCode() { + return key1.hashCode() + 37 * key2.hashCode(); + } + } + /* * returns true if the Graphics is print Graphics * false otherwise diff --git a/jdk/src/java.desktop/share/native/libawt/java2d/loops/AlphaMath.c b/jdk/src/java.desktop/share/native/libawt/java2d/loops/AlphaMath.c index 12cde0f3b10..83e8d1ede34 100644 --- a/jdk/src/java.desktop/share/native/libawt/java2d/loops/AlphaMath.c +++ b/jdk/src/java.desktop/share/native/libawt/java2d/loops/AlphaMath.c @@ -34,8 +34,8 @@ void initAlphaTables() unsigned int j; for (i = 1; i < 256; i++) { /* SCALE == (1 << 24) */ - int inc = (i << 16) + (i<<8) + i; /* approx. SCALE * (i/255.0) */ - int val = inc + (1 << 23); /* inc + SCALE*0.5 */ + unsigned int inc = (i << 16) + (i<<8) + i; /* approx. SCALE * (i/255.0) */ + unsigned int val = inc + (1 << 23); /* inc + SCALE*0.5 */ for (j = 1; j < 256; j++) { mul8table[i][j] = (val >> 24); /* val / SCALE */ val += inc; diff --git a/jdk/src/java.desktop/share/native/libfontmanager/layout/SunLayoutEngine.cpp b/jdk/src/java.desktop/share/native/libfontmanager/layout/SunLayoutEngine.cpp index a9aea06683e..c5284d7ec44 100644 --- a/jdk/src/java.desktop/share/native/libfontmanager/layout/SunLayoutEngine.cpp +++ b/jdk/src/java.desktop/share/native/libfontmanager/layout/SunLayoutEngine.cpp @@ -151,7 +151,8 @@ JNIEXPORT void JNICALL Java_sun_font_SunLayoutEngine_nativeLayout return; } - if (min < 0) min = 0; if (max < min) max = min; /* defensive coding */ + if (min < 0) min = 0; + if (max < min) max = min; /* defensive coding */ // have to copy, yuck, since code does upcalls now. this will be soooo slow jint len = max - min; jchar buffer[256]; diff --git a/jdk/src/java.desktop/share/native/libfontmanager/scriptMapping.c b/jdk/src/java.desktop/share/native/libfontmanager/scriptMapping.c index 64093508ad0..038b63c125f 100644 --- a/jdk/src/java.desktop/share/native/libfontmanager/scriptMapping.c +++ b/jdk/src/java.desktop/share/native/libfontmanager/scriptMapping.c @@ -85,7 +85,7 @@ hb_script_t ICU_to_Harfbuzz_ScriptCode[] = { int MAX_ICU_SCRIPTCODE = 45; hb_script_t getHBScriptCode(int code) { - if (code > MAX_ICU_SCRIPTCODE) { + if ((code < 0) || (code > MAX_ICU_SCRIPTCODE)) { return HB_SCRIPT_INVALID; } return ICU_to_Harfbuzz_ScriptCode[code]; diff --git a/jdk/src/java.desktop/share/native/libsplashscreen/splashscreen_jpeg.c b/jdk/src/java.desktop/share/native/libsplashscreen/splashscreen_jpeg.c index e773fd4ee39..ba91abbed46 100644 --- a/jdk/src/java.desktop/share/native/libsplashscreen/splashscreen_jpeg.c +++ b/jdk/src/java.desktop/share/native/libsplashscreen/splashscreen_jpeg.c @@ -237,13 +237,14 @@ int SplashDecodeJpegStream(Splash * splash, SplashStream * stream) { struct jpeg_decompress_struct cinfo; - int success = 0; + int success; struct my_error_mgr jerr; cinfo.err = jpeg_std_error(&jerr.pub); jerr.pub.error_exit = my_error_exit; if (setjmp(jerr.setjmp_buffer)) { + success = 0; goto done; } jpeg_create_decompress(&cinfo); diff --git a/jdk/src/java.desktop/unix/classes/sun/awt/X11/XKeysym.java b/jdk/src/java.desktop/unix/classes/sun/awt/X11/XKeysym.java index e34298a13e7..377b12271ff 100644 --- a/jdk/src/java.desktop/unix/classes/sun/awt/X11/XKeysym.java +++ b/jdk/src/java.desktop/unix/classes/sun/awt/X11/XKeysym.java @@ -952,7 +952,7 @@ public class XKeysym { keysym2UCSHash.put( (long)0x9f4, (char)0x251c); // XK_leftt --> BOX DRAWINGS LIGHT VERTICAL AND RIGHT keysym2UCSHash.put( (long)0x9f5, (char)0x2524); // XK_rightt --> BOX DRAWINGS LIGHT VERTICAL AND LEFT keysym2UCSHash.put( (long)0x9f6, (char)0x2534); // XK_bott --> BOX DRAWINGS LIGHT UP AND HORIZONTAL - keysym2UCSHash.put( (long)0x9f7, (char)0x242c); // XK_topt --> + keysym2UCSHash.put( (long)0x9f7, (char)0x252c); // XK_topt --> BOX DRAWINGS LIGHT DOWN AND HORIZONTAL keysym2UCSHash.put( (long)0x9f8, (char)0x2502); // XK_vertbar --> BOX DRAWINGS LIGHT VERTICAL keysym2UCSHash.put( (long)0xaa1, (char)0x2003); // XK_emspace --> EM SPACE keysym2UCSHash.put( (long)0xaa2, (char)0x2002); // XK_enspace --> EN SPACE diff --git a/jdk/src/java.desktop/unix/classes/sun/awt/X11/keysym2ucs.h b/jdk/src/java.desktop/unix/classes/sun/awt/X11/keysym2ucs.h index b0c75b313fa..11bbf7e4721 100644 --- a/jdk/src/java.desktop/unix/classes/sun/awt/X11/keysym2ucs.h +++ b/jdk/src/java.desktop/unix/classes/sun/awt/X11/keysym2ucs.h @@ -1685,7 +1685,7 @@ SOFTWARE. 0x251c #define XK_leftt 0x9f4 0x2524 #define XK_rightt 0x9f5 0x2534 #define XK_bott 0x9f6 -0x242c #define XK_topt 0x9f7 +0x252c #define XK_topt 0x9f7 0x2502 #define XK_vertbar 0x9f8 #endif /* XK_SPECIAL */ diff --git a/jdk/src/java.desktop/unix/native/libawt_xawt/awt/Xrandr.h b/jdk/src/java.desktop/unix/native/libawt_xawt/awt/Xrandr.h index 5abade26727..aed7c54f9e7 100644 --- a/jdk/src/java.desktop/unix/native/libawt_xawt/awt/Xrandr.h +++ b/jdk/src/java.desktop/unix/native/libawt_xawt/awt/Xrandr.h @@ -5,8 +5,8 @@ /* * $XFree86: xc/lib/Xrandr/Xrandr.h,v 1.9 2002/09/29 23:39:44 keithp Exp $ * - * Copyright © 2000 Compaq Computer Corporation, Inc. - * Copyright © 2002 Hewlett-Packard Company, Inc. + * Copyright © 2000 Compaq Computer Corporation, Inc. + * Copyright © 2002 Hewlett-Packard Company, Inc. * * Permission to use, copy, modify, distribute, and sell this software and its * documentation for any purpose is hereby granted without fee, provided that @@ -66,6 +66,65 @@ typedef struct { int mheight; } XRRScreenChangeNotifyEvent; +typedef XID RROutput; +typedef XID RRCrtc; +typedef XID RRMode; + +typedef unsigned long XRRModeFlags; + +typedef struct { + RRMode id; + unsigned int width; + unsigned int height; + unsigned long dotClock; + unsigned int hSyncStart; + unsigned int hSyncEnd; + unsigned int hTotal; + unsigned int hSkew; + unsigned int vSyncStart; + unsigned int vSyncEnd; + unsigned int vTotal; + char *name; + unsigned int nameLength; + XRRModeFlags modeFlags; +} XRRModeInfo; + +typedef struct { + Time timestamp; + Time configTimestamp; + int ncrtc; + RRCrtc *crtcs; + int noutput; + RROutput *outputs; + int nmode; + XRRModeInfo *modes; +} XRRScreenResources; + +typedef struct { + Time timestamp; + RRCrtc crtc; + char *name; + int nameLen; + unsigned long mm_width; + unsigned long mm_height; + Connection connection; + SubpixelOrder subpixel_order; + int ncrtc; + RRCrtc *crtcs; + int nclone; + RROutput *clones; + int nmode; + int npreferred; + RRMode *modes; +} XRROutputInfo; + +XRRScreenResources *XRRGetScreenResources (Display *dpy, Window window); + +void XRRFreeScreenResources (XRRScreenResources *resources); + +XRROutputInfo * XRRGetOutputInfo (Display *dpy, XRRScreenResources *resources, + RROutput output); +void XRRFreeOutputInfo (XRROutputInfo *outputInfo); /* internal representation is private to the library */ typedef struct _XRRScreenConfiguration XRRScreenConfiguration; diff --git a/jdk/src/java.desktop/unix/native/libawt_xawt/awt/awt_GraphicsEnv.c b/jdk/src/java.desktop/unix/native/libawt_xawt/awt/awt_GraphicsEnv.c index 8b64034a295..40aa4463085 100644 --- a/jdk/src/java.desktop/unix/native/libawt_xawt/awt/awt_GraphicsEnv.c +++ b/jdk/src/java.desktop/unix/native/libawt_xawt/awt/awt_GraphicsEnv.c @@ -1657,6 +1657,16 @@ typedef Rotation (*XRRConfigRotationsType)(XRRScreenConfiguration *config, Rotation *current_rotation); +typedef XRRScreenResources* (*XRRGetScreenResourcesType)(Display *dpy, + Window window); + +typedef void (*XRRFreeScreenResourcesType)(XRRScreenResources *resources); + +typedef XRROutputInfo * (*XRRGetOutputInfoType)(Display *dpy, + XRRScreenResources *resources, RROutput output); + +typedef void (*XRRFreeOutputInfoType)(XRROutputInfo *outputInfo); + static XRRQueryVersionType awt_XRRQueryVersion; static XRRGetScreenInfoType awt_XRRGetScreenInfo; static XRRFreeScreenConfigInfoType awt_XRRFreeScreenConfigInfo; @@ -1666,6 +1676,10 @@ static XRRConfigSizesType awt_XRRConfigSizes; static XRRConfigCurrentConfigurationType awt_XRRConfigCurrentConfiguration; static XRRSetScreenConfigAndRateType awt_XRRSetScreenConfigAndRate; static XRRConfigRotationsType awt_XRRConfigRotations; +static XRRGetScreenResourcesType awt_XRRGetScreenResources; +static XRRFreeScreenResourcesType awt_XRRFreeScreenResources; +static XRRGetOutputInfoType awt_XRRGetOutputInfo; +static XRRFreeOutputInfoType awt_XRRFreeOutputInfo; #define LOAD_XRANDR_FUNC(f) \ do { \ @@ -1737,6 +1751,10 @@ X11GD_InitXrandrFuncs(JNIEnv *env) LOAD_XRANDR_FUNC(XRRConfigCurrentConfiguration); LOAD_XRANDR_FUNC(XRRSetScreenConfigAndRate); LOAD_XRANDR_FUNC(XRRConfigRotations); + LOAD_XRANDR_FUNC(XRRGetScreenResources); + LOAD_XRANDR_FUNC(XRRFreeScreenResources); + LOAD_XRANDR_FUNC(XRRGetOutputInfo); + LOAD_XRANDR_FUNC(XRRFreeOutputInfo); return JNI_TRUE; } @@ -1924,36 +1942,73 @@ Java_sun_awt_X11GraphicsDevice_enumDisplayModes jint screen, jobject arrayList) { #ifndef HEADLESS - XRRScreenConfiguration *config; AWT_LOCK(); - config = awt_XRRGetScreenInfo(awt_display, - RootWindow(awt_display, screen)); - if (config != NULL) { - int nsizes, i, j; - XRRScreenSize *sizes = awt_XRRConfigSizes(config, &nsizes); + if (usingXinerama && XScreenCount(awt_display) > 0) { + XRRScreenResources *res = awt_XRRGetScreenResources(awt_display, + RootWindow(awt_display, 0)); + if (res) { + if (res->noutput > screen) { + XRROutputInfo *output_info = awt_XRRGetOutputInfo(awt_display, + res, res->outputs[screen]); + if (output_info) { + int i; + for (i = 0; i < res->nmode; i++) { + RRMode m = output_info->modes[i]; + int j; + XRRModeInfo *mode; + for (j = 0; j < res->nmode; j++) { + mode = &res->modes[j]; + if (mode->id == m) { + float rate = 0; + if (mode->hTotal && mode->vTotal) { + rate = ((float)mode->dotClock / + ((float)mode->hTotal * + (float)mode->vTotal)); + } + X11GD_AddDisplayMode(env, arrayList, + mode->width, mode->height, + BIT_DEPTH_MULTI, (int)(rate +.2)); + break; + } + } + } + awt_XRRFreeOutputInfo(output_info); + } + } + awt_XRRFreeScreenResources(res); + } + } else { + XRRScreenConfiguration *config; - if (sizes != NULL) { - for (i = 0; i < nsizes; i++) { - int nrates; - XRRScreenSize size = sizes[i]; - short *rates = awt_XRRConfigRates(config, i, &nrates); + config = awt_XRRGetScreenInfo(awt_display, + RootWindow(awt_display, screen)); + if (config != NULL) { + int nsizes, i, j; + XRRScreenSize *sizes = awt_XRRConfigSizes(config, &nsizes); - for (j = 0; j < nrates; j++) { - X11GD_AddDisplayMode(env, arrayList, - size.width, - size.height, - BIT_DEPTH_MULTI, - rates[j]); - if ((*env)->ExceptionCheck(env)) { - break; + if (sizes != NULL) { + for (i = 0; i < nsizes; i++) { + int nrates; + XRRScreenSize size = sizes[i]; + short *rates = awt_XRRConfigRates(config, i, &nrates); + + for (j = 0; j < nrates; j++) { + X11GD_AddDisplayMode(env, arrayList, + size.width, + size.height, + BIT_DEPTH_MULTI, + rates[j]); + if ((*env)->ExceptionCheck(env)) { + break; + } } } } - } - awt_XRRFreeScreenConfigInfo(config); + awt_XRRFreeScreenConfigInfo(config); + } } AWT_FLUSH_UNLOCK(); diff --git a/jdk/src/java.desktop/unix/native/libawt_xawt/awt/randr.h b/jdk/src/java.desktop/unix/native/libawt_xawt/awt/randr.h index 6e8b2ade1db..e289c7b8ff9 100644 --- a/jdk/src/java.desktop/unix/native/libawt_xawt/awt/randr.h +++ b/jdk/src/java.desktop/unix/native/libawt_xawt/awt/randr.h @@ -5,8 +5,8 @@ /* * $XFree86: xc/include/extensions/randr.h,v 1.4 2001/11/24 07:24:58 keithp Exp $ * - * Copyright © 2000, Compaq Computer Corporation, - * Copyright © 2002, Hewlett Packard, Inc. + * Copyright © 2000, Compaq Computer Corporation, + * Copyright © 2002, Hewlett Packard, Inc. * * Permission to use, copy, modify, distribute, and sell this software and its * documentation for any purpose is hereby granted without fee, provided that @@ -31,6 +31,7 @@ #ifndef _RANDR_H_ #define _RANDR_H_ +typedef unsigned short Connection; typedef unsigned short Rotation; typedef unsigned short SizeID; typedef unsigned short SubpixelOrder; diff --git a/jdk/src/java.desktop/windows/classes/sun/awt/shell/Win32ShellFolder2.java b/jdk/src/java.desktop/windows/classes/sun/awt/shell/Win32ShellFolder2.java index dab4129ade5..b2e62b41d27 100644 --- a/jdk/src/java.desktop/windows/classes/sun/awt/shell/Win32ShellFolder2.java +++ b/jdk/src/java.desktop/windows/classes/sun/awt/shell/Win32ShellFolder2.java @@ -27,7 +27,9 @@ package sun.awt.shell; import java.awt.Image; import java.awt.Toolkit; +import java.awt.image.AbstractMultiResolutionImage; import java.awt.image.BufferedImage; +import java.awt.image.ImageObserver; import java.io.File; import java.io.FileNotFoundException; import java.io.IOException; @@ -982,11 +984,12 @@ final class Win32ShellFolder2 extends ShellFolder { // Return the bits from an HICON. This has a side effect of setting // the imageHash variable for efficient caching / comparing. - private static native int[] getIconBits(long hIcon, int iconSize); + private static native int[] getIconBits(long hIcon); // Dispose the HICON private static native void disposeIcon(long hIcon); - static native int[] getStandardViewButton0(int iconIndex); + // Get buttons from native toolbar implementation. + static native int[] getStandardViewButton0(int iconIndex, boolean small); // Should be called from the COM thread private long getIShellIcon() { @@ -1000,12 +1003,17 @@ final class Win32ShellFolder2 extends ShellFolder { private static Image makeIcon(long hIcon, boolean getLargeIcon) { if (hIcon != 0L && hIcon != -1L) { // Get the bits. This has the side effect of setting the imageHash value for this object. - int size = getLargeIcon ? 32 : 16; - int[] iconBits = getIconBits(hIcon, size); + final int[] iconBits = getIconBits(hIcon); if (iconBits != null) { - BufferedImage img = new BufferedImage(size, size, BufferedImage.TYPE_INT_ARGB); + // icons are always square + final int size = (int) Math.sqrt(iconBits.length); + final int baseSize = getLargeIcon ? 32 : 16; + final BufferedImage img = + new BufferedImage(size, size, BufferedImage.TYPE_INT_ARGB); img.setRGB(0, 0, size, size, iconBits, 0, size); - return img; + return size == baseSize + ? img + : new MultiResolutionIconImage(baseSize, img); } } return null; @@ -1298,4 +1306,39 @@ final class Win32ShellFolder2 extends ShellFolder { }); } + static class MultiResolutionIconImage extends AbstractMultiResolutionImage { + + final int baseSize; + final Image resolutionVariant; + + public MultiResolutionIconImage(int baseSize, Image resolutionVariant) { + this.baseSize = baseSize; + this.resolutionVariant = resolutionVariant; + } + + @Override + public int getWidth(ImageObserver observer) { + return baseSize; + } + + @Override + public int getHeight(ImageObserver observer) { + return baseSize; + } + + @Override + protected Image getBaseImage() { + return resolutionVariant; + } + + @Override + public Image getResolutionVariant(double width, double height) { + return resolutionVariant; + } + + @Override + public List getResolutionVariants() { + return Arrays.asList(resolutionVariant); + } + } } diff --git a/jdk/src/java.desktop/windows/classes/sun/awt/shell/Win32ShellFolderManager2.java b/jdk/src/java.desktop/windows/classes/sun/awt/shell/Win32ShellFolderManager2.java index 1e20c3582f7..ffee0ac7ae6 100644 --- a/jdk/src/java.desktop/windows/classes/sun/awt/shell/Win32ShellFolderManager2.java +++ b/jdk/src/java.desktop/windows/classes/sun/awt/shell/Win32ShellFolderManager2.java @@ -27,6 +27,7 @@ package sun.awt.shell; import java.awt.*; import java.awt.image.BufferedImage; +import java.awt.image.BaseMultiResolutionImage; import java.io.File; import java.io.FileNotFoundException; @@ -116,13 +117,21 @@ final class Win32ShellFolderManager2 extends ShellFolderManager { return result; } - BufferedImage img = new BufferedImage(16, 16, BufferedImage.TYPE_INT_ARGB); + final int[] iconBits = Win32ShellFolder2 + .getStandardViewButton0(iconIndex, true); + if (iconBits != null) { + // icons are always square + final int size = (int) Math.sqrt(iconBits.length); + final BufferedImage img = + new BufferedImage(size, size, BufferedImage.TYPE_INT_ARGB); + img.setRGB(0, 0, size, size, iconBits, 0, size); - img.setRGB(0, 0, 16, 16, Win32ShellFolder2.getStandardViewButton0(iconIndex), 0, 16); + STANDARD_VIEW_BUTTONS[iconIndex] = (size == 16) + ? img + : new MultiResolutionIconImage(16, img); + } - STANDARD_VIEW_BUTTONS[iconIndex] = img; - - return img; + return STANDARD_VIEW_BUTTONS[iconIndex]; } // Special folders diff --git a/jdk/src/java.desktop/windows/classes/sun/print/Win32PrintService.java b/jdk/src/java.desktop/windows/classes/sun/print/Win32PrintService.java index cdb18138ed3..c8f74d9e2a9 100644 --- a/jdk/src/java.desktop/windows/classes/sun/print/Win32PrintService.java +++ b/jdk/src/java.desktop/windows/classes/sun/print/Win32PrintService.java @@ -759,10 +759,18 @@ public class Win32PrintService implements PrintService, AttributeUpdater, private boolean isSupportedMediaPrintableArea(MediaPrintableArea mpa) { getMediaPrintables(null); + int units = MediaPrintableArea.INCH; if (mediaPrintables != null) { for (int i=0; i= mediaPrintables[i].getX(units)) && + (mpa.getY(units) >= mediaPrintables[i].getY(units)) && + (mpa.getX(units) + mpa.getWidth(units) <= + mediaPrintables[i].getX(units) + + mediaPrintables[i].getWidth(units)) && + (mpa.getY(units) + mpa.getHeight(units) <= + mediaPrintables[i].getY(units) + + mediaPrintables[i].getHeight(units))) { return true; } } diff --git a/jdk/src/java.desktop/windows/native/libawt/windows/ShellFolder2.cpp b/jdk/src/java.desktop/windows/native/libawt/windows/ShellFolder2.cpp index 05273d41bad..7ffdb5d7e52 100644 --- a/jdk/src/java.desktop/windows/native/libawt/windows/ShellFolder2.cpp +++ b/jdk/src/java.desktop/windows/native/libawt/windows/ShellFolder2.cpp @@ -930,19 +930,43 @@ JNIEXPORT void JNICALL Java_sun_awt_shell_Win32ShellFolder2_disposeIcon /* * Class: sun_awt_shell_Win32ShellFolder2 * Method: getIconBits - * Signature: (JI)[I + * Signature: (J)[I */ JNIEXPORT jintArray JNICALL Java_sun_awt_shell_Win32ShellFolder2_getIconBits - (JNIEnv* env, jclass cls, jlong hicon, jint iconSize) + (JNIEnv* env, jclass cls, jlong hicon) { + const int MAX_ICON_SIZE = 128; + int iconSize = 0; jintArray iconBits = NULL; + BITMAP bmp; + memset(&bmp, 0, sizeof(BITMAP)); + // Get the icon info ICONINFO iconInfo; if (fn_GetIconInfo((HICON)hicon, &iconInfo)) { // Get the screen DC HDC dc = GetDC(NULL); if (dc != NULL) { + // find out the icon size in order to deal with different sizes + // delivered depending on HiDPI mode or SD DPI mode. + if (iconInfo.hbmColor) { + const int nWrittenBytes = GetObject(iconInfo.hbmColor, sizeof(bmp), &bmp); + if(nWrittenBytes > 0) { + iconSize = bmp.bmWidth; + } + } else if (iconInfo.hbmMask) { + // Icon has no color plane, image data stored in mask + const int nWrittenBytes = GetObject(iconInfo.hbmMask, sizeof(bmp), &bmp); + if (nWrittenBytes > 0) { + iconSize = bmp.bmWidth; + } + } + // limit iconSize to MAX_ICON_SIZE, so that the colorBits and maskBits + // arrays are big enough. + // (logic: rather show bad icons than overrun the array size) + iconSize = iconSize > MAX_ICON_SIZE ? MAX_ICON_SIZE : iconSize; + // Set up BITMAPINFO BITMAPINFO bmi; memset(&bmi, 0, sizeof(BITMAPINFO)); @@ -954,7 +978,7 @@ JNIEXPORT jintArray JNICALL Java_sun_awt_shell_Win32ShellFolder2_getIconBits bmi.bmiHeader.biCompression = BI_RGB; // Extract the color bitmap int nBits = iconSize * iconSize; - long colorBits[1024]; + long colorBits[MAX_ICON_SIZE * MAX_ICON_SIZE]; GetDIBits(dc, iconInfo.hbmColor, 0, iconSize, colorBits, &bmi, DIB_RGB_COLORS); // XP supports alpha in some icons, and depending on device. // This should take precedence over the icon mask bits. @@ -969,7 +993,7 @@ JNIEXPORT jintArray JNICALL Java_sun_awt_shell_Win32ShellFolder2_getIconBits } if (!hasAlpha) { // Extract the mask bitmap - long maskBits[1024]; + long maskBits[MAX_ICON_SIZE * MAX_ICON_SIZE]; GetDIBits(dc, iconInfo.hbmMask, 0, iconSize, maskBits, &bmi, DIB_RGB_COLORS); // Copy the mask alphas into the color bits for (int i = 0; i < nBits; i++) { @@ -1001,10 +1025,10 @@ JNIEXPORT jintArray JNICALL Java_sun_awt_shell_Win32ShellFolder2_getIconBits /* * Class: sun_awt_shell_Win32ShellFolder2 * Method: getStandardViewButton0 - * Signature: (I)[I + * Signature: (IZ)[I */ JNIEXPORT jintArray JNICALL Java_sun_awt_shell_Win32ShellFolder2_getStandardViewButton0 - (JNIEnv* env, jclass cls, jint iconIndex) + (JNIEnv* env, jclass cls, jint iconIndex, jboolean smallIcon) { jintArray result = NULL; @@ -1014,7 +1038,8 @@ JNIEXPORT jintArray JNICALL Java_sun_awt_shell_Win32ShellFolder2_getStandardView NULL, NULL, NULL, NULL); if (hWndToolbar != NULL) { - SendMessage(hWndToolbar, TB_LOADIMAGES, (WPARAM)IDB_VIEW_SMALL_COLOR, (LPARAM)HINST_COMMCTRL); + WPARAM size = smallIcon ? (WPARAM)IDB_VIEW_SMALL_COLOR : (WPARAM)IDB_VIEW_LARGE_COLOR; + SendMessage(hWndToolbar, TB_LOADIMAGES, size, (LPARAM)HINST_COMMCTRL); HIMAGELIST hImageList = (HIMAGELIST) SendMessage(hWndToolbar, TB_GETIMAGELIST, 0, 0); @@ -1022,7 +1047,7 @@ JNIEXPORT jintArray JNICALL Java_sun_awt_shell_Win32ShellFolder2_getStandardView HICON hIcon = ImageList_GetIcon(hImageList, iconIndex, ILD_TRANSPARENT); if (hIcon != NULL) { - result = Java_sun_awt_shell_Win32ShellFolder2_getIconBits(env, cls, ptr_to_jlong(hIcon), 16); + result = Java_sun_awt_shell_Win32ShellFolder2_getIconBits(env, cls, ptr_to_jlong(hIcon)); DestroyIcon(hIcon); } diff --git a/jdk/src/java.desktop/windows/native/libawt/windows/awt_Component.cpp b/jdk/src/java.desktop/windows/native/libawt/windows/awt_Component.cpp index c169ea9aba4..13b061eb31a 100644 --- a/jdk/src/java.desktop/windows/native/libawt/windows/awt_Component.cpp +++ b/jdk/src/java.desktop/windows/native/libawt/windows/awt_Component.cpp @@ -257,6 +257,8 @@ AwtComponent::AwtComponent() AwtComponent::BuildPrimaryDynamicTable(); sm_PrimaryDynamicTableBuilt = TRUE; } + + deadKeyActive = FALSE; } AwtComponent::~AwtComponent() @@ -2952,6 +2954,7 @@ static const CharToVKEntry charToDeadVKTable[] = { {0x037A, java_awt_event_KeyEvent_VK_DEAD_IOTA}, // ASCII ??? {0x309B, java_awt_event_KeyEvent_VK_DEAD_VOICED_SOUND}, {0x309C, java_awt_event_KeyEvent_VK_DEAD_SEMIVOICED_SOUND}, + {0x0004, java_awt_event_KeyEvent_VK_COMPOSE}, {0,0} }; @@ -3444,8 +3447,9 @@ UINT AwtComponent::WindowsKeyToJavaChar(UINT wkey, UINT modifiers, TransOps ops, AwtToolkit::GetKeyboardState(keyboardState); // apply modifiers to keyboard state if necessary + BOOL shiftIsDown = FALSE; if (modifiers) { - BOOL shiftIsDown = modifiers & java_awt_event_InputEvent_SHIFT_DOWN_MASK; + shiftIsDown = modifiers & java_awt_event_InputEvent_SHIFT_DOWN_MASK; BOOL altIsDown = modifiers & java_awt_event_InputEvent_ALT_DOWN_MASK; BOOL ctrlIsDown = modifiers & java_awt_event_InputEvent_CTRL_DOWN_MASK; @@ -3517,18 +3521,27 @@ UINT AwtComponent::WindowsKeyToJavaChar(UINT wkey, UINT modifiers, TransOps ops, } // ctrlIsDown } // modifiers - // instead of creating our own conversion tables, I'll let Win32 - // convert the character for me. WORD wChar[2]; - UINT scancode = ::MapVirtualKey(wkey, 0); - int converted = ::ToUnicodeEx(wkey, scancode, keyboardState, - wChar, 2, 0, GetKeyboardLayout()); + int converted = 1; + UINT ch = ::MapVirtualKey(wkey, 2); + if (ch & 0x80000000) { + // Dead key which is handled as a normal key + isDeadKey = deadKeyActive = TRUE; + } else if (deadKeyActive) { + // We cannot use ::ToUnicodeEx if dead key is active because this will + // break dead key function + wChar[0] = shiftIsDown ? ch : tolower(ch); + } else { + UINT scancode = ::MapVirtualKey(wkey, 0); + converted = ::ToUnicodeEx(wkey, scancode, keyboardState, + wChar, 2, 0, GetKeyboardLayout()); + } UINT translation; BOOL deadKeyFlag = (converted == 2); // Dead Key - if (converted < 0) { + if (converted < 0 || isDeadKey) { translation = java_awt_event_KeyEvent_CHAR_UNDEFINED; } else // No translation available -- try known conversions or else punt. @@ -3682,6 +3695,8 @@ MsgRouting AwtComponent::WmIMEChar(UINT character, UINT repCnt, UINT flags, BOOL MsgRouting AwtComponent::WmChar(UINT character, UINT repCnt, UINT flags, BOOL system) { + deadKeyActive = FALSE; + // Will only get WmChar messages with DBCS if we create them for // an Edit class in the WmForwardChar method. These synthesized // DBCS chars are ok to pass on directly to the default window diff --git a/jdk/src/java.desktop/windows/native/libawt/windows/awt_Component.h b/jdk/src/java.desktop/windows/native/libawt/windows/awt_Component.h index 135ac39b874..bcf96a78669 100644 --- a/jdk/src/java.desktop/windows/native/libawt/windows/awt_Component.h +++ b/jdk/src/java.desktop/windows/native/libawt/windows/awt_Component.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -826,6 +826,8 @@ private: // 6524352: support finer-resolution int m_wheelRotationAmount; + BOOL deadKeyActive; + /* * The association list of children's IDs and corresponding components. * Some components like Choice or List are required their sizes while diff --git a/jdk/src/java.desktop/windows/native/libawt/windows/awt_FileDialog.cpp b/jdk/src/java.desktop/windows/native/libawt/windows/awt_FileDialog.cpp index a24e3373398..7b2d703bb6a 100644 --- a/jdk/src/java.desktop/windows/native/libawt/windows/awt_FileDialog.cpp +++ b/jdk/src/java.desktop/windows/native/libawt/windows/awt_FileDialog.cpp @@ -357,9 +357,9 @@ AwtFileDialog::Show(void *p) // show the Win32 file dialog if (mode == java_awt_FileDialog_LOAD) { - result = AwtFileDialog::GetOpenFileName(&ofn); + result = ::GetOpenFileName(&ofn); } else { - result = AwtFileDialog::GetSaveFileName(&ofn); + result = ::GetSaveFileName(&ofn); } // Fix for 4181310: FileDialog does not show up. // If the dialog is not shown because of invalid file name @@ -369,9 +369,9 @@ AwtFileDialog::Show(void *p) if (dlgerr == FNERR_INVALIDFILENAME) { _tcscpy_s(fileBuffer, bufferLimit, TEXT("")); if (mode == java_awt_FileDialog_LOAD) { - result = AwtFileDialog::GetOpenFileName(&ofn); + result = ::GetOpenFileName(&ofn); } else { - result = AwtFileDialog::GetSaveFileName(&ofn); + result = ::GetSaveFileName(&ofn); } } } @@ -430,22 +430,6 @@ AwtFileDialog::Show(void *p) delete[] ofn.lpstrFile; } -BOOL -AwtFileDialog::GetOpenFileName(LPOPENFILENAME data) { - return static_cast(reinterpret_cast( - AwtToolkit::GetInstance().InvokeFunction((void*(*)(void*)) - ::GetOpenFileName, data))); - -} - -BOOL -AwtFileDialog::GetSaveFileName(LPOPENFILENAME data) { - return static_cast(reinterpret_cast( - AwtToolkit::GetInstance().InvokeFunction((void *(*)(void *)) - ::GetSaveFileName, data))); - -} - BOOL AwtFileDialog::InheritsNativeMouseWheelBehavior() {return true;} void AwtFileDialog::_DisposeOrHide(void *param) @@ -593,9 +577,10 @@ Java_sun_awt_windows_WFileDialogPeer__1show(JNIEnv *env, jobject peer) */ jobject peerGlobal = env->NewGlobalRef(peer); - AwtToolkit::GetInstance().InvokeFunction(AwtFileDialog::Show, peerGlobal); - - env->DeleteGlobalRef(peerGlobal); + if (!AwtToolkit::GetInstance().PostMessage(WM_AWT_INVOKE_METHOD, + (WPARAM)AwtFileDialog::Show, (LPARAM)peerGlobal)) { + env->DeleteGlobalRef(peerGlobal); + } CATCH_BAD_ALLOC; } diff --git a/jdk/src/java.desktop/windows/native/libawt/windows/awt_FileDialog.h b/jdk/src/java.desktop/windows/native/libawt/windows/awt_FileDialog.h index ee5bea37e1d..53c3bde0035 100644 --- a/jdk/src/java.desktop/windows/native/libawt/windows/awt_FileDialog.h +++ b/jdk/src/java.desktop/windows/native/libawt/windows/awt_FileDialog.h @@ -60,9 +60,6 @@ public: static void Initialize(JNIEnv *env, jstring filterDescription); static void Show(void *peer); - static BOOL GetOpenFileName(LPOPENFILENAME); - static BOOL GetSaveFileName(LPOPENFILENAME); - virtual BOOL InheritsNativeMouseWheelBehavior(); // some methods called on Toolkit thread diff --git a/jdk/src/java.desktop/windows/native/libawt/windows/awt_PrintControl.cpp b/jdk/src/java.desktop/windows/native/libawt/windows/awt_PrintControl.cpp index 94965e74893..6c36d177fb2 100644 --- a/jdk/src/java.desktop/windows/native/libawt/windows/awt_PrintControl.cpp +++ b/jdk/src/java.desktop/windows/native/libawt/windows/awt_PrintControl.cpp @@ -1000,8 +1000,19 @@ BOOL AwtPrintControl::UpdateAttributes(JNIEnv *env, } } else { int xRes = devmode->dmPrintQuality; - int yRes = (devmode->dmFields & DM_YRESOLUTION) ? - devmode->dmYResolution : devmode->dmPrintQuality; + + /* For some printers, printer quality can specify 1200IQ + * In this case, dmPrintQuality comes out 600 and + * dmYResolution comes out 2, similarly for 2400IQ + * dmPrintQuality comes out 600 and dmYResolution comes out 4 + * which is not a valid resolution + * so for IQ setting, we modify y-resolution only when it is + * greater than 10. + */ + int yRes = (devmode->dmFields & DM_YRESOLUTION) && + (devmode->dmYResolution > 10) ? + devmode->dmYResolution : devmode->dmPrintQuality; + env->CallVoidMethod(printCtrl, AwtPrintControl::setResID, xRes, yRes); } diff --git a/jdk/src/java.desktop/windows/native/libawt/windows/awt_TextArea.cpp b/jdk/src/java.desktop/windows/native/libawt/windows/awt_TextArea.cpp index 7ec74314bfd..cd40b1f237f 100644 --- a/jdk/src/java.desktop/windows/native/libawt/windows/awt_TextArea.cpp +++ b/jdk/src/java.desktop/windows/native/libawt/windows/awt_TextArea.cpp @@ -73,7 +73,10 @@ AwtTextArea* AwtTextArea::Create(jobject peer, jobject parent) } void AwtTextArea::EditSetSel(CHARRANGE &cr) { + // Fix for 5003402: added restoring/hiding selection to enable automatic scrolling + SendMessage(EM_HIDESELECTION, FALSE, TRUE); SendMessage(EM_EXSETSEL, 0, reinterpret_cast(&cr)); + SendMessage(EM_HIDESELECTION, TRUE, TRUE); // 6417581: force expected drawing if (IS_WINVISTA && cr.cpMin == cr.cpMax) { ::InvalidateRect(GetHWnd(), NULL, TRUE); diff --git a/jdk/src/java.httpclient/share/classes/java/net/http/AsyncSSLDelegate.java b/jdk/src/java.httpclient/share/classes/java/net/http/AsyncSSLDelegate.java index f11b8ed16e3..6d500285f4b 100644 --- a/jdk/src/java.httpclient/share/classes/java/net/http/AsyncSSLDelegate.java +++ b/jdk/src/java.httpclient/share/classes/java/net/http/AsyncSSLDelegate.java @@ -81,7 +81,7 @@ import static javax.net.ssl.SSLEngineResult.HandshakeStatus.*; * the channel to be closed, and the error is reported to the user's * Consumer */ -public class AsyncSSLDelegate implements Closeable, AsyncConnection { +class AsyncSSLDelegate implements Closeable, AsyncConnection { // outgoing buffers put in this queue first and may remain here // while SSL handshaking happening. diff --git a/jdk/src/java.security.jgss/share/classes/sun/security/krb5/Config.java b/jdk/src/java.security.jgss/share/classes/sun/security/krb5/Config.java index 0a67cf7135e..c43c373785f 100644 --- a/jdk/src/java.security.jgss/share/classes/sun/security/krb5/Config.java +++ b/jdk/src/java.security.jgss/share/classes/sun/security/krb5/Config.java @@ -562,7 +562,7 @@ public class Config { boolean inDirectives = true; for (String line: lines) { line = line.trim(); - if (line.isEmpty() || line.startsWith("#")) { + if (line.isEmpty() || line.startsWith("#") || line.startsWith(";")) { continue; } if (inDirectives) { diff --git a/jdk/src/jdk.accessibility/share/classes/com/sun/java/accessibility/util/package-info.java b/jdk/src/jdk.accessibility/share/classes/com/sun/java/accessibility/util/package-info.java index f3b0a62dd36..92ed3e627b3 100644 --- a/jdk/src/jdk.accessibility/share/classes/com/sun/java/accessibility/util/package-info.java +++ b/jdk/src/jdk.accessibility/share/classes/com/sun/java/accessibility/util/package-info.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2015 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_HKSCS.java.template b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_HKSCS.java.template index 3b2ad7eb5d5..99958a30dd0 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_HKSCS.java.template +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_HKSCS.java.template @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010 Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it diff --git a/jdk/src/jdk.crypto.ucrypto/solaris/classes/com/oracle/security/ucrypto/Config.java b/jdk/src/jdk.crypto.ucrypto/solaris/classes/com/oracle/security/ucrypto/Config.java index e9abf1a73ec..4fd0f9946b0 100644 --- a/jdk/src/jdk.crypto.ucrypto/solaris/classes/com/oracle/security/ucrypto/Config.java +++ b/jdk/src/jdk.crypto.ucrypto/solaris/classes/com/oracle/security/ucrypto/Config.java @@ -66,7 +66,7 @@ final class Config { Config(String filename) throws IOException { FileInputStream in = new FileInputStream(expand(filename)); - reader = new BufferedReader(new InputStreamReader(in)); + reader = new BufferedReader(new InputStreamReader(in, "ISO-8859-1")); parsedKeywords = new HashSet(); st = new StreamTokenizer(reader); setupTokenizer(); diff --git a/jdk/src/jdk.jartool/share/classes/sun/security/tools/jarsigner/Resources_ja.java b/jdk/src/jdk.jartool/share/classes/sun/security/tools/jarsigner/Resources_ja.java index cdb1bc29e04..fbd134b44c9 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/security/tools/jarsigner/Resources_ja.java +++ b/jdk/src/jdk.jartool/share/classes/sun/security/tools/jarsigner/Resources_ja.java @@ -243,9 +243,9 @@ public class Resources_ja extends java.util.ListResourceBundle { {"This.jar.contains.entries.whose.certificate.chain.is.not.validated.reason.1", "\u3053\u306Ejar\u306B\u306F\u3001\u8A3C\u660E\u66F8\u30C1\u30A7\u30FC\u30F3\u304C\u307E\u3060\u691C\u8A3C\u3055\u308C\u3066\u3044\u306A\u3044\u30A8\u30F3\u30C8\u30EA\u304C\u542B\u307E\u308C\u3066\u3044\u307E\u3059\u3002\u7406\u7531: %s"}, {"no.timestamp.signing", - "-tsa\u307E\u305F\u306F-tsacert\u304C\u6307\u5B9A\u3055\u308C\u3066\u3044\u306A\u3044\u305F\u3081\u3001\u3053\u306Ejar\u306B\u306F\u30BF\u30A4\u30E0\u30B9\u30BF\u30F3\u30D7\u304C\u4ED8\u52A0\u3055\u308C\u3066\u3044\u307E\u305B\u3093\u3002\u30BF\u30A4\u30E0\u30B9\u30BF\u30F3\u30D7\u304C\u306A\u3044\u3068\u3001\u7F72\u540D\u8005\u8A3C\u660E\u66F8\u306E\u6709\u52B9\u671F\u9650(%1$tY-%1$tm-%1$td)\u5F8C\u307E\u305F\u306F\u5C06\u6765\u306E\u5931\u52B9\u65E5\u5F8C\u306B\u3001\u30E6\u30FC\u30B6\u30FC\u306F\u3053\u306Ejar\u3092\u691C\u8A3C\u3067\u304D\u306A\u3044\u53EF\u80FD\u6027\u304C\u3042\u308A\u307E\u3059\u3002"}, + "-tsa\u307E\u305F\u306F-tsacert\u304C\u6307\u5B9A\u3055\u308C\u3066\u3044\u306A\u3044\u305F\u3081\u3001\u3053\u306Ejar\u306B\u306F\u30BF\u30A4\u30E0\u30B9\u30BF\u30F3\u30D7\u304C\u4ED8\u52A0\u3055\u308C\u3066\u3044\u307E\u305B\u3093\u3002\u30BF\u30A4\u30E0\u30B9\u30BF\u30F3\u30D7\u304C\u306A\u3044\u3068\u3001\u7F72\u540D\u8005\u8A3C\u660E\u66F8\u306E\u6709\u52B9\u671F\u9650(%1$tY-%1$tm-%1$td)\u5F8C\u306B\u3001\u30E6\u30FC\u30B6\u30FC\u306F\u3053\u306Ejar\u3092\u691C\u8A3C\u3067\u304D\u306A\u3044\u53EF\u80FD\u6027\u304C\u3042\u308A\u307E\u3059\u3002"}, {"no.timestamp.verifying", - "\u3053\u306Ejar\u306B\u306F\u3001\u30BF\u30A4\u30E0\u30B9\u30BF\u30F3\u30D7\u304C\u306A\u3044\u7F72\u540D\u304C\u542B\u307E\u308C\u3066\u3044\u307E\u3059\u3002\u30BF\u30A4\u30E0\u30B9\u30BF\u30F3\u30D7\u304C\u306A\u3044\u3068\u3001\u7F72\u540D\u8005\u8A3C\u660E\u66F8\u306E\u6709\u52B9\u671F\u9650(%1$tY-%1$tm-%1$td)\u5F8C\u307E\u305F\u306F\u5C06\u6765\u306E\u5931\u52B9\u65E5\u5F8C\u306B\u3001\u30E6\u30FC\u30B6\u30FC\u306F\u3053\u306Ejar\u3092\u691C\u8A3C\u3067\u304D\u306A\u3044\u53EF\u80FD\u6027\u304C\u3042\u308A\u307E\u3059\u3002"}, + "\u3053\u306Ejar\u306B\u306F\u3001\u30BF\u30A4\u30E0\u30B9\u30BF\u30F3\u30D7\u304C\u306A\u3044\u7F72\u540D\u304C\u542B\u307E\u308C\u3066\u3044\u307E\u3059\u3002\u30BF\u30A4\u30E0\u30B9\u30BF\u30F3\u30D7\u304C\u306A\u3044\u3068\u3001\u7F72\u540D\u8005\u8A3C\u660E\u66F8\u306E\u6709\u52B9\u671F\u9650(%1$tY-%1$tm-%1$td)\u5F8C\u306B\u3001\u30E6\u30FC\u30B6\u30FC\u306F\u3053\u306Ejar\u3092\u691C\u8A3C\u3067\u304D\u306A\u3044\u53EF\u80FD\u6027\u304C\u3042\u308A\u307E\u3059\u3002"}, {"Unknown.password.type.", "\u4E0D\u660E\u306A\u30D1\u30B9\u30EF\u30FC\u30C9\u30FB\u30BF\u30A4\u30D7: "}, {"Cannot.find.environment.variable.", "\u74B0\u5883\u5909\u6570\u304C\u898B\u3064\u304B\u308A\u307E\u305B\u3093: "}, diff --git a/jdk/src/jdk.jartool/share/classes/sun/security/tools/jarsigner/Resources_zh_CN.java b/jdk/src/jdk.jartool/share/classes/sun/security/tools/jarsigner/Resources_zh_CN.java index de484f00082..2ae688055ae 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/security/tools/jarsigner/Resources_zh_CN.java +++ b/jdk/src/jdk.jartool/share/classes/sun/security/tools/jarsigner/Resources_zh_CN.java @@ -243,9 +243,9 @@ public class Resources_zh_CN extends java.util.ListResourceBundle { {"This.jar.contains.entries.whose.certificate.chain.is.not.validated.reason.1", "\u6B64 jar \u5305\u542B\u5176\u8BC1\u4E66\u94FE\u672A\u7ECF\u8FC7\u9A8C\u8BC1\u7684\u6761\u76EE\u3002\u539F\u56E0: %s"}, {"no.timestamp.signing", - "\u672A\u63D0\u4F9B -tsa \u6216 -tsacert, \u6B64 jar \u6CA1\u6709\u65F6\u95F4\u6233\u3002\u5982\u679C\u6CA1\u6709\u65F6\u95F4\u6233, \u5219\u5728\u7B7E\u540D\u8005\u8BC1\u4E66\u7684\u5230\u671F\u65E5\u671F (%1$tY-%1$tm-%1$td) \u6216\u4EE5\u540E\u7684\u4EFB\u4F55\u64A4\u9500\u65E5\u671F\u4E4B\u540E, \u7528\u6237\u53EF\u80FD\u65E0\u6CD5\u9A8C\u8BC1\u6B64 jar\u3002"}, + "\u672A\u63D0\u4F9B -tsa \u6216 -tsacert, \u6B64 jar \u6CA1\u6709\u65F6\u95F4\u6233\u3002\u5982\u679C\u6CA1\u6709\u65F6\u95F4\u6233, \u5219\u5728\u7B7E\u540D\u8005\u8BC1\u4E66\u7684\u5230\u671F\u65E5\u671F (%1$tY-%1$tm-%1$td) \u4E4B\u540E, \u7528\u6237\u53EF\u80FD\u65E0\u6CD5\u9A8C\u8BC1\u6B64 jar\u3002"}, {"no.timestamp.verifying", - "\u6B64 jar \u5305\u542B\u7684\u7B7E\u540D\u6CA1\u6709\u65F6\u95F4\u6233\u3002\u5982\u679C\u6CA1\u6709\u65F6\u95F4\u6233, \u5219\u5728\u7B7E\u540D\u8005\u8BC1\u4E66\u7684\u5230\u671F\u65E5\u671F (%1$tY-%1$tm-%1$td) \u6216\u4EE5\u540E\u7684\u4EFB\u4F55\u64A4\u9500\u65E5\u671F\u4E4B\u540E, \u7528\u6237\u53EF\u80FD\u65E0\u6CD5\u9A8C\u8BC1\u6B64 jar\u3002"}, + "\u6B64 jar \u5305\u542B\u7684\u7B7E\u540D\u6CA1\u6709\u65F6\u95F4\u6233\u3002\u5982\u679C\u6CA1\u6709\u65F6\u95F4\u6233, \u5219\u5728\u7B7E\u540D\u8005\u8BC1\u4E66\u7684\u5230\u671F\u65E5\u671F (%1$tY-%1$tm-%1$td) \u4E4B\u540E, \u7528\u6237\u53EF\u80FD\u65E0\u6CD5\u9A8C\u8BC1\u6B64 jar\u3002"}, {"Unknown.password.type.", "\u672A\u77E5\u53E3\u4EE4\u7C7B\u578B: "}, {"Cannot.find.environment.variable.", "\u627E\u4E0D\u5230\u73AF\u5883\u53D8\u91CF: "}, diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_de.properties b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_de.properties index e850da1f88d..54768049cea 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_de.properties +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_de.properties @@ -39,14 +39,22 @@ error.create.dir={0}: Verzeichnis konnte nicht erstellt werden error.incorrect.length=Falsche L\u00E4nge bei der Verarbeitung: {0} error.create.tempfile=Es konnte keine tempor\u00E4re Datei erstellt werden error.hash.dep=Abh\u00E4ngigkeiten bei Hashing-Modul {0}. Modul {1} kann nicht im Modulpfad gefunden werden -error.module.options.without.info=--module-version oder --hash-dependencies ohne module-info.class +error.module.options.without.info=--module-version oder --hash-modules ohne module-info.class error.unexpected.module-info=Unerwarteter Moduldeskriptor {0} error.module.descriptor.not.found=Moduldeskriptor nicht gefunden +error.versioned.info.without.root=module-info.class in Abschnitt mit Versionsangabe ohne module-info.class in Root ermittelt +error.versioned.info.name.notequal=module-info.class in Abschnitt mit Versionsangabe enth\u00E4lt falschen Namen +error.versioned.info.requires.public=module-info.class in Abschnitt mit Versionsangabe enth\u00E4lt zus\u00E4tzlichen "requires public" +error.versioned.info.requires.added=module-info.class in Abschnitt mit Versionsangabe enth\u00E4lt zus\u00E4tzlichen "requires" +error.versioned.info.requires.dropped=module-info.class in Abschnitt mit Versionsangabe enth\u00E4lt fehlenden "requires" +error.versioned.info.exports.notequal=module-info.class in Abschnitt mit Versionsangabe enth\u00E4lt unterschiedliche "exports" +error.versioned.info.provides.notequal=module-info.class in Abschnitt mit Versionsangabe enth\u00E4lt unterschiedliche "provides" +error.invalid.versioned.module.attribute=Ung\u00FCltiges Moduldeskriptorattribut {0} error.missing.provider=Serviceprovider nicht gefunden: {0} out.added.manifest=Manifest wurde hinzugef\u00FCgt -out.added.module-info=module-info.class hinzugef\u00FCgt +out.added.module-info=module-info hinzugef\u00FCgt: {0} out.update.manifest=Manifest wurde aktualisiert -out.update.module-info=module-info.class aktualisiert +out.update.module-info=module-info aktualisiert: {0} out.ignore.entry=Eintrag {0} wird ignoriert out.adding={0} wird hinzugef\u00FCgt out.deflated=({0} % verkleinert) @@ -77,7 +85,7 @@ main.help.opt.create.update.main-class=\ -e, --main-class=CLASSNAME Der Anwendu main.help.opt.create.update.manifest=\ -m, --manifest=FILE Die Manifestinformationen aus der angegebenen\n Manifestdatei aufnehmen main.help.opt.create.update.no-manifest=\ -M, --no-manifest Keine Manifestdatei f\u00FCr die Eintr\u00E4ge erstellen main.help.opt.create.update.module-version=\ --module-version=VERSION Die Modulversion beim Erstellen eines modularen\n JAR-Archivs oder Aktualisieren eines nicht modularen JAR-Archivs -main.help.opt.create.update.hash-dependencies=\ --hash-dependencies=PATTERN Die Hashes von Modulabh\u00E4ngigkeiten\n entsprechend dem angegebenen Muster beim Erstellen eines\n modularen JAR-Archivs oder Aktualisieren eines nicht modularen\n JAR-Archivs berechnen und aufzeichnen +main.help.opt.create.update.hash-modules=\ --hash-modules=PATTERN Berechnet und zeichnet die Hashes von Modulen auf, \n die mit einem bestimmten Muster \u00FCbereinstimmen, und direkt oder\n indirekt von einem modularen JAR-Archiv abh\u00E4ngen, das erstellt\n wird, oder einem nicht-modularen JAR-Archiv, das aktualisiert wird main.help.opt.create.update.modulepath=\ --modulepath Ort von Modulabh\u00E4ngigkeit zum Generieren \ des Hash main.help.opt.create.update.index=\ Vorgangsmodifikatoren, die nur im Erstellungs-, Aktualisierungs- und Indexgenerierungsmodus g\u00FCltig sind:\n @@ -85,4 +93,4 @@ main.help.opt.create.update.index.no-compress=\ -0, --no-compress Nur main.help.opt.other=\ Weitere Optionen:\n main.help.opt.other.help=\ -?, --help[:compat] Diese Meldung oder optional die Kompatibilit\u00E4t, Hilfe angeben main.help.opt.other.version=\ --version Programmversion ausgeben -main.help.postopt=\ Ein Archiv ist ein modulares JAR-Archiv, wenn der Moduldeskriptor "module-info.class"\n in der Root der angegebenen Verzeichnisse oder in der Root des JAR-Archivs selbst\n vorhanden ist. Die folgenden Vorg\u00E4nge sind nur g\u00FCltig, wenn Sie ein modulares JAR-Archiv\n erstellen oder ein vorhandenes nicht modulares JAR-Archiv aktualisieren: "--module-version",\n "--hash-dependencies" und "--modulepath".\n\n Obligatorische oder optionale Argumente zu langen Optionen sind auch f\u00FCr die jeweils\n zugeh\u00F6rigen kurzen Optionen obligatorisch oder optional. +main.help.postopt=\ Ein Archiv ist ein modulares JAR-Archiv, wenn der Moduldeskriptor "module-info.class"\n in der Root der angegebenen Verzeichnisse oder in der Root des JAR-Archivs selbst\n vorhanden ist. Die folgenden Vorg\u00E4nge sind nur g\u00FCltig, wenn Sie ein modulares JAR-Archiv\n erstellen oder ein vorhandenes nicht modulares JAR-Archiv aktualisieren: "--module-version",\n "--hash-modules" und "--modulepath".\n\n Obligatorische oder optionale Argumente zu langen Optionen sind auch f\u00FCr die jeweils\n zugeh\u00F6rigen kurzen Optionen obligatorisch oder optional. diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_es.properties b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_es.properties index 6032df409d0..0429e0b9621 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_es.properties +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_es.properties @@ -39,14 +39,22 @@ error.create.dir={0} : no se ha podido crear el directorio error.incorrect.length=longitud incorrecta al procesar: {0} error.create.tempfile=No se ha podido crear el archivo temporal error.hash.dep=Aplicando hash a las dependencias del m\u00F3dulo {0}, no se ha encontrado el m\u00F3dulo {1} en la ruta del m\u00F3dulo -error.module.options.without.info=Una de las dependencias --module-version o --hash-dependencies sin module-info.class +error.module.options.without.info=Uno de --module-version o -hash-modules sin module-info.class error.unexpected.module-info=Descriptor de m\u00F3dulo inesperado {0} error.module.descriptor.not.found=No se ha encontrado el descriptor de m\u00F3dulo +error.versioned.info.without.root=Se ha encontrado module-info.class en la secci\u00F3n de versi\u00F3n sin module-info.class en la ra\u00EDz +error.versioned.info.name.notequal=module-info.class en la secci\u00F3n de versi\u00F3n contiene un nombre incorrecto +error.versioned.info.requires.public=module-info.class en la secci\u00F3n de versi\u00F3n contiene requisitos p\u00FAblicos adicionales +error.versioned.info.requires.added=module-info.class en la secci\u00F3n de versi\u00F3n contiene requisitos adicionales +error.versioned.info.requires.dropped=module-info.class en la secci\u00F3n de versi\u00F3n contiene requisitos que faltan +error.versioned.info.exports.notequal=module-info.class en la secci\u00F3n de versi\u00F3n contiene exportaciones diferentes +error.versioned.info.provides.notequal=module-info.class en la secci\u00F3n de versi\u00F3n contiene aportaciones diferentes +error.invalid.versioned.module.attribute=Atributo de descriptor de m\u00F3dulo no v\u00E1lido {0} error.missing.provider=No se ha encontrado el proveedor de servicios: {0} out.added.manifest=manifiesto agregado -out.added.module-info=module-info.class agregado +out.added.module-info=module-info agregado: {0} out.update.manifest=manifiesto actualizado -out.update.module-info=module-info.class actualizado +out.update.module-info=module-info actualizado: {0} out.ignore.entry=ignorando entrada {0} out.adding=agregando: {0} out.deflated=(desinflado {0}%) @@ -77,7 +85,7 @@ main.help.opt.create.update.main-class=\ -e, --main-class=CLASSNAME Punto de en main.help.opt.create.update.manifest=\ -m, --manifest=FILE Incluir la informaci\u00F3n de manifiesto del archivo\n de manifiesto proporcionado main.help.opt.create.update.no-manifest=\ -M, --no-manifest No crear ning\u00FAn archivo de manifiesto para las entradas main.help.opt.create.update.module-version=\ --module-version=VERSION Versi\u00F3n del m\u00F3dulo, si se va a crear un archivo jar modular\n o actualizar un archivo jar no modular -main.help.opt.create.update.hash-dependencies=\ --hash-dependencies=PATTERN Calcular y registrar los hash de dependencias\n de m\u00F3dulo que coinciden con el patr\u00F3n proporcionado, si se va a crear\n un archivo jar modular o actualizar un archivo jar no\n modular +main.help.opt.create.update.hash-modules=\ --hash-modules=PATTERN Calcular y registrar los hash de m\u00F3dulos\n que coinciden con el patr\u00F3n proporcionado y que dependen\n directa o indirectamente de la creaci\u00F3n de un archivo jar modular\n o de la actualizaci\u00F3n de un archivo jar no modular main.help.opt.create.update.modulepath=\ --modulepath Ubicaci\u00F3n de la dependencia de m\u00F3dulo para generaci\u00F3n \ hash main.help.opt.create.update.index=\ Modificadores de operaci\u00F3n v\u00E1lidos solo en el modo de creaci\u00F3n, actualizaci\u00F3n y generaci\u00F3n de \u00EDndice:\n @@ -85,4 +93,4 @@ main.help.opt.create.update.index.no-compress=\ -0, --no-compress Solo main.help.opt.other=\ Otras opciones:\n main.help.opt.other.help=\ -?, --help[:compat] Utilice este valor, u opcionalmente la compatibilidad, ayuda main.help.opt.other.version=\ --version Imprimir versi\u00F3n del programa -main.help.postopt=\ Un archivo es un jar modular si el descriptor de m\u00F3dulo, 'module-info.class', est\u00E1\n en la ra\u00EDz de los directorios proporcionados o en la ra\u00EDz del archivo jar.\n Las siguientes operaciones solo son v\u00E1lidas si se va a crear un jar modular\n o se va a actualizar un jar existente no modular: '--module-version',\n '--hash-dependencies', y '--modulepath'.\n\n Los argumentos obligatorios u opcionales en las opciones largas tambi\u00E9n son obligatorios u opcionales\n en cualquiera de las opciones cortas. +main.help.postopt=\ Un archivo es un jar modular si el descriptor de m\u00F3dulo, 'module-info.class', est\u00E1\n en la ra\u00EDz de los directorios proporcionados o en la ra\u00EDz del archivo jar.\n Las siguientes operaciones solo son v\u00E1lidas si se va a crear un jar modular\n o se va a actualizar un jar existente no modular: '--module-version',\n '--hash-modules' y '--modulepath'.\n\n Los argumentos obligatorios u opcionales en las opciones largas tambi\u00E9n son obligatorios u opcionales\n en cualquiera de las opciones cortas. diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_fr.properties b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_fr.properties index 014aec7442b..9eeba33f6c8 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_fr.properties +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_fr.properties @@ -39,14 +39,22 @@ error.create.dir={0} : impossible de cr\u00E9er le r\u00E9pertoire error.incorrect.length=longueur incorrecte lors du traitement de : {0} error.create.tempfile=Impossible de cr\u00E9er un fichier temporaire error.hash.dep=Hachage des d\u00E9pendances du module {0}, module {1} introuvable sur le chemin de module -error.module.options.without.info=Une des options --module-version ou --hash-dependencies sans module-info.class +error.module.options.without.info=Une des options --module-version ou --hash-modules sans module-info.class error.unexpected.module-info=Descripteur de module {0} inattendu error.module.descriptor.not.found=Descripteur de module introuvable +error.versioned.info.without.root=module-info.class a \u00E9t\u00E9 d\u00E9tect\u00E9 dans la section avec num\u00E9ro de version sans module-info.class dans la racine +error.versioned.info.name.notequal=module-info.class dans la section avec num\u00E9ro de version contient un nom incorrect +error.versioned.info.requires.public=module-info.class dans la section avec num\u00E9ro de version contient des exigences publiques suppl\u00E9mentaires +error.versioned.info.requires.added=module-info.class dans la section avec num\u00E9ro de version contient des exigences suppl\u00E9mentaires +error.versioned.info.requires.dropped=module-info.class dans la section avec num\u00E9ro de version contient des exigences manquantes +error.versioned.info.exports.notequal=module-info.class dans la section avec num\u00E9ro de version contient des exports diff\u00E9rents +error.versioned.info.provides.notequal=module-info.class dans la section avec num\u00E9ro de version contient des fournitures diff\u00E9rentes +error.invalid.versioned.module.attribute=Attribut de descripteur de module non valide {0} error.missing.provider=Fournisseur de services introuvable : {0} out.added.manifest=manifeste ajout\u00E9 -out.added.module-info=module-info.class ajout\u00E9 +out.added.module-info=module-info ajout\u00E9 : {0} out.update.manifest=manifeste mis \u00E0 jour -out.update.module-info=module-info.class mis \u00E0 jour +out.update.module-info=module-info mis \u00E0 jour : {0} out.ignore.entry=entr\u00E9e {0} ignor\u00E9e out.adding=ajout : {0} out.deflated=(compression : {0} %) @@ -77,7 +85,7 @@ main.help.opt.create.update.main-class=\ -e, --main-class=CLASSNAME Point d'ent main.help.opt.create.update.manifest=\ -m, --manifest=FILE Inclut les informations de manifeste du fichier\n manifeste donn\u00E9 main.help.opt.create.update.no-manifest=\ -M, --no-manifest Ne cr\u00E9e pas de fichier manifeste pour les entr\u00E9es main.help.opt.create.update.module-version=\ --module-version=VERSION Version de module lors de la cr\u00E9ation d'un fichier JAR\n modulaire ou de la mise \u00E0 jour d'un fichier JAR non modulaire -main.help.opt.create.update.hash-dependencies=\ --hash-dependencies=PATTERN Calcule et enregistre les hachages des d\u00E9pendances\n de module mises en correspondance d'apr\u00E8s le mod\u00E8le donn\u00E9, lors\n de la cr\u00E9ation d'un JAR modulaire ou de la mise \u00E0 jour d'un JAR\n non modulaire +main.help.opt.create.update.hash-modules=\ --hash-modules=PATTERN Calcule et enregistre les hachages des modules \n mis en correspondance d'apr\u00E8s le mod\u00E8le donn\u00E9 et d\u00E9pendant\n directement ou indirectement d'un fichier JAR modulaire\n en cours de cr\u00E9ation ou d'un fichier JAR non modulaire en cours de mise \u00E0 jour main.help.opt.create.update.modulepath=\ --modulepath Emplacement d'une d\u00E9pendance de module pour la g\u00E9n\u00E9ration \ du hachage main.help.opt.create.update.index=\ Modificateurs d'op\u00E9ration valides uniquement en modes create, update et generate-index :\n @@ -85,4 +93,4 @@ main.help.opt.create.update.index.no-compress=\ -0, --no-compress Stoc main.help.opt.other=\ Autres options :\n main.help.opt.other.help=\ -?, --help[:compat] Affiche l'aide ou \u00E9ventuellement la compatibilit\u00E9 main.help.opt.other.version=\ --version Imprime la version de programme -main.help.postopt=\ Une archive est un fichier JAR modulaire si un descripteur de module, 'module-info.class', se\n trouve dans la racine des r\u00E9pertoires donn\u00E9s ou dans la racine de l'archive JAR\n elle-m\u00EAme. Les op\u00E9rations suivantes sont valides uniquement lors de la cr\u00E9ation d'un fichier JAR modulaire\n ou de la mise \u00E0 jour d'un fichier JAR non modulaire existant : '--module-version',\n '--hash-dependencies' et '--modulepath'.\n\n Les arguments obligatoires ou facultatifs pour les options longues sont \u00E9galement obligatoires ou facultatifs\n pour toute option courte correspondante. +main.help.postopt=\ Une archive est un fichier JAR modulaire si un descripteur de module, 'module-info.class', se\n trouve dans la racine des r\u00E9pertoires donn\u00E9s ou dans la racine de l'archive JAR\n elle-m\u00EAme. Les op\u00E9rations suivantes sont valides uniquement lors de la cr\u00E9ation d'un fichier JAR modulaire\n ou de la mise \u00E0 jour d'un fichier JAR non modulaire existant : '--module-version',\n '--hash-modules' et '--modulepath'.\n\n Les arguments obligatoires ou facultatifs pour les options longues sont \u00E9galement obligatoires ou facultatifs\n pour toute option courte correspondante. diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_it.properties b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_it.properties index 78609545e9d..dac191162b5 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_it.properties +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_it.properties @@ -39,14 +39,22 @@ error.create.dir={0} : impossibile creare la directory error.incorrect.length=lunghezza non valida durante l''elaborazione: {0} error.create.tempfile=Impossibile creare il file temporaneo. error.hash.dep={0} dipendenze del modulo di hashing. Impossibile trovare il modulo {1} nel percorso del modulo -error.module.options.without.info=Una delle opzioni --module-version o --hash-dependencies non contiene module-info.class +error.module.options.without.info=Una delle opzioni --module-version o --hash-modules non contiene module-info.class error.unexpected.module-info=Descrittore di modulo {0} imprevisto error.module.descriptor.not.found=Descrittore di modulo non trovato +error.versioned.info.without.root=module-info.class trovato nella sezione con controllo delle versioni senza module-info.class nella radice +error.versioned.info.name.notequal=module-info.class nella sezione con controllo delle versioni contiene un nome errato +error.versioned.info.requires.public=module-info.class nella sezione con controllo delle versioni contiene requisiti aggiuntivi pubblici +error.versioned.info.requires.added=module-info.class nella sezione con controllo delle versioni contiene requisiti aggiuntivi +error.versioned.info.requires.dropped=Mancano requisiti in module-info.class nella sezione con controllo delle versioni +error.versioned.info.exports.notequal=module-info.class nella sezione con controllo delle versioni contiene esportazioni differenti +error.versioned.info.provides.notequal=module-info.class nella sezione con controllo delle versioni contiene elementi differenti +error.invalid.versioned.module.attribute=Attributo descrittore del modulo {0} non valido. error.missing.provider=Provider di servizi non trovato: {0} out.added.manifest=aggiunto manifest -out.added.module-info=module-info.class aggiunto +out.added.module-info=aggiunto module-info: {0} out.update.manifest=aggiornato manifest -out.update.module-info=module-info.class aggiornato +out.update.module-info=aggiornato module-info: {0} out.ignore.entry=la voce {0} sar\u00E0 ignorata out.adding=aggiunta in corso di: {0} out.deflated=(compresso {0}%) @@ -77,7 +85,7 @@ main.help.opt.create.update.main-class=\ -e, --main-class=CLASSNAME Punto di in main.help.opt.create.update.manifest=\ -m, --manifest=FILE Include le informazioni sul file manifest dal file\n manifest specificato main.help.opt.create.update.no-manifest=\ -M, --no-manifest Non crea un file manifest per le voci main.help.opt.create.update.module-version=\ --module-version=VERSION Versione del modulo utilizzata durante la creazione di un file\n jar modulare o l'aggiornamento di un file jar non modulare -main.help.opt.create.update.hash-dependencies=\ --hash-dependencies=PATTERN Calcola e registra gli hash delle dipendenze\n del modulo corrispondenti in base al pattern specificato durante\n la creazione di un file jar modulare o l'aggiornamento di\n un file jar non modulare +main.help.opt.create.update.hash-modules=\ --hash-modules=PATTERN Calcola e registra gli hash dei moduli \n corrispondenti in base al pattern specificato e dipendenti\n in modo diretto o indiretto dalla creazione di un file jar modulare\n o dall'aggiornamento di un file jar non modulare main.help.opt.create.update.modulepath=\ --modulepath Posizione della dipendenza del modulo per la generazione \ dell'hash main.help.opt.create.update.index=\ Modificatori di funzionamento validi solo nella modalit\u00E0 di creazione, aggiornamento e di generazione dell'indice:\n @@ -85,4 +93,4 @@ main.help.opt.create.update.index.no-compress=\ -0, --no-compress Solo main.help.opt.other=\ Altre opzioni:\n main.help.opt.other.help=\ -?, --help[:compat] Fornisce questa Guida o facoltativamente la Guida sulla compatibilit\u00E0 main.help.opt.other.version=\ --version Stampa la versione del programma -main.help.postopt=\ Un archivio \u00E8 un file jar modulare se un descrittore di modulo, 'module-info.class', si trova\n nella directory radice delle directory specificate o nella radice dell'archivio jar\n stesso. Le operazioni seguenti sono valide solo durante la creazione di un jar modulare\n o l'aggiornamento di un file jar non modulare esistente: '--module-version',\n '--hash-dependencies' e '--modulepath'.\n\n Gli argomenti obbligatori o facoltativi per le opzioni lunghe sono obbligatori\n o facoltativi anche per le opzioni brevi corrispondenti. +main.help.postopt=\ Un archivio \u00E8 un file jar modulare se un descrittore di modulo, 'module-info.class', si trova\n nella directory radice delle directory specificate o nella radice dell'archivio jar\n stesso. Le operazioni seguenti sono valide solo durante la creazione di un jar modulare\n o l'aggiornamento di un file jar non modulare esistente: '--module-version',\n '--hash-modules' e '--modulepath'.\n\n Gli argomenti obbligatori o facoltativi per le opzioni lunghe sono obbligatori\n o facoltativi anche per le opzioni brevi corrispondenti. diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_ja.properties b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_ja.properties index 27d3da00fd5..f45a10c8b77 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_ja.properties +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_ja.properties @@ -39,14 +39,22 @@ error.create.dir=\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA{0}\u3092\u4F5C\u6210\u3067 error.incorrect.length={0}\u306E\u51E6\u7406\u4E2D\u306B\u4E0D\u6B63\u306A\u9577\u3055\u304C\u3042\u308A\u307E\u3057\u305F error.create.tempfile=\u4E00\u6642\u30D5\u30A1\u30A4\u30EB\u3092\u4F5C\u6210\u3067\u304D\u307E\u305B\u3093\u3067\u3057\u305F error.hash.dep=\u30E2\u30B8\u30E5\u30FC\u30EB{0}\u4F9D\u5B58\u6027\u306E\u30CF\u30C3\u30B7\u30E5\u3067\u30E2\u30B8\u30E5\u30FC\u30EB{1}\u304C\u30E2\u30B8\u30E5\u30FC\u30EB\u30FB\u30D1\u30B9\u306B\u898B\u3064\u304B\u308A\u307E\u305B\u3093 -error.module.options.without.info=--module-version\u307E\u305F\u306F--hash-dependencies\u306E\u3044\u305A\u308C\u304B\u3067module-info.class\u304C\u3042\u308A\u307E\u305B\u3093 +error.module.options.without.info=--module-version\u307E\u305F\u306F--hash-modules\u306E\u3044\u305A\u308C\u304B\u3067module-info.class\u304C\u3042\u308A\u307E\u305B\u3093 error.unexpected.module-info=\u4E88\u671F\u3057\u306A\u3044\u30E2\u30B8\u30E5\u30FC\u30EB\u30FB\u30C7\u30A3\u30B9\u30AF\u30EA\u30D7\u30BF{0} error.module.descriptor.not.found=\u30E2\u30B8\u30E5\u30FC\u30EB\u30FB\u30C7\u30A3\u30B9\u30AF\u30EA\u30D7\u30BF\u304C\u898B\u3064\u304B\u308A\u307E\u305B\u3093 +error.versioned.info.without.root=\u30EB\u30FC\u30C8\u306Bmodule-info.class\u306E\u306A\u3044module-info.class\u304C\u30D0\u30FC\u30B8\u30E7\u30CB\u30F3\u30B0\u30FB\u30BB\u30AF\u30B7\u30E7\u30F3\u306B\u898B\u3064\u304B\u308A\u307E\u3057\u305F +error.versioned.info.name.notequal=\u30D0\u30FC\u30B8\u30E7\u30CB\u30F3\u30B0\u30FB\u30BB\u30AF\u30B7\u30E7\u30F3\u306Emodule-info.class\u306B\u6B63\u3057\u304F\u306A\u3044\u540D\u524D\u304C\u542B\u307E\u308C\u3066\u3044\u307E\u3059 +error.versioned.info.requires.public=\u30D0\u30FC\u30B8\u30E7\u30CB\u30F3\u30B0\u30FB\u30BB\u30AF\u30B7\u30E7\u30F3\u306Emodule-info.class\u306B\u8FFD\u52A0\u306Erequires public\u304C\u542B\u307E\u308C\u3066\u3044\u307E\u3059 +error.versioned.info.requires.added=\u30D0\u30FC\u30B8\u30E7\u30CB\u30F3\u30B0\u30FB\u30BB\u30AF\u30B7\u30E7\u30F3\u306Emodule-info.class\u306B\u8FFD\u52A0\u306Erequires\u304C\u542B\u307E\u308C\u3066\u3044\u307E\u3059 +error.versioned.info.requires.dropped=\u30D0\u30FC\u30B8\u30E7\u30CB\u30F3\u30B0\u30FB\u30BB\u30AF\u30B7\u30E7\u30F3\u306Emodule-info.class\u306B\u6B20\u843D\u3057\u3066\u3044\u308Brequires\u304C\u542B\u307E\u308C\u3066\u3044\u307E\u3059 +error.versioned.info.exports.notequal=\u30D0\u30FC\u30B8\u30E7\u30CB\u30F3\u30B0\u30FB\u30BB\u30AF\u30B7\u30E7\u30F3\u306Emodule-info.class\u306B\u7570\u306A\u308Bexports\u304C\u542B\u307E\u308C\u3066\u3044\u307E\u3059 +error.versioned.info.provides.notequal=\u30D0\u30FC\u30B8\u30E7\u30CB\u30F3\u30B0\u30FB\u30BB\u30AF\u30B7\u30E7\u30F3\u306Emodule-info.class\u306B\u7570\u306A\u308Bprovides\u304C\u542B\u307E\u308C\u3066\u3044\u307E\u3059 +error.invalid.versioned.module.attribute=\u30E2\u30B8\u30E5\u30FC\u30EB\u30FB\u30C7\u30A3\u30B9\u30AF\u30EA\u30D7\u30BF\u5C5E\u6027{0}\u304C\u7121\u52B9\u3067\u3059 error.missing.provider=\u30B5\u30FC\u30D3\u30B9\u30FB\u30D7\u30ED\u30D0\u30A4\u30C0\u304C\u898B\u3064\u304B\u308A\u307E\u305B\u3093: {0} out.added.manifest=\u30DE\u30CB\u30D5\u30A7\u30B9\u30C8\u304C\u8FFD\u52A0\u3055\u308C\u307E\u3057\u305F -out.added.module-info=module-info.class\u304C\u8FFD\u52A0\u3055\u308C\u307E\u3057\u305F +out.added.module-info=module-info\u304C\u8FFD\u52A0\u3055\u308C\u307E\u3057\u305F: {0} out.update.manifest=\u30DE\u30CB\u30D5\u30A7\u30B9\u30C8\u304C\u66F4\u65B0\u3055\u308C\u307E\u3057\u305F -out.update.module-info=module-info.class\u304C\u66F4\u65B0\u3055\u308C\u307E\u3057\u305F +out.update.module-info=module-info\u304C\u66F4\u65B0\u3055\u308C\u307E\u3057\u305F: {0} out.ignore.entry=\u30A8\u30F3\u30C8\u30EA{0}\u3092\u7121\u8996\u3057\u307E\u3059 out.adding={0}\u3092\u8FFD\u52A0\u4E2D\u3067\u3059 out.deflated=({0}%\u53CE\u7E2E\u3055\u308C\u307E\u3057\u305F) @@ -77,7 +85,7 @@ main.help.opt.create.update.main-class=\ -e\u3001--main-class=CLASSNAME \u30E2\ main.help.opt.create.update.manifest=\ -m\u3001--manifest=FILE \u6307\u5B9A\u306E\u30DE\u30CB\u30D5\u30A7\u30B9\u30C8\u30FB\u30D5\u30A1\u30A4\u30EB\u304B\u3089\u30DE\u30CB\u30D5\u30A7\u30B9\u30C8\u60C5\u5831\u3092\n \u53D6\u308A\u8FBC\u307F\u307E\u3059 main.help.opt.create.update.no-manifest=\ -M\u3001--no-manifest \u30A8\u30F3\u30C8\u30EA\u306E\u30DE\u30CB\u30D5\u30A7\u30B9\u30C8\u30FB\u30D5\u30A1\u30A4\u30EB\u3092\u4F5C\u6210\u3057\u307E\u305B\u3093 main.help.opt.create.update.module-version=\ --module-version=VERSION \u30E2\u30B8\u30E5\u30E9jar\u306E\u4F5C\u6210\u6642\u307E\u305F\u306F\u975E\u30E2\u30B8\u30E5\u30E9jar\u306E\u66F4\u65B0\u6642\u306E\n \u30E2\u30B8\u30E5\u30FC\u30EB\u30FB\u30D0\u30FC\u30B8\u30E7\u30F3 -main.help.opt.create.update.hash-dependencies=\ --hash-dependencies=PATTERN \u30E2\u30B8\u30E5\u30E9jar\u306E\u4F5C\u6210\u6642\u307E\u305F\u306F\n \u975E\u30E2\u30B8\u30E5\u30E9jar\u306E\u66F4\u65B0\u6642\u306B\u3001\u6307\u5B9A\u306E\u30D1\u30BF\u30FC\u30F3\u3067\n \u4E00\u81F4\u3057\u305F\u30E2\u30B8\u30E5\u30FC\u30EB\u4F9D\u5B58\u6027\u306E\u30CF\u30C3\u30B7\u30E5\u3092\n \u8A08\u7B97\u304A\u3088\u3073\u8A18\u9332\u3057\u307E\u3059 +main.help.opt.create.update.hash-modules=\ --hash-modules=PATTERN \u30E2\u30B8\u30E5\u30E9jar\u306E\u4F5C\u6210\u6642\u307E\u305F\u306F\u975E\u30E2\u30B8\u30E5\u30E9jar\u306E\u66F4\u65B0\u6642\u306B\n \u6307\u5B9A\u306E\u30D1\u30BF\u30FC\u30F3\u306B\u4E00\u81F4\u3057\u3001\u76F4\u63A5\u307E\u305F\u306F\u9593\u63A5\u7684\u306B\n \u4F9D\u5B58\u3057\u3066\u3044\u308B\u30E2\u30B8\u30E5\u30FC\u30EB\u306E\u30CF\u30C3\u30B7\u30E5\u3092\n \u8A08\u7B97\u304A\u3088\u3073\u8A18\u9332\u3057\u307E\u3059 main.help.opt.create.update.modulepath=\ --modulepath \u751F\u6210\u3059\u308B\u30E2\u30B8\u30E5\u30FC\u30EB\u4F9D\u5B58\u6027\u306E\u5834\u6240 \ \u30CF\u30C3\u30B7\u30E5 main.help.opt.create.update.index=\ \u4F5C\u6210\u3001\u66F4\u65B0\u304A\u3088\u3073\u7D22\u5F15\u751F\u6210\u30E2\u30FC\u30C9\u3067\u306E\u307F\u6709\u52B9\u306A\u64CD\u4F5C\u4FEE\u98FE\u5B50:\n @@ -85,4 +93,4 @@ main.help.opt.create.update.index.no-compress=\ -0, --no-compress \u68 main.help.opt.other=\ \u305D\u306E\u4ED6\u306E\u30AA\u30D7\u30B7\u30E7\u30F3:\n main.help.opt.other.help=\ -?, --help[:compat] \u3053\u308C(\u30AA\u30D7\u30B7\u30E7\u30F3\u3067\u4E92\u63DB\u6027)\u3092help\u306B\u6307\u5B9A\u3057\u307E\u3059 main.help.opt.other.version=\ --version \u30D7\u30ED\u30B0\u30E9\u30E0\u30FB\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u51FA\u529B\u3057\u307E\u3059 -main.help.postopt=\ \u30E2\u30B8\u30E5\u30FC\u30EB\u30FB\u30C7\u30A3\u30B9\u30AF\u30EA\u30D7\u30BF'module-info.class'\u304C\u6307\u5B9A\u306E\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u306E\u30EB\u30FC\u30C8\u307E\u305F\u306F\n jar\u30A2\u30FC\u30AB\u30A4\u30D6\u81EA\u4F53\u306E\u30EB\u30FC\u30C8\u306B\u3042\u308B\u5834\u5408\u3001\u30A2\u30FC\u30AB\u30A4\u30D6\u306F\u30E2\u30B8\u30E5\u30E9jar\u3067\u3059\u3002\n \u6B21\u306E\u64CD\u4F5C\u306F\u3001\u30E2\u30B8\u30E5\u30E9jar\u306E\u4F5C\u6210\u6642\u307E\u305F\u306F\u65E2\u5B58\u306E\u975E\u30E2\u30B8\u30E5\u30E9jar\u306E\u66F4\u65B0\u6642\u306B\n \u306E\u307F\u6709\u52B9\u3067\u3059: '--module-version'\u3001\n '--hash-dependencies'\u304A\u3088\u3073'--modulepath'\u3002\n\n \u30ED\u30F3\u30B0\u30FB\u30AA\u30D7\u30B7\u30E7\u30F3\u3078\u306E\u5FC5\u9808\u307E\u305F\u306F\u30AA\u30D7\u30B7\u30E7\u30F3\u306E\u5F15\u6570\u306F\u3001\u5BFE\u5FDC\u3059\u308B\u30B7\u30E7\u30FC\u30C8\u30FB\u30AA\u30D7\u30B7\u30E7\u30F3\n \u306B\u5BFE\u3057\u3066\u3082\u5FC5\u9808\u307E\u305F\u306F\u30AA\u30D7\u30B7\u30E7\u30F3\u306B\u306A\u308A\u307E\u3059\u3002 +main.help.postopt=\ \u30E2\u30B8\u30E5\u30FC\u30EB\u30FB\u30C7\u30A3\u30B9\u30AF\u30EA\u30D7\u30BF'module-info.class'\u304C\u6307\u5B9A\u306E\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u306E\u30EB\u30FC\u30C8\u307E\u305F\u306F\n jar\u30A2\u30FC\u30AB\u30A4\u30D6\u81EA\u4F53\u306E\u30EB\u30FC\u30C8\u306B\u3042\u308B\u5834\u5408\u3001\u30A2\u30FC\u30AB\u30A4\u30D6\u306F\u30E2\u30B8\u30E5\u30E9jar\u3067\u3059\u3002\n \u6B21\u306E\u64CD\u4F5C\u306F\u3001\u30E2\u30B8\u30E5\u30E9jar\u306E\u4F5C\u6210\u6642\u307E\u305F\u306F\u65E2\u5B58\u306E\u975E\u30E2\u30B8\u30E5\u30E9jar\u306E\u66F4\u65B0\u6642\u306B\n \u306E\u307F\u6709\u52B9\u3067\u3059: '--module-version'\u3001\n '--hash-modules'\u304A\u3088\u3073'--modulepath'\u3002\n\n \u30ED\u30F3\u30B0\u30FB\u30AA\u30D7\u30B7\u30E7\u30F3\u3078\u306E\u5FC5\u9808\u307E\u305F\u306F\u30AA\u30D7\u30B7\u30E7\u30F3\u306E\u5F15\u6570\u306F\u3001\u5BFE\u5FDC\u3059\u308B\u30B7\u30E7\u30FC\u30C8\u30FB\u30AA\u30D7\u30B7\u30E7\u30F3\n \u306B\u5BFE\u3057\u3066\u3082\u5FC5\u9808\u307E\u305F\u306F\u30AA\u30D7\u30B7\u30E7\u30F3\u306B\u306A\u308A\u307E\u3059\u3002 diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_ko.properties b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_ko.properties index a80cca49749..7e1505626c7 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_ko.properties +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_ko.properties @@ -39,14 +39,22 @@ error.create.dir={0}: \uB514\uB809\uD1A0\uB9AC\uB97C \uC0DD\uC131\uD560 \uC218 \ error.incorrect.length=\uCC98\uB9AC \uC911 \uC62C\uBC14\uB974\uC9C0 \uC54A\uC740 \uAE38\uC774\uAC00 \uBC1C\uACAC\uB428: {0} error.create.tempfile=\uC784\uC2DC \uD30C\uC77C\uC744 \uC0DD\uC131\uD560 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4. error.hash.dep=\uBAA8\uB4C8 {0} \uC885\uC18D\uC131\uC744 \uD574\uC2DC\uD558\uB294 \uC911 \uBAA8\uB4C8 \uACBD\uB85C\uC5D0\uC11C {1} \uBAA8\uB4C8\uC744 \uCC3E\uC744 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4. -error.module.options.without.info=module-info.class \uC5C6\uC774 --module-version \uB610\uB294 --hash-dependencies \uC911 \uD558\uB098 +error.module.options.without.info=module-info.class \uC5C6\uC774 --module-version \uB610\uB294 --hash-modules \uC911 \uD558\uB098 error.unexpected.module-info=\uC608\uC0C1\uCE58 \uC54A\uC740 \uBAA8\uB4C8 \uAE30\uC220\uC790 {0} error.module.descriptor.not.found=\uBAA8\uB4C8 \uAE30\uC220\uC790\uB97C \uCC3E\uC744 \uC218 \uC5C6\uC74C +error.versioned.info.without.root=\uB8E8\uD2B8\uC5D0\uC11C module-info.class \uC5C6\uC774 \uBC84\uC804 \uC9C0\uC815\uB41C \uC139\uC158\uC5D0\uC11C module-info.class\uAC00 \uBC1C\uACAC\uB428 +error.versioned.info.name.notequal=\uBC84\uC804 \uC9C0\uC815\uB41C \uC139\uC158\uC758 module-info.class\uC5D0 \uC798\uBABB\uB41C \uC774\uB984\uC774 \uD3EC\uD568\uB428 +error.versioned.info.requires.public=\uBC84\uC804 \uC9C0\uC815\uB41C \uC139\uC158\uC758 module-info.class\uC5D0 \uCD94\uAC00 \uD544\uC218 \uACF5\uC6A9 \uD56D\uBAA9\uC774 \uD3EC\uD568\uB428 +error.versioned.info.requires.added=\uBC84\uC804 \uC9C0\uC815\uB41C \uC139\uC158\uC758 module-info.class\uC5D0 \uCD94\uAC00 \uD544\uC218 \uD56D\uBAA9\uC774 \uD3EC\uD568\uB428 +error.versioned.info.requires.dropped=\uBC84\uC804 \uC9C0\uC815\uB41C \uC139\uC158\uC758 module-info.class\uC5D0 \uB204\uB77D\uB41C \uD544\uC218 \uD56D\uBAA9\uC774 \uD3EC\uD568\uB428 +error.versioned.info.exports.notequal=\uBC84\uC804 \uC9C0\uC815\uB41C \uC139\uC158\uC758 module-info.class\uC5D0 \uB2E4\uB978 \uC775\uC2A4\uD3EC\uD2B8 \uD56D\uBAA9\uC774 \uD3EC\uD568\uB428 +error.versioned.info.provides.notequal=\uBC84\uC804 \uC9C0\uC815\uB41C \uC139\uC158\uC758 module-info.class\uC5D0 \uB2E4\uB978 \uC81C\uACF5 \uD56D\uBAA9\uC774 \uD3EC\uD568\uB428 +error.invalid.versioned.module.attribute=\uBD80\uC801\uD569\uD55C \uBAA8\uB4C8 \uAE30\uC220\uC790 \uC18D\uC131 {0} error.missing.provider=\uC11C\uBE44\uC2A4 \uC81C\uACF5\uC790\uB97C \uCC3E\uC744 \uC218 \uC5C6\uC74C: {0} out.added.manifest=Manifest\uB97C \uCD94\uAC00\uD568 -out.added.module-info=module-info.class\uB97C \uCD94\uAC00\uD568 +out.added.module-info=\uCD94\uAC00\uB41C \uBAA8\uB4C8 \uC815\uBCF4: {0} out.update.manifest=Manifest\uB97C \uC5C5\uB370\uC774\uD2B8\uD568 -out.update.module-info=module-info.class\uB97C \uC5C5\uB370\uC774\uD2B8\uD568 +out.update.module-info=\uC5C5\uB370\uC774\uD2B8\uB41C \uBAA8\uB4C8 \uC815\uBCF4: {0} out.ignore.entry={0} \uD56D\uBAA9\uC744 \uBB34\uC2DC\uD558\uB294 \uC911 out.adding=\uCD94\uAC00\uD558\uB294 \uC911: {0} out.deflated=({0}%\uB97C \uAC10\uC18C\uD568) @@ -77,7 +85,7 @@ main.help.opt.create.update.main-class=\ -e, --main-class=CLASSNAME \uBAA8\uB4C main.help.opt.create.update.manifest=\ -m, --manifest=FILE \uC9C0\uC815\uB41C Manifest \uD30C\uC77C\uC758 Manifest \uC815\uBCF4\uB97C\n \uD3EC\uD568\uD569\uB2C8\uB2E4. main.help.opt.create.update.no-manifest=\ -M, --no-manifest \uD56D\uBAA9\uC5D0 \uB300\uD574 Manifest \uD30C\uC77C\uC744 \uC0DD\uC131\uD558\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4. main.help.opt.create.update.module-version=\ --module-version=VERSION \uBAA8\uB4C8\uD615 jar\uB97C \uC0DD\uC131\uD558\uAC70\uB098 \uBE44\uBAA8\uB4C8 jar\uB97C\n \uC5C5\uB370\uC774\uD2B8\uD560 \uB54C \uBAA8\uB4C8 \uBC84\uC804\uC785\uB2C8\uB2E4. -main.help.opt.create.update.hash-dependencies=\ --hash-dependencies=PATTERN \uBAA8\uB4C8\uD615 jar\uB97C \uC0DD\uC131\uD558\uAC70\uB098 \uBE44\uBAA8\uB4C8 jar\uB97C\n \uC5C5\uB370\uC774\uD2B8\uD560 \uB54C \uC8FC\uC5B4\uC9C4 \uD328\uD134\uACFC \uC77C\uCE58\uD558\uB294\n \uBAA8\uB4C8 \uC885\uC18D\uC131\uC758 \uD574\uC2DC\uB97C \uCEF4\uD4E8\uD2B8\uD558\uACE0\n \uAE30\uB85D\uD569\uB2C8\uB2E4. +main.help.opt.create.update.hash-modules=\ --hash-modules=PATTERN \uC0DD\uC131 \uC911\uC778 \uBAA8\uB4C8\uD615 jar \uB610\uB294 \uC5C5\uB370\uC774\uD2B8 \uC911\uC778 \uBE44\uBAA8\uB4C8 jar\uC5D0 \n \uC9C1\uC811 \uB610\uB294 \uAC04\uC811\uC801\uC73C\uB85C \uC758\uC874\uD558\uACE0 \uC8FC\uC5B4\uC9C4 \uD328\uD134\uACFC \uC77C\uCE58\uD558\uB294\n \uBAA8\uB4C8\uC758 \uD574\uC2DC\uB97C \uCEF4\uD4E8\uD2B8\uD558\uACE0\n \uAE30\uB85D\uD569\uB2C8\uB2E4. main.help.opt.create.update.modulepath=\ --modulepath \uD574\uC2DC\uB97C \uC0DD\uC131\uD558\uAE30 \uC704\uD55C \uBAA8\uB4C8 \uC885\uC18D\uC131\uC758 \ \uC704\uCE58\uC785\uB2C8\uB2E4. main.help.opt.create.update.index=\ \uC0DD\uC131, \uC5C5\uB370\uC774\uD2B8 \uBC0F generate-index \uBAA8\uB4DC\uC5D0\uC11C\uB9CC \uC801\uD569\uD55C \uC791\uC5C5 \uC218\uC815\uC790:\n @@ -85,4 +93,4 @@ main.help.opt.create.update.index.no-compress=\ -0, --no-compress \uC8 main.help.opt.other=\ \uAE30\uD0C0 \uC635\uC158:\n main.help.opt.other.help=\ -?, --help[:compat] \uC774 \uB3C4\uC6C0\uB9D0(\uB610\uB294 \uC120\uD0DD\uC801\uC73C\uB85C \uD638\uD658\uC131)\uC744 \uC81C\uACF5\uD569\uB2C8\uB2E4. main.help.opt.other.version=\ --version \uD504\uB85C\uADF8\uB7A8 \uBC84\uC804\uC744 \uC778\uC1C4\uD569\uB2C8\uB2E4. -main.help.postopt=\ \uC544\uCE74\uC774\uBE0C\uB294 \uBAA8\uB4C8 \uAE30\uC220\uC790 'module-info.class'\uAC00 \uC8FC\uC5B4\uC9C4 \uB514\uB809\uD1A0\uB9AC\uC758\n \uB8E8\uD2B8 \uB610\uB294 jar \uC544\uCE74\uC774\uBE0C \uC790\uCCB4\uC758 \uB8E8\uD2B8\uC5D0 \uC704\uCE58\uD55C \uACBD\uC6B0 \uBAA8\uB4C8\uD615 jar\uC785\uB2C8\uB2E4.\n \uB2E4\uC74C \uC791\uC5C5\uC740 \uBAA8\uB4C8\uD615 jar\uB97C \uC0DD\uC131\uD558\uAC70\uB098 \uAE30\uC874 \uBE44\uBAA8\uB4C8 jar\uB97C\n \uC5C5\uB370\uC774\uD2B8\uD560 \uB54C\uB9CC \uC801\uD569\uD569\uB2C8\uB2E4. '--module-version',\n '--hash-dependencies', '--modulepath'.\n\n long \uC635\uC158\uC758 \uD544\uC218 \uB610\uB294 \uC120\uD0DD\uC801 \uC778\uC218\uB294 \uD574\uB2F9\uD558\uB294 short \uC635\uC158\uC5D0 \uB300\uD574\uC11C\uB3C4\n \uD544\uC218 \uB610\uB294 \uC120\uD0DD\uC801\uC785\uB2C8\uB2E4. +main.help.postopt=\ \uC544\uCE74\uC774\uBE0C\uB294 \uBAA8\uB4C8 \uAE30\uC220\uC790 'module-info.class'\uAC00 \uC8FC\uC5B4\uC9C4 \uB514\uB809\uD1A0\uB9AC\uC758\n \uB8E8\uD2B8 \uB610\uB294 jar \uC544\uCE74\uC774\uBE0C \uC790\uCCB4\uC758 \uB8E8\uD2B8\uC5D0 \uC704\uCE58\uD55C \uACBD\uC6B0 \uBAA8\uB4C8\uD615 jar\uC785\uB2C8\uB2E4.\n \uB2E4\uC74C \uC791\uC5C5\uC740 \uBAA8\uB4C8\uD615 jar\uB97C \uC0DD\uC131\uD558\uAC70\uB098 \uAE30\uC874 \uBE44\uBAA8\uB4C8 jar\uB97C\n \uC5C5\uB370\uC774\uD2B8\uD560 \uB54C\uB9CC \uC801\uD569\uD569\uB2C8\uB2E4. '--module-version',\n '--hash-modules' \uBC0F '--modulepath'.\n\n long \uC635\uC158\uC758 \uD544\uC218 \uB610\uB294 \uC120\uD0DD\uC801 \uC778\uC218\uB294 \uD574\uB2F9\uD558\uB294 short \uC635\uC158\uC5D0 \uB300\uD574\uC11C\uB3C4\n \uD544\uC218 \uB610\uB294 \uC120\uD0DD\uC801\uC785\uB2C8\uB2E4. diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_pt_BR.properties b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_pt_BR.properties index 67bd08bea81..b591285f593 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_pt_BR.properties +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_pt_BR.properties @@ -39,14 +39,22 @@ error.create.dir={0} : n\u00E3o foi poss\u00EDvel criar o diret\u00F3rio error.incorrect.length=largura incorreta durante o processamento: {0} error.create.tempfile=N\u00E3o foi poss\u00EDvel criar um arquivo tempor\u00E1rio error.hash.dep=M\u00F3dulo de hashing com {0} depend\u00EAncias. N\u00E3o \u00E9 poss\u00EDvel localizar o m\u00F3dulo {1} no caminho do m\u00F3dulo -error.module.options.without.info=Um dentre --module-version ou --hash-dependencies est\u00E1 sem module-info.class +error.module.options.without.info=Um dentre --module-version ou --hash-modules est\u00E1 sem module-info.class error.unexpected.module-info=Descritor de m\u00F3dulo inesperado {0} error.module.descriptor.not.found=Descritor de m\u00F3dulo n\u00E3o encontrado +error.versioned.info.without.root=module-info.class encontrado na se\u00E7\u00E3o com controle de vers\u00E3o sem module-info.class na raiz +error.versioned.info.name.notequal=module-info.class na se\u00E7\u00E3o com controle de vers\u00E3o cont\u00E9m nome incorreto +error.versioned.info.requires.public=module-info.class na se\u00E7\u00E3o com controle de vers\u00E3o cont\u00E9m uma depend\u00EAncia requires public adicional +error.versioned.info.requires.added=module-info.class na se\u00E7\u00E3o com controle de vers\u00E3o cont\u00E9m depend\u00EAncias require adicionais +error.versioned.info.requires.dropped=module-info.class na se\u00E7\u00E3o com controle de vers\u00E3o cont\u00E9m depend\u00EAncias require ausentes +error.versioned.info.exports.notequal=module-info.class na se\u00E7\u00E3o com controle de vers\u00E3o cont\u00E9m cl\u00E1usulas exports diferentes +error.versioned.info.provides.notequal=module-info.class na se\u00E7\u00E3o com controle de vers\u00E3o cont\u00E9m cl\u00E1usulas provides diferentes +error.invalid.versioned.module.attribute=Atributo {0} de descritor de m\u00F3dulo inv\u00E1lido error.missing.provider=Prestador de servi\u00E7os n\u00E3o encontrado: {0} out.added.manifest=manifesto adicionado -out.added.module-info=module-info.class adicionado +out.added.module-info=module-info: {0} adicionado out.update.manifest=manifesto atualizado -out.update.module-info=module-info.class atualizado +out.update.module-info=module-info: {0} atualizado out.ignore.entry=ignorando entrada {0} out.adding=adicionando: {0} out.deflated=(compactado {0}%) @@ -77,7 +85,7 @@ main.help.opt.create.update.main-class=\ -e, --main-class=CLASSNAME O ponto de main.help.opt.create.update.manifest=\ -m, --manifest=FILE Inclui as informa\u00E7\u00F5es de manifesto provenientes do arquivo de\n manifesto em quest\u00E3o main.help.opt.create.update.no-manifest=\ -M, --no-manifest N\u00E3o cria um arquivo de manifesto para as entradas main.help.opt.create.update.module-version=\ --module-version=VERSION A vers\u00E3o do m\u00F3dulo, ao criar um arquivo jar\n modular, ou atualizar um arquivo jar n\u00E3o modular -main.help.opt.create.update.hash-dependencies=\ --hash-dependencies=PATTERN Calcula e registra os hashes das depend\u00EAncias do\n m\u00F3dulo correlacionadas pelo padr\u00E3o fornecido, ao\n criar um arquivo jar modular ou atualizar um arquivo jar n\u00E3o\n modular +main.help.opt.create.update.hash-modules=\ --hash-modules=PATTERN Calcula e registra os hashes dos m\u00F3dulos\n correlacionado pelo padr\u00E3o fornecido e do qual depende\n direta ou indiretamente em um arquivo jar modular que est\u00E1 sendo\n criado ou em um arquivo jar n\u00E3o modular que est\u00E1 sendo atualizado main.help.opt.create.update.modulepath=\ --modulepath Localiza\u00E7\u00E3o da depend\u00EAncia de m\u00F3dulo para gerar \ o hash main.help.opt.create.update.index=\ Modificadores de opera\u00E7\u00E3o v\u00E1lidos somente no modo de cria\u00E7\u00E3o, atualiza\u00E7\u00E3o e gera\u00E7\u00E3o de \u00EDndice:\n @@ -85,4 +93,4 @@ main.help.opt.create.update.index.no-compress=\ -0, --no-compress Some main.help.opt.other=\ Outras op\u00E7\u00F5es:\n main.help.opt.other.help=\ -?, --help[:compat] Fornece esta ajuda ou, opcionalmente, a ajuda de compatibilidade main.help.opt.other.version=\ --version Imprime a vers\u00E3o do programa -main.help.postopt=\ Um arquivo compactado \u00E9 um arquivo jar modular se um descritor de m\u00F3dulo, 'module-info.class', estiver\n localizado na raiz dos diret\u00F3rios fornecidos, ou na raiz do arquivo compactado jar\n propriamente dito. As seguintes opera\u00E7\u00F5es s\u00F3 s\u00E3o v\u00E1lidas ao criar um arquivo jar modular,\n ou atualizar um arquivo jar n\u00E3o modular existente: '--module-version',\n '--hash-dependencies', e '--modulepath'.\n\n Argumentos obrigat\u00F3rios ou opcionais para op\u00E7\u00F5es longas tamb\u00E9m s\u00E3o obrigat\u00F3rios ou opcionais\n para quaisquer op\u00E7\u00F5es curtas correspondentes. +main.help.postopt=\ Um arquivo compactado \u00E9 um arquivo jar modular se um descritor de m\u00F3dulo, 'module-info.class', estiver\n localizado na raiz dos diret\u00F3rios fornecidos, ou na raiz do arquivo compactado jar\n propriamente dito. As seguintes opera\u00E7\u00F5es s\u00F3 s\u00E3o v\u00E1lidas ao criar um arquivo jar modular\n ou atualizar um arquivo jar n\u00E3o modular existente: '--module-version',\n '--hash-modules' e '--modulepath'.\n\n Argumentos obrigat\u00F3rios ou opcionais para op\u00E7\u00F5es longas tamb\u00E9m s\u00E3o obrigat\u00F3rios ou opcionais\n para quaisquer op\u00E7\u00F5es curtas correspondentes. diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_sv.properties b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_sv.properties index d3c2fcb4ad0..08520e08638 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_sv.properties +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_sv.properties @@ -39,14 +39,22 @@ error.create.dir={0} : kunde inte skapa n\u00E5gon katalog error.incorrect.length=ogiltig l\u00E4ngd vid bearbetning: {0} error.create.tempfile=Kunde inte skapa en tillf\u00E4llig fil error.hash.dep={0}-beroenden f\u00F6r hashningsmodulen, kan inte hitta modulen {1} p\u00E5 moduls\u00F6kv\u00E4gen -error.module.options.without.info=--module-version eller --hash-dependencies utan module-info.class +error.module.options.without.info=--module-version eller --hash-modules utan module-info.class error.unexpected.module-info=Ov\u00E4ntad moduldeskriptor, {0} error.module.descriptor.not.found=Moduldeskriptorn hittades inte +error.versioned.info.without.root=module-info.class hittades i versionshanterad sektion utan module-info.class i roten +error.versioned.info.name.notequal=module-info.class i en versionshanterad sektion inneh\u00E5ller ett felaktigt namn +error.versioned.info.requires.public=module-info.class i en versionshanterad sektion inneh\u00E5ller fler allm\u00E4nna obligatoriska +error.versioned.info.requires.added=module-info.class i en versionshanterad sektion inneh\u00E5ller fler obligatoriska +error.versioned.info.requires.dropped=module-info.class i en versionshanterad sektion inneh\u00E5ller saknade obligatoriska +error.versioned.info.exports.notequal=module-info.class i en versionshanterad sektion inneh\u00E5ller olika exporter +error.versioned.info.provides.notequal=module-info.class i en versionshanterad sektion inneh\u00E5ller olika tillhandah\u00E5llna +error.invalid.versioned.module.attribute=Ogiltigt attribut f\u00F6r moduldeskriptor, {0} error.missing.provider=Tj\u00E4nsteleverant\u00F6ren hittades inte: {0} out.added.manifest=tillagt manifestfil -out.added.module-info=lade till module-info.class +out.added.module-info=lade till module-info: {0} out.update.manifest=uppdaterat manifest -out.update.module-info=uppdaterade module-info.class +out.update.module-info=uppdaterade module-info: {0} out.ignore.entry=ignorerar posten {0} out.adding=l\u00E4gger till: {0} out.deflated=({0}% packat) @@ -77,7 +85,7 @@ main.help.opt.create.update.main-class=\ -e, --main-class=CLASSNAME Applikation main.help.opt.create.update.manifest=\ -m, --manifest=FILE Inkludera manifestinformationen fr\u00E5n den angivna\n manifestfilen main.help.opt.create.update.no-manifest=\ -M, --no-manifest Skapa inte en manifestfil f\u00F6r posterna main.help.opt.create.update.module-version=\ --module-version=VERSION Modulversionen vid skapande av ett modul\u00E4rt\n jar-arkiv eller vid uppdatering av ett icke-modul\u00E4rt jar-arkiv -main.help.opt.create.update.hash-dependencies=\ --hash-dependencies=PATTERN Ber\u00E4kna och registrera hashningarna f\u00F6r\n modulberoenden som matchar det angivna m\u00F6nstret vid skapande\n att ett modul\u00E4rt jar-arkiv eller vid uppdatering av ett\n icke-modul\u00E4rt jar-arkiv +main.help.opt.create.update.hash-modules=\ --hash-modules=PATTERN Ber\u00E4kna och registrera hashningarna f\u00F6r moduler som\n matchar det angivna m\u00F6nstret och som \u00E4r direkt eller\n indirekt beroende av att ett modul\u00E4rt jar-arkiv skapas\n eller att ett icke-modul\u00E4rt jar-arkiv uppdateras main.help.opt.create.update.modulepath=\ --modulepath Plats f\u00F6r modulberoende f\u00F6r att generera \ hashningen main.help.opt.create.update.index=\ \u00C5tg\u00E4rdsmodifierare som endast \u00E4r giltiga i l\u00E4gena create, update och generate-index:\n @@ -85,4 +93,4 @@ main.help.opt.create.update.index.no-compress=\ -0, --no-compress Enda main.help.opt.other=\ \u00D6vriga alternativ:\n main.help.opt.other.help=\ -?, --help[:compat] Visa den h\u00E4r hj\u00E4lpen eller kompatibilitetshj\u00E4lpen (valfritt) main.help.opt.other.version=\ --version Skriv ut programversion -main.help.postopt=\ Ett arkiv \u00E4r ett modul\u00E4rt jar-arkiv om en moduldeskriptor, 'module-info.class',\n finns i roten av de angivna katalogerna eller det angivna jar-arkivet.\n F\u00F6ljande \u00E5tg\u00E4rder \u00E4r endast giltiga vid skapande av ett modul\u00E4rt jar-arkiv och\n vid uppdatering av ett befintligt icke-modul\u00E4rt jar-arkiv: '--module-version',\n '--hash-dependencies' och '--modulepath'.\n\n Obligatoriska och valfria alternativ f\u00F6r l\u00E5nga alternativ \u00E4r \u00E4ven obligatoriska\n respektive valfria f\u00F6r alla motsvarande korta alternativ. +main.help.postopt=\ Ett arkiv \u00E4r ett modul\u00E4rt jar-arkiv om en moduldeskriptor, 'module-info.class',\n finns i roten av de angivna katalogerna eller det angivna jar-arkivet.\n F\u00F6ljande \u00E5tg\u00E4rder \u00E4r endast giltiga vid skapande av ett modul\u00E4rt jar-arkiv och\n vid uppdatering av ett befintligt icke-modul\u00E4rt jar-arkiv: '--module-version',\n '--hash-modules' och '--modulepath'.\n\n Obligatoriska och valfria alternativ f\u00F6r l\u00E5nga alternativ \u00E4r \u00E4ven obligatoriska\n respektive valfria f\u00F6r alla motsvarande korta alternativ. diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_zh_CN.properties b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_zh_CN.properties index ceea0131e48..b0bec89236b 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_zh_CN.properties +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_zh_CN.properties @@ -39,14 +39,22 @@ error.create.dir={0}: \u65E0\u6CD5\u521B\u5EFA\u76EE\u5F55 error.incorrect.length=\u5904\u7406\u65F6\u9047\u5230\u4E0D\u6B63\u786E\u7684\u957F\u5EA6: {0} error.create.tempfile=\u65E0\u6CD5\u521B\u5EFA\u4E34\u65F6\u6587\u4EF6 error.hash.dep=\u6B63\u5728\u5BF9\u6A21\u5757 {0} \u7684\u88AB\u4F9D\u8D56\u5BF9\u8C61\u6267\u884C\u6563\u5217\u5904\u7406, \u5728\u6A21\u5757\u8DEF\u5F84\u4E2D\u627E\u4E0D\u5230\u6A21\u5757 {1} -error.module.options.without.info=--module-version \u6216 --hash-dependencies \u4E4B\u4E00\u6CA1\u6709 module-info.class +error.module.options.without.info=--module-version \u6216 --hash-modules \u4E4B\u4E00\u6CA1\u6709 module-info.class error.unexpected.module-info=\u610F\u5916\u7684\u6A21\u5757\u63CF\u8FF0\u7B26 {0} error.module.descriptor.not.found=\u627E\u4E0D\u5230\u6A21\u5757\u63CF\u8FF0\u7B26 +error.versioned.info.without.root=\u5728\u7248\u672C\u5316\u8282\u4E2D\u627E\u5230\u4E86 module-info.class, \u4F46\u6839\u4E2D\u6CA1\u6709 module-info.class +error.versioned.info.name.notequal=\u7248\u672C\u5316\u8282\u4E2D\u7684 module-info.class \u5305\u542B\u4E0D\u6B63\u786E\u7684\u540D\u79F0 +error.versioned.info.requires.public=\u7248\u672C\u5316\u8282\u4E2D\u7684 module-info.class \u5305\u542B\u989D\u5916\u7684 requires public +error.versioned.info.requires.added=\u7248\u672C\u5316\u8282\u4E2D\u7684 module-info.class \u5305\u542B\u989D\u5916\u7684 requires +error.versioned.info.requires.dropped=\u7248\u672C\u5316\u8282\u4E2D\u7684 module-info.class \u5305\u542B\u7F3A\u5C11\u7684 requires +error.versioned.info.exports.notequal=\u7248\u672C\u5316\u8282\u4E2D\u7684 module-info.class \u5305\u542B\u4E0D\u540C\u7684 exports +error.versioned.info.provides.notequal=\u7248\u672C\u5316\u8282\u4E2D\u7684 module-info.class \u5305\u542B\u4E0D\u540C\u7684 provides +error.invalid.versioned.module.attribute=\u65E0\u6548\u7684\u6A21\u5757\u63CF\u8FF0\u7B26\u5C5E\u6027 {0} error.missing.provider=\u672A\u627E\u5230\u670D\u52A1\u63D0\u4F9B\u65B9: {0} out.added.manifest=\u5DF2\u6DFB\u52A0\u6E05\u5355 -out.added.module-info=\u5DF2\u6DFB\u52A0 module-info.class +out.added.module-info=\u5DF2\u6DFB\u52A0 module-info: {0} out.update.manifest=\u5DF2\u66F4\u65B0\u6E05\u5355 -out.update.module-info=\u5DF2\u66F4\u65B0 module-info.class +out.update.module-info=\u5DF2\u66F4\u65B0 module-info: {0} out.ignore.entry=\u6B63\u5728\u5FFD\u7565\u6761\u76EE{0} out.adding=\u6B63\u5728\u6DFB\u52A0: {0} out.deflated=(\u538B\u7F29\u4E86 {0}%) @@ -77,7 +85,7 @@ main.help.opt.create.update.main-class=\ -e, --main-class=CLASSNAME \u6346\u7ED main.help.opt.create.update.manifest=\ -m, --manifest=FILE \u5305\u542B\u6307\u5B9A\u6E05\u5355\u6587\u4EF6\u4E2D\u7684\n \u6E05\u5355\u4FE1\u606F main.help.opt.create.update.no-manifest=\ -M, --no-manifest \u4E0D\u4E3A\u6761\u76EE\u521B\u5EFA\u6E05\u5355\u6587\u4EF6 main.help.opt.create.update.module-version=\ --module-version=VERSION \u521B\u5EFA\u6A21\u5757\u5316 jar \u6216\u66F4\u65B0\n \u975E\u6A21\u5757\u5316 jar \u65F6\u7684\u6A21\u5757\u7248\u672C -main.help.opt.create.update.hash-dependencies=\ --hash-dependencies=PATTERN \u521B\u5EFA\u6A21\u5757\u5316 jar \u6216\u66F4\u65B0\n \u975E\u6A21\u5757\u5316 jar \u65F6\u8BA1\u7B97\u548C\u8BB0\u5F55\n \u6309\u6307\u5B9A\u6A21\u5F0F\u5339\u914D\u7684\u6A21\u5757\u88AB\u4F9D\u8D56\n \u5BF9\u8C61\u7684\u6563\u5217 +main.help.opt.create.update.hash-modules=\ --hash-modules=PATTERN \u8BA1\u7B97\u548C\u8BB0\u5F55\u6A21\u5757\u7684\u6563\u5217, \n \u8FD9\u4E9B\u6A21\u5757\u6309\u6307\u5B9A\u6A21\u5F0F\u5339\u914D\u5E76\u76F4\u63A5\u6216\n \u95F4\u63A5\u4F9D\u8D56\u4E8E\u6240\u521B\u5EFA\u7684\u6A21\u5757\u5316 jar \u6216\n \u6240\u66F4\u65B0\u7684\u975E\u6A21\u5757\u5316 jar main.help.opt.create.update.modulepath=\ --modulepath \u6A21\u5757\u88AB\u4F9D\u8D56\u5BF9\u8C61\u7684\u4F4D\u7F6E, \u7528\u4E8E\u751F\u6210 \ \u6563\u5217 main.help.opt.create.update.index=\ \u53EA\u5728\u521B\u5EFA, \u66F4\u65B0\u548C\u751F\u6210\u7D22\u5F15\u6A21\u5F0F\u4E0B\u6709\u6548\u7684\u64CD\u4F5C\u4FEE\u9970\u7B26:\n @@ -85,4 +93,4 @@ main.help.opt.create.update.index.no-compress=\ -0, --no-compress \u4E main.help.opt.other=\ \u5176\u4ED6\u9009\u9879:\n main.help.opt.other.help=\ -?, --help[:compat] \u63D0\u4F9B\u6B64\u5E2E\u52A9, \u4E5F\u53EF\u4EE5\u9009\u62E9\u6027\u5730\u63D0\u4F9B\u517C\u5BB9\u6027\u5E2E\u52A9 main.help.opt.other.version=\ --version \u8F93\u51FA\u7A0B\u5E8F\u7248\u672C -main.help.postopt=\ \u5982\u679C\u6A21\u5757\u63CF\u8FF0\u7B26 'module-info.class' \u4F4D\u4E8E\u6307\u5B9A\u76EE\u5F55\u7684\n \u6839\u76EE\u5F55\u4E2D, \u6216\u8005\u4F4D\u4E8E jar \u6863\u6848\u672C\u8EAB\u7684\u6839\u76EE\u5F55\u4E2D, \u5219\n \u8BE5\u6863\u6848\u662F\u4E00\u4E2A\u6A21\u5757\u5316 jar\u3002\u4EE5\u4E0B\u64CD\u4F5C\u53EA\u5728\u521B\u5EFA\u6A21\u5757\u5316 jar\n \u6216\u66F4\u65B0\u73B0\u6709\u7684\u975E\u6A21\u5757\u5316 jar \u65F6\u6709\u6548: '--module-version',\n '--hash-dependencies' \u548C '--modulepath'\u3002\n\n \u5982\u679C\u4E3A\u957F\u9009\u9879\u63D0\u4F9B\u4E86\u5FC5\u9700\u53C2\u6570\u6216\u53EF\u9009\u53C2\u6570, \u5219\u5B83\u4EEC\u5BF9\u4E8E\n \u4EFB\u4F55\u5BF9\u5E94\u7684\u77ED\u9009\u9879\u4E5F\u662F\u5FC5\u9700\u6216\u53EF\u9009\u7684\u3002 +main.help.postopt=\ \u5982\u679C\u6A21\u5757\u63CF\u8FF0\u7B26 'module-info.class' \u4F4D\u4E8E\u6307\u5B9A\u76EE\u5F55\u7684\n \u6839\u76EE\u5F55\u4E2D, \u6216\u8005\u4F4D\u4E8E jar \u6863\u6848\u672C\u8EAB\u7684\u6839\u76EE\u5F55\u4E2D, \u5219\n \u8BE5\u6863\u6848\u662F\u4E00\u4E2A\u6A21\u5757\u5316 jar\u3002\u4EE5\u4E0B\u64CD\u4F5C\u53EA\u5728\u521B\u5EFA\u6A21\u5757\u5316 jar\n \u6216\u66F4\u65B0\u73B0\u6709\u7684\u975E\u6A21\u5757\u5316 jar \u65F6\u6709\u6548: '--module-version',\n --hash-modules' \u548C '--modulepath'\u3002\n\n \u5982\u679C\u4E3A\u957F\u9009\u9879\u63D0\u4F9B\u4E86\u5FC5\u9700\u53C2\u6570\u6216\u53EF\u9009\u53C2\u6570, \u5219\u5B83\u4EEC\u5BF9\u4E8E\n \u4EFB\u4F55\u5BF9\u5E94\u7684\u77ED\u9009\u9879\u4E5F\u662F\u5FC5\u9700\u6216\u53EF\u9009\u7684\u3002 diff --git a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_zh_TW.properties b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_zh_TW.properties index 48d9f73385b..1501bb2d656 100644 --- a/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_zh_TW.properties +++ b/jdk/src/jdk.jartool/share/classes/sun/tools/jar/resources/jar_zh_TW.properties @@ -39,14 +39,22 @@ error.create.dir={0} : \u7121\u6CD5\u5EFA\u7ACB\u76EE\u9304 error.incorrect.length=\u8655\u7406 {0} \u6642\u9577\u5EA6\u4E0D\u6B63\u78BA error.create.tempfile=\u7121\u6CD5\u5EFA\u7ACB\u66AB\u5B58\u6A94\u6848 error.hash.dep=\u96DC\u6E4A\u6A21\u7D44 {0} \u76F8\u4F9D\u6027\uFF0C\u5728\u6A21\u7D44\u8DEF\u5F91\u4E0A\u627E\u4E0D\u5230\u6A21\u7D44 {1} -error.module.options.without.info=--module-version \u6216 --hash-dependencies \u5176\u4E2D\u4E00\u500B\u6C92\u6709 module-info.class +error.module.options.without.info=--module-version \u6216 --hash-modules \u5176\u4E2D\u4E00\u500B\u6C92\u6709 module-info.class error.unexpected.module-info=\u672A\u9810\u671F\u7684\u6A21\u7D44\u63CF\u8FF0\u5340 {0} error.module.descriptor.not.found=\u627E\u4E0D\u5230\u6A21\u7D44\u63CF\u8FF0\u5340 +error.versioned.info.without.root=versioned \u6BB5\u843D\u4E2D\u767C\u73FE module-info.class\uFF0C\u4F46\u662F\u6839\u4E2D\u6C92\u6709 module-info.class +error.versioned.info.name.notequal=versioned \u6BB5\u843D\u4E2D\u7684 module-info.class \u5305\u542B\u4E0D\u6B63\u78BA\u7684\u540D\u7A31 +error.versioned.info.requires.public=versioned \u6BB5\u843D\u4E2D\u7684 module-info.class \u5305\u542B\u984D\u5916\u7684\u516C\u958B\u9700\u6C42\u9805\u76EE +error.versioned.info.requires.added=versioned \u6BB5\u843D\u4E2D\u7684 module-info.class \u5305\u542B\u984D\u5916\u7684\u9700\u6C42\u9805\u76EE +error.versioned.info.requires.dropped=versioned \u6BB5\u843D\u4E2D\u7684 module-info.class \u5305\u542B\u907A\u6F0F\u7684\u9700\u6C42\u9805\u76EE +error.versioned.info.exports.notequal=versioned \u6BB5\u843D\u4E2D\u7684 module-info.class \u5305\u542B\u4E0D\u540C\u7684\u532F\u51FA\u9805\u76EE +error.versioned.info.provides.notequal=versioned \u6BB5\u843D\u4E2D\u7684 module-info.class \u5305\u542B\u4E0D\u540C\u7684\u63D0\u4F9B\u9805\u76EE +error.invalid.versioned.module.attribute=\u6A21\u7D44\u63CF\u8FF0\u5340\u5C6C\u6027 {0} \u7121\u6548 error.missing.provider=\u627E\u4E0D\u5230\u670D\u52D9\u63D0\u4F9B\u8005: {0} out.added.manifest=\u5DF2\u65B0\u589E\u8CC7\u8A0A\u6E05\u55AE -out.added.module-info=\u5DF2\u65B0\u589E module-info.class +out.added.module-info=\u5DF2\u65B0\u589E module-info: {0} out.update.manifest=\u5DF2\u66F4\u65B0\u8CC7\u8A0A\u6E05\u55AE -out.update.module-info=\u5DF2\u66F4\u65B0 module-info.class +out.update.module-info=\u5DF2\u66F4\u65B0 module-info: {0} out.ignore.entry=\u5FFD\u7565\u9805\u76EE {0} out.adding=\u65B0\u589E: {0} out.deflated=(\u58D3\u7E2E {0}%) @@ -77,7 +85,7 @@ main.help.opt.create.update.main-class=\ -e, --main-class=CLASSNAME \u96A8\u964 main.help.opt.create.update.manifest=\ -m, --manifest=FILE \u5305\u542B\u6307\u5B9A\u8CC7\u8A0A\u6E05\u55AE\u6A94\u6848\u4E2D\u7684\u8CC7\u8A0A\u6E05\u55AE\n \u8CC7\u8A0A main.help.opt.create.update.no-manifest=\ -M, --no-manifest \u4E0D\u70BA\u9805\u76EE\u5EFA\u7ACB\u8CC7\u8A0A\u6E05\u55AE\u6A94\u6848 main.help.opt.create.update.module-version=\ --module-version=VERSION \u5EFA\u7ACB\u6A21\u7D44\u5316 jar \u6216\u66F4\u65B0\u975E\u6A21\u7D44\u5316 jar \u6642\n \u4F7F\u7528\u7684\u6A21\u7D44\u7248\u672C -main.help.opt.create.update.hash-dependencies=\ --hash-dependencies=PATTERN \u5EFA\u7ACB\u6A21\u7D44\u5316 jar \u6216\u66F4\u65B0\n \u975E\u6A21\u7D44\u5316 jar \u6642\uFF0C\u904B\u7B97\u53CA\u8A18\u9304\n \u8207\u6307\u5B9A\u6A23\u5F0F\u76F8\u7B26\u7684\u6A21\u7D44\u76F8\u4F9D\u6027\n \u96DC\u6E4A +main.help.opt.create.update.hash-modules=\ --hash-modules=PATTERN \u904B\u7B97\u53CA\u8A18\u9304\u8207\u6307\u5B9A\u6A23\u5F0F\n \u76F8\u7B26\u7684\u6A21\u7D44\u96DC\u6E4A\uFF0C\u9019\u76F4\u63A5\u6216\u9593\u63A5\u5730\n \u76F8\u4F9D\u65BC\u6B63\u5728\u5EFA\u7ACB\u7684\u6A21\u7D44\u5316 jar \u6216\u6B63\u5728\n \u66F4\u65B0\u7684\u975E\u6A21\u7D44\u5316 jar main.help.opt.create.update.modulepath=\ --modulepath \u6A21\u7D44\u76F8\u4F9D\u6027\u7684\u4F4D\u7F6E\uFF0C\u7528\u65BC\u7522\u751F \ \u96DC\u6E4A main.help.opt.create.update.index=\ \u53EA\u80FD\u5728\u5EFA\u7ACB\u3001\u66F4\u65B0\u53CA\u7522\u751F\u7D22\u5F15\u6A21\u5F0F\u4E0B\u4F7F\u7528\u7684\u4F5C\u696D\u4FEE\u98FE\u689D\u4EF6:\n @@ -85,4 +93,4 @@ main.help.opt.create.update.index.no-compress=\ -0, --no-compress \u50 main.help.opt.other=\ \u5176\u4ED6\u9078\u9805:\n main.help.opt.other.help=\ -?, --help[:compat] \u63D0\u4F9B\u6B64\u8AAA\u660E\u6216\u9078\u64C7\u6027\u986F\u793A\u76F8\u5BB9\u6027\u8AAA\u660E main.help.opt.other.version=\ --version \u5217\u5370\u7A0B\u5F0F\u7248\u672C -main.help.postopt=\ \u5982\u679C\u6A21\u7D44\u63CF\u8FF0\u5340 ('module-info.class') \u4F4D\u65BC\u6307\u5B9A\u76EE\u9304\u7684\u6839\n \u6216 jar \u5B58\u6A94\u672C\u8EAB\u7684\u6839\uFF0C\u5247\u5B58\u6A94\u6703\u662F\n \u6A21\u7D44\u5316\u7684 jar\u3002\u4E0B\u5217\u4F5C\u696D\u53EA\u80FD\u5728\u5EFA\u7ACB\u6A21\u7D44\u5316 jar \u6216\u66F4\u65B0\n \u73FE\u6709\u975E\u6A21\u7D44\u5316 jar \u6642\u9032\u884C: '--module-version'\u3001\n '--hash-dependencies' \u548C '--modulepath'\u3002\n\n \u9577\u9078\u9805\u7684\u5F37\u5236\u6027\u6216\u9078\u64C7\u6027\u5F15\u6578\u4E5F\u6703\u662F\u4EFB\u4F55\u5C0D\u61C9\u77ED\u9078\u9805\u7684\n \u5F37\u5236\u6027\u6216\u9078\u64C7\u6027\u5F15\u6578\u3002 +main.help.postopt=\ \u5982\u679C\u6A21\u7D44\u63CF\u8FF0\u5340 ('module-info.class') \u4F4D\u65BC\u6307\u5B9A\u76EE\u9304\u7684\u6839\n \u6216 jar \u5B58\u6A94\u672C\u8EAB\u7684\u6839\uFF0C\u5247\u5B58\u6A94\u6703\u662F\n \u6A21\u7D44\u5316\u7684 jar\u3002\u4E0B\u5217\u4F5C\u696D\u53EA\u80FD\u5728\u5EFA\u7ACB\u6A21\u7D44\u5316 jar \u6216\u66F4\u65B0\n \u73FE\u6709\u975E\u6A21\u7D44\u5316 jar \u6642\u9032\u884C: '--module-version'\u3001\n '--hash-modules' \u548C '--modulepath'\u3002\n\n \u9577\u9078\u9805\u7684\u5F37\u5236\u6027\u6216\u9078\u64C7\u6027\u5F15\u6578\u4E5F\u6703\u662F\u4EFB\u4F55\u5C0D\u61C9\u77ED\u9078\u9805\u7684\n \u5F37\u5236\u6027\u6216\u9078\u64C7\u6027\u5F15\u6578\u3002 diff --git a/jdk/src/jdk.jdwp.agent/share/native/libjdwp/debugInit.c b/jdk/src/jdk.jdwp.agent/share/native/libjdwp/debugInit.c index c8944a49939..44596d6ee3e 100644 --- a/jdk/src/jdk.jdwp.agent/share/native/libjdwp/debugInit.c +++ b/jdk/src/jdk.jdwp.agent/share/native/libjdwp/debugInit.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -870,8 +870,9 @@ printUsage(void) "onuncaught=y|n debug on any uncaught? n\n" "timeout= for listen/attach in milliseconds n\n" "mutf8=y|n output modified utf-8 n\n" - "quiet=y|n control over terminal messages n\n" - "\n" + "quiet=y|n control over terminal messages n\n")); + + TTY_MESSAGE(( "Obsolete Options\n" "----------------\n" "strict=y|n\n" @@ -914,7 +915,9 @@ printUsage(void) " locations = 0x020\n" " callbacks = 0x040\n" " errors = 0x080\n" - " everything = 0xfff\n" + " everything = 0xfff")); + + TTY_MESSAGE(( "debugflags=flags debug flags (bitmask) none\n" " USE_ITERATE_THROUGH_HEAP 0x01\n" "\n" diff --git a/jdk/src/jdk.jdwp.agent/share/native/libjdwp/error_messages.c b/jdk/src/jdk.jdwp.agent/share/native/libjdwp/error_messages.c index 9c2fdd72927..d6a08c12961 100644 --- a/jdk/src/jdk.jdwp.agent/share/native/libjdwp/error_messages.c +++ b/jdk/src/jdk.jdwp.agent/share/native/libjdwp/error_messages.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -50,8 +50,12 @@ #include "utf_util.h" #include "proc_md.h" -/* Maximim length of a message */ -#define MAX_MESSAGE_LEN MAXPATHLEN*2+512 +/* Maximum number of bytes in a message, including the trailing zero. + * Do not print very long messages as they could be truncated. + * Use at most one pathname per message. NOTE, we use MAXPATHLEN*2 + * in case each character in the pathname takes 2 bytes. + */ +#define MAX_MESSAGE_BUF MAXPATHLEN*2+512 /* Print message in platform encoding (assume all input is UTF-8 safe) * NOTE: This function is at the lowest level of the call tree. @@ -61,17 +65,16 @@ static void vprint_message(FILE *fp, const char *prefix, const char *suffix, const char *format, va_list ap) { - jbyte utf8buf[MAX_MESSAGE_LEN+1]; + jbyte utf8buf[MAX_MESSAGE_BUF]; int len; - char pbuf[MAX_MESSAGE_LEN+1]; + char pbuf[MAX_MESSAGE_BUF]; /* Fill buffer with single UTF-8 string */ - (void)vsnprintf((char*)utf8buf, MAX_MESSAGE_LEN, format, ap); - utf8buf[MAX_MESSAGE_LEN] = 0; + (void)vsnprintf((char*)utf8buf, sizeof(utf8buf), format, ap); len = (int)strlen((char*)utf8buf); /* Convert to platform encoding (ignore errors, dangerous area) */ - (void)utf8ToPlatform(utf8buf, len, pbuf, MAX_MESSAGE_LEN); + (void)utf8ToPlatform(utf8buf, len, pbuf, (int)sizeof(pbuf)); (void)fprintf(fp, "%s%s%s", prefix, pbuf, suffix); } diff --git a/jdk/src/jdk.jdwp.agent/share/native/libjdwp/transport.c b/jdk/src/jdk.jdwp.agent/share/native/libjdwp/transport.c index e9b83f200f4..1587393a509 100644 --- a/jdk/src/jdk.jdwp.agent/share/native/libjdwp/transport.c +++ b/jdk/src/jdk.jdwp.agent/share/native/libjdwp/transport.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -67,8 +67,7 @@ printLastError(jdwpTransportEnv *t, jdwpTransportError err) maxlen = len+len/2+2; /* Should allow for plenty of room */ utf8msg = (jbyte*)jvmtiAllocate(maxlen+1); if (utf8msg != NULL) { - (void)utf8FromPlatform(msg, len, utf8msg, maxlen); - utf8msg[maxlen] = 0; + (void)utf8FromPlatform(msg, len, utf8msg, maxlen+1); } } if (rv == JDWPTRANSPORT_ERROR_NONE) { diff --git a/jdk/src/jdk.jdwp.agent/share/native/libjdwp/utf_util.c b/jdk/src/jdk.jdwp.agent/share/native/libjdwp/utf_util.c index 38793dfd95a..3fb38893e7d 100644 --- a/jdk/src/jdk.jdwp.agent/share/native/libjdwp/utf_util.c +++ b/jdk/src/jdk.jdwp.agent/share/native/libjdwp/utf_util.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -350,16 +350,20 @@ static WCHAR* getWideString(UINT codePage, char* str, int len, int *pwlen) { /* * Convert UTF-8 to a platform string + * NOTE: outputBufSize includes the space for the trailing 0. */ -int JNICALL utf8ToPlatform(jbyte *utf8, int len, char* output, int outputMaxLen) { +int JNICALL utf8ToPlatform(jbyte *utf8, int len, char* output, int outputBufSize) { int wlen; int plen; WCHAR* wstr; UINT codepage; + int outputMaxLen; UTF_ASSERT(utf8); UTF_ASSERT(output); - UTF_ASSERT(outputMaxLen > len); + UTF_ASSERT(len >= 0); + UTF_ASSERT(outputBufSize > len); + outputMaxLen = outputBufSize - 1; // leave space for trailing 0 /* Zero length is ok, but we don't need to do much */ if ( len == 0 ) { @@ -394,16 +398,20 @@ just_copy_bytes: /* * Convert Platform Encoding to UTF-8. + * NOTE: outputBufSize includes the space for the trailing 0. */ -int JNICALL utf8FromPlatform(char *str, int len, jbyte *output, int outputMaxLen) { +int JNICALL utf8FromPlatform(char *str, int len, jbyte *output, int outputBufSize) { int wlen; int plen; WCHAR* wstr; UINT codepage; + int outputMaxLen; UTF_ASSERT(str); UTF_ASSERT(output); - UTF_ASSERT(outputMaxLen > len); + UTF_ASSERT(len >= 0); + UTF_ASSERT(outputBufSize > len); + outputMaxLen = outputBufSize - 1; // leave space for trailing 0 /* Zero length is ok, but we don't need to do much */ if ( len == 0 ) { @@ -449,18 +457,21 @@ typedef enum {TO_UTF8, FROM_UTF8} conv_direction; /* * Do iconv() conversion. * Returns length or -1 if output overflows. + * NOTE: outputBufSize includes the space for the trailing 0. */ -static int iconvConvert(conv_direction drn, char *bytes, size_t len, char *output, size_t outputMaxLen) { +static int iconvConvert(conv_direction drn, char *bytes, size_t len, char *output, size_t outputBufSize) { static char *codeset = 0; iconv_t func; size_t bytes_converted; size_t inLeft, outLeft; char *inbuf, *outbuf; + int outputMaxLen; UTF_ASSERT(bytes); UTF_ASSERT(output); - UTF_ASSERT(outputMaxLen > len); + UTF_ASSERT(outputBufSize > len); + outputMaxLen = outputBufSize - 1; // leave space for trailing 0 /* Zero length is ok, but we don't need to do much */ if ( len == 0 ) { @@ -524,17 +535,19 @@ just_copy_bytes: /* * Convert UTF-8 to Platform Encoding. * Returns length or -1 if output overflows. + * NOTE: outputBufSize includes the space for the trailing 0. */ -int JNICALL utf8ToPlatform(jbyte *utf8, int len, char *output, int outputMaxLen) { - return iconvConvert(FROM_UTF8, (char*)utf8, len, output, outputMaxLen); +int JNICALL utf8ToPlatform(jbyte *utf8, int len, char *output, int outputBufSize) { + return iconvConvert(FROM_UTF8, (char*)utf8, len, output, outputBufSize); } /* * Convert Platform Encoding to UTF-8. * Returns length or -1 if output overflows. + * NOTE: outputBufSize includes the space for the trailing 0. */ -int JNICALL utf8FromPlatform(char *str, int len, jbyte *output, int outputMaxLen) { - return iconvConvert(TO_UTF8, str, len, (char*) output, outputMaxLen); +int JNICALL utf8FromPlatform(char *str, int len, jbyte *output, int outputBufSize) { + return iconvConvert(TO_UTF8, str, len, (char*) output, outputBufSize); } #endif diff --git a/jdk/src/jdk.jdwp.agent/share/native/libjdwp/utf_util.h b/jdk/src/jdk.jdwp.agent/share/native/libjdwp/utf_util.h index 0892150adc7..ca87e87eae4 100644 --- a/jdk/src/jdk.jdwp.agent/share/native/libjdwp/utf_util.h +++ b/jdk/src/jdk.jdwp.agent/share/native/libjdwp/utf_util.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -34,7 +34,7 @@ void JNICALL utf8sToUtf8m(jbyte *string, int length, jbyte *newString, int newLe int JNICALL utf8mToUtf8sLength(jbyte *string, int length); void JNICALL utf8mToUtf8s(jbyte *string, int length, jbyte *newString, int newLength); -int JNICALL utf8ToPlatform(jbyte *utf8, int len, char* output, int outputMaxLen); -int JNICALL utf8FromPlatform(char *str, int len, jbyte *output, int outputMaxLen); +int JNICALL utf8ToPlatform(jbyte *utf8, int len, char* output, int outputBufSize); +int JNICALL utf8FromPlatform(char *str, int len, jbyte *output, int outputBufSize); #endif diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginConfiguration.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginConfiguration.java index 37064ec13d8..11f400f477e 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginConfiguration.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/ImagePluginConfiguration.java @@ -93,8 +93,7 @@ public final class ImagePluginConfiguration { List orderedPlugins = new ArrayList<>(); plugins.entrySet().stream().forEach((entry) -> { - // Sort according to plugin constraints - orderedPlugins.addAll(PluginOrderingGraph.sort(entry.getValue())); + orderedPlugins.addAll(entry.getValue()); }); Plugin lastSorter = null; for (Plugin plugin : orderedPlugins) { diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/PluginOrderingGraph.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/PluginOrderingGraph.java deleted file mode 100644 index 6a8c0124b17..00000000000 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/PluginOrderingGraph.java +++ /dev/null @@ -1,150 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.tools.jlink.internal; - -import java.util.ArrayList; -import java.util.HashMap; -import java.util.HashSet; -import java.util.LinkedHashMap; -import java.util.LinkedHashSet; -import java.util.List; -import java.util.Map; -import java.util.Set; -import jdk.tools.jlink.plugin.Plugin; -import jdk.tools.jlink.plugin.PluginException; - -public class PluginOrderingGraph { - - static class Node { - - Plugin plugin; - Set nexts = new HashSet<>(); - Set previous = new HashSet<>(); - - @Override - public String toString() { - return plugin.getName(); - } - } - - public static List sort(List plugs) { - List plugins = new ArrayList<>(); - plugins.addAll(plugs); - - // for each plugin creates its graph. - Map graphs = buildGraphs(plugins); - - // At this points all individual graphs are connected - // Check for cycles. - for (Node n : graphs.values()) { - checkCycle(n); - } - - List orderedPlugins = new ArrayList<>(); - // Retrieve the current roots, add them to the result, remove them from - while (!plugins.isEmpty()) { - // Build the current set of graphs from the list of input plugins - Map currentGraphs = buildGraphs(plugins); - // Retrieve the root nodes (no previous) - List roots = getRoots(currentGraphs); - for (Node n : roots) { - // add them to the ordered list. - orderedPlugins.add(n.plugin); - // remove them from the input list. - plugins.remove(n.plugin); - } - } - return orderedPlugins; - } - - // Create a grapth according to list of plugins. - private static Map buildGraphs(List plugins) { - Map nodeStore = new HashMap<>(); - for (Plugin p : plugins) { - Node newNode = new Node(); - newNode.plugin = p; - nodeStore.put(p.getName(), newNode); - } - // for each plugin creates its graph. - Map graphs = new LinkedHashMap<>(); - for (Plugin p : plugins) { - Node node = nodeStore.get(p.getName()); - for (String after : p.isAfter()) { - Node previous = nodeStore.get(after); - if (previous == null) { - continue; - } - node.previous.add(previous); - previous.nexts.add(node); - } - for (String before : p.isBefore()) { - Node next = nodeStore.get(before); - if (next == null) { - continue; - } - node.nexts.add(next); - next.previous.add(node); - } - graphs.put(p, node); - - } - return graphs; - } - - private static List getRoots(Map graphs) { - List ret = new ArrayList<>(); - for (Node n : graphs.values()) { - if (n.previous.isEmpty()) { - ret.add(n); - } - } - return ret; - } - - private static void checkCycle(Node root) { - for (Node next : root.nexts) { - Set path = new LinkedHashSet<>(); - path.add(root); - checkCycle(next, root, path); - } - } - - private static void checkCycle(Node current, Node root, Set path) { - path.add(current); - if (current == root) { - StringBuilder builder = new StringBuilder(); - for (Node p : path) { - builder.append(p.plugin.getName()).append(">"); - } - builder.append(root); - throw new PluginException("Cycle detected for " + builder.toString() - + ". Please fix Plugin ordering (before, after constraints)."); - } - - for (Node n : current.nexts) { - checkCycle(n, root, path); - } - } -} diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ClassForNamePlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ClassForNamePlugin.java new file mode 100644 index 00000000000..7f126e4f203 --- /dev/null +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/ClassForNamePlugin.java @@ -0,0 +1,188 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +package jdk.tools.jlink.internal.plugins; + +import java.util.Iterator; +import java.util.List; +import java.util.Map; +import java.util.Objects; +import java.util.stream.Collectors; +import jdk.tools.jlink.plugin.ModulePool; +import jdk.tools.jlink.plugin.Plugin.Category; +import jdk.internal.org.objectweb.asm.ClassReader; +import static jdk.internal.org.objectweb.asm.ClassReader.*; +import jdk.internal.org.objectweb.asm.ClassWriter; +import jdk.internal.org.objectweb.asm.Opcodes; +import jdk.internal.org.objectweb.asm.Type; +import jdk.internal.org.objectweb.asm.tree.AbstractInsnNode; +import jdk.internal.org.objectweb.asm.tree.ClassNode; +import jdk.internal.org.objectweb.asm.tree.InsnList; +import jdk.internal.org.objectweb.asm.tree.LabelNode; +import jdk.internal.org.objectweb.asm.tree.LdcInsnNode; +import jdk.internal.org.objectweb.asm.tree.LineNumberNode; +import jdk.internal.org.objectweb.asm.tree.MethodInsnNode; +import jdk.internal.org.objectweb.asm.tree.MethodNode; +import jdk.tools.jlink.plugin.ModuleEntry; +import jdk.tools.jlink.plugin.Plugin; + +public final class ClassForNamePlugin implements Plugin { + public static final String NAME = "class-for-name"; + + private static String binaryClassName(String path) { + return path.substring(path.indexOf('/', 1) + 1, + path.length() - ".class".length()); + } + + private static int getAccess(ModuleEntry resource) { + ClassReader cr = new ClassReader(resource.getBytes()); + + return cr.getAccess(); + } + + private static String getPackage(String binaryName) { + int index = binaryName.lastIndexOf("/"); + + return index == -1 ? "" : binaryName.substring(0, index); + } + + private ModuleEntry transform(ModuleEntry resource, Map classes) { + byte[] inBytes = resource.getBytes(); + ClassReader cr = new ClassReader(inBytes); + ClassNode cn = new ClassNode(); + cr.accept(cn, EXPAND_FRAMES); + List ms = cn.methods; + boolean modified = false; + LdcInsnNode ldc = null; + + String thisPackage = getPackage(binaryClassName(resource.getPath())); + + for (MethodNode mn : ms) { + InsnList il = mn.instructions; + Iterator it = il.iterator(); + + while (it.hasNext()) { + AbstractInsnNode insn = it.next(); + + if (insn instanceof LdcInsnNode) { + ldc = (LdcInsnNode)insn; + } else if (insn instanceof MethodInsnNode && ldc != null) { + MethodInsnNode min = (MethodInsnNode)insn; + + if (min.getOpcode() == Opcodes.INVOKESTATIC && + min.name.equals("forName") && + min.owner.equals("java/lang/Class") && + min.desc.equals("(Ljava/lang/String;)Ljava/lang/Class;")) { + String ldcClassName = ldc.cst.toString(); + String thatClassName = ldcClassName.replaceAll("\\.", "/"); + ModuleEntry thatClass = classes.get(thatClassName); + + if (thatClass != null) { + int thatAccess = getAccess(thatClass); + String thatPackage = getPackage(thatClassName); + + if ((thatAccess & Opcodes.ACC_PRIVATE) != Opcodes.ACC_PRIVATE && + ((thatAccess & Opcodes.ACC_PUBLIC) == Opcodes.ACC_PUBLIC || + thisPackage.equals(thatPackage))) { + Type type = Type.getObjectType(thatClassName); + il.remove(ldc); + il.set(min, new LdcInsnNode(type)); + modified = true; + } + } + } + + ldc = null; + } else if (!(insn instanceof LabelNode) && + !(insn instanceof LineNumberNode)) { + ldc = null; + } + + } + } + + if (modified) { + ClassWriter cw = new ClassWriter(cr, 0); + cn.accept(cw); + byte[] outBytes = cw.toByteArray(); + + return resource.create(outBytes); + } + + return resource; + } + + @Override + public String getName() { + return NAME; + } + + @Override + public void visit(ModulePool in, ModulePool out) { + Objects.requireNonNull(in); + Objects.requireNonNull(out); + Map classes = in.entries() + .filter(resource -> resource != null && + resource.getPath().endsWith(".class") && + !resource.getPath().endsWith("/module-info.class")) + .collect(Collectors.toMap(resource -> binaryClassName(resource.getPath()), + resource -> resource)); + in.entries() + .filter(resource -> resource != null) + .forEach(resource -> { + String path = resource.getPath(); + + if (path.endsWith(".class") && !path.endsWith("/module-info.class")) { + out.add(transform(resource, classes)); + } else { + out.add(resource); + } + }); + } + + @Override + public Category getType() { + return Category.TRANSFORMER; + } + + @Override + public boolean hasArguments() { + return false; + } + + @Override + public String getDescription() { + return PluginsResourceBundle.getDescription(NAME); + } + + @Override + public String getArgumentsDescription() { + return PluginsResourceBundle.getArgument(NAME); + } + + @Override + public void configure(Map config) { + + } +} diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OptimizationPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OptimizationPlugin.java deleted file mode 100644 index d522fa0c7e5..00000000000 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/OptimizationPlugin.java +++ /dev/null @@ -1,285 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.tools.jlink.internal.plugins; - -import java.io.FileOutputStream; -import java.io.IOException; -import java.io.OutputStream; -import java.io.UncheckedIOException; -import java.nio.charset.StandardCharsets; -import java.util.ArrayList; -import java.util.List; -import java.util.Map; -import java.util.Objects; -import java.util.Set; -import java.util.function.Consumer; -import jdk.internal.org.objectweb.asm.ClassReader; -import jdk.internal.org.objectweb.asm.ClassWriter; -import jdk.internal.org.objectweb.asm.Opcodes; -import jdk.tools.jlink.internal.plugins.asm.AsmPools; -import jdk.tools.jlink.internal.plugins.asm.AsmPlugin; -import jdk.internal.org.objectweb.asm.tree.ClassNode; -import jdk.internal.org.objectweb.asm.tree.MethodNode; -import jdk.internal.org.objectweb.asm.util.CheckClassAdapter; -import jdk.tools.jlink.internal.plugins.asm.AsmModulePool; -import jdk.tools.jlink.internal.plugins.optim.ForNameFolding; -import jdk.tools.jlink.internal.plugins.optim.ReflectionOptimizer.TypeResolver; -import jdk.tools.jlink.plugin.PluginException; - -/** - * - * Optimize Classes following various strategies. Strategies are implementation - * of ClassOptimizer and MethodOptimizer. - */ -public final class OptimizationPlugin extends AsmPlugin { - - public static final String NAME = "class-optim"; - public static final String LOG = "log"; - public static final String ALL = "all"; - public static final String FORNAME_REMOVAL = "forName-folding"; - - /** - * Default resolver. A resolver that retrieve types that are in an - * accessible package, are public or are located in the same package as the - * caller. - */ - private static final class DefaultTypeResolver implements TypeResolver { - - private final Set packages; - private final AsmPools pools; - - DefaultTypeResolver(AsmPools pools, AsmModulePool modulePool) { - Objects.requireNonNull(pools); - Objects.requireNonNull(modulePool); - this.pools = pools; - packages = pools.getGlobalPool().getAccessiblePackages(modulePool.getModuleName()); - } - - @Override - public ClassReader resolve(ClassNode cn, MethodNode mn, String type) { - int classIndex = cn.name.lastIndexOf("/"); - String callerPkg = classIndex == -1 ? "" - : cn.name.substring(0, classIndex); - int typeClassIndex = type.lastIndexOf("/"); - String pkg = typeClassIndex == - 1 ? "" - : type.substring(0, typeClassIndex); - ClassReader reader = null; - if (packages.contains(pkg) || pkg.equals(callerPkg)) { - ClassReader r = pools.getGlobalPool().getClassReader(type); - if (r != null) { - // if not private - if ((r.getAccess() & Opcodes.ACC_PRIVATE) - != Opcodes.ACC_PRIVATE) { - // public - if (((r.getAccess() & Opcodes.ACC_PUBLIC) - == Opcodes.ACC_PUBLIC)) { - reader = r; - } else if (pkg.equals(callerPkg)) { - reader = r; - } - } - } - } - return reader; - } - } - - public interface Optimizer { - - void close() throws IOException; - } - - public interface ClassOptimizer extends Optimizer { - - boolean optimize(Consumer logger, AsmPools pools, - AsmModulePool modulePool, - ClassNode cn) throws Exception; - } - - public interface MethodOptimizer extends Optimizer { - - boolean optimize(Consumer logger, AsmPools pools, - AsmModulePool modulePool, - ClassNode cn, MethodNode m, TypeResolver resolver) throws Exception; - } - - private List optimizers = new ArrayList<>(); - - private OutputStream stream; - private int numMethods; - - private void log(String content) { - if (stream != null) { - try { - content = content + "\n"; - stream.write(content.getBytes(StandardCharsets.UTF_8)); - } catch (IOException ex) { - System.err.println(ex); - } - } - } - - private void close() throws IOException { - log("Num analyzed methods " + numMethods); - - for (Optimizer optimizer : optimizers) { - try { - optimizer.close(); - } catch (IOException ex) { - System.err.println("Error closing optimizer " + ex); - } - } - if (stream != null) { - stream.close(); - } - } - - @Override - public String getName() { - return NAME; - } - - @Override - public void visit(AsmPools pools) { - try { - for (AsmModulePool p : pools.getModulePools()) { - DefaultTypeResolver resolver = new DefaultTypeResolver(pools, p); - p.visitClassReaders((reader) -> { - ClassWriter w = null; - try { - w = optimize(pools, p, reader, resolver); - } catch (IOException ex) { - throw new PluginException("Problem optimizing " - + reader.getClassName(), ex); - } - return w; - }); - } - } finally { - try { - close(); - } catch (IOException ex) { - throw new UncheckedIOException(ex); - } - } - } - - private ClassWriter optimize(AsmPools pools, AsmModulePool modulePool, - ClassReader reader, TypeResolver resolver) - throws IOException { - ClassNode cn = new ClassNode(); - ClassWriter writer = null; - if ((reader.getAccess() & Opcodes.ACC_INTERFACE) == 0) { - reader.accept(cn, ClassReader.EXPAND_FRAMES); - boolean optimized = false; - for (Optimizer optimizer : optimizers) { - if (optimizer instanceof ClassOptimizer) { - try { - boolean optim = ((ClassOptimizer) optimizer). - optimize(this::log, pools, modulePool, cn); - if (optim) { - optimized = true; - } - } catch (Throwable ex) { - throw new PluginException("Exception optimizing " - + reader.getClassName(), ex); - } - } else { - MethodOptimizer moptimizer = (MethodOptimizer) optimizer; - for (MethodNode m : cn.methods) { - if ((m.access & Opcodes.ACC_ABSTRACT) == 0 - && (m.access & Opcodes.ACC_NATIVE) == 0) { - numMethods += 1; - try { - boolean optim = moptimizer. - optimize(this::log, pools, modulePool, cn, - m, resolver); - if (optim) { - optimized = true; - } - } catch (Throwable ex) { - throw new PluginException("Exception optimizing " - + reader.getClassName() + "." + m.name, ex); - } - - } - } - } - } - - if (optimized) { - writer = new ClassWriter(ClassWriter.COMPUTE_MAXS); - try { - // add a validation layer in between to check for class vallidity - CheckClassAdapter ca = new CheckClassAdapter(writer); - cn.accept(ca); - } catch (Exception ex) { - throw new PluginException("Exception optimizing class " + cn.name, ex); - } - } - } - return writer; - } - - @Override - public String getDescription() { - return PluginsResourceBundle.getDescription(NAME); - } - - @Override - public boolean hasArguments() { - return true; - } - - @Override - public String getArgumentsDescription() { - return PluginsResourceBundle.getArgument(NAME); - } - - @Override - public void configure(Map config) { - String strategies = config.get(NAME); - String[] arr = strategies.split(","); - for (String s : arr) { - if (s.equals(ALL)) { - optimizers.clear(); - optimizers.add(new ForNameFolding()); - break; - } else if (s.equals(FORNAME_REMOVAL)) { - optimizers.add(new ForNameFolding()); - } else { - throw new IllegalArgumentException("Unknown optimization: " + s); - } - } - String f = config.get(LOG); - if (f != null) { - try { - stream = new FileOutputStream(f); - } catch (IOException ex) { - throw new UncheckedIOException(ex); - } - } - } -} diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmModulePool.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmModulePool.java deleted file mode 100644 index ddd20b59d39..00000000000 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmModulePool.java +++ /dev/null @@ -1,90 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.tools.jlink.internal.plugins.asm; - -import java.lang.module.ModuleDescriptor; -import java.util.Set; -import jdk.internal.org.objectweb.asm.ClassReader; - -/** - * A pool for a given module - */ -public interface AsmModulePool extends AsmPool { - - /** - * Associate a package to this module, useful when adding new classes in new - * packages. WARNING: In order to properly handle new package and/or new - * module, module-info class must be added and/or updated. - * - * @param pkg The new package, following java binary syntax (/-separated - * path name). - * @throws jdk.tools.jlink.plugins.PluginException If a mapping already - * exist for this package. - */ - public void addPackage(String pkg); - - /** - * The module name of this pool. - * @return The module name; - */ - public String getModuleName(); - - /** - * Lookup the class in this pool and the required pools. NB: static module - * readability can be different at execution time. - * - * @param binaryName The class to lookup. - * @return The reader or null if not found - * @throws jdk.tools.jlink.plugins.PluginException - */ - public ClassReader getClassReaderInDependencies(String binaryName); - - /** - * Lookup the class in the exported packages of this module. "public - * requires" modules are looked up. NB: static module readability can be - * different at execution time. - * - * @param callerModule Name of calling module. - * @param binaryName The class to lookup. - * @return The reader or null if not found - * @throws jdk.tools.jlink.plugins.PluginException - */ - public ClassReader getExportedClassReader(String callerModule, - String binaryName); - - /** - * The module descriptor. - * - * @return The module descriptor; - */ - public ModuleDescriptor getDescriptor(); - - /** - * Retrieve the internal and exported packages. - * - * @return - */ - public Set getAllPackages(); -} diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPlugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPlugin.java deleted file mode 100644 index d99ec7bfcb5..00000000000 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPlugin.java +++ /dev/null @@ -1,68 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.tools.jlink.internal.plugins.asm; - -import java.util.Objects; -import jdk.tools.jlink.plugin.Plugin; -import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.plugin.ModulePool; -import jdk.tools.jlink.internal.ModulePoolImpl; - -/** - * Extend this class to develop your own plugin in order to transform jimage - * resources. - * - */ -public abstract class AsmPlugin implements Plugin { - - public AsmPlugin() { - } - - @Override - public void visit(ModulePool allContent, ModulePool outResources) { - Objects.requireNonNull(allContent); - Objects.requireNonNull(outResources); - ModulePoolImpl resources = new ModulePoolImpl(allContent.getByteOrder()); - allContent.entries().forEach(md -> { - if(md.getType().equals(ModuleEntry.Type.CLASS_OR_RESOURCE)) { - resources.add(md); - } else { - outResources.add(md); - } - }); - AsmPools pools = new AsmPools(resources); - visit(pools); - pools.fillOutputResources(outResources); - } - - /** - * This is the method to implement in order to - * apply Asm transformation to jimage contained classes. - * @param pools The pool of Asm classes and other resource files. - * @param strings To add a string to the jimage strings table. - * @throws jdk.tools.jlink.plugin.PluginException - */ - public abstract void visit(AsmPools pools); -} diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPool.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPool.java deleted file mode 100644 index aa5c1cb5ef5..00000000000 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPool.java +++ /dev/null @@ -1,314 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.tools.jlink.internal.plugins.asm; - -import java.util.Collection; -import java.util.List; -import jdk.internal.org.objectweb.asm.ClassReader; -import jdk.internal.org.objectweb.asm.ClassWriter; -import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.plugin.ModulePool; - -/** - * A pool of ClassReader and other resource files. - * This class allows to transform and sort classes and resource files. - *

      - * Classes in the class pool are named following java binary name specification. - * For example, java.lang.Object class is named java/lang/Object - *

      - * Module information has been stripped out from class and other resource files - * (.properties, binary files, ...).

      - */ -public interface AsmPool { - - /** - * A resource that is not a class file. - *

      - * The path of a resource is a /-separated path name that identifies the - * resource. For example com.foo.bar.Bundle.properties resource name is - * com/foo/bar/Bundle.properties

      - *

      - */ - public class ResourceFile { - - private final String path; - private final byte[] content; - - public ResourceFile(String path, byte[] content) { - this.path = path; - this.content = content; - } - - public String getPath() { - return path; - } - - public byte[] getContent() { - return content; - } - } - - /** - * To visit each Class contained in the pool - */ - public interface ClassReaderVisitor { - - /** - * Called for each ClassReader located in the pool. - * - * @param reader A class reader. - * @return A writer or null if the class has not been transformed. - */ - public ClassWriter visit(ClassReader reader); - } - - /** - * To visit each Resource contained in the pool - */ - public interface ResourceFileVisitor { - - /** - * Called for each Resource file located in the pool. - * - * @param reader A resource file. - * @return A resource file or null if the resource has not been - * transformed. - */ - public ResourceFile visit(ResourceFile reader); - } - - /** - * Contains the transformed classes. When the jimage file is generated, - * transformed classes take precedence on unmodified ones. - */ - public interface WritableClassPool { - - /** - * Add a class to the pool, if a class already exists, it is replaced. - * - * @param writer The class writer. - * @throws jdk.tools.jlink.plugin.PluginException - */ - public void addClass(ClassWriter writer); - - /** - * The class will be not added to the jimage file. - * - * @param className The class name to forget. - * @throws jdk.tools.jlink.plugin.PluginException - */ - public void forgetClass(String className); - - /** - * Get a transformed class. - * - * @param binaryName The java class binary name - * @return The ClassReader or null if the class is not found. - * @throws jdk.tools.jlink.plugin.PluginException - */ - public ClassReader getClassReader(String binaryName); - - /** - * Get a transformed class. - * - * @param res A class resource. - * @return The ClassReader or null if the class is not found. - * @throws jdk.tools.jlink.plugin.PluginException - */ - public ClassReader getClassReader(ModuleEntry res); - - /** - * Returns all the classes contained in the writable pool. - * - * @return The collection of classes. - */ - public Collection getClasses(); - } - - /** - * Contains the transformed resources. When the jimage file is generated, - * transformed resources take precedence on unmodified ones. - */ - public interface WritableResourcePool { - - /** - * Add a resource, if the resource exists, it is replaced. - * - * @param resFile The resource file to add. - * @throws jdk.tools.jlink.plugin.PluginException - */ - public void addResourceFile(ResourceFile resFile); - - /** - * The resource will be not added to the jimage file. - * - * @param resourceName - * @throws jdk.tools.jlink.plugin.PluginException If the resource to - * forget doesn't exist or is null. - */ - public void forgetResourceFile(String resourceName); - - /** - * Get a transformed resource. - * - * @param name The java resource name - * @return The Resource or null if the resource is not found. - */ - public ResourceFile getResourceFile(String name); - - /** - * Get a transformed resource. - * - * @param res The java resource - * @return The Resource or null if the resource is not found. - */ - public ResourceFile getResourceFile(ModuleEntry res); - - /** - * Returns all the resources contained in the writable pool. - * - * @return The array of resources. - */ - public Collection getResourceFiles(); - } - - /** - * To order the classes and resources within a jimage file. - */ - public interface Sorter { - - /** - * @param resources The resources will be added to the jimage following - * the order of this ResourcePool. - * @return The resource paths ordered in the way to use for storage in the jimage. - * @throws jdk.tools.jlink.plugin.PluginException - */ - public List sort(ModulePool resources); - } - - /** - * The writable pool used to store transformed resources. - * - * @return The writable pool. - */ - public WritableClassPool getTransformedClasses(); - - /** - * The writable pool used to store transformed resource files. - * - * @return The writable pool. - */ - public WritableResourcePool getTransformedResourceFiles(); - - /** - * Set a sorter instance to sort all files. If no sorter is set, then input - * Resources will be added in the order they have been received followed by - * newly added resources. - * - * @param sorter - */ - public void setSorter(Sorter sorter); - - /** - * Returns the classes contained in the pool. - * - * @return The classes. - */ - public Collection getClasses(); - - /** - * Returns the resources contained in the pool. Resources are all the file - * that are not classes (eg: properties file, binary files, ...) - * - * @return The array of resource files. - */ - public Collection getResourceFiles(); - - /** - * Retrieves a resource based on the binary name. This name doesn't contain - * the module name. - * NB: When dealing with resources that have the same name in various - * modules (eg: META-INFO/*), you should use the ResourcePool - * referenced from this AsmClassPool. - * - * @param binaryName Name of a Java resource or null if the resource doesn't - * exist. - * @return - */ - public ResourceFile getResourceFile(String binaryName); - - /** - * Retrieves a resource for the passed resource. - * - * @param res The resource - * @return The resource file or null if it doesn't exist. - */ - public ResourceFile getResourceFile(ModuleEntry res); - - /** - * Retrieve a ClassReader from the pool. - * - * @param binaryName Class binary name - * @return A reader or null if the class is unknown - * @throws jdk.tools.jlink.plugin.PluginException - */ - public ClassReader getClassReader(String binaryName); - - /** - * Retrieve a ClassReader from the pool. - * - * @param res A resource. - * @return A reader or null if the class is unknown - * @throws jdk.tools.jlink.plugin.PluginException - */ - public ClassReader getClassReader(ModuleEntry res); - - /** - * To visit the set of ClassReaders. - * - * @param visitor The visitor. - * @throws jdk.tools.jlink.plugin.PluginException - */ - public void visitClassReaders(ClassReaderVisitor visitor); - - /** - * To visit the set of ClassReaders. - * - * @param visitor The visitor. - * @throws jdk.tools.jlink.plugin.PluginException - */ - public void visitResourceFiles(ResourceFileVisitor visitor); - - /** - * Returns the pool of all the resources (transformed and unmodified). - * The input resources are replaced by the transformed ones. - * If a sorter has been set, it is used to sort the returned resources. - * - * @param output The pool used to fill the jimage. - * @throws jdk.tools.jlink.plugin.PluginException - */ - public void fillOutputResources(ModulePool output); - -} diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPoolImpl.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPoolImpl.java deleted file mode 100644 index b82eca51895..00000000000 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPoolImpl.java +++ /dev/null @@ -1,698 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.tools.jlink.internal.plugins.asm; - -import java.io.ByteArrayInputStream; -import java.io.IOException; -import java.io.UncheckedIOException; -import java.lang.module.ModuleDescriptor; -import java.lang.module.ModuleDescriptor.Requires; -import java.lang.module.ModuleDescriptor.Requires.Modifier; -import java.lang.module.ModuleDescriptor.Exports; -import java.util.ArrayList; -import java.util.Collection; -import java.util.Collections; -import java.util.HashMap; -import java.util.HashSet; -import java.util.LinkedHashMap; -import java.util.List; -import java.util.Map; -import java.util.Map.Entry; -import java.util.Objects; -import java.util.Set; -import jdk.internal.org.objectweb.asm.ClassReader; -import jdk.internal.org.objectweb.asm.ClassWriter; -import jdk.tools.jlink.internal.ImageFileCreator; -import jdk.tools.jlink.internal.ModulePoolImpl; -import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.plugin.PluginException; -import jdk.tools.jlink.plugin.ModulePool; - -/** - * A pool of ClassReader and other resource files. This class allows to - * transform and sort classes and resource files. - *

      - * Classes in the class pool are named following java binary name specification. - * For example, java.lang.Object class is named java/lang/Object - *

      - * Module information has been stripped out from class and other resource files - * (.properties, binary files, ...).

      - */ -final class AsmPoolImpl implements AsmModulePool { - - /** - * Contains the transformed classes. When the jimage file is generated, - * transformed classes take precedence on unmodified ones. - */ - public final class WritableClassPoolImpl implements WritableClassPool { - - private WritableClassPoolImpl() { - } - - /** - * Add a class to the pool, if a class already exists, it is replaced. - * - * @param writer The class writer. - * @throws java.io.IOException - */ - @Override - public void addClass(ClassWriter writer) { - Objects.requireNonNull(writer); - // Retrieve the className - ClassReader reader = newClassReader(writer.toByteArray()); - String className = reader.getClassName(); - String path; - if (className.endsWith("module-info")) { - // remove the module name contained in the class name - className = className.substring(className.indexOf("/") + 1); - path = "/" + moduleName + "/" + className; - } else { - path = toClassNamePath(className); - } - - byte[] content = writer.toByteArray(); - ModuleEntry res = ModuleEntry.create(path, content); - transformedClasses.put(className, res); - } - - /** - * The class will be not added to the jimage file. - * - * @param className The class name to forget. - */ - @Override - public void forgetClass(String className) { - Objects.requireNonNull(className); - // do we have a resource? - ModuleEntry res = transformedClasses.get(className); - if (res == null) { - res = inputClasses.get(className); - if (res == null) { - throw new PluginException("Unknown class " + className); - } - } - String path = toClassNamePath(className); - forgetResources.add(path); - // Just in case it has been added. - transformedClasses.remove(className); - } - - /** - * Get a transformed class. - * - * @param binaryName The java class binary name - * @return The ClassReader or null if the class is not found. - */ - @Override - public ClassReader getClassReader(String binaryName) { - Objects.requireNonNull(binaryName); - ModuleEntry res = transformedClasses.get(binaryName); - ClassReader reader = null; - if (res != null) { - reader = getClassReader(res); - } - return reader; - } - - /** - * Returns all the classes contained in the writable pool. - * - * @return The array of transformed classes. - */ - @Override - public Collection getClasses() { - List classes = new ArrayList<>(); - for (Entry entry : transformedClasses.entrySet()) { - classes.add(entry.getValue()); - } - return classes; - } - - @Override - public ClassReader getClassReader(ModuleEntry res) { - return newClassReader(res.getBytes()); - } - } - - /** - * Contains the transformed resources. When the jimage file is generated, - * transformed resources take precedence on unmodified ones. - */ - public final class WritableResourcePoolImpl implements WritableResourcePool { - - private WritableResourcePoolImpl() { - } - - /** - * Add a resource, if the resource exists, it is replaced. - * - * @param resFile The resource file to add. - */ - @Override - public void addResourceFile(ResourceFile resFile) { - Objects.requireNonNull(resFile); - String path = toResourceNamePath(resFile.getPath()); - ModuleEntry res = ModuleEntry.create(path, resFile.getContent()); - transformedResources.put(resFile.getPath(), res); - } - - /** - * The resource will be not added to the jimage file. - * - * @param resourceName - * @throws java.io.IOException - */ - @Override - public void forgetResourceFile(String resourceName) { - Objects.requireNonNull(resourceName); - String path = toResourceNamePath(resourceName); - // do we have a resource? - ModuleEntry res = transformedResources.get(resourceName); - if (res == null) { - res = inputResources.get(resourceName); - if (res == null) { - throw new PluginException("Unknown resource " + resourceName); - } - } - forgetResources.add(path); - // Just in case it has been added. - transformedResources.remove(resourceName); - } - - /** - * Get a transformed resource. - * - * @param name The java resource name - * @return The Resource or null if the resource is not found. - */ - @Override - public ResourceFile getResourceFile(String name) { - Objects.requireNonNull(name); - ModuleEntry res = transformedResources.get(name); - ResourceFile resFile = null; - if (res != null) { - resFile = getResourceFile(res); - } - return resFile; - } - - /** - * Returns all the resources contained in the writable pool. - * - * @return The array of transformed classes. - */ - @Override - public Collection getResourceFiles() { - List resources = new ArrayList<>(); - for (Entry entry : transformedResources.entrySet()) { - resources.add(entry.getValue()); - } - return resources; - } - - @Override - public ResourceFile getResourceFile(ModuleEntry res) { - return new ResourceFile(toJavaBinaryResourceName(res.getPath()), - res.getBytes()); - } - } - - private final ModulePool jimageResources; - private final Map inputClasses; - private final Map inputResources; - private final Map inputClassPackageMapping; - private final Map inputOtherPackageMapping; - - private final WritableClassPool transClassesPool - = new WritableClassPoolImpl(); - private final WritableResourcePool transResourcesPool - = new WritableResourcePoolImpl(); - - private Sorter sorter; - - private final Map transformedClasses - = new LinkedHashMap<>(); - private final Map transformedResources - = new LinkedHashMap<>(); - private final List forgetResources = new ArrayList<>(); - private final Map newPackageMapping = new HashMap<>(); - - private final String moduleName; - - private final ModuleDescriptor descriptor; - private final AsmPools pools; - - /** - * A new Asm pool. - * - * @param inputResources The raw resources to build the pool from. - * @param moduleName The name of a module. - * @param pools The resource pools. - * @param descriptor The module descriptor. - */ - AsmPoolImpl(ModulePool inputResources, String moduleName, - AsmPools pools, - ModuleDescriptor descriptor) { - Objects.requireNonNull(inputResources); - Objects.requireNonNull(moduleName); - Objects.requireNonNull(pools); - Objects.requireNonNull(descriptor); - this.jimageResources = inputResources; - this.moduleName = moduleName; - this.pools = pools; - this.descriptor = descriptor; - Map classes = new LinkedHashMap<>(); - Map resources = new LinkedHashMap<>(); - Map packageClassToModule = new HashMap<>(); - Map packageOtherToModule = new HashMap<>(); - inputResources.entries().forEach(res -> { - if (res.getPath().endsWith(".class")) { - classes.put(toJavaBinaryClassName(res.getPath()), res); - } else { - resources.put(toJavaBinaryResourceName(res.getPath()), res); - } - String[] split = ImageFileCreator.splitPath(res.getPath()); - if (ImageFileCreator.isClassPackage(res.getPath())) { - packageClassToModule.put(split[1], res.getModule()); - } else { - // Keep a map of other resources - // Same resource names such as META-INF/* should be handled with full path name. - if (!split[1].isEmpty()) { - packageOtherToModule.put(split[1], res.getModule()); - } - } - }); - this.inputClasses = Collections.unmodifiableMap(classes); - this.inputResources = Collections.unmodifiableMap(resources); - - this.inputClassPackageMapping = Collections.unmodifiableMap(packageClassToModule); - this.inputOtherPackageMapping = Collections.unmodifiableMap(packageOtherToModule); - } - - @Override - public String getModuleName() { - return moduleName; - } - - /** - * The writable pool used to store transformed resources. - * - * @return The writable pool. - */ - @Override - public WritableClassPool getTransformedClasses() { - return transClassesPool; - } - - /** - * The writable pool used to store transformed resource files. - * - * @return The writable pool. - */ - @Override - public WritableResourcePool getTransformedResourceFiles() { - return transResourcesPool; - } - - /** - * Set a sorter instance to sort all files. If no sorter is set, then input - * Resources will be added in the order they have been received followed by - * newly added resources. - * - * @param sorter - */ - @Override - public void setSorter(Sorter sorter) { - this.sorter = sorter; - } - - /** - * Returns the classes contained in the pool. - * - * @return The array of classes. - */ - @Override - public Collection getClasses() { - return inputClasses.values(); - } - - /** - * Returns the resources contained in the pool. Resources are all the file - * that are not classes (eg: properties file, binary files, ...) - * - * @return The array of classes. - */ - @Override - public Collection getResourceFiles() { - return inputResources.values(); - } - - /** - * Retrieves a resource based on the binary name. This name doesn't contain - * the module name. - * NB: When dealing with resources that have the same name in various - * modules (eg: META-INFO/*), you should use the ResourcePool - * referenced from this AsmClassPool. - * - * @param binaryName Name of a Java resource or null if the resource doesn't - * exist. - * @return - */ - @Override - public ResourceFile getResourceFile(String binaryName) { - Objects.requireNonNull(binaryName); - ModuleEntry res = inputResources.get(binaryName); - ResourceFile resFile = null; - if (res != null) { - resFile = getResourceFile(res); - } - return resFile; - } - - /** - * Retrieve a ClassReader from the pool. - * - * @param binaryName Class binary name - * @return A reader or null if the class is unknown - */ - @Override - public ClassReader getClassReader(String binaryName) { - Objects.requireNonNull(binaryName); - ModuleEntry res = inputClasses.get(binaryName); - ClassReader reader = null; - if (res != null) { - reader = getClassReader(res); - } - return reader; - } - - @Override - public ResourceFile getResourceFile(ModuleEntry res) { - return new ResourceFile(toJavaBinaryResourceName(res.getPath()), - res.getBytes()); - } - - @Override - public ClassReader getClassReader(ModuleEntry res) { - return newClassReader(res.getBytes()); - } - - /** - * Lookup the class in this pool and the required pools. NB: static module - * readability can be different at execution time. - * - * @param binaryName The class to lookup. - * @return The reader or null if not found - */ - @Override - public ClassReader getClassReaderInDependencies(String binaryName) { - Objects.requireNonNull(binaryName); - ClassReader reader = getClassReader(binaryName); - if (reader == null) { - for (Requires requires : descriptor.requires()) { - AsmModulePool pool = pools.getModulePool(requires.name()); - reader = pool.getExportedClassReader(moduleName, binaryName); - if (reader != null) { - break; - } - } - } - return reader; - } - - /** - * Lookup the class in the exported packages of this module. "public - * requires" modules are looked up. NB: static module readability can be - * different at execution time. - * - * @param callerModule Name of calling module. - * @param binaryName The class to lookup. - * @return The reader or null if not found - */ - @Override - public ClassReader getExportedClassReader(String callerModule, String binaryName) { - Objects.requireNonNull(callerModule); - Objects.requireNonNull(binaryName); - boolean exported = false; - ClassReader clazz = null; - for (Exports e : descriptor.exports()) { - String pkg = e.source(); - Set targets = e.targets(); - System.out.println("PKG " + pkg); - if (targets.isEmpty() || targets.contains(callerModule)) { - if (binaryName.startsWith(pkg)) { - String className = binaryName.substring(pkg.length()); - System.out.println("CLASS " + className); - exported = !className.contains("."); - } - if (exported) { - break; - } - } - } - // public requires (re-export) - if (!exported) { - for (Requires requires : descriptor.requires()) { - if (requires.modifiers().contains(Modifier.PUBLIC)) { - AsmModulePool pool = pools.getModulePool(requires.name()); - clazz = pool.getExportedClassReader(moduleName, binaryName); - if (clazz != null) { - break; - } - } - } - } else { - clazz = getClassReader(binaryName); - } - return clazz; - - } - - @Override - public ModuleDescriptor getDescriptor() { - return descriptor; - } - - /** - * To visit the set of ClassReaders. - * - * @param visitor The visitor. - */ - @Override - public void visitClassReaders(ClassReaderVisitor visitor) { - Objects.requireNonNull(visitor); - for (ModuleEntry res : getClasses()) { - ClassReader reader = newClassReader(res.getBytes()); - ClassWriter writer = visitor.visit(reader); - if (writer != null) { - - getTransformedClasses().addClass(writer); - } - } - } - - /** - * To visit the set of ClassReaders. - * - * @param visitor The visitor. - */ - @Override - public void visitResourceFiles(ResourceFileVisitor visitor) { - Objects.requireNonNull(visitor); - for (ModuleEntry resource : getResourceFiles()) { - ResourceFile resFile - = new ResourceFile(toJavaBinaryResourceName(resource.getPath()), - resource.getBytes()); - ResourceFile res = visitor.visit(resFile); - if (res != null) { - getTransformedResourceFiles().addResourceFile(res); - } - } - } - - /** - * Returns the pool of all the resources (transformed and unmodified). The - * input resources are replaced by the transformed ones. If a sorter has - * been set, it is used to sort the returned resources. * - */ - @Override - public void fillOutputResources(ModulePool outputResources) { - List added = new ArrayList<>(); - // If the sorter is null, use the input order. - // New resources are added at the end - // First input classes that have not been removed - ModulePool output = new ModulePoolImpl(outputResources.getByteOrder(), - ((ModulePoolImpl)outputResources).getStringTable()); - jimageResources.entries().forEach(inResource -> { - if (!forgetResources.contains(inResource.getPath())) { - ModuleEntry resource = inResource; - // Do we have a transformed class with the same name? - ModuleEntry res = transformedResources. - get(toJavaBinaryResourceName(inResource.getPath())); - if (res != null) { - resource = res; - } else { - res = transformedClasses. - get(toJavaBinaryClassName(inResource.getPath())); - if (res != null) { - resource = res; - } - } - output.add(resource); - added.add(resource.getPath()); - } - }); - // Then new resources - for (Map.Entry entry : transformedResources.entrySet()) { - ModuleEntry resource = entry.getValue(); - if (!forgetResources.contains(resource.getPath())) { - if (!added.contains(resource.getPath())) { - output.add(resource); - } - } - } - // And new classes - for (Map.Entry entry : transformedClasses.entrySet()) { - ModuleEntry resource = entry.getValue(); - if (!forgetResources.contains(resource.getPath())) { - if (!added.contains(resource.getPath())) { - output.add(resource); - } - } - } - - AsmPools.sort(outputResources, output, sorter); - } - - /** - * Associate a package to this module, useful when adding new classes in new - * packages. WARNING: In order to properly handle new package and/or new - * module, module-info class must be added and/or updated. - * - * @param pkg The new package, following java binary syntax (/-separated - * path name). - * @throws PluginException If a mapping already exist for this package. - */ - @Override - public void addPackage(String pkg) { - Objects.requireNonNull(pkg); - Objects.requireNonNull(moduleName); - pkg = pkg.replaceAll("/", "."); - String mod = newPackageMapping.get(pkg); - if (mod != null) { - throw new PluginException(mod + " module already contains package " + pkg); - } - newPackageMapping.put(pkg, moduleName); - } - - @Override - public Set getAllPackages() { - ModuleDescriptor desc = getDescriptor(); - Set packages = new HashSet<>(); - for (String p : desc.conceals()) { - packages.add(p.replaceAll("\\.", "/")); - } - for (String p : newPackageMapping.keySet()) { - packages.add(p.replaceAll("\\.", "/")); - } - for (Exports ex : desc.exports()) { - packages.add(ex.source().replaceAll("\\.", "/")); - } - return packages; - } - - private static ClassReader newClassReader(byte[] bytes) { - try { - ByteArrayInputStream stream = new ByteArrayInputStream(bytes); - ClassReader reader = new ClassReader(stream); - return reader; - } catch (IOException ex) { - throw new UncheckedIOException(ex); - } - } - - private static String toJavaBinaryClassName(String path) { - if (path.endsWith("module-info.class")) { - path = removeClassExtension(path); - } else { - path = removeModuleName(path); - path = removeClassExtension(path); - } - return path; - } - - private static String toJavaBinaryResourceName(String path) { - if (!path.endsWith("module-info.class")) { - path = removeModuleName(path); - } - return path; - } - - private static String removeClassExtension(String path) { - return path.substring(0, path.length() - ".class".length()); - } - - private static String removeModuleName(String path) { - path = path.substring(1); - return path.substring(path.indexOf("/") + 1, path.length()); - } - - private String toClassNamePath(String className) { - return toResourceNamePath(className) + ".class"; - } - - /** - * Entry point to manage resource<->module association. - */ - private String toResourceNamePath(String resourceName) { - if (!resourceName.startsWith("/")) { - resourceName = "/" + resourceName; - } - String pkg = toPackage(resourceName); - String module = inputClassPackageMapping.get(pkg); - if (module == null) { - module = newPackageMapping.get(pkg); - if (module == null) { - module = inputOtherPackageMapping.get(pkg); - if (module == null) { - throw new PluginException("No module for package" + pkg); - } - } - } - return "/" + module + resourceName; - } - - private static String toPackage(String path) { - if (path.startsWith("/")) { - path = path.substring(1); - } - int i = path.lastIndexOf("/"); - if (i == -1) { - // Default package... - return ""; - } - return path.substring(0, i).replaceAll("/", "."); - } -} diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPools.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPools.java deleted file mode 100644 index 53742ee5ad7..00000000000 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmPools.java +++ /dev/null @@ -1,497 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.tools.jlink.internal.plugins.asm; - -import java.lang.module.ModuleDescriptor; -import java.lang.module.ModuleDescriptor.Exports; -import java.lang.module.ModuleDescriptor.Requires; -import static java.lang.module.ModuleDescriptor.Requires.Modifier.PUBLIC; -import java.nio.ByteBuffer; -import java.util.ArrayList; -import java.util.Collection; -import java.util.HashMap; -import java.util.HashSet; -import java.util.LinkedHashMap; -import java.util.List; -import java.util.Map; -import java.util.Map.Entry; -import java.util.Objects; -import java.util.Set; -import jdk.internal.org.objectweb.asm.ClassReader; -import jdk.internal.org.objectweb.asm.ClassWriter; -import jdk.tools.jlink.internal.ModulePoolImpl; -import jdk.tools.jlink.internal.plugins.asm.AsmPool.Sorter; -import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.plugin.PluginException; -import jdk.tools.jlink.plugin.ModulePool; - -/** - * A container for pools of ClassReader and other resource files. A pool of all - * the resources or a pool for a given module can be retrieved - */ -public final class AsmPools { - - /** - * Sort the order in which the modules will be stored in the jimage file. - */ - public interface ModuleSorter { - - /** - * Sort the list of modules. - * - * @param modules The list of module names. The module will be stored in - * the jimage following this order. - * @return A list of module names that expresses the order in which the - * modules are stored in the jimage. - */ - public List sort(List modules); - } - - private class AsmGlobalPoolImpl implements AsmGlobalPool { - - private Sorter sorter = null; - - private class GlobalWritableClassPool implements WritableClassPool { - - @Override - public void addClass(ClassWriter writer) { - visitFirstNonFailingPool((AsmModulePool pool) -> { - pool.getTransformedClasses().addClass(writer); - }); - } - - @Override - public void forgetClass(String className) { - visitFirstNonFailingPool((AsmModulePool pool) -> { - pool.getTransformedClasses().forgetClass(className); - }); - } - - @Override - public ClassReader getClassReader(String binaryName) { - return visitPools((AsmModulePool pool) -> { - return pool.getTransformedClasses().getClassReader(binaryName); - }); - } - - @Override - public Collection getClasses() { - List all = new ArrayList<>(); - visitAllPools((AsmModulePool pool) -> { - for (ModuleEntry rf : pool.getTransformedClasses().getClasses()) { - all.add(rf); - } - }); - return all; - } - - @Override - public ClassReader getClassReader(ModuleEntry res) { - return visitPools((AsmModulePool pool) -> { - return pool.getTransformedClasses().getClassReader(res); - }); - } - - } - - private class GlobalWritableResourcePool implements WritableResourcePool { - - @Override - public void addResourceFile(ResourceFile resFile) { - visitFirstNonFailingPool((AsmModulePool pool) -> { - pool.getTransformedResourceFiles().addResourceFile(resFile); - }); - } - - @Override - public void forgetResourceFile(String resourceName) { - visitFirstNonFailingPool((AsmModulePool pool) -> { - pool.getTransformedResourceFiles().forgetResourceFile(resourceName); - }); - } - - @Override - public ResourceFile getResourceFile(String name) { - return visitPools((AsmModulePool pool) -> { - return pool.getTransformedResourceFiles().getResourceFile(name); - }); - } - - @Override - public Collection getResourceFiles() { - List all = new ArrayList<>(); - visitAllPools((AsmModulePool pool) -> { - for (ModuleEntry rf : pool.getTransformedResourceFiles().getResourceFiles()) { - all.add(rf); - } - }); - return all; - } - - @Override - public ResourceFile getResourceFile(ModuleEntry res) { - return visitPools((AsmModulePool pool) -> { - return pool.getTransformedResourceFiles().getResourceFile(res); - }); - } - - } - - @Override - public AsmPool.WritableClassPool getTransformedClasses() { - return new GlobalWritableClassPool(); - } - - @Override - public AsmPool.WritableResourcePool getTransformedResourceFiles() { - return new GlobalWritableResourcePool(); - } - - @Override - public void setSorter(AsmPool.Sorter sorter) { - this.sorter = sorter; - } - - @Override - public Collection getClasses() { - List all = new ArrayList<>(); - visitAllPools((AsmModulePool pool) -> { - for (ModuleEntry rf : pool.getClasses()) { - all.add(rf); - } - }); - return all; - } - - @Override - public Collection getResourceFiles() { - List all = new ArrayList<>(); - visitAllPools((AsmModulePool pool) -> { - for (ModuleEntry rf : pool.getResourceFiles()) { - all.add(rf); - } - }); - return all; - } - - @Override - public AsmPool.ResourceFile getResourceFile(String binaryName) { - return visitPools((AsmModulePool pool) -> { - return pool.getResourceFile(binaryName); - }); - } - - @Override - public ClassReader getClassReader(String binaryName) { - return visitPoolsEx((AsmModulePool pool) -> { - return pool.getClassReader(binaryName); - }); - } - - @Override - public ResourceFile getResourceFile(ModuleEntry res) { - return visitPools((AsmModulePool pool) -> { - return pool.getResourceFile(res); - }); - } - - @Override - public ClassReader getClassReader(ModuleEntry res) { - return visitPoolsEx((AsmModulePool pool) -> { - return pool.getClassReader(res); - }); - } - - @Override - public void visitClassReaders(AsmPool.ClassReaderVisitor visitor) { - visitAllPoolsEx((AsmModulePool pool) -> { - pool.visitClassReaders(visitor); - }); - } - - @Override - public void visitResourceFiles(AsmPool.ResourceFileVisitor visitor) { - visitAllPoolsEx((AsmModulePool pool) -> { - pool.visitResourceFiles(visitor); - }); - } - - @Override - public void fillOutputResources(ModulePool outputResources) { - AsmPools.this.fillOutputResources(outputResources); - } - - @Override - public void addPackageModuleMapping(String pkg, String module) { - AsmModulePool p = pools.get(module); - if (p == null) { - throw new PluginException("Unknown module " + module); - } - p.addPackage(pkg); - } - - @Override - public Set getAccessiblePackages(String module) { - AsmModulePool p = pools.get(module); - if (p == null) { - return null; - } - ModuleDescriptor desc = p.getDescriptor(); - Set packages = new HashSet<>(); - packages.addAll(p.getAllPackages()); - - // Retrieve direct dependencies and indirect ones (public) - Set modules = new HashSet<>(); - for (Requires req : desc.requires()) { - modules.add(req.name()); - addAllRequirePublicModules(req.name(), modules); - } - // Add exported packages of readable modules - for (String readable : modules) { - AsmModulePool mp = pools.get(readable); - if (mp != null) { - for (Exports e : mp.getDescriptor().exports()) { - // exported to all or to the targeted module - if (e.targets().isEmpty() || e.targets().contains(module)) { - packages.add(e.source().replaceAll("\\.", "/")); - } - } - - } - } - return packages; - } - - private void addAllRequirePublicModules(String module, Set modules) { - AsmModulePool p = pools.get(module); - if (p != null) { - for (Requires req : p.getDescriptor().requires()) { - if (req.modifiers().contains(PUBLIC)) { - modules.add(req.name()); - addAllRequirePublicModules(req.name(), modules); - } - } - } - } - - } - - private interface VoidPoolVisitor { - - void visit(AsmModulePool pool); - } - - private interface VoidPoolVisitorEx { - - void visit(AsmModulePool pool); - } - - private interface RetPoolVisitor

      { - - P visit(AsmModulePool pool); - } - - private final Map pools = new LinkedHashMap<>(); - private final AsmModulePool[] poolsArray; - private final AsmGlobalPoolImpl global; - - private ModuleSorter moduleSorter; - - /** - * A new Asm pools. - * - * @param inputResources The raw resources to build the pool from. - */ - public AsmPools(ModulePool inputResources) { - Objects.requireNonNull(inputResources); - Map resPools = new LinkedHashMap<>(); - Map descriptors = new HashMap<>(); - inputResources.entries().forEach(res -> { - ModulePool p = resPools.get(res.getModule()); - if (p == null) { - p = new ModulePoolImpl(inputResources.getByteOrder(), - ((ModulePoolImpl)inputResources).getStringTable()); - resPools.put(res.getModule(), p); - } - if (res.getPath().endsWith("module-info.class")) { - ByteBuffer bb = ByteBuffer.wrap(res.getBytes()); - ModuleDescriptor descriptor = ModuleDescriptor.read(bb); - descriptors.put(res.getModule(), descriptor); - } - p.add(res); - }); - poolsArray = new AsmModulePool[resPools.size()]; - int i = 0; - - for (Entry entry : resPools.entrySet()) { - ModuleDescriptor descriptor = descriptors.get(entry.getKey()); - if (descriptor == null) { - throw new PluginException("module-info.class not found for " + entry.getKey() + " module"); - } - AsmModulePool p = new AsmPoolImpl(entry.getValue(), - entry.getKey(), this, descriptor); - pools.put(entry.getKey(), p); - poolsArray[i] = p; - i += 1; - } - global = new AsmGlobalPoolImpl(); - } - - /** - * The pool containing all classes and other resources. - * - * @return The global pool - */ - public AsmGlobalPool getGlobalPool() { - return global; - } - - /** - * A pool for a given module - * - * @param name The module name - * @return The pool that contains content of the passed module or null if - * the module doesn't exist. - */ - public AsmModulePool getModulePool(String name) { - Objects.requireNonNull(name); - return pools.get(name); - } - - /** - * The array of module pools. - * @return The module pool array. - */ - public AsmModulePool[] getModulePools() { - return poolsArray.clone(); - } - - /** - * Set a module sorter. Sorter is used when computing the output resources. - * - * @param moduleSorter The module sorter - */ - public void setModuleSorter(ModuleSorter moduleSorter) { - Objects.requireNonNull(moduleSorter); - this.moduleSorter = moduleSorter; - } - - /** - * Returns the pool of all the resources (transformed and unmodified). The - * input resources are replaced by the transformed ones. If a sorter has - * been set, it is used to sort in modules. - * - * @param outputResources The pool used to fill the jimage. - */ - public void fillOutputResources(ModulePool outputResources) { - // First sort modules - List modules = new ArrayList<>(); - for (String k : pools.keySet()) { - modules.add(k); - } - if (moduleSorter != null) { - modules = moduleSorter.sort(modules); - } - ModulePool output = new ModulePoolImpl(outputResources.getByteOrder(), - ((ModulePoolImpl)outputResources).getStringTable()); - for (String mn : modules) { - AsmPool pool = pools.get(mn); - pool.fillOutputResources(output); - } - sort(outputResources, output, global.sorter); - } - - static void sort(ModulePool outputResources, - ModulePool transientOutput, Sorter sorter) { - if (sorter != null) { - List order = sorter.sort(transientOutput); - for (String s : order) { - outputResources.add(transientOutput.findEntry(s).get()); - } - } else { - transientOutput.entries().forEach(res-> { - outputResources.add(res); - }); - } - } - - private void visitFirstNonFailingPool(VoidPoolVisitorEx pv) { - boolean found = false; - for (Entry entry : pools.entrySet()) { - try { - pv.visit(entry.getValue()); - found = true; - break; - } catch (Exception ex) { - // XXX OK, try another one. - } - } - if (!found) { - throw new PluginException("No module found"); - } - } - - private void visitAllPools(VoidPoolVisitor pv) { - for (Entry entry : pools.entrySet()) { - pv.visit(entry.getValue()); - } - } - - private void visitAllPoolsEx(VoidPoolVisitorEx pv) { - for (Entry entry : pools.entrySet()) { - pv.visit(entry.getValue()); - } - } - - private

      P visitPoolsEx(RetPoolVisitor

      pv) { - P p = null; - for (Entry entry : pools.entrySet()) { - try { - p = pv.visit(entry.getValue()); - if (p != null) { - break; - } - } catch (Exception ex) { - // XXX OK, try another one. - } - } - return p; - } - - private

      P visitPools(RetPoolVisitor

      pv) { - P p = null; - for (Entry entry : pools.entrySet()) { - try { - p = pv.visit(entry.getValue()); - if (p != null) { - break; - } - } catch (Exception ex) { - // XXX OK, try another one. - } - } - return p; - } -} diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/ControlFlow.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/ControlFlow.java deleted file mode 100644 index d8806666039..00000000000 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/ControlFlow.java +++ /dev/null @@ -1,516 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.tools.jlink.internal.plugins.optim; - -import java.util.ArrayList; -import java.util.Collection; -import java.util.Collections; -import java.util.HashMap; -import java.util.HashSet; -import java.util.Iterator; -import java.util.List; -import java.util.Map; -import java.util.Map.Entry; -import java.util.Objects; -import java.util.Set; -import java.util.Stack; -import java.util.TreeSet; -import jdk.internal.org.objectweb.asm.tree.AbstractInsnNode; -import jdk.internal.org.objectweb.asm.tree.MethodNode; -import jdk.internal.org.objectweb.asm.tree.analysis.Analyzer; -import jdk.internal.org.objectweb.asm.tree.analysis.AnalyzerException; -import jdk.internal.org.objectweb.asm.tree.analysis.BasicInterpreter; -import jdk.internal.org.objectweb.asm.tree.analysis.BasicValue; - -/** - * Split Java method onto a control flow. - * - */ -public final class ControlFlow { - - /** - * A block of control - */ - public static final class Block implements Comparable { - - private final InstructionNode firstInstruction; - private final List instr = new ArrayList<>(); - private final List reachable = new ArrayList<>(); - private final List exceptionHandlers = new ArrayList<>(); - private boolean isExceptionHandler; - - private Block(InstructionNode firstInstruction) { - this.firstInstruction = firstInstruction; - } - - @Override - public boolean equals(Object other) { - if (!(other instanceof Block)) { - return false; - } - Block b = (Block) other; - return firstInstruction.equals(b.firstInstruction); - } - - @Override - public int hashCode() { - return Objects.hashCode(this.firstInstruction); - } - - @Override - public String toString() { - StringBuilder builder = new StringBuilder(); - for (InstructionNode in : instr) { - builder.append(in).append(" "); - } - builder.append(" reachables: "); - for (Block r : reachable) { - builder.append(r.getFirstInstruction()).append(" "); - } - builder.append(" exception handlers: "); - for (Block r : exceptionHandlers) { - builder.append(r.getFirstInstruction()).append(" "); - } - - return "block[" + getFirstInstruction() + "],ex:" - + isExceptionHandler + ", " + builder.toString(); - } - - /** - * @return the firstInstruction - */ - public InstructionNode getFirstInstruction() { - return firstInstruction; - } - - /** - * @return the instr - */ - public List getInstructions() { - return Collections.unmodifiableList(instr); - } - - /** - * @return the reachable - */ - public List getReachableBlocks() { - return Collections.unmodifiableList(reachable); - } - - /** - * @return the exceptionHandlers - */ - public List getExceptionHandlerBlocks() { - return Collections.unmodifiableList(exceptionHandlers); - } - - @Override - public int compareTo(Block t) { - return this.firstInstruction.index - t.firstInstruction.index; - } - - public boolean isExceptionHandler() { - return isExceptionHandler; - } - - } - - private class ClosureBuilder { - - private final Block root; - - private ClosureBuilder(Block root) { - Objects.requireNonNull(root); - this.root = root; - } - - private Set build() { - Set allReachable = new TreeSet<>(); - addAll(root, allReachable); - // filter out the reachable from outside this graph - Iterator it = allReachable.iterator(); - Set toExclude = new HashSet<>(); - while (it.hasNext()) { - Block b = it.next(); - for (Block ref : blocks) { - if (!allReachable.contains(ref) && ref.reachable.contains(b)) { - addAll(b, toExclude); - break; - } - } - } - //System.err.println("TO EXCLUDE:\n " + toExclude); - allReachable.removeAll(toExclude); - //System.err.println("CLOSURE:\n " + allReachable); - return Collections.unmodifiableSet(allReachable); - } - - // Compute the set of blocks reachable from the current block - private void addAll(Block current, Set closure) { - Objects.requireNonNull(current); - closure.add(current); - for (Block ex : current.exceptionHandlers) { - Objects.requireNonNull(ex); - if (!closure.contains(ex)) { - addAll(ex, closure); - } - } - for (Block r : current.reachable) { - Objects.requireNonNull(r); - if (!closure.contains(r)) { - addAll(r, closure); - } - } - - } - } - - /** - * An instruction - */ - public static final class InstructionNode { - - private final int index; - private final List next = new ArrayList<>(); - private final AbstractInsnNode instr; - - private InstructionNode(int index, AbstractInsnNode instr) { - this.index = index; - this.instr = instr; - } - - @Override - public boolean equals(Object obj) { - if (!(obj instanceof InstructionNode)) { - return false; - } - final InstructionNode other = (InstructionNode) obj; - return this.getIndex() == other.getIndex(); - } - - @Override - public int hashCode() { - return this.getIndex(); - } - - @Override - public String toString() { - return getIndex() + "(" + (getInstr().getOpcode() == - 1 ? -1 - : Integer.toHexString(getInstr().getOpcode())) + ")"; - } - - /** - * @return the index - */ - public int getIndex() { - return index; - } - - /** - * @return the instr - */ - public AbstractInsnNode getInstr() { - return instr; - } - - } - - private final Map allBlocks; - private final List blocks = new ArrayList<>(); - - private ControlFlow(Map allBlocks) { - this.allBlocks = allBlocks; - for (Block b : allBlocks.values()) { - blocks.add(b); - } - Collections.sort(blocks); - } - - public List getBlocks() { - - return Collections.unmodifiableList(blocks); - } - - public Block getBlock(int firstInstr) { - return allBlocks.get(firstInstr); - } - - public static ControlFlow createControlFlow(String owner, - MethodNode method) throws Exception { - - BlockBuilder bb = new BlockBuilder(owner, method); - return bb.build(); - } - - /** - * Return the set of blocks that are only reachable from this block For - * example, if b is an Exception handler, returns all the blocks reachable - * only from this handler - * - * @param b - * @return - */ - public Set getClosure(Block b) { - return new ClosureBuilder(b).build(); - } - - private static final class BlockBuilder { - - private InstructionNode root; - private final Map instructions = new HashMap<>(); - private final Map> handlers = new HashMap<>(); - private final Map allBlocks = new HashMap<>(); - - private final String owner; - private final MethodNode method; - - private BlockBuilder(String owner, MethodNode method) { - this.owner = owner; - this.method = method; - } - - private void analyze() throws AnalyzerException { - Analyzer analyzer = new Analyzer(new BasicInterpreter()) { - - @Override - protected boolean newControlFlowExceptionEdge(int insn, - int successor) { - List lst = handlers.get(successor); - if (lst == null) { - lst = new ArrayList<>(); - handlers.put(successor, lst); - } - lst.add(insn); - return true; - } - - @Override - protected void newControlFlowEdge(int from, - int to) { - if (root == null) { - root = new InstructionNode(from, method.instructions.get(from)); - instructions.put(from, root); - } - InstructionNode fromNode = instructions.get(from); - if (fromNode == null) { - fromNode = new InstructionNode(from, method.instructions.get(from)); - instructions.put(from, fromNode); - } - InstructionNode toNode = instructions.get(to); - if (toNode == null) { - toNode = new InstructionNode(to, method.instructions.get(to)); - instructions.put(to, toNode); - } - if (!fromNode.next.contains(toNode)) { - fromNode.next.add(toNode); - } - - } - }; - analyzer.analyze(owner, method); - } - - private Block newBlock(InstructionNode firstInstruction) { - Objects.requireNonNull(firstInstruction); - Block b = new Block(firstInstruction); - allBlocks.put(firstInstruction.getIndex(), b); - return b; - } - - private ControlFlow build() throws AnalyzerException { - analyze(); - buildBlocks(); - return new ControlFlow(allBlocks); - } - - private void buildBlocks() { - List reachableBlocks = new ArrayList<>(); - createBlocks(root, reachableBlocks); - List handlersBlocks = new ArrayList<>(); - for (Entry> entry : handlers.entrySet()) { - InstructionNode node = instructions.get(entry.getKey()); - createBlocks(node, handlersBlocks); - } - - // attach handler to try blocks - for (Entry> entry : handlers.entrySet()) { - Block handlerBlock = allBlocks.get(entry.getKey()); - handlerBlock.isExceptionHandler = true; - int startTry = entry.getValue().get(0); - Block tryBlock = allBlocks.get(startTry); - if (tryBlock == null) { - // Need to find the block that contains the instruction and - // make a new block - Block split = null; - for (Block b : allBlocks.values()) { - Iterator it = b.instr.iterator(); - while (it.hasNext()) { - InstructionNode in = it.next(); - if (split == null) { - if (in.index == startTry) { - split = newBlock(in); - split.instr.add(in); - it.remove(); - } - } else { - split.instr.add(in); - it.remove(); - } - } - if (split != null) { - Iterator reachables = b.reachable.iterator(); - while (reachables.hasNext()) { - Block r = reachables.next(); - split.reachable.add(r); - reachables.remove(); - } - b.reachable.add(split); - break; - } - } - if (split == null) { - throw new RuntimeException("No try block for handler " + handlerBlock); - } - split.exceptionHandlers.add(handlerBlock); - } else { - tryBlock.exceptionHandlers.add(handlerBlock); - } - } - -// System.err.println("ALL BLOCKS FOUND"); -// Iterator> blockIt0 = allBlocks.entrySet().iterator(); -// while (blockIt0.hasNext()) { -// Block b = blockIt0.next().getValue(); -// System.err.println(b); -// } - //compute real exception blocks, if an instruction is in another block, stop. - Iterator> blockIt = allBlocks.entrySet().iterator(); - while (blockIt.hasNext()) { - Block b = blockIt.next().getValue(); - Iterator in = b.instr.iterator(); - boolean found = false; - while (in.hasNext()) { - int i = in.next().getIndex(); - if (found) { - in.remove(); - } else { - if (startsWith(b, i, allBlocks.values())) { - // Move it to reachable - Block r = allBlocks.get(i); - b.reachable.add(r); - found = true; - in.remove(); - } else { - } - } - } - } - -// System.err.println("Reduced blocks"); -// Iterator> blockIt1 = allBlocks.entrySet().iterator(); -// while (blockIt1.hasNext()) { -// Block b = blockIt1.next().getValue(); -// System.err.println(b); -// } - } - - private boolean startsWith(Block block, int index, Collection reachableBlocks) { - for (Block b : reachableBlocks) { - if (b != block && !b.instr.isEmpty() && b.instr.get(0).getIndex() == index) { - return true; - } - } - return false; - } - - private static final class StackItem { - - private final InstructionNode instr; - private final Block currentBlock; - - private StackItem(InstructionNode instr, Block currentBlock) { - Objects.requireNonNull(instr); - Objects.requireNonNull(currentBlock); - this.instr = instr; - this.currentBlock = currentBlock; - } - } - - /** - * This algorithm can't be recursive, possibly too much instructions in - * methods. - */ - private void createBlocks(InstructionNode root, List blocks) { - final Stack stack = new Stack<>(); - stack.push(new StackItem(root, newBlock(root))); - while (!stack.isEmpty()) { - final StackItem item = stack.pop(); - final Block currentBlock = item.currentBlock; - final InstructionNode current = item.instr; - // loop - if (currentBlock.instr.contains(current)) { - currentBlock.reachable.add(currentBlock); - continue; - } - Block existing = allBlocks.get(current.index); - if (existing != null && existing != currentBlock) { - currentBlock.reachable.add(existing); - continue; - } - int previous = currentBlock.instr.size() > 0 - ? currentBlock.instr.get(currentBlock.instr.size() - 1).getIndex() : -1; - if (previous == -1 || current.getIndex() == previous + 1) { - currentBlock.instr.add(current); - if (current.next.isEmpty()) { - blocks.add(currentBlock); - } else { - if (current.next.size() > 1) { - blocks.add(currentBlock); - for (InstructionNode n : current.next) { - Block loop = allBlocks.get(n.index); - if (loop == null) { - Block newBlock = newBlock(n); - currentBlock.reachable.add(newBlock); - stack.push(new StackItem(n, newBlock)); - } else { // loop - currentBlock.reachable.add(loop); - } - } - } else { - stack.push(new StackItem(current.next.get(0), - currentBlock)); - } - } - } else { // to a new block... - // Do nothing... - blocks.add(currentBlock); - Block newBlock = newBlock(current); - currentBlock.reachable.add(newBlock); - stack.push(new StackItem(current, newBlock)); - } - } - } - } -} diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/ForNameFolding.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/ForNameFolding.java deleted file mode 100644 index fcf12be3ea9..00000000000 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/ForNameFolding.java +++ /dev/null @@ -1,111 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.tools.jlink.internal.plugins.optim; - -import java.io.IOException; -import java.util.Map.Entry; -import java.util.Set; -import java.util.function.Consumer; -import jdk.internal.org.objectweb.asm.ClassReader; -import jdk.tools.jlink.internal.plugins.asm.AsmPools; -import jdk.internal.org.objectweb.asm.tree.ClassNode; -import jdk.internal.org.objectweb.asm.tree.MethodNode; -import jdk.tools.jlink.internal.plugins.OptimizationPlugin.MethodOptimizer; -import jdk.tools.jlink.internal.plugins.asm.AsmModulePool; -import jdk.tools.jlink.internal.plugins.optim.ControlFlow.Block; -import jdk.tools.jlink.internal.plugins.optim.ReflectionOptimizer.Data; -import jdk.tools.jlink.internal.plugins.optim.ReflectionOptimizer.TypeResolver; - - -/** - * MethodOptimizer that removes Class.forName when possible. - * WARNING: This code is experimental. - * TODO: Need to check that the type is accessible prior to replace with a constant. - */ -public class ForNameFolding implements MethodOptimizer { - - private int numNotReplaced; - private int numReplacement; - private int numRemovedHandlers; - private int instructionsRemoved; - - private Consumer logger; - - @Override - public boolean optimize(Consumer logger, AsmPools pools, - AsmModulePool modulePool, - ClassNode cn, MethodNode m, TypeResolver resolver) throws Exception { - this.logger = logger; - Data data = ReflectionOptimizer.replaceWithClassConstant(cn, m, createResolver(resolver)); - instructionsRemoved += data.removedInstructions(); - numRemovedHandlers += data.removedHandlers().size(); - for (Entry> entry : data.removedHandlers().entrySet()) { - logRemoval(cn.name + "." + m.name + "removed block for " + entry.getKey() - + " : " + entry.getValue()); - } - return data.removedInstructions() > 0; - } - - public TypeResolver createResolver(TypeResolver resolver) { - return (ClassNode cn, MethodNode mn, String type) -> { - ClassReader reader = resolver.resolve(cn, mn, type); - if (reader == null) { - logNotReplaced(type); - } else { - logReplaced(type); - } - return reader; - }; - } - - private void logReplaced(String type) { - numReplacement += 1; - } - - private void logNotReplaced(String type) { - numNotReplaced += 1; - if (logger != null) { - logger.accept(type + " not resolved"); - } - } - - private void logRemoval(String content) { - numRemovedHandlers += 1; - if (logger != null) { - logger.accept(content); - } - } - - @Override - public void close() throws IOException { - if (logger != null) { - logger.accept("Class.forName Folding results:\n " + numReplacement - + " removed reflection. " + numRemovedHandlers - + " removed exception handlers." - + numNotReplaced + " types unknown. " - + instructionsRemoved + " instructions removed\n"); - } - } -} diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/ReflectionOptimizer.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/ReflectionOptimizer.java deleted file mode 100644 index 690b884d800..00000000000 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/ReflectionOptimizer.java +++ /dev/null @@ -1,226 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.tools.jlink.internal.plugins.optim; - -import java.util.ArrayList; -import java.util.Collections; -import java.util.HashMap; -import java.util.IdentityHashMap; -import java.util.Iterator; -import java.util.List; -import java.util.Map; -import java.util.Set; -import java.util.TreeSet; -import jdk.internal.org.objectweb.asm.ClassReader; -import jdk.internal.org.objectweb.asm.Type; -import jdk.internal.org.objectweb.asm.tree.AbstractInsnNode; -import jdk.internal.org.objectweb.asm.tree.ClassNode; -import jdk.internal.org.objectweb.asm.tree.LabelNode; -import jdk.internal.org.objectweb.asm.tree.LdcInsnNode; -import jdk.internal.org.objectweb.asm.tree.LineNumberNode; -import jdk.internal.org.objectweb.asm.tree.MethodInsnNode; -import jdk.internal.org.objectweb.asm.tree.MethodNode; -import jdk.internal.org.objectweb.asm.tree.TryCatchBlockNode; -import jdk.tools.jlink.internal.plugins.optim.ControlFlow.Block; - -/** - * Implement the reflection optimization. - */ -public class ReflectionOptimizer { - - public static class Data { - - private int removedInstructions; - private final Map> removedHandlers = new HashMap<>(); - - private Data() { - } - - public int removedInstructions() { - return removedInstructions; - } - - public Map> removedHandlers() { - return Collections.unmodifiableMap(removedHandlers); - } - } - - public interface TypeResolver { - - public ClassReader resolve(ClassNode cn, MethodNode m, String type); - } - - public static Data replaceWithClassConstant(ClassNode cn, MethodNode m, - TypeResolver cch) - throws Exception { - Iterator it = m.instructions.iterator(); - LdcInsnNode insNode = null; - Map replacement = new IdentityHashMap<>(); - Data data = new Data(); - while (it.hasNext()) { - AbstractInsnNode n = it.next(); - if (n instanceof LdcInsnNode) { - LdcInsnNode ldc = (LdcInsnNode) n; - if (ldc.cst instanceof String) { - insNode = ldc; - } - } else { - if (n instanceof MethodInsnNode && insNode != null) { - MethodInsnNode met = (MethodInsnNode) n; - if (met.name.equals("forName") - && met.owner.equals("java/lang/Class") - && met.desc.equals("(Ljava/lang/String;)Ljava/lang/Class;")) { - // Can we load the type? - Type type = null; - String binaryName = insNode.cst.toString().replaceAll("\\.", "/"); - String unaryClassName = binaryName; - int arrayIndex = binaryName.lastIndexOf("["); - if (arrayIndex >= 0) { - int objIndex = unaryClassName.indexOf("L"); - if (objIndex >= 0) { - unaryClassName = unaryClassName.substring(objIndex + 1); - unaryClassName = unaryClassName.substring(0, - unaryClassName.length() - 1); - } else { - //primitive, this is just fine. - type = Type.getObjectType(binaryName); - } - } - if (type == null) { - if (cch.resolve(cn, m, unaryClassName) != null) { - type = Type.getObjectType(binaryName); - } - } - if (type != null) { - replacement.put(insNode, new LdcInsnNode(type)); - it.remove(); - data.removedInstructions += 1; - } - } else { - insNode = null; - } - // Virtual node, not taken into account - } else if (!(n instanceof LabelNode) && !(n instanceof LineNumberNode)) { - insNode = null; - } - } - } - for (Map.Entry entry : replacement.entrySet()) { - m.instructions.set(entry.getKey(), entry.getValue()); - } - if (!replacement.isEmpty()) { - String[] types = {"java/lang/ClassNotFoundException"}; - data.removedInstructions += deleteExceptionHandlers(cch, data, cn, m, types); - - } - return data; - } - - private static int deleteExceptionHandlers(TypeResolver cch, Data data, - ClassNode cn, MethodNode m, String[] exTypes) - throws Exception { - int instructionsRemoved = 0; - for (String ex : exTypes) { - ControlFlow f = ControlFlow.createControlFlow(cn.name, m); - List removed = new ArrayList<>(); - Set blocksToRemove = new TreeSet<>(); - Iterator it = m.tryCatchBlocks.iterator(); - List tcbToRemove = new ArrayList<>(); - while (it.hasNext()) { - TryCatchBlockNode bn = it.next(); - if (bn.type == null - || !bn.type.equals(ex) // An empty block - || tcbToRemove.contains(bn)) { - continue; - } - // Check that the handler is still required - if (!Utils.canThrowCheckedException(cch, cn, m, bn)) { - // try to suppress it. - int block = m.instructions.indexOf(bn.handler); - ControlFlow.Block blockHandler = f.getBlock(block); - if (blockHandler == null) { - if (removed.contains(block)) { - continue; - } else { - throw new Exception(cn.name - + ", no block for handler " + block); - } - } - tcbToRemove.add(bn); - // Don't delete block if shared (eg: ClassNotFoundException | NoSuchMethodException | - Iterator it2 = m.tryCatchBlocks.iterator(); - boolean cont = false; - while (it2.hasNext()) { - TryCatchBlockNode bn2 = it2.next(); - if (bn2 != bn) { - if (bn2.start.equals(bn.start)) { - cont = true; - } - } - } - if (cont) { - continue; - } - // An handler is a root, blocks that are only reachable by it - // can be removed. - Set blocks = f.getClosure(blockHandler); - StringBuilder sb = new StringBuilder(); - for (ControlFlow.Block b : blocks) { - sb.append(b).append("\n"); - removed.add(b.getFirstInstruction().getIndex()); - // Remove Exception handler if the associated block has been removed - for (TryCatchBlockNode tcb : m.tryCatchBlocks) { - if (tcb != bn) { - // An exception handler removed as a side effect. - if (b.isExceptionHandler() - && b.getFirstInstruction().getInstr() == tcb.handler) { - tcbToRemove.add(tcb); - } - } - } - } - blocksToRemove.addAll(blocks); - - data.removedHandlers.put(ex, blocks); - - } - } - - m.tryCatchBlocks.removeAll(tcbToRemove); - - if (!blocksToRemove.isEmpty()) { - for (ControlFlow.Block b : blocksToRemove) { - for (ControlFlow.InstructionNode ins : b.getInstructions()) { - if (ins.getInstr().getOpcode() > 0) { - instructionsRemoved += 1; - } - } - } - Utils.suppressBlocks(m, blocksToRemove); - } - } - return instructionsRemoved; - } -} diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/Utils.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/Utils.java deleted file mode 100644 index 2e75127436d..00000000000 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/optim/Utils.java +++ /dev/null @@ -1,97 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -package jdk.tools.jlink.internal.plugins.optim; - -import java.util.Iterator; -import java.util.Set; -import jdk.internal.org.objectweb.asm.ClassReader; -import jdk.internal.org.objectweb.asm.tree.AbstractInsnNode; -import jdk.internal.org.objectweb.asm.tree.ClassNode; -import jdk.internal.org.objectweb.asm.tree.MethodInsnNode; -import jdk.internal.org.objectweb.asm.tree.MethodNode; -import jdk.internal.org.objectweb.asm.tree.TryCatchBlockNode; - -/** - * Optimization utility methods - */ -public class Utils { - - public static boolean canThrowCheckedException(ReflectionOptimizer.TypeResolver cch, - ClassNode classNode, MethodNode m, TryCatchBlockNode bn) throws Exception { - int istart = m.instructions.indexOf(bn.start); - int iend = m.instructions.indexOf(bn.end); - for (int i = istart; i < iend - 1; i++) { - AbstractInsnNode instr = m.instructions.get(i); - if (instr instanceof MethodInsnNode) { - MethodInsnNode meth = (MethodInsnNode) instr; - ClassReader reader = cch.resolve(classNode, m, meth.owner); - if (reader != null) { - ClassNode cn = new ClassNode(); - reader.accept(cn, ClassReader.EXPAND_FRAMES); - for (MethodNode method : cn.methods) { - if (method.name.equals(meth.name)) { - for (String e : method.exceptions) { - if (e.equals(bn.type)) { - return true; - } - } - } - } - } else { - return true; - } - } - } - return false; - } - - public static void suppressBlocks(MethodNode m, Set toRemove) throws Exception { - m.instructions.resetLabels(); - Iterator it = m.instructions.iterator(); - while (it.hasNext()) { - AbstractInsnNode n = it.next(); - Iterator handlers = m.tryCatchBlocks.iterator(); - boolean cont = false; - // Do not delete instructions that are end of other try block. - while (handlers.hasNext()) { - TryCatchBlockNode handler = handlers.next(); - if (handler.end == n) { - cont = true; - } - } - if (cont) { - continue; - } - - for (ControlFlow.Block b : toRemove) { - for (ControlFlow.InstructionNode ins : b.getInstructions()) { - if (ins.getInstr() == n) { - it.remove(); - } - } - } - } - } -} diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/Plugin.java b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/Plugin.java index b83d5036954..eea330e2e7b 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/Plugin.java +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/plugin/Plugin.java @@ -106,24 +106,6 @@ public interface Plugin { return EnumSet.of(State.FUNCTIONAL); } - /** - * The set of plugin names that must be located, within the stack of plugins, - * before this plugin. - * @return The set of names. By default this set is empty. - */ - public default Set isBefore() { - return Collections.emptySet(); - } - - /** - * The set of plugin names that must be located, within the stack of plugins, - * after this plugin. - * @return The set of names. By default this set is empty. - */ - public default Set isAfter() { - return Collections.emptySet(); - } - /** * The plugin name. * @return The name. diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/jlink_ja.properties b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/jlink_ja.properties index 955bb0aa106..7fa48a21acb 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/jlink_ja.properties +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/jlink_ja.properties @@ -1,3 +1,28 @@ +# +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. +# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. +# +# This code is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License version 2 only, as +# published by the Free Software Foundation. Oracle designates this +# particular file as subject to the "Classpath" exception as provided +# by Oracle in the LICENSE file that accompanied this code. +# +# This code is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +# version 2 for more details (a copy is included in the LICENSE file that +# accompanied this code). +# +# You should have received a copy of the GNU General Public License version +# 2 along with this work; if not, write to the Free Software Foundation, +# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. +# +# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA +# or visit www.oracle.com if you need additional information or have any +# questions. +# + main.usage.summary=\u4F7F\u7528\u65B9\u6CD5: {0} --modulepath --addmods --output \n\u4F7F\u7528\u53EF\u80FD\u306A\u30AA\u30D7\u30B7\u30E7\u30F3\u306E\u30EA\u30B9\u30C8\u306B\u3064\u3044\u3066\u306F\u3001--help\u3092\u4F7F\u7528\u3057\u307E\u3059 main.usage=\u4F7F\u7528\u65B9\u6CD5: {0} --modulepath --addmods --output \n\u4F7F\u7528\u53EF\u80FD\u306A\u30AA\u30D7\u30B7\u30E7\u30F3\u306B\u306F\u6B21\u306E\u3082\u306E\u304C\u3042\u308A\u307E\u3059\u3002 @@ -21,8 +46,6 @@ main.command.files=\ @ \u30D5\u30A1\u30A4\u30EB main.opt.endian=\ --endian \u751F\u6210\u3055\u308C\u305Fjimage (default:native)\u306E\u30D0\u30A4\u30C8\u9806 -main.opt.genbom=\ --genbom jlink\u60C5\u5831\u3092\u542B\u3080bom\u30D5\u30A1\u30A4\u30EB\u3092\u751F\u6210\u3057\u307E\u3059 - main.opt.saveopts=\ --saveopts \u6307\u5B9A\u306E\u30D5\u30A1\u30A4\u30EB\u306Bjlink\u30AA\u30D7\u30B7\u30E7\u30F3\u3092\u4FDD\u5B58\u3057\u307E\u3059 main.msg.bug=jlink\u3067\u4F8B\u5916\u304C\u767A\u751F\u3057\u307E\u3057\u305F\u3002\u30C7\u30FC\u30BF\u30D9\u30FC\u30B9\u3067\u91CD\u8907\u304C\u306A\u3044\u304B\u3092\u3054\u78BA\u8A8D\u306E\u3046\u3048\u3001Java Bug Database (http://bugreport.java.com/bugreport/)\u3067bug\u306E\u767B\u9332\u3092\u304A\u9858\u3044\u3044\u305F\u3057\u307E\u3059\u3002\u30EC\u30DD\u30FC\u30C8\u306B\u306F\u3001\u305D\u306E\u30D7\u30ED\u30B0\u30E9\u30E0\u3068\u6B21\u306E\u8A3A\u65AD\u5185\u5BB9\u3092\u542B\u3081\u3066\u304F\u3060\u3055\u3044\u3002\u3054\u5354\u529B\u3042\u308A\u304C\u3068\u3046\u3054\u3056\u3044\u307E\u3059\u3002 diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/jlink_zh_CN.properties b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/jlink_zh_CN.properties index b609a6a988c..1c3b14b3261 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/jlink_zh_CN.properties +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/jlink_zh_CN.properties @@ -1,3 +1,28 @@ +# +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. +# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. +# +# This code is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License version 2 only, as +# published by the Free Software Foundation. Oracle designates this +# particular file as subject to the "Classpath" exception as provided +# by Oracle in the LICENSE file that accompanied this code. +# +# This code is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +# version 2 for more details (a copy is included in the LICENSE file that +# accompanied this code). +# +# You should have received a copy of the GNU General Public License version +# 2 along with this work; if not, write to the Free Software Foundation, +# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. +# +# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA +# or visit www.oracle.com if you need additional information or have any +# questions. +# + main.usage.summary=\u7528\u6CD5: {0} --modulepath --addmods --output \n\u4F7F\u7528 --help \u53EF\u4EE5\u5217\u51FA\u53EF\u80FD\u7684\u9009\u9879 main.usage=\u7528\u6CD5: {0} --modulepath --addmods --output \n\u53EF\u80FD\u7684\u9009\u9879\u5305\u62EC: @@ -21,8 +46,6 @@ main.command.files=\ @ \u4ECE\u6587\u4EF6\u4E2D main.opt.endian=\ --endian \u6240\u751F\u6210 jimage \u7684\u5B57\u8282\u987A\u5E8F (\u9ED8\u8BA4\u503C: native) -main.opt.genbom=\ --genbom \u751F\u6210\u5305\u542B jlink \u4FE1\u606F\u7684 bom \u6587\u4EF6 - main.opt.saveopts=\ --saveopts \u5C06 jlink \u9009\u9879\u4FDD\u5B58\u5728\u6307\u5B9A\u6587\u4EF6\u4E2D main.msg.bug=jlink \u4E2D\u51FA\u73B0\u5F02\u5E38\u9519\u8BEF\u3002\u5982\u679C\u5728 Java Bug Database (http://bugreport.java.com/bugreport/) \u4E2D\u6CA1\u6709\u627E\u5230\u8BE5\u9519\u8BEF, \u8BF7\u5728\u8BE5\u6570\u636E\u5E93\u4E2D\u5EFA\u7ACB Bug\u3002\u8BF7\u5728\u62A5\u544A\u4E2D\u9644\u4E0A\u60A8\u7684\u7A0B\u5E8F\u548C\u4EE5\u4E0B\u8BCA\u65AD\u4FE1\u606F\u3002\u8C22\u8C22\u3002 diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/plugins.properties b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/plugins.properties index afab935c836..285600e2c77 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/plugins.properties +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/resources/plugins.properties @@ -31,11 +31,10 @@ add: is to add properties to the 'release' file.\n\ Any number of = pairs can be passed.\n\ del: is to delete the list of keys in release file. -class-optim.argument=[:log=] +class-for-name.argument= -class-optim.description=\ -Class optimization. Warning: This plugin is experimental.\n\ -An optional can be specified to log applied optimizations. +class-for-name.description=\ +Class optimization: convert Class.forName calls to constant loads. compress.argument=<0|1|2>[:filter=] @@ -47,7 +46,6 @@ Level 2: both.\n\ An optional filter can be specified to list the pattern of\n\ files to be included. - compact-cp.argument= compact-cp.description=Constant Pool strings sharing.\n\ diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/resources/jmod_ja.properties b/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/resources/jmod_ja.properties index 8555acae4ac..4cc91ca7f3d 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/resources/jmod_ja.properties +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/resources/jmod_ja.properties @@ -1,6 +1,31 @@ -main.usage.summary=\u4F7F\u7528\u65B9\u6CD5: {0} (create|list|describe) \n\u4F7F\u7528\u53EF\u80FD\u306A\u30AA\u30D7\u30B7\u30E7\u30F3\u306E\u30EA\u30B9\u30C8\u306B\u3064\u3044\u3066\u306F\u3001--help\u3092\u4F7F\u7528\u3057\u307E\u3059 +# +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. +# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. +# +# This code is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License version 2 only, as +# published by the Free Software Foundation. Oracle designates this +# particular file as subject to the "Classpath" exception as provided +# by Oracle in the LICENSE file that accompanied this code. +# +# This code is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +# version 2 for more details (a copy is included in the LICENSE file that +# accompanied this code). +# +# You should have received a copy of the GNU General Public License version +# 2 along with this work; if not, write to the Free Software Foundation, +# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. +# +# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA +# or visit www.oracle.com if you need additional information or have any +# questions. +# -main.usage=\u4F7F\u7528\u65B9\u6CD5: {0} (create|list|describe) +main.usage.summary=\u4F7F\u7528\u65B9\u6CD5: {0} (create|list|describe|hash) \n\u4F7F\u7528\u53EF\u80FD\u306A\u30AA\u30D7\u30B7\u30E7\u30F3\u306E\u30EA\u30B9\u30C8\u306B\u3064\u3044\u3066\u306F\u3001--help\u3092\u4F7F\u7528\u3057\u307E\u3059 + +main.usage=\u4F7F\u7528\u65B9\u6CD5: {0} (create|list|describe|hash) error.prefix=\u30A8\u30E9\u30FC: warn.prefix=\u8B66\u544A: @@ -8,6 +33,7 @@ warn.prefix=\u8B66\u544A: main.opt.mode.create=create - \u65B0\u898F\u306Ejmod\u30A2\u30FC\u30AB\u30A4\u30D6\u3092\u4F5C\u6210\u3057\u307E\u3059 main.opt.mode.list=list - \u3059\u3079\u3066\u306E\u30A8\u30F3\u30C8\u30EA\u306E\u540D\u524D\u3092\u51FA\u529B\u3057\u307E\u3059 main.opt.mode.describe=describe - \u30E2\u30B8\u30E5\u30FC\u30EB\u306E\u8A73\u7D30\u3092\u51FA\u529B\u3057\u307E\u3059 +main.opt.mode.hash=hash - \u30E2\u30B8\u30E5\u30FC\u30EB\u306E\u30CF\u30C3\u30B7\u30E5\u3092\u8A18\u9332\u3057\u307E\u3059\u3002 main.opt.help=\u3053\u306E\u4F7F\u7528\u65B9\u6CD5\u306E\u30E1\u30C3\u30BB\u30FC\u30B8\u3092\u51FA\u529B\u3057\u307E\u3059 main.opt.version=\u30D0\u30FC\u30B8\u30E7\u30F3\u60C5\u5831 @@ -15,9 +41,9 @@ main.opt.class-path=\u30AF\u30E9\u30B9\u3092\u542B\u3080\u30A2\u30D7\u30EA\u30B1 main.opt.libs=\u30CD\u30A4\u30C6\u30A3\u30D6\u30FB\u30E9\u30A4\u30D6\u30E9\u30EA\u306E\u5834\u6240 main.opt.cmds=\u30CD\u30A4\u30C6\u30A3\u30D6\u30FB\u30B3\u30DE\u30F3\u30C9\u306E\u5834\u6240 main.opt.config=\u30E6\u30FC\u30B6\u30FC\u304C\u7DE8\u96C6\u53EF\u80FD\u306A\u69CB\u6210\u30D5\u30A1\u30A4\u30EB\u306E\u5834\u6240 +main.opt.dry-run=\u30CF\u30C3\u30B7\u30E5\u30FB\u30E2\u30FC\u30C9\u306E\u8A66\u9A13\u7684\u306A\u5B9F\u884C main.opt.exclude=PATTERN\u3068\u3057\u3066\u6307\u5B9A\u3055\u308C\u305F\u30D5\u30A1\u30A4\u30EB\u3092\u9664\u5916\u3057\u307E\u3059 main.opt.module-version= \u30E2\u30B8\u30E5\u30FC\u30EB\u30FB\u30D0\u30FC\u30B8\u30E7\u30F3 -main.opt.modulepath=\u30E2\u30B8\u30E5\u30FC\u30EB\u30FB\u30D1\u30B9 main.opt.main-class=\u30E1\u30A4\u30F3\u30FB\u30AF\u30E9\u30B9 main.opt.main-class.arg=class-name main.opt.os-name=\u30AA\u30DA\u30EC\u30FC\u30C6\u30A3\u30F3\u30B0\u30FB\u30B7\u30B9\u30C6\u30E0\u540D @@ -26,18 +52,22 @@ main.opt.os-arch=\u30AA\u30DA\u30EC\u30FC\u30C6\u30A3\u30F3\u30B0\u30FB\u30B7\u3 main.opt.os-arch.arg=os-arch main.opt.os-version=\u30AA\u30DA\u30EC\u30FC\u30C6\u30A3\u30F3\u30B0\u30FB\u30B7\u30B9\u30C6\u30E0\u30FB\u30D0\u30FC\u30B8\u30E7\u30F3 main.opt.os-version.arg=os-version -main.opt.hash-dependencies=\u30D1\u30BF\u30FC\u30F3\u306B\u4E00\u81F4\u3057\u305F\u4F9D\u5B58\u6027\u306E\u30CF\u30C3\u30B7\u30E5\u3092\u8A08\u7B97\u304A\u3088\u3073\u8A18\u9332\u3057\u307E\u3059 +main.opt.modulepath=\u30E2\u30B8\u30E5\u30FC\u30EB\u30FB\u30D1\u30B9 +main.opt.hash-modules=\u6307\u5B9A\u306E\u30D1\u30BF\u30FC\u30F3\u306B\u4E00\u81F4\u3057\u3001\u76F4\u63A5\u307E\u305F\u306F\u9593\u63A5\u7684\u306B\u4F9D\u5B58\u3057\u3066\u3044\u308B\u30E2\u30B8\u30E5\u30FC\u30EB\u3067\u30D1\u30C3\u30B1\u30FC\u30B8\u30FB\u30E2\u30B8\u30E5\u30FC\u30EB\u3092\u7D50\u5408\u3059\u308B\u30CF\u30C3\u30B7\u30E5\u3092\u8A08\u7B97\u304A\u3088\u3073\u8A18\u9332\u3057\u307E\u3059\u3002\u30CF\u30C3\u30B7\u30E5\u306F\u3001\u4F5C\u6210\u3055\u308C\u3066\u3044\u308BJMOD\u30D5\u30A1\u30A4\u30EB\u3001jmod hash\u30B3\u30DE\u30F3\u30C9\u3067\u6307\u5B9A\u3057\u305F\u30E2\u30B8\u30E5\u30FC\u30EB\u30FB\u30D1\u30B9\u306EJMOD\u30D5\u30A1\u30A4\u30EB\u307E\u305F\u306F\u30E2\u30B8\u30E5\u30E9JAR\u306B\u8A18\u9332\u3055\u308C\u307E\u3059\u3002 + main.opt.cmdfile=\u6307\u5B9A\u3057\u305F\u30D5\u30A1\u30A4\u30EB\u304B\u3089\u30AA\u30D7\u30B7\u30E7\u30F3\u3092\u8AAD\u307F\u53D6\u308A\u307E\u3059 -err.missing.mode=create\u3001list\u307E\u305F\u306Fdescribe\u306E\u3044\u305A\u308C\u304B\u3092\u6307\u5B9A\u3059\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059 -err.invalid.mode=\u30E2\u30FC\u30C9\u306Fcreate\u3001list\u307E\u305F\u306Fdescribe\u306E\u3044\u305A\u308C\u304B\u306B\u3059\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059: {0} +module.hashes.recorded=\u30E2\u30B8\u30E5\u30FC\u30EB{0}\u306E\u30CF\u30C3\u30B7\u30E5\u304C\u8A18\u9332\u3055\u308C\u307E\u3059 + +err.missing.mode=create\u3001list\u3001describe\u307E\u305F\u306Fhash\u306E\u3044\u305A\u308C\u304B\u3092\u6307\u5B9A\u3059\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059 +err.invalid.mode=\u30E2\u30FC\u30C9\u306Fcreate\u3001list\u3001describe\u307E\u305F\u306Fhash\u306E\u3044\u305A\u308C\u304B\u306B\u3059\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059: {0} err.classpath.must.be.specified=--class-path\u3092\u6307\u5B9A\u3059\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059 err.jmod.must.be.specified=jmod-file\u3092\u6307\u5B9A\u3059\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059 err.invalid.version=\u7121\u52B9\u306A\u30E2\u30B8\u30E5\u30FC\u30EB\u30FB\u30D0\u30FC\u30B8\u30E7\u30F3{0} -err.output.must.be.specified:--output\u3092\u6307\u5B9A\u3059\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059 -err.mods.must.be.specified:--mods\u3092\u6307\u5B9A\u3059\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059 -err.modulepath.must.be.specified:\u4F9D\u5B58\u6027\u306E\u30CF\u30C3\u30B7\u30E5\u6642\u306B\u306F--module-path\u3092\u6307\u5B9A\u3059\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059 -err.invalid.main-class:\u7121\u52B9\u306A\u30E1\u30A4\u30F3\u30AF\u30E9\u30B9\u540D: {0} +err.output.must.be.specified=--output\u3092\u6307\u5B9A\u3059\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059 +err.mods.must.be.specified=--mods\u3092\u6307\u5B9A\u3059\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059 +err.modulepath.must.be.specified=\u30E2\u30B8\u30E5\u30FC\u30EB\u306E\u30CF\u30C3\u30B7\u30E5\u6642\u306B\u306F--module-path\u3092\u6307\u5B9A\u3059\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059 +err.invalid.main-class=\u7121\u52B9\u306A\u30E1\u30A4\u30F3\u30AF\u30E9\u30B9\u540D: {0} err.path.not.found=\u30D1\u30B9\u304C\u898B\u3064\u304B\u308A\u307E\u305B\u3093: {0} err.path.not.valid=\u7121\u52B9\u306A\u30D1\u30B9: {0} err.path.not.a.dir=\u30D1\u30B9\u306F\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u3067\u3042\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059: {0} @@ -48,5 +78,9 @@ err.bad.pattern=\u4E0D\u6B63\u30D1\u30BF\u30FC\u30F3{0} err.unknown.option=\u4E0D\u660E\u306A\u30AA\u30D7\u30B7\u30E7\u30F3: {0} err.missing.arg={0}\u306B\u5024\u304C\u6307\u5B9A\u3055\u308C\u3066\u3044\u307E\u305B\u3093 err.internal.error=\u5185\u90E8\u30A8\u30E9\u30FC: {0} {1} {2} +err.invalid.dryrun.option=--dry-run\u306F\u30CF\u30C3\u30B7\u30E5\u30FB\u30E2\u30FC\u30C9\u3068\u4E00\u7DD2\u306B\u306E\u307F\u4F7F\u7528\u3067\u304D\u307E\u3059 err.module.descriptor.not.found=\u30E2\u30B8\u30E5\u30FC\u30EB\u30FB\u30C7\u30A3\u30B9\u30AF\u30EA\u30D7\u30BF\u304C\u898B\u3064\u304B\u308A\u307E\u305B\u3093 warn.invalid.arg=\u7121\u52B9\u306A\u30AF\u30E9\u30B9\u540D\u307E\u305F\u306F\u30D1\u30B9\u540D\u304C\u5B58\u5728\u3057\u307E\u305B\u3093: {0} +warn.no.module.hashes=\u30CF\u30C3\u30B7\u30E5\u304C\u8A18\u9332\u3055\u308C\u3066\u3044\u307E\u305B\u3093: {0}\u306B\u4F9D\u5B58\u3059\u308B\u30CF\u30C3\u30B7\u30E5\u306B\u5BFE\u3057\u3066\u30E2\u30B8\u30E5\u30FC\u30EB\u304C\u6307\u5B9A\u3055\u308C\u3066\u3044\u307E\u305B\u3093 +warn.module.resolution.fail=\u30CF\u30C3\u30B7\u30E5\u304C\u8A18\u9332\u3055\u308C\u3066\u3044\u307E\u305B\u3093: {0} + diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/resources/jmod_zh_CN.properties b/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/resources/jmod_zh_CN.properties index adb8d63b7e2..15cd753e3a1 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/resources/jmod_zh_CN.properties +++ b/jdk/src/jdk.jlink/share/classes/jdk/tools/jmod/resources/jmod_zh_CN.properties @@ -1,6 +1,31 @@ -main.usage.summary=\u7528\u6CD5: {0} (create|list|describe) \n\u4F7F\u7528 --help \u5217\u51FA\u53EF\u80FD\u7684\u9009\u9879 +# +# Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. +# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. +# +# This code is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License version 2 only, as +# published by the Free Software Foundation. Oracle designates this +# particular file as subject to the "Classpath" exception as provided +# by Oracle in the LICENSE file that accompanied this code. +# +# This code is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +# version 2 for more details (a copy is included in the LICENSE file that +# accompanied this code). +# +# You should have received a copy of the GNU General Public License version +# 2 along with this work; if not, write to the Free Software Foundation, +# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. +# +# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA +# or visit www.oracle.com if you need additional information or have any +# questions. +# -main.usage=\u7528\u6CD5: {0} (create|list|describe) +main.usage.summary=\u7528\u6CD5: {0} (create|list|describe|hash) <\u9009\u9879> \n\u4F7F\u7528 --help \u5217\u51FA\u53EF\u80FD\u7684\u9009\u9879 + +main.usage=\u7528\u6CD5: {0} (create|list|describe|hash) <\u9009\u9879> error.prefix=\u9519\u8BEF: warn.prefix=\u8B66\u544A: @@ -8,6 +33,7 @@ warn.prefix=\u8B66\u544A: main.opt.mode.create=create - \u521B\u5EFA\u65B0\u7684 jmod \u6863\u6848 main.opt.mode.list=list - \u8F93\u51FA\u6240\u6709\u6761\u76EE\u7684\u540D\u79F0 main.opt.mode.describe=describe - \u8F93\u51FA\u6A21\u5757\u8BE6\u7EC6\u4FE1\u606F +main.opt.mode.hash=hash - \u8BB0\u5F55\u7ED1\u5B9A\u6A21\u5757\u7684\u6563\u5217\u3002 main.opt.help=\u8F93\u51FA\u6B64\u7528\u6CD5\u6D88\u606F main.opt.version=\u7248\u672C\u4FE1\u606F @@ -15,9 +41,9 @@ main.opt.class-path=\u5305\u542B\u7C7B\u7684\u5E94\u7528\u7A0B\u5E8F jar \u6587\ main.opt.libs=\u672C\u673A\u5E93\u7684\u4F4D\u7F6E main.opt.cmds=\u672C\u673A\u547D\u4EE4\u7684\u4F4D\u7F6E main.opt.config=\u7528\u6237\u53EF\u7F16\u8F91\u914D\u7F6E\u6587\u4EF6\u7684\u4F4D\u7F6E +main.opt.dry-run=\u6563\u5217\u6A21\u5F0F\u7684\u6A21\u62DF\u8FD0\u884C main.opt.exclude=\u6392\u9664\u4EE5\u6A21\u5F0F\u6307\u5B9A\u7684\u6587\u4EF6 main.opt.module-version= \u6A21\u5757\u7248\u672C -main.opt.modulepath=\u6A21\u5757\u8DEF\u5F84 main.opt.main-class=\u4E3B\u7C7B main.opt.main-class.arg=class-name main.opt.os-name=\u64CD\u4F5C\u7CFB\u7EDF\u540D\u79F0 @@ -26,18 +52,22 @@ main.opt.os-arch=\u64CD\u4F5C\u7CFB\u7EDF\u4F53\u7CFB\u7ED3\u6784 main.opt.os-arch.arg=os-arch main.opt.os-version=\u64CD\u4F5C\u7CFB\u7EDF\u7248\u672C main.opt.os-version.arg=os-version -main.opt.hash-dependencies=\u8BA1\u7B97\u548C\u8BB0\u5F55\u6309\u6A21\u5F0F\u5339\u914D\u7684\u88AB\u4F9D\u8D56\u5BF9\u8C61\u7684\u6563\u5217 +main.opt.modulepath=\u6A21\u5757\u8DEF\u5F84 +main.opt.hash-modules=\u8BA1\u7B97\u548C\u8BB0\u5F55\u6563\u5217, \u4EE5\u5C06\u6253\u5305\u6A21\u5757\u7ED1\u5B9A\u5230\u4E0E\u6307\u5B9A\u6A21\u5F0F\u5339\u914D\u5E76\u76F4\u63A5\u6216\u95F4\u63A5\u4F9D\u8D56\u4E8E\u7684\u6A21\u5757\u3002\u6563\u5217\u8BB0\u5F55\u5728\u6240\u521B\u5EFA\u7684 JMOD \u6587\u4EF6\u4E2D, \u6216\u8005\u8BB0\u5F55\u5728 jmod hash \u547D\u4EE4\u6307\u5B9A\u7684\u6A21\u5757\u8DEF\u5F84\u7684 JMOD \u6587\u4EF6\u6216\u6A21\u5757\u5316 JAR \u4E2D\u3002 + main.opt.cmdfile=\u4ECE\u6307\u5B9A\u6587\u4EF6\u8BFB\u53D6\u9009\u9879 -err.missing.mode=\u5FC5\u987B\u6307\u5B9A\u521B\u5EFA, \u5217\u51FA\u6216\u63CF\u8FF0\u4E4B\u4E00 -err.invalid.mode=\u6A21\u5F0F\u5FC5\u987B\u4E3A\u521B\u5EFA, \u5217\u51FA\u6216\u63CF\u8FF0\u4E4B\u4E00: {0} +module.hashes.recorded=\u6563\u5217\u8BB0\u5F55\u5728\u6A21\u5757 {0} \u4E2D + +err.missing.mode=\u5FC5\u987B\u6307\u5B9A\u521B\u5EFA, \u5217\u51FA, \u63CF\u8FF0\u6216\u6563\u5217\u4E4B\u4E00 +err.invalid.mode=\u6A21\u5F0F\u5FC5\u987B\u4E3A\u521B\u5EFA, \u5217\u51FA, \u63CF\u8FF0\u6216\u6563\u5217\u4E4B\u4E00: {0} err.classpath.must.be.specified=\u5FC5\u987B\u6307\u5B9A --class-path err.jmod.must.be.specified=\u5FC5\u987B\u6307\u5B9A jmod-file err.invalid.version=\u65E0\u6548\u7684\u6A21\u5757\u7248\u672C {0} -err.output.must.be.specified:\u5FC5\u987B\u6307\u5B9A --output -err.mods.must.be.specified:\u5FC5\u987B\u6307\u5B9A --mods -err.modulepath.must.be.specified:\u5BF9\u88AB\u4F9D\u8D56\u5BF9\u8C61\u8FDB\u884C\u6563\u5217\u5904\u7406\u65F6\u5FC5\u987B\u6307\u5B9A --module-path -err.invalid.main-class:\u65E0\u6548\u7684\u4E3B\u7C7B\u540D\u79F0: {0} +err.output.must.be.specified=\u5FC5\u987B\u6307\u5B9A --output +err.mods.must.be.specified=\u5FC5\u987B\u6307\u5B9A --mods +err.modulepath.must.be.specified=\u5BF9\u6A21\u5757\u8FDB\u884C\u6563\u5217\u5904\u7406\u65F6\u5FC5\u987B\u6307\u5B9A --module-path +err.invalid.main-class=\u65E0\u6548\u7684\u4E3B\u7C7B\u540D\u79F0: {0} err.path.not.found=\u627E\u4E0D\u5230\u8DEF\u5F84: {0} err.path.not.valid=\u65E0\u6548\u8DEF\u5F84: {0} err.path.not.a.dir=\u8DEF\u5F84\u5FC5\u987B\u4E3A\u76EE\u5F55: {0} @@ -48,5 +78,9 @@ err.bad.pattern=\u9519\u8BEF\u7684\u6A21\u5F0F {0} err.unknown.option=\u672A\u77E5\u9009\u9879: {0} err.missing.arg=\u6CA1\u6709\u4E3A{0}\u6307\u5B9A\u503C err.internal.error=\u5185\u90E8\u9519\u8BEF: {0} {1} {2} +err.invalid.dryrun.option=--dry-run \u53EA\u80FD\u7528\u4E8E\u6563\u5217\u6A21\u5F0F err.module.descriptor.not.found=\u627E\u4E0D\u5230\u6A21\u5757\u63CF\u8FF0\u7B26 warn.invalid.arg=\u7C7B\u540D\u65E0\u6548\u6216\u8DEF\u5F84\u540D\u4E0D\u5B58\u5728: {0} +warn.no.module.hashes=\u672A\u8BB0\u5F55\u4EFB\u4F55\u6563\u5217: \u6CA1\u6709\u4E3A\u4F9D\u8D56\u4E8E {0} \u7684\u6563\u5217\u5904\u7406\u6307\u5B9A\u6A21\u5757 +warn.module.resolution.fail=\u672A\u8BB0\u5F55\u4EFB\u4F55\u6563\u5217: {0} + diff --git a/jdk/src/jdk.jlink/share/classes/module-info.java b/jdk/src/jdk.jlink/share/classes/module-info.java index b2ce1fd94bd..0b1995129f2 100644 --- a/jdk/src/jdk.jlink/share/classes/module-info.java +++ b/jdk/src/jdk.jlink/share/classes/module-info.java @@ -39,9 +39,9 @@ module jdk.jlink { provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.StripNativeCommandsPlugin; provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.OrderResourcesPlugin; provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.DefaultCompressPlugin; - provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.OptimizationPlugin; provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.ExcludeVMPlugin; provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.IncludeLocalesPlugin; provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.GenerateJLIClassesPlugin; provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.ReleaseInfoPlugin; -} + provides jdk.tools.jlink.plugin.Plugin with jdk.tools.jlink.internal.plugins.ClassForNamePlugin; + } diff --git a/jdk/src/jdk.rmic/share/classes/sun/tools/javac/resources/javac_ja.properties b/jdk/src/jdk.rmic/share/classes/sun/tools/javac/resources/javac_ja.properties index 4623edb734d..985e7acd75f 100644 --- a/jdk/src/jdk.rmic/share/classes/sun/tools/javac/resources/javac_ja.properties +++ b/jdk/src/jdk.rmic/share/classes/sun/tools/javac/resources/javac_ja.properties @@ -1,5 +1,5 @@ # -# Copyright (c) 1996, 2011, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -141,6 +141,7 @@ javac.err.invoke.abstract={1}\u306E\u30E1\u30BD\u30C3\u30C9{0}\u306Fabstract\u30 javac.err.unmatched.meth={0}\u306B\u9069\u5408\u3059\u308B\u30E1\u30BD\u30C3\u30C9\u304C{1}\u306B\u306F\u3042\u308A\u307E\u305B\u3093\u3002 javac.err.unmatched.constr={0}\u306B\u9069\u5408\u3059\u308B\u30B3\u30F3\u30B9\u30C8\u30E9\u30AF\u30BF\u304C{1}\u306B\u306F\u3042\u308A\u307E\u305B\u3093\u3002 javac.err.wrong.number.args={0}\u306E\u5F15\u6570\u306E\u6570\u304C\u4E0D\u6B63\u3067\u3059\u3002 +javac.err.wrong.number.args={0}\u306E\u5F15\u6570\u306E\u6570\u304C\u4E0D\u6B63\u3067\u3059\u3002 javac.err.forward.ref={1}\u3067\u306F{0}\u306B\u524D\u65B9\u53C2\u7167\u3059\u308B\u3053\u3068\u306F\u3067\u304D\u307E\u305B\u3093\u3002 javac.err.array.dim.missing=\u914D\u5217\u306E\u5927\u304D\u3055\u304C\u6307\u5B9A\u3055\u308C\u3066\u3044\u307E\u305B\u3093\u3002 javac.err.new.abstract={0}\u306Fabstract\u30AF\u30E9\u30B9\u3067\u3059\u3002\u30A4\u30F3\u30B9\u30BF\u30F3\u30B9\u3092\u751F\u6210\u3059\u308B\u3053\u3068\u306F\u3067\u304D\u307E\u305B\u3093\u3002 @@ -256,8 +257,8 @@ javac.err.catch.not.throwable=\u4F8B\u5916{0}\u306F\u6355\u6349\u3067\u304D\u307 javac.err.initializer.exception=\u521D\u671F\u5316\u5B50\u5185\u3067\u306F\u4F8B\u5916{0}\u3092\u30B9\u30ED\u30FC\u3067\u304D\u307E\u305B\u3093\u3002 javac.err.cant.read={0}\u3092\u8AAD\u307F\u8FBC\u3081\u307E\u305B\u3093 javac.err.cant.write={0}\u304C\u66F8\u304D\u8FBC\u3081\u307E\u305B\u3093 -javac.err.fatal.error=\u30B3\u30F3\u30D1\u30A4\u30E9\u5185\u90E8\u3067\u30A8\u30E9\u30FC\u304C\u767A\u751F\u3057\u307E\u3057\u305F\u3002http://java.sun.com/cgi-bin/bugreport.cgi\u3067\u30D0\u30B0\u5831\u544A\u3092\u3057\u3066\u304F\u3060\u3055\u3044\u3002 -javac.err.fatal.exception=\u30B3\u30F3\u30D1\u30A4\u30E9\u5185\u90E8\u3067\u4F8B\u5916\u304C\u767A\u751F\u3057\u307E\u3057\u305F\u3002http://java.sun.com/cgi-bin/bugreport.cgi\u3067\u30D0\u30B0\u5831\u544A\u3092\u3057\u3066\u304F\u3060\u3055\u3044\u3002 +javac.err.fatal.error=\u30B3\u30F3\u30D1\u30A4\u30E9\u5185\u90E8\u3067\u30A8\u30E9\u30FC\u304C\u767A\u751F\u3057\u307E\u3057\u305F\u3002http://bugreport.java.com/bugreport/\u3067\u30D0\u30B0\u5831\u544A\u3092\u3057\u3066\u304F\u3060\u3055\u3044\u3002 +javac.err.fatal.exception=\u30B3\u30F3\u30D1\u30A4\u30E9\u5185\u90E8\u3067\u4F8B\u5916\u304C\u767A\u751F\u3057\u307E\u3057\u305F\u3002http://bugreport.java.com/bugreport/\u3067\u30D0\u30B0\u5831\u544A\u3092\u3057\u3066\u304F\u3060\u3055\u3044\u3002 javac.err.no.inner.classes=\u5185\u90E8\u30AF\u30E9\u30B9\u306E\u30B5\u30DD\u30FC\u30C8\u306F\u4E2D\u6B62\u3055\u308C\u307E\u3057\u305F\u3002 javac.err.uncaught.exception=\u4F8B\u5916{0}\u306F\u6355\u6349\u3055\u308C\u308B\u304B\u3001\u3042\u308B\u3044\u306F\u3053\u306E\u30E1\u30BD\u30C3\u30C9\u306Ethrows\u7BC0\u3067\u5BA3\u8A00\u3055\u308C\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059\u3002 javac.err.constructor.exception=\u4F8B\u5916{0}\u306F\u6355\u6349\u3055\u308C\u308B\u304B\u3001\u307E\u305F\u306F\u3053\u306E\u30B3\u30F3\u30B9\u30C8\u30E9\u30AF\u30BF\u306Ethrows\u7BC0\u3067\u5BA3\u8A00\u3055\u308C\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059\u3002 @@ -291,9 +292,9 @@ benv.parsed_in=[{0}\u3092{1}\u30DF\u30EA\u79D2\u3067\u69CB\u6587\u89E3\u6790\u30 benv.loaded_in=[{0}\u3092{1}\u30DF\u30EA\u79D2\u3067\u8AAD\u307F\u8FBC\u307F\u307E\u3057\u305F] benv.failed_to_close_class_path=\u30AF\u30E9\u30B9\u30D1\u30B9: {0}\u3092\u9589\u3058\u308B\u3053\u3068\u304C\u3067\u304D\u307E\u305B\u3093\u3067\u3057\u305F # -main.usage=\u4F7F\u7528\u65B9\u6CD5: {0} \n\n\u306B\u306F\u6B21\u306E\u3082\u306E\u304C\u3042\u308A\u307E\u3059\u3002\n\\ -g \u3059\u3079\u3066\u306E\u30C7\u30D0\u30C3\u30B0\u60C5\u5831\u3092\u751F\u6210\u3059\u308B\n\\ -g:none \u30C7\u30D0\u30C3\u30B0\u60C5\u5831\u3092\u751F\u6210\u3057\u306A\u3044\n\\ -g:''{''lines,vars,source''}''\u3044\u304F\u3064\u304B\u306E\u30C7\u30D0\u30C3\u30B0\u60C5\u5831\u306E\u307F\u3092\u751F\u6210\u3059\u308B\n\\ -O \u6700\u9069\u5316;\u30C7\u30D0\u30C3\u30B0\u3092\u6291\u5236\u3057\u3001\u30AF\u30E9\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u3092\u5927\u304D\u304F\u3059\u308B\n\\ -nowarn \u8B66\u544A\u3092\u767A\u751F\u3055\u305B\u306A\u3044\n\\ -verbose \u30B3\u30F3\u30D1\u30A4\u30E9\u306E\u52D5\u4F5C\u306B\u3064\u3044\u3066\u30E1\u30C3\u30BB\u30FC\u30B8\u3092\u51FA\u529B\u3059\u308B\n\\ -deprecation \u63A8\u5968\u3055\u308C\u306A\u3044API\u304C\u4F7F\u7528\u3055\u308C\u3066\u3044\u308B\u30BD\u30FC\u30B9\u306E\u4F4D\u7F6E\u3092\u51FA\u529B\u3059\u308B\n\\ -classpath \u30E6\u30FC\u30B6\u30FC\u30FB\u30AF\u30E9\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u306E\u3042\u308B\u5834\u6240\u3092\u6307\u5B9A\u3059\u308B\n\\ -sourcepath \u5165\u529B\u30BD\u30FC\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u306E\u3042\u308B\u5834\u6240\u3092\u6307\u5B9A\u3059\u308B\n\\ -bootclasspath \u30D6\u30FC\u30C8\u30B9\u30C8\u30E9\u30C3\u30D7\u30FB\u30AF\u30E9\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u306E\u4F4D\u7F6E\u3092\u30AA\u30FC\u30D0\u30FC\u30E9\u30A4\u30C9\u3059\u308B\n\\ -extdirs \u62E1\u5F35\u6A5F\u80FD\u304C\u30A4\u30F3\u30B9\u30C8\u30FC\u30EB\u3055\u308C\u305F\u4F4D\u7F6E\u3092\u30AA\u30FC\u30D0\u30FC\u30E9\u30A4\u30C9\u3059\u308B\n\\ -d \u751F\u6210\u3055\u308C\u305F\u30AF\u30E9\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u3092\u683C\u7D0D\u3059\u308B\u5834\u6240\u3092\u30AA\u30FC\u30D0\u30FC\u30E9\u30A4\u30C9\u3059\u308B\n\\ -encoding \u30BD\u30FC\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u304C\u4F7F\u7528\u3059\u308B\u6587\u5B57\u30A8\u30F3\u30B3\u30FC\u30C7\u30A3\u30F3\u30B0\u3092\u6307\u5B9A\u3059\u308B\n\\ -target \u7279\u5B9A\u306EVM\u30D0\u30FC\u30B8\u30E7\u30F3\u7528\u306E\u30AF\u30E9\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u3092\u751F\u6210\u3059\u308B +main.usage=\u4F7F\u7528\u65B9\u6CD5: {0} \n\n\u306B\u306F\u6B21\u306E\u3082\u306E\u304C\u3042\u308A\u307E\u3059\u3002\n\\ -g \u3059\u3079\u3066\u306E\u30C7\u30D0\u30C3\u30B0\u60C5\u5831\u3092\u751F\u6210\u3059\u308B\n\\ -g:none \u30C7\u30D0\u30C3\u30B0\u60C5\u5831\u3092\u751F\u6210\u3057\u306A\u3044\n\\ -g:'{'lines,vars,source'}'\u3044\u304F\u3064\u304B\u306E\u30C7\u30D0\u30C3\u30B0\u60C5\u5831\u306E\u307F\u3092\u751F\u6210\u3059\u308B\n\\ -O \u6700\u9069\u5316;\u30C7\u30D0\u30C3\u30B0\u3092\u6291\u5236\u3057\u3001\u30AF\u30E9\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u3092\u5927\u304D\u304F\u3059\u308B\n\\ -nowarn \u8B66\u544A\u3092\u767A\u751F\u3055\u305B\u306A\u3044\n\\ -verbose \u30B3\u30F3\u30D1\u30A4\u30E9\u306E\u52D5\u4F5C\u306B\u3064\u3044\u3066\u30E1\u30C3\u30BB\u30FC\u30B8\u3092\u51FA\u529B\u3059\u308B\n\\ -deprecation \u63A8\u5968\u3055\u308C\u306A\u3044API\u304C\u4F7F\u7528\u3055\u308C\u3066\u3044\u308B\u30BD\u30FC\u30B9\u306E\u4F4D\u7F6E\u3092\u51FA\u529B\u3059\u308B\n\\ -classpath \u30E6\u30FC\u30B6\u30FC\u30FB\u30AF\u30E9\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u306E\u3042\u308B\u5834\u6240\u3092\u6307\u5B9A\u3059\u308B\n\\ -sourcepath \u5165\u529B\u30BD\u30FC\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u306E\u3042\u308B\u5834\u6240\u3092\u6307\u5B9A\u3059\u308B\n\\ -bootclasspath \u30D6\u30FC\u30C8\u30B9\u30C8\u30E9\u30C3\u30D7\u30FB\u30AF\u30E9\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u306E\u4F4D\u7F6E\u3092\u30AA\u30FC\u30D0\u30FC\u30E9\u30A4\u30C9\u3059\u308B\n\\ -extdirs \u62E1\u5F35\u6A5F\u80FD\u304C\u30A4\u30F3\u30B9\u30C8\u30FC\u30EB\u3055\u308C\u305F\u4F4D\u7F6E\u3092\u30AA\u30FC\u30D0\u30FC\u30E9\u30A4\u30C9\u3059\u308B\n\\ -d \u751F\u6210\u3055\u308C\u305F\u30AF\u30E9\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u3092\u683C\u7D0D\u3059\u308B\u5834\u6240\u3092\u30AA\u30FC\u30D0\u30FC\u30E9\u30A4\u30C9\u3059\u308B\n\\ -encoding \u30BD\u30FC\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u304C\u4F7F\u7528\u3059\u308B\u6587\u5B57\u30A8\u30F3\u30B3\u30FC\u30C7\u30A3\u30F3\u30B0\u3092\u6307\u5B9A\u3059\u308B\n\\ -target \u7279\u5B9A\u306EVM\u30D0\u30FC\u30B8\u30E7\u30F3\u7528\u306E\u30AF\u30E9\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u3092\u751F\u6210\u3059\u308B # -main.unsupported.usage=\ \ -Xdepend \u518D\u30B3\u30F3\u30D1\u30A4\u30EB\u306E\u305F\u3081\u306E\u3055\u3089\u306B\u65B0\u3057\u3044\u30D5\u30A1\u30A4\u30EB\u3092\u518D\u5E30\u7684\u306B\u691C\u7D22\u3059\u308B\n\\ -Xstdout \u30E1\u30C3\u30BB\u30FC\u30B8\u3092System.out\u306B\u9001\u308B\n\\ -Xverbosepath \u30D1\u30B9\u3068\u6A19\u6E96\u62E1\u5F35\u6A5F\u80FD\u306E\u691C\u7D22\u65B9\u6CD5\u3092\u8A18\u8FF0\u3059\u308B\n\\ -J \u5F15\u6570\u3092Java\u30A4\u30F3\u30BF\u30FC\u30D7\u30EA\u30BF\u306B\u6E21\u3059\n\n-X\u304A\u3088\u3073-J\u30AA\u30D7\u30B7\u30E7\u30F3\u306F\u6A19\u6E96\u3067\u306F\u306A\u304F\u3001\u4E88\u544A\u306A\u3057\u306B\u5909\u66F4\u3055\u308C\u308B\u53EF\u80FD\u6027\u304C\u3042\u308A\u307E\u3059\u3002 +main.unsupported.usage=\ -Xdepend \u518D\u30B3\u30F3\u30D1\u30A4\u30EB\u306E\u305F\u3081\u306E\u3055\u3089\u306B\u65B0\u3057\u3044\u30D5\u30A1\u30A4\u30EB\u3092\u518D\u5E30\u7684\u306B\u691C\u7D22\u3059\u308B\n\\ -Xstdout \u30E1\u30C3\u30BB\u30FC\u30B8\u3092System.out\u306B\u9001\u308B\n\\ -Xverbosepath \u30D1\u30B9\u3068\u6A19\u6E96\u62E1\u5F35\u6A5F\u80FD\u306E\u691C\u7D22\u65B9\u6CD5\u3092\u8A18\u8FF0\u3059\u308B\n\\ -J \u5F15\u6570\u3092Java\u30A4\u30F3\u30BF\u30FC\u30D7\u30EA\u30BF\u306B\u6E21\u3059\n\n-X\u304A\u3088\u3073-J\u30AA\u30D7\u30B7\u30E7\u30F3\u306F\u6A19\u6E96\u3067\u306F\u306A\u304F\u3001\u4E88\u544A\u306A\u3057\u306B\u5909\u66F4\u3055\u308C\u308B\u53EF\u80FD\u6027\u304C\u3042\u308A\u307E\u3059\u3002 # main.conflicting.options=\u30AA\u30D7\u30B7\u30E7\u30F3{0}\u3068{1}\u306F\u540C\u6642\u306B\u306F\u4F7F\u7528\u3057\u307E\u305B\u3093\u3002 main.option.already.seen={0}\u30AA\u30D7\u30B7\u30E7\u30F3\u304C\u8907\u6570\u6307\u5B9A\u3055\u308C\u3066\u3044\u307E\u3059\u3002 @@ -311,4 +312,4 @@ main.done_in=[{0}\u30DF\u30EA\u79D2\u3067\u5B8C\u4E86] main.no.memory=\u30B3\u30F3\u30D1\u30A4\u30E9\u306B\u30E1\u30E2\u30EA\u30FC\u304C\u4E0D\u8DB3\u3057\u3066\u3044\u307E\u3059\u3002"-J-mx"\u30B3\u30DE\u30F3\u30C9\u30E9\u30A4\u30F3\u30FB\u30AA\u30D7\u30B7\u30E7\u30F3\u3092\u4F7F\u7528\u3057\u3066\u3001\u6700\u5927\u30D2\u30FC\u30D7\u30FB\u30B5\u30A4\u30BA\u3092\u5897\u3084\u3057\u3066\u304F\u3060\u3055\u3044\u3002 main.stack.overflow=\u30B3\u30F3\u30D1\u30A4\u30E9\u306B\u30B9\u30BF\u30C3\u30AF\u7A7A\u9593\u304C\u4E0D\u8DB3\u3057\u3066\u3044\u307E\u3059\u3002"-J-oss"\u30B3\u30DE\u30F3\u30C9\u30E9\u30A4\u30F3\u30FB\u30AA\u30D7\u30B7\u30E7\u30F3\u3092\u4F7F\u7528\u3057\u3066\u3001Java\u30B9\u30BF\u30C3\u30AF\u306B\u5272\u308A\u5F53\u3066\u308B\u30E1\u30E2\u30EA\u30FC\u3092\u5897\u3084\u3057\u3066\u304F\u3060\u3055\u3044\u3002 main.path.msg=[\u30BD\u30FC\u30B9\u30FB\u30AF\u30E9\u30B9\u30D1\u30B9\u306F"{0}"\u3067\u3059]\n[\u30E9\u30A4\u30D6\u30E9\u30EA\u30FB\u30AF\u30E9\u30B9\u30D1\u30B9\u306F "{1}"\u3067\u3059] -javac.err.invalid.encoding.char=\u3053\u306E\u30BD\u30FC\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u306E\u30A8\u30F3\u30B3\u30FC\u30C7\u30A3\u30F3\u30B0\u304C\u30D7\u30E9\u30C3\u30C8\u30D5\u30A9\u30FC\u30E0\u306E\u3082\u306E\u3068\u7570\u306A\u3063\u3066\u3044\u308B\u53EF\u80FD\u6027\u304C\u3042\u308A\u307E\u3059\u3002-encoding\u30AA\u30D7\u30B7\u30E7\u30F3\u3092\u6307\u5B9A\u3057\u3066\u30D5\u30A1\u30A4\u30EB\u306E\u30A8\u30F3\u30B3\u30FC\u30C7\u30A3\u30F3\u30B0\u3092\u6307\u5B9A\u3059\u308B\u304B\u3001\u307E\u305F\u306Fnative2ascii\u30E6\u30FC\u30C6\u30A3\u30EA\u30C6\u30A3\u3092\u4F7F\u7528\u3057\u3066\u30BD\u30FC\u30B9\u30FB\u30B3\u30FC\u30C9\u3092ASCII\u6587\u5B57\u306E\u307F\u306B\u3057\u3066\u304F\u3060\u3055\u3044\u3002 +javac.err.invalid.encoding.char=\u3053\u306E\u30BD\u30FC\u30B9\u30FB\u30D5\u30A1\u30A4\u30EB\u306E\u30A8\u30F3\u30B3\u30FC\u30C7\u30A3\u30F3\u30B0\u304C\u30D7\u30E9\u30C3\u30C8\u30D5\u30A9\u30FC\u30E0\u306E\u3082\u306E\u3068\u7570\u306A\u3063\u3066\u3044\u308B\u53EF\u80FD\u6027\u304C\u3042\u308A\u307E\u3059\u3002-encoding\u30AA\u30D7\u30B7\u30E7\u30F3\u3092\u6307\u5B9A\u3057\u3066\u30D5\u30A1\u30A4\u30EB\u306E\u30A8\u30F3\u30B3\u30FC\u30C7\u30A3\u30F3\u30B0\u3092\u5909\u66F4\u3059\u308B\u304B\u3001\u307E\u305F\u306F\u30D5\u30A1\u30A4\u30EB\u306F\u5FC5\u305AASCII\u30A8\u30F3\u30B3\u30FC\u30C7\u30A3\u30F3\u30B0\u306B\u5909\u63DB\u3057\u3066\u304F\u3060\u3055\u3044\u3002 diff --git a/jdk/src/jdk.rmic/share/classes/sun/tools/javac/resources/javac_zh_CN.properties b/jdk/src/jdk.rmic/share/classes/sun/tools/javac/resources/javac_zh_CN.properties index 20e128bf703..4719fb5e676 100644 --- a/jdk/src/jdk.rmic/share/classes/sun/tools/javac/resources/javac_zh_CN.properties +++ b/jdk/src/jdk.rmic/share/classes/sun/tools/javac/resources/javac_zh_CN.properties @@ -1,5 +1,5 @@ # -# Copyright (c) 1996, 2011, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -141,6 +141,7 @@ javac.err.invoke.abstract=\u65E0\u6CD5\u5728{1}\u4E2D\u76F4\u63A5\u8C03\u7528\u6 javac.err.unmatched.meth=\u5728{1}\u4E2D\u627E\u4E0D\u5230\u4E0E{0}\u5339\u914D\u7684\u65B9\u6CD5\u3002 javac.err.unmatched.constr=\u5728{1}\u4E2D\u627E\u4E0D\u5230\u4E0E{0}\u5339\u914D\u7684\u6784\u9020\u5668\u3002 javac.err.wrong.number.args={0}\u4E2D\u7684\u53C2\u6570\u6570\u76EE\u9519\u8BEF\u3002 +javac.err.wrong.number.args={0}\u4E2D\u7684\u53C2\u6570\u6570\u76EE\u9519\u8BEF\u3002 javac.err.forward.ref=\u65E0\u6CD5\u524D\u5411\u5F15\u7528{1}\u4E2D\u7684{0}\u3002 javac.err.array.dim.missing=\u7F3A\u5C11\u6570\u7EC4\u7EF4\u3002 javac.err.new.abstract={0}\u662F\u62BD\u8C61\u7C7B\u3002\u65E0\u6CD5\u5B9E\u4F8B\u5316\u3002 @@ -256,8 +257,8 @@ javac.err.catch.not.throwable=\u65E0\u6CD5\u6355\u83B7{0}; \u5B83\u5FC5\u987B\u4 javac.err.initializer.exception=\u4E0D\u80FD\u5728\u521D\u59CB\u5316\u7A0B\u5E8F\u4E2D\u629B\u51FA\u5F02\u5E38\u9519\u8BEF{0}\u3002 javac.err.cant.read=\u65E0\u6CD5\u8BFB\u53D6: {0} javac.err.cant.write=\u65E0\u6CD5\u5199\u5165: {0} -javac.err.fatal.error=\u7F16\u8BD1\u5668\u51FA\u9519; \u8BF7\u5EFA\u7ACB Bug \u62A5\u544A (http://java.sun.com/cgi-bin/bugreport.cgi)\u3002 -javac.err.fatal.exception=\u7F16\u8BD1\u5668\u4E2D\u51FA\u73B0\u5F02\u5E38\u9519\u8BEF; \u8BF7\u5EFA\u7ACB Bug \u62A5\u544A (http://java.sun.com/cgi-bin/bugreport.cgi)\u3002 +javac.err.fatal.error=\u7F16\u8BD1\u5668\u51FA\u9519; \u8BF7\u5EFA\u7ACB Bug \u62A5\u544A (http://bugreport.java.com/bugreport/)\u3002 +javac.err.fatal.exception=\u7F16\u8BD1\u5668\u51FA\u73B0\u5F02\u5E38\u9519\u8BEF; \u8BF7\u5EFA\u7ACB Bug \u62A5\u544A (http://bugreport.java.com/bugreport/)\u3002 javac.err.no.inner.classes=\u5DF2\u7981\u7528\u5BF9\u5185\u90E8\u7C7B\u7684\u652F\u6301\u3002 javac.err.uncaught.exception=\u5FC5\u987B\u6355\u83B7\u5F02\u5E38\u9519\u8BEF{0}, \u5426\u5219\u5FC5\u987B\u5728\u6B64\u65B9\u6CD5\u7684 throws \u5B50\u53E5\u4E2D\u5BF9\u5176\u8FDB\u884C\u58F0\u660E\u3002 javac.err.constructor.exception=\u5FC5\u987B\u6355\u83B7\u5F02\u5E38\u9519\u8BEF{0}, \u5426\u5219\u5FC5\u987B\u5728\u6B64\u6784\u9020\u5668\u7684 throws \u5B50\u53E5\u4E2D\u5BF9\u5176\u8FDB\u884C\u58F0\u660E\u3002 @@ -291,9 +292,9 @@ benv.parsed_in=[\u5DF2\u5728 {1} \u6BEB\u79D2\u5185\u5BF9{0}\u8FDB\u884C\u8BED\u benv.loaded_in=[\u5DF2\u5728 {1} \u6BEB\u79D2\u5185\u52A0\u8F7D{0}] benv.failed_to_close_class_path=\u65E0\u6CD5\u5173\u95ED\u7C7B\u8DEF\u5F84: {0} # -main.usage=\u7528\u6CD5: {0} \n\n\u5176\u4E2D \u5305\u62EC:\n\ \ -g \u751F\u6210\u6240\u6709\u8C03\u8BD5\u4FE1\u606F\n\ \ -g:none \u4E0D\u751F\u6210\u4EFB\u4F55\u8C03\u8BD5\u4FE1\u606F\n\ \ -g:''{''lines,vars,source''}'' \u53EA\u751F\u6210\u67D0\u4E9B\u8C03\u8BD5\u4FE1\u606F\n\ \ -O \u4F18\u5316; \u53EF\u4EE5\u963B\u788D\u8C03\u8BD5\u6216\u6269\u5927\u7C7B\u6587\u4EF6\n\ \ -nowarn \u4E0D\u751F\u6210\u4EFB\u4F55\u8B66\u544A\n\ \ -verbose \u8F93\u51FA\u6709\u5173\u7F16\u8BD1\u5668\u6B63\u5728\u6267\u884C\u7684\u64CD\u4F5C\u7684\u6D88\u606F\n\ \ -deprecation \u8F93\u51FA\u4F7F\u7528\u5DF2\u8FC7\u65F6\u7684 API \u7684\u6E90\u4F4D\u7F6E\n\ \ -classpath \u6307\u5B9A\u67E5\u627E\u7528\u6237\u7C7B\u6587\u4EF6\u7684\u4F4D\u7F6E\n\ \ -sourcepath \u6307\u5B9A\u67E5\u627E\u8F93\u5165\u6E90\u6587\u4EF6\u7684\u4F4D\u7F6E\n\ \ -bootclasspath \u8986\u76D6\u5F15\u5BFC\u7C7B\u6587\u4EF6\u7684\u4F4D\u7F6E\n\ \ -extdirs \u8986\u76D6\u6240\u5B89\u88C5\u6269\u5C55\u7684\u4F4D\u7F6E\n\ \ -d \u6307\u5B9A\u653E\u7F6E\u751F\u6210\u7684\u7C7B\u6587\u4EF6\u7684\u4F4D\u7F6E\n\ \ -encoding \u6307\u5B9A\u6E90\u6587\u4EF6\u4F7F\u7528\u7684\u5B57\u7B26\u7F16\u7801\n\ \ -target \u751F\u6210\u7279\u5B9A VM \u7248\u672C\u7684\u7C7B\u6587\u4EF6 +main.usage=\u7528\u6CD5: {0} \n\n\u5176\u4E2D \u5305\u62EC:\n -g \u751F\u6210\u6240\u6709\u8C03\u8BD5\u4FE1\u606F\n -g:none \u4E0D\u751F\u6210\u4EFB\u4F55\u8C03\u8BD5\u4FE1\u606F\n -g:'{'lines,vars,source'}' \u53EA\u751F\u6210\u67D0\u4E9B\u8C03\u8BD5\u4FE1\u606F\n -O \u4F18\u5316; \u53EF\u4EE5\u963B\u788D\u8C03\u8BD5\u6216\u6269\u5927\u7C7B\u6587\u4EF6\n -nowarn \u4E0D\u751F\u6210\u4EFB\u4F55\u8B66\u544A\n -verbose \u8F93\u51FA\u6709\u5173\u7F16\u8BD1\u5668\u6B63\u5728\u6267\u884C\u7684\u64CD\u4F5C\u7684\u6D88\u606F\n -deprecation \u8F93\u51FA\u4F7F\u7528\u5DF2\u8FC7\u65F6\u7684 API \u7684\u6E90\u4F4D\u7F6E\n -classpath \u6307\u5B9A\u67E5\u627E\u7528\u6237\u7C7B\u6587\u4EF6\u7684\u4F4D\u7F6E\n -sourcepath \u6307\u5B9A\u67E5\u627E\u8F93\u5165\u6E90\u6587\u4EF6\u7684\u4F4D\u7F6E\n -bootclasspath \u8986\u76D6\u5F15\u5BFC\u7C7B\u6587\u4EF6\u7684\u4F4D\u7F6E\n -extdirs \u8986\u76D6\u6240\u5B89\u88C5\u6269\u5C55\u7684\u4F4D\u7F6E\n -d \u6307\u5B9A\u653E\u7F6E\u751F\u6210\u7684\u7C7B\u6587\u4EF6\u7684\u4F4D\u7F6E\n -encoding \u6307\u5B9A\u6E90\u6587\u4EF6\u4F7F\u7528\u7684\u5B57\u7B26\u7F16\u7801\n -target \u751F\u6210\u7279\u5B9A VM \u7248\u672C\u7684\u7C7B\u6587\u4EF6 # -main.unsupported.usage=\ \ -Xdepend \u9012\u5F52\u641C\u7D22\u6700\u65B0\u6E90\u6587\u4EF6\u4EE5\u8FDB\u884C\u91CD\u65B0\u7F16\u8BD1\n\ \ -Xstdout \u5C06\u6D88\u606F\u53D1\u9001\u5230 System.out\n\ \ -Xverbosepath \u8BF4\u660E\u641C\u7D22\u8DEF\u5F84\u548C\u6807\u51C6\u6269\u5C55\u7684\u65B9\u6CD5\n\ \ -J<\u8FD0\u884C\u65F6\u6807\u8BB0> \u5411 java \u89E3\u91CA\u5668\u4F20\u9012\u53C2\u6570\n\n-X \u548C -J \u9009\u9879\u90FD\u662F\u975E\u6807\u51C6\u9009\u9879, \u5982\u6709\u66F4\u6539, \u6055\u4E0D\u53E6\u884C\u901A\u77E5\u3002 +main.unsupported.usage=\ -Xdepend \u9012\u5F52\u641C\u7D22\u6700\u65B0\u6E90\u6587\u4EF6\u4EE5\u8FDB\u884C\u91CD\u65B0\u7F16\u8BD1\n -Xstdout \u5C06\u6D88\u606F\u53D1\u9001\u5230 System.out\n -Xverbosepath \u8BF4\u660E\u641C\u7D22\u8DEF\u5F84\u548C\u6807\u51C6\u6269\u5C55\u7684\u65B9\u6CD5\n -J<\u8FD0\u884C\u65F6\u6807\u8BB0> \u5411 java \u89E3\u91CA\u5668\u4F20\u9012\u53C2\u6570\n\n-X \u548C -J \u9009\u9879\u90FD\u662F\u975E\u6807\u51C6\u9009\u9879, \u5982\u6709\u66F4\u6539, \u6055\u4E0D\u53E6\u884C\u901A\u77E5\u3002 # main.conflicting.options=\u4E0D\u80FD\u540C\u65F6\u4F7F\u7528\u9009\u9879{0}\u548C{1}\u3002 main.option.already.seen={0}\u9009\u9879\u53EA\u80FD\u6307\u5B9A\u4E00\u6B21\u3002 @@ -311,4 +312,4 @@ main.done_in=[\u5728 {0} \u6BEB\u79D2\u5185\u5B8C\u6210] main.no.memory=\u7F16\u8BD1\u5668\u6240\u7528\u5185\u5B58\u4E0D\u8DB3\u3002\u8BF7\u8003\u8651\u4F7F\u7528 "-J-mx<\u6570\u5B57>" \u547D\u4EE4\u884C\u9009\u9879\u6765\u63D0\u9AD8\u5806\u5927\u5C0F\u7684\u6700\u5927\u503C\u3002 main.stack.overflow=\u7F16\u8BD1\u5668\u6240\u7528\u5806\u6808\u7A7A\u95F4\u4E0D\u8DB3\u3002\u8BF7\u8003\u8651\u4F7F\u7528 "-J-oss<\u6570\u5B57>" \u547D\u4EE4\u884C\u9009\u9879\u6765\u63D0\u9AD8\u5206\u914D\u7ED9 Java \u5806\u6808\u7684\u5185\u5B58\u5927\u5C0F\u3002 main.path.msg=[\u6E90\u7C7B\u8DEF\u5F84\u4E3A "{0}"]\n[\u5E93\u7C7B\u8DEF\u5F84\u4E3A "{1}"] -javac.err.invalid.encoding.char=\u6E90\u6587\u4EF6\u7F16\u7801\u4E0E\u6B64\u5E73\u53F0\u7F16\u7801\u4E0D\u540C\u3002\u8BF7\u4F7F\u7528 -encoding \u9009\u9879\u6765\u8C03\u6574\u6587\u4EF6\u7F16\u7801, \u6216\u5E94\u7528 native2ascii \u5B9E\u7528\u7A0B\u5E8F\u6765\u5C06\u6E90\u6587\u4EF6\u8F6C\u6362\u4E3A ASCII \u7F16\u7801\u3002 +javac.err.invalid.encoding.char=\u6E90\u6587\u4EF6\u7F16\u7801\u4E0E\u6B64\u5E73\u53F0\u7F16\u7801\u4E0D\u540C\u3002\u8BF7\u4F7F\u7528 -encoding \u9009\u9879\u6765\u8C03\u6574\u6587\u4EF6\u7F16\u7801, \u6216\u786E\u4FDD\u6E90\u6587\u4EF6\u8F6C\u6362\u4E3A ASCII \u7F16\u7801\u3002 diff --git a/jdk/test/ProblemList.txt b/jdk/test/ProblemList.txt index 0806355ff08..167e2493cf3 100644 --- a/jdk/test/ProblemList.txt +++ b/jdk/test/ProblemList.txt @@ -124,6 +124,10 @@ java/beans/Introspector/8132566/OverrideUserDefPropertyInfoTest.java 8132565 gen # jdk_lang java/lang/StringCoding/CheckEncodings.sh 7008363 generic-all +java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessBoolean.java 8160690 generic-all +java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessByte.java 8160690 generic-all +java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessChar.java 8160690 generic-all +java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessShort.java 8160690 generic-all ############################################################################ @@ -136,6 +140,9 @@ java/lang/instrument/BootClassPath/BootClassPathTest.sh 8072130 macosx-a java/lang/management/MemoryMXBean/LowMemoryTest.java 8130339 generic-all +java/lang/management/MemoryMXBean/Pending.java 8158837 generic-all +java/lang/management/MemoryMXBean/PendingAllGC.sh 8158760 generic-all + ############################################################################ # jdk_io @@ -278,8 +285,6 @@ sun/security/krb5/auto/HttpNegotiateServer.java 8038079 generic- sun/security/tools/keytool/autotest.sh 8130302 generic-all -sun/security/x509/URICertStore/ExtensionsWithLDAP.java 8134577 generic-all - ############################################################################ # jdk_sound @@ -344,8 +349,6 @@ com/sun/jdi/GetLocalVariables4Test.sh 8067354 windows- java/util/spi/ResourceBundleControlProvider/UserDefaultControlTest.java 8062512 generic-all -java/util/stream/test/org/openjdk/tests/java/util/stream/IntPrimitiveOpsTests.java 8130337 generic-all - java/util/Arrays/ParallelPrefix.java 8080165,8085982 generic-all java/util/BitSet/BitSetStreamTest.java 8079538 generic-all @@ -364,6 +367,8 @@ sun/tools/jmap/heapconfig/JMapHeapConfigTest.java 8072131,8132452 sun/tools/jstatd/TestJstatdExternalRegistry.java 8046285 generic-all +sun/tools/jps/TestJpsJar.java 8160923 generic-all + sun/tools/jps/TestJpsJarRelative.java 6456333 generic-all sun/tools/jinfo/JInfoRunningProcessFlagTest.java 6734748 generic-all diff --git a/jdk/test/TEST.groups b/jdk/test/TEST.groups index be1540695df..86fb263da4f 100644 --- a/jdk/test/TEST.groups +++ b/jdk/test/TEST.groups @@ -27,6 +27,7 @@ tier1 = \ :jdk_lang \ + -java/lang/ProcessBuilder/Zombies.java \ :jdk_util \ -java/util/concurrent/ThreadPoolExecutor/ConfigChanges.java \ -java/util/concurrent/forkjoin/FJExceptionTableLeak.java \ @@ -37,6 +38,7 @@ tier1 = \ tools/pack200 tier2 = \ + java/lang/ProcessBuilder/Zombies.java \ java/util/concurrent/ThreadPoolExecutor/ConfigChanges.java \ java/util/concurrent/forkjoin/FJExceptionTableLeak.java \ :jdk_io \ diff --git a/jdk/test/com/apple/laf/ScreenMenu/ScreenMenuMemoryLeakTest.java b/jdk/test/com/apple/laf/ScreenMenu/ScreenMenuMemoryLeakTest.java new file mode 100644 index 00000000000..8aabcae42c7 --- /dev/null +++ b/jdk/test/com/apple/laf/ScreenMenu/ScreenMenuMemoryLeakTest.java @@ -0,0 +1,105 @@ +/* + * Copyright (c) 2016 Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +/* + * @test + * @bug 8158325 + * @summary Memory leak in com.apple.laf.ScreenMenu: removed JMenuItems are still referenced + * @requires (os.family == "mac") + * @run main/timeout=300/othervm -Xmx16m ScreenMenuMemoryLeakTest + */ +import java.awt.EventQueue; +import java.lang.ref.WeakReference; +import java.lang.reflect.InvocationTargetException; +import java.util.Objects; + +import javax.swing.JFrame; +import javax.swing.JLabel; +import javax.swing.JMenu; +import javax.swing.JMenuBar; +import javax.swing.JMenuItem; +import javax.swing.WindowConstants; + +public class ScreenMenuMemoryLeakTest { + + private static byte[] sBytes; + + private static WeakReference sMenuItem; + private static JFrame sFrame; + private static JMenu sMenu; + + public static void main(String[] args) throws InvocationTargetException, InterruptedException { + EventQueue.invokeAndWait(new Runnable() { + @Override + public void run() { + System.setProperty("apple.laf.useScreenMenuBar", "true"); + showUI(); + } + }); + + EventQueue.invokeAndWait(new Runnable() { + @Override + public void run() { + removeMenuItemFromMenu(); + } + }); + System.gc(); + System.runFinalization(); + JMenuItem menuItem = sMenuItem.get(); + EventQueue.invokeAndWait(new Runnable() { + @Override + public void run() { + sFrame.dispose(); + } + }); + if (menuItem != null) { + throw new RuntimeException("The menu item should have been GC-ed"); + } + } + + private static void showUI() { + sFrame = new JFrame(); + sFrame.add(new JLabel("Some dummy content")); + + JMenuBar menuBar = new JMenuBar(); + + sMenu = new JMenu("Menu"); + JMenuItem item = new JMenuItem("Item"); + sMenu.add(item); + + sMenuItem = new WeakReference<>(item); + + menuBar.add(sMenu); + + sFrame.setJMenuBar(menuBar); + + sFrame.setDefaultCloseOperation(WindowConstants.DO_NOTHING_ON_CLOSE); + sFrame.pack(); + sFrame.setVisible(true); + } + + private static void removeMenuItemFromMenu() { + JMenuItem menuItem = sMenuItem.get(); + Objects.requireNonNull(menuItem, "The menu item should still be available at this point"); + sMenu.remove(menuItem); + } +} \ No newline at end of file diff --git a/jdk/test/com/oracle/security/ucrypto/ReadConfInUTF16Env.java b/jdk/test/com/oracle/security/ucrypto/ReadConfInUTF16Env.java new file mode 100644 index 00000000000..b4301fd88d4 --- /dev/null +++ b/jdk/test/com/oracle/security/ucrypto/ReadConfInUTF16Env.java @@ -0,0 +1,31 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +import java.security.Security; + +public class ReadConfInUTF16Env { + public static void main(String argv[]) { + String name = Security.getProvider("OracleUcrypto").getName(); + System.out.println(name); + } +} diff --git a/jdk/make/mapfiles/libjdga/mapfile-vers b/jdk/test/com/oracle/security/ucrypto/ReadConfInUTF16Env.sh similarity index 57% rename from jdk/make/mapfiles/libjdga/mapfile-vers rename to jdk/test/com/oracle/security/ucrypto/ReadConfInUTF16Env.sh index 28d8acfe72a..10a35f0cd6e 100644 --- a/jdk/make/mapfiles/libjdga/mapfile-vers +++ b/jdk/test/com/oracle/security/ucrypto/ReadConfInUTF16Env.sh @@ -1,12 +1,10 @@ # -# Copyright (c) 2005, 2013, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it # under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. +# published by the Free Software Foundation. # # This code is distributed in the hope that it will be useful, but WITHOUT # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or @@ -23,11 +21,18 @@ # questions. # -# Define library interface. +# @test +# @bug 8160267 +# @requires (os.family == "solaris") +# @summary Ucrypto config file cannot be read with -Dfile.encoding=UTF-16 +# @build UcryptoTest ReadConfInUTF16Env +# @run shell ReadConfInUTF16Env.sh -SUNWprivate_1.1 { - global: - JDgaLibInit; - local: - *; -}; +# jtreg does not like -Dfile.encoding=UTF-16 inside a @run main line, +# testlibrary.ProcessTools.createJavaProcessBuilder() also had troubles +# executing a subprocess with -Dfile.encoding=UTF-16 option added, +# therefore a shell test is written. + +$TESTJAVA/bin/java $TESTVMOPTS -cp $TESTCLASSES \ + -Dfile.encoding=UTF-16 \ + ReadConfInUTF16Env diff --git a/jdk/test/com/sun/crypto/provider/KeyAgreement/SupportedDHParamGens.java b/jdk/test/com/sun/crypto/provider/KeyAgreement/SupportedDHParamGens.java index 863563263ad..ac3f384bcf2 100644 --- a/jdk/test/com/sun/crypto/provider/KeyAgreement/SupportedDHParamGens.java +++ b/jdk/test/com/sun/crypto/provider/KeyAgreement/SupportedDHParamGens.java @@ -29,8 +29,8 @@ * @run main/timeout=300 SupportedDHParamGens 768 * @run main/timeout=300 SupportedDHParamGens 832 * @run main/timeout=300 SupportedDHParamGens 1024 - * @run main/timeout=300 SupportedDHParamGens 2048 - * @run main/timeout=450 SupportedDHParamGens 3072 + * @run main/timeout=600 SupportedDHParamGens 2048 + * @run main/timeout=700 SupportedDHParamGens 3072 */ import java.math.BigInteger; diff --git a/jdk/test/java/awt/FileDialog/DeleteInsideFileDialog/DeleteInsideFileDialogTest.java b/jdk/test/java/awt/FileDialog/DeleteInsideFileDialog/DeleteInsideFileDialogTest.java new file mode 100644 index 00000000000..091733abf69 --- /dev/null +++ b/jdk/test/java/awt/FileDialog/DeleteInsideFileDialog/DeleteInsideFileDialogTest.java @@ -0,0 +1,81 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + @test + @bug 8075516 + @requires os.family=="windows" + @summary Deleting a file from either the open or save java.awt.FileDialog + hangs. + @run main/manual DeleteInsideFileDialogTest +*/ + +import java.awt.*; +import java.nio.file.Files; +import java.nio.file.Path; +import java.nio.file.Paths; + +public class DeleteInsideFileDialogTest { + + private static Path dir; + private static Path file1; + private static Path file2; + private static Frame f; + private static FileDialog fd; + + public static void main(String[] args) throws Exception { + + String instructions = + "1) Delete file deleteMe.tst in the opened File Dialog window" + + " using the right click popup menu\n" + + "2) Select thenSelectMe.tst file in the File Dialog and press" + + " Open (if this is not possible the test fails)\n"; + dir = Files.createTempDirectory("Test"); + file1 = Files.createFile(Paths.get(dir.toString(), "deleteMe.tst")); + file2 = Files.createFile(Paths.get(dir.toString(), "thenSelectMe.tst")); + try { + f = new Frame("Instructions"); + f.add(new TextArea(instructions, 6, 60, TextArea.SCROLLBARS_NONE)); + f.pack(); + f.setLocation(100, 500); + f.setVisible(true); + + fd = new FileDialog((Frame)null); + fd.setDirectory(dir.toString()); + fd.setVisible(true); + if (fd.getFile() == null) { + throw new RuntimeException("Failed"); + } + } finally { + if (fd != null) { + fd.dispose(); + } + if (f != null) { + f.dispose(); + } + Files.deleteIfExists(file1); + Files.deleteIfExists(file2); + Files.deleteIfExists(dir); + } + } +} diff --git a/jdk/test/java/awt/GraphicsDevice/DisplayModes/CompareToXrandrTest.java b/jdk/test/java/awt/GraphicsDevice/DisplayModes/CompareToXrandrTest.java new file mode 100644 index 00000000000..6992a808253 --- /dev/null +++ b/jdk/test/java/awt/GraphicsDevice/DisplayModes/CompareToXrandrTest.java @@ -0,0 +1,76 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/** + * @test + * @bug 8022810 + * @summary Cannot list all the available display modes on Ubuntu linux in case + * of two screen devices + * @run main CompareToXrandrTest + */ + +import java.awt.GraphicsEnvironment; +import java.awt.GraphicsDevice; +import java.io.BufferedReader; +import java.io.File; +import java.io.InputStreamReader; +import java.util.Arrays; +import java.util.Set; +import java.util.regex.Matcher; +import java.util.regex.Pattern; +import java.util.stream.Collectors; + +public class CompareToXrandrTest { + + public static void main(String[] args) throws Exception { + if (!new File("/usr/bin/xrandr").exists()) { + System.out.println("No xrandr tool to compare"); + return; + } + + BufferedReader reader = new BufferedReader(new InputStreamReader( + Runtime.getRuntime().exec("/usr/bin/xrandr").getInputStream())); + reader.readLine(); + reader.readLine(); + Pattern pattern = Pattern.compile("^\\s*(\\d+x\\d+)"); + + for (GraphicsDevice d : GraphicsEnvironment + .getLocalGraphicsEnvironment().getScreenDevices()) { + + Set xrandrModes = reader.lines().map(pattern::matcher) + .takeWhile(Matcher::find).map(m -> m.group(1)) + .collect(Collectors.toSet()); + + Set javaModes = Arrays.stream(d.getDisplayModes()) + .map(m -> m.getWidth() + "x" + m.getHeight()) + .collect(Collectors.toSet()); + + if (!xrandrModes.equals(javaModes)) { + throw new RuntimeException("Failed"); + } else { + System.out.println("Device " + d + ": " + javaModes.size() + + " modes found."); + } + } + } +} diff --git a/jdk/test/java/awt/InputMethods/DiacriticsTest/DiacriticsTest.html b/jdk/test/java/awt/InputMethods/DiacriticsTest/DiacriticsTest.html index 89dab3d87ef..5cf5c91ea71 100644 --- a/jdk/test/java/awt/InputMethods/DiacriticsTest/DiacriticsTest.html +++ b/jdk/test/java/awt/InputMethods/DiacriticsTest/DiacriticsTest.html @@ -1,5 +1,5 @@ + + + +Verify that Chinese comma can be entered in JTextField with Pinyin input method (IM). + +This test is for OS X only. For other platforms please simply press "Pass". + +1. Go to "System Preferences -> Keyboard -> Input Sources" and add "Pinyin – Traditional" or "Pinyin – Simplified" IM from Chinese language group. +2. Set current IM to "Pinyin". +3. Set focus to the text field of the test and press "comma" character on the keyboard. +4. Set current IM to the IM used before "Pinyin" was set. +5. If "," character is displayed in the text area, press "Pass", if "," character is displayed, press "Fail". + + + + diff --git a/jdk/test/java/awt/im/8148984/bug8148984.java b/jdk/test/java/awt/im/8148984/bug8148984.java new file mode 100644 index 00000000000..3869b3cd372 --- /dev/null +++ b/jdk/test/java/awt/im/8148984/bug8148984.java @@ -0,0 +1,47 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* @test + * @bug 8148984 + * @summary Chinese Comma cannot be entered using Pinyin Input Method on OS X + * @author Dmitry Markov + * @run applet/manual=yesno bug8148984.html + */ + +import javax.swing.*; + +public class bug8148984 extends JApplet { + @Override + public void init() { + SwingUtilities.invokeLater(new Runnable() { + @Override + public void run() { + JPanel panel = new JPanel(); + panel.add(new JLabel("Text field:")); + panel.add(new JTextField(20)); + add(panel); + } + }); + } +} + diff --git a/jdk/test/java/awt/im/8154816/bug8154816.html b/jdk/test/java/awt/im/8154816/bug8154816.html new file mode 100644 index 00000000000..1fdb5fd10ae --- /dev/null +++ b/jdk/test/java/awt/im/8154816/bug8154816.html @@ -0,0 +1,39 @@ + + + + +Verify that Caps Lock key works properly with Pinyin input method, (i.e. if +Caps Lock is pressed, input should be swithced to lowercase latin letters). + +This test is for OS X only. For other platforms please simply press "Pass". + +1. Go to "System Preferences -> Keyboard -> Input Sources" and add "Pinyin – Traditional" or "Pinyin – Simplified" IM from Chinese language group. +2. Set current IM to "Pinyin". +3. Set focus to the text field of the test and press Caps Lock key on the keyboard. +4. Press "a" character on the keyboard +5. If "a" character is displayed in the text field, press "Pass", if "A" character is displayed, press "Fail". + + + + diff --git a/jdk/test/java/awt/im/8154816/bug8154816.java b/jdk/test/java/awt/im/8154816/bug8154816.java new file mode 100644 index 00000000000..b3bda4f4728 --- /dev/null +++ b/jdk/test/java/awt/im/8154816/bug8154816.java @@ -0,0 +1,47 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* @test + * @bug 8154816 + * @summary Caps Lock doesn't work as expected when using Pinyin Simplified input method + * @author Dmitry Markov + * @run applet/manual=yesno bug8154816.html + */ + +import javax.swing.*; + +public class bug8154816 extends JApplet { + @Override + public void init() { + SwingUtilities.invokeLater(new Runnable() { + @Override + public void run() { + JPanel panel = new JPanel(); + panel.add(new JLabel("Text field:")); + panel.add(new JTextField(20)); + add(panel); + } + }); + } +} + diff --git a/jdk/test/java/awt/keyboard/AllKeyCode/AllKeyCode.java b/jdk/test/java/awt/keyboard/AllKeyCode/AllKeyCode.java index 2cb9c5cd3f2..7890f08b8a9 100644 --- a/jdk/test/java/awt/keyboard/AllKeyCode/AllKeyCode.java +++ b/jdk/test/java/awt/keyboard/AllKeyCode/AllKeyCode.java @@ -22,15 +22,14 @@ */ /* - @test - @bug 8149456 8147834 8150230 - @requires os.family == "mac" - @summary KeyEvents for all keys - @run main AllKeyCode -*/ + @test + @bug 8149456 8147834 8150230 8155740 + @requires os.family == "mac" + @summary Tests key codes for all keys supported in Java for Mac OS X. + @run main AllKeyCode + */ import java.awt.AWTException; -import java.awt.GridBagLayout; import java.awt.Robot; import java.awt.event.KeyEvent; import java.awt.event.KeyListener; @@ -149,7 +148,8 @@ public class AllKeyCode extends Frame { KeyEvent.VK_F17, KeyEvent.VK_F18, KeyEvent.VK_F19, - KeyEvent.VK_F20 + KeyEvent.VK_F20, + KeyEvent.VK_ALT_GRAPH }; keyPressedIndex = -1; diff --git a/jdk/test/java/awt/keyboard/Bug8158478/Test8158478.java b/jdk/test/java/awt/keyboard/Bug8158478/Test8158478.java new file mode 100644 index 00000000000..f4c6d8c7697 --- /dev/null +++ b/jdk/test/java/awt/keyboard/Bug8158478/Test8158478.java @@ -0,0 +1,151 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + + /* +* @test +* @bug 8158478 +* @requires (os.family == "linux") +* @summary To Verify X11 Keysym unicode for topt +* @run main/manual Test8158478 + */ +import java.awt.Button; +import java.awt.Frame; +import java.awt.GridBagConstraints; +import java.awt.GridBagLayout; +import java.awt.Panel; +import java.awt.TextArea; +import java.awt.event.ActionEvent; +import java.awt.event.ActionListener; +import java.util.concurrent.CountDownLatch; + +public class Test8158478 { + + public static void main(String args[]) throws Exception { + final CountDownLatch latch = new CountDownLatch(1); + + X11KeysymTest test = new X11KeysymTest(latch); + Thread T1 = new Thread(test); + T1.start(); + + // wait for latch to complete + latch.await(); + + if (test.testResult == false) { + throw new RuntimeException("User Clicked Fail! " + + "Wrong Unicode Character"); + } + } +} + +class X11KeysymTest implements Runnable { + + private static GridBagLayout layout; + private static Panel mainControlPanel; + private static Panel resultButtonPanel; + private static TextArea instructionTextArea; + private static Button passButton; + private static Button failButton; + private static Frame mainFrame; + private static TextArea testArea; + private final CountDownLatch latch; + public volatile boolean testResult = false; + + public X11KeysymTest(CountDownLatch latch) { + this.latch = latch; + } + + @Override + public void run() { + createUI(); + } + + public final void createUI() { + + mainFrame = new Frame("X11 Keysym Test"); + layout = new GridBagLayout(); + mainControlPanel = new Panel(layout); + resultButtonPanel = new Panel(layout); + + GridBagConstraints gbc = new GridBagConstraints(); + String instructions + = "INSTRUCTIONS:" + + "\n Have a custom X11 keyboard layout with" + + " \"topt\" assigned to some key: " + + "\n Map \"topt\" key to \"Caps_Lock\" by executing" + + " following command in Terminal:" + + "\n xmodmap -e \"keysym Caps_Lock = topt\"." + + "\n Go to TextArea below and press \"CAPSLOCK\" key" + + "\n If Symbol: " + "\u252c" + " is displayed then test Pass," + + "\n If Symbol: " + "\u242c" + " is displayed then test Fail," + + "\n Execute the below command to reset the above settigs, " + + "\n setxkbmap -layout us"; + + instructionTextArea = new TextArea(); + instructionTextArea.setText(instructions); + instructionTextArea.setEnabled(true); + + gbc.gridx = 0; + gbc.gridy = 0; + gbc.fill = GridBagConstraints.HORIZONTAL; + mainControlPanel.add(instructionTextArea, gbc); + + testArea = new TextArea("TextArea"); + gbc.gridx = 0; + gbc.gridy = 1; + mainControlPanel.add(testArea, gbc); + passButton = new Button("Pass"); + passButton.setActionCommand("Pass"); + passButton.addActionListener((ActionEvent e) -> { + testResult = true; + mainFrame.dispose(); + latch.countDown(); + + }); + failButton = new Button("Fail"); + failButton.setActionCommand("Fail"); + failButton.addActionListener(new ActionListener() { + @Override + public void actionPerformed(ActionEvent e) { + testResult = false; + mainFrame.dispose(); + latch.countDown(); + } + }); + gbc.gridx = 0; + gbc.gridy = 0; + resultButtonPanel.add(passButton, gbc); + gbc.gridx = 1; + gbc.gridy = 0; + resultButtonPanel.add(failButton, gbc); + + gbc.gridx = 0; + gbc.gridy = 2; + mainControlPanel.add(resultButtonPanel, gbc); + + mainFrame.add(mainControlPanel); + mainFrame.pack(); + mainFrame.setVisible(true); + } + +} + diff --git a/jdk/test/java/awt/print/PrinterJob/LandscapeStackOverflow.java b/jdk/test/java/awt/print/PrinterJob/LandscapeStackOverflow.java index 9480b3bc816..66a4ebd369c 100644 --- a/jdk/test/java/awt/print/PrinterJob/LandscapeStackOverflow.java +++ b/jdk/test/java/awt/print/PrinterJob/LandscapeStackOverflow.java @@ -22,7 +22,7 @@ */ /* * @test - * @bug 6842011 + * @bug 6842011 8158758 * @summary Test if StackOverflowError occurs during printing landscape with * scale and transform. * @run main LandscapeStackOverflow @@ -47,9 +47,6 @@ public class LandscapeStackOverflow { PrintRequestAttributeSet attributes = new HashPrintRequestAttributeSet(); attributes.add( OrientationRequested.LANDSCAPE ); - boolean print = printjob.printDialog( attributes ); - if( !print ) return; - try { printjob.setPrintable( new Painter() ); printjob.print( attributes ); diff --git a/jdk/test/java/awt/print/PrinterJob/Margins.java b/jdk/test/java/awt/print/PrinterJob/Margins.java index efdebe4c9ec..c55ae8a6423 100644 --- a/jdk/test/java/awt/print/PrinterJob/Margins.java +++ b/jdk/test/java/awt/print/PrinterJob/Margins.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,15 +23,22 @@ /** * @test - * @bug 6543815 + * @bug 6543815 6601097 * @summary Image should be sent to printer, no exceptions thrown. - * The 2 printouts should have a rectangle which is the minimum - * possible margin. + * The 3 printouts should have a rectangle which is the minimum + * possible margins ie, the margins should be hardware margins + * and not java default 1 inch margins. * @run main/manual Margins */ -import java.awt.*; -import java.awt.print.*; +import java.awt.print.PrinterJob; +import java.awt.print.Printable; +import java.awt.print.PageFormat; +import java.awt.print.Paper; +import java.awt.print.PrinterException; +import java.awt.Graphics; +import java.awt.Graphics2D; +import java.awt.Color; public class Margins implements Printable { @@ -59,7 +66,22 @@ public class Margins implements Printable { job.print(); } catch (PrinterException e) { } - } + + pageFormat = job.defaultPage(); + paper = pageFormat.getPaper(); + wid = paper.getWidth(); + hgt = paper.getHeight(); + + paper.setImageableArea(0, -10, -wid, hgt); + pageFormat = job.pageDialog(pageFormat); + pageFormat.setPaper(paper); + + job.setPrintable(new Margins(), pageFormat); + try { + job.print(); + } catch (PrinterException e) { + } + } public int print(Graphics g, PageFormat pf, int page) throws PrinterException { @@ -76,12 +98,22 @@ public class Margins implements Printable { throw new RuntimeException("Imageable x or y is a negative value."); } + Paper paper = pf.getPaper(); double wid = paper.getWidth(); double hgt = paper.getHeight(); + /* If imageable width/height is -ve, then print was done with 1" margin + * ie ix=72 iy=72 iw=451 ih=697 and wid=595 + * but with fix, we get print with hardware margin ie + * ix=12, iy=12, iw=571, ih=817 + */ + if ((wid - iw > 72) || (hgt - ih > 72)) { + throw new RuntimeException("Imageable width or height is negative value"); + } if ((ix+iw > wid) || (iy+ih > hgt)) { - throw new RuntimeException("Printable width or height exceeds paper width or height."); + throw new RuntimeException("Printable width or height " + + "exceeds paper width or height."); } Graphics2D g2d = (Graphics2D)g; diff --git a/jdk/test/java/awt/print/PrinterJob/PrintDlgSelectionAttribTest.java b/jdk/test/java/awt/print/PrinterJob/PrintDlgSelectionAttribTest.java index 8640038eacb..98585478626 100644 --- a/jdk/test/java/awt/print/PrinterJob/PrintDlgSelectionAttribTest.java +++ b/jdk/test/java/awt/print/PrinterJob/PrintDlgSelectionAttribTest.java @@ -22,7 +22,7 @@ */ /* * @test - * @bug 6529030 + * @bug 6529030 8159134 * @summary Verifies if Java Printing: Selection radiobutton gets enabled. * @requires (os.family == "windows") * @run main/manual PrintDlgSelectionAttribTest @@ -83,7 +83,7 @@ public class PrintDlgSelectionAttribTest { }); mainThread = Thread.currentThread(); try { - Thread.sleep(30000); + Thread.sleep(60000); } catch (InterruptedException e) { if (!testPassed && testGeneratedInterrupt) { throw new RuntimeException("" diff --git a/jdk/test/java/awt/print/PrinterJob/PrintTestLexmarkIQ.java b/jdk/test/java/awt/print/PrinterJob/PrintTestLexmarkIQ.java new file mode 100644 index 00000000000..3cc424f5037 --- /dev/null +++ b/jdk/test/java/awt/print/PrinterJob/PrintTestLexmarkIQ.java @@ -0,0 +1,166 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +/* + * @test + * @bug 6966350 + * @summary Verifies if Empty pages are printed on Lexmark E352dn PS3 + * with "1200 IQ" setting + * @run main/manual PrintTestLexmarkIQ + */ +import java.awt.BorderLayout; +import java.awt.Color; +import java.awt.FlowLayout; +import java.awt.Font; +import java.awt.Graphics; +import java.awt.Graphics2D; +import java.awt.geom.Rectangle2D; +import java.awt.print.PageFormat; +import java.awt.print.Paper; +import java.awt.print.Printable; +import static java.awt.print.Printable.NO_SUCH_PAGE; +import static java.awt.print.Printable.PAGE_EXISTS; +import java.awt.print.PrinterException; +import java.awt.print.PrinterJob; +import javax.swing.JButton; +import javax.swing.JDialog; +import javax.swing.JPanel; +import javax.swing.JTextArea; +import javax.swing.SwingUtilities; + +public class PrintTestLexmarkIQ implements Printable { + + private static Thread mainThread; + private static boolean testPassed; + private static boolean testGeneratedInterrupt; + + public static void main(String[] args) throws Exception { + SwingUtilities.invokeAndWait(() -> { + doTest(PrintTestLexmarkIQ::printTest); + }); + mainThread = Thread.currentThread(); + try { + Thread.sleep(90000); + } catch (InterruptedException e) { + if (!testPassed && testGeneratedInterrupt) { + throw new RuntimeException(" Empty pages printed "); + } + } + if (!testGeneratedInterrupt) { + throw new RuntimeException("user has not executed the test"); + } + } + + private static void printTest() { + PrinterJob pj = PrinterJob.getPrinterJob(); + + PageFormat pf = pj.defaultPage(); + Paper paper = new Paper(); + double margin = 36; // half inch + paper.setImageableArea(margin, margin, paper.getWidth() - margin * 2, + paper.getHeight() - margin * 2); + pf.setPaper(paper); + + pj.setPrintable(new PrintTestLexmarkIQ(), pf); + if (pj.printDialog()) { + try { + pj.print(); + } catch (PrinterException e) { + System.out.println(e); + } + } + } + + public static synchronized void pass() { + testPassed = true; + testGeneratedInterrupt = true; + mainThread.interrupt(); + } + + public static synchronized void fail() { + testPassed = false; + testGeneratedInterrupt = true; + mainThread.interrupt(); + } + + private static void doTest(Runnable action) { + String description + = " Install Lexmark E352dn PS3 or Dell 5310n printer.\n" + + " A print dialog will be shown.\n" + + " Select Normal 1200IQ setting in Properties->PrintQuality in Dell 5310n \n" + + " or for Lexmark E352dn printer, select Normal 1200IQ setting in\n " + + " Properties -> Advanced -> Graphic -> Print Quality.\n" + + " Press Print. Verify the print output.\n " + + " If empty page is printed, press Fail else press Pass."; + + final JDialog dialog = new JDialog(); + dialog.setTitle("1200IQTest"); + JTextArea textArea = new JTextArea(description); + textArea.setEditable(false); + final JButton testButton = new JButton("Start Test"); + final JButton passButton = new JButton("PASS"); + passButton.setEnabled(false); + passButton.addActionListener((e) -> { + dialog.dispose(); + pass(); + }); + final JButton failButton = new JButton("FAIL"); + failButton.setEnabled(false); + failButton.addActionListener((e) -> { + dialog.dispose(); + fail(); + }); + testButton.addActionListener((e) -> { + testButton.setEnabled(false); + action.run(); + passButton.setEnabled(true); + failButton.setEnabled(true); + }); + JPanel mainPanel = new JPanel(new BorderLayout()); + mainPanel.add(textArea, BorderLayout.CENTER); + JPanel buttonPanel = new JPanel(new FlowLayout()); + buttonPanel.add(testButton); + buttonPanel.add(passButton); + buttonPanel.add(failButton); + mainPanel.add(buttonPanel, BorderLayout.SOUTH); + dialog.add(mainPanel); + dialog.pack(); + dialog.setVisible(true); + } + + public int print(Graphics g, PageFormat pf, int pi) + throws PrinterException { + if (pi != 0) { + return NO_SUCH_PAGE; + } + Graphics2D g2 = (Graphics2D) g; + g2.setFont(new Font("Serif", Font.PLAIN, 36)); + g2.setPaint(Color.black); + g2.drawString("Java Source and Support", 100, 100); + Rectangle2D outline = new Rectangle2D.Double(pf.getImageableX(), pf + .getImageableY(), pf.getImageableWidth(), pf + .getImageableHeight()); + g2.draw(outline); + return PAGE_EXISTS; + } + +} diff --git a/jdk/test/java/awt/print/PrinterJob/TestPgfmtSetMPA.java b/jdk/test/java/awt/print/PrinterJob/TestPgfmtSetMPA.java new file mode 100644 index 00000000000..8e09acf7886 --- /dev/null +++ b/jdk/test/java/awt/print/PrinterJob/TestPgfmtSetMPA.java @@ -0,0 +1,72 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +/* + * @test + * @bug 6789262 + * @summary Verifies if getPageFormat returns correct mediaprintable value + * @run main TestPgfmtSetMPA + */ +import java.awt.print.PageFormat; +import java.awt.print.PrinterJob; +import javax.print.attribute.HashPrintRequestAttributeSet; +import javax.print.attribute.PrintRequestAttributeSet; +import javax.print.attribute.standard.MediaPrintableArea; + +public class TestPgfmtSetMPA { + + public static void main(String args[]) { + PrinterJob job; + + job = PrinterJob.getPrinterJob(); + + PrintRequestAttributeSet pras = new HashPrintRequestAttributeSet(); + + // Here you could see the PageFormat with an empty PrintRequestAttributeSet + PageFormat pf2 = job.getPageFormat(pras); + System.out.println((pf2.getImageableX() / 72f) + " " + + (pf2.getImageableY() / 72f) + " " + + (pf2.getImageableWidth() / 72f) + " " + + (pf2.getImageableHeight() / 72f) + ); + + // Set left margin to 2.0 + pras.add(new MediaPrintableArea(2.0f, + (float)(pf2.getImageableY() / 72f), + (float) ((pf2.getImageableWidth() / 72f) - 1.0f), + (float) (pf2.getImageableHeight() / 72f), + MediaPrintableArea.INCH)); + + pf2 = job.getPageFormat(pras); + System.out.println((pf2.getImageableX() / 72f) + " " + + (pf2.getImageableY() / 72f) + " " + + (pf2.getImageableWidth() / 72f) + " " + + (pf2.getImageableHeight() / 72f) + ); + + // check if returned left margin of imageable area is 2.0 as set earlier + if (pf2.getImageableX() / 72f != 2.0f) { + throw new RuntimeException("getPageFormat doesn't apply specified " + + "MediaPrintableArea attribute"); + } + } +} diff --git a/jdk/test/java/io/Reader/ReaderBulkReadContract.java b/jdk/test/java/io/Reader/ReaderBulkReadContract.java index 98a2c767a88..88463dbd578 100644 --- a/jdk/test/java/io/Reader/ReaderBulkReadContract.java +++ b/jdk/test/java/io/Reader/ReaderBulkReadContract.java @@ -148,7 +148,8 @@ public class ReaderBulkReadContract { private static File createTempFileWithContents(String contents) { try { - File file = File.createTempFile("ReaderContract", ""); + File testDir = new File(System.getProperty("test.dir", ".")); + File file = File.createTempFile("ReaderContract", "", testDir); try (FileWriter w = new FileWriter(file)) { w.write(contents); } diff --git a/jdk/test/java/io/Serializable/failureAtomicity/FailureAtomicity.java b/jdk/test/java/io/Serializable/failureAtomicity/FailureAtomicity.java index 70ba268d52b..789153d394d 100644 --- a/jdk/test/java/io/Serializable/failureAtomicity/FailureAtomicity.java +++ b/jdk/test/java/io/Serializable/failureAtomicity/FailureAtomicity.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,6 +25,7 @@ * @test * @bug 8071474 * @summary Better failure atomicity for default read object. + * @modules jdk.compiler * @library /lib/testlibrary * @build jdk.testlibrary.FileUtils * @compile FailureAtomicity.java SerialRef.java diff --git a/jdk/test/java/lang/ProcessBuilder/Zombies.java b/jdk/test/java/lang/ProcessBuilder/Zombies.java index c417b696c2b..e77f01cce93 100644 --- a/jdk/test/java/lang/ProcessBuilder/Zombies.java +++ b/jdk/test/java/lang/ProcessBuilder/Zombies.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2006, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2006, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -42,6 +42,9 @@ public class Zombies { ! new File("/bin/ps").canExecute()) return; System.out.println("Looks like a Unix system."); + long mypid = ProcessHandle.current().getPid(); + System.out.printf("mypid: %d%n", mypid); + final Runtime rt = Runtime.getRuntime(); try { @@ -59,7 +62,10 @@ public class Zombies { throw new Error("expected IOException not thrown"); } catch (IOException expected) {/* OK */} - rt.exec(TrueCommand).waitFor(); + Process p = rt.exec(TrueCommand); + ProcessHandle pp = p.toHandle().parent().orElse(null); + System.out.printf("pid: %d, parent: %s%n", p.getPid(), pp); + p.waitFor(); // Count all the zombies that are children of this Java process final String[] zombieCounter = { @@ -68,6 +74,13 @@ public class Zombies { }; int zombies = rt.exec(zombieCounter).waitFor(); - if (zombies != 0) throw new Error(zombies + " zombies!"); + if (zombies != 0) { + // Log remaining processes + ProcessBuilder pb = new ProcessBuilder("/bin/ps", "-ef"); + pb.inheritIO(); + Process p2 = pb.start(); + p2.waitFor(); + throw new Error(zombies + " zombies!"); + } } } diff --git a/jdk/test/java/lang/SecurityManager/CheckSecurityProvider.java b/jdk/test/java/lang/SecurityManager/CheckSecurityProvider.java index 45efe0493e0..1c7f7b42f93 100644 --- a/jdk/test/java/lang/SecurityManager/CheckSecurityProvider.java +++ b/jdk/test/java/lang/SecurityManager/CheckSecurityProvider.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -28,11 +28,14 @@ * @run main/othervm CheckSecurityProvider */ +import java.lang.reflect.Layer; import java.security.Provider; import java.security.Security; import java.util.ArrayList; import java.util.Iterator; import java.util.List; +import java.util.stream.Collectors; +import java.util.stream.Stream; /* * The main benefit of this test is to catch merge errors or other types @@ -42,6 +45,8 @@ import java.util.List; */ public class CheckSecurityProvider { public static void main(String[] args) throws Exception { + Layer layer = Layer.boot(); + System.setSecurityManager(new SecurityManager()); String os = System.getProperty("os.name"); @@ -55,43 +60,60 @@ public class CheckSecurityProvider { // NOTE: the ordering must match what's defined inside java.security if (os.equals("SunOS")) { - expected.add("com.oracle.security.ucrypto.UcryptoProvider"); - expected.add("sun.security.pkcs11.SunPKCS11"); + layer.findModule("jdk.crypto.ucrypto") + .ifPresent(m -> expected.add("com.oracle.security.ucrypto.UcryptoProvider")); + layer.findModule("jdk.crypto.pkcs11") + .ifPresent(m -> expected.add("sun.security.pkcs11.SunPKCS11")); } expected.add("sun.security.provider.Sun"); expected.add("sun.security.rsa.SunRsaSign"); - expected.add("sun.security.ec.SunEC"); + layer.findModule("jdk.crypto.ec") + .ifPresent(m -> expected.add("sun.security.ec.SunEC")); expected.add("com.sun.net.ssl.internal.ssl.Provider"); expected.add("com.sun.crypto.provider.SunJCE"); - expected.add("sun.security.jgss.SunProvider"); - expected.add("com.sun.security.sasl.Provider"); - expected.add("org.jcp.xml.dsig.internal.dom.XMLDSigRI"); - expected.add("sun.security.smartcardio.SunPCSC"); - expected.add("sun.security.provider.certpath.ldap.JdkLDAP"); - expected.add("com.sun.security.sasl.gsskerb.JdkSASL"); + layer.findModule("jdk.security.jgss") + .ifPresent(m -> expected.add("sun.security.jgss.SunProvider")); + layer.findModule("java.security.sasl") + .ifPresent(m -> expected.add("com.sun.security.sasl.Provider")); + layer.findModule("java.xml.crypto") + .ifPresent(m -> expected.add("org.jcp.xml.dsig.internal.dom.XMLDSigRI")); + layer.findModule("java.smartcardio") + .ifPresent(m -> expected.add("sun.security.smartcardio.SunPCSC")); + layer.findModule("java.naming") + .ifPresent(m -> expected.add("sun.security.provider.certpath.ldap.JdkLDAP")); + layer.findModule("jdk.security.jgss") + .ifPresent(m -> expected.add("com.sun.security.sasl.gsskerb.JdkSASL")); if (os.startsWith("Windows")) { - expected.add("sun.security.mscapi.SunMSCAPI"); + layer.findModule("jdk.crypto.mscapi") + .ifPresent(m -> expected.add("sun.security.mscapi.SunMSCAPI")); } if (os.contains("OS X")) { expected.add("apple.security.AppleProvider"); } if (!os.equals("SunOS")) { - expected.add("sun.security.pkcs11.SunPKCS11"); + layer.findModule("jdk.crypto.pkcs11") + .ifPresent(m -> expected.add("sun.security.pkcs11.SunPKCS11")); } - Iterator iter = expected.iterator(); - for (Provider p: Security.getProviders()) { - if (!iter.hasNext()) { - throw new Exception("Less expected"); - } - String n1 = iter.next(); - String n2 = p.getClass().getName(); - if (!n1.equals(n2)) { - throw new Exception("Expected " + n1 + ", actual " + n2); - } + List actual = Stream.of(Security.getProviders()) + .map(p -> p.getClass().getName()) + .collect(Collectors.toList()); + + System.out.println("Expected providers:"); + expected.stream().forEach(System.out::println); + System.out.println("Actual providers:"); + actual.stream().forEach(System.out::println); + + if (expected.size() != actual.size()) { + throw new Exception("Unexpected provider count. " + + "Expected: " + expected.size() + ". Actual: " + actual.size()); } - if (iter.hasNext()) { - throw new Exception("More expected"); + Iterator iter = expected.iterator(); + for (String p: actual) { + String nextExpected = iter.next(); + if (!nextExpected.equals(p)) { + throw new Exception("Expected " + nextExpected + ", actual " + p); + } } } } diff --git a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmGlobalPool.java b/jdk/test/java/lang/annotation/AnnotationVerifier.java similarity index 50% rename from jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmGlobalPool.java rename to jdk/test/java/lang/annotation/AnnotationVerifier.java index b3dbc370b79..2aaeb3ccdb6 100644 --- a/jdk/src/jdk.jlink/share/classes/jdk/tools/jlink/internal/plugins/asm/AsmGlobalPool.java +++ b/jdk/test/java/lang/annotation/AnnotationVerifier.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -22,33 +22,42 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ -package jdk.tools.jlink.internal.plugins.asm; -import java.util.Set; - -/** - * A pool containing all class and resource files. +/* + * Create class file using ASM, slightly modified the ASMifier output */ -public interface AsmGlobalPool extends AsmPool { - /** - * Associate a package to a module, useful when adding new classes in new - * packages. WARNING: In order to properly handle new package and/or new - * module, module-info class must be added and/or updated. - * - * @param pkg The new package, following java binary syntax (/-separated - * path name). - * @param module An existing or new module. - * @throws jdk.tools.jlink.plugins.PluginException If a mapping already - * exist for this package. - */ - public void addPackageModuleMapping(String pkg, String module); +import sun.reflect.annotation.AnnotationType; +import java.lang.annotation.AnnotationFormatError; +import org.testng.annotations.*; - /** - * Return the set of accessible packages for a given module. - * - * @param module The module from which packages are accessible. - * @return Set of packages or null if the module is not found. - */ - public Set getAccessiblePackages(String module); +/* + * @test + * @bug 8158510 + * @summary Verify valid annotation + * @modules java.base/jdk.internal.org.objectweb.asm + * @modules java.base/sun.reflect.annotation + * @clean AnnotationWithVoidReturn.class AnnotationWithParameter.class + * @compile -XDignore.symbol.file ClassFileGenerator.java + * @run main ClassFileGenerator + * @run testng AnnotationVerifier + */ + +public class AnnotationVerifier { + + @AnnotationWithParameter + @AnnotationWithVoidReturn + static class BadAnnotation { + } + + @Test + @ExpectedExceptions(IllegalArgumentException.class) + public void annotationValidationIAE() { + AnnotationType.getInstance(AnnotationWithParameter.class); + } + + @Test(expectedExceptions = AnnotationFormatError.class) + public void annotationValidationAFE() { + BadAnnotation.class.getAnnotation(AnnotationWithVoidReturn.class); + } } diff --git a/jdk/test/java/lang/annotation/ClassFileGenerator.java b/jdk/test/java/lang/annotation/ClassFileGenerator.java new file mode 100644 index 00000000000..80bdd4de873 --- /dev/null +++ b/jdk/test/java/lang/annotation/ClassFileGenerator.java @@ -0,0 +1,139 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * Create class file using ASM, slightly modified the ASMifier output + */ + + + +import java.io.File; +import java.io.FileOutputStream; +import java.io.IOException; +import jdk.internal.org.objectweb.asm.*; + + +public class ClassFileGenerator { + + public static void main(String... args) throws Exception { + classFileWriter("AnnotationWithVoidReturn.class", AnnoationWithVoidReturnDump.dump()); + classFileWriter("AnnotationWithParameter.class", AnnoationWithParameterDump.dump()); + } + + private static void classFileWriter(String name, byte[] contents) throws IOException { + try (FileOutputStream fos = new FileOutputStream(new File(System.getProperty("test.classes"), + name))) { + fos.write(contents); + } + } + + /* + Following code create equivalent classfile, + which is not allowed by javac. + + @Retention(RetentionPolicy.RUNTIME) + public @interface AnnotationWithVoidReturn { + void m() default 1; + } + */ + + private static class AnnoationWithVoidReturnDump implements Opcodes { + public static byte[] dump() throws Exception { + ClassWriter cw = new ClassWriter(0); + MethodVisitor mv; + AnnotationVisitor av0; + + cw.visit(52, ACC_PUBLIC + ACC_ANNOTATION + ACC_ABSTRACT + +ACC_INTERFACE, + "AnnotationWithVoidReturn", null, + "java/lang/Object", new String[]{"java/lang/annotation/Annotation"}); + + { + av0 = cw.visitAnnotation("Ljava/lang/annotation/Retention;", true); + av0.visitEnum("value", "Ljava/lang/annotation/RetentionPolicy;", + "RUNTIME"); + av0.visitEnd(); + } + { + mv = cw.visitMethod(ACC_PUBLIC + ACC_ABSTRACT, "m", "()V", null, null); + mv.visitEnd(); + } + { + av0 = mv.visitAnnotationDefault(); + av0.visit(null, new Integer(1)); + av0.visitEnd(); + } + cw.visitEnd(); + + return cw.toByteArray(); + + } + } + + /* + Following code create equivalent classfile, + which is not allowed by javac. + + @Retention(RetentionPolicy.RUNTIME) + public @interface AnnotationWithParameter { + int m(int x); + } + */ + + private static class AnnoationWithParameterDump implements Opcodes { + public static byte[] dump() throws Exception { + + ClassWriter cw = new ClassWriter(0); + MethodVisitor mv; + AnnotationVisitor av0; + + cw.visit(52, ACC_PUBLIC + ACC_ANNOTATION + ACC_ABSTRACT + ACC_INTERFACE, + "AnnotationWithParameter", null, + "java/lang/Object", new String[]{"java/lang/annotation/Annotation"}); + + { + av0 = cw.visitAnnotation("Ljava/lang/annotation/Retention;", true); + av0.visitEnum("value", "Ljava/lang/annotation/RetentionPolicy;", + "RUNTIME"); + av0.visitEnd(); + } + { + mv = cw.visitMethod(ACC_PUBLIC + ACC_ABSTRACT, + "badValue", + "(I)I", // Bad method with a parameter + null, null); + mv.visitEnd(); + } + { + av0 = mv.visitAnnotationDefault(); + av0.visit(null, new Integer(-1)); + av0.visitEnd(); + } + cw.visitEnd(); + + return cw.toByteArray(); + } + } + +} diff --git a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMData.java b/jdk/test/java/lang/annotation/typeAnnotations/MissingAnnotation.java similarity index 67% rename from hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMData.java rename to jdk/test/java/lang/annotation/typeAnnotations/MissingAnnotation.java index f993fd620ee..498b6c103ac 100644 --- a/hotspot/src/jdk.vm.ci/share/classes/jdk.vm.ci.hotspotvmconfig/src/jdk/vm/ci/hotspotvmconfig/HotSpotVMData.java +++ b/jdk/test/java/lang/annotation/typeAnnotations/MissingAnnotation.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -20,25 +20,9 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ -package jdk.vm.ci.hotspotvmconfig; -import java.lang.annotation.ElementType; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.Target; +import java.lang.annotation.*; -/** - * Refers to a entry in {@code gHotSpotVMData}. - */ -@Target(ElementType.FIELD) @Retention(RetentionPolicy.RUNTIME) -public @interface HotSpotVMData { - - /** - * Returns the array index of this field. - * - * @return array index of field - */ - int index(); - -} +@Target(ElementType.TYPE_USE) +public @interface MissingAnnotation { } diff --git a/jdk/test/java/lang/annotation/typeAnnotations/NoNpeOnMissingAnnotation.java b/jdk/test/java/lang/annotation/typeAnnotations/NoNpeOnMissingAnnotation.java new file mode 100644 index 00000000000..49e44010052 --- /dev/null +++ b/jdk/test/java/lang/annotation/typeAnnotations/NoNpeOnMissingAnnotation.java @@ -0,0 +1,44 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @bug 8152174 + * @summary Verify that a missing class file for a type use annotation doesn't cause a NPE when attempting to read the annotation. + * @compile NoNpeOnMissingAnnotation.java MissingAnnotation.java + * @run main NoNpeOnMissingAnnotation + * @clean MissingAnnotation + * @run main NoNpeOnMissingAnnotation + */ + +import java.lang.annotation.*; + +public class NoNpeOnMissingAnnotation { + public static void main(String... args) throws Exception { + System.out.println(NoNpeOnMissingAnnotation.class. + getDeclaredMethod("foo"). + getAnnotatedReturnType()); + } + + @MissingAnnotation Object foo() { return null; } +} diff --git a/jdk/test/java/lang/invoke/DropArgumentsTest.java b/jdk/test/java/lang/invoke/DropArgumentsTest.java index 319d5b86eb3..be65b39b276 100644 --- a/jdk/test/java/lang/invoke/DropArgumentsTest.java +++ b/jdk/test/java/lang/invoke/DropArgumentsTest.java @@ -24,6 +24,7 @@ */ /* @test + * @bug 8158169 * @summary unit tests for java.lang.invoke.MethodHandles * @run testng test.java.lang.invoke.DropArgumentsTest */ @@ -32,6 +33,7 @@ package test.java.lang.invoke; import java.lang.invoke.MethodHandle; import java.lang.invoke.MethodHandles; import java.lang.invoke.MethodType; +import java.util.Collections; import java.util.List; import static java.lang.invoke.MethodHandles.*; import static java.lang.invoke.MethodType.*; @@ -78,6 +80,7 @@ public class DropArgumentsTest { {cat, -1, bigType.parameterList(), 0}, {cat, 0, bigType.parameterList(), -1}, {cat, 3, bigType.parameterList(), 0}, + {cat, 0, bigType.parameterList(), 6}, {cat, 0, bigType.parameterList(), 2} }; } @@ -96,4 +99,30 @@ public class DropArgumentsTest { MethodType bigTypewithVoid = cat.type().insertParameterTypes(0, void.class, String.class, int.class); MethodHandle handle2 = MethodHandles.dropArgumentsToMatch(cat, 0, bigTypewithVoid.parameterList(), 1); } + + public static class MethodSet { + + static void mVoid() { + + } + + static void mVoid(int t) { + + } + } + + @Test + public void dropArgumentsToMatchPosSkipRange() throws Throwable { + // newTypes.size() == 1, pos == 1 && target.paramSize() == 0, skip == 0 + MethodHandle mh1 = MethodHandles.lookup().findStatic(MethodSet.class, "mVoid", + MethodType.methodType(void.class)); + MethodHandle handle1 = dropArgumentsToMatch(mh1, 0, Collections.singletonList(int.class), 1); + assertEquals(1, handle1.type().parameterList().size()); + + // newTypes.size() == 1, pos == 0 && target.paramSize() == 1, skip == 1 + MethodHandle mh2 = MethodHandles.lookup().findStatic(MethodSet.class, "mVoid", + MethodType.methodType(void.class, int.class)); + MethodHandle handle2 = dropArgumentsToMatch(mh2, 1, Collections.singletonList(int.class), 0); + assertEquals(2, handle2.type().parameterList().size()); + } } diff --git a/jdk/test/java/lang/invoke/LoopCombinatorLongSignatureTest.java b/jdk/test/java/lang/invoke/LoopCombinatorLongSignatureTest.java new file mode 100644 index 00000000000..0e4f6dff726 --- /dev/null +++ b/jdk/test/java/lang/invoke/LoopCombinatorLongSignatureTest.java @@ -0,0 +1,105 @@ +/* + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* @test + * @bug 8160717 + * @run main/othervm -ea -esa -Djava.lang.invoke.MethodHandle.COMPILE_THRESHOLD=-1 test.java.lang.invoke.LoopCombinatorLongSignatureTest + * @run main/othervm -ea -esa test.java.lang.invoke.LoopCombinatorLongSignatureTest + */ + +package test.java.lang.invoke; + +import java.lang.invoke.MethodHandle; +import java.lang.invoke.MethodHandles; +import java.util.Arrays; + +/** + * If a loop with an excessive amount of clauses is created, so that the number of parameters to the resulting loop + * handle exceeds the allowed maximum, an IAE must be signalled. The test is run first in LambdaForm interpretation mode + * and then in default mode, wherein bytecode generation falls back to LFI mode due to excessively long methods. + */ +public class LoopCombinatorLongSignatureTest { + + static final MethodHandle INIT = MethodHandles.constant(int.class, 0); + static final MethodHandle STEP = MethodHandles.identity(int.class); + static final MethodHandle PRED_F = MethodHandles.constant(boolean.class, false); + static final MethodHandle PRED_T = MethodHandles.constant(boolean.class, true); + static final MethodHandle FINI = MethodHandles.identity(int.class); + + static final int ARG_LIMIT = 254; // for internal reasons, this is the maximum allowed number of arguments + + public static void main(String[] args) { + for (int loopArgs = 0; loopArgs < 2; ++loopArgs) { + testLongSignature(loopArgs, false); + testLongSignature(loopArgs, true); + } + } + + static void testLongSignature(int loopArgs, boolean excessive) { + int nClauses = ARG_LIMIT - loopArgs + (excessive ? 1 : 0); + + System.out.print((excessive ? "(EXCESSIVE)" : "(LONG )") + " arguments: " + loopArgs + ", clauses: " + nClauses + " -> "); + + // extend init to denote what arguments the loop should accept + Class[] argTypes = new Class[loopArgs]; + Arrays.fill(argTypes, int.class); + MethodHandle init = MethodHandles.dropArguments(INIT, 0, argTypes); + + // build clauses + MethodHandle[][] clauses = new MethodHandle[nClauses][]; + MethodHandle[] clause = {init, STEP, PRED_T, FINI}; + MethodHandle[] fclause = {init, STEP, PRED_F, FINI}; + Arrays.fill(clauses, clause); + clauses[nClauses - 1] = fclause; // make the last clause terminate the loop + + try { + MethodHandle loop = MethodHandles.loop(clauses); + if (excessive) { + throw new AssertionError("loop construction should have failed"); + } else { + int r; + if (loopArgs == 0) { + r = (int) loop.invoke(); + } else { + Object[] args = new Object[loopArgs]; + Arrays.fill(args, 0); + r = (int) loop.invokeWithArguments(args); + } + System.out.println("SUCCEEDED (OK) -> " + r); + } + } catch (IllegalArgumentException iae) { + if (excessive) { + System.out.println("FAILED (OK)"); + } else { + iae.printStackTrace(System.out); + throw new AssertionError("loop construction should not have failed (see above)"); + } + } catch (Throwable t) { + t.printStackTrace(System.out); + throw new AssertionError("unexpected failure (see above)"); + } + } + +} diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleBaseTest.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleBaseTest.java index b8cbc17784d..ed3160b9979 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleBaseTest.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleBaseTest.java @@ -145,7 +145,7 @@ abstract class VarHandleBaseTest { GET_OPAQUE(TestAccessType.GET), SET_OPAQUE(TestAccessType.SET), COMPARE_AND_SET(TestAccessType.COMPARE_AND_SET), - COMPARE_AND_EXCHANGE_VOLATILE(TestAccessType.COMPARE_AND_EXCHANGE), + COMPARE_AND_EXCHANGE(TestAccessType.COMPARE_AND_EXCHANGE), COMPARE_AND_EXCHANGE_ACQUIRE(TestAccessType.COMPARE_AND_EXCHANGE), COMPARE_AND_EXCHANGE_RELEASE(TestAccessType.COMPARE_AND_EXCHANGE), WEAK_COMPARE_AND_SET(TestAccessType.COMPARE_AND_SET), diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessBoolean.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessBoolean.java index 9a02753d945..ae23346c689 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessBoolean.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessBoolean.java @@ -99,15 +99,15 @@ public class VarHandleTestAccessBoolean extends VarHandleBaseTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_OPAQUE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_VOLATILE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_ACQUIRE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_RELEASE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_ACQUIRE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_RELEASE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_SET)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_ADD)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.ADD_AND_GET)); @@ -260,41 +260,6 @@ public class VarHandleTestAccessBoolean extends VarHandleBaseTest { vh.setOpaque(recv, false); }); - checkUOE(() -> { - boolean r = vh.compareAndSet(recv, true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeVolatile(recv, true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeAcquire(recv, true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeRelease(recv, true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(recv, true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(recv, true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(recv, true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(recv, true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.getAndSet(recv, true); - }); checkUOE(() -> { boolean o = (boolean) vh.getAndAdd(recv, true); @@ -350,41 +315,6 @@ public class VarHandleTestAccessBoolean extends VarHandleBaseTest { vh.setOpaque(false); }); - checkUOE(() -> { - boolean r = vh.compareAndSet(true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeVolatile(true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeAcquire(true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeRelease(true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.getAndSet(true); - }); checkUOE(() -> { boolean o = (boolean) vh.getAndAdd(true); @@ -426,45 +356,116 @@ public class VarHandleTestAccessBoolean extends VarHandleBaseTest { assertEquals(x, false, "setOpaque boolean value"); } + vh.set(recv, true); + + // Compare + { + boolean r = vh.compareAndSet(recv, true, false); + assertEquals(r, true, "success compareAndSet boolean"); + boolean x = (boolean) vh.get(recv); + assertEquals(x, false, "success compareAndSet boolean value"); + } + + { + boolean r = vh.compareAndSet(recv, true, false); + assertEquals(r, false, "failing compareAndSet boolean"); + boolean x = (boolean) vh.get(recv); + assertEquals(x, false, "failing compareAndSet boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchange(recv, false, true); + assertEquals(r, false, "success compareAndExchange boolean"); + boolean x = (boolean) vh.get(recv); + assertEquals(x, true, "success compareAndExchange boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchange(recv, false, false); + assertEquals(r, true, "failing compareAndExchange boolean"); + boolean x = (boolean) vh.get(recv); + assertEquals(x, true, "failing compareAndExchange boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchangeAcquire(recv, true, false); + assertEquals(r, true, "success compareAndExchangeAcquire boolean"); + boolean x = (boolean) vh.get(recv); + assertEquals(x, false, "success compareAndExchangeAcquire boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchangeAcquire(recv, true, false); + assertEquals(r, false, "failing compareAndExchangeAcquire boolean"); + boolean x = (boolean) vh.get(recv); + assertEquals(x, false, "failing compareAndExchangeAcquire boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchangeRelease(recv, false, true); + assertEquals(r, false, "success compareAndExchangeRelease boolean"); + boolean x = (boolean) vh.get(recv); + assertEquals(x, true, "success compareAndExchangeRelease boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchangeRelease(recv, false, false); + assertEquals(r, true, "failing compareAndExchangeRelease boolean"); + boolean x = (boolean) vh.get(recv); + assertEquals(x, true, "failing compareAndExchangeRelease boolean value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(recv, true, false); + } + assertEquals(success, true, "weakCompareAndSet boolean"); + boolean x = (boolean) vh.get(recv); + assertEquals(x, false, "weakCompareAndSet boolean value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(recv, false, true); + } + assertEquals(success, true, "weakCompareAndSetAcquire boolean"); + boolean x = (boolean) vh.get(recv); + assertEquals(x, true, "weakCompareAndSetAcquire boolean"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(recv, true, false); + } + assertEquals(success, true, "weakCompareAndSetRelease boolean"); + boolean x = (boolean) vh.get(recv); + assertEquals(x, false, "weakCompareAndSetRelease boolean"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetVolatile(recv, false, true); + } + assertEquals(success, true, "weakCompareAndSetVolatile boolean"); + boolean x = (boolean) vh.get(recv); + assertEquals(x, true, "weakCompareAndSetVolatile boolean value"); + } + + // Compare set and get + { + boolean o = (boolean) vh.getAndSet(recv, false); + assertEquals(o, true, "getAndSet boolean"); + boolean x = (boolean) vh.get(recv); + assertEquals(x, false, "getAndSet boolean value"); + } } static void testInstanceFieldUnsupported(VarHandleTestAccessBoolean recv, VarHandle vh) { - checkUOE(() -> { - boolean r = vh.compareAndSet(recv, true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeVolatile(recv, true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeAcquire(recv, true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeRelease(recv, true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(recv, true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(recv, true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(recv, true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(recv, true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.getAndSet(recv, true); - }); checkUOE(() -> { boolean o = (boolean) vh.getAndAdd(recv, true); @@ -506,45 +507,116 @@ public class VarHandleTestAccessBoolean extends VarHandleBaseTest { assertEquals(x, false, "setOpaque boolean value"); } + vh.set(true); + + // Compare + { + boolean r = vh.compareAndSet(true, false); + assertEquals(r, true, "success compareAndSet boolean"); + boolean x = (boolean) vh.get(); + assertEquals(x, false, "success compareAndSet boolean value"); + } + + { + boolean r = vh.compareAndSet(true, false); + assertEquals(r, false, "failing compareAndSet boolean"); + boolean x = (boolean) vh.get(); + assertEquals(x, false, "failing compareAndSet boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchange(false, true); + assertEquals(r, false, "success compareAndExchange boolean"); + boolean x = (boolean) vh.get(); + assertEquals(x, true, "success compareAndExchange boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchange(false, false); + assertEquals(r, true, "failing compareAndExchange boolean"); + boolean x = (boolean) vh.get(); + assertEquals(x, true, "failing compareAndExchange boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchangeAcquire(true, false); + assertEquals(r, true, "success compareAndExchangeAcquire boolean"); + boolean x = (boolean) vh.get(); + assertEquals(x, false, "success compareAndExchangeAcquire boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchangeAcquire(true, false); + assertEquals(r, false, "failing compareAndExchangeAcquire boolean"); + boolean x = (boolean) vh.get(); + assertEquals(x, false, "failing compareAndExchangeAcquire boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchangeRelease(false, true); + assertEquals(r, false, "success compareAndExchangeRelease boolean"); + boolean x = (boolean) vh.get(); + assertEquals(x, true, "success compareAndExchangeRelease boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchangeRelease(false, false); + assertEquals(r, true, "failing compareAndExchangeRelease boolean"); + boolean x = (boolean) vh.get(); + assertEquals(x, true, "failing compareAndExchangeRelease boolean value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(true, false); + } + assertEquals(success, true, "weakCompareAndSet boolean"); + boolean x = (boolean) vh.get(); + assertEquals(x, false, "weakCompareAndSet boolean value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(false, true); + } + assertEquals(success, true, "weakCompareAndSetAcquire boolean"); + boolean x = (boolean) vh.get(); + assertEquals(x, true, "weakCompareAndSetAcquire boolean"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(true, false); + } + assertEquals(success, true, "weakCompareAndSetRelease boolean"); + boolean x = (boolean) vh.get(); + assertEquals(x, false, "weakCompareAndSetRelease boolean"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(false, true); + } + assertEquals(success, true, "weakCompareAndSetVolatile boolean"); + boolean x = (boolean) vh.get(); + assertEquals(x, true, "weakCompareAndSetVolatile boolean"); + } + + // Compare set and get + { + boolean o = (boolean) vh.getAndSet(false); + assertEquals(o, true, "getAndSet boolean"); + boolean x = (boolean) vh.get(); + assertEquals(x, false, "getAndSet boolean value"); + } } static void testStaticFieldUnsupported(VarHandle vh) { - checkUOE(() -> { - boolean r = vh.compareAndSet(true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeVolatile(true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeAcquire(true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeRelease(true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.getAndSet(true); - }); checkUOE(() -> { boolean o = (boolean) vh.getAndAdd(true); @@ -589,6 +661,112 @@ public class VarHandleTestAccessBoolean extends VarHandleBaseTest { assertEquals(x, false, "setOpaque boolean value"); } + vh.set(array, i, true); + + // Compare + { + boolean r = vh.compareAndSet(array, i, true, false); + assertEquals(r, true, "success compareAndSet boolean"); + boolean x = (boolean) vh.get(array, i); + assertEquals(x, false, "success compareAndSet boolean value"); + } + + { + boolean r = vh.compareAndSet(array, i, true, false); + assertEquals(r, false, "failing compareAndSet boolean"); + boolean x = (boolean) vh.get(array, i); + assertEquals(x, false, "failing compareAndSet boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchange(array, i, false, true); + assertEquals(r, false, "success compareAndExchange boolean"); + boolean x = (boolean) vh.get(array, i); + assertEquals(x, true, "success compareAndExchange boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchange(array, i, false, false); + assertEquals(r, true, "failing compareAndExchange boolean"); + boolean x = (boolean) vh.get(array, i); + assertEquals(x, true, "failing compareAndExchange boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchangeAcquire(array, i, true, false); + assertEquals(r, true, "success compareAndExchangeAcquire boolean"); + boolean x = (boolean) vh.get(array, i); + assertEquals(x, false, "success compareAndExchangeAcquire boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchangeAcquire(array, i, true, false); + assertEquals(r, false, "failing compareAndExchangeAcquire boolean"); + boolean x = (boolean) vh.get(array, i); + assertEquals(x, false, "failing compareAndExchangeAcquire boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchangeRelease(array, i, false, true); + assertEquals(r, false, "success compareAndExchangeRelease boolean"); + boolean x = (boolean) vh.get(array, i); + assertEquals(x, true, "success compareAndExchangeRelease boolean value"); + } + + { + boolean r = (boolean) vh.compareAndExchangeRelease(array, i, false, false); + assertEquals(r, true, "failing compareAndExchangeRelease boolean"); + boolean x = (boolean) vh.get(array, i); + assertEquals(x, true, "failing compareAndExchangeRelease boolean value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(array, i, true, false); + } + assertEquals(success, true, "weakCompareAndSet boolean"); + boolean x = (boolean) vh.get(array, i); + assertEquals(x, false, "weakCompareAndSet boolean value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(array, i, false, true); + } + assertEquals(success, true, "weakCompareAndSetAcquire boolean"); + boolean x = (boolean) vh.get(array, i); + assertEquals(x, true, "weakCompareAndSetAcquire boolean"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(array, i, true, false); + } + assertEquals(success, true, "weakCompareAndSetRelease boolean"); + boolean x = (boolean) vh.get(array, i); + assertEquals(x, false, "weakCompareAndSetRelease boolean"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetVolatile(array, i, false, true); + } + assertEquals(success, true, "weakCompareAndSetVolatile boolean"); + boolean x = (boolean) vh.get(array, i); + assertEquals(x, true, "weakCompareAndSetVolatile boolean"); + } + + // Compare set and get + { + boolean o = (boolean) vh.getAndSet(array, i, false); + assertEquals(o, true, "getAndSet boolean"); + boolean x = (boolean) vh.get(array, i); + assertEquals(x, false, "getAndSet boolean value"); + } } } @@ -597,41 +775,6 @@ public class VarHandleTestAccessBoolean extends VarHandleBaseTest { boolean[] array = new boolean[10]; int i = 0; - checkUOE(() -> { - boolean r = vh.compareAndSet(array, i, true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeVolatile(array, i, true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeAcquire(array, i, true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.compareAndExchangeRelease(array, i, true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(array, i, true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(array, i, true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(array, i, true, false); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(array, i, true, false); - }); - - checkUOE(() -> { - boolean r = (boolean) vh.getAndSet(array, i, true); - }); checkUOE(() -> { boolean o = (boolean) vh.getAndAdd(array, i, true); @@ -680,6 +823,41 @@ public class VarHandleTestAccessBoolean extends VarHandleBaseTest { vh.setOpaque(array, ci, true); }); + checkIOOBE(() -> { + boolean r = vh.compareAndSet(array, ci, true, false); + }); + + checkIOOBE(() -> { + boolean r = (boolean) vh.compareAndExchange(array, ci, false, true); + }); + + checkIOOBE(() -> { + boolean r = (boolean) vh.compareAndExchangeAcquire(array, ci, false, true); + }); + + checkIOOBE(() -> { + boolean r = (boolean) vh.compareAndExchangeRelease(array, ci, false, true); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSet(array, ci, true, false); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetVolatile(array, ci, true, false); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetAcquire(array, ci, true, false); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetRelease(array, ci, true, false); + }); + + checkIOOBE(() -> { + boolean o = (boolean) vh.getAndSet(array, ci, true); + }); } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessByte.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessByte.java index 17544907e8d..754f4908a8a 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessByte.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessByte.java @@ -42,11 +42,11 @@ import java.util.List; import static org.testng.Assert.*; public class VarHandleTestAccessByte extends VarHandleBaseTest { - static final byte static_final_v = (byte)1; + static final byte static_final_v = (byte)0x01; static byte static_v; - final byte final_v = (byte)1; + final byte final_v = (byte)0x01; byte v; @@ -99,18 +99,18 @@ public class VarHandleTestAccessByte extends VarHandleBaseTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_OPAQUE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_VOLATILE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_ACQUIRE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_RELEASE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_ACQUIRE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_RELEASE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_ADD)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.ADD_AND_GET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_ADD)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.ADD_AND_GET)); } @@ -220,89 +220,47 @@ public class VarHandleTestAccessByte extends VarHandleBaseTest { // Plain { byte x = (byte) vh.get(recv); - assertEquals(x, (byte)1, "get byte value"); + assertEquals(x, (byte)0x01, "get byte value"); } // Volatile { byte x = (byte) vh.getVolatile(recv); - assertEquals(x, (byte)1, "getVolatile byte value"); + assertEquals(x, (byte)0x01, "getVolatile byte value"); } // Lazy { byte x = (byte) vh.getAcquire(recv); - assertEquals(x, (byte)1, "getRelease byte value"); + assertEquals(x, (byte)0x01, "getRelease byte value"); } // Opaque { byte x = (byte) vh.getOpaque(recv); - assertEquals(x, (byte)1, "getOpaque byte value"); + assertEquals(x, (byte)0x01, "getOpaque byte value"); } } static void testInstanceFinalFieldUnsupported(VarHandleTestAccessByte recv, VarHandle vh) { checkUOE(() -> { - vh.set(recv, (byte)2); + vh.set(recv, (byte)0x23); }); checkUOE(() -> { - vh.setVolatile(recv, (byte)2); + vh.setVolatile(recv, (byte)0x23); }); checkUOE(() -> { - vh.setRelease(recv, (byte)2); + vh.setRelease(recv, (byte)0x23); }); checkUOE(() -> { - vh.setOpaque(recv, (byte)2); + vh.setOpaque(recv, (byte)0x23); }); - checkUOE(() -> { - boolean r = vh.compareAndSet(recv, (byte)1, (byte)2); - }); - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeVolatile(recv, (byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeAcquire(recv, (byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeRelease(recv, (byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(recv, (byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(recv, (byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(recv, (byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(recv, (byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.getAndSet(recv, (byte)1); - }); - - checkUOE(() -> { - byte o = (byte) vh.getAndAdd(recv, (byte)1); - }); - - checkUOE(() -> { - byte o = (byte) vh.addAndGet(recv, (byte)1); - }); } @@ -310,249 +268,353 @@ public class VarHandleTestAccessByte extends VarHandleBaseTest { // Plain { byte x = (byte) vh.get(); - assertEquals(x, (byte)1, "get byte value"); + assertEquals(x, (byte)0x01, "get byte value"); } // Volatile { byte x = (byte) vh.getVolatile(); - assertEquals(x, (byte)1, "getVolatile byte value"); + assertEquals(x, (byte)0x01, "getVolatile byte value"); } // Lazy { byte x = (byte) vh.getAcquire(); - assertEquals(x, (byte)1, "getRelease byte value"); + assertEquals(x, (byte)0x01, "getRelease byte value"); } // Opaque { byte x = (byte) vh.getOpaque(); - assertEquals(x, (byte)1, "getOpaque byte value"); + assertEquals(x, (byte)0x01, "getOpaque byte value"); } } static void testStaticFinalFieldUnsupported(VarHandle vh) { checkUOE(() -> { - vh.set((byte)2); + vh.set((byte)0x23); }); checkUOE(() -> { - vh.setVolatile((byte)2); + vh.setVolatile((byte)0x23); }); checkUOE(() -> { - vh.setRelease((byte)2); + vh.setRelease((byte)0x23); }); checkUOE(() -> { - vh.setOpaque((byte)2); + vh.setOpaque((byte)0x23); }); - checkUOE(() -> { - boolean r = vh.compareAndSet((byte)1, (byte)2); - }); - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeVolatile((byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeAcquire((byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeRelease((byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet((byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile((byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire((byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease((byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.getAndSet((byte)1); - }); - - checkUOE(() -> { - byte o = (byte) vh.getAndAdd((byte)1); - }); - - checkUOE(() -> { - byte o = (byte) vh.addAndGet((byte)1); - }); } static void testInstanceField(VarHandleTestAccessByte recv, VarHandle vh) { // Plain { - vh.set(recv, (byte)1); + vh.set(recv, (byte)0x01); byte x = (byte) vh.get(recv); - assertEquals(x, (byte)1, "set byte value"); + assertEquals(x, (byte)0x01, "set byte value"); } // Volatile { - vh.setVolatile(recv, (byte)2); + vh.setVolatile(recv, (byte)0x23); byte x = (byte) vh.getVolatile(recv); - assertEquals(x, (byte)2, "setVolatile byte value"); + assertEquals(x, (byte)0x23, "setVolatile byte value"); } // Lazy { - vh.setRelease(recv, (byte)1); + vh.setRelease(recv, (byte)0x01); byte x = (byte) vh.getAcquire(recv); - assertEquals(x, (byte)1, "setRelease byte value"); + assertEquals(x, (byte)0x01, "setRelease byte value"); } // Opaque { - vh.setOpaque(recv, (byte)2); + vh.setOpaque(recv, (byte)0x23); byte x = (byte) vh.getOpaque(recv); - assertEquals(x, (byte)2, "setOpaque byte value"); + assertEquals(x, (byte)0x23, "setOpaque byte value"); } + vh.set(recv, (byte)0x01); + // Compare + { + boolean r = vh.compareAndSet(recv, (byte)0x01, (byte)0x23); + assertEquals(r, true, "success compareAndSet byte"); + byte x = (byte) vh.get(recv); + assertEquals(x, (byte)0x23, "success compareAndSet byte value"); + } + + { + boolean r = vh.compareAndSet(recv, (byte)0x01, (byte)0x45); + assertEquals(r, false, "failing compareAndSet byte"); + byte x = (byte) vh.get(recv); + assertEquals(x, (byte)0x23, "failing compareAndSet byte value"); + } + + { + byte r = (byte) vh.compareAndExchange(recv, (byte)0x23, (byte)0x01); + assertEquals(r, (byte)0x23, "success compareAndExchange byte"); + byte x = (byte) vh.get(recv); + assertEquals(x, (byte)0x01, "success compareAndExchange byte value"); + } + + { + byte r = (byte) vh.compareAndExchange(recv, (byte)0x23, (byte)0x45); + assertEquals(r, (byte)0x01, "failing compareAndExchange byte"); + byte x = (byte) vh.get(recv); + assertEquals(x, (byte)0x01, "failing compareAndExchange byte value"); + } + + { + byte r = (byte) vh.compareAndExchangeAcquire(recv, (byte)0x01, (byte)0x23); + assertEquals(r, (byte)0x01, "success compareAndExchangeAcquire byte"); + byte x = (byte) vh.get(recv); + assertEquals(x, (byte)0x23, "success compareAndExchangeAcquire byte value"); + } + + { + byte r = (byte) vh.compareAndExchangeAcquire(recv, (byte)0x01, (byte)0x45); + assertEquals(r, (byte)0x23, "failing compareAndExchangeAcquire byte"); + byte x = (byte) vh.get(recv); + assertEquals(x, (byte)0x23, "failing compareAndExchangeAcquire byte value"); + } + + { + byte r = (byte) vh.compareAndExchangeRelease(recv, (byte)0x23, (byte)0x01); + assertEquals(r, (byte)0x23, "success compareAndExchangeRelease byte"); + byte x = (byte) vh.get(recv); + assertEquals(x, (byte)0x01, "success compareAndExchangeRelease byte value"); + } + + { + byte r = (byte) vh.compareAndExchangeRelease(recv, (byte)0x23, (byte)0x45); + assertEquals(r, (byte)0x01, "failing compareAndExchangeRelease byte"); + byte x = (byte) vh.get(recv); + assertEquals(x, (byte)0x01, "failing compareAndExchangeRelease byte value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(recv, (byte)0x01, (byte)0x23); + } + assertEquals(success, true, "weakCompareAndSet byte"); + byte x = (byte) vh.get(recv); + assertEquals(x, (byte)0x23, "weakCompareAndSet byte value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(recv, (byte)0x23, (byte)0x01); + } + assertEquals(success, true, "weakCompareAndSetAcquire byte"); + byte x = (byte) vh.get(recv); + assertEquals(x, (byte)0x01, "weakCompareAndSetAcquire byte"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(recv, (byte)0x01, (byte)0x23); + } + assertEquals(success, true, "weakCompareAndSetRelease byte"); + byte x = (byte) vh.get(recv); + assertEquals(x, (byte)0x23, "weakCompareAndSetRelease byte"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetVolatile(recv, (byte)0x23, (byte)0x01); + } + assertEquals(success, true, "weakCompareAndSetVolatile byte"); + byte x = (byte) vh.get(recv); + assertEquals(x, (byte)0x01, "weakCompareAndSetVolatile byte value"); + } + + // Compare set and get + { + byte o = (byte) vh.getAndSet(recv, (byte)0x23); + assertEquals(o, (byte)0x01, "getAndSet byte"); + byte x = (byte) vh.get(recv); + assertEquals(x, (byte)0x23, "getAndSet byte value"); + } + + vh.set(recv, (byte)0x01); + + // get and add, add and get + { + byte o = (byte) vh.getAndAdd(recv, (byte)0x45); + assertEquals(o, (byte)0x01, "getAndAdd byte"); + byte c = (byte) vh.addAndGet(recv, (byte)0x45); + assertEquals(c, (byte)((byte)0x01 + (byte)0x45 + (byte)0x45), "getAndAdd byte value"); + } } static void testInstanceFieldUnsupported(VarHandleTestAccessByte recv, VarHandle vh) { - checkUOE(() -> { - boolean r = vh.compareAndSet(recv, (byte)1, (byte)2); - }); - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeVolatile(recv, (byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeAcquire(recv, (byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeRelease(recv, (byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(recv, (byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(recv, (byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(recv, (byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(recv, (byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.getAndSet(recv, (byte)1); - }); - - checkUOE(() -> { - byte o = (byte) vh.getAndAdd(recv, (byte)1); - }); - - checkUOE(() -> { - byte o = (byte) vh.addAndGet(recv, (byte)1); - }); } static void testStaticField(VarHandle vh) { // Plain { - vh.set((byte)1); + vh.set((byte)0x01); byte x = (byte) vh.get(); - assertEquals(x, (byte)1, "set byte value"); + assertEquals(x, (byte)0x01, "set byte value"); } // Volatile { - vh.setVolatile((byte)2); + vh.setVolatile((byte)0x23); byte x = (byte) vh.getVolatile(); - assertEquals(x, (byte)2, "setVolatile byte value"); + assertEquals(x, (byte)0x23, "setVolatile byte value"); } // Lazy { - vh.setRelease((byte)1); + vh.setRelease((byte)0x01); byte x = (byte) vh.getAcquire(); - assertEquals(x, (byte)1, "setRelease byte value"); + assertEquals(x, (byte)0x01, "setRelease byte value"); } // Opaque { - vh.setOpaque((byte)2); + vh.setOpaque((byte)0x23); byte x = (byte) vh.getOpaque(); - assertEquals(x, (byte)2, "setOpaque byte value"); + assertEquals(x, (byte)0x23, "setOpaque byte value"); } + vh.set((byte)0x01); + // Compare + { + boolean r = vh.compareAndSet((byte)0x01, (byte)0x23); + assertEquals(r, true, "success compareAndSet byte"); + byte x = (byte) vh.get(); + assertEquals(x, (byte)0x23, "success compareAndSet byte value"); + } + + { + boolean r = vh.compareAndSet((byte)0x01, (byte)0x45); + assertEquals(r, false, "failing compareAndSet byte"); + byte x = (byte) vh.get(); + assertEquals(x, (byte)0x23, "failing compareAndSet byte value"); + } + + { + byte r = (byte) vh.compareAndExchange((byte)0x23, (byte)0x01); + assertEquals(r, (byte)0x23, "success compareAndExchange byte"); + byte x = (byte) vh.get(); + assertEquals(x, (byte)0x01, "success compareAndExchange byte value"); + } + + { + byte r = (byte) vh.compareAndExchange((byte)0x23, (byte)0x45); + assertEquals(r, (byte)0x01, "failing compareAndExchange byte"); + byte x = (byte) vh.get(); + assertEquals(x, (byte)0x01, "failing compareAndExchange byte value"); + } + + { + byte r = (byte) vh.compareAndExchangeAcquire((byte)0x01, (byte)0x23); + assertEquals(r, (byte)0x01, "success compareAndExchangeAcquire byte"); + byte x = (byte) vh.get(); + assertEquals(x, (byte)0x23, "success compareAndExchangeAcquire byte value"); + } + + { + byte r = (byte) vh.compareAndExchangeAcquire((byte)0x01, (byte)0x45); + assertEquals(r, (byte)0x23, "failing compareAndExchangeAcquire byte"); + byte x = (byte) vh.get(); + assertEquals(x, (byte)0x23, "failing compareAndExchangeAcquire byte value"); + } + + { + byte r = (byte) vh.compareAndExchangeRelease((byte)0x23, (byte)0x01); + assertEquals(r, (byte)0x23, "success compareAndExchangeRelease byte"); + byte x = (byte) vh.get(); + assertEquals(x, (byte)0x01, "success compareAndExchangeRelease byte value"); + } + + { + byte r = (byte) vh.compareAndExchangeRelease((byte)0x23, (byte)0x45); + assertEquals(r, (byte)0x01, "failing compareAndExchangeRelease byte"); + byte x = (byte) vh.get(); + assertEquals(x, (byte)0x01, "failing compareAndExchangeRelease byte value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet((byte)0x01, (byte)0x23); + } + assertEquals(success, true, "weakCompareAndSet byte"); + byte x = (byte) vh.get(); + assertEquals(x, (byte)0x23, "weakCompareAndSet byte value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire((byte)0x23, (byte)0x01); + } + assertEquals(success, true, "weakCompareAndSetAcquire byte"); + byte x = (byte) vh.get(); + assertEquals(x, (byte)0x01, "weakCompareAndSetAcquire byte"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease((byte)0x01, (byte)0x23); + } + assertEquals(success, true, "weakCompareAndSetRelease byte"); + byte x = (byte) vh.get(); + assertEquals(x, (byte)0x23, "weakCompareAndSetRelease byte"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease((byte)0x23, (byte)0x01); + } + assertEquals(success, true, "weakCompareAndSetVolatile byte"); + byte x = (byte) vh.get(); + assertEquals(x, (byte)0x01, "weakCompareAndSetVolatile byte"); + } + + // Compare set and get + { + byte o = (byte) vh.getAndSet((byte)0x23); + assertEquals(o, (byte)0x01, "getAndSet byte"); + byte x = (byte) vh.get(); + assertEquals(x, (byte)0x23, "getAndSet byte value"); + } + + vh.set((byte)0x01); + + // get and add, add and get + { + byte o = (byte) vh.getAndAdd( (byte)0x45); + assertEquals(o, (byte)0x01, "getAndAdd byte"); + byte c = (byte) vh.addAndGet((byte)0x45); + assertEquals(c, (byte)((byte)0x01 + (byte)0x45 + (byte)0x45), "getAndAdd byte value"); + } } static void testStaticFieldUnsupported(VarHandle vh) { - checkUOE(() -> { - boolean r = vh.compareAndSet((byte)1, (byte)2); - }); - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeVolatile((byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeAcquire((byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeRelease((byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet((byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile((byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire((byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease((byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.getAndSet((byte)1); - }); - - checkUOE(() -> { - byte o = (byte) vh.getAndAdd((byte)1); - }); - - checkUOE(() -> { - byte o = (byte) vh.addAndGet((byte)1); - }); } @@ -562,34 +624,149 @@ public class VarHandleTestAccessByte extends VarHandleBaseTest { for (int i = 0; i < array.length; i++) { // Plain { - vh.set(array, i, (byte)1); + vh.set(array, i, (byte)0x01); byte x = (byte) vh.get(array, i); - assertEquals(x, (byte)1, "get byte value"); + assertEquals(x, (byte)0x01, "get byte value"); } // Volatile { - vh.setVolatile(array, i, (byte)2); + vh.setVolatile(array, i, (byte)0x23); byte x = (byte) vh.getVolatile(array, i); - assertEquals(x, (byte)2, "setVolatile byte value"); + assertEquals(x, (byte)0x23, "setVolatile byte value"); } // Lazy { - vh.setRelease(array, i, (byte)1); + vh.setRelease(array, i, (byte)0x01); byte x = (byte) vh.getAcquire(array, i); - assertEquals(x, (byte)1, "setRelease byte value"); + assertEquals(x, (byte)0x01, "setRelease byte value"); } // Opaque { - vh.setOpaque(array, i, (byte)2); + vh.setOpaque(array, i, (byte)0x23); byte x = (byte) vh.getOpaque(array, i); - assertEquals(x, (byte)2, "setOpaque byte value"); + assertEquals(x, (byte)0x23, "setOpaque byte value"); } + vh.set(array, i, (byte)0x01); + // Compare + { + boolean r = vh.compareAndSet(array, i, (byte)0x01, (byte)0x23); + assertEquals(r, true, "success compareAndSet byte"); + byte x = (byte) vh.get(array, i); + assertEquals(x, (byte)0x23, "success compareAndSet byte value"); + } + + { + boolean r = vh.compareAndSet(array, i, (byte)0x01, (byte)0x45); + assertEquals(r, false, "failing compareAndSet byte"); + byte x = (byte) vh.get(array, i); + assertEquals(x, (byte)0x23, "failing compareAndSet byte value"); + } + + { + byte r = (byte) vh.compareAndExchange(array, i, (byte)0x23, (byte)0x01); + assertEquals(r, (byte)0x23, "success compareAndExchange byte"); + byte x = (byte) vh.get(array, i); + assertEquals(x, (byte)0x01, "success compareAndExchange byte value"); + } + + { + byte r = (byte) vh.compareAndExchange(array, i, (byte)0x23, (byte)0x45); + assertEquals(r, (byte)0x01, "failing compareAndExchange byte"); + byte x = (byte) vh.get(array, i); + assertEquals(x, (byte)0x01, "failing compareAndExchange byte value"); + } + + { + byte r = (byte) vh.compareAndExchangeAcquire(array, i, (byte)0x01, (byte)0x23); + assertEquals(r, (byte)0x01, "success compareAndExchangeAcquire byte"); + byte x = (byte) vh.get(array, i); + assertEquals(x, (byte)0x23, "success compareAndExchangeAcquire byte value"); + } + + { + byte r = (byte) vh.compareAndExchangeAcquire(array, i, (byte)0x01, (byte)0x45); + assertEquals(r, (byte)0x23, "failing compareAndExchangeAcquire byte"); + byte x = (byte) vh.get(array, i); + assertEquals(x, (byte)0x23, "failing compareAndExchangeAcquire byte value"); + } + + { + byte r = (byte) vh.compareAndExchangeRelease(array, i, (byte)0x23, (byte)0x01); + assertEquals(r, (byte)0x23, "success compareAndExchangeRelease byte"); + byte x = (byte) vh.get(array, i); + assertEquals(x, (byte)0x01, "success compareAndExchangeRelease byte value"); + } + + { + byte r = (byte) vh.compareAndExchangeRelease(array, i, (byte)0x23, (byte)0x45); + assertEquals(r, (byte)0x01, "failing compareAndExchangeRelease byte"); + byte x = (byte) vh.get(array, i); + assertEquals(x, (byte)0x01, "failing compareAndExchangeRelease byte value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(array, i, (byte)0x01, (byte)0x23); + } + assertEquals(success, true, "weakCompareAndSet byte"); + byte x = (byte) vh.get(array, i); + assertEquals(x, (byte)0x23, "weakCompareAndSet byte value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(array, i, (byte)0x23, (byte)0x01); + } + assertEquals(success, true, "weakCompareAndSetAcquire byte"); + byte x = (byte) vh.get(array, i); + assertEquals(x, (byte)0x01, "weakCompareAndSetAcquire byte"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(array, i, (byte)0x01, (byte)0x23); + } + assertEquals(success, true, "weakCompareAndSetRelease byte"); + byte x = (byte) vh.get(array, i); + assertEquals(x, (byte)0x23, "weakCompareAndSetRelease byte"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetVolatile(array, i, (byte)0x23, (byte)0x01); + } + assertEquals(success, true, "weakCompareAndSetVolatile byte"); + byte x = (byte) vh.get(array, i); + assertEquals(x, (byte)0x01, "weakCompareAndSetVolatile byte"); + } + + // Compare set and get + { + byte o = (byte) vh.getAndSet(array, i, (byte)0x23); + assertEquals(o, (byte)0x01, "getAndSet byte"); + byte x = (byte) vh.get(array, i); + assertEquals(x, (byte)0x23, "getAndSet byte value"); + } + + vh.set(array, i, (byte)0x01); + + // get and add, add and get + { + byte o = (byte) vh.getAndAdd(array, i, (byte)0x45); + assertEquals(o, (byte)0x01, "getAndAdd byte"); + byte c = (byte) vh.addAndGet(array, i, (byte)0x45); + assertEquals(c, (byte)((byte)0x01 + (byte)0x45 + (byte)0x45), "getAndAdd byte value"); + } } } @@ -597,49 +774,7 @@ public class VarHandleTestAccessByte extends VarHandleBaseTest { byte[] array = new byte[10]; int i = 0; - checkUOE(() -> { - boolean r = vh.compareAndSet(array, i, (byte)1, (byte)2); - }); - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeVolatile(array, i, (byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeAcquire(array, i, (byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.compareAndExchangeRelease(array, i, (byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(array, i, (byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(array, i, (byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(array, i, (byte)1, (byte)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(array, i, (byte)1, (byte)2); - }); - - checkUOE(() -> { - byte r = (byte) vh.getAndSet(array, i, (byte)1); - }); - - checkUOE(() -> { - byte o = (byte) vh.getAndAdd(array, i, (byte)1); - }); - - checkUOE(() -> { - byte o = (byte) vh.addAndGet(array, i, (byte)1); - }); } static void testArrayIndexOutOfBounds(VarHandle vh) throws Throwable { @@ -653,7 +788,7 @@ public class VarHandleTestAccessByte extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.set(array, ci, (byte)1); + vh.set(array, ci, (byte)0x01); }); checkIOOBE(() -> { @@ -661,7 +796,7 @@ public class VarHandleTestAccessByte extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setVolatile(array, ci, (byte)1); + vh.setVolatile(array, ci, (byte)0x01); }); checkIOOBE(() -> { @@ -669,7 +804,7 @@ public class VarHandleTestAccessByte extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setRelease(array, ci, (byte)1); + vh.setRelease(array, ci, (byte)0x01); }); checkIOOBE(() -> { @@ -677,10 +812,52 @@ public class VarHandleTestAccessByte extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setOpaque(array, ci, (byte)1); + vh.setOpaque(array, ci, (byte)0x01); }); + checkIOOBE(() -> { + boolean r = vh.compareAndSet(array, ci, (byte)0x01, (byte)0x23); + }); + checkIOOBE(() -> { + byte r = (byte) vh.compareAndExchange(array, ci, (byte)0x23, (byte)0x01); + }); + + checkIOOBE(() -> { + byte r = (byte) vh.compareAndExchangeAcquire(array, ci, (byte)0x23, (byte)0x01); + }); + + checkIOOBE(() -> { + byte r = (byte) vh.compareAndExchangeRelease(array, ci, (byte)0x23, (byte)0x01); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSet(array, ci, (byte)0x01, (byte)0x23); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetVolatile(array, ci, (byte)0x01, (byte)0x23); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetAcquire(array, ci, (byte)0x01, (byte)0x23); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetRelease(array, ci, (byte)0x01, (byte)0x23); + }); + + checkIOOBE(() -> { + byte o = (byte) vh.getAndSet(array, ci, (byte)0x01); + }); + + checkIOOBE(() -> { + byte o = (byte) vh.getAndAdd(array, ci, (byte)0x45); + }); + + checkIOOBE(() -> { + byte o = (byte) vh.addAndGet(array, ci, (byte)0x45); + }); } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessChar.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessChar.java index 88bad8475cb..9a0af41e930 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessChar.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessChar.java @@ -42,11 +42,11 @@ import java.util.List; import static org.testng.Assert.*; public class VarHandleTestAccessChar extends VarHandleBaseTest { - static final char static_final_v = 'a'; + static final char static_final_v = '\u0123'; static char static_v; - final char final_v = 'a'; + final char final_v = '\u0123'; char v; @@ -99,18 +99,18 @@ public class VarHandleTestAccessChar extends VarHandleBaseTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_OPAQUE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_VOLATILE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_ACQUIRE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_RELEASE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_ACQUIRE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_RELEASE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_ADD)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.ADD_AND_GET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_ADD)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.ADD_AND_GET)); } @@ -220,89 +220,47 @@ public class VarHandleTestAccessChar extends VarHandleBaseTest { // Plain { char x = (char) vh.get(recv); - assertEquals(x, 'a', "get char value"); + assertEquals(x, '\u0123', "get char value"); } // Volatile { char x = (char) vh.getVolatile(recv); - assertEquals(x, 'a', "getVolatile char value"); + assertEquals(x, '\u0123', "getVolatile char value"); } // Lazy { char x = (char) vh.getAcquire(recv); - assertEquals(x, 'a', "getRelease char value"); + assertEquals(x, '\u0123', "getRelease char value"); } // Opaque { char x = (char) vh.getOpaque(recv); - assertEquals(x, 'a', "getOpaque char value"); + assertEquals(x, '\u0123', "getOpaque char value"); } } static void testInstanceFinalFieldUnsupported(VarHandleTestAccessChar recv, VarHandle vh) { checkUOE(() -> { - vh.set(recv, 'b'); + vh.set(recv, '\u4567'); }); checkUOE(() -> { - vh.setVolatile(recv, 'b'); + vh.setVolatile(recv, '\u4567'); }); checkUOE(() -> { - vh.setRelease(recv, 'b'); + vh.setRelease(recv, '\u4567'); }); checkUOE(() -> { - vh.setOpaque(recv, 'b'); + vh.setOpaque(recv, '\u4567'); }); - checkUOE(() -> { - boolean r = vh.compareAndSet(recv, 'a', 'b'); - }); - checkUOE(() -> { - char r = (char) vh.compareAndExchangeVolatile(recv, 'a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.compareAndExchangeAcquire(recv, 'a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.compareAndExchangeRelease(recv, 'a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(recv, 'a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(recv, 'a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(recv, 'a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(recv, 'a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.getAndSet(recv, 'a'); - }); - - checkUOE(() -> { - char o = (char) vh.getAndAdd(recv, 'a'); - }); - - checkUOE(() -> { - char o = (char) vh.addAndGet(recv, 'a'); - }); } @@ -310,249 +268,353 @@ public class VarHandleTestAccessChar extends VarHandleBaseTest { // Plain { char x = (char) vh.get(); - assertEquals(x, 'a', "get char value"); + assertEquals(x, '\u0123', "get char value"); } // Volatile { char x = (char) vh.getVolatile(); - assertEquals(x, 'a', "getVolatile char value"); + assertEquals(x, '\u0123', "getVolatile char value"); } // Lazy { char x = (char) vh.getAcquire(); - assertEquals(x, 'a', "getRelease char value"); + assertEquals(x, '\u0123', "getRelease char value"); } // Opaque { char x = (char) vh.getOpaque(); - assertEquals(x, 'a', "getOpaque char value"); + assertEquals(x, '\u0123', "getOpaque char value"); } } static void testStaticFinalFieldUnsupported(VarHandle vh) { checkUOE(() -> { - vh.set('b'); + vh.set('\u4567'); }); checkUOE(() -> { - vh.setVolatile('b'); + vh.setVolatile('\u4567'); }); checkUOE(() -> { - vh.setRelease('b'); + vh.setRelease('\u4567'); }); checkUOE(() -> { - vh.setOpaque('b'); + vh.setOpaque('\u4567'); }); - checkUOE(() -> { - boolean r = vh.compareAndSet('a', 'b'); - }); - checkUOE(() -> { - char r = (char) vh.compareAndExchangeVolatile('a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.compareAndExchangeAcquire('a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.compareAndExchangeRelease('a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet('a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile('a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire('a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease('a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.getAndSet('a'); - }); - - checkUOE(() -> { - char o = (char) vh.getAndAdd('a'); - }); - - checkUOE(() -> { - char o = (char) vh.addAndGet('a'); - }); } static void testInstanceField(VarHandleTestAccessChar recv, VarHandle vh) { // Plain { - vh.set(recv, 'a'); + vh.set(recv, '\u0123'); char x = (char) vh.get(recv); - assertEquals(x, 'a', "set char value"); + assertEquals(x, '\u0123', "set char value"); } // Volatile { - vh.setVolatile(recv, 'b'); + vh.setVolatile(recv, '\u4567'); char x = (char) vh.getVolatile(recv); - assertEquals(x, 'b', "setVolatile char value"); + assertEquals(x, '\u4567', "setVolatile char value"); } // Lazy { - vh.setRelease(recv, 'a'); + vh.setRelease(recv, '\u0123'); char x = (char) vh.getAcquire(recv); - assertEquals(x, 'a', "setRelease char value"); + assertEquals(x, '\u0123', "setRelease char value"); } // Opaque { - vh.setOpaque(recv, 'b'); + vh.setOpaque(recv, '\u4567'); char x = (char) vh.getOpaque(recv); - assertEquals(x, 'b', "setOpaque char value"); + assertEquals(x, '\u4567', "setOpaque char value"); } + vh.set(recv, '\u0123'); + // Compare + { + boolean r = vh.compareAndSet(recv, '\u0123', '\u4567'); + assertEquals(r, true, "success compareAndSet char"); + char x = (char) vh.get(recv); + assertEquals(x, '\u4567', "success compareAndSet char value"); + } + + { + boolean r = vh.compareAndSet(recv, '\u0123', '\u89AB'); + assertEquals(r, false, "failing compareAndSet char"); + char x = (char) vh.get(recv); + assertEquals(x, '\u4567', "failing compareAndSet char value"); + } + + { + char r = (char) vh.compareAndExchange(recv, '\u4567', '\u0123'); + assertEquals(r, '\u4567', "success compareAndExchange char"); + char x = (char) vh.get(recv); + assertEquals(x, '\u0123', "success compareAndExchange char value"); + } + + { + char r = (char) vh.compareAndExchange(recv, '\u4567', '\u89AB'); + assertEquals(r, '\u0123', "failing compareAndExchange char"); + char x = (char) vh.get(recv); + assertEquals(x, '\u0123', "failing compareAndExchange char value"); + } + + { + char r = (char) vh.compareAndExchangeAcquire(recv, '\u0123', '\u4567'); + assertEquals(r, '\u0123', "success compareAndExchangeAcquire char"); + char x = (char) vh.get(recv); + assertEquals(x, '\u4567', "success compareAndExchangeAcquire char value"); + } + + { + char r = (char) vh.compareAndExchangeAcquire(recv, '\u0123', '\u89AB'); + assertEquals(r, '\u4567', "failing compareAndExchangeAcquire char"); + char x = (char) vh.get(recv); + assertEquals(x, '\u4567', "failing compareAndExchangeAcquire char value"); + } + + { + char r = (char) vh.compareAndExchangeRelease(recv, '\u4567', '\u0123'); + assertEquals(r, '\u4567', "success compareAndExchangeRelease char"); + char x = (char) vh.get(recv); + assertEquals(x, '\u0123', "success compareAndExchangeRelease char value"); + } + + { + char r = (char) vh.compareAndExchangeRelease(recv, '\u4567', '\u89AB'); + assertEquals(r, '\u0123', "failing compareAndExchangeRelease char"); + char x = (char) vh.get(recv); + assertEquals(x, '\u0123', "failing compareAndExchangeRelease char value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(recv, '\u0123', '\u4567'); + } + assertEquals(success, true, "weakCompareAndSet char"); + char x = (char) vh.get(recv); + assertEquals(x, '\u4567', "weakCompareAndSet char value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(recv, '\u4567', '\u0123'); + } + assertEquals(success, true, "weakCompareAndSetAcquire char"); + char x = (char) vh.get(recv); + assertEquals(x, '\u0123', "weakCompareAndSetAcquire char"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(recv, '\u0123', '\u4567'); + } + assertEquals(success, true, "weakCompareAndSetRelease char"); + char x = (char) vh.get(recv); + assertEquals(x, '\u4567', "weakCompareAndSetRelease char"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetVolatile(recv, '\u4567', '\u0123'); + } + assertEquals(success, true, "weakCompareAndSetVolatile char"); + char x = (char) vh.get(recv); + assertEquals(x, '\u0123', "weakCompareAndSetVolatile char value"); + } + + // Compare set and get + { + char o = (char) vh.getAndSet(recv, '\u4567'); + assertEquals(o, '\u0123', "getAndSet char"); + char x = (char) vh.get(recv); + assertEquals(x, '\u4567', "getAndSet char value"); + } + + vh.set(recv, '\u0123'); + + // get and add, add and get + { + char o = (char) vh.getAndAdd(recv, '\u89AB'); + assertEquals(o, '\u0123', "getAndAdd char"); + char c = (char) vh.addAndGet(recv, '\u89AB'); + assertEquals(c, (char)('\u0123' + '\u89AB' + '\u89AB'), "getAndAdd char value"); + } } static void testInstanceFieldUnsupported(VarHandleTestAccessChar recv, VarHandle vh) { - checkUOE(() -> { - boolean r = vh.compareAndSet(recv, 'a', 'b'); - }); - checkUOE(() -> { - char r = (char) vh.compareAndExchangeVolatile(recv, 'a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.compareAndExchangeAcquire(recv, 'a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.compareAndExchangeRelease(recv, 'a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(recv, 'a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(recv, 'a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(recv, 'a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(recv, 'a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.getAndSet(recv, 'a'); - }); - - checkUOE(() -> { - char o = (char) vh.getAndAdd(recv, 'a'); - }); - - checkUOE(() -> { - char o = (char) vh.addAndGet(recv, 'a'); - }); } static void testStaticField(VarHandle vh) { // Plain { - vh.set('a'); + vh.set('\u0123'); char x = (char) vh.get(); - assertEquals(x, 'a', "set char value"); + assertEquals(x, '\u0123', "set char value"); } // Volatile { - vh.setVolatile('b'); + vh.setVolatile('\u4567'); char x = (char) vh.getVolatile(); - assertEquals(x, 'b', "setVolatile char value"); + assertEquals(x, '\u4567', "setVolatile char value"); } // Lazy { - vh.setRelease('a'); + vh.setRelease('\u0123'); char x = (char) vh.getAcquire(); - assertEquals(x, 'a', "setRelease char value"); + assertEquals(x, '\u0123', "setRelease char value"); } // Opaque { - vh.setOpaque('b'); + vh.setOpaque('\u4567'); char x = (char) vh.getOpaque(); - assertEquals(x, 'b', "setOpaque char value"); + assertEquals(x, '\u4567', "setOpaque char value"); } + vh.set('\u0123'); + // Compare + { + boolean r = vh.compareAndSet('\u0123', '\u4567'); + assertEquals(r, true, "success compareAndSet char"); + char x = (char) vh.get(); + assertEquals(x, '\u4567', "success compareAndSet char value"); + } + + { + boolean r = vh.compareAndSet('\u0123', '\u89AB'); + assertEquals(r, false, "failing compareAndSet char"); + char x = (char) vh.get(); + assertEquals(x, '\u4567', "failing compareAndSet char value"); + } + + { + char r = (char) vh.compareAndExchange('\u4567', '\u0123'); + assertEquals(r, '\u4567', "success compareAndExchange char"); + char x = (char) vh.get(); + assertEquals(x, '\u0123', "success compareAndExchange char value"); + } + + { + char r = (char) vh.compareAndExchange('\u4567', '\u89AB'); + assertEquals(r, '\u0123', "failing compareAndExchange char"); + char x = (char) vh.get(); + assertEquals(x, '\u0123', "failing compareAndExchange char value"); + } + + { + char r = (char) vh.compareAndExchangeAcquire('\u0123', '\u4567'); + assertEquals(r, '\u0123', "success compareAndExchangeAcquire char"); + char x = (char) vh.get(); + assertEquals(x, '\u4567', "success compareAndExchangeAcquire char value"); + } + + { + char r = (char) vh.compareAndExchangeAcquire('\u0123', '\u89AB'); + assertEquals(r, '\u4567', "failing compareAndExchangeAcquire char"); + char x = (char) vh.get(); + assertEquals(x, '\u4567', "failing compareAndExchangeAcquire char value"); + } + + { + char r = (char) vh.compareAndExchangeRelease('\u4567', '\u0123'); + assertEquals(r, '\u4567', "success compareAndExchangeRelease char"); + char x = (char) vh.get(); + assertEquals(x, '\u0123', "success compareAndExchangeRelease char value"); + } + + { + char r = (char) vh.compareAndExchangeRelease('\u4567', '\u89AB'); + assertEquals(r, '\u0123', "failing compareAndExchangeRelease char"); + char x = (char) vh.get(); + assertEquals(x, '\u0123', "failing compareAndExchangeRelease char value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet('\u0123', '\u4567'); + } + assertEquals(success, true, "weakCompareAndSet char"); + char x = (char) vh.get(); + assertEquals(x, '\u4567', "weakCompareAndSet char value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire('\u4567', '\u0123'); + } + assertEquals(success, true, "weakCompareAndSetAcquire char"); + char x = (char) vh.get(); + assertEquals(x, '\u0123', "weakCompareAndSetAcquire char"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease('\u0123', '\u4567'); + } + assertEquals(success, true, "weakCompareAndSetRelease char"); + char x = (char) vh.get(); + assertEquals(x, '\u4567', "weakCompareAndSetRelease char"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease('\u4567', '\u0123'); + } + assertEquals(success, true, "weakCompareAndSetVolatile char"); + char x = (char) vh.get(); + assertEquals(x, '\u0123', "weakCompareAndSetVolatile char"); + } + + // Compare set and get + { + char o = (char) vh.getAndSet('\u4567'); + assertEquals(o, '\u0123', "getAndSet char"); + char x = (char) vh.get(); + assertEquals(x, '\u4567', "getAndSet char value"); + } + + vh.set('\u0123'); + + // get and add, add and get + { + char o = (char) vh.getAndAdd( '\u89AB'); + assertEquals(o, '\u0123', "getAndAdd char"); + char c = (char) vh.addAndGet('\u89AB'); + assertEquals(c, (char)('\u0123' + '\u89AB' + '\u89AB'), "getAndAdd char value"); + } } static void testStaticFieldUnsupported(VarHandle vh) { - checkUOE(() -> { - boolean r = vh.compareAndSet('a', 'b'); - }); - checkUOE(() -> { - char r = (char) vh.compareAndExchangeVolatile('a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.compareAndExchangeAcquire('a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.compareAndExchangeRelease('a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet('a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile('a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire('a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease('a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.getAndSet('a'); - }); - - checkUOE(() -> { - char o = (char) vh.getAndAdd('a'); - }); - - checkUOE(() -> { - char o = (char) vh.addAndGet('a'); - }); } @@ -562,34 +624,149 @@ public class VarHandleTestAccessChar extends VarHandleBaseTest { for (int i = 0; i < array.length; i++) { // Plain { - vh.set(array, i, 'a'); + vh.set(array, i, '\u0123'); char x = (char) vh.get(array, i); - assertEquals(x, 'a', "get char value"); + assertEquals(x, '\u0123', "get char value"); } // Volatile { - vh.setVolatile(array, i, 'b'); + vh.setVolatile(array, i, '\u4567'); char x = (char) vh.getVolatile(array, i); - assertEquals(x, 'b', "setVolatile char value"); + assertEquals(x, '\u4567', "setVolatile char value"); } // Lazy { - vh.setRelease(array, i, 'a'); + vh.setRelease(array, i, '\u0123'); char x = (char) vh.getAcquire(array, i); - assertEquals(x, 'a', "setRelease char value"); + assertEquals(x, '\u0123', "setRelease char value"); } // Opaque { - vh.setOpaque(array, i, 'b'); + vh.setOpaque(array, i, '\u4567'); char x = (char) vh.getOpaque(array, i); - assertEquals(x, 'b', "setOpaque char value"); + assertEquals(x, '\u4567', "setOpaque char value"); } + vh.set(array, i, '\u0123'); + // Compare + { + boolean r = vh.compareAndSet(array, i, '\u0123', '\u4567'); + assertEquals(r, true, "success compareAndSet char"); + char x = (char) vh.get(array, i); + assertEquals(x, '\u4567', "success compareAndSet char value"); + } + + { + boolean r = vh.compareAndSet(array, i, '\u0123', '\u89AB'); + assertEquals(r, false, "failing compareAndSet char"); + char x = (char) vh.get(array, i); + assertEquals(x, '\u4567', "failing compareAndSet char value"); + } + + { + char r = (char) vh.compareAndExchange(array, i, '\u4567', '\u0123'); + assertEquals(r, '\u4567', "success compareAndExchange char"); + char x = (char) vh.get(array, i); + assertEquals(x, '\u0123', "success compareAndExchange char value"); + } + + { + char r = (char) vh.compareAndExchange(array, i, '\u4567', '\u89AB'); + assertEquals(r, '\u0123', "failing compareAndExchange char"); + char x = (char) vh.get(array, i); + assertEquals(x, '\u0123', "failing compareAndExchange char value"); + } + + { + char r = (char) vh.compareAndExchangeAcquire(array, i, '\u0123', '\u4567'); + assertEquals(r, '\u0123', "success compareAndExchangeAcquire char"); + char x = (char) vh.get(array, i); + assertEquals(x, '\u4567', "success compareAndExchangeAcquire char value"); + } + + { + char r = (char) vh.compareAndExchangeAcquire(array, i, '\u0123', '\u89AB'); + assertEquals(r, '\u4567', "failing compareAndExchangeAcquire char"); + char x = (char) vh.get(array, i); + assertEquals(x, '\u4567', "failing compareAndExchangeAcquire char value"); + } + + { + char r = (char) vh.compareAndExchangeRelease(array, i, '\u4567', '\u0123'); + assertEquals(r, '\u4567', "success compareAndExchangeRelease char"); + char x = (char) vh.get(array, i); + assertEquals(x, '\u0123', "success compareAndExchangeRelease char value"); + } + + { + char r = (char) vh.compareAndExchangeRelease(array, i, '\u4567', '\u89AB'); + assertEquals(r, '\u0123', "failing compareAndExchangeRelease char"); + char x = (char) vh.get(array, i); + assertEquals(x, '\u0123', "failing compareAndExchangeRelease char value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(array, i, '\u0123', '\u4567'); + } + assertEquals(success, true, "weakCompareAndSet char"); + char x = (char) vh.get(array, i); + assertEquals(x, '\u4567', "weakCompareAndSet char value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(array, i, '\u4567', '\u0123'); + } + assertEquals(success, true, "weakCompareAndSetAcquire char"); + char x = (char) vh.get(array, i); + assertEquals(x, '\u0123', "weakCompareAndSetAcquire char"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(array, i, '\u0123', '\u4567'); + } + assertEquals(success, true, "weakCompareAndSetRelease char"); + char x = (char) vh.get(array, i); + assertEquals(x, '\u4567', "weakCompareAndSetRelease char"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetVolatile(array, i, '\u4567', '\u0123'); + } + assertEquals(success, true, "weakCompareAndSetVolatile char"); + char x = (char) vh.get(array, i); + assertEquals(x, '\u0123', "weakCompareAndSetVolatile char"); + } + + // Compare set and get + { + char o = (char) vh.getAndSet(array, i, '\u4567'); + assertEquals(o, '\u0123', "getAndSet char"); + char x = (char) vh.get(array, i); + assertEquals(x, '\u4567', "getAndSet char value"); + } + + vh.set(array, i, '\u0123'); + + // get and add, add and get + { + char o = (char) vh.getAndAdd(array, i, '\u89AB'); + assertEquals(o, '\u0123', "getAndAdd char"); + char c = (char) vh.addAndGet(array, i, '\u89AB'); + assertEquals(c, (char)('\u0123' + '\u89AB' + '\u89AB'), "getAndAdd char value"); + } } } @@ -597,49 +774,7 @@ public class VarHandleTestAccessChar extends VarHandleBaseTest { char[] array = new char[10]; int i = 0; - checkUOE(() -> { - boolean r = vh.compareAndSet(array, i, 'a', 'b'); - }); - checkUOE(() -> { - char r = (char) vh.compareAndExchangeVolatile(array, i, 'a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.compareAndExchangeAcquire(array, i, 'a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.compareAndExchangeRelease(array, i, 'a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(array, i, 'a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(array, i, 'a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(array, i, 'a', 'b'); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(array, i, 'a', 'b'); - }); - - checkUOE(() -> { - char r = (char) vh.getAndSet(array, i, 'a'); - }); - - checkUOE(() -> { - char o = (char) vh.getAndAdd(array, i, 'a'); - }); - - checkUOE(() -> { - char o = (char) vh.addAndGet(array, i, 'a'); - }); } static void testArrayIndexOutOfBounds(VarHandle vh) throws Throwable { @@ -653,7 +788,7 @@ public class VarHandleTestAccessChar extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.set(array, ci, 'a'); + vh.set(array, ci, '\u0123'); }); checkIOOBE(() -> { @@ -661,7 +796,7 @@ public class VarHandleTestAccessChar extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setVolatile(array, ci, 'a'); + vh.setVolatile(array, ci, '\u0123'); }); checkIOOBE(() -> { @@ -669,7 +804,7 @@ public class VarHandleTestAccessChar extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setRelease(array, ci, 'a'); + vh.setRelease(array, ci, '\u0123'); }); checkIOOBE(() -> { @@ -677,10 +812,52 @@ public class VarHandleTestAccessChar extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setOpaque(array, ci, 'a'); + vh.setOpaque(array, ci, '\u0123'); }); + checkIOOBE(() -> { + boolean r = vh.compareAndSet(array, ci, '\u0123', '\u4567'); + }); + checkIOOBE(() -> { + char r = (char) vh.compareAndExchange(array, ci, '\u4567', '\u0123'); + }); + + checkIOOBE(() -> { + char r = (char) vh.compareAndExchangeAcquire(array, ci, '\u4567', '\u0123'); + }); + + checkIOOBE(() -> { + char r = (char) vh.compareAndExchangeRelease(array, ci, '\u4567', '\u0123'); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSet(array, ci, '\u0123', '\u4567'); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetVolatile(array, ci, '\u0123', '\u4567'); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetAcquire(array, ci, '\u0123', '\u4567'); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetRelease(array, ci, '\u0123', '\u4567'); + }); + + checkIOOBE(() -> { + char o = (char) vh.getAndSet(array, ci, '\u0123'); + }); + + checkIOOBE(() -> { + char o = (char) vh.getAndAdd(array, ci, '\u89AB'); + }); + + checkIOOBE(() -> { + char o = (char) vh.addAndGet(array, ci, '\u89AB'); + }); } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessDouble.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessDouble.java index 1861e5919dc..710aae87fc1 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessDouble.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessDouble.java @@ -99,18 +99,18 @@ public class VarHandleTestAccessDouble extends VarHandleBaseTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_OPAQUE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_VOLATILE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_ACQUIRE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_RELEASE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_ACQUIRE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_RELEASE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_ADD)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.ADD_AND_GET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_ADD)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.ADD_AND_GET)); } @@ -260,49 +260,7 @@ public class VarHandleTestAccessDouble extends VarHandleBaseTest { vh.setOpaque(recv, 2.0d); }); - checkUOE(() -> { - boolean r = vh.compareAndSet(recv, 1.0d, 2.0d); - }); - checkUOE(() -> { - double r = (double) vh.compareAndExchangeVolatile(recv, 1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.compareAndExchangeAcquire(recv, 1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.compareAndExchangeRelease(recv, 1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(recv, 1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(recv, 1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(recv, 1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(recv, 1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.getAndSet(recv, 1.0d); - }); - - checkUOE(() -> { - double o = (double) vh.getAndAdd(recv, 1.0d); - }); - - checkUOE(() -> { - double o = (double) vh.addAndGet(recv, 1.0d); - }); } @@ -350,49 +308,7 @@ public class VarHandleTestAccessDouble extends VarHandleBaseTest { vh.setOpaque(2.0d); }); - checkUOE(() -> { - boolean r = vh.compareAndSet(1.0d, 2.0d); - }); - checkUOE(() -> { - double r = (double) vh.compareAndExchangeVolatile(1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.compareAndExchangeAcquire(1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.compareAndExchangeRelease(1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.getAndSet(1.0d); - }); - - checkUOE(() -> { - double o = (double) vh.getAndAdd(1.0d); - }); - - checkUOE(() -> { - double o = (double) vh.addAndGet(1.0d); - }); } @@ -426,53 +342,126 @@ public class VarHandleTestAccessDouble extends VarHandleBaseTest { assertEquals(x, 2.0d, "setOpaque double value"); } + vh.set(recv, 1.0d); + // Compare + { + boolean r = vh.compareAndSet(recv, 1.0d, 2.0d); + assertEquals(r, true, "success compareAndSet double"); + double x = (double) vh.get(recv); + assertEquals(x, 2.0d, "success compareAndSet double value"); + } + + { + boolean r = vh.compareAndSet(recv, 1.0d, 3.0d); + assertEquals(r, false, "failing compareAndSet double"); + double x = (double) vh.get(recv); + assertEquals(x, 2.0d, "failing compareAndSet double value"); + } + + { + double r = (double) vh.compareAndExchange(recv, 2.0d, 1.0d); + assertEquals(r, 2.0d, "success compareAndExchange double"); + double x = (double) vh.get(recv); + assertEquals(x, 1.0d, "success compareAndExchange double value"); + } + + { + double r = (double) vh.compareAndExchange(recv, 2.0d, 3.0d); + assertEquals(r, 1.0d, "failing compareAndExchange double"); + double x = (double) vh.get(recv); + assertEquals(x, 1.0d, "failing compareAndExchange double value"); + } + + { + double r = (double) vh.compareAndExchangeAcquire(recv, 1.0d, 2.0d); + assertEquals(r, 1.0d, "success compareAndExchangeAcquire double"); + double x = (double) vh.get(recv); + assertEquals(x, 2.0d, "success compareAndExchangeAcquire double value"); + } + + { + double r = (double) vh.compareAndExchangeAcquire(recv, 1.0d, 3.0d); + assertEquals(r, 2.0d, "failing compareAndExchangeAcquire double"); + double x = (double) vh.get(recv); + assertEquals(x, 2.0d, "failing compareAndExchangeAcquire double value"); + } + + { + double r = (double) vh.compareAndExchangeRelease(recv, 2.0d, 1.0d); + assertEquals(r, 2.0d, "success compareAndExchangeRelease double"); + double x = (double) vh.get(recv); + assertEquals(x, 1.0d, "success compareAndExchangeRelease double value"); + } + + { + double r = (double) vh.compareAndExchangeRelease(recv, 2.0d, 3.0d); + assertEquals(r, 1.0d, "failing compareAndExchangeRelease double"); + double x = (double) vh.get(recv); + assertEquals(x, 1.0d, "failing compareAndExchangeRelease double value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(recv, 1.0d, 2.0d); + } + assertEquals(success, true, "weakCompareAndSet double"); + double x = (double) vh.get(recv); + assertEquals(x, 2.0d, "weakCompareAndSet double value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(recv, 2.0d, 1.0d); + } + assertEquals(success, true, "weakCompareAndSetAcquire double"); + double x = (double) vh.get(recv); + assertEquals(x, 1.0d, "weakCompareAndSetAcquire double"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(recv, 1.0d, 2.0d); + } + assertEquals(success, true, "weakCompareAndSetRelease double"); + double x = (double) vh.get(recv); + assertEquals(x, 2.0d, "weakCompareAndSetRelease double"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetVolatile(recv, 2.0d, 1.0d); + } + assertEquals(success, true, "weakCompareAndSetVolatile double"); + double x = (double) vh.get(recv); + assertEquals(x, 1.0d, "weakCompareAndSetVolatile double value"); + } + + // Compare set and get + { + double o = (double) vh.getAndSet(recv, 2.0d); + assertEquals(o, 1.0d, "getAndSet double"); + double x = (double) vh.get(recv); + assertEquals(x, 2.0d, "getAndSet double value"); + } + + vh.set(recv, 1.0d); + + // get and add, add and get + { + double o = (double) vh.getAndAdd(recv, 3.0d); + assertEquals(o, 1.0d, "getAndAdd double"); + double c = (double) vh.addAndGet(recv, 3.0d); + assertEquals(c, (double)(1.0d + 3.0d + 3.0d), "getAndAdd double value"); + } } static void testInstanceFieldUnsupported(VarHandleTestAccessDouble recv, VarHandle vh) { - checkUOE(() -> { - boolean r = vh.compareAndSet(recv, 1.0d, 2.0d); - }); - checkUOE(() -> { - double r = (double) vh.compareAndExchangeVolatile(recv, 1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.compareAndExchangeAcquire(recv, 1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.compareAndExchangeRelease(recv, 1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(recv, 1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(recv, 1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(recv, 1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(recv, 1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.getAndSet(recv, 1.0d); - }); - - checkUOE(() -> { - double o = (double) vh.getAndAdd(recv, 1.0d); - }); - - checkUOE(() -> { - double o = (double) vh.addAndGet(recv, 1.0d); - }); } @@ -506,53 +495,126 @@ public class VarHandleTestAccessDouble extends VarHandleBaseTest { assertEquals(x, 2.0d, "setOpaque double value"); } + vh.set(1.0d); + // Compare + { + boolean r = vh.compareAndSet(1.0d, 2.0d); + assertEquals(r, true, "success compareAndSet double"); + double x = (double) vh.get(); + assertEquals(x, 2.0d, "success compareAndSet double value"); + } + + { + boolean r = vh.compareAndSet(1.0d, 3.0d); + assertEquals(r, false, "failing compareAndSet double"); + double x = (double) vh.get(); + assertEquals(x, 2.0d, "failing compareAndSet double value"); + } + + { + double r = (double) vh.compareAndExchange(2.0d, 1.0d); + assertEquals(r, 2.0d, "success compareAndExchange double"); + double x = (double) vh.get(); + assertEquals(x, 1.0d, "success compareAndExchange double value"); + } + + { + double r = (double) vh.compareAndExchange(2.0d, 3.0d); + assertEquals(r, 1.0d, "failing compareAndExchange double"); + double x = (double) vh.get(); + assertEquals(x, 1.0d, "failing compareAndExchange double value"); + } + + { + double r = (double) vh.compareAndExchangeAcquire(1.0d, 2.0d); + assertEquals(r, 1.0d, "success compareAndExchangeAcquire double"); + double x = (double) vh.get(); + assertEquals(x, 2.0d, "success compareAndExchangeAcquire double value"); + } + + { + double r = (double) vh.compareAndExchangeAcquire(1.0d, 3.0d); + assertEquals(r, 2.0d, "failing compareAndExchangeAcquire double"); + double x = (double) vh.get(); + assertEquals(x, 2.0d, "failing compareAndExchangeAcquire double value"); + } + + { + double r = (double) vh.compareAndExchangeRelease(2.0d, 1.0d); + assertEquals(r, 2.0d, "success compareAndExchangeRelease double"); + double x = (double) vh.get(); + assertEquals(x, 1.0d, "success compareAndExchangeRelease double value"); + } + + { + double r = (double) vh.compareAndExchangeRelease(2.0d, 3.0d); + assertEquals(r, 1.0d, "failing compareAndExchangeRelease double"); + double x = (double) vh.get(); + assertEquals(x, 1.0d, "failing compareAndExchangeRelease double value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(1.0d, 2.0d); + } + assertEquals(success, true, "weakCompareAndSet double"); + double x = (double) vh.get(); + assertEquals(x, 2.0d, "weakCompareAndSet double value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(2.0d, 1.0d); + } + assertEquals(success, true, "weakCompareAndSetAcquire double"); + double x = (double) vh.get(); + assertEquals(x, 1.0d, "weakCompareAndSetAcquire double"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(1.0d, 2.0d); + } + assertEquals(success, true, "weakCompareAndSetRelease double"); + double x = (double) vh.get(); + assertEquals(x, 2.0d, "weakCompareAndSetRelease double"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(2.0d, 1.0d); + } + assertEquals(success, true, "weakCompareAndSetVolatile double"); + double x = (double) vh.get(); + assertEquals(x, 1.0d, "weakCompareAndSetVolatile double"); + } + + // Compare set and get + { + double o = (double) vh.getAndSet(2.0d); + assertEquals(o, 1.0d, "getAndSet double"); + double x = (double) vh.get(); + assertEquals(x, 2.0d, "getAndSet double value"); + } + + vh.set(1.0d); + + // get and add, add and get + { + double o = (double) vh.getAndAdd( 3.0d); + assertEquals(o, 1.0d, "getAndAdd double"); + double c = (double) vh.addAndGet(3.0d); + assertEquals(c, (double)(1.0d + 3.0d + 3.0d), "getAndAdd double value"); + } } static void testStaticFieldUnsupported(VarHandle vh) { - checkUOE(() -> { - boolean r = vh.compareAndSet(1.0d, 2.0d); - }); - checkUOE(() -> { - double r = (double) vh.compareAndExchangeVolatile(1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.compareAndExchangeAcquire(1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.compareAndExchangeRelease(1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.getAndSet(1.0d); - }); - - checkUOE(() -> { - double o = (double) vh.getAndAdd(1.0d); - }); - - checkUOE(() -> { - double o = (double) vh.addAndGet(1.0d); - }); } @@ -589,7 +651,122 @@ public class VarHandleTestAccessDouble extends VarHandleBaseTest { assertEquals(x, 2.0d, "setOpaque double value"); } + vh.set(array, i, 1.0d); + // Compare + { + boolean r = vh.compareAndSet(array, i, 1.0d, 2.0d); + assertEquals(r, true, "success compareAndSet double"); + double x = (double) vh.get(array, i); + assertEquals(x, 2.0d, "success compareAndSet double value"); + } + + { + boolean r = vh.compareAndSet(array, i, 1.0d, 3.0d); + assertEquals(r, false, "failing compareAndSet double"); + double x = (double) vh.get(array, i); + assertEquals(x, 2.0d, "failing compareAndSet double value"); + } + + { + double r = (double) vh.compareAndExchange(array, i, 2.0d, 1.0d); + assertEquals(r, 2.0d, "success compareAndExchange double"); + double x = (double) vh.get(array, i); + assertEquals(x, 1.0d, "success compareAndExchange double value"); + } + + { + double r = (double) vh.compareAndExchange(array, i, 2.0d, 3.0d); + assertEquals(r, 1.0d, "failing compareAndExchange double"); + double x = (double) vh.get(array, i); + assertEquals(x, 1.0d, "failing compareAndExchange double value"); + } + + { + double r = (double) vh.compareAndExchangeAcquire(array, i, 1.0d, 2.0d); + assertEquals(r, 1.0d, "success compareAndExchangeAcquire double"); + double x = (double) vh.get(array, i); + assertEquals(x, 2.0d, "success compareAndExchangeAcquire double value"); + } + + { + double r = (double) vh.compareAndExchangeAcquire(array, i, 1.0d, 3.0d); + assertEquals(r, 2.0d, "failing compareAndExchangeAcquire double"); + double x = (double) vh.get(array, i); + assertEquals(x, 2.0d, "failing compareAndExchangeAcquire double value"); + } + + { + double r = (double) vh.compareAndExchangeRelease(array, i, 2.0d, 1.0d); + assertEquals(r, 2.0d, "success compareAndExchangeRelease double"); + double x = (double) vh.get(array, i); + assertEquals(x, 1.0d, "success compareAndExchangeRelease double value"); + } + + { + double r = (double) vh.compareAndExchangeRelease(array, i, 2.0d, 3.0d); + assertEquals(r, 1.0d, "failing compareAndExchangeRelease double"); + double x = (double) vh.get(array, i); + assertEquals(x, 1.0d, "failing compareAndExchangeRelease double value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(array, i, 1.0d, 2.0d); + } + assertEquals(success, true, "weakCompareAndSet double"); + double x = (double) vh.get(array, i); + assertEquals(x, 2.0d, "weakCompareAndSet double value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(array, i, 2.0d, 1.0d); + } + assertEquals(success, true, "weakCompareAndSetAcquire double"); + double x = (double) vh.get(array, i); + assertEquals(x, 1.0d, "weakCompareAndSetAcquire double"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(array, i, 1.0d, 2.0d); + } + assertEquals(success, true, "weakCompareAndSetRelease double"); + double x = (double) vh.get(array, i); + assertEquals(x, 2.0d, "weakCompareAndSetRelease double"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetVolatile(array, i, 2.0d, 1.0d); + } + assertEquals(success, true, "weakCompareAndSetVolatile double"); + double x = (double) vh.get(array, i); + assertEquals(x, 1.0d, "weakCompareAndSetVolatile double"); + } + + // Compare set and get + { + double o = (double) vh.getAndSet(array, i, 2.0d); + assertEquals(o, 1.0d, "getAndSet double"); + double x = (double) vh.get(array, i); + assertEquals(x, 2.0d, "getAndSet double value"); + } + + vh.set(array, i, 1.0d); + + // get and add, add and get + { + double o = (double) vh.getAndAdd(array, i, 3.0d); + assertEquals(o, 1.0d, "getAndAdd double"); + double c = (double) vh.addAndGet(array, i, 3.0d); + assertEquals(c, (double)(1.0d + 3.0d + 3.0d), "getAndAdd double value"); + } } } @@ -597,49 +774,7 @@ public class VarHandleTestAccessDouble extends VarHandleBaseTest { double[] array = new double[10]; int i = 0; - checkUOE(() -> { - boolean r = vh.compareAndSet(array, i, 1.0d, 2.0d); - }); - checkUOE(() -> { - double r = (double) vh.compareAndExchangeVolatile(array, i, 1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.compareAndExchangeAcquire(array, i, 1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.compareAndExchangeRelease(array, i, 1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(array, i, 1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(array, i, 1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(array, i, 1.0d, 2.0d); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(array, i, 1.0d, 2.0d); - }); - - checkUOE(() -> { - double r = (double) vh.getAndSet(array, i, 1.0d); - }); - - checkUOE(() -> { - double o = (double) vh.getAndAdd(array, i, 1.0d); - }); - - checkUOE(() -> { - double o = (double) vh.addAndGet(array, i, 1.0d); - }); } static void testArrayIndexOutOfBounds(VarHandle vh) throws Throwable { @@ -680,7 +815,49 @@ public class VarHandleTestAccessDouble extends VarHandleBaseTest { vh.setOpaque(array, ci, 1.0d); }); + checkIOOBE(() -> { + boolean r = vh.compareAndSet(array, ci, 1.0d, 2.0d); + }); + checkIOOBE(() -> { + double r = (double) vh.compareAndExchange(array, ci, 2.0d, 1.0d); + }); + + checkIOOBE(() -> { + double r = (double) vh.compareAndExchangeAcquire(array, ci, 2.0d, 1.0d); + }); + + checkIOOBE(() -> { + double r = (double) vh.compareAndExchangeRelease(array, ci, 2.0d, 1.0d); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSet(array, ci, 1.0d, 2.0d); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetVolatile(array, ci, 1.0d, 2.0d); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetAcquire(array, ci, 1.0d, 2.0d); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetRelease(array, ci, 1.0d, 2.0d); + }); + + checkIOOBE(() -> { + double o = (double) vh.getAndSet(array, ci, 1.0d); + }); + + checkIOOBE(() -> { + double o = (double) vh.getAndAdd(array, ci, 3.0d); + }); + + checkIOOBE(() -> { + double o = (double) vh.addAndGet(array, ci, 3.0d); + }); } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessFloat.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessFloat.java index dce87f72755..4a2306bcab6 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessFloat.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessFloat.java @@ -99,18 +99,18 @@ public class VarHandleTestAccessFloat extends VarHandleBaseTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_OPAQUE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_VOLATILE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_ACQUIRE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_RELEASE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_ACQUIRE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_RELEASE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_ADD)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.ADD_AND_GET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_ADD)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.ADD_AND_GET)); } @@ -260,49 +260,7 @@ public class VarHandleTestAccessFloat extends VarHandleBaseTest { vh.setOpaque(recv, 2.0f); }); - checkUOE(() -> { - boolean r = vh.compareAndSet(recv, 1.0f, 2.0f); - }); - checkUOE(() -> { - float r = (float) vh.compareAndExchangeVolatile(recv, 1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.compareAndExchangeAcquire(recv, 1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.compareAndExchangeRelease(recv, 1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(recv, 1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(recv, 1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(recv, 1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(recv, 1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.getAndSet(recv, 1.0f); - }); - - checkUOE(() -> { - float o = (float) vh.getAndAdd(recv, 1.0f); - }); - - checkUOE(() -> { - float o = (float) vh.addAndGet(recv, 1.0f); - }); } @@ -350,49 +308,7 @@ public class VarHandleTestAccessFloat extends VarHandleBaseTest { vh.setOpaque(2.0f); }); - checkUOE(() -> { - boolean r = vh.compareAndSet(1.0f, 2.0f); - }); - checkUOE(() -> { - float r = (float) vh.compareAndExchangeVolatile(1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.compareAndExchangeAcquire(1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.compareAndExchangeRelease(1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.getAndSet(1.0f); - }); - - checkUOE(() -> { - float o = (float) vh.getAndAdd(1.0f); - }); - - checkUOE(() -> { - float o = (float) vh.addAndGet(1.0f); - }); } @@ -426,53 +342,126 @@ public class VarHandleTestAccessFloat extends VarHandleBaseTest { assertEquals(x, 2.0f, "setOpaque float value"); } + vh.set(recv, 1.0f); + // Compare + { + boolean r = vh.compareAndSet(recv, 1.0f, 2.0f); + assertEquals(r, true, "success compareAndSet float"); + float x = (float) vh.get(recv); + assertEquals(x, 2.0f, "success compareAndSet float value"); + } + + { + boolean r = vh.compareAndSet(recv, 1.0f, 3.0f); + assertEquals(r, false, "failing compareAndSet float"); + float x = (float) vh.get(recv); + assertEquals(x, 2.0f, "failing compareAndSet float value"); + } + + { + float r = (float) vh.compareAndExchange(recv, 2.0f, 1.0f); + assertEquals(r, 2.0f, "success compareAndExchange float"); + float x = (float) vh.get(recv); + assertEquals(x, 1.0f, "success compareAndExchange float value"); + } + + { + float r = (float) vh.compareAndExchange(recv, 2.0f, 3.0f); + assertEquals(r, 1.0f, "failing compareAndExchange float"); + float x = (float) vh.get(recv); + assertEquals(x, 1.0f, "failing compareAndExchange float value"); + } + + { + float r = (float) vh.compareAndExchangeAcquire(recv, 1.0f, 2.0f); + assertEquals(r, 1.0f, "success compareAndExchangeAcquire float"); + float x = (float) vh.get(recv); + assertEquals(x, 2.0f, "success compareAndExchangeAcquire float value"); + } + + { + float r = (float) vh.compareAndExchangeAcquire(recv, 1.0f, 3.0f); + assertEquals(r, 2.0f, "failing compareAndExchangeAcquire float"); + float x = (float) vh.get(recv); + assertEquals(x, 2.0f, "failing compareAndExchangeAcquire float value"); + } + + { + float r = (float) vh.compareAndExchangeRelease(recv, 2.0f, 1.0f); + assertEquals(r, 2.0f, "success compareAndExchangeRelease float"); + float x = (float) vh.get(recv); + assertEquals(x, 1.0f, "success compareAndExchangeRelease float value"); + } + + { + float r = (float) vh.compareAndExchangeRelease(recv, 2.0f, 3.0f); + assertEquals(r, 1.0f, "failing compareAndExchangeRelease float"); + float x = (float) vh.get(recv); + assertEquals(x, 1.0f, "failing compareAndExchangeRelease float value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(recv, 1.0f, 2.0f); + } + assertEquals(success, true, "weakCompareAndSet float"); + float x = (float) vh.get(recv); + assertEquals(x, 2.0f, "weakCompareAndSet float value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(recv, 2.0f, 1.0f); + } + assertEquals(success, true, "weakCompareAndSetAcquire float"); + float x = (float) vh.get(recv); + assertEquals(x, 1.0f, "weakCompareAndSetAcquire float"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(recv, 1.0f, 2.0f); + } + assertEquals(success, true, "weakCompareAndSetRelease float"); + float x = (float) vh.get(recv); + assertEquals(x, 2.0f, "weakCompareAndSetRelease float"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetVolatile(recv, 2.0f, 1.0f); + } + assertEquals(success, true, "weakCompareAndSetVolatile float"); + float x = (float) vh.get(recv); + assertEquals(x, 1.0f, "weakCompareAndSetVolatile float value"); + } + + // Compare set and get + { + float o = (float) vh.getAndSet(recv, 2.0f); + assertEquals(o, 1.0f, "getAndSet float"); + float x = (float) vh.get(recv); + assertEquals(x, 2.0f, "getAndSet float value"); + } + + vh.set(recv, 1.0f); + + // get and add, add and get + { + float o = (float) vh.getAndAdd(recv, 3.0f); + assertEquals(o, 1.0f, "getAndAdd float"); + float c = (float) vh.addAndGet(recv, 3.0f); + assertEquals(c, (float)(1.0f + 3.0f + 3.0f), "getAndAdd float value"); + } } static void testInstanceFieldUnsupported(VarHandleTestAccessFloat recv, VarHandle vh) { - checkUOE(() -> { - boolean r = vh.compareAndSet(recv, 1.0f, 2.0f); - }); - checkUOE(() -> { - float r = (float) vh.compareAndExchangeVolatile(recv, 1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.compareAndExchangeAcquire(recv, 1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.compareAndExchangeRelease(recv, 1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(recv, 1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(recv, 1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(recv, 1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(recv, 1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.getAndSet(recv, 1.0f); - }); - - checkUOE(() -> { - float o = (float) vh.getAndAdd(recv, 1.0f); - }); - - checkUOE(() -> { - float o = (float) vh.addAndGet(recv, 1.0f); - }); } @@ -506,53 +495,126 @@ public class VarHandleTestAccessFloat extends VarHandleBaseTest { assertEquals(x, 2.0f, "setOpaque float value"); } + vh.set(1.0f); + // Compare + { + boolean r = vh.compareAndSet(1.0f, 2.0f); + assertEquals(r, true, "success compareAndSet float"); + float x = (float) vh.get(); + assertEquals(x, 2.0f, "success compareAndSet float value"); + } + + { + boolean r = vh.compareAndSet(1.0f, 3.0f); + assertEquals(r, false, "failing compareAndSet float"); + float x = (float) vh.get(); + assertEquals(x, 2.0f, "failing compareAndSet float value"); + } + + { + float r = (float) vh.compareAndExchange(2.0f, 1.0f); + assertEquals(r, 2.0f, "success compareAndExchange float"); + float x = (float) vh.get(); + assertEquals(x, 1.0f, "success compareAndExchange float value"); + } + + { + float r = (float) vh.compareAndExchange(2.0f, 3.0f); + assertEquals(r, 1.0f, "failing compareAndExchange float"); + float x = (float) vh.get(); + assertEquals(x, 1.0f, "failing compareAndExchange float value"); + } + + { + float r = (float) vh.compareAndExchangeAcquire(1.0f, 2.0f); + assertEquals(r, 1.0f, "success compareAndExchangeAcquire float"); + float x = (float) vh.get(); + assertEquals(x, 2.0f, "success compareAndExchangeAcquire float value"); + } + + { + float r = (float) vh.compareAndExchangeAcquire(1.0f, 3.0f); + assertEquals(r, 2.0f, "failing compareAndExchangeAcquire float"); + float x = (float) vh.get(); + assertEquals(x, 2.0f, "failing compareAndExchangeAcquire float value"); + } + + { + float r = (float) vh.compareAndExchangeRelease(2.0f, 1.0f); + assertEquals(r, 2.0f, "success compareAndExchangeRelease float"); + float x = (float) vh.get(); + assertEquals(x, 1.0f, "success compareAndExchangeRelease float value"); + } + + { + float r = (float) vh.compareAndExchangeRelease(2.0f, 3.0f); + assertEquals(r, 1.0f, "failing compareAndExchangeRelease float"); + float x = (float) vh.get(); + assertEquals(x, 1.0f, "failing compareAndExchangeRelease float value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(1.0f, 2.0f); + } + assertEquals(success, true, "weakCompareAndSet float"); + float x = (float) vh.get(); + assertEquals(x, 2.0f, "weakCompareAndSet float value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(2.0f, 1.0f); + } + assertEquals(success, true, "weakCompareAndSetAcquire float"); + float x = (float) vh.get(); + assertEquals(x, 1.0f, "weakCompareAndSetAcquire float"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(1.0f, 2.0f); + } + assertEquals(success, true, "weakCompareAndSetRelease float"); + float x = (float) vh.get(); + assertEquals(x, 2.0f, "weakCompareAndSetRelease float"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(2.0f, 1.0f); + } + assertEquals(success, true, "weakCompareAndSetVolatile float"); + float x = (float) vh.get(); + assertEquals(x, 1.0f, "weakCompareAndSetVolatile float"); + } + + // Compare set and get + { + float o = (float) vh.getAndSet(2.0f); + assertEquals(o, 1.0f, "getAndSet float"); + float x = (float) vh.get(); + assertEquals(x, 2.0f, "getAndSet float value"); + } + + vh.set(1.0f); + + // get and add, add and get + { + float o = (float) vh.getAndAdd( 3.0f); + assertEquals(o, 1.0f, "getAndAdd float"); + float c = (float) vh.addAndGet(3.0f); + assertEquals(c, (float)(1.0f + 3.0f + 3.0f), "getAndAdd float value"); + } } static void testStaticFieldUnsupported(VarHandle vh) { - checkUOE(() -> { - boolean r = vh.compareAndSet(1.0f, 2.0f); - }); - checkUOE(() -> { - float r = (float) vh.compareAndExchangeVolatile(1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.compareAndExchangeAcquire(1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.compareAndExchangeRelease(1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.getAndSet(1.0f); - }); - - checkUOE(() -> { - float o = (float) vh.getAndAdd(1.0f); - }); - - checkUOE(() -> { - float o = (float) vh.addAndGet(1.0f); - }); } @@ -589,7 +651,122 @@ public class VarHandleTestAccessFloat extends VarHandleBaseTest { assertEquals(x, 2.0f, "setOpaque float value"); } + vh.set(array, i, 1.0f); + // Compare + { + boolean r = vh.compareAndSet(array, i, 1.0f, 2.0f); + assertEquals(r, true, "success compareAndSet float"); + float x = (float) vh.get(array, i); + assertEquals(x, 2.0f, "success compareAndSet float value"); + } + + { + boolean r = vh.compareAndSet(array, i, 1.0f, 3.0f); + assertEquals(r, false, "failing compareAndSet float"); + float x = (float) vh.get(array, i); + assertEquals(x, 2.0f, "failing compareAndSet float value"); + } + + { + float r = (float) vh.compareAndExchange(array, i, 2.0f, 1.0f); + assertEquals(r, 2.0f, "success compareAndExchange float"); + float x = (float) vh.get(array, i); + assertEquals(x, 1.0f, "success compareAndExchange float value"); + } + + { + float r = (float) vh.compareAndExchange(array, i, 2.0f, 3.0f); + assertEquals(r, 1.0f, "failing compareAndExchange float"); + float x = (float) vh.get(array, i); + assertEquals(x, 1.0f, "failing compareAndExchange float value"); + } + + { + float r = (float) vh.compareAndExchangeAcquire(array, i, 1.0f, 2.0f); + assertEquals(r, 1.0f, "success compareAndExchangeAcquire float"); + float x = (float) vh.get(array, i); + assertEquals(x, 2.0f, "success compareAndExchangeAcquire float value"); + } + + { + float r = (float) vh.compareAndExchangeAcquire(array, i, 1.0f, 3.0f); + assertEquals(r, 2.0f, "failing compareAndExchangeAcquire float"); + float x = (float) vh.get(array, i); + assertEquals(x, 2.0f, "failing compareAndExchangeAcquire float value"); + } + + { + float r = (float) vh.compareAndExchangeRelease(array, i, 2.0f, 1.0f); + assertEquals(r, 2.0f, "success compareAndExchangeRelease float"); + float x = (float) vh.get(array, i); + assertEquals(x, 1.0f, "success compareAndExchangeRelease float value"); + } + + { + float r = (float) vh.compareAndExchangeRelease(array, i, 2.0f, 3.0f); + assertEquals(r, 1.0f, "failing compareAndExchangeRelease float"); + float x = (float) vh.get(array, i); + assertEquals(x, 1.0f, "failing compareAndExchangeRelease float value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(array, i, 1.0f, 2.0f); + } + assertEquals(success, true, "weakCompareAndSet float"); + float x = (float) vh.get(array, i); + assertEquals(x, 2.0f, "weakCompareAndSet float value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(array, i, 2.0f, 1.0f); + } + assertEquals(success, true, "weakCompareAndSetAcquire float"); + float x = (float) vh.get(array, i); + assertEquals(x, 1.0f, "weakCompareAndSetAcquire float"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(array, i, 1.0f, 2.0f); + } + assertEquals(success, true, "weakCompareAndSetRelease float"); + float x = (float) vh.get(array, i); + assertEquals(x, 2.0f, "weakCompareAndSetRelease float"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetVolatile(array, i, 2.0f, 1.0f); + } + assertEquals(success, true, "weakCompareAndSetVolatile float"); + float x = (float) vh.get(array, i); + assertEquals(x, 1.0f, "weakCompareAndSetVolatile float"); + } + + // Compare set and get + { + float o = (float) vh.getAndSet(array, i, 2.0f); + assertEquals(o, 1.0f, "getAndSet float"); + float x = (float) vh.get(array, i); + assertEquals(x, 2.0f, "getAndSet float value"); + } + + vh.set(array, i, 1.0f); + + // get and add, add and get + { + float o = (float) vh.getAndAdd(array, i, 3.0f); + assertEquals(o, 1.0f, "getAndAdd float"); + float c = (float) vh.addAndGet(array, i, 3.0f); + assertEquals(c, (float)(1.0f + 3.0f + 3.0f), "getAndAdd float value"); + } } } @@ -597,49 +774,7 @@ public class VarHandleTestAccessFloat extends VarHandleBaseTest { float[] array = new float[10]; int i = 0; - checkUOE(() -> { - boolean r = vh.compareAndSet(array, i, 1.0f, 2.0f); - }); - checkUOE(() -> { - float r = (float) vh.compareAndExchangeVolatile(array, i, 1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.compareAndExchangeAcquire(array, i, 1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.compareAndExchangeRelease(array, i, 1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(array, i, 1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(array, i, 1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(array, i, 1.0f, 2.0f); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(array, i, 1.0f, 2.0f); - }); - - checkUOE(() -> { - float r = (float) vh.getAndSet(array, i, 1.0f); - }); - - checkUOE(() -> { - float o = (float) vh.getAndAdd(array, i, 1.0f); - }); - - checkUOE(() -> { - float o = (float) vh.addAndGet(array, i, 1.0f); - }); } static void testArrayIndexOutOfBounds(VarHandle vh) throws Throwable { @@ -680,7 +815,49 @@ public class VarHandleTestAccessFloat extends VarHandleBaseTest { vh.setOpaque(array, ci, 1.0f); }); + checkIOOBE(() -> { + boolean r = vh.compareAndSet(array, ci, 1.0f, 2.0f); + }); + checkIOOBE(() -> { + float r = (float) vh.compareAndExchange(array, ci, 2.0f, 1.0f); + }); + + checkIOOBE(() -> { + float r = (float) vh.compareAndExchangeAcquire(array, ci, 2.0f, 1.0f); + }); + + checkIOOBE(() -> { + float r = (float) vh.compareAndExchangeRelease(array, ci, 2.0f, 1.0f); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSet(array, ci, 1.0f, 2.0f); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetVolatile(array, ci, 1.0f, 2.0f); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetAcquire(array, ci, 1.0f, 2.0f); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetRelease(array, ci, 1.0f, 2.0f); + }); + + checkIOOBE(() -> { + float o = (float) vh.getAndSet(array, ci, 1.0f); + }); + + checkIOOBE(() -> { + float o = (float) vh.getAndAdd(array, ci, 3.0f); + }); + + checkIOOBE(() -> { + float o = (float) vh.addAndGet(array, ci, 3.0f); + }); } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessInt.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessInt.java index 1897821dc06..930ba12eb89 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessInt.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessInt.java @@ -42,11 +42,11 @@ import java.util.List; import static org.testng.Assert.*; public class VarHandleTestAccessInt extends VarHandleBaseTest { - static final int static_final_v = 1; + static final int static_final_v = 0x01234567; static int static_v; - final int final_v = 1; + final int final_v = 0x01234567; int v; @@ -100,7 +100,7 @@ public class VarHandleTestAccessInt extends VarHandleBaseTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); @@ -220,44 +220,44 @@ public class VarHandleTestAccessInt extends VarHandleBaseTest { // Plain { int x = (int) vh.get(recv); - assertEquals(x, 1, "get int value"); + assertEquals(x, 0x01234567, "get int value"); } // Volatile { int x = (int) vh.getVolatile(recv); - assertEquals(x, 1, "getVolatile int value"); + assertEquals(x, 0x01234567, "getVolatile int value"); } // Lazy { int x = (int) vh.getAcquire(recv); - assertEquals(x, 1, "getRelease int value"); + assertEquals(x, 0x01234567, "getRelease int value"); } // Opaque { int x = (int) vh.getOpaque(recv); - assertEquals(x, 1, "getOpaque int value"); + assertEquals(x, 0x01234567, "getOpaque int value"); } } static void testInstanceFinalFieldUnsupported(VarHandleTestAccessInt recv, VarHandle vh) { checkUOE(() -> { - vh.set(recv, 2); + vh.set(recv, 0x89ABCDEF); }); checkUOE(() -> { - vh.setVolatile(recv, 2); + vh.setVolatile(recv, 0x89ABCDEF); }); checkUOE(() -> { - vh.setRelease(recv, 2); + vh.setRelease(recv, 0x89ABCDEF); }); checkUOE(() -> { - vh.setOpaque(recv, 2); + vh.setOpaque(recv, 0x89ABCDEF); }); @@ -268,44 +268,44 @@ public class VarHandleTestAccessInt extends VarHandleBaseTest { // Plain { int x = (int) vh.get(); - assertEquals(x, 1, "get int value"); + assertEquals(x, 0x01234567, "get int value"); } // Volatile { int x = (int) vh.getVolatile(); - assertEquals(x, 1, "getVolatile int value"); + assertEquals(x, 0x01234567, "getVolatile int value"); } // Lazy { int x = (int) vh.getAcquire(); - assertEquals(x, 1, "getRelease int value"); + assertEquals(x, 0x01234567, "getRelease int value"); } // Opaque { int x = (int) vh.getOpaque(); - assertEquals(x, 1, "getOpaque int value"); + assertEquals(x, 0x01234567, "getOpaque int value"); } } static void testStaticFinalFieldUnsupported(VarHandle vh) { checkUOE(() -> { - vh.set(2); + vh.set(0x89ABCDEF); }); checkUOE(() -> { - vh.setVolatile(2); + vh.setVolatile(0x89ABCDEF); }); checkUOE(() -> { - vh.setRelease(2); + vh.setRelease(0x89ABCDEF); }); checkUOE(() -> { - vh.setOpaque(2); + vh.setOpaque(0x89ABCDEF); }); @@ -315,148 +315,148 @@ public class VarHandleTestAccessInt extends VarHandleBaseTest { static void testInstanceField(VarHandleTestAccessInt recv, VarHandle vh) { // Plain { - vh.set(recv, 1); + vh.set(recv, 0x01234567); int x = (int) vh.get(recv); - assertEquals(x, 1, "set int value"); + assertEquals(x, 0x01234567, "set int value"); } // Volatile { - vh.setVolatile(recv, 2); + vh.setVolatile(recv, 0x89ABCDEF); int x = (int) vh.getVolatile(recv); - assertEquals(x, 2, "setVolatile int value"); + assertEquals(x, 0x89ABCDEF, "setVolatile int value"); } // Lazy { - vh.setRelease(recv, 1); + vh.setRelease(recv, 0x01234567); int x = (int) vh.getAcquire(recv); - assertEquals(x, 1, "setRelease int value"); + assertEquals(x, 0x01234567, "setRelease int value"); } // Opaque { - vh.setOpaque(recv, 2); + vh.setOpaque(recv, 0x89ABCDEF); int x = (int) vh.getOpaque(recv); - assertEquals(x, 2, "setOpaque int value"); + assertEquals(x, 0x89ABCDEF, "setOpaque int value"); } - vh.set(recv, 1); + vh.set(recv, 0x01234567); // Compare { - boolean r = vh.compareAndSet(recv, 1, 2); + boolean r = vh.compareAndSet(recv, 0x01234567, 0x89ABCDEF); assertEquals(r, true, "success compareAndSet int"); int x = (int) vh.get(recv); - assertEquals(x, 2, "success compareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndSet int value"); } { - boolean r = vh.compareAndSet(recv, 1, 3); + boolean r = vh.compareAndSet(recv, 0x01234567, 0xCAFEBABE); assertEquals(r, false, "failing compareAndSet int"); int x = (int) vh.get(recv); - assertEquals(x, 2, "failing compareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndSet int value"); } { - int r = (int) vh.compareAndExchangeVolatile(recv, 2, 1); - assertEquals(r, 2, "success compareAndExchangeVolatile int"); + int r = (int) vh.compareAndExchange(recv, 0x89ABCDEF, 0x01234567); + assertEquals(r, 0x89ABCDEF, "success compareAndExchange int"); int x = (int) vh.get(recv); - assertEquals(x, 1, "success compareAndExchangeVolatile int value"); + assertEquals(x, 0x01234567, "success compareAndExchange int value"); } { - int r = (int) vh.compareAndExchangeVolatile(recv, 2, 3); - assertEquals(r, 1, "failing compareAndExchangeVolatile int"); + int r = (int) vh.compareAndExchange(recv, 0x89ABCDEF, 0xCAFEBABE); + assertEquals(r, 0x01234567, "failing compareAndExchange int"); int x = (int) vh.get(recv); - assertEquals(x, 1, "failing compareAndExchangeVolatile int value"); + assertEquals(x, 0x01234567, "failing compareAndExchange int value"); } { - int r = (int) vh.compareAndExchangeAcquire(recv, 1, 2); - assertEquals(r, 1, "success compareAndExchangeAcquire int"); + int r = (int) vh.compareAndExchangeAcquire(recv, 0x01234567, 0x89ABCDEF); + assertEquals(r, 0x01234567, "success compareAndExchangeAcquire int"); int x = (int) vh.get(recv); - assertEquals(x, 2, "success compareAndExchangeAcquire int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndExchangeAcquire int value"); } { - int r = (int) vh.compareAndExchangeAcquire(recv, 1, 3); - assertEquals(r, 2, "failing compareAndExchangeAcquire int"); + int r = (int) vh.compareAndExchangeAcquire(recv, 0x01234567, 0xCAFEBABE); + assertEquals(r, 0x89ABCDEF, "failing compareAndExchangeAcquire int"); int x = (int) vh.get(recv); - assertEquals(x, 2, "failing compareAndExchangeAcquire int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndExchangeAcquire int value"); } { - int r = (int) vh.compareAndExchangeRelease(recv, 2, 1); - assertEquals(r, 2, "success compareAndExchangeRelease int"); + int r = (int) vh.compareAndExchangeRelease(recv, 0x89ABCDEF, 0x01234567); + assertEquals(r, 0x89ABCDEF, "success compareAndExchangeRelease int"); int x = (int) vh.get(recv); - assertEquals(x, 1, "success compareAndExchangeRelease int value"); + assertEquals(x, 0x01234567, "success compareAndExchangeRelease int value"); } { - int r = (int) vh.compareAndExchangeRelease(recv, 2, 3); - assertEquals(r, 1, "failing compareAndExchangeRelease int"); + int r = (int) vh.compareAndExchangeRelease(recv, 0x89ABCDEF, 0xCAFEBABE); + assertEquals(r, 0x01234567, "failing compareAndExchangeRelease int"); int x = (int) vh.get(recv); - assertEquals(x, 1, "failing compareAndExchangeRelease int value"); + assertEquals(x, 0x01234567, "failing compareAndExchangeRelease int value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSet(recv, 1, 2); + success = vh.weakCompareAndSet(recv, 0x01234567, 0x89ABCDEF); } assertEquals(success, true, "weakCompareAndSet int"); int x = (int) vh.get(recv); - assertEquals(x, 2, "weakCompareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "weakCompareAndSet int value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetAcquire(recv, 2, 1); + success = vh.weakCompareAndSetAcquire(recv, 0x89ABCDEF, 0x01234567); } assertEquals(success, true, "weakCompareAndSetAcquire int"); int x = (int) vh.get(recv); - assertEquals(x, 1, "weakCompareAndSetAcquire int"); + assertEquals(x, 0x01234567, "weakCompareAndSetAcquire int"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetRelease(recv, 1, 2); + success = vh.weakCompareAndSetRelease(recv, 0x01234567, 0x89ABCDEF); } assertEquals(success, true, "weakCompareAndSetRelease int"); int x = (int) vh.get(recv); - assertEquals(x, 2, "weakCompareAndSetRelease int"); + assertEquals(x, 0x89ABCDEF, "weakCompareAndSetRelease int"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetVolatile(recv, 2, 1); + success = vh.weakCompareAndSetVolatile(recv, 0x89ABCDEF, 0x01234567); } assertEquals(success, true, "weakCompareAndSetVolatile int"); int x = (int) vh.get(recv); - assertEquals(x, 1, "weakCompareAndSetVolatile int value"); + assertEquals(x, 0x01234567, "weakCompareAndSetVolatile int value"); } // Compare set and get { - int o = (int) vh.getAndSet(recv, 2); - assertEquals(o, 1, "getAndSet int"); + int o = (int) vh.getAndSet(recv, 0x89ABCDEF); + assertEquals(o, 0x01234567, "getAndSet int"); int x = (int) vh.get(recv); - assertEquals(x, 2, "getAndSet int value"); + assertEquals(x, 0x89ABCDEF, "getAndSet int value"); } - vh.set(recv, 1); + vh.set(recv, 0x01234567); // get and add, add and get { - int o = (int) vh.getAndAdd(recv, 3); - assertEquals(o, 1, "getAndAdd int"); - int c = (int) vh.addAndGet(recv, 3); - assertEquals(c, 1 + 3 + 3, "getAndAdd int value"); + int o = (int) vh.getAndAdd(recv, 0xCAFEBABE); + assertEquals(o, 0x01234567, "getAndAdd int"); + int c = (int) vh.addAndGet(recv, 0xCAFEBABE); + assertEquals(c, (int)(0x01234567 + 0xCAFEBABE + 0xCAFEBABE), "getAndAdd int value"); } } @@ -468,148 +468,148 @@ public class VarHandleTestAccessInt extends VarHandleBaseTest { static void testStaticField(VarHandle vh) { // Plain { - vh.set(1); + vh.set(0x01234567); int x = (int) vh.get(); - assertEquals(x, 1, "set int value"); + assertEquals(x, 0x01234567, "set int value"); } // Volatile { - vh.setVolatile(2); + vh.setVolatile(0x89ABCDEF); int x = (int) vh.getVolatile(); - assertEquals(x, 2, "setVolatile int value"); + assertEquals(x, 0x89ABCDEF, "setVolatile int value"); } // Lazy { - vh.setRelease(1); + vh.setRelease(0x01234567); int x = (int) vh.getAcquire(); - assertEquals(x, 1, "setRelease int value"); + assertEquals(x, 0x01234567, "setRelease int value"); } // Opaque { - vh.setOpaque(2); + vh.setOpaque(0x89ABCDEF); int x = (int) vh.getOpaque(); - assertEquals(x, 2, "setOpaque int value"); + assertEquals(x, 0x89ABCDEF, "setOpaque int value"); } - vh.set(1); + vh.set(0x01234567); // Compare { - boolean r = vh.compareAndSet(1, 2); + boolean r = vh.compareAndSet(0x01234567, 0x89ABCDEF); assertEquals(r, true, "success compareAndSet int"); int x = (int) vh.get(); - assertEquals(x, 2, "success compareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndSet int value"); } { - boolean r = vh.compareAndSet(1, 3); + boolean r = vh.compareAndSet(0x01234567, 0xCAFEBABE); assertEquals(r, false, "failing compareAndSet int"); int x = (int) vh.get(); - assertEquals(x, 2, "failing compareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndSet int value"); } { - int r = (int) vh.compareAndExchangeVolatile(2, 1); - assertEquals(r, 2, "success compareAndExchangeVolatile int"); + int r = (int) vh.compareAndExchange(0x89ABCDEF, 0x01234567); + assertEquals(r, 0x89ABCDEF, "success compareAndExchange int"); int x = (int) vh.get(); - assertEquals(x, 1, "success compareAndExchangeVolatile int value"); + assertEquals(x, 0x01234567, "success compareAndExchange int value"); } { - int r = (int) vh.compareAndExchangeVolatile(2, 3); - assertEquals(r, 1, "failing compareAndExchangeVolatile int"); + int r = (int) vh.compareAndExchange(0x89ABCDEF, 0xCAFEBABE); + assertEquals(r, 0x01234567, "failing compareAndExchange int"); int x = (int) vh.get(); - assertEquals(x, 1, "failing compareAndExchangeVolatile int value"); + assertEquals(x, 0x01234567, "failing compareAndExchange int value"); } { - int r = (int) vh.compareAndExchangeAcquire(1, 2); - assertEquals(r, 1, "success compareAndExchangeAcquire int"); + int r = (int) vh.compareAndExchangeAcquire(0x01234567, 0x89ABCDEF); + assertEquals(r, 0x01234567, "success compareAndExchangeAcquire int"); int x = (int) vh.get(); - assertEquals(x, 2, "success compareAndExchangeAcquire int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndExchangeAcquire int value"); } { - int r = (int) vh.compareAndExchangeAcquire(1, 3); - assertEquals(r, 2, "failing compareAndExchangeAcquire int"); + int r = (int) vh.compareAndExchangeAcquire(0x01234567, 0xCAFEBABE); + assertEquals(r, 0x89ABCDEF, "failing compareAndExchangeAcquire int"); int x = (int) vh.get(); - assertEquals(x, 2, "failing compareAndExchangeAcquire int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndExchangeAcquire int value"); } { - int r = (int) vh.compareAndExchangeRelease(2, 1); - assertEquals(r, 2, "success compareAndExchangeRelease int"); + int r = (int) vh.compareAndExchangeRelease(0x89ABCDEF, 0x01234567); + assertEquals(r, 0x89ABCDEF, "success compareAndExchangeRelease int"); int x = (int) vh.get(); - assertEquals(x, 1, "success compareAndExchangeRelease int value"); + assertEquals(x, 0x01234567, "success compareAndExchangeRelease int value"); } { - int r = (int) vh.compareAndExchangeRelease(2, 3); - assertEquals(r, 1, "failing compareAndExchangeRelease int"); + int r = (int) vh.compareAndExchangeRelease(0x89ABCDEF, 0xCAFEBABE); + assertEquals(r, 0x01234567, "failing compareAndExchangeRelease int"); int x = (int) vh.get(); - assertEquals(x, 1, "failing compareAndExchangeRelease int value"); + assertEquals(x, 0x01234567, "failing compareAndExchangeRelease int value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSet(1, 2); + success = vh.weakCompareAndSet(0x01234567, 0x89ABCDEF); } assertEquals(success, true, "weakCompareAndSet int"); int x = (int) vh.get(); - assertEquals(x, 2, "weakCompareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "weakCompareAndSet int value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetAcquire(2, 1); + success = vh.weakCompareAndSetAcquire(0x89ABCDEF, 0x01234567); } assertEquals(success, true, "weakCompareAndSetAcquire int"); int x = (int) vh.get(); - assertEquals(x, 1, "weakCompareAndSetAcquire int"); + assertEquals(x, 0x01234567, "weakCompareAndSetAcquire int"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetRelease(1, 2); + success = vh.weakCompareAndSetRelease(0x01234567, 0x89ABCDEF); } assertEquals(success, true, "weakCompareAndSetRelease int"); int x = (int) vh.get(); - assertEquals(x, 2, "weakCompareAndSetRelease int"); + assertEquals(x, 0x89ABCDEF, "weakCompareAndSetRelease int"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetRelease(2, 1); + success = vh.weakCompareAndSetRelease(0x89ABCDEF, 0x01234567); } assertEquals(success, true, "weakCompareAndSetVolatile int"); int x = (int) vh.get(); - assertEquals(x, 1, "weakCompareAndSetVolatile int"); + assertEquals(x, 0x01234567, "weakCompareAndSetVolatile int"); } // Compare set and get { - int o = (int) vh.getAndSet(2); - assertEquals(o, 1, "getAndSet int"); + int o = (int) vh.getAndSet(0x89ABCDEF); + assertEquals(o, 0x01234567, "getAndSet int"); int x = (int) vh.get(); - assertEquals(x, 2, "getAndSet int value"); + assertEquals(x, 0x89ABCDEF, "getAndSet int value"); } - vh.set(1); + vh.set(0x01234567); // get and add, add and get { - int o = (int) vh.getAndAdd( 3); - assertEquals(o, 1, "getAndAdd int"); - int c = (int) vh.addAndGet(3); - assertEquals(c, 1 + 3 + 3, "getAndAdd int value"); + int o = (int) vh.getAndAdd( 0xCAFEBABE); + assertEquals(o, 0x01234567, "getAndAdd int"); + int c = (int) vh.addAndGet(0xCAFEBABE); + assertEquals(c, (int)(0x01234567 + 0xCAFEBABE + 0xCAFEBABE), "getAndAdd int value"); } } @@ -624,148 +624,148 @@ public class VarHandleTestAccessInt extends VarHandleBaseTest { for (int i = 0; i < array.length; i++) { // Plain { - vh.set(array, i, 1); + vh.set(array, i, 0x01234567); int x = (int) vh.get(array, i); - assertEquals(x, 1, "get int value"); + assertEquals(x, 0x01234567, "get int value"); } // Volatile { - vh.setVolatile(array, i, 2); + vh.setVolatile(array, i, 0x89ABCDEF); int x = (int) vh.getVolatile(array, i); - assertEquals(x, 2, "setVolatile int value"); + assertEquals(x, 0x89ABCDEF, "setVolatile int value"); } // Lazy { - vh.setRelease(array, i, 1); + vh.setRelease(array, i, 0x01234567); int x = (int) vh.getAcquire(array, i); - assertEquals(x, 1, "setRelease int value"); + assertEquals(x, 0x01234567, "setRelease int value"); } // Opaque { - vh.setOpaque(array, i, 2); + vh.setOpaque(array, i, 0x89ABCDEF); int x = (int) vh.getOpaque(array, i); - assertEquals(x, 2, "setOpaque int value"); + assertEquals(x, 0x89ABCDEF, "setOpaque int value"); } - vh.set(array, i, 1); + vh.set(array, i, 0x01234567); // Compare { - boolean r = vh.compareAndSet(array, i, 1, 2); + boolean r = vh.compareAndSet(array, i, 0x01234567, 0x89ABCDEF); assertEquals(r, true, "success compareAndSet int"); int x = (int) vh.get(array, i); - assertEquals(x, 2, "success compareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndSet int value"); } { - boolean r = vh.compareAndSet(array, i, 1, 3); + boolean r = vh.compareAndSet(array, i, 0x01234567, 0xCAFEBABE); assertEquals(r, false, "failing compareAndSet int"); int x = (int) vh.get(array, i); - assertEquals(x, 2, "failing compareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndSet int value"); } { - int r = (int) vh.compareAndExchangeVolatile(array, i, 2, 1); - assertEquals(r, 2, "success compareAndExchangeVolatile int"); + int r = (int) vh.compareAndExchange(array, i, 0x89ABCDEF, 0x01234567); + assertEquals(r, 0x89ABCDEF, "success compareAndExchange int"); int x = (int) vh.get(array, i); - assertEquals(x, 1, "success compareAndExchangeVolatile int value"); + assertEquals(x, 0x01234567, "success compareAndExchange int value"); } { - int r = (int) vh.compareAndExchangeVolatile(array, i, 2, 3); - assertEquals(r, 1, "failing compareAndExchangeVolatile int"); + int r = (int) vh.compareAndExchange(array, i, 0x89ABCDEF, 0xCAFEBABE); + assertEquals(r, 0x01234567, "failing compareAndExchange int"); int x = (int) vh.get(array, i); - assertEquals(x, 1, "failing compareAndExchangeVolatile int value"); + assertEquals(x, 0x01234567, "failing compareAndExchange int value"); } { - int r = (int) vh.compareAndExchangeAcquire(array, i, 1, 2); - assertEquals(r, 1, "success compareAndExchangeAcquire int"); + int r = (int) vh.compareAndExchangeAcquire(array, i, 0x01234567, 0x89ABCDEF); + assertEquals(r, 0x01234567, "success compareAndExchangeAcquire int"); int x = (int) vh.get(array, i); - assertEquals(x, 2, "success compareAndExchangeAcquire int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndExchangeAcquire int value"); } { - int r = (int) vh.compareAndExchangeAcquire(array, i, 1, 3); - assertEquals(r, 2, "failing compareAndExchangeAcquire int"); + int r = (int) vh.compareAndExchangeAcquire(array, i, 0x01234567, 0xCAFEBABE); + assertEquals(r, 0x89ABCDEF, "failing compareAndExchangeAcquire int"); int x = (int) vh.get(array, i); - assertEquals(x, 2, "failing compareAndExchangeAcquire int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndExchangeAcquire int value"); } { - int r = (int) vh.compareAndExchangeRelease(array, i, 2, 1); - assertEquals(r, 2, "success compareAndExchangeRelease int"); + int r = (int) vh.compareAndExchangeRelease(array, i, 0x89ABCDEF, 0x01234567); + assertEquals(r, 0x89ABCDEF, "success compareAndExchangeRelease int"); int x = (int) vh.get(array, i); - assertEquals(x, 1, "success compareAndExchangeRelease int value"); + assertEquals(x, 0x01234567, "success compareAndExchangeRelease int value"); } { - int r = (int) vh.compareAndExchangeRelease(array, i, 2, 3); - assertEquals(r, 1, "failing compareAndExchangeRelease int"); + int r = (int) vh.compareAndExchangeRelease(array, i, 0x89ABCDEF, 0xCAFEBABE); + assertEquals(r, 0x01234567, "failing compareAndExchangeRelease int"); int x = (int) vh.get(array, i); - assertEquals(x, 1, "failing compareAndExchangeRelease int value"); + assertEquals(x, 0x01234567, "failing compareAndExchangeRelease int value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSet(array, i, 1, 2); + success = vh.weakCompareAndSet(array, i, 0x01234567, 0x89ABCDEF); } assertEquals(success, true, "weakCompareAndSet int"); int x = (int) vh.get(array, i); - assertEquals(x, 2, "weakCompareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "weakCompareAndSet int value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetAcquire(array, i, 2, 1); + success = vh.weakCompareAndSetAcquire(array, i, 0x89ABCDEF, 0x01234567); } assertEquals(success, true, "weakCompareAndSetAcquire int"); int x = (int) vh.get(array, i); - assertEquals(x, 1, "weakCompareAndSetAcquire int"); + assertEquals(x, 0x01234567, "weakCompareAndSetAcquire int"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetRelease(array, i, 1, 2); + success = vh.weakCompareAndSetRelease(array, i, 0x01234567, 0x89ABCDEF); } assertEquals(success, true, "weakCompareAndSetRelease int"); int x = (int) vh.get(array, i); - assertEquals(x, 2, "weakCompareAndSetRelease int"); + assertEquals(x, 0x89ABCDEF, "weakCompareAndSetRelease int"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetVolatile(array, i, 2, 1); + success = vh.weakCompareAndSetVolatile(array, i, 0x89ABCDEF, 0x01234567); } assertEquals(success, true, "weakCompareAndSetVolatile int"); int x = (int) vh.get(array, i); - assertEquals(x, 1, "weakCompareAndSetVolatile int"); + assertEquals(x, 0x01234567, "weakCompareAndSetVolatile int"); } // Compare set and get { - int o = (int) vh.getAndSet(array, i, 2); - assertEquals(o, 1, "getAndSet int"); + int o = (int) vh.getAndSet(array, i, 0x89ABCDEF); + assertEquals(o, 0x01234567, "getAndSet int"); int x = (int) vh.get(array, i); - assertEquals(x, 2, "getAndSet int value"); + assertEquals(x, 0x89ABCDEF, "getAndSet int value"); } - vh.set(array, i, 1); + vh.set(array, i, 0x01234567); // get and add, add and get { - int o = (int) vh.getAndAdd(array, i, 3); - assertEquals(o, 1, "getAndAdd int"); - int c = (int) vh.addAndGet(array, i, 3); - assertEquals(c, 1 + 3 + 3, "getAndAdd int value"); + int o = (int) vh.getAndAdd(array, i, 0xCAFEBABE); + assertEquals(o, 0x01234567, "getAndAdd int"); + int c = (int) vh.addAndGet(array, i, 0xCAFEBABE); + assertEquals(c, (int)(0x01234567 + 0xCAFEBABE + 0xCAFEBABE), "getAndAdd int value"); } } } @@ -788,7 +788,7 @@ public class VarHandleTestAccessInt extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.set(array, ci, 1); + vh.set(array, ci, 0x01234567); }); checkIOOBE(() -> { @@ -796,7 +796,7 @@ public class VarHandleTestAccessInt extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setVolatile(array, ci, 1); + vh.setVolatile(array, ci, 0x01234567); }); checkIOOBE(() -> { @@ -804,7 +804,7 @@ public class VarHandleTestAccessInt extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setRelease(array, ci, 1); + vh.setRelease(array, ci, 0x01234567); }); checkIOOBE(() -> { @@ -812,51 +812,51 @@ public class VarHandleTestAccessInt extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setOpaque(array, ci, 1); + vh.setOpaque(array, ci, 0x01234567); }); checkIOOBE(() -> { - boolean r = vh.compareAndSet(array, ci, 1, 2); + boolean r = vh.compareAndSet(array, ci, 0x01234567, 0x89ABCDEF); }); checkIOOBE(() -> { - int r = (int) vh.compareAndExchangeVolatile(array, ci, 2, 1); + int r = (int) vh.compareAndExchange(array, ci, 0x89ABCDEF, 0x01234567); }); checkIOOBE(() -> { - int r = (int) vh.compareAndExchangeAcquire(array, ci, 2, 1); + int r = (int) vh.compareAndExchangeAcquire(array, ci, 0x89ABCDEF, 0x01234567); }); checkIOOBE(() -> { - int r = (int) vh.compareAndExchangeRelease(array, ci, 2, 1); + int r = (int) vh.compareAndExchangeRelease(array, ci, 0x89ABCDEF, 0x01234567); }); checkIOOBE(() -> { - boolean r = vh.weakCompareAndSet(array, ci, 1, 2); + boolean r = vh.weakCompareAndSet(array, ci, 0x01234567, 0x89ABCDEF); }); checkIOOBE(() -> { - boolean r = vh.weakCompareAndSetVolatile(array, ci, 1, 2); + boolean r = vh.weakCompareAndSetVolatile(array, ci, 0x01234567, 0x89ABCDEF); }); checkIOOBE(() -> { - boolean r = vh.weakCompareAndSetAcquire(array, ci, 1, 2); + boolean r = vh.weakCompareAndSetAcquire(array, ci, 0x01234567, 0x89ABCDEF); }); checkIOOBE(() -> { - boolean r = vh.weakCompareAndSetRelease(array, ci, 1, 2); + boolean r = vh.weakCompareAndSetRelease(array, ci, 0x01234567, 0x89ABCDEF); }); checkIOOBE(() -> { - int o = (int) vh.getAndSet(array, ci, 1); + int o = (int) vh.getAndSet(array, ci, 0x01234567); }); checkIOOBE(() -> { - int o = (int) vh.getAndAdd(array, ci, 3); + int o = (int) vh.getAndAdd(array, ci, 0xCAFEBABE); }); checkIOOBE(() -> { - int o = (int) vh.addAndGet(array, ci, 3); + int o = (int) vh.addAndGet(array, ci, 0xCAFEBABE); }); } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessLong.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessLong.java index adea5ed82a1..257e56b3b32 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessLong.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessLong.java @@ -42,11 +42,11 @@ import java.util.List; import static org.testng.Assert.*; public class VarHandleTestAccessLong extends VarHandleBaseTest { - static final long static_final_v = 1L; + static final long static_final_v = 0x0123456789ABCDEFL; static long static_v; - final long final_v = 1L; + final long final_v = 0x0123456789ABCDEFL; long v; @@ -100,7 +100,7 @@ public class VarHandleTestAccessLong extends VarHandleBaseTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); @@ -220,44 +220,44 @@ public class VarHandleTestAccessLong extends VarHandleBaseTest { // Plain { long x = (long) vh.get(recv); - assertEquals(x, 1L, "get long value"); + assertEquals(x, 0x0123456789ABCDEFL, "get long value"); } // Volatile { long x = (long) vh.getVolatile(recv); - assertEquals(x, 1L, "getVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "getVolatile long value"); } // Lazy { long x = (long) vh.getAcquire(recv); - assertEquals(x, 1L, "getRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "getRelease long value"); } // Opaque { long x = (long) vh.getOpaque(recv); - assertEquals(x, 1L, "getOpaque long value"); + assertEquals(x, 0x0123456789ABCDEFL, "getOpaque long value"); } } static void testInstanceFinalFieldUnsupported(VarHandleTestAccessLong recv, VarHandle vh) { checkUOE(() -> { - vh.set(recv, 2L); + vh.set(recv, 0xCAFEBABECAFEBABEL); }); checkUOE(() -> { - vh.setVolatile(recv, 2L); + vh.setVolatile(recv, 0xCAFEBABECAFEBABEL); }); checkUOE(() -> { - vh.setRelease(recv, 2L); + vh.setRelease(recv, 0xCAFEBABECAFEBABEL); }); checkUOE(() -> { - vh.setOpaque(recv, 2L); + vh.setOpaque(recv, 0xCAFEBABECAFEBABEL); }); @@ -268,44 +268,44 @@ public class VarHandleTestAccessLong extends VarHandleBaseTest { // Plain { long x = (long) vh.get(); - assertEquals(x, 1L, "get long value"); + assertEquals(x, 0x0123456789ABCDEFL, "get long value"); } // Volatile { long x = (long) vh.getVolatile(); - assertEquals(x, 1L, "getVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "getVolatile long value"); } // Lazy { long x = (long) vh.getAcquire(); - assertEquals(x, 1L, "getRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "getRelease long value"); } // Opaque { long x = (long) vh.getOpaque(); - assertEquals(x, 1L, "getOpaque long value"); + assertEquals(x, 0x0123456789ABCDEFL, "getOpaque long value"); } } static void testStaticFinalFieldUnsupported(VarHandle vh) { checkUOE(() -> { - vh.set(2L); + vh.set(0xCAFEBABECAFEBABEL); }); checkUOE(() -> { - vh.setVolatile(2L); + vh.setVolatile(0xCAFEBABECAFEBABEL); }); checkUOE(() -> { - vh.setRelease(2L); + vh.setRelease(0xCAFEBABECAFEBABEL); }); checkUOE(() -> { - vh.setOpaque(2L); + vh.setOpaque(0xCAFEBABECAFEBABEL); }); @@ -315,148 +315,148 @@ public class VarHandleTestAccessLong extends VarHandleBaseTest { static void testInstanceField(VarHandleTestAccessLong recv, VarHandle vh) { // Plain { - vh.set(recv, 1L); + vh.set(recv, 0x0123456789ABCDEFL); long x = (long) vh.get(recv); - assertEquals(x, 1L, "set long value"); + assertEquals(x, 0x0123456789ABCDEFL, "set long value"); } // Volatile { - vh.setVolatile(recv, 2L); + vh.setVolatile(recv, 0xCAFEBABECAFEBABEL); long x = (long) vh.getVolatile(recv); - assertEquals(x, 2L, "setVolatile long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "setVolatile long value"); } // Lazy { - vh.setRelease(recv, 1L); + vh.setRelease(recv, 0x0123456789ABCDEFL); long x = (long) vh.getAcquire(recv); - assertEquals(x, 1L, "setRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "setRelease long value"); } // Opaque { - vh.setOpaque(recv, 2L); + vh.setOpaque(recv, 0xCAFEBABECAFEBABEL); long x = (long) vh.getOpaque(recv); - assertEquals(x, 2L, "setOpaque long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "setOpaque long value"); } - vh.set(recv, 1L); + vh.set(recv, 0x0123456789ABCDEFL); // Compare { - boolean r = vh.compareAndSet(recv, 1L, 2L); + boolean r = vh.compareAndSet(recv, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); assertEquals(r, true, "success compareAndSet long"); long x = (long) vh.get(recv); - assertEquals(x, 2L, "success compareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndSet long value"); } { - boolean r = vh.compareAndSet(recv, 1L, 3L); + boolean r = vh.compareAndSet(recv, 0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); assertEquals(r, false, "failing compareAndSet long"); long x = (long) vh.get(recv); - assertEquals(x, 2L, "failing compareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndSet long value"); } { - long r = (long) vh.compareAndExchangeVolatile(recv, 2L, 1L); - assertEquals(r, 2L, "success compareAndExchangeVolatile long"); + long r = (long) vh.compareAndExchange(recv, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "success compareAndExchange long"); long x = (long) vh.get(recv); - assertEquals(x, 1L, "success compareAndExchangeVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "success compareAndExchange long value"); } { - long r = (long) vh.compareAndExchangeVolatile(recv, 2L, 3L); - assertEquals(r, 1L, "failing compareAndExchangeVolatile long"); + long r = (long) vh.compareAndExchange(recv, 0xCAFEBABECAFEBABEL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0x0123456789ABCDEFL, "failing compareAndExchange long"); long x = (long) vh.get(recv); - assertEquals(x, 1L, "failing compareAndExchangeVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "failing compareAndExchange long value"); } { - long r = (long) vh.compareAndExchangeAcquire(recv, 1L, 2L); - assertEquals(r, 1L, "success compareAndExchangeAcquire long"); + long r = (long) vh.compareAndExchangeAcquire(recv, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); + assertEquals(r, 0x0123456789ABCDEFL, "success compareAndExchangeAcquire long"); long x = (long) vh.get(recv); - assertEquals(x, 2L, "success compareAndExchangeAcquire long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndExchangeAcquire long value"); } { - long r = (long) vh.compareAndExchangeAcquire(recv, 1L, 3L); - assertEquals(r, 2L, "failing compareAndExchangeAcquire long"); + long r = (long) vh.compareAndExchangeAcquire(recv, 0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "failing compareAndExchangeAcquire long"); long x = (long) vh.get(recv); - assertEquals(x, 2L, "failing compareAndExchangeAcquire long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndExchangeAcquire long value"); } { - long r = (long) vh.compareAndExchangeRelease(recv, 2L, 1L); - assertEquals(r, 2L, "success compareAndExchangeRelease long"); + long r = (long) vh.compareAndExchangeRelease(recv, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "success compareAndExchangeRelease long"); long x = (long) vh.get(recv); - assertEquals(x, 1L, "success compareAndExchangeRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "success compareAndExchangeRelease long value"); } { - long r = (long) vh.compareAndExchangeRelease(recv, 2L, 3L); - assertEquals(r, 1L, "failing compareAndExchangeRelease long"); + long r = (long) vh.compareAndExchangeRelease(recv, 0xCAFEBABECAFEBABEL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0x0123456789ABCDEFL, "failing compareAndExchangeRelease long"); long x = (long) vh.get(recv); - assertEquals(x, 1L, "failing compareAndExchangeRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "failing compareAndExchangeRelease long value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSet(recv, 1L, 2L); + success = vh.weakCompareAndSet(recv, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); } assertEquals(success, true, "weakCompareAndSet long"); long x = (long) vh.get(recv); - assertEquals(x, 2L, "weakCompareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "weakCompareAndSet long value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetAcquire(recv, 2L, 1L); + success = vh.weakCompareAndSetAcquire(recv, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); } assertEquals(success, true, "weakCompareAndSetAcquire long"); long x = (long) vh.get(recv); - assertEquals(x, 1L, "weakCompareAndSetAcquire long"); + assertEquals(x, 0x0123456789ABCDEFL, "weakCompareAndSetAcquire long"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetRelease(recv, 1L, 2L); + success = vh.weakCompareAndSetRelease(recv, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); } assertEquals(success, true, "weakCompareAndSetRelease long"); long x = (long) vh.get(recv); - assertEquals(x, 2L, "weakCompareAndSetRelease long"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "weakCompareAndSetRelease long"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetVolatile(recv, 2L, 1L); + success = vh.weakCompareAndSetVolatile(recv, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); } assertEquals(success, true, "weakCompareAndSetVolatile long"); long x = (long) vh.get(recv); - assertEquals(x, 1L, "weakCompareAndSetVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "weakCompareAndSetVolatile long value"); } // Compare set and get { - long o = (long) vh.getAndSet(recv, 2L); - assertEquals(o, 1L, "getAndSet long"); + long o = (long) vh.getAndSet(recv, 0xCAFEBABECAFEBABEL); + assertEquals(o, 0x0123456789ABCDEFL, "getAndSet long"); long x = (long) vh.get(recv); - assertEquals(x, 2L, "getAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "getAndSet long value"); } - vh.set(recv, 1L); + vh.set(recv, 0x0123456789ABCDEFL); // get and add, add and get { - long o = (long) vh.getAndAdd(recv, 3L); - assertEquals(o, 1L, "getAndAdd long"); - long c = (long) vh.addAndGet(recv, 3L); - assertEquals(c, 1L + 3L + 3L, "getAndAdd long value"); + long o = (long) vh.getAndAdd(recv, 0xDEADBEEFDEADBEEFL); + assertEquals(o, 0x0123456789ABCDEFL, "getAndAdd long"); + long c = (long) vh.addAndGet(recv, 0xDEADBEEFDEADBEEFL); + assertEquals(c, (long)(0x0123456789ABCDEFL + 0xDEADBEEFDEADBEEFL + 0xDEADBEEFDEADBEEFL), "getAndAdd long value"); } } @@ -468,148 +468,148 @@ public class VarHandleTestAccessLong extends VarHandleBaseTest { static void testStaticField(VarHandle vh) { // Plain { - vh.set(1L); + vh.set(0x0123456789ABCDEFL); long x = (long) vh.get(); - assertEquals(x, 1L, "set long value"); + assertEquals(x, 0x0123456789ABCDEFL, "set long value"); } // Volatile { - vh.setVolatile(2L); + vh.setVolatile(0xCAFEBABECAFEBABEL); long x = (long) vh.getVolatile(); - assertEquals(x, 2L, "setVolatile long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "setVolatile long value"); } // Lazy { - vh.setRelease(1L); + vh.setRelease(0x0123456789ABCDEFL); long x = (long) vh.getAcquire(); - assertEquals(x, 1L, "setRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "setRelease long value"); } // Opaque { - vh.setOpaque(2L); + vh.setOpaque(0xCAFEBABECAFEBABEL); long x = (long) vh.getOpaque(); - assertEquals(x, 2L, "setOpaque long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "setOpaque long value"); } - vh.set(1L); + vh.set(0x0123456789ABCDEFL); // Compare { - boolean r = vh.compareAndSet(1L, 2L); + boolean r = vh.compareAndSet(0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); assertEquals(r, true, "success compareAndSet long"); long x = (long) vh.get(); - assertEquals(x, 2L, "success compareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndSet long value"); } { - boolean r = vh.compareAndSet(1L, 3L); + boolean r = vh.compareAndSet(0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); assertEquals(r, false, "failing compareAndSet long"); long x = (long) vh.get(); - assertEquals(x, 2L, "failing compareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndSet long value"); } { - long r = (long) vh.compareAndExchangeVolatile(2L, 1L); - assertEquals(r, 2L, "success compareAndExchangeVolatile long"); + long r = (long) vh.compareAndExchange(0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "success compareAndExchange long"); long x = (long) vh.get(); - assertEquals(x, 1L, "success compareAndExchangeVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "success compareAndExchange long value"); } { - long r = (long) vh.compareAndExchangeVolatile(2L, 3L); - assertEquals(r, 1L, "failing compareAndExchangeVolatile long"); + long r = (long) vh.compareAndExchange(0xCAFEBABECAFEBABEL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0x0123456789ABCDEFL, "failing compareAndExchange long"); long x = (long) vh.get(); - assertEquals(x, 1L, "failing compareAndExchangeVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "failing compareAndExchange long value"); } { - long r = (long) vh.compareAndExchangeAcquire(1L, 2L); - assertEquals(r, 1L, "success compareAndExchangeAcquire long"); + long r = (long) vh.compareAndExchangeAcquire(0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); + assertEquals(r, 0x0123456789ABCDEFL, "success compareAndExchangeAcquire long"); long x = (long) vh.get(); - assertEquals(x, 2L, "success compareAndExchangeAcquire long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndExchangeAcquire long value"); } { - long r = (long) vh.compareAndExchangeAcquire(1L, 3L); - assertEquals(r, 2L, "failing compareAndExchangeAcquire long"); + long r = (long) vh.compareAndExchangeAcquire(0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "failing compareAndExchangeAcquire long"); long x = (long) vh.get(); - assertEquals(x, 2L, "failing compareAndExchangeAcquire long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndExchangeAcquire long value"); } { - long r = (long) vh.compareAndExchangeRelease(2L, 1L); - assertEquals(r, 2L, "success compareAndExchangeRelease long"); + long r = (long) vh.compareAndExchangeRelease(0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "success compareAndExchangeRelease long"); long x = (long) vh.get(); - assertEquals(x, 1L, "success compareAndExchangeRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "success compareAndExchangeRelease long value"); } { - long r = (long) vh.compareAndExchangeRelease(2L, 3L); - assertEquals(r, 1L, "failing compareAndExchangeRelease long"); + long r = (long) vh.compareAndExchangeRelease(0xCAFEBABECAFEBABEL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0x0123456789ABCDEFL, "failing compareAndExchangeRelease long"); long x = (long) vh.get(); - assertEquals(x, 1L, "failing compareAndExchangeRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "failing compareAndExchangeRelease long value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSet(1L, 2L); + success = vh.weakCompareAndSet(0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); } assertEquals(success, true, "weakCompareAndSet long"); long x = (long) vh.get(); - assertEquals(x, 2L, "weakCompareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "weakCompareAndSet long value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetAcquire(2L, 1L); + success = vh.weakCompareAndSetAcquire(0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); } assertEquals(success, true, "weakCompareAndSetAcquire long"); long x = (long) vh.get(); - assertEquals(x, 1L, "weakCompareAndSetAcquire long"); + assertEquals(x, 0x0123456789ABCDEFL, "weakCompareAndSetAcquire long"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetRelease(1L, 2L); + success = vh.weakCompareAndSetRelease(0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); } assertEquals(success, true, "weakCompareAndSetRelease long"); long x = (long) vh.get(); - assertEquals(x, 2L, "weakCompareAndSetRelease long"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "weakCompareAndSetRelease long"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetRelease(2L, 1L); + success = vh.weakCompareAndSetRelease(0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); } assertEquals(success, true, "weakCompareAndSetVolatile long"); long x = (long) vh.get(); - assertEquals(x, 1L, "weakCompareAndSetVolatile long"); + assertEquals(x, 0x0123456789ABCDEFL, "weakCompareAndSetVolatile long"); } // Compare set and get { - long o = (long) vh.getAndSet(2L); - assertEquals(o, 1L, "getAndSet long"); + long o = (long) vh.getAndSet(0xCAFEBABECAFEBABEL); + assertEquals(o, 0x0123456789ABCDEFL, "getAndSet long"); long x = (long) vh.get(); - assertEquals(x, 2L, "getAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "getAndSet long value"); } - vh.set(1L); + vh.set(0x0123456789ABCDEFL); // get and add, add and get { - long o = (long) vh.getAndAdd( 3L); - assertEquals(o, 1L, "getAndAdd long"); - long c = (long) vh.addAndGet(3L); - assertEquals(c, 1L + 3L + 3L, "getAndAdd long value"); + long o = (long) vh.getAndAdd( 0xDEADBEEFDEADBEEFL); + assertEquals(o, 0x0123456789ABCDEFL, "getAndAdd long"); + long c = (long) vh.addAndGet(0xDEADBEEFDEADBEEFL); + assertEquals(c, (long)(0x0123456789ABCDEFL + 0xDEADBEEFDEADBEEFL + 0xDEADBEEFDEADBEEFL), "getAndAdd long value"); } } @@ -624,148 +624,148 @@ public class VarHandleTestAccessLong extends VarHandleBaseTest { for (int i = 0; i < array.length; i++) { // Plain { - vh.set(array, i, 1L); + vh.set(array, i, 0x0123456789ABCDEFL); long x = (long) vh.get(array, i); - assertEquals(x, 1L, "get long value"); + assertEquals(x, 0x0123456789ABCDEFL, "get long value"); } // Volatile { - vh.setVolatile(array, i, 2L); + vh.setVolatile(array, i, 0xCAFEBABECAFEBABEL); long x = (long) vh.getVolatile(array, i); - assertEquals(x, 2L, "setVolatile long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "setVolatile long value"); } // Lazy { - vh.setRelease(array, i, 1L); + vh.setRelease(array, i, 0x0123456789ABCDEFL); long x = (long) vh.getAcquire(array, i); - assertEquals(x, 1L, "setRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "setRelease long value"); } // Opaque { - vh.setOpaque(array, i, 2L); + vh.setOpaque(array, i, 0xCAFEBABECAFEBABEL); long x = (long) vh.getOpaque(array, i); - assertEquals(x, 2L, "setOpaque long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "setOpaque long value"); } - vh.set(array, i, 1L); + vh.set(array, i, 0x0123456789ABCDEFL); // Compare { - boolean r = vh.compareAndSet(array, i, 1L, 2L); + boolean r = vh.compareAndSet(array, i, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); assertEquals(r, true, "success compareAndSet long"); long x = (long) vh.get(array, i); - assertEquals(x, 2L, "success compareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndSet long value"); } { - boolean r = vh.compareAndSet(array, i, 1L, 3L); + boolean r = vh.compareAndSet(array, i, 0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); assertEquals(r, false, "failing compareAndSet long"); long x = (long) vh.get(array, i); - assertEquals(x, 2L, "failing compareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndSet long value"); } { - long r = (long) vh.compareAndExchangeVolatile(array, i, 2L, 1L); - assertEquals(r, 2L, "success compareAndExchangeVolatile long"); + long r = (long) vh.compareAndExchange(array, i, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "success compareAndExchange long"); long x = (long) vh.get(array, i); - assertEquals(x, 1L, "success compareAndExchangeVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "success compareAndExchange long value"); } { - long r = (long) vh.compareAndExchangeVolatile(array, i, 2L, 3L); - assertEquals(r, 1L, "failing compareAndExchangeVolatile long"); + long r = (long) vh.compareAndExchange(array, i, 0xCAFEBABECAFEBABEL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0x0123456789ABCDEFL, "failing compareAndExchange long"); long x = (long) vh.get(array, i); - assertEquals(x, 1L, "failing compareAndExchangeVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "failing compareAndExchange long value"); } { - long r = (long) vh.compareAndExchangeAcquire(array, i, 1L, 2L); - assertEquals(r, 1L, "success compareAndExchangeAcquire long"); + long r = (long) vh.compareAndExchangeAcquire(array, i, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); + assertEquals(r, 0x0123456789ABCDEFL, "success compareAndExchangeAcquire long"); long x = (long) vh.get(array, i); - assertEquals(x, 2L, "success compareAndExchangeAcquire long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndExchangeAcquire long value"); } { - long r = (long) vh.compareAndExchangeAcquire(array, i, 1L, 3L); - assertEquals(r, 2L, "failing compareAndExchangeAcquire long"); + long r = (long) vh.compareAndExchangeAcquire(array, i, 0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "failing compareAndExchangeAcquire long"); long x = (long) vh.get(array, i); - assertEquals(x, 2L, "failing compareAndExchangeAcquire long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndExchangeAcquire long value"); } { - long r = (long) vh.compareAndExchangeRelease(array, i, 2L, 1L); - assertEquals(r, 2L, "success compareAndExchangeRelease long"); + long r = (long) vh.compareAndExchangeRelease(array, i, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "success compareAndExchangeRelease long"); long x = (long) vh.get(array, i); - assertEquals(x, 1L, "success compareAndExchangeRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "success compareAndExchangeRelease long value"); } { - long r = (long) vh.compareAndExchangeRelease(array, i, 2L, 3L); - assertEquals(r, 1L, "failing compareAndExchangeRelease long"); + long r = (long) vh.compareAndExchangeRelease(array, i, 0xCAFEBABECAFEBABEL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0x0123456789ABCDEFL, "failing compareAndExchangeRelease long"); long x = (long) vh.get(array, i); - assertEquals(x, 1L, "failing compareAndExchangeRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "failing compareAndExchangeRelease long value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSet(array, i, 1L, 2L); + success = vh.weakCompareAndSet(array, i, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); } assertEquals(success, true, "weakCompareAndSet long"); long x = (long) vh.get(array, i); - assertEquals(x, 2L, "weakCompareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "weakCompareAndSet long value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetAcquire(array, i, 2L, 1L); + success = vh.weakCompareAndSetAcquire(array, i, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); } assertEquals(success, true, "weakCompareAndSetAcquire long"); long x = (long) vh.get(array, i); - assertEquals(x, 1L, "weakCompareAndSetAcquire long"); + assertEquals(x, 0x0123456789ABCDEFL, "weakCompareAndSetAcquire long"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetRelease(array, i, 1L, 2L); + success = vh.weakCompareAndSetRelease(array, i, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); } assertEquals(success, true, "weakCompareAndSetRelease long"); long x = (long) vh.get(array, i); - assertEquals(x, 2L, "weakCompareAndSetRelease long"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "weakCompareAndSetRelease long"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = vh.weakCompareAndSetVolatile(array, i, 2L, 1L); + success = vh.weakCompareAndSetVolatile(array, i, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); } assertEquals(success, true, "weakCompareAndSetVolatile long"); long x = (long) vh.get(array, i); - assertEquals(x, 1L, "weakCompareAndSetVolatile long"); + assertEquals(x, 0x0123456789ABCDEFL, "weakCompareAndSetVolatile long"); } // Compare set and get { - long o = (long) vh.getAndSet(array, i, 2L); - assertEquals(o, 1L, "getAndSet long"); + long o = (long) vh.getAndSet(array, i, 0xCAFEBABECAFEBABEL); + assertEquals(o, 0x0123456789ABCDEFL, "getAndSet long"); long x = (long) vh.get(array, i); - assertEquals(x, 2L, "getAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "getAndSet long value"); } - vh.set(array, i, 1L); + vh.set(array, i, 0x0123456789ABCDEFL); // get and add, add and get { - long o = (long) vh.getAndAdd(array, i, 3L); - assertEquals(o, 1L, "getAndAdd long"); - long c = (long) vh.addAndGet(array, i, 3L); - assertEquals(c, 1L + 3L + 3L, "getAndAdd long value"); + long o = (long) vh.getAndAdd(array, i, 0xDEADBEEFDEADBEEFL); + assertEquals(o, 0x0123456789ABCDEFL, "getAndAdd long"); + long c = (long) vh.addAndGet(array, i, 0xDEADBEEFDEADBEEFL); + assertEquals(c, (long)(0x0123456789ABCDEFL + 0xDEADBEEFDEADBEEFL + 0xDEADBEEFDEADBEEFL), "getAndAdd long value"); } } } @@ -788,7 +788,7 @@ public class VarHandleTestAccessLong extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.set(array, ci, 1L); + vh.set(array, ci, 0x0123456789ABCDEFL); }); checkIOOBE(() -> { @@ -796,7 +796,7 @@ public class VarHandleTestAccessLong extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setVolatile(array, ci, 1L); + vh.setVolatile(array, ci, 0x0123456789ABCDEFL); }); checkIOOBE(() -> { @@ -804,7 +804,7 @@ public class VarHandleTestAccessLong extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setRelease(array, ci, 1L); + vh.setRelease(array, ci, 0x0123456789ABCDEFL); }); checkIOOBE(() -> { @@ -812,51 +812,51 @@ public class VarHandleTestAccessLong extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setOpaque(array, ci, 1L); + vh.setOpaque(array, ci, 0x0123456789ABCDEFL); }); checkIOOBE(() -> { - boolean r = vh.compareAndSet(array, ci, 1L, 2L); + boolean r = vh.compareAndSet(array, ci, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); }); checkIOOBE(() -> { - long r = (long) vh.compareAndExchangeVolatile(array, ci, 2L, 1L); + long r = (long) vh.compareAndExchange(array, ci, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); }); checkIOOBE(() -> { - long r = (long) vh.compareAndExchangeAcquire(array, ci, 2L, 1L); + long r = (long) vh.compareAndExchangeAcquire(array, ci, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); }); checkIOOBE(() -> { - long r = (long) vh.compareAndExchangeRelease(array, ci, 2L, 1L); + long r = (long) vh.compareAndExchangeRelease(array, ci, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); }); checkIOOBE(() -> { - boolean r = vh.weakCompareAndSet(array, ci, 1L, 2L); + boolean r = vh.weakCompareAndSet(array, ci, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); }); checkIOOBE(() -> { - boolean r = vh.weakCompareAndSetVolatile(array, ci, 1L, 2L); + boolean r = vh.weakCompareAndSetVolatile(array, ci, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); }); checkIOOBE(() -> { - boolean r = vh.weakCompareAndSetAcquire(array, ci, 1L, 2L); + boolean r = vh.weakCompareAndSetAcquire(array, ci, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); }); checkIOOBE(() -> { - boolean r = vh.weakCompareAndSetRelease(array, ci, 1L, 2L); + boolean r = vh.weakCompareAndSetRelease(array, ci, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); }); checkIOOBE(() -> { - long o = (long) vh.getAndSet(array, ci, 1L); + long o = (long) vh.getAndSet(array, ci, 0x0123456789ABCDEFL); }); checkIOOBE(() -> { - long o = (long) vh.getAndAdd(array, ci, 3L); + long o = (long) vh.getAndAdd(array, ci, 0xDEADBEEFDEADBEEFL); }); checkIOOBE(() -> { - long o = (long) vh.addAndGet(array, ci, 3L); + long o = (long) vh.addAndGet(array, ci, 0xDEADBEEFDEADBEEFL); }); } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessShort.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessShort.java index a8091a838cb..53535de28c9 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessShort.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessShort.java @@ -42,11 +42,11 @@ import java.util.List; import static org.testng.Assert.*; public class VarHandleTestAccessShort extends VarHandleBaseTest { - static final short static_final_v = (short)1; + static final short static_final_v = (short)0x0123; static short static_v; - final short final_v = (short)1; + final short final_v = (short)0x0123; short v; @@ -99,18 +99,18 @@ public class VarHandleTestAccessShort extends VarHandleBaseTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_OPAQUE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_VOLATILE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_ACQUIRE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_RELEASE)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_ACQUIRE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET_RELEASE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_ADD)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.ADD_AND_GET)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_ADD)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.ADD_AND_GET)); } @@ -220,89 +220,47 @@ public class VarHandleTestAccessShort extends VarHandleBaseTest { // Plain { short x = (short) vh.get(recv); - assertEquals(x, (short)1, "get short value"); + assertEquals(x, (short)0x0123, "get short value"); } // Volatile { short x = (short) vh.getVolatile(recv); - assertEquals(x, (short)1, "getVolatile short value"); + assertEquals(x, (short)0x0123, "getVolatile short value"); } // Lazy { short x = (short) vh.getAcquire(recv); - assertEquals(x, (short)1, "getRelease short value"); + assertEquals(x, (short)0x0123, "getRelease short value"); } // Opaque { short x = (short) vh.getOpaque(recv); - assertEquals(x, (short)1, "getOpaque short value"); + assertEquals(x, (short)0x0123, "getOpaque short value"); } } static void testInstanceFinalFieldUnsupported(VarHandleTestAccessShort recv, VarHandle vh) { checkUOE(() -> { - vh.set(recv, (short)2); + vh.set(recv, (short)0x4567); }); checkUOE(() -> { - vh.setVolatile(recv, (short)2); + vh.setVolatile(recv, (short)0x4567); }); checkUOE(() -> { - vh.setRelease(recv, (short)2); + vh.setRelease(recv, (short)0x4567); }); checkUOE(() -> { - vh.setOpaque(recv, (short)2); + vh.setOpaque(recv, (short)0x4567); }); - checkUOE(() -> { - boolean r = vh.compareAndSet(recv, (short)1, (short)2); - }); - checkUOE(() -> { - short r = (short) vh.compareAndExchangeVolatile(recv, (short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.compareAndExchangeAcquire(recv, (short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.compareAndExchangeRelease(recv, (short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(recv, (short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(recv, (short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(recv, (short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(recv, (short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.getAndSet(recv, (short)1); - }); - - checkUOE(() -> { - short o = (short) vh.getAndAdd(recv, (short)1); - }); - - checkUOE(() -> { - short o = (short) vh.addAndGet(recv, (short)1); - }); } @@ -310,249 +268,353 @@ public class VarHandleTestAccessShort extends VarHandleBaseTest { // Plain { short x = (short) vh.get(); - assertEquals(x, (short)1, "get short value"); + assertEquals(x, (short)0x0123, "get short value"); } // Volatile { short x = (short) vh.getVolatile(); - assertEquals(x, (short)1, "getVolatile short value"); + assertEquals(x, (short)0x0123, "getVolatile short value"); } // Lazy { short x = (short) vh.getAcquire(); - assertEquals(x, (short)1, "getRelease short value"); + assertEquals(x, (short)0x0123, "getRelease short value"); } // Opaque { short x = (short) vh.getOpaque(); - assertEquals(x, (short)1, "getOpaque short value"); + assertEquals(x, (short)0x0123, "getOpaque short value"); } } static void testStaticFinalFieldUnsupported(VarHandle vh) { checkUOE(() -> { - vh.set((short)2); + vh.set((short)0x4567); }); checkUOE(() -> { - vh.setVolatile((short)2); + vh.setVolatile((short)0x4567); }); checkUOE(() -> { - vh.setRelease((short)2); + vh.setRelease((short)0x4567); }); checkUOE(() -> { - vh.setOpaque((short)2); + vh.setOpaque((short)0x4567); }); - checkUOE(() -> { - boolean r = vh.compareAndSet((short)1, (short)2); - }); - checkUOE(() -> { - short r = (short) vh.compareAndExchangeVolatile((short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.compareAndExchangeAcquire((short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.compareAndExchangeRelease((short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet((short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile((short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire((short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease((short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.getAndSet((short)1); - }); - - checkUOE(() -> { - short o = (short) vh.getAndAdd((short)1); - }); - - checkUOE(() -> { - short o = (short) vh.addAndGet((short)1); - }); } static void testInstanceField(VarHandleTestAccessShort recv, VarHandle vh) { // Plain { - vh.set(recv, (short)1); + vh.set(recv, (short)0x0123); short x = (short) vh.get(recv); - assertEquals(x, (short)1, "set short value"); + assertEquals(x, (short)0x0123, "set short value"); } // Volatile { - vh.setVolatile(recv, (short)2); + vh.setVolatile(recv, (short)0x4567); short x = (short) vh.getVolatile(recv); - assertEquals(x, (short)2, "setVolatile short value"); + assertEquals(x, (short)0x4567, "setVolatile short value"); } // Lazy { - vh.setRelease(recv, (short)1); + vh.setRelease(recv, (short)0x0123); short x = (short) vh.getAcquire(recv); - assertEquals(x, (short)1, "setRelease short value"); + assertEquals(x, (short)0x0123, "setRelease short value"); } // Opaque { - vh.setOpaque(recv, (short)2); + vh.setOpaque(recv, (short)0x4567); short x = (short) vh.getOpaque(recv); - assertEquals(x, (short)2, "setOpaque short value"); + assertEquals(x, (short)0x4567, "setOpaque short value"); } + vh.set(recv, (short)0x0123); + // Compare + { + boolean r = vh.compareAndSet(recv, (short)0x0123, (short)0x4567); + assertEquals(r, true, "success compareAndSet short"); + short x = (short) vh.get(recv); + assertEquals(x, (short)0x4567, "success compareAndSet short value"); + } + + { + boolean r = vh.compareAndSet(recv, (short)0x0123, (short)0x89AB); + assertEquals(r, false, "failing compareAndSet short"); + short x = (short) vh.get(recv); + assertEquals(x, (short)0x4567, "failing compareAndSet short value"); + } + + { + short r = (short) vh.compareAndExchange(recv, (short)0x4567, (short)0x0123); + assertEquals(r, (short)0x4567, "success compareAndExchange short"); + short x = (short) vh.get(recv); + assertEquals(x, (short)0x0123, "success compareAndExchange short value"); + } + + { + short r = (short) vh.compareAndExchange(recv, (short)0x4567, (short)0x89AB); + assertEquals(r, (short)0x0123, "failing compareAndExchange short"); + short x = (short) vh.get(recv); + assertEquals(x, (short)0x0123, "failing compareAndExchange short value"); + } + + { + short r = (short) vh.compareAndExchangeAcquire(recv, (short)0x0123, (short)0x4567); + assertEquals(r, (short)0x0123, "success compareAndExchangeAcquire short"); + short x = (short) vh.get(recv); + assertEquals(x, (short)0x4567, "success compareAndExchangeAcquire short value"); + } + + { + short r = (short) vh.compareAndExchangeAcquire(recv, (short)0x0123, (short)0x89AB); + assertEquals(r, (short)0x4567, "failing compareAndExchangeAcquire short"); + short x = (short) vh.get(recv); + assertEquals(x, (short)0x4567, "failing compareAndExchangeAcquire short value"); + } + + { + short r = (short) vh.compareAndExchangeRelease(recv, (short)0x4567, (short)0x0123); + assertEquals(r, (short)0x4567, "success compareAndExchangeRelease short"); + short x = (short) vh.get(recv); + assertEquals(x, (short)0x0123, "success compareAndExchangeRelease short value"); + } + + { + short r = (short) vh.compareAndExchangeRelease(recv, (short)0x4567, (short)0x89AB); + assertEquals(r, (short)0x0123, "failing compareAndExchangeRelease short"); + short x = (short) vh.get(recv); + assertEquals(x, (short)0x0123, "failing compareAndExchangeRelease short value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(recv, (short)0x0123, (short)0x4567); + } + assertEquals(success, true, "weakCompareAndSet short"); + short x = (short) vh.get(recv); + assertEquals(x, (short)0x4567, "weakCompareAndSet short value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(recv, (short)0x4567, (short)0x0123); + } + assertEquals(success, true, "weakCompareAndSetAcquire short"); + short x = (short) vh.get(recv); + assertEquals(x, (short)0x0123, "weakCompareAndSetAcquire short"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(recv, (short)0x0123, (short)0x4567); + } + assertEquals(success, true, "weakCompareAndSetRelease short"); + short x = (short) vh.get(recv); + assertEquals(x, (short)0x4567, "weakCompareAndSetRelease short"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetVolatile(recv, (short)0x4567, (short)0x0123); + } + assertEquals(success, true, "weakCompareAndSetVolatile short"); + short x = (short) vh.get(recv); + assertEquals(x, (short)0x0123, "weakCompareAndSetVolatile short value"); + } + + // Compare set and get + { + short o = (short) vh.getAndSet(recv, (short)0x4567); + assertEquals(o, (short)0x0123, "getAndSet short"); + short x = (short) vh.get(recv); + assertEquals(x, (short)0x4567, "getAndSet short value"); + } + + vh.set(recv, (short)0x0123); + + // get and add, add and get + { + short o = (short) vh.getAndAdd(recv, (short)0x89AB); + assertEquals(o, (short)0x0123, "getAndAdd short"); + short c = (short) vh.addAndGet(recv, (short)0x89AB); + assertEquals(c, (short)((short)0x0123 + (short)0x89AB + (short)0x89AB), "getAndAdd short value"); + } } static void testInstanceFieldUnsupported(VarHandleTestAccessShort recv, VarHandle vh) { - checkUOE(() -> { - boolean r = vh.compareAndSet(recv, (short)1, (short)2); - }); - checkUOE(() -> { - short r = (short) vh.compareAndExchangeVolatile(recv, (short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.compareAndExchangeAcquire(recv, (short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.compareAndExchangeRelease(recv, (short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(recv, (short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(recv, (short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(recv, (short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(recv, (short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.getAndSet(recv, (short)1); - }); - - checkUOE(() -> { - short o = (short) vh.getAndAdd(recv, (short)1); - }); - - checkUOE(() -> { - short o = (short) vh.addAndGet(recv, (short)1); - }); } static void testStaticField(VarHandle vh) { // Plain { - vh.set((short)1); + vh.set((short)0x0123); short x = (short) vh.get(); - assertEquals(x, (short)1, "set short value"); + assertEquals(x, (short)0x0123, "set short value"); } // Volatile { - vh.setVolatile((short)2); + vh.setVolatile((short)0x4567); short x = (short) vh.getVolatile(); - assertEquals(x, (short)2, "setVolatile short value"); + assertEquals(x, (short)0x4567, "setVolatile short value"); } // Lazy { - vh.setRelease((short)1); + vh.setRelease((short)0x0123); short x = (short) vh.getAcquire(); - assertEquals(x, (short)1, "setRelease short value"); + assertEquals(x, (short)0x0123, "setRelease short value"); } // Opaque { - vh.setOpaque((short)2); + vh.setOpaque((short)0x4567); short x = (short) vh.getOpaque(); - assertEquals(x, (short)2, "setOpaque short value"); + assertEquals(x, (short)0x4567, "setOpaque short value"); } + vh.set((short)0x0123); + // Compare + { + boolean r = vh.compareAndSet((short)0x0123, (short)0x4567); + assertEquals(r, true, "success compareAndSet short"); + short x = (short) vh.get(); + assertEquals(x, (short)0x4567, "success compareAndSet short value"); + } + + { + boolean r = vh.compareAndSet((short)0x0123, (short)0x89AB); + assertEquals(r, false, "failing compareAndSet short"); + short x = (short) vh.get(); + assertEquals(x, (short)0x4567, "failing compareAndSet short value"); + } + + { + short r = (short) vh.compareAndExchange((short)0x4567, (short)0x0123); + assertEquals(r, (short)0x4567, "success compareAndExchange short"); + short x = (short) vh.get(); + assertEquals(x, (short)0x0123, "success compareAndExchange short value"); + } + + { + short r = (short) vh.compareAndExchange((short)0x4567, (short)0x89AB); + assertEquals(r, (short)0x0123, "failing compareAndExchange short"); + short x = (short) vh.get(); + assertEquals(x, (short)0x0123, "failing compareAndExchange short value"); + } + + { + short r = (short) vh.compareAndExchangeAcquire((short)0x0123, (short)0x4567); + assertEquals(r, (short)0x0123, "success compareAndExchangeAcquire short"); + short x = (short) vh.get(); + assertEquals(x, (short)0x4567, "success compareAndExchangeAcquire short value"); + } + + { + short r = (short) vh.compareAndExchangeAcquire((short)0x0123, (short)0x89AB); + assertEquals(r, (short)0x4567, "failing compareAndExchangeAcquire short"); + short x = (short) vh.get(); + assertEquals(x, (short)0x4567, "failing compareAndExchangeAcquire short value"); + } + + { + short r = (short) vh.compareAndExchangeRelease((short)0x4567, (short)0x0123); + assertEquals(r, (short)0x4567, "success compareAndExchangeRelease short"); + short x = (short) vh.get(); + assertEquals(x, (short)0x0123, "success compareAndExchangeRelease short value"); + } + + { + short r = (short) vh.compareAndExchangeRelease((short)0x4567, (short)0x89AB); + assertEquals(r, (short)0x0123, "failing compareAndExchangeRelease short"); + short x = (short) vh.get(); + assertEquals(x, (short)0x0123, "failing compareAndExchangeRelease short value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet((short)0x0123, (short)0x4567); + } + assertEquals(success, true, "weakCompareAndSet short"); + short x = (short) vh.get(); + assertEquals(x, (short)0x4567, "weakCompareAndSet short value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire((short)0x4567, (short)0x0123); + } + assertEquals(success, true, "weakCompareAndSetAcquire short"); + short x = (short) vh.get(); + assertEquals(x, (short)0x0123, "weakCompareAndSetAcquire short"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease((short)0x0123, (short)0x4567); + } + assertEquals(success, true, "weakCompareAndSetRelease short"); + short x = (short) vh.get(); + assertEquals(x, (short)0x4567, "weakCompareAndSetRelease short"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease((short)0x4567, (short)0x0123); + } + assertEquals(success, true, "weakCompareAndSetVolatile short"); + short x = (short) vh.get(); + assertEquals(x, (short)0x0123, "weakCompareAndSetVolatile short"); + } + + // Compare set and get + { + short o = (short) vh.getAndSet((short)0x4567); + assertEquals(o, (short)0x0123, "getAndSet short"); + short x = (short) vh.get(); + assertEquals(x, (short)0x4567, "getAndSet short value"); + } + + vh.set((short)0x0123); + + // get and add, add and get + { + short o = (short) vh.getAndAdd( (short)0x89AB); + assertEquals(o, (short)0x0123, "getAndAdd short"); + short c = (short) vh.addAndGet((short)0x89AB); + assertEquals(c, (short)((short)0x0123 + (short)0x89AB + (short)0x89AB), "getAndAdd short value"); + } } static void testStaticFieldUnsupported(VarHandle vh) { - checkUOE(() -> { - boolean r = vh.compareAndSet((short)1, (short)2); - }); - checkUOE(() -> { - short r = (short) vh.compareAndExchangeVolatile((short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.compareAndExchangeAcquire((short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.compareAndExchangeRelease((short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet((short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile((short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire((short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease((short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.getAndSet((short)1); - }); - - checkUOE(() -> { - short o = (short) vh.getAndAdd((short)1); - }); - - checkUOE(() -> { - short o = (short) vh.addAndGet((short)1); - }); } @@ -562,34 +624,149 @@ public class VarHandleTestAccessShort extends VarHandleBaseTest { for (int i = 0; i < array.length; i++) { // Plain { - vh.set(array, i, (short)1); + vh.set(array, i, (short)0x0123); short x = (short) vh.get(array, i); - assertEquals(x, (short)1, "get short value"); + assertEquals(x, (short)0x0123, "get short value"); } // Volatile { - vh.setVolatile(array, i, (short)2); + vh.setVolatile(array, i, (short)0x4567); short x = (short) vh.getVolatile(array, i); - assertEquals(x, (short)2, "setVolatile short value"); + assertEquals(x, (short)0x4567, "setVolatile short value"); } // Lazy { - vh.setRelease(array, i, (short)1); + vh.setRelease(array, i, (short)0x0123); short x = (short) vh.getAcquire(array, i); - assertEquals(x, (short)1, "setRelease short value"); + assertEquals(x, (short)0x0123, "setRelease short value"); } // Opaque { - vh.setOpaque(array, i, (short)2); + vh.setOpaque(array, i, (short)0x4567); short x = (short) vh.getOpaque(array, i); - assertEquals(x, (short)2, "setOpaque short value"); + assertEquals(x, (short)0x4567, "setOpaque short value"); } + vh.set(array, i, (short)0x0123); + // Compare + { + boolean r = vh.compareAndSet(array, i, (short)0x0123, (short)0x4567); + assertEquals(r, true, "success compareAndSet short"); + short x = (short) vh.get(array, i); + assertEquals(x, (short)0x4567, "success compareAndSet short value"); + } + + { + boolean r = vh.compareAndSet(array, i, (short)0x0123, (short)0x89AB); + assertEquals(r, false, "failing compareAndSet short"); + short x = (short) vh.get(array, i); + assertEquals(x, (short)0x4567, "failing compareAndSet short value"); + } + + { + short r = (short) vh.compareAndExchange(array, i, (short)0x4567, (short)0x0123); + assertEquals(r, (short)0x4567, "success compareAndExchange short"); + short x = (short) vh.get(array, i); + assertEquals(x, (short)0x0123, "success compareAndExchange short value"); + } + + { + short r = (short) vh.compareAndExchange(array, i, (short)0x4567, (short)0x89AB); + assertEquals(r, (short)0x0123, "failing compareAndExchange short"); + short x = (short) vh.get(array, i); + assertEquals(x, (short)0x0123, "failing compareAndExchange short value"); + } + + { + short r = (short) vh.compareAndExchangeAcquire(array, i, (short)0x0123, (short)0x4567); + assertEquals(r, (short)0x0123, "success compareAndExchangeAcquire short"); + short x = (short) vh.get(array, i); + assertEquals(x, (short)0x4567, "success compareAndExchangeAcquire short value"); + } + + { + short r = (short) vh.compareAndExchangeAcquire(array, i, (short)0x0123, (short)0x89AB); + assertEquals(r, (short)0x4567, "failing compareAndExchangeAcquire short"); + short x = (short) vh.get(array, i); + assertEquals(x, (short)0x4567, "failing compareAndExchangeAcquire short value"); + } + + { + short r = (short) vh.compareAndExchangeRelease(array, i, (short)0x4567, (short)0x0123); + assertEquals(r, (short)0x4567, "success compareAndExchangeRelease short"); + short x = (short) vh.get(array, i); + assertEquals(x, (short)0x0123, "success compareAndExchangeRelease short value"); + } + + { + short r = (short) vh.compareAndExchangeRelease(array, i, (short)0x4567, (short)0x89AB); + assertEquals(r, (short)0x0123, "failing compareAndExchangeRelease short"); + short x = (short) vh.get(array, i); + assertEquals(x, (short)0x0123, "failing compareAndExchangeRelease short value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSet(array, i, (short)0x0123, (short)0x4567); + } + assertEquals(success, true, "weakCompareAndSet short"); + short x = (short) vh.get(array, i); + assertEquals(x, (short)0x4567, "weakCompareAndSet short value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetAcquire(array, i, (short)0x4567, (short)0x0123); + } + assertEquals(success, true, "weakCompareAndSetAcquire short"); + short x = (short) vh.get(array, i); + assertEquals(x, (short)0x0123, "weakCompareAndSetAcquire short"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetRelease(array, i, (short)0x0123, (short)0x4567); + } + assertEquals(success, true, "weakCompareAndSetRelease short"); + short x = (short) vh.get(array, i); + assertEquals(x, (short)0x4567, "weakCompareAndSetRelease short"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = vh.weakCompareAndSetVolatile(array, i, (short)0x4567, (short)0x0123); + } + assertEquals(success, true, "weakCompareAndSetVolatile short"); + short x = (short) vh.get(array, i); + assertEquals(x, (short)0x0123, "weakCompareAndSetVolatile short"); + } + + // Compare set and get + { + short o = (short) vh.getAndSet(array, i, (short)0x4567); + assertEquals(o, (short)0x0123, "getAndSet short"); + short x = (short) vh.get(array, i); + assertEquals(x, (short)0x4567, "getAndSet short value"); + } + + vh.set(array, i, (short)0x0123); + + // get and add, add and get + { + short o = (short) vh.getAndAdd(array, i, (short)0x89AB); + assertEquals(o, (short)0x0123, "getAndAdd short"); + short c = (short) vh.addAndGet(array, i, (short)0x89AB); + assertEquals(c, (short)((short)0x0123 + (short)0x89AB + (short)0x89AB), "getAndAdd short value"); + } } } @@ -597,49 +774,7 @@ public class VarHandleTestAccessShort extends VarHandleBaseTest { short[] array = new short[10]; int i = 0; - checkUOE(() -> { - boolean r = vh.compareAndSet(array, i, (short)1, (short)2); - }); - checkUOE(() -> { - short r = (short) vh.compareAndExchangeVolatile(array, i, (short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.compareAndExchangeAcquire(array, i, (short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.compareAndExchangeRelease(array, i, (short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSet(array, i, (short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetVolatile(array, i, (short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetAcquire(array, i, (short)1, (short)2); - }); - - checkUOE(() -> { - boolean r = vh.weakCompareAndSetRelease(array, i, (short)1, (short)2); - }); - - checkUOE(() -> { - short r = (short) vh.getAndSet(array, i, (short)1); - }); - - checkUOE(() -> { - short o = (short) vh.getAndAdd(array, i, (short)1); - }); - - checkUOE(() -> { - short o = (short) vh.addAndGet(array, i, (short)1); - }); } static void testArrayIndexOutOfBounds(VarHandle vh) throws Throwable { @@ -653,7 +788,7 @@ public class VarHandleTestAccessShort extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.set(array, ci, (short)1); + vh.set(array, ci, (short)0x0123); }); checkIOOBE(() -> { @@ -661,7 +796,7 @@ public class VarHandleTestAccessShort extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setVolatile(array, ci, (short)1); + vh.setVolatile(array, ci, (short)0x0123); }); checkIOOBE(() -> { @@ -669,7 +804,7 @@ public class VarHandleTestAccessShort extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setRelease(array, ci, (short)1); + vh.setRelease(array, ci, (short)0x0123); }); checkIOOBE(() -> { @@ -677,10 +812,52 @@ public class VarHandleTestAccessShort extends VarHandleBaseTest { }); checkIOOBE(() -> { - vh.setOpaque(array, ci, (short)1); + vh.setOpaque(array, ci, (short)0x0123); }); + checkIOOBE(() -> { + boolean r = vh.compareAndSet(array, ci, (short)0x0123, (short)0x4567); + }); + checkIOOBE(() -> { + short r = (short) vh.compareAndExchange(array, ci, (short)0x4567, (short)0x0123); + }); + + checkIOOBE(() -> { + short r = (short) vh.compareAndExchangeAcquire(array, ci, (short)0x4567, (short)0x0123); + }); + + checkIOOBE(() -> { + short r = (short) vh.compareAndExchangeRelease(array, ci, (short)0x4567, (short)0x0123); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSet(array, ci, (short)0x0123, (short)0x4567); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetVolatile(array, ci, (short)0x0123, (short)0x4567); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetAcquire(array, ci, (short)0x0123, (short)0x4567); + }); + + checkIOOBE(() -> { + boolean r = vh.weakCompareAndSetRelease(array, ci, (short)0x0123, (short)0x4567); + }); + + checkIOOBE(() -> { + short o = (short) vh.getAndSet(array, ci, (short)0x0123); + }); + + checkIOOBE(() -> { + short o = (short) vh.getAndAdd(array, ci, (short)0x89AB); + }); + + checkIOOBE(() -> { + short o = (short) vh.addAndGet(array, ci, (short)0x89AB); + }); } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessString.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessString.java index 405206ef22c..0ac329d65f8 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessString.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestAccessString.java @@ -100,7 +100,7 @@ public class VarHandleTestAccessString extends VarHandleBaseTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); @@ -374,17 +374,17 @@ public class VarHandleTestAccessString extends VarHandleBaseTest { } { - String r = (String) vh.compareAndExchangeVolatile(recv, "bar", "foo"); - assertEquals(r, "bar", "success compareAndExchangeVolatile String"); + String r = (String) vh.compareAndExchange(recv, "bar", "foo"); + assertEquals(r, "bar", "success compareAndExchange String"); String x = (String) vh.get(recv); - assertEquals(x, "foo", "success compareAndExchangeVolatile String value"); + assertEquals(x, "foo", "success compareAndExchange String value"); } { - String r = (String) vh.compareAndExchangeVolatile(recv, "bar", "baz"); - assertEquals(r, "foo", "failing compareAndExchangeVolatile String"); + String r = (String) vh.compareAndExchange(recv, "bar", "baz"); + assertEquals(r, "foo", "failing compareAndExchange String"); String x = (String) vh.get(recv); - assertEquals(x, "foo", "failing compareAndExchangeVolatile String value"); + assertEquals(x, "foo", "failing compareAndExchange String value"); } { @@ -525,17 +525,17 @@ public class VarHandleTestAccessString extends VarHandleBaseTest { } { - String r = (String) vh.compareAndExchangeVolatile("bar", "foo"); - assertEquals(r, "bar", "success compareAndExchangeVolatile String"); + String r = (String) vh.compareAndExchange("bar", "foo"); + assertEquals(r, "bar", "success compareAndExchange String"); String x = (String) vh.get(); - assertEquals(x, "foo", "success compareAndExchangeVolatile String value"); + assertEquals(x, "foo", "success compareAndExchange String value"); } { - String r = (String) vh.compareAndExchangeVolatile("bar", "baz"); - assertEquals(r, "foo", "failing compareAndExchangeVolatile String"); + String r = (String) vh.compareAndExchange("bar", "baz"); + assertEquals(r, "foo", "failing compareAndExchange String"); String x = (String) vh.get(); - assertEquals(x, "foo", "failing compareAndExchangeVolatile String value"); + assertEquals(x, "foo", "failing compareAndExchange String value"); } { @@ -679,17 +679,17 @@ public class VarHandleTestAccessString extends VarHandleBaseTest { } { - String r = (String) vh.compareAndExchangeVolatile(array, i, "bar", "foo"); - assertEquals(r, "bar", "success compareAndExchangeVolatile String"); + String r = (String) vh.compareAndExchange(array, i, "bar", "foo"); + assertEquals(r, "bar", "success compareAndExchange String"); String x = (String) vh.get(array, i); - assertEquals(x, "foo", "success compareAndExchangeVolatile String value"); + assertEquals(x, "foo", "success compareAndExchange String value"); } { - String r = (String) vh.compareAndExchangeVolatile(array, i, "bar", "baz"); - assertEquals(r, "foo", "failing compareAndExchangeVolatile String"); + String r = (String) vh.compareAndExchange(array, i, "bar", "baz"); + assertEquals(r, "foo", "failing compareAndExchange String"); String x = (String) vh.get(array, i); - assertEquals(x, "foo", "failing compareAndExchangeVolatile String value"); + assertEquals(x, "foo", "failing compareAndExchange String value"); } { @@ -828,7 +828,7 @@ public class VarHandleTestAccessString extends VarHandleBaseTest { }); checkIOOBE(() -> { - String r = (String) vh.compareAndExchangeVolatile(array, ci, "bar", "foo"); + String r = (String) vh.compareAndExchange(array, ci, "bar", "foo"); }); checkIOOBE(() -> { diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsChar.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsChar.java index 8038315e391..dc9db6f2d26 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsChar.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsChar.java @@ -89,7 +89,7 @@ public class VarHandleTestByteArrayAsChar extends VarHandleBaseByteArrayTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); + assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); @@ -189,7 +189,7 @@ public class VarHandleTestByteArrayAsChar extends VarHandleBaseByteArrayTest { }); checkUOE(() -> { - char r = (char) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + char r = (char) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkUOE(() -> { @@ -258,7 +258,7 @@ public class VarHandleTestByteArrayAsChar extends VarHandleBaseByteArrayTest { }); checkUOE(() -> { - char r = (char) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + char r = (char) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkUOE(() -> { @@ -303,7 +303,7 @@ public class VarHandleTestByteArrayAsChar extends VarHandleBaseByteArrayTest { }); checkUOE(() -> { - char r = (char) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + char r = (char) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkUOE(() -> { diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsDouble.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsDouble.java index 53db9cd239b..a713e91b979 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsDouble.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsDouble.java @@ -89,7 +89,7 @@ public class VarHandleTestByteArrayAsDouble extends VarHandleBaseByteArrayTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); @@ -224,7 +224,7 @@ public class VarHandleTestByteArrayAsDouble extends VarHandleBaseByteArrayTest { }); checkROBE(() -> { - double r = (double) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + double r = (double) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkROBE(() -> { @@ -321,7 +321,7 @@ public class VarHandleTestByteArrayAsDouble extends VarHandleBaseByteArrayTest { }); checkIOOBE(() -> { - double r = (double) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + double r = (double) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkIOOBE(() -> { @@ -406,7 +406,7 @@ public class VarHandleTestByteArrayAsDouble extends VarHandleBaseByteArrayTest { }); checkIOOBE(() -> { - double r = (double) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + double r = (double) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkIOOBE(() -> { @@ -482,7 +482,7 @@ public class VarHandleTestByteArrayAsDouble extends VarHandleBaseByteArrayTest { }); checkISE(() -> { - double r = (double) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + double r = (double) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkISE(() -> { @@ -561,7 +561,7 @@ public class VarHandleTestByteArrayAsDouble extends VarHandleBaseByteArrayTest { }); checkISE(() -> { - double r = (double) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + double r = (double) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkISE(() -> { @@ -656,17 +656,17 @@ public class VarHandleTestByteArrayAsDouble extends VarHandleBaseByteArrayTest { } { - double r = (double) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_1); - assertEquals(r, VALUE_2, "success compareAndExchangeVolatile double"); + double r = (double) vh.compareAndExchange(array, i, VALUE_2, VALUE_1); + assertEquals(r, VALUE_2, "success compareAndExchange double"); double x = (double) vh.get(array, i); - assertEquals(x, VALUE_1, "success compareAndExchangeVolatile double value"); + assertEquals(x, VALUE_1, "success compareAndExchange double value"); } { - double r = (double) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_3); - assertEquals(r, VALUE_1, "failing compareAndExchangeVolatile double"); + double r = (double) vh.compareAndExchange(array, i, VALUE_2, VALUE_3); + assertEquals(r, VALUE_1, "failing compareAndExchange double"); double x = (double) vh.get(array, i); - assertEquals(x, VALUE_1, "failing compareAndExchangeVolatile double value"); + assertEquals(x, VALUE_1, "failing compareAndExchange double value"); } { @@ -805,17 +805,17 @@ public class VarHandleTestByteArrayAsDouble extends VarHandleBaseByteArrayTest { } { - double r = (double) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_1); - assertEquals(r, VALUE_2, "success compareAndExchangeVolatile double"); + double r = (double) vh.compareAndExchange(array, i, VALUE_2, VALUE_1); + assertEquals(r, VALUE_2, "success compareAndExchange double"); double x = (double) vh.get(array, i); - assertEquals(x, VALUE_1, "success compareAndExchangeVolatile double value"); + assertEquals(x, VALUE_1, "success compareAndExchange double value"); } { - double r = (double) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_3); - assertEquals(r, VALUE_1, "failing compareAndExchangeVolatile double"); + double r = (double) vh.compareAndExchange(array, i, VALUE_2, VALUE_3); + assertEquals(r, VALUE_1, "failing compareAndExchange double"); double x = (double) vh.get(array, i); - assertEquals(x, VALUE_1, "failing compareAndExchangeVolatile double value"); + assertEquals(x, VALUE_1, "failing compareAndExchange double value"); } { diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsFloat.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsFloat.java index d2688cf925a..3e964dcd46a 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsFloat.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsFloat.java @@ -89,7 +89,7 @@ public class VarHandleTestByteArrayAsFloat extends VarHandleBaseByteArrayTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); @@ -224,7 +224,7 @@ public class VarHandleTestByteArrayAsFloat extends VarHandleBaseByteArrayTest { }); checkROBE(() -> { - float r = (float) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + float r = (float) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkROBE(() -> { @@ -321,7 +321,7 @@ public class VarHandleTestByteArrayAsFloat extends VarHandleBaseByteArrayTest { }); checkIOOBE(() -> { - float r = (float) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + float r = (float) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkIOOBE(() -> { @@ -406,7 +406,7 @@ public class VarHandleTestByteArrayAsFloat extends VarHandleBaseByteArrayTest { }); checkIOOBE(() -> { - float r = (float) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + float r = (float) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkIOOBE(() -> { @@ -482,7 +482,7 @@ public class VarHandleTestByteArrayAsFloat extends VarHandleBaseByteArrayTest { }); checkISE(() -> { - float r = (float) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + float r = (float) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkISE(() -> { @@ -561,7 +561,7 @@ public class VarHandleTestByteArrayAsFloat extends VarHandleBaseByteArrayTest { }); checkISE(() -> { - float r = (float) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + float r = (float) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkISE(() -> { @@ -656,17 +656,17 @@ public class VarHandleTestByteArrayAsFloat extends VarHandleBaseByteArrayTest { } { - float r = (float) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_1); - assertEquals(r, VALUE_2, "success compareAndExchangeVolatile float"); + float r = (float) vh.compareAndExchange(array, i, VALUE_2, VALUE_1); + assertEquals(r, VALUE_2, "success compareAndExchange float"); float x = (float) vh.get(array, i); - assertEquals(x, VALUE_1, "success compareAndExchangeVolatile float value"); + assertEquals(x, VALUE_1, "success compareAndExchange float value"); } { - float r = (float) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_3); - assertEquals(r, VALUE_1, "failing compareAndExchangeVolatile float"); + float r = (float) vh.compareAndExchange(array, i, VALUE_2, VALUE_3); + assertEquals(r, VALUE_1, "failing compareAndExchange float"); float x = (float) vh.get(array, i); - assertEquals(x, VALUE_1, "failing compareAndExchangeVolatile float value"); + assertEquals(x, VALUE_1, "failing compareAndExchange float value"); } { @@ -805,17 +805,17 @@ public class VarHandleTestByteArrayAsFloat extends VarHandleBaseByteArrayTest { } { - float r = (float) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_1); - assertEquals(r, VALUE_2, "success compareAndExchangeVolatile float"); + float r = (float) vh.compareAndExchange(array, i, VALUE_2, VALUE_1); + assertEquals(r, VALUE_2, "success compareAndExchange float"); float x = (float) vh.get(array, i); - assertEquals(x, VALUE_1, "success compareAndExchangeVolatile float value"); + assertEquals(x, VALUE_1, "success compareAndExchange float value"); } { - float r = (float) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_3); - assertEquals(r, VALUE_1, "failing compareAndExchangeVolatile float"); + float r = (float) vh.compareAndExchange(array, i, VALUE_2, VALUE_3); + assertEquals(r, VALUE_1, "failing compareAndExchange float"); float x = (float) vh.get(array, i); - assertEquals(x, VALUE_1, "failing compareAndExchangeVolatile float value"); + assertEquals(x, VALUE_1, "failing compareAndExchange float value"); } { diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsInt.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsInt.java index 9e47532c20b..bbda8c0270f 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsInt.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsInt.java @@ -89,7 +89,7 @@ public class VarHandleTestByteArrayAsInt extends VarHandleBaseByteArrayTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); @@ -217,7 +217,7 @@ public class VarHandleTestByteArrayAsInt extends VarHandleBaseByteArrayTest { }); checkROBE(() -> { - int r = (int) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + int r = (int) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkROBE(() -> { @@ -307,7 +307,7 @@ public class VarHandleTestByteArrayAsInt extends VarHandleBaseByteArrayTest { }); checkIOOBE(() -> { - int r = (int) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + int r = (int) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkIOOBE(() -> { @@ -399,7 +399,7 @@ public class VarHandleTestByteArrayAsInt extends VarHandleBaseByteArrayTest { }); checkIOOBE(() -> { - int r = (int) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + int r = (int) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkIOOBE(() -> { @@ -482,7 +482,7 @@ public class VarHandleTestByteArrayAsInt extends VarHandleBaseByteArrayTest { }); checkISE(() -> { - int r = (int) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + int r = (int) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkISE(() -> { @@ -568,7 +568,7 @@ public class VarHandleTestByteArrayAsInt extends VarHandleBaseByteArrayTest { }); checkISE(() -> { - int r = (int) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + int r = (int) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkISE(() -> { @@ -670,17 +670,17 @@ public class VarHandleTestByteArrayAsInt extends VarHandleBaseByteArrayTest { } { - int r = (int) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_1); - assertEquals(r, VALUE_2, "success compareAndExchangeVolatile int"); + int r = (int) vh.compareAndExchange(array, i, VALUE_2, VALUE_1); + assertEquals(r, VALUE_2, "success compareAndExchange int"); int x = (int) vh.get(array, i); - assertEquals(x, VALUE_1, "success compareAndExchangeVolatile int value"); + assertEquals(x, VALUE_1, "success compareAndExchange int value"); } { - int r = (int) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_3); - assertEquals(r, VALUE_1, "failing compareAndExchangeVolatile int"); + int r = (int) vh.compareAndExchange(array, i, VALUE_2, VALUE_3); + assertEquals(r, VALUE_1, "failing compareAndExchange int"); int x = (int) vh.get(array, i); - assertEquals(x, VALUE_1, "failing compareAndExchangeVolatile int value"); + assertEquals(x, VALUE_1, "failing compareAndExchange int value"); } { @@ -828,17 +828,17 @@ public class VarHandleTestByteArrayAsInt extends VarHandleBaseByteArrayTest { } { - int r = (int) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_1); - assertEquals(r, VALUE_2, "success compareAndExchangeVolatile int"); + int r = (int) vh.compareAndExchange(array, i, VALUE_2, VALUE_1); + assertEquals(r, VALUE_2, "success compareAndExchange int"); int x = (int) vh.get(array, i); - assertEquals(x, VALUE_1, "success compareAndExchangeVolatile int value"); + assertEquals(x, VALUE_1, "success compareAndExchange int value"); } { - int r = (int) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_3); - assertEquals(r, VALUE_1, "failing compareAndExchangeVolatile int"); + int r = (int) vh.compareAndExchange(array, i, VALUE_2, VALUE_3); + assertEquals(r, VALUE_1, "failing compareAndExchange int"); int x = (int) vh.get(array, i); - assertEquals(x, VALUE_1, "failing compareAndExchangeVolatile int value"); + assertEquals(x, VALUE_1, "failing compareAndExchange int value"); } { diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsLong.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsLong.java index f9ed92f0e07..e203f8e23f7 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsLong.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsLong.java @@ -89,7 +89,7 @@ public class VarHandleTestByteArrayAsLong extends VarHandleBaseByteArrayTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); @@ -217,7 +217,7 @@ public class VarHandleTestByteArrayAsLong extends VarHandleBaseByteArrayTest { }); checkROBE(() -> { - long r = (long) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + long r = (long) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkROBE(() -> { @@ -307,7 +307,7 @@ public class VarHandleTestByteArrayAsLong extends VarHandleBaseByteArrayTest { }); checkIOOBE(() -> { - long r = (long) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + long r = (long) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkIOOBE(() -> { @@ -399,7 +399,7 @@ public class VarHandleTestByteArrayAsLong extends VarHandleBaseByteArrayTest { }); checkIOOBE(() -> { - long r = (long) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + long r = (long) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkIOOBE(() -> { @@ -482,7 +482,7 @@ public class VarHandleTestByteArrayAsLong extends VarHandleBaseByteArrayTest { }); checkISE(() -> { - long r = (long) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + long r = (long) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkISE(() -> { @@ -568,7 +568,7 @@ public class VarHandleTestByteArrayAsLong extends VarHandleBaseByteArrayTest { }); checkISE(() -> { - long r = (long) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + long r = (long) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkISE(() -> { @@ -670,17 +670,17 @@ public class VarHandleTestByteArrayAsLong extends VarHandleBaseByteArrayTest { } { - long r = (long) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_1); - assertEquals(r, VALUE_2, "success compareAndExchangeVolatile long"); + long r = (long) vh.compareAndExchange(array, i, VALUE_2, VALUE_1); + assertEquals(r, VALUE_2, "success compareAndExchange long"); long x = (long) vh.get(array, i); - assertEquals(x, VALUE_1, "success compareAndExchangeVolatile long value"); + assertEquals(x, VALUE_1, "success compareAndExchange long value"); } { - long r = (long) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_3); - assertEquals(r, VALUE_1, "failing compareAndExchangeVolatile long"); + long r = (long) vh.compareAndExchange(array, i, VALUE_2, VALUE_3); + assertEquals(r, VALUE_1, "failing compareAndExchange long"); long x = (long) vh.get(array, i); - assertEquals(x, VALUE_1, "failing compareAndExchangeVolatile long value"); + assertEquals(x, VALUE_1, "failing compareAndExchange long value"); } { @@ -828,17 +828,17 @@ public class VarHandleTestByteArrayAsLong extends VarHandleBaseByteArrayTest { } { - long r = (long) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_1); - assertEquals(r, VALUE_2, "success compareAndExchangeVolatile long"); + long r = (long) vh.compareAndExchange(array, i, VALUE_2, VALUE_1); + assertEquals(r, VALUE_2, "success compareAndExchange long"); long x = (long) vh.get(array, i); - assertEquals(x, VALUE_1, "success compareAndExchangeVolatile long value"); + assertEquals(x, VALUE_1, "success compareAndExchange long value"); } { - long r = (long) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_3); - assertEquals(r, VALUE_1, "failing compareAndExchangeVolatile long"); + long r = (long) vh.compareAndExchange(array, i, VALUE_2, VALUE_3); + assertEquals(r, VALUE_1, "failing compareAndExchange long"); long x = (long) vh.get(array, i); - assertEquals(x, VALUE_1, "failing compareAndExchangeVolatile long value"); + assertEquals(x, VALUE_1, "failing compareAndExchange long value"); } { diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsShort.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsShort.java index 0a9aa6e871c..d96715ed083 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsShort.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestByteArrayAsShort.java @@ -89,7 +89,7 @@ public class VarHandleTestByteArrayAsShort extends VarHandleBaseByteArrayTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.SET_OPAQUE)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); + assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); @@ -189,7 +189,7 @@ public class VarHandleTestByteArrayAsShort extends VarHandleBaseByteArrayTest { }); checkUOE(() -> { - short r = (short) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + short r = (short) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkUOE(() -> { @@ -258,7 +258,7 @@ public class VarHandleTestByteArrayAsShort extends VarHandleBaseByteArrayTest { }); checkUOE(() -> { - short r = (short) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + short r = (short) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkUOE(() -> { @@ -303,7 +303,7 @@ public class VarHandleTestByteArrayAsShort extends VarHandleBaseByteArrayTest { }); checkUOE(() -> { - short r = (short) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + short r = (short) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkUOE(() -> { diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessBoolean.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessBoolean.java index 32761fe0e3f..544fcb3c0ee 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessBoolean.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessBoolean.java @@ -148,27 +148,116 @@ public class VarHandleTestMethodHandleAccessBoolean extends VarHandleBaseTest { assertEquals(x, false, "setOpaque boolean value"); } + hs.get(TestAccessMode.SET).invokeExact(recv, true); + + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, true, false); + assertEquals(r, true, "success compareAndSet boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, false, "success compareAndSet boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, true, false); + assertEquals(r, false, "failing compareAndSet boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, false, "failing compareAndSet boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, false, true); + assertEquals(r, false, "success compareAndExchange boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, true, "success compareAndExchange boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, false, false); + assertEquals(r, true, "failing compareAndExchange boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, true, "failing compareAndExchange boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, true, false); + assertEquals(r, true, "success compareAndExchangeAcquire boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, false, "success compareAndExchangeAcquire boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, true, false); + assertEquals(r, false, "failing compareAndExchangeAcquire boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, false, "failing compareAndExchangeAcquire boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, false, true); + assertEquals(r, false, "success compareAndExchangeRelease boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, true, "success compareAndExchangeRelease boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, false, false); + assertEquals(r, true, "failing compareAndExchangeRelease boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, true, "failing compareAndExchangeRelease boolean value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(recv, true, false); + } + assertEquals(success, true, "weakCompareAndSet boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, false, "weakCompareAndSet boolean value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(recv, false, true); + } + assertEquals(success, true, "weakCompareAndSetAcquire boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, true, "weakCompareAndSetAcquire boolean"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(recv, true, false); + } + assertEquals(success, true, "weakCompareAndSetRelease boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, false, "weakCompareAndSetRelease boolean"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(recv, false, true); + } + assertEquals(success, true, "weakCompareAndSetVolatile boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, true, "weakCompareAndSetVolatile boolean"); + } + + // Compare set and get + { + boolean o = (boolean) hs.get(TestAccessMode.GET_AND_SET).invokeExact(recv, false); + assertEquals(o, true, "getAndSet boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, false, "getAndSet boolean value"); + } } static void testInstanceFieldUnsupported(VarHandleTestMethodHandleAccessBoolean recv, Handles hs) throws Throwable { - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(recv, true, false); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(recv, true, false); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(recv, true); - }); - } for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { checkUOE(am, () -> { @@ -208,27 +297,116 @@ public class VarHandleTestMethodHandleAccessBoolean extends VarHandleBaseTest { assertEquals(x, false, "setOpaque boolean value"); } + hs.get(TestAccessMode.SET).invokeExact(true); + + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(true, false); + assertEquals(r, true, "success compareAndSet boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, false, "success compareAndSet boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(true, false); + assertEquals(r, false, "failing compareAndSet boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, false, "failing compareAndSet boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(false, true); + assertEquals(r, false, "success compareAndExchange boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, true, "success compareAndExchange boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(false, false); + assertEquals(r, true, "failing compareAndExchange boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, true, "failing compareAndExchange boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(true, false); + assertEquals(r, true, "success compareAndExchangeAcquire boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, false, "success compareAndExchangeAcquire boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(true, false); + assertEquals(r, false, "failing compareAndExchangeAcquire boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, false, "failing compareAndExchangeAcquire boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(false, true); + assertEquals(r, false, "success compareAndExchangeRelease boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, true, "success compareAndExchangeRelease boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(false, false); + assertEquals(r, true, "failing compareAndExchangeRelease boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, true, "failing compareAndExchangeRelease boolean value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(true, false); + } + assertEquals(success, true, "weakCompareAndSet boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, false, "weakCompareAndSet boolean value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(false, true); + } + assertEquals(success, true, "weakCompareAndSetAcquire boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, true, "weakCompareAndSetAcquire boolean"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(true, false); + } + assertEquals(success, true, "weakCompareAndSetRelease boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, false, "weakCompareAndSetRelease boolean"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(false, true); + } + assertEquals(success, true, "weakCompareAndSetVolatile boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, true, "weakCompareAndSetVolatile boolean"); + } + + // Compare set and get + { + boolean o = (boolean) hs.get(TestAccessMode.GET_AND_SET).invokeExact( false); + assertEquals(o, true, "getAndSet boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, false, "getAndSet boolean value"); + } } static void testStaticFieldUnsupported(Handles hs) throws Throwable { - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(true, false); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(true, false); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(true); - }); - } for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { checkUOE(am, () -> { @@ -271,6 +449,112 @@ public class VarHandleTestMethodHandleAccessBoolean extends VarHandleBaseTest { assertEquals(x, false, "setOpaque boolean value"); } + hs.get(TestAccessMode.SET).invokeExact(array, i, true); + + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, true, false); + assertEquals(r, true, "success compareAndSet boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, false, "success compareAndSet boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, true, false); + assertEquals(r, false, "failing compareAndSet boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, false, "failing compareAndSet boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, false, true); + assertEquals(r, false, "success compareAndExchange boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, true, "success compareAndExchange boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, false, false); + assertEquals(r, true, "failing compareAndExchange boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, true, "failing compareAndExchange boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, true, false); + assertEquals(r, true, "success compareAndExchangeAcquire boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, false, "success compareAndExchangeAcquire boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, true, false); + assertEquals(r, false, "failing compareAndExchangeAcquire boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, false, "failing compareAndExchangeAcquire boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, false, true); + assertEquals(r, false, "success compareAndExchangeRelease boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, true, "success compareAndExchangeRelease boolean value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, false, false); + assertEquals(r, true, "failing compareAndExchangeRelease boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, true, "failing compareAndExchangeRelease boolean value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(array, i, true, false); + } + assertEquals(success, true, "weakCompareAndSet boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, false, "weakCompareAndSet boolean value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(array, i, false, true); + } + assertEquals(success, true, "weakCompareAndSetAcquire boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, true, "weakCompareAndSetAcquire boolean"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(array, i, true, false); + } + assertEquals(success, true, "weakCompareAndSetRelease boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, false, "weakCompareAndSetRelease boolean"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(array, i, false, true); + } + assertEquals(success, true, "weakCompareAndSetVolatile boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, true, "weakCompareAndSetVolatile boolean"); + } + + // Compare set and get + { + boolean o = (boolean) hs.get(TestAccessMode.GET_AND_SET).invokeExact(array, i, false); + assertEquals(o, true, "getAndSet boolean"); + boolean x = (boolean) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, false, "getAndSet boolean value"); + } } } @@ -279,23 +563,6 @@ public class VarHandleTestMethodHandleAccessBoolean extends VarHandleBaseTest { boolean[] array = new boolean[10]; final int i = 0; - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(array, i, true, false); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(array, i, true, false); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(array, i, true); - }); - } for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { checkUOE(am, () -> { @@ -322,6 +589,23 @@ public class VarHandleTestMethodHandleAccessBoolean extends VarHandleBaseTest { }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + checkIOOBE(am, () -> { + boolean r = (boolean) hs.get(am).invokeExact(array, ci, true, false); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + checkIOOBE(am, () -> { + boolean r = (boolean) hs.get(am).invokeExact(array, ci, false, true); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + checkIOOBE(am, () -> { + boolean o = (boolean) hs.get(am).invokeExact(array, ci, true); + }); + } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessByte.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessByte.java index 8c36eb861c5..21e09b83953 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessByte.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessByte.java @@ -39,11 +39,11 @@ import java.util.List; import static org.testng.Assert.*; public class VarHandleTestMethodHandleAccessByte extends VarHandleBaseTest { - static final byte static_final_v = (byte)1; + static final byte static_final_v = (byte)0x01; static byte static_v; - final byte final_v = (byte)1; + final byte final_v = (byte)0x01; byte v; @@ -121,120 +121,306 @@ public class VarHandleTestMethodHandleAccessByte extends VarHandleBaseTest { static void testInstanceField(VarHandleTestMethodHandleAccessByte recv, Handles hs) throws Throwable { // Plain { - hs.get(TestAccessMode.SET).invokeExact(recv, (byte)1); + hs.get(TestAccessMode.SET).invokeExact(recv, (byte)0x01); byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, (byte)1, "set byte value"); + assertEquals(x, (byte)0x01, "set byte value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact(recv, (byte)2); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact(recv, (byte)0x23); byte x = (byte) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(recv); - assertEquals(x, (byte)2, "setVolatile byte value"); + assertEquals(x, (byte)0x23, "setVolatile byte value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact(recv, (byte)1); + hs.get(TestAccessMode.SET_RELEASE).invokeExact(recv, (byte)0x01); byte x = (byte) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(recv); - assertEquals(x, (byte)1, "setRelease byte value"); + assertEquals(x, (byte)0x01, "setRelease byte value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact(recv, (byte)2); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact(recv, (byte)0x23); byte x = (byte) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(recv); - assertEquals(x, (byte)2, "setOpaque byte value"); + assertEquals(x, (byte)0x23, "setOpaque byte value"); } + hs.get(TestAccessMode.SET).invokeExact(recv, (byte)0x01); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, (byte)0x01, (byte)0x23); + assertEquals(r, true, "success compareAndSet byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (byte)0x23, "success compareAndSet byte value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, (byte)0x01, (byte)0x45); + assertEquals(r, false, "failing compareAndSet byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (byte)0x23, "failing compareAndSet byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, (byte)0x23, (byte)0x01); + assertEquals(r, (byte)0x23, "success compareAndExchange byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (byte)0x01, "success compareAndExchange byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, (byte)0x23, (byte)0x45); + assertEquals(r, (byte)0x01, "failing compareAndExchange byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (byte)0x01, "failing compareAndExchange byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, (byte)0x01, (byte)0x23); + assertEquals(r, (byte)0x01, "success compareAndExchangeAcquire byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (byte)0x23, "success compareAndExchangeAcquire byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, (byte)0x01, (byte)0x45); + assertEquals(r, (byte)0x23, "failing compareAndExchangeAcquire byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (byte)0x23, "failing compareAndExchangeAcquire byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, (byte)0x23, (byte)0x01); + assertEquals(r, (byte)0x23, "success compareAndExchangeRelease byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (byte)0x01, "success compareAndExchangeRelease byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, (byte)0x23, (byte)0x45); + assertEquals(r, (byte)0x01, "failing compareAndExchangeRelease byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (byte)0x01, "failing compareAndExchangeRelease byte value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(recv, (byte)0x01, (byte)0x23); + } + assertEquals(success, true, "weakCompareAndSet byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (byte)0x23, "weakCompareAndSet byte value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(recv, (byte)0x23, (byte)0x01); + } + assertEquals(success, true, "weakCompareAndSetAcquire byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (byte)0x01, "weakCompareAndSetAcquire byte"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(recv, (byte)0x01, (byte)0x23); + } + assertEquals(success, true, "weakCompareAndSetRelease byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (byte)0x23, "weakCompareAndSetRelease byte"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(recv, (byte)0x23, (byte)0x01); + } + assertEquals(success, true, "weakCompareAndSetVolatile byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (byte)0x01, "weakCompareAndSetVolatile byte"); + } + + // Compare set and get + { + byte o = (byte) hs.get(TestAccessMode.GET_AND_SET).invokeExact(recv, (byte)0x23); + assertEquals(o, (byte)0x01, "getAndSet byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (byte)0x23, "getAndSet byte value"); + } + + hs.get(TestAccessMode.SET).invokeExact(recv, (byte)0x01); + + // get and add, add and get + { + byte o = (byte) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(recv, (byte)0x45); + assertEquals(o, (byte)0x01, "getAndAdd byte"); + byte c = (byte) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(recv, (byte)0x45); + assertEquals(c, (byte)((byte)0x01 + (byte)0x45 + (byte)0x45), "getAndAdd byte value"); + } } static void testInstanceFieldUnsupported(VarHandleTestMethodHandleAccessByte recv, Handles hs) throws Throwable { - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(recv, (byte)1, (byte)2); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - byte r = (byte) hs.get(am).invokeExact(recv, (byte)1, (byte)2); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - byte r = (byte) hs.get(am).invokeExact(recv, (byte)1); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - byte r = (byte) hs.get(am).invokeExact(recv, (byte)1); - }); - } } static void testStaticField(Handles hs) throws Throwable { // Plain { - hs.get(TestAccessMode.SET).invokeExact((byte)1); + hs.get(TestAccessMode.SET).invokeExact((byte)0x01); byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, (byte)1, "set byte value"); + assertEquals(x, (byte)0x01, "set byte value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact((byte)2); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact((byte)0x23); byte x = (byte) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(); - assertEquals(x, (byte)2, "setVolatile byte value"); + assertEquals(x, (byte)0x23, "setVolatile byte value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact((byte)1); + hs.get(TestAccessMode.SET_RELEASE).invokeExact((byte)0x01); byte x = (byte) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(); - assertEquals(x, (byte)1, "setRelease byte value"); + assertEquals(x, (byte)0x01, "setRelease byte value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact((byte)2); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact((byte)0x23); byte x = (byte) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(); - assertEquals(x, (byte)2, "setOpaque byte value"); + assertEquals(x, (byte)0x23, "setOpaque byte value"); } + hs.get(TestAccessMode.SET).invokeExact((byte)0x01); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact((byte)0x01, (byte)0x23); + assertEquals(r, true, "success compareAndSet byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (byte)0x23, "success compareAndSet byte value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact((byte)0x01, (byte)0x45); + assertEquals(r, false, "failing compareAndSet byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (byte)0x23, "failing compareAndSet byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact((byte)0x23, (byte)0x01); + assertEquals(r, (byte)0x23, "success compareAndExchange byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (byte)0x01, "success compareAndExchange byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact((byte)0x23, (byte)0x45); + assertEquals(r, (byte)0x01, "failing compareAndExchange byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (byte)0x01, "failing compareAndExchange byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact((byte)0x01, (byte)0x23); + assertEquals(r, (byte)0x01, "success compareAndExchangeAcquire byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (byte)0x23, "success compareAndExchangeAcquire byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact((byte)0x01, (byte)0x45); + assertEquals(r, (byte)0x23, "failing compareAndExchangeAcquire byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (byte)0x23, "failing compareAndExchangeAcquire byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact((byte)0x23, (byte)0x01); + assertEquals(r, (byte)0x23, "success compareAndExchangeRelease byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (byte)0x01, "success compareAndExchangeRelease byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact((byte)0x23, (byte)0x45); + assertEquals(r, (byte)0x01, "failing compareAndExchangeRelease byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (byte)0x01, "failing compareAndExchangeRelease byte value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact((byte)0x01, (byte)0x23); + } + assertEquals(success, true, "weakCompareAndSet byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (byte)0x23, "weakCompareAndSet byte value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact((byte)0x23, (byte)0x01); + } + assertEquals(success, true, "weakCompareAndSetAcquire byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (byte)0x01, "weakCompareAndSetAcquire byte"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact((byte)0x01, (byte)0x23); + } + assertEquals(success, true, "weakCompareAndSetRelease byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (byte)0x23, "weakCompareAndSetRelease byte"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact((byte)0x23, (byte)0x01); + } + assertEquals(success, true, "weakCompareAndSetVolatile byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (byte)0x01, "weakCompareAndSetVolatile byte"); + } + + // Compare set and get + { + byte o = (byte) hs.get(TestAccessMode.GET_AND_SET).invokeExact( (byte)0x23); + assertEquals(o, (byte)0x01, "getAndSet byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (byte)0x23, "getAndSet byte value"); + } + + hs.get(TestAccessMode.SET).invokeExact((byte)0x01); + + // get and add, add and get + { + byte o = (byte) hs.get(TestAccessMode.GET_AND_ADD).invokeExact( (byte)0x45); + assertEquals(o, (byte)0x01, "getAndAdd byte"); + byte c = (byte) hs.get(TestAccessMode.ADD_AND_GET).invokeExact((byte)0x45); + assertEquals(c, (byte)((byte)0x01 + (byte)0x45 + (byte)0x45), "getAndAdd byte value"); + } } static void testStaticFieldUnsupported(Handles hs) throws Throwable { - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact((byte)1, (byte)2); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - byte r = (byte) hs.get(am).invokeExact((byte)1, (byte)2); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - byte r = (byte) hs.get(am).invokeExact((byte)1); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - byte r = (byte) hs.get(am).invokeExact((byte)1); - }); - } } @@ -244,34 +430,149 @@ public class VarHandleTestMethodHandleAccessByte extends VarHandleBaseTest { for (int i = 0; i < array.length; i++) { // Plain { - hs.get(TestAccessMode.SET).invokeExact(array, i, (byte)1); + hs.get(TestAccessMode.SET).invokeExact(array, i, (byte)0x01); byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, (byte)1, "get byte value"); + assertEquals(x, (byte)0x01, "get byte value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact(array, i, (byte)2); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact(array, i, (byte)0x23); byte x = (byte) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(array, i); - assertEquals(x, (byte)2, "setVolatile byte value"); + assertEquals(x, (byte)0x23, "setVolatile byte value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact(array, i, (byte)1); + hs.get(TestAccessMode.SET_RELEASE).invokeExact(array, i, (byte)0x01); byte x = (byte) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(array, i); - assertEquals(x, (byte)1, "setRelease byte value"); + assertEquals(x, (byte)0x01, "setRelease byte value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact(array, i, (byte)2); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact(array, i, (byte)0x23); byte x = (byte) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(array, i); - assertEquals(x, (byte)2, "setOpaque byte value"); + assertEquals(x, (byte)0x23, "setOpaque byte value"); } + hs.get(TestAccessMode.SET).invokeExact(array, i, (byte)0x01); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, (byte)0x01, (byte)0x23); + assertEquals(r, true, "success compareAndSet byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (byte)0x23, "success compareAndSet byte value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, (byte)0x01, (byte)0x45); + assertEquals(r, false, "failing compareAndSet byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (byte)0x23, "failing compareAndSet byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, (byte)0x23, (byte)0x01); + assertEquals(r, (byte)0x23, "success compareAndExchange byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (byte)0x01, "success compareAndExchange byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, (byte)0x23, (byte)0x45); + assertEquals(r, (byte)0x01, "failing compareAndExchange byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (byte)0x01, "failing compareAndExchange byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, (byte)0x01, (byte)0x23); + assertEquals(r, (byte)0x01, "success compareAndExchangeAcquire byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (byte)0x23, "success compareAndExchangeAcquire byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, (byte)0x01, (byte)0x45); + assertEquals(r, (byte)0x23, "failing compareAndExchangeAcquire byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (byte)0x23, "failing compareAndExchangeAcquire byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, (byte)0x23, (byte)0x01); + assertEquals(r, (byte)0x23, "success compareAndExchangeRelease byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (byte)0x01, "success compareAndExchangeRelease byte value"); + } + + { + byte r = (byte) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, (byte)0x23, (byte)0x45); + assertEquals(r, (byte)0x01, "failing compareAndExchangeRelease byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (byte)0x01, "failing compareAndExchangeRelease byte value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(array, i, (byte)0x01, (byte)0x23); + } + assertEquals(success, true, "weakCompareAndSet byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (byte)0x23, "weakCompareAndSet byte value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(array, i, (byte)0x23, (byte)0x01); + } + assertEquals(success, true, "weakCompareAndSetAcquire byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (byte)0x01, "weakCompareAndSetAcquire byte"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(array, i, (byte)0x01, (byte)0x23); + } + assertEquals(success, true, "weakCompareAndSetRelease byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (byte)0x23, "weakCompareAndSetRelease byte"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(array, i, (byte)0x23, (byte)0x01); + } + assertEquals(success, true, "weakCompareAndSetVolatile byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (byte)0x01, "weakCompareAndSetVolatile byte"); + } + + // Compare set and get + { + byte o = (byte) hs.get(TestAccessMode.GET_AND_SET).invokeExact(array, i, (byte)0x23); + assertEquals(o, (byte)0x01, "getAndSet byte"); + byte x = (byte) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (byte)0x23, "getAndSet byte value"); + } + + hs.get(TestAccessMode.SET).invokeExact(array, i, (byte)0x01); + + // get and add, add and get + { + byte o = (byte) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(array, i, (byte)0x45); + assertEquals(o, (byte)0x01, "getAndAdd byte"); + byte c = (byte) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(array, i, (byte)0x45); + assertEquals(c, (byte)((byte)0x01 + (byte)0x45 + (byte)0x45), "getAndAdd byte value"); + } } } @@ -279,29 +580,7 @@ public class VarHandleTestMethodHandleAccessByte extends VarHandleBaseTest { byte[] array = new byte[10]; final int i = 0; - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(array, i, (byte)1, (byte)2); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - byte r = (byte) hs.get(am).invokeExact(array, i, (byte)1, (byte)2); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - byte r = (byte) hs.get(am).invokeExact(array, i, (byte)1); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - byte o = (byte) hs.get(am).invokeExact(array, i, (byte)1); - }); - } } static void testArrayIndexOutOfBounds(Handles hs) throws Throwable { @@ -318,11 +597,33 @@ public class VarHandleTestMethodHandleAccessByte extends VarHandleBaseTest { for (TestAccessMode am : testAccessModesOfType(TestAccessType.SET)) { checkIOOBE(am, () -> { - hs.get(am).invokeExact(array, ci, (byte)1); + hs.get(am).invokeExact(array, ci, (byte)0x01); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + checkIOOBE(am, () -> { + boolean r = (boolean) hs.get(am).invokeExact(array, ci, (byte)0x01, (byte)0x23); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + checkIOOBE(am, () -> { + byte r = (byte) hs.get(am).invokeExact(array, ci, (byte)0x23, (byte)0x01); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + checkIOOBE(am, () -> { + byte o = (byte) hs.get(am).invokeExact(array, ci, (byte)0x01); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + checkIOOBE(am, () -> { + byte o = (byte) hs.get(am).invokeExact(array, ci, (byte)0x45); + }); + } } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessChar.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessChar.java index fb1f3877342..1f2e5ee10c6 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessChar.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessChar.java @@ -39,11 +39,11 @@ import java.util.List; import static org.testng.Assert.*; public class VarHandleTestMethodHandleAccessChar extends VarHandleBaseTest { - static final char static_final_v = 'a'; + static final char static_final_v = '\u0123'; static char static_v; - final char final_v = 'a'; + final char final_v = '\u0123'; char v; @@ -121,120 +121,306 @@ public class VarHandleTestMethodHandleAccessChar extends VarHandleBaseTest { static void testInstanceField(VarHandleTestMethodHandleAccessChar recv, Handles hs) throws Throwable { // Plain { - hs.get(TestAccessMode.SET).invokeExact(recv, 'a'); + hs.get(TestAccessMode.SET).invokeExact(recv, '\u0123'); char x = (char) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 'a', "set char value"); + assertEquals(x, '\u0123', "set char value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact(recv, 'b'); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact(recv, '\u4567'); char x = (char) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(recv); - assertEquals(x, 'b', "setVolatile char value"); + assertEquals(x, '\u4567', "setVolatile char value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact(recv, 'a'); + hs.get(TestAccessMode.SET_RELEASE).invokeExact(recv, '\u0123'); char x = (char) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(recv); - assertEquals(x, 'a', "setRelease char value"); + assertEquals(x, '\u0123', "setRelease char value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact(recv, 'b'); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact(recv, '\u4567'); char x = (char) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(recv); - assertEquals(x, 'b', "setOpaque char value"); + assertEquals(x, '\u4567', "setOpaque char value"); } + hs.get(TestAccessMode.SET).invokeExact(recv, '\u0123'); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, '\u0123', '\u4567'); + assertEquals(r, true, "success compareAndSet char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, '\u4567', "success compareAndSet char value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, '\u0123', '\u89AB'); + assertEquals(r, false, "failing compareAndSet char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, '\u4567', "failing compareAndSet char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, '\u4567', '\u0123'); + assertEquals(r, '\u4567', "success compareAndExchange char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, '\u0123', "success compareAndExchange char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, '\u4567', '\u89AB'); + assertEquals(r, '\u0123', "failing compareAndExchange char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, '\u0123', "failing compareAndExchange char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, '\u0123', '\u4567'); + assertEquals(r, '\u0123', "success compareAndExchangeAcquire char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, '\u4567', "success compareAndExchangeAcquire char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, '\u0123', '\u89AB'); + assertEquals(r, '\u4567', "failing compareAndExchangeAcquire char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, '\u4567', "failing compareAndExchangeAcquire char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, '\u4567', '\u0123'); + assertEquals(r, '\u4567', "success compareAndExchangeRelease char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, '\u0123', "success compareAndExchangeRelease char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, '\u4567', '\u89AB'); + assertEquals(r, '\u0123', "failing compareAndExchangeRelease char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, '\u0123', "failing compareAndExchangeRelease char value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(recv, '\u0123', '\u4567'); + } + assertEquals(success, true, "weakCompareAndSet char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, '\u4567', "weakCompareAndSet char value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(recv, '\u4567', '\u0123'); + } + assertEquals(success, true, "weakCompareAndSetAcquire char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, '\u0123', "weakCompareAndSetAcquire char"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(recv, '\u0123', '\u4567'); + } + assertEquals(success, true, "weakCompareAndSetRelease char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, '\u4567', "weakCompareAndSetRelease char"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(recv, '\u4567', '\u0123'); + } + assertEquals(success, true, "weakCompareAndSetVolatile char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, '\u0123', "weakCompareAndSetVolatile char"); + } + + // Compare set and get + { + char o = (char) hs.get(TestAccessMode.GET_AND_SET).invokeExact(recv, '\u4567'); + assertEquals(o, '\u0123', "getAndSet char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, '\u4567', "getAndSet char value"); + } + + hs.get(TestAccessMode.SET).invokeExact(recv, '\u0123'); + + // get and add, add and get + { + char o = (char) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(recv, '\u89AB'); + assertEquals(o, '\u0123', "getAndAdd char"); + char c = (char) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(recv, '\u89AB'); + assertEquals(c, (char)('\u0123' + '\u89AB' + '\u89AB'), "getAndAdd char value"); + } } static void testInstanceFieldUnsupported(VarHandleTestMethodHandleAccessChar recv, Handles hs) throws Throwable { - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(recv, 'a', 'b'); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - char r = (char) hs.get(am).invokeExact(recv, 'a', 'b'); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - char r = (char) hs.get(am).invokeExact(recv, 'a'); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - char r = (char) hs.get(am).invokeExact(recv, 'a'); - }); - } } static void testStaticField(Handles hs) throws Throwable { // Plain { - hs.get(TestAccessMode.SET).invokeExact('a'); + hs.get(TestAccessMode.SET).invokeExact('\u0123'); char x = (char) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 'a', "set char value"); + assertEquals(x, '\u0123', "set char value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact('b'); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact('\u4567'); char x = (char) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(); - assertEquals(x, 'b', "setVolatile char value"); + assertEquals(x, '\u4567', "setVolatile char value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact('a'); + hs.get(TestAccessMode.SET_RELEASE).invokeExact('\u0123'); char x = (char) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(); - assertEquals(x, 'a', "setRelease char value"); + assertEquals(x, '\u0123', "setRelease char value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact('b'); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact('\u4567'); char x = (char) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(); - assertEquals(x, 'b', "setOpaque char value"); + assertEquals(x, '\u4567', "setOpaque char value"); } + hs.get(TestAccessMode.SET).invokeExact('\u0123'); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact('\u0123', '\u4567'); + assertEquals(r, true, "success compareAndSet char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, '\u4567', "success compareAndSet char value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact('\u0123', '\u89AB'); + assertEquals(r, false, "failing compareAndSet char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, '\u4567', "failing compareAndSet char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact('\u4567', '\u0123'); + assertEquals(r, '\u4567', "success compareAndExchange char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, '\u0123', "success compareAndExchange char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact('\u4567', '\u89AB'); + assertEquals(r, '\u0123', "failing compareAndExchange char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, '\u0123', "failing compareAndExchange char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact('\u0123', '\u4567'); + assertEquals(r, '\u0123', "success compareAndExchangeAcquire char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, '\u4567', "success compareAndExchangeAcquire char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact('\u0123', '\u89AB'); + assertEquals(r, '\u4567', "failing compareAndExchangeAcquire char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, '\u4567', "failing compareAndExchangeAcquire char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact('\u4567', '\u0123'); + assertEquals(r, '\u4567', "success compareAndExchangeRelease char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, '\u0123', "success compareAndExchangeRelease char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact('\u4567', '\u89AB'); + assertEquals(r, '\u0123', "failing compareAndExchangeRelease char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, '\u0123', "failing compareAndExchangeRelease char value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact('\u0123', '\u4567'); + } + assertEquals(success, true, "weakCompareAndSet char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, '\u4567', "weakCompareAndSet char value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact('\u4567', '\u0123'); + } + assertEquals(success, true, "weakCompareAndSetAcquire char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, '\u0123', "weakCompareAndSetAcquire char"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact('\u0123', '\u4567'); + } + assertEquals(success, true, "weakCompareAndSetRelease char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, '\u4567', "weakCompareAndSetRelease char"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact('\u4567', '\u0123'); + } + assertEquals(success, true, "weakCompareAndSetVolatile char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, '\u0123', "weakCompareAndSetVolatile char"); + } + + // Compare set and get + { + char o = (char) hs.get(TestAccessMode.GET_AND_SET).invokeExact( '\u4567'); + assertEquals(o, '\u0123', "getAndSet char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, '\u4567', "getAndSet char value"); + } + + hs.get(TestAccessMode.SET).invokeExact('\u0123'); + + // get and add, add and get + { + char o = (char) hs.get(TestAccessMode.GET_AND_ADD).invokeExact( '\u89AB'); + assertEquals(o, '\u0123', "getAndAdd char"); + char c = (char) hs.get(TestAccessMode.ADD_AND_GET).invokeExact('\u89AB'); + assertEquals(c, (char)('\u0123' + '\u89AB' + '\u89AB'), "getAndAdd char value"); + } } static void testStaticFieldUnsupported(Handles hs) throws Throwable { - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact('a', 'b'); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - char r = (char) hs.get(am).invokeExact('a', 'b'); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - char r = (char) hs.get(am).invokeExact('a'); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - char r = (char) hs.get(am).invokeExact('a'); - }); - } } @@ -244,34 +430,149 @@ public class VarHandleTestMethodHandleAccessChar extends VarHandleBaseTest { for (int i = 0; i < array.length; i++) { // Plain { - hs.get(TestAccessMode.SET).invokeExact(array, i, 'a'); + hs.get(TestAccessMode.SET).invokeExact(array, i, '\u0123'); char x = (char) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 'a', "get char value"); + assertEquals(x, '\u0123', "get char value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact(array, i, 'b'); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact(array, i, '\u4567'); char x = (char) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(array, i); - assertEquals(x, 'b', "setVolatile char value"); + assertEquals(x, '\u4567', "setVolatile char value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact(array, i, 'a'); + hs.get(TestAccessMode.SET_RELEASE).invokeExact(array, i, '\u0123'); char x = (char) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(array, i); - assertEquals(x, 'a', "setRelease char value"); + assertEquals(x, '\u0123', "setRelease char value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact(array, i, 'b'); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact(array, i, '\u4567'); char x = (char) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(array, i); - assertEquals(x, 'b', "setOpaque char value"); + assertEquals(x, '\u4567', "setOpaque char value"); } + hs.get(TestAccessMode.SET).invokeExact(array, i, '\u0123'); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, '\u0123', '\u4567'); + assertEquals(r, true, "success compareAndSet char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, '\u4567', "success compareAndSet char value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, '\u0123', '\u89AB'); + assertEquals(r, false, "failing compareAndSet char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, '\u4567', "failing compareAndSet char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, '\u4567', '\u0123'); + assertEquals(r, '\u4567', "success compareAndExchange char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, '\u0123', "success compareAndExchange char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, '\u4567', '\u89AB'); + assertEquals(r, '\u0123', "failing compareAndExchange char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, '\u0123', "failing compareAndExchange char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, '\u0123', '\u4567'); + assertEquals(r, '\u0123', "success compareAndExchangeAcquire char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, '\u4567', "success compareAndExchangeAcquire char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, '\u0123', '\u89AB'); + assertEquals(r, '\u4567', "failing compareAndExchangeAcquire char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, '\u4567', "failing compareAndExchangeAcquire char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, '\u4567', '\u0123'); + assertEquals(r, '\u4567', "success compareAndExchangeRelease char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, '\u0123', "success compareAndExchangeRelease char value"); + } + + { + char r = (char) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, '\u4567', '\u89AB'); + assertEquals(r, '\u0123', "failing compareAndExchangeRelease char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, '\u0123', "failing compareAndExchangeRelease char value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(array, i, '\u0123', '\u4567'); + } + assertEquals(success, true, "weakCompareAndSet char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, '\u4567', "weakCompareAndSet char value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(array, i, '\u4567', '\u0123'); + } + assertEquals(success, true, "weakCompareAndSetAcquire char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, '\u0123', "weakCompareAndSetAcquire char"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(array, i, '\u0123', '\u4567'); + } + assertEquals(success, true, "weakCompareAndSetRelease char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, '\u4567', "weakCompareAndSetRelease char"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(array, i, '\u4567', '\u0123'); + } + assertEquals(success, true, "weakCompareAndSetVolatile char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, '\u0123', "weakCompareAndSetVolatile char"); + } + + // Compare set and get + { + char o = (char) hs.get(TestAccessMode.GET_AND_SET).invokeExact(array, i, '\u4567'); + assertEquals(o, '\u0123', "getAndSet char"); + char x = (char) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, '\u4567', "getAndSet char value"); + } + + hs.get(TestAccessMode.SET).invokeExact(array, i, '\u0123'); + + // get and add, add and get + { + char o = (char) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(array, i, '\u89AB'); + assertEquals(o, '\u0123', "getAndAdd char"); + char c = (char) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(array, i, '\u89AB'); + assertEquals(c, (char)('\u0123' + '\u89AB' + '\u89AB'), "getAndAdd char value"); + } } } @@ -279,29 +580,7 @@ public class VarHandleTestMethodHandleAccessChar extends VarHandleBaseTest { char[] array = new char[10]; final int i = 0; - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(array, i, 'a', 'b'); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - char r = (char) hs.get(am).invokeExact(array, i, 'a', 'b'); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - char r = (char) hs.get(am).invokeExact(array, i, 'a'); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - char o = (char) hs.get(am).invokeExact(array, i, 'a'); - }); - } } static void testArrayIndexOutOfBounds(Handles hs) throws Throwable { @@ -318,11 +597,33 @@ public class VarHandleTestMethodHandleAccessChar extends VarHandleBaseTest { for (TestAccessMode am : testAccessModesOfType(TestAccessType.SET)) { checkIOOBE(am, () -> { - hs.get(am).invokeExact(array, ci, 'a'); + hs.get(am).invokeExact(array, ci, '\u0123'); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + checkIOOBE(am, () -> { + boolean r = (boolean) hs.get(am).invokeExact(array, ci, '\u0123', '\u4567'); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + checkIOOBE(am, () -> { + char r = (char) hs.get(am).invokeExact(array, ci, '\u4567', '\u0123'); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + checkIOOBE(am, () -> { + char o = (char) hs.get(am).invokeExact(array, ci, '\u0123'); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + checkIOOBE(am, () -> { + char o = (char) hs.get(am).invokeExact(array, ci, '\u89AB'); + }); + } } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessDouble.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessDouble.java index cd2c15d04d3..26cb426ab81 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessDouble.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessDouble.java @@ -148,33 +148,126 @@ public class VarHandleTestMethodHandleAccessDouble extends VarHandleBaseTest { assertEquals(x, 2.0d, "setOpaque double value"); } + hs.get(TestAccessMode.SET).invokeExact(recv, 1.0d); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, 1.0d, 2.0d); + assertEquals(r, true, "success compareAndSet double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 2.0d, "success compareAndSet double value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, 1.0d, 3.0d); + assertEquals(r, false, "failing compareAndSet double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 2.0d, "failing compareAndSet double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, 2.0d, 1.0d); + assertEquals(r, 2.0d, "success compareAndExchange double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 1.0d, "success compareAndExchange double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, 2.0d, 3.0d); + assertEquals(r, 1.0d, "failing compareAndExchange double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 1.0d, "failing compareAndExchange double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, 1.0d, 2.0d); + assertEquals(r, 1.0d, "success compareAndExchangeAcquire double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 2.0d, "success compareAndExchangeAcquire double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, 1.0d, 3.0d); + assertEquals(r, 2.0d, "failing compareAndExchangeAcquire double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 2.0d, "failing compareAndExchangeAcquire double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, 2.0d, 1.0d); + assertEquals(r, 2.0d, "success compareAndExchangeRelease double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 1.0d, "success compareAndExchangeRelease double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, 2.0d, 3.0d); + assertEquals(r, 1.0d, "failing compareAndExchangeRelease double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 1.0d, "failing compareAndExchangeRelease double value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(recv, 1.0d, 2.0d); + } + assertEquals(success, true, "weakCompareAndSet double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 2.0d, "weakCompareAndSet double value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(recv, 2.0d, 1.0d); + } + assertEquals(success, true, "weakCompareAndSetAcquire double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 1.0d, "weakCompareAndSetAcquire double"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(recv, 1.0d, 2.0d); + } + assertEquals(success, true, "weakCompareAndSetRelease double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 2.0d, "weakCompareAndSetRelease double"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(recv, 2.0d, 1.0d); + } + assertEquals(success, true, "weakCompareAndSetVolatile double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 1.0d, "weakCompareAndSetVolatile double"); + } + + // Compare set and get + { + double o = (double) hs.get(TestAccessMode.GET_AND_SET).invokeExact(recv, 2.0d); + assertEquals(o, 1.0d, "getAndSet double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 2.0d, "getAndSet double value"); + } + + hs.get(TestAccessMode.SET).invokeExact(recv, 1.0d); + + // get and add, add and get + { + double o = (double) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(recv, 3.0d); + assertEquals(o, 1.0d, "getAndAdd double"); + double c = (double) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(recv, 3.0d); + assertEquals(c, (double)(1.0d + 3.0d + 3.0d), "getAndAdd double value"); + } } static void testInstanceFieldUnsupported(VarHandleTestMethodHandleAccessDouble recv, Handles hs) throws Throwable { - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(recv, 1.0d, 2.0d); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - double r = (double) hs.get(am).invokeExact(recv, 1.0d, 2.0d); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - double r = (double) hs.get(am).invokeExact(recv, 1.0d); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - double r = (double) hs.get(am).invokeExact(recv, 1.0d); - }); - } } @@ -208,33 +301,126 @@ public class VarHandleTestMethodHandleAccessDouble extends VarHandleBaseTest { assertEquals(x, 2.0d, "setOpaque double value"); } + hs.get(TestAccessMode.SET).invokeExact(1.0d); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(1.0d, 2.0d); + assertEquals(r, true, "success compareAndSet double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 2.0d, "success compareAndSet double value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(1.0d, 3.0d); + assertEquals(r, false, "failing compareAndSet double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 2.0d, "failing compareAndSet double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(2.0d, 1.0d); + assertEquals(r, 2.0d, "success compareAndExchange double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 1.0d, "success compareAndExchange double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(2.0d, 3.0d); + assertEquals(r, 1.0d, "failing compareAndExchange double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 1.0d, "failing compareAndExchange double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(1.0d, 2.0d); + assertEquals(r, 1.0d, "success compareAndExchangeAcquire double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 2.0d, "success compareAndExchangeAcquire double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(1.0d, 3.0d); + assertEquals(r, 2.0d, "failing compareAndExchangeAcquire double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 2.0d, "failing compareAndExchangeAcquire double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(2.0d, 1.0d); + assertEquals(r, 2.0d, "success compareAndExchangeRelease double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 1.0d, "success compareAndExchangeRelease double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(2.0d, 3.0d); + assertEquals(r, 1.0d, "failing compareAndExchangeRelease double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 1.0d, "failing compareAndExchangeRelease double value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(1.0d, 2.0d); + } + assertEquals(success, true, "weakCompareAndSet double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 2.0d, "weakCompareAndSet double value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(2.0d, 1.0d); + } + assertEquals(success, true, "weakCompareAndSetAcquire double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 1.0d, "weakCompareAndSetAcquire double"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(1.0d, 2.0d); + } + assertEquals(success, true, "weakCompareAndSetRelease double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 2.0d, "weakCompareAndSetRelease double"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(2.0d, 1.0d); + } + assertEquals(success, true, "weakCompareAndSetVolatile double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 1.0d, "weakCompareAndSetVolatile double"); + } + + // Compare set and get + { + double o = (double) hs.get(TestAccessMode.GET_AND_SET).invokeExact( 2.0d); + assertEquals(o, 1.0d, "getAndSet double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 2.0d, "getAndSet double value"); + } + + hs.get(TestAccessMode.SET).invokeExact(1.0d); + + // get and add, add and get + { + double o = (double) hs.get(TestAccessMode.GET_AND_ADD).invokeExact( 3.0d); + assertEquals(o, 1.0d, "getAndAdd double"); + double c = (double) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(3.0d); + assertEquals(c, (double)(1.0d + 3.0d + 3.0d), "getAndAdd double value"); + } } static void testStaticFieldUnsupported(Handles hs) throws Throwable { - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(1.0d, 2.0d); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - double r = (double) hs.get(am).invokeExact(1.0d, 2.0d); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - double r = (double) hs.get(am).invokeExact(1.0d); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - double r = (double) hs.get(am).invokeExact(1.0d); - }); - } } @@ -271,7 +457,122 @@ public class VarHandleTestMethodHandleAccessDouble extends VarHandleBaseTest { assertEquals(x, 2.0d, "setOpaque double value"); } + hs.get(TestAccessMode.SET).invokeExact(array, i, 1.0d); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, 1.0d, 2.0d); + assertEquals(r, true, "success compareAndSet double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 2.0d, "success compareAndSet double value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, 1.0d, 3.0d); + assertEquals(r, false, "failing compareAndSet double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 2.0d, "failing compareAndSet double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, 2.0d, 1.0d); + assertEquals(r, 2.0d, "success compareAndExchange double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 1.0d, "success compareAndExchange double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, 2.0d, 3.0d); + assertEquals(r, 1.0d, "failing compareAndExchange double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 1.0d, "failing compareAndExchange double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, 1.0d, 2.0d); + assertEquals(r, 1.0d, "success compareAndExchangeAcquire double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 2.0d, "success compareAndExchangeAcquire double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, 1.0d, 3.0d); + assertEquals(r, 2.0d, "failing compareAndExchangeAcquire double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 2.0d, "failing compareAndExchangeAcquire double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, 2.0d, 1.0d); + assertEquals(r, 2.0d, "success compareAndExchangeRelease double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 1.0d, "success compareAndExchangeRelease double value"); + } + + { + double r = (double) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, 2.0d, 3.0d); + assertEquals(r, 1.0d, "failing compareAndExchangeRelease double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 1.0d, "failing compareAndExchangeRelease double value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(array, i, 1.0d, 2.0d); + } + assertEquals(success, true, "weakCompareAndSet double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 2.0d, "weakCompareAndSet double value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(array, i, 2.0d, 1.0d); + } + assertEquals(success, true, "weakCompareAndSetAcquire double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 1.0d, "weakCompareAndSetAcquire double"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(array, i, 1.0d, 2.0d); + } + assertEquals(success, true, "weakCompareAndSetRelease double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 2.0d, "weakCompareAndSetRelease double"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(array, i, 2.0d, 1.0d); + } + assertEquals(success, true, "weakCompareAndSetVolatile double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 1.0d, "weakCompareAndSetVolatile double"); + } + + // Compare set and get + { + double o = (double) hs.get(TestAccessMode.GET_AND_SET).invokeExact(array, i, 2.0d); + assertEquals(o, 1.0d, "getAndSet double"); + double x = (double) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 2.0d, "getAndSet double value"); + } + + hs.get(TestAccessMode.SET).invokeExact(array, i, 1.0d); + + // get and add, add and get + { + double o = (double) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(array, i, 3.0d); + assertEquals(o, 1.0d, "getAndAdd double"); + double c = (double) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(array, i, 3.0d); + assertEquals(c, (double)(1.0d + 3.0d + 3.0d), "getAndAdd double value"); + } } } @@ -279,29 +580,7 @@ public class VarHandleTestMethodHandleAccessDouble extends VarHandleBaseTest { double[] array = new double[10]; final int i = 0; - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(array, i, 1.0d, 2.0d); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - double r = (double) hs.get(am).invokeExact(array, i, 1.0d, 2.0d); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - double r = (double) hs.get(am).invokeExact(array, i, 1.0d); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - double o = (double) hs.get(am).invokeExact(array, i, 1.0d); - }); - } } static void testArrayIndexOutOfBounds(Handles hs) throws Throwable { @@ -322,7 +601,29 @@ public class VarHandleTestMethodHandleAccessDouble extends VarHandleBaseTest { }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + checkIOOBE(am, () -> { + boolean r = (boolean) hs.get(am).invokeExact(array, ci, 1.0d, 2.0d); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + checkIOOBE(am, () -> { + double r = (double) hs.get(am).invokeExact(array, ci, 2.0d, 1.0d); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + checkIOOBE(am, () -> { + double o = (double) hs.get(am).invokeExact(array, ci, 1.0d); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + checkIOOBE(am, () -> { + double o = (double) hs.get(am).invokeExact(array, ci, 3.0d); + }); + } } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessFloat.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessFloat.java index 58d9e295298..d28e2f41b6e 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessFloat.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessFloat.java @@ -148,33 +148,126 @@ public class VarHandleTestMethodHandleAccessFloat extends VarHandleBaseTest { assertEquals(x, 2.0f, "setOpaque float value"); } + hs.get(TestAccessMode.SET).invokeExact(recv, 1.0f); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, 1.0f, 2.0f); + assertEquals(r, true, "success compareAndSet float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 2.0f, "success compareAndSet float value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, 1.0f, 3.0f); + assertEquals(r, false, "failing compareAndSet float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 2.0f, "failing compareAndSet float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, 2.0f, 1.0f); + assertEquals(r, 2.0f, "success compareAndExchange float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 1.0f, "success compareAndExchange float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, 2.0f, 3.0f); + assertEquals(r, 1.0f, "failing compareAndExchange float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 1.0f, "failing compareAndExchange float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, 1.0f, 2.0f); + assertEquals(r, 1.0f, "success compareAndExchangeAcquire float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 2.0f, "success compareAndExchangeAcquire float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, 1.0f, 3.0f); + assertEquals(r, 2.0f, "failing compareAndExchangeAcquire float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 2.0f, "failing compareAndExchangeAcquire float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, 2.0f, 1.0f); + assertEquals(r, 2.0f, "success compareAndExchangeRelease float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 1.0f, "success compareAndExchangeRelease float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, 2.0f, 3.0f); + assertEquals(r, 1.0f, "failing compareAndExchangeRelease float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 1.0f, "failing compareAndExchangeRelease float value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(recv, 1.0f, 2.0f); + } + assertEquals(success, true, "weakCompareAndSet float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 2.0f, "weakCompareAndSet float value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(recv, 2.0f, 1.0f); + } + assertEquals(success, true, "weakCompareAndSetAcquire float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 1.0f, "weakCompareAndSetAcquire float"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(recv, 1.0f, 2.0f); + } + assertEquals(success, true, "weakCompareAndSetRelease float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 2.0f, "weakCompareAndSetRelease float"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(recv, 2.0f, 1.0f); + } + assertEquals(success, true, "weakCompareAndSetVolatile float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 1.0f, "weakCompareAndSetVolatile float"); + } + + // Compare set and get + { + float o = (float) hs.get(TestAccessMode.GET_AND_SET).invokeExact(recv, 2.0f); + assertEquals(o, 1.0f, "getAndSet float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, 2.0f, "getAndSet float value"); + } + + hs.get(TestAccessMode.SET).invokeExact(recv, 1.0f); + + // get and add, add and get + { + float o = (float) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(recv, 3.0f); + assertEquals(o, 1.0f, "getAndAdd float"); + float c = (float) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(recv, 3.0f); + assertEquals(c, (float)(1.0f + 3.0f + 3.0f), "getAndAdd float value"); + } } static void testInstanceFieldUnsupported(VarHandleTestMethodHandleAccessFloat recv, Handles hs) throws Throwable { - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(recv, 1.0f, 2.0f); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - float r = (float) hs.get(am).invokeExact(recv, 1.0f, 2.0f); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - float r = (float) hs.get(am).invokeExact(recv, 1.0f); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - float r = (float) hs.get(am).invokeExact(recv, 1.0f); - }); - } } @@ -208,33 +301,126 @@ public class VarHandleTestMethodHandleAccessFloat extends VarHandleBaseTest { assertEquals(x, 2.0f, "setOpaque float value"); } + hs.get(TestAccessMode.SET).invokeExact(1.0f); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(1.0f, 2.0f); + assertEquals(r, true, "success compareAndSet float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 2.0f, "success compareAndSet float value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(1.0f, 3.0f); + assertEquals(r, false, "failing compareAndSet float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 2.0f, "failing compareAndSet float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(2.0f, 1.0f); + assertEquals(r, 2.0f, "success compareAndExchange float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 1.0f, "success compareAndExchange float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(2.0f, 3.0f); + assertEquals(r, 1.0f, "failing compareAndExchange float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 1.0f, "failing compareAndExchange float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(1.0f, 2.0f); + assertEquals(r, 1.0f, "success compareAndExchangeAcquire float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 2.0f, "success compareAndExchangeAcquire float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(1.0f, 3.0f); + assertEquals(r, 2.0f, "failing compareAndExchangeAcquire float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 2.0f, "failing compareAndExchangeAcquire float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(2.0f, 1.0f); + assertEquals(r, 2.0f, "success compareAndExchangeRelease float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 1.0f, "success compareAndExchangeRelease float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(2.0f, 3.0f); + assertEquals(r, 1.0f, "failing compareAndExchangeRelease float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 1.0f, "failing compareAndExchangeRelease float value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(1.0f, 2.0f); + } + assertEquals(success, true, "weakCompareAndSet float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 2.0f, "weakCompareAndSet float value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(2.0f, 1.0f); + } + assertEquals(success, true, "weakCompareAndSetAcquire float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 1.0f, "weakCompareAndSetAcquire float"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(1.0f, 2.0f); + } + assertEquals(success, true, "weakCompareAndSetRelease float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 2.0f, "weakCompareAndSetRelease float"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(2.0f, 1.0f); + } + assertEquals(success, true, "weakCompareAndSetVolatile float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 1.0f, "weakCompareAndSetVolatile float"); + } + + // Compare set and get + { + float o = (float) hs.get(TestAccessMode.GET_AND_SET).invokeExact( 2.0f); + assertEquals(o, 1.0f, "getAndSet float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, 2.0f, "getAndSet float value"); + } + + hs.get(TestAccessMode.SET).invokeExact(1.0f); + + // get and add, add and get + { + float o = (float) hs.get(TestAccessMode.GET_AND_ADD).invokeExact( 3.0f); + assertEquals(o, 1.0f, "getAndAdd float"); + float c = (float) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(3.0f); + assertEquals(c, (float)(1.0f + 3.0f + 3.0f), "getAndAdd float value"); + } } static void testStaticFieldUnsupported(Handles hs) throws Throwable { - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(1.0f, 2.0f); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - float r = (float) hs.get(am).invokeExact(1.0f, 2.0f); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - float r = (float) hs.get(am).invokeExact(1.0f); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - float r = (float) hs.get(am).invokeExact(1.0f); - }); - } } @@ -271,7 +457,122 @@ public class VarHandleTestMethodHandleAccessFloat extends VarHandleBaseTest { assertEquals(x, 2.0f, "setOpaque float value"); } + hs.get(TestAccessMode.SET).invokeExact(array, i, 1.0f); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, 1.0f, 2.0f); + assertEquals(r, true, "success compareAndSet float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 2.0f, "success compareAndSet float value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, 1.0f, 3.0f); + assertEquals(r, false, "failing compareAndSet float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 2.0f, "failing compareAndSet float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, 2.0f, 1.0f); + assertEquals(r, 2.0f, "success compareAndExchange float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 1.0f, "success compareAndExchange float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, 2.0f, 3.0f); + assertEquals(r, 1.0f, "failing compareAndExchange float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 1.0f, "failing compareAndExchange float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, 1.0f, 2.0f); + assertEquals(r, 1.0f, "success compareAndExchangeAcquire float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 2.0f, "success compareAndExchangeAcquire float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, 1.0f, 3.0f); + assertEquals(r, 2.0f, "failing compareAndExchangeAcquire float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 2.0f, "failing compareAndExchangeAcquire float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, 2.0f, 1.0f); + assertEquals(r, 2.0f, "success compareAndExchangeRelease float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 1.0f, "success compareAndExchangeRelease float value"); + } + + { + float r = (float) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, 2.0f, 3.0f); + assertEquals(r, 1.0f, "failing compareAndExchangeRelease float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 1.0f, "failing compareAndExchangeRelease float value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(array, i, 1.0f, 2.0f); + } + assertEquals(success, true, "weakCompareAndSet float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 2.0f, "weakCompareAndSet float value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(array, i, 2.0f, 1.0f); + } + assertEquals(success, true, "weakCompareAndSetAcquire float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 1.0f, "weakCompareAndSetAcquire float"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(array, i, 1.0f, 2.0f); + } + assertEquals(success, true, "weakCompareAndSetRelease float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 2.0f, "weakCompareAndSetRelease float"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(array, i, 2.0f, 1.0f); + } + assertEquals(success, true, "weakCompareAndSetVolatile float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 1.0f, "weakCompareAndSetVolatile float"); + } + + // Compare set and get + { + float o = (float) hs.get(TestAccessMode.GET_AND_SET).invokeExact(array, i, 2.0f); + assertEquals(o, 1.0f, "getAndSet float"); + float x = (float) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, 2.0f, "getAndSet float value"); + } + + hs.get(TestAccessMode.SET).invokeExact(array, i, 1.0f); + + // get and add, add and get + { + float o = (float) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(array, i, 3.0f); + assertEquals(o, 1.0f, "getAndAdd float"); + float c = (float) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(array, i, 3.0f); + assertEquals(c, (float)(1.0f + 3.0f + 3.0f), "getAndAdd float value"); + } } } @@ -279,29 +580,7 @@ public class VarHandleTestMethodHandleAccessFloat extends VarHandleBaseTest { float[] array = new float[10]; final int i = 0; - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(array, i, 1.0f, 2.0f); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - float r = (float) hs.get(am).invokeExact(array, i, 1.0f, 2.0f); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - float r = (float) hs.get(am).invokeExact(array, i, 1.0f); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - float o = (float) hs.get(am).invokeExact(array, i, 1.0f); - }); - } } static void testArrayIndexOutOfBounds(Handles hs) throws Throwable { @@ -322,7 +601,29 @@ public class VarHandleTestMethodHandleAccessFloat extends VarHandleBaseTest { }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + checkIOOBE(am, () -> { + boolean r = (boolean) hs.get(am).invokeExact(array, ci, 1.0f, 2.0f); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + checkIOOBE(am, () -> { + float r = (float) hs.get(am).invokeExact(array, ci, 2.0f, 1.0f); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + checkIOOBE(am, () -> { + float o = (float) hs.get(am).invokeExact(array, ci, 1.0f); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + checkIOOBE(am, () -> { + float o = (float) hs.get(am).invokeExact(array, ci, 3.0f); + }); + } } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessInt.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessInt.java index 00f78a57159..56954238e27 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessInt.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessInt.java @@ -39,11 +39,11 @@ import java.util.List; import static org.testng.Assert.*; public class VarHandleTestMethodHandleAccessInt extends VarHandleBaseTest { - static final int static_final_v = 1; + static final int static_final_v = 0x01234567; static int static_v; - final int final_v = 1; + final int final_v = 0x01234567; int v; @@ -121,148 +121,148 @@ public class VarHandleTestMethodHandleAccessInt extends VarHandleBaseTest { static void testInstanceField(VarHandleTestMethodHandleAccessInt recv, Handles hs) throws Throwable { // Plain { - hs.get(TestAccessMode.SET).invokeExact(recv, 1); + hs.get(TestAccessMode.SET).invokeExact(recv, 0x01234567); int x = (int) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 1, "set int value"); + assertEquals(x, 0x01234567, "set int value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact(recv, 2); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact(recv, 0x89ABCDEF); int x = (int) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(recv); - assertEquals(x, 2, "setVolatile int value"); + assertEquals(x, 0x89ABCDEF, "setVolatile int value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact(recv, 1); + hs.get(TestAccessMode.SET_RELEASE).invokeExact(recv, 0x01234567); int x = (int) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(recv); - assertEquals(x, 1, "setRelease int value"); + assertEquals(x, 0x01234567, "setRelease int value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact(recv, 2); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact(recv, 0x89ABCDEF); int x = (int) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(recv); - assertEquals(x, 2, "setOpaque int value"); + assertEquals(x, 0x89ABCDEF, "setOpaque int value"); } - hs.get(TestAccessMode.SET).invokeExact(recv, 1); + hs.get(TestAccessMode.SET).invokeExact(recv, 0x01234567); // Compare { - boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, 1, 2); + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, 0x01234567, 0x89ABCDEF); assertEquals(r, true, "success compareAndSet int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 2, "success compareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndSet int value"); } { - boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, 1, 3); + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, 0x01234567, 0xCAFEBABE); assertEquals(r, false, "failing compareAndSet int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 2, "failing compareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndSet int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(recv, 2, 1); - assertEquals(r, 2, "success compareAndExchangeVolatile int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, 0x89ABCDEF, 0x01234567); + assertEquals(r, 0x89ABCDEF, "success compareAndExchange int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 1, "success compareAndExchangeVolatile int value"); + assertEquals(x, 0x01234567, "success compareAndExchange int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(recv, 2, 3); - assertEquals(r, 1, "failing compareAndExchangeVolatile int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, 0x89ABCDEF, 0xCAFEBABE); + assertEquals(r, 0x01234567, "failing compareAndExchange int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 1, "failing compareAndExchangeVolatile int value"); + assertEquals(x, 0x01234567, "failing compareAndExchange int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, 1, 2); - assertEquals(r, 1, "success compareAndExchangeAcquire int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, 0x01234567, 0x89ABCDEF); + assertEquals(r, 0x01234567, "success compareAndExchangeAcquire int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 2, "success compareAndExchangeAcquire int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndExchangeAcquire int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, 1, 3); - assertEquals(r, 2, "failing compareAndExchangeAcquire int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, 0x01234567, 0xCAFEBABE); + assertEquals(r, 0x89ABCDEF, "failing compareAndExchangeAcquire int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 2, "failing compareAndExchangeAcquire int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndExchangeAcquire int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, 2, 1); - assertEquals(r, 2, "success compareAndExchangeRelease int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, 0x89ABCDEF, 0x01234567); + assertEquals(r, 0x89ABCDEF, "success compareAndExchangeRelease int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 1, "success compareAndExchangeRelease int value"); + assertEquals(x, 0x01234567, "success compareAndExchangeRelease int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, 2, 3); - assertEquals(r, 1, "failing compareAndExchangeRelease int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, 0x89ABCDEF, 0xCAFEBABE); + assertEquals(r, 0x01234567, "failing compareAndExchangeRelease int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 1, "failing compareAndExchangeRelease int value"); + assertEquals(x, 0x01234567, "failing compareAndExchangeRelease int value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(recv, 1, 2); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(recv, 0x01234567, 0x89ABCDEF); } assertEquals(success, true, "weakCompareAndSet int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 2, "weakCompareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "weakCompareAndSet int value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(recv, 2, 1); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(recv, 0x89ABCDEF, 0x01234567); } assertEquals(success, true, "weakCompareAndSetAcquire int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 1, "weakCompareAndSetAcquire int"); + assertEquals(x, 0x01234567, "weakCompareAndSetAcquire int"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(recv, 1, 2); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(recv, 0x01234567, 0x89ABCDEF); } assertEquals(success, true, "weakCompareAndSetRelease int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 2, "weakCompareAndSetRelease int"); + assertEquals(x, 0x89ABCDEF, "weakCompareAndSetRelease int"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(recv, 2, 1); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(recv, 0x89ABCDEF, 0x01234567); } assertEquals(success, true, "weakCompareAndSetVolatile int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 1, "weakCompareAndSetVolatile int"); + assertEquals(x, 0x01234567, "weakCompareAndSetVolatile int"); } // Compare set and get { - int o = (int) hs.get(TestAccessMode.GET_AND_SET).invokeExact(recv, 2); - assertEquals(o, 1, "getAndSet int"); + int o = (int) hs.get(TestAccessMode.GET_AND_SET).invokeExact(recv, 0x89ABCDEF); + assertEquals(o, 0x01234567, "getAndSet int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 2, "getAndSet int value"); + assertEquals(x, 0x89ABCDEF, "getAndSet int value"); } - hs.get(TestAccessMode.SET).invokeExact(recv, 1); + hs.get(TestAccessMode.SET).invokeExact(recv, 0x01234567); // get and add, add and get { - int o = (int) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(recv, 3); - assertEquals(o, 1, "getAndAdd int"); - int c = (int) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(recv, 3); - assertEquals(c, 1 + 3 + 3, "getAndAdd int value"); + int o = (int) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(recv, 0xCAFEBABE); + assertEquals(o, 0x01234567, "getAndAdd int"); + int c = (int) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(recv, 0xCAFEBABE); + assertEquals(c, (int)(0x01234567 + 0xCAFEBABE + 0xCAFEBABE), "getAndAdd int value"); } } @@ -274,148 +274,148 @@ public class VarHandleTestMethodHandleAccessInt extends VarHandleBaseTest { static void testStaticField(Handles hs) throws Throwable { // Plain { - hs.get(TestAccessMode.SET).invokeExact(1); + hs.get(TestAccessMode.SET).invokeExact(0x01234567); int x = (int) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 1, "set int value"); + assertEquals(x, 0x01234567, "set int value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact(2); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact(0x89ABCDEF); int x = (int) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(); - assertEquals(x, 2, "setVolatile int value"); + assertEquals(x, 0x89ABCDEF, "setVolatile int value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact(1); + hs.get(TestAccessMode.SET_RELEASE).invokeExact(0x01234567); int x = (int) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(); - assertEquals(x, 1, "setRelease int value"); + assertEquals(x, 0x01234567, "setRelease int value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact(2); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact(0x89ABCDEF); int x = (int) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(); - assertEquals(x, 2, "setOpaque int value"); + assertEquals(x, 0x89ABCDEF, "setOpaque int value"); } - hs.get(TestAccessMode.SET).invokeExact(1); + hs.get(TestAccessMode.SET).invokeExact(0x01234567); // Compare { - boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(1, 2); + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(0x01234567, 0x89ABCDEF); assertEquals(r, true, "success compareAndSet int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 2, "success compareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndSet int value"); } { - boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(1, 3); + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(0x01234567, 0xCAFEBABE); assertEquals(r, false, "failing compareAndSet int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 2, "failing compareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndSet int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(2, 1); - assertEquals(r, 2, "success compareAndExchangeVolatile int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(0x89ABCDEF, 0x01234567); + assertEquals(r, 0x89ABCDEF, "success compareAndExchange int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 1, "success compareAndExchangeVolatile int value"); + assertEquals(x, 0x01234567, "success compareAndExchange int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(2, 3); - assertEquals(r, 1, "failing compareAndExchangeVolatile int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(0x89ABCDEF, 0xCAFEBABE); + assertEquals(r, 0x01234567, "failing compareAndExchange int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 1, "failing compareAndExchangeVolatile int value"); + assertEquals(x, 0x01234567, "failing compareAndExchange int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(1, 2); - assertEquals(r, 1, "success compareAndExchangeAcquire int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(0x01234567, 0x89ABCDEF); + assertEquals(r, 0x01234567, "success compareAndExchangeAcquire int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 2, "success compareAndExchangeAcquire int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndExchangeAcquire int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(1, 3); - assertEquals(r, 2, "failing compareAndExchangeAcquire int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(0x01234567, 0xCAFEBABE); + assertEquals(r, 0x89ABCDEF, "failing compareAndExchangeAcquire int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 2, "failing compareAndExchangeAcquire int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndExchangeAcquire int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(2, 1); - assertEquals(r, 2, "success compareAndExchangeRelease int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(0x89ABCDEF, 0x01234567); + assertEquals(r, 0x89ABCDEF, "success compareAndExchangeRelease int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 1, "success compareAndExchangeRelease int value"); + assertEquals(x, 0x01234567, "success compareAndExchangeRelease int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(2, 3); - assertEquals(r, 1, "failing compareAndExchangeRelease int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(0x89ABCDEF, 0xCAFEBABE); + assertEquals(r, 0x01234567, "failing compareAndExchangeRelease int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 1, "failing compareAndExchangeRelease int value"); + assertEquals(x, 0x01234567, "failing compareAndExchangeRelease int value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(1, 2); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(0x01234567, 0x89ABCDEF); } assertEquals(success, true, "weakCompareAndSet int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 2, "weakCompareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "weakCompareAndSet int value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(2, 1); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(0x89ABCDEF, 0x01234567); } assertEquals(success, true, "weakCompareAndSetAcquire int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 1, "weakCompareAndSetAcquire int"); + assertEquals(x, 0x01234567, "weakCompareAndSetAcquire int"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(1, 2); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(0x01234567, 0x89ABCDEF); } assertEquals(success, true, "weakCompareAndSetRelease int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 2, "weakCompareAndSetRelease int"); + assertEquals(x, 0x89ABCDEF, "weakCompareAndSetRelease int"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(2, 1); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(0x89ABCDEF, 0x01234567); } assertEquals(success, true, "weakCompareAndSetVolatile int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 1, "weakCompareAndSetVolatile int"); + assertEquals(x, 0x01234567, "weakCompareAndSetVolatile int"); } // Compare set and get { - int o = (int) hs.get(TestAccessMode.GET_AND_SET).invokeExact( 2); - assertEquals(o, 1, "getAndSet int"); + int o = (int) hs.get(TestAccessMode.GET_AND_SET).invokeExact( 0x89ABCDEF); + assertEquals(o, 0x01234567, "getAndSet int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 2, "getAndSet int value"); + assertEquals(x, 0x89ABCDEF, "getAndSet int value"); } - hs.get(TestAccessMode.SET).invokeExact(1); + hs.get(TestAccessMode.SET).invokeExact(0x01234567); // get and add, add and get { - int o = (int) hs.get(TestAccessMode.GET_AND_ADD).invokeExact( 3); - assertEquals(o, 1, "getAndAdd int"); - int c = (int) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(3); - assertEquals(c, 1 + 3 + 3, "getAndAdd int value"); + int o = (int) hs.get(TestAccessMode.GET_AND_ADD).invokeExact( 0xCAFEBABE); + assertEquals(o, 0x01234567, "getAndAdd int"); + int c = (int) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(0xCAFEBABE); + assertEquals(c, (int)(0x01234567 + 0xCAFEBABE + 0xCAFEBABE), "getAndAdd int value"); } } @@ -430,148 +430,148 @@ public class VarHandleTestMethodHandleAccessInt extends VarHandleBaseTest { for (int i = 0; i < array.length; i++) { // Plain { - hs.get(TestAccessMode.SET).invokeExact(array, i, 1); + hs.get(TestAccessMode.SET).invokeExact(array, i, 0x01234567); int x = (int) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 1, "get int value"); + assertEquals(x, 0x01234567, "get int value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact(array, i, 2); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact(array, i, 0x89ABCDEF); int x = (int) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(array, i); - assertEquals(x, 2, "setVolatile int value"); + assertEquals(x, 0x89ABCDEF, "setVolatile int value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact(array, i, 1); + hs.get(TestAccessMode.SET_RELEASE).invokeExact(array, i, 0x01234567); int x = (int) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(array, i); - assertEquals(x, 1, "setRelease int value"); + assertEquals(x, 0x01234567, "setRelease int value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact(array, i, 2); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact(array, i, 0x89ABCDEF); int x = (int) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(array, i); - assertEquals(x, 2, "setOpaque int value"); + assertEquals(x, 0x89ABCDEF, "setOpaque int value"); } - hs.get(TestAccessMode.SET).invokeExact(array, i, 1); + hs.get(TestAccessMode.SET).invokeExact(array, i, 0x01234567); // Compare { - boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, 1, 2); + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, 0x01234567, 0x89ABCDEF); assertEquals(r, true, "success compareAndSet int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 2, "success compareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndSet int value"); } { - boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, 1, 3); + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, 0x01234567, 0xCAFEBABE); assertEquals(r, false, "failing compareAndSet int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 2, "failing compareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndSet int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(array, i, 2, 1); - assertEquals(r, 2, "success compareAndExchangeVolatile int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, 0x89ABCDEF, 0x01234567); + assertEquals(r, 0x89ABCDEF, "success compareAndExchange int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 1, "success compareAndExchangeVolatile int value"); + assertEquals(x, 0x01234567, "success compareAndExchange int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(array, i, 2, 3); - assertEquals(r, 1, "failing compareAndExchangeVolatile int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, 0x89ABCDEF, 0xCAFEBABE); + assertEquals(r, 0x01234567, "failing compareAndExchange int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 1, "failing compareAndExchangeVolatile int value"); + assertEquals(x, 0x01234567, "failing compareAndExchange int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, 1, 2); - assertEquals(r, 1, "success compareAndExchangeAcquire int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, 0x01234567, 0x89ABCDEF); + assertEquals(r, 0x01234567, "success compareAndExchangeAcquire int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 2, "success compareAndExchangeAcquire int value"); + assertEquals(x, 0x89ABCDEF, "success compareAndExchangeAcquire int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, 1, 3); - assertEquals(r, 2, "failing compareAndExchangeAcquire int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, 0x01234567, 0xCAFEBABE); + assertEquals(r, 0x89ABCDEF, "failing compareAndExchangeAcquire int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 2, "failing compareAndExchangeAcquire int value"); + assertEquals(x, 0x89ABCDEF, "failing compareAndExchangeAcquire int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, 2, 1); - assertEquals(r, 2, "success compareAndExchangeRelease int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, 0x89ABCDEF, 0x01234567); + assertEquals(r, 0x89ABCDEF, "success compareAndExchangeRelease int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 1, "success compareAndExchangeRelease int value"); + assertEquals(x, 0x01234567, "success compareAndExchangeRelease int value"); } { - int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, 2, 3); - assertEquals(r, 1, "failing compareAndExchangeRelease int"); + int r = (int) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, 0x89ABCDEF, 0xCAFEBABE); + assertEquals(r, 0x01234567, "failing compareAndExchangeRelease int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 1, "failing compareAndExchangeRelease int value"); + assertEquals(x, 0x01234567, "failing compareAndExchangeRelease int value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(array, i, 1, 2); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(array, i, 0x01234567, 0x89ABCDEF); } assertEquals(success, true, "weakCompareAndSet int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 2, "weakCompareAndSet int value"); + assertEquals(x, 0x89ABCDEF, "weakCompareAndSet int value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(array, i, 2, 1); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(array, i, 0x89ABCDEF, 0x01234567); } assertEquals(success, true, "weakCompareAndSetAcquire int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 1, "weakCompareAndSetAcquire int"); + assertEquals(x, 0x01234567, "weakCompareAndSetAcquire int"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(array, i, 1, 2); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(array, i, 0x01234567, 0x89ABCDEF); } assertEquals(success, true, "weakCompareAndSetRelease int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 2, "weakCompareAndSetRelease int"); + assertEquals(x, 0x89ABCDEF, "weakCompareAndSetRelease int"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(array, i, 2, 1); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(array, i, 0x89ABCDEF, 0x01234567); } assertEquals(success, true, "weakCompareAndSetVolatile int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 1, "weakCompareAndSetVolatile int"); + assertEquals(x, 0x01234567, "weakCompareAndSetVolatile int"); } // Compare set and get { - int o = (int) hs.get(TestAccessMode.GET_AND_SET).invokeExact(array, i, 2); - assertEquals(o, 1, "getAndSet int"); + int o = (int) hs.get(TestAccessMode.GET_AND_SET).invokeExact(array, i, 0x89ABCDEF); + assertEquals(o, 0x01234567, "getAndSet int"); int x = (int) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 2, "getAndSet int value"); + assertEquals(x, 0x89ABCDEF, "getAndSet int value"); } - hs.get(TestAccessMode.SET).invokeExact(array, i, 1); + hs.get(TestAccessMode.SET).invokeExact(array, i, 0x01234567); // get and add, add and get { - int o = (int) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(array, i, 3); - assertEquals(o, 1, "getAndAdd int"); - int c = (int) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(array, i, 3); - assertEquals(c, 1 + 3 + 3, "getAndAdd int value"); + int o = (int) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(array, i, 0xCAFEBABE); + assertEquals(o, 0x01234567, "getAndAdd int"); + int c = (int) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(array, i, 0xCAFEBABE); + assertEquals(c, (int)(0x01234567 + 0xCAFEBABE + 0xCAFEBABE), "getAndAdd int value"); } } } @@ -597,31 +597,31 @@ public class VarHandleTestMethodHandleAccessInt extends VarHandleBaseTest { for (TestAccessMode am : testAccessModesOfType(TestAccessType.SET)) { checkIOOBE(am, () -> { - hs.get(am).invokeExact(array, ci, 1); + hs.get(am).invokeExact(array, ci, 0x01234567); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { checkIOOBE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(array, ci, 1, 2); + boolean r = (boolean) hs.get(am).invokeExact(array, ci, 0x01234567, 0x89ABCDEF); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { checkIOOBE(am, () -> { - int r = (int) hs.get(am).invokeExact(array, ci, 2, 1); + int r = (int) hs.get(am).invokeExact(array, ci, 0x89ABCDEF, 0x01234567); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { checkIOOBE(am, () -> { - int o = (int) hs.get(am).invokeExact(array, ci, 1); + int o = (int) hs.get(am).invokeExact(array, ci, 0x01234567); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { checkIOOBE(am, () -> { - int o = (int) hs.get(am).invokeExact(array, ci, 3); + int o = (int) hs.get(am).invokeExact(array, ci, 0xCAFEBABE); }); } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessLong.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessLong.java index 2bb8b9a1ee8..848da74e166 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessLong.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessLong.java @@ -39,11 +39,11 @@ import java.util.List; import static org.testng.Assert.*; public class VarHandleTestMethodHandleAccessLong extends VarHandleBaseTest { - static final long static_final_v = 1L; + static final long static_final_v = 0x0123456789ABCDEFL; static long static_v; - final long final_v = 1L; + final long final_v = 0x0123456789ABCDEFL; long v; @@ -121,148 +121,148 @@ public class VarHandleTestMethodHandleAccessLong extends VarHandleBaseTest { static void testInstanceField(VarHandleTestMethodHandleAccessLong recv, Handles hs) throws Throwable { // Plain { - hs.get(TestAccessMode.SET).invokeExact(recv, 1L); + hs.get(TestAccessMode.SET).invokeExact(recv, 0x0123456789ABCDEFL); long x = (long) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 1L, "set long value"); + assertEquals(x, 0x0123456789ABCDEFL, "set long value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact(recv, 2L); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact(recv, 0xCAFEBABECAFEBABEL); long x = (long) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(recv); - assertEquals(x, 2L, "setVolatile long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "setVolatile long value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact(recv, 1L); + hs.get(TestAccessMode.SET_RELEASE).invokeExact(recv, 0x0123456789ABCDEFL); long x = (long) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(recv); - assertEquals(x, 1L, "setRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "setRelease long value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact(recv, 2L); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact(recv, 0xCAFEBABECAFEBABEL); long x = (long) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(recv); - assertEquals(x, 2L, "setOpaque long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "setOpaque long value"); } - hs.get(TestAccessMode.SET).invokeExact(recv, 1L); + hs.get(TestAccessMode.SET).invokeExact(recv, 0x0123456789ABCDEFL); // Compare { - boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, 1L, 2L); + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); assertEquals(r, true, "success compareAndSet long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 2L, "success compareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndSet long value"); } { - boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, 1L, 3L); + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, 0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); assertEquals(r, false, "failing compareAndSet long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 2L, "failing compareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndSet long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(recv, 2L, 1L); - assertEquals(r, 2L, "success compareAndExchangeVolatile long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "success compareAndExchange long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 1L, "success compareAndExchangeVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "success compareAndExchange long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(recv, 2L, 3L); - assertEquals(r, 1L, "failing compareAndExchangeVolatile long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, 0xCAFEBABECAFEBABEL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0x0123456789ABCDEFL, "failing compareAndExchange long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 1L, "failing compareAndExchangeVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "failing compareAndExchange long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, 1L, 2L); - assertEquals(r, 1L, "success compareAndExchangeAcquire long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); + assertEquals(r, 0x0123456789ABCDEFL, "success compareAndExchangeAcquire long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 2L, "success compareAndExchangeAcquire long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndExchangeAcquire long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, 1L, 3L); - assertEquals(r, 2L, "failing compareAndExchangeAcquire long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, 0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "failing compareAndExchangeAcquire long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 2L, "failing compareAndExchangeAcquire long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndExchangeAcquire long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, 2L, 1L); - assertEquals(r, 2L, "success compareAndExchangeRelease long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "success compareAndExchangeRelease long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 1L, "success compareAndExchangeRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "success compareAndExchangeRelease long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, 2L, 3L); - assertEquals(r, 1L, "failing compareAndExchangeRelease long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, 0xCAFEBABECAFEBABEL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0x0123456789ABCDEFL, "failing compareAndExchangeRelease long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 1L, "failing compareAndExchangeRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "failing compareAndExchangeRelease long value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(recv, 1L, 2L); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(recv, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); } assertEquals(success, true, "weakCompareAndSet long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 2L, "weakCompareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "weakCompareAndSet long value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(recv, 2L, 1L); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(recv, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); } assertEquals(success, true, "weakCompareAndSetAcquire long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 1L, "weakCompareAndSetAcquire long"); + assertEquals(x, 0x0123456789ABCDEFL, "weakCompareAndSetAcquire long"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(recv, 1L, 2L); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(recv, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); } assertEquals(success, true, "weakCompareAndSetRelease long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 2L, "weakCompareAndSetRelease long"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "weakCompareAndSetRelease long"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(recv, 2L, 1L); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(recv, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); } assertEquals(success, true, "weakCompareAndSetVolatile long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 1L, "weakCompareAndSetVolatile long"); + assertEquals(x, 0x0123456789ABCDEFL, "weakCompareAndSetVolatile long"); } // Compare set and get { - long o = (long) hs.get(TestAccessMode.GET_AND_SET).invokeExact(recv, 2L); - assertEquals(o, 1L, "getAndSet long"); + long o = (long) hs.get(TestAccessMode.GET_AND_SET).invokeExact(recv, 0xCAFEBABECAFEBABEL); + assertEquals(o, 0x0123456789ABCDEFL, "getAndSet long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, 2L, "getAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "getAndSet long value"); } - hs.get(TestAccessMode.SET).invokeExact(recv, 1L); + hs.get(TestAccessMode.SET).invokeExact(recv, 0x0123456789ABCDEFL); // get and add, add and get { - long o = (long) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(recv, 3L); - assertEquals(o, 1L, "getAndAdd long"); - long c = (long) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(recv, 3L); - assertEquals(c, 1L + 3L + 3L, "getAndAdd long value"); + long o = (long) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(recv, 0xDEADBEEFDEADBEEFL); + assertEquals(o, 0x0123456789ABCDEFL, "getAndAdd long"); + long c = (long) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(recv, 0xDEADBEEFDEADBEEFL); + assertEquals(c, (long)(0x0123456789ABCDEFL + 0xDEADBEEFDEADBEEFL + 0xDEADBEEFDEADBEEFL), "getAndAdd long value"); } } @@ -274,148 +274,148 @@ public class VarHandleTestMethodHandleAccessLong extends VarHandleBaseTest { static void testStaticField(Handles hs) throws Throwable { // Plain { - hs.get(TestAccessMode.SET).invokeExact(1L); + hs.get(TestAccessMode.SET).invokeExact(0x0123456789ABCDEFL); long x = (long) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 1L, "set long value"); + assertEquals(x, 0x0123456789ABCDEFL, "set long value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact(2L); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact(0xCAFEBABECAFEBABEL); long x = (long) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(); - assertEquals(x, 2L, "setVolatile long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "setVolatile long value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact(1L); + hs.get(TestAccessMode.SET_RELEASE).invokeExact(0x0123456789ABCDEFL); long x = (long) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(); - assertEquals(x, 1L, "setRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "setRelease long value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact(2L); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact(0xCAFEBABECAFEBABEL); long x = (long) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(); - assertEquals(x, 2L, "setOpaque long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "setOpaque long value"); } - hs.get(TestAccessMode.SET).invokeExact(1L); + hs.get(TestAccessMode.SET).invokeExact(0x0123456789ABCDEFL); // Compare { - boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(1L, 2L); + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); assertEquals(r, true, "success compareAndSet long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 2L, "success compareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndSet long value"); } { - boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(1L, 3L); + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); assertEquals(r, false, "failing compareAndSet long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 2L, "failing compareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndSet long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(2L, 1L); - assertEquals(r, 2L, "success compareAndExchangeVolatile long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "success compareAndExchange long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 1L, "success compareAndExchangeVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "success compareAndExchange long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(2L, 3L); - assertEquals(r, 1L, "failing compareAndExchangeVolatile long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(0xCAFEBABECAFEBABEL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0x0123456789ABCDEFL, "failing compareAndExchange long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 1L, "failing compareAndExchangeVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "failing compareAndExchange long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(1L, 2L); - assertEquals(r, 1L, "success compareAndExchangeAcquire long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); + assertEquals(r, 0x0123456789ABCDEFL, "success compareAndExchangeAcquire long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 2L, "success compareAndExchangeAcquire long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndExchangeAcquire long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(1L, 3L); - assertEquals(r, 2L, "failing compareAndExchangeAcquire long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "failing compareAndExchangeAcquire long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 2L, "failing compareAndExchangeAcquire long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndExchangeAcquire long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(2L, 1L); - assertEquals(r, 2L, "success compareAndExchangeRelease long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "success compareAndExchangeRelease long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 1L, "success compareAndExchangeRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "success compareAndExchangeRelease long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(2L, 3L); - assertEquals(r, 1L, "failing compareAndExchangeRelease long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(0xCAFEBABECAFEBABEL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0x0123456789ABCDEFL, "failing compareAndExchangeRelease long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 1L, "failing compareAndExchangeRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "failing compareAndExchangeRelease long value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(1L, 2L); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); } assertEquals(success, true, "weakCompareAndSet long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 2L, "weakCompareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "weakCompareAndSet long value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(2L, 1L); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); } assertEquals(success, true, "weakCompareAndSetAcquire long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 1L, "weakCompareAndSetAcquire long"); + assertEquals(x, 0x0123456789ABCDEFL, "weakCompareAndSetAcquire long"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(1L, 2L); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); } assertEquals(success, true, "weakCompareAndSetRelease long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 2L, "weakCompareAndSetRelease long"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "weakCompareAndSetRelease long"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(2L, 1L); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); } assertEquals(success, true, "weakCompareAndSetVolatile long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 1L, "weakCompareAndSetVolatile long"); + assertEquals(x, 0x0123456789ABCDEFL, "weakCompareAndSetVolatile long"); } // Compare set and get { - long o = (long) hs.get(TestAccessMode.GET_AND_SET).invokeExact( 2L); - assertEquals(o, 1L, "getAndSet long"); + long o = (long) hs.get(TestAccessMode.GET_AND_SET).invokeExact( 0xCAFEBABECAFEBABEL); + assertEquals(o, 0x0123456789ABCDEFL, "getAndSet long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, 2L, "getAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "getAndSet long value"); } - hs.get(TestAccessMode.SET).invokeExact(1L); + hs.get(TestAccessMode.SET).invokeExact(0x0123456789ABCDEFL); // get and add, add and get { - long o = (long) hs.get(TestAccessMode.GET_AND_ADD).invokeExact( 3L); - assertEquals(o, 1L, "getAndAdd long"); - long c = (long) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(3L); - assertEquals(c, 1L + 3L + 3L, "getAndAdd long value"); + long o = (long) hs.get(TestAccessMode.GET_AND_ADD).invokeExact( 0xDEADBEEFDEADBEEFL); + assertEquals(o, 0x0123456789ABCDEFL, "getAndAdd long"); + long c = (long) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(0xDEADBEEFDEADBEEFL); + assertEquals(c, (long)(0x0123456789ABCDEFL + 0xDEADBEEFDEADBEEFL + 0xDEADBEEFDEADBEEFL), "getAndAdd long value"); } } @@ -430,148 +430,148 @@ public class VarHandleTestMethodHandleAccessLong extends VarHandleBaseTest { for (int i = 0; i < array.length; i++) { // Plain { - hs.get(TestAccessMode.SET).invokeExact(array, i, 1L); + hs.get(TestAccessMode.SET).invokeExact(array, i, 0x0123456789ABCDEFL); long x = (long) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 1L, "get long value"); + assertEquals(x, 0x0123456789ABCDEFL, "get long value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact(array, i, 2L); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact(array, i, 0xCAFEBABECAFEBABEL); long x = (long) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(array, i); - assertEquals(x, 2L, "setVolatile long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "setVolatile long value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact(array, i, 1L); + hs.get(TestAccessMode.SET_RELEASE).invokeExact(array, i, 0x0123456789ABCDEFL); long x = (long) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(array, i); - assertEquals(x, 1L, "setRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "setRelease long value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact(array, i, 2L); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact(array, i, 0xCAFEBABECAFEBABEL); long x = (long) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(array, i); - assertEquals(x, 2L, "setOpaque long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "setOpaque long value"); } - hs.get(TestAccessMode.SET).invokeExact(array, i, 1L); + hs.get(TestAccessMode.SET).invokeExact(array, i, 0x0123456789ABCDEFL); // Compare { - boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, 1L, 2L); + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); assertEquals(r, true, "success compareAndSet long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 2L, "success compareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndSet long value"); } { - boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, 1L, 3L); + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, 0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); assertEquals(r, false, "failing compareAndSet long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 2L, "failing compareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndSet long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(array, i, 2L, 1L); - assertEquals(r, 2L, "success compareAndExchangeVolatile long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "success compareAndExchange long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 1L, "success compareAndExchangeVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "success compareAndExchange long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(array, i, 2L, 3L); - assertEquals(r, 1L, "failing compareAndExchangeVolatile long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, 0xCAFEBABECAFEBABEL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0x0123456789ABCDEFL, "failing compareAndExchange long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 1L, "failing compareAndExchangeVolatile long value"); + assertEquals(x, 0x0123456789ABCDEFL, "failing compareAndExchange long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, 1L, 2L); - assertEquals(r, 1L, "success compareAndExchangeAcquire long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); + assertEquals(r, 0x0123456789ABCDEFL, "success compareAndExchangeAcquire long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 2L, "success compareAndExchangeAcquire long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "success compareAndExchangeAcquire long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, 1L, 3L); - assertEquals(r, 2L, "failing compareAndExchangeAcquire long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, 0x0123456789ABCDEFL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "failing compareAndExchangeAcquire long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 2L, "failing compareAndExchangeAcquire long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "failing compareAndExchangeAcquire long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, 2L, 1L); - assertEquals(r, 2L, "success compareAndExchangeRelease long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); + assertEquals(r, 0xCAFEBABECAFEBABEL, "success compareAndExchangeRelease long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 1L, "success compareAndExchangeRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "success compareAndExchangeRelease long value"); } { - long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, 2L, 3L); - assertEquals(r, 1L, "failing compareAndExchangeRelease long"); + long r = (long) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, 0xCAFEBABECAFEBABEL, 0xDEADBEEFDEADBEEFL); + assertEquals(r, 0x0123456789ABCDEFL, "failing compareAndExchangeRelease long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 1L, "failing compareAndExchangeRelease long value"); + assertEquals(x, 0x0123456789ABCDEFL, "failing compareAndExchangeRelease long value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(array, i, 1L, 2L); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(array, i, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); } assertEquals(success, true, "weakCompareAndSet long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 2L, "weakCompareAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "weakCompareAndSet long value"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(array, i, 2L, 1L); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(array, i, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); } assertEquals(success, true, "weakCompareAndSetAcquire long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 1L, "weakCompareAndSetAcquire long"); + assertEquals(x, 0x0123456789ABCDEFL, "weakCompareAndSetAcquire long"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(array, i, 1L, 2L); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(array, i, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); } assertEquals(success, true, "weakCompareAndSetRelease long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 2L, "weakCompareAndSetRelease long"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "weakCompareAndSetRelease long"); } { boolean success = false; for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { - success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(array, i, 2L, 1L); + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(array, i, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); } assertEquals(success, true, "weakCompareAndSetVolatile long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 1L, "weakCompareAndSetVolatile long"); + assertEquals(x, 0x0123456789ABCDEFL, "weakCompareAndSetVolatile long"); } // Compare set and get { - long o = (long) hs.get(TestAccessMode.GET_AND_SET).invokeExact(array, i, 2L); - assertEquals(o, 1L, "getAndSet long"); + long o = (long) hs.get(TestAccessMode.GET_AND_SET).invokeExact(array, i, 0xCAFEBABECAFEBABEL); + assertEquals(o, 0x0123456789ABCDEFL, "getAndSet long"); long x = (long) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, 2L, "getAndSet long value"); + assertEquals(x, 0xCAFEBABECAFEBABEL, "getAndSet long value"); } - hs.get(TestAccessMode.SET).invokeExact(array, i, 1L); + hs.get(TestAccessMode.SET).invokeExact(array, i, 0x0123456789ABCDEFL); // get and add, add and get { - long o = (long) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(array, i, 3L); - assertEquals(o, 1L, "getAndAdd long"); - long c = (long) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(array, i, 3L); - assertEquals(c, 1L + 3L + 3L, "getAndAdd long value"); + long o = (long) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(array, i, 0xDEADBEEFDEADBEEFL); + assertEquals(o, 0x0123456789ABCDEFL, "getAndAdd long"); + long c = (long) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(array, i, 0xDEADBEEFDEADBEEFL); + assertEquals(c, (long)(0x0123456789ABCDEFL + 0xDEADBEEFDEADBEEFL + 0xDEADBEEFDEADBEEFL), "getAndAdd long value"); } } } @@ -597,31 +597,31 @@ public class VarHandleTestMethodHandleAccessLong extends VarHandleBaseTest { for (TestAccessMode am : testAccessModesOfType(TestAccessType.SET)) { checkIOOBE(am, () -> { - hs.get(am).invokeExact(array, ci, 1L); + hs.get(am).invokeExact(array, ci, 0x0123456789ABCDEFL); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { checkIOOBE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(array, ci, 1L, 2L); + boolean r = (boolean) hs.get(am).invokeExact(array, ci, 0x0123456789ABCDEFL, 0xCAFEBABECAFEBABEL); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { checkIOOBE(am, () -> { - long r = (long) hs.get(am).invokeExact(array, ci, 2L, 1L); + long r = (long) hs.get(am).invokeExact(array, ci, 0xCAFEBABECAFEBABEL, 0x0123456789ABCDEFL); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { checkIOOBE(am, () -> { - long o = (long) hs.get(am).invokeExact(array, ci, 1L); + long o = (long) hs.get(am).invokeExact(array, ci, 0x0123456789ABCDEFL); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { checkIOOBE(am, () -> { - long o = (long) hs.get(am).invokeExact(array, ci, 3L); + long o = (long) hs.get(am).invokeExact(array, ci, 0xDEADBEEFDEADBEEFL); }); } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessShort.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessShort.java index 6edc9b19b68..ca4121e412e 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessShort.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessShort.java @@ -39,11 +39,11 @@ import java.util.List; import static org.testng.Assert.*; public class VarHandleTestMethodHandleAccessShort extends VarHandleBaseTest { - static final short static_final_v = (short)1; + static final short static_final_v = (short)0x0123; static short static_v; - final short final_v = (short)1; + final short final_v = (short)0x0123; short v; @@ -121,120 +121,306 @@ public class VarHandleTestMethodHandleAccessShort extends VarHandleBaseTest { static void testInstanceField(VarHandleTestMethodHandleAccessShort recv, Handles hs) throws Throwable { // Plain { - hs.get(TestAccessMode.SET).invokeExact(recv, (short)1); + hs.get(TestAccessMode.SET).invokeExact(recv, (short)0x0123); short x = (short) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, (short)1, "set short value"); + assertEquals(x, (short)0x0123, "set short value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact(recv, (short)2); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact(recv, (short)0x4567); short x = (short) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(recv); - assertEquals(x, (short)2, "setVolatile short value"); + assertEquals(x, (short)0x4567, "setVolatile short value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact(recv, (short)1); + hs.get(TestAccessMode.SET_RELEASE).invokeExact(recv, (short)0x0123); short x = (short) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(recv); - assertEquals(x, (short)1, "setRelease short value"); + assertEquals(x, (short)0x0123, "setRelease short value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact(recv, (short)2); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact(recv, (short)0x4567); short x = (short) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(recv); - assertEquals(x, (short)2, "setOpaque short value"); + assertEquals(x, (short)0x4567, "setOpaque short value"); } + hs.get(TestAccessMode.SET).invokeExact(recv, (short)0x0123); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, (short)0x0123, (short)0x4567); + assertEquals(r, true, "success compareAndSet short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (short)0x4567, "success compareAndSet short value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(recv, (short)0x0123, (short)0x89AB); + assertEquals(r, false, "failing compareAndSet short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (short)0x4567, "failing compareAndSet short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, (short)0x4567, (short)0x0123); + assertEquals(r, (short)0x4567, "success compareAndExchange short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (short)0x0123, "success compareAndExchange short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, (short)0x4567, (short)0x89AB); + assertEquals(r, (short)0x0123, "failing compareAndExchange short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (short)0x0123, "failing compareAndExchange short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, (short)0x0123, (short)0x4567); + assertEquals(r, (short)0x0123, "success compareAndExchangeAcquire short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (short)0x4567, "success compareAndExchangeAcquire short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(recv, (short)0x0123, (short)0x89AB); + assertEquals(r, (short)0x4567, "failing compareAndExchangeAcquire short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (short)0x4567, "failing compareAndExchangeAcquire short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, (short)0x4567, (short)0x0123); + assertEquals(r, (short)0x4567, "success compareAndExchangeRelease short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (short)0x0123, "success compareAndExchangeRelease short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(recv, (short)0x4567, (short)0x89AB); + assertEquals(r, (short)0x0123, "failing compareAndExchangeRelease short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (short)0x0123, "failing compareAndExchangeRelease short value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(recv, (short)0x0123, (short)0x4567); + } + assertEquals(success, true, "weakCompareAndSet short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (short)0x4567, "weakCompareAndSet short value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(recv, (short)0x4567, (short)0x0123); + } + assertEquals(success, true, "weakCompareAndSetAcquire short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (short)0x0123, "weakCompareAndSetAcquire short"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(recv, (short)0x0123, (short)0x4567); + } + assertEquals(success, true, "weakCompareAndSetRelease short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (short)0x4567, "weakCompareAndSetRelease short"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(recv, (short)0x4567, (short)0x0123); + } + assertEquals(success, true, "weakCompareAndSetVolatile short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (short)0x0123, "weakCompareAndSetVolatile short"); + } + + // Compare set and get + { + short o = (short) hs.get(TestAccessMode.GET_AND_SET).invokeExact(recv, (short)0x4567); + assertEquals(o, (short)0x0123, "getAndSet short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(recv); + assertEquals(x, (short)0x4567, "getAndSet short value"); + } + + hs.get(TestAccessMode.SET).invokeExact(recv, (short)0x0123); + + // get and add, add and get + { + short o = (short) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(recv, (short)0x89AB); + assertEquals(o, (short)0x0123, "getAndAdd short"); + short c = (short) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(recv, (short)0x89AB); + assertEquals(c, (short)((short)0x0123 + (short)0x89AB + (short)0x89AB), "getAndAdd short value"); + } } static void testInstanceFieldUnsupported(VarHandleTestMethodHandleAccessShort recv, Handles hs) throws Throwable { - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(recv, (short)1, (short)2); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - short r = (short) hs.get(am).invokeExact(recv, (short)1, (short)2); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - short r = (short) hs.get(am).invokeExact(recv, (short)1); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - short r = (short) hs.get(am).invokeExact(recv, (short)1); - }); - } } static void testStaticField(Handles hs) throws Throwable { // Plain { - hs.get(TestAccessMode.SET).invokeExact((short)1); + hs.get(TestAccessMode.SET).invokeExact((short)0x0123); short x = (short) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, (short)1, "set short value"); + assertEquals(x, (short)0x0123, "set short value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact((short)2); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact((short)0x4567); short x = (short) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(); - assertEquals(x, (short)2, "setVolatile short value"); + assertEquals(x, (short)0x4567, "setVolatile short value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact((short)1); + hs.get(TestAccessMode.SET_RELEASE).invokeExact((short)0x0123); short x = (short) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(); - assertEquals(x, (short)1, "setRelease short value"); + assertEquals(x, (short)0x0123, "setRelease short value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact((short)2); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact((short)0x4567); short x = (short) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(); - assertEquals(x, (short)2, "setOpaque short value"); + assertEquals(x, (short)0x4567, "setOpaque short value"); } + hs.get(TestAccessMode.SET).invokeExact((short)0x0123); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact((short)0x0123, (short)0x4567); + assertEquals(r, true, "success compareAndSet short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (short)0x4567, "success compareAndSet short value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact((short)0x0123, (short)0x89AB); + assertEquals(r, false, "failing compareAndSet short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (short)0x4567, "failing compareAndSet short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact((short)0x4567, (short)0x0123); + assertEquals(r, (short)0x4567, "success compareAndExchange short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (short)0x0123, "success compareAndExchange short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact((short)0x4567, (short)0x89AB); + assertEquals(r, (short)0x0123, "failing compareAndExchange short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (short)0x0123, "failing compareAndExchange short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact((short)0x0123, (short)0x4567); + assertEquals(r, (short)0x0123, "success compareAndExchangeAcquire short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (short)0x4567, "success compareAndExchangeAcquire short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact((short)0x0123, (short)0x89AB); + assertEquals(r, (short)0x4567, "failing compareAndExchangeAcquire short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (short)0x4567, "failing compareAndExchangeAcquire short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact((short)0x4567, (short)0x0123); + assertEquals(r, (short)0x4567, "success compareAndExchangeRelease short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (short)0x0123, "success compareAndExchangeRelease short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact((short)0x4567, (short)0x89AB); + assertEquals(r, (short)0x0123, "failing compareAndExchangeRelease short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (short)0x0123, "failing compareAndExchangeRelease short value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact((short)0x0123, (short)0x4567); + } + assertEquals(success, true, "weakCompareAndSet short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (short)0x4567, "weakCompareAndSet short value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact((short)0x4567, (short)0x0123); + } + assertEquals(success, true, "weakCompareAndSetAcquire short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (short)0x0123, "weakCompareAndSetAcquire short"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact((short)0x0123, (short)0x4567); + } + assertEquals(success, true, "weakCompareAndSetRelease short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (short)0x4567, "weakCompareAndSetRelease short"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact((short)0x4567, (short)0x0123); + } + assertEquals(success, true, "weakCompareAndSetVolatile short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (short)0x0123, "weakCompareAndSetVolatile short"); + } + + // Compare set and get + { + short o = (short) hs.get(TestAccessMode.GET_AND_SET).invokeExact( (short)0x4567); + assertEquals(o, (short)0x0123, "getAndSet short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(); + assertEquals(x, (short)0x4567, "getAndSet short value"); + } + + hs.get(TestAccessMode.SET).invokeExact((short)0x0123); + + // get and add, add and get + { + short o = (short) hs.get(TestAccessMode.GET_AND_ADD).invokeExact( (short)0x89AB); + assertEquals(o, (short)0x0123, "getAndAdd short"); + short c = (short) hs.get(TestAccessMode.ADD_AND_GET).invokeExact((short)0x89AB); + assertEquals(c, (short)((short)0x0123 + (short)0x89AB + (short)0x89AB), "getAndAdd short value"); + } } static void testStaticFieldUnsupported(Handles hs) throws Throwable { - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact((short)1, (short)2); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - short r = (short) hs.get(am).invokeExact((short)1, (short)2); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - short r = (short) hs.get(am).invokeExact((short)1); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - short r = (short) hs.get(am).invokeExact((short)1); - }); - } } @@ -244,34 +430,149 @@ public class VarHandleTestMethodHandleAccessShort extends VarHandleBaseTest { for (int i = 0; i < array.length; i++) { // Plain { - hs.get(TestAccessMode.SET).invokeExact(array, i, (short)1); + hs.get(TestAccessMode.SET).invokeExact(array, i, (short)0x0123); short x = (short) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, (short)1, "get short value"); + assertEquals(x, (short)0x0123, "get short value"); } // Volatile { - hs.get(TestAccessMode.SET_VOLATILE).invokeExact(array, i, (short)2); + hs.get(TestAccessMode.SET_VOLATILE).invokeExact(array, i, (short)0x4567); short x = (short) hs.get(TestAccessMode.GET_VOLATILE).invokeExact(array, i); - assertEquals(x, (short)2, "setVolatile short value"); + assertEquals(x, (short)0x4567, "setVolatile short value"); } // Lazy { - hs.get(TestAccessMode.SET_RELEASE).invokeExact(array, i, (short)1); + hs.get(TestAccessMode.SET_RELEASE).invokeExact(array, i, (short)0x0123); short x = (short) hs.get(TestAccessMode.GET_ACQUIRE).invokeExact(array, i); - assertEquals(x, (short)1, "setRelease short value"); + assertEquals(x, (short)0x0123, "setRelease short value"); } // Opaque { - hs.get(TestAccessMode.SET_OPAQUE).invokeExact(array, i, (short)2); + hs.get(TestAccessMode.SET_OPAQUE).invokeExact(array, i, (short)0x4567); short x = (short) hs.get(TestAccessMode.GET_OPAQUE).invokeExact(array, i); - assertEquals(x, (short)2, "setOpaque short value"); + assertEquals(x, (short)0x4567, "setOpaque short value"); } + hs.get(TestAccessMode.SET).invokeExact(array, i, (short)0x0123); + // Compare + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, (short)0x0123, (short)0x4567); + assertEquals(r, true, "success compareAndSet short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (short)0x4567, "success compareAndSet short value"); + } + + { + boolean r = (boolean) hs.get(TestAccessMode.COMPARE_AND_SET).invokeExact(array, i, (short)0x0123, (short)0x89AB); + assertEquals(r, false, "failing compareAndSet short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (short)0x4567, "failing compareAndSet short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, (short)0x4567, (short)0x0123); + assertEquals(r, (short)0x4567, "success compareAndExchange short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (short)0x0123, "success compareAndExchange short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, (short)0x4567, (short)0x89AB); + assertEquals(r, (short)0x0123, "failing compareAndExchange short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (short)0x0123, "failing compareAndExchange short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, (short)0x0123, (short)0x4567); + assertEquals(r, (short)0x0123, "success compareAndExchangeAcquire short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (short)0x4567, "success compareAndExchangeAcquire short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_ACQUIRE).invokeExact(array, i, (short)0x0123, (short)0x89AB); + assertEquals(r, (short)0x4567, "failing compareAndExchangeAcquire short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (short)0x4567, "failing compareAndExchangeAcquire short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, (short)0x4567, (short)0x0123); + assertEquals(r, (short)0x4567, "success compareAndExchangeRelease short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (short)0x0123, "success compareAndExchangeRelease short value"); + } + + { + short r = (short) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_RELEASE).invokeExact(array, i, (short)0x4567, (short)0x89AB); + assertEquals(r, (short)0x0123, "failing compareAndExchangeRelease short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (short)0x0123, "failing compareAndExchangeRelease short value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET).invokeExact(array, i, (short)0x0123, (short)0x4567); + } + assertEquals(success, true, "weakCompareAndSet short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (short)0x4567, "weakCompareAndSet short value"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_ACQUIRE).invokeExact(array, i, (short)0x4567, (short)0x0123); + } + assertEquals(success, true, "weakCompareAndSetAcquire short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (short)0x0123, "weakCompareAndSetAcquire short"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_RELEASE).invokeExact(array, i, (short)0x0123, (short)0x4567); + } + assertEquals(success, true, "weakCompareAndSetRelease short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (short)0x4567, "weakCompareAndSetRelease short"); + } + + { + boolean success = false; + for (int c = 0; c < WEAK_ATTEMPTS && !success; c++) { + success = (boolean) hs.get(TestAccessMode.WEAK_COMPARE_AND_SET_VOLATILE).invokeExact(array, i, (short)0x4567, (short)0x0123); + } + assertEquals(success, true, "weakCompareAndSetVolatile short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (short)0x0123, "weakCompareAndSetVolatile short"); + } + + // Compare set and get + { + short o = (short) hs.get(TestAccessMode.GET_AND_SET).invokeExact(array, i, (short)0x4567); + assertEquals(o, (short)0x0123, "getAndSet short"); + short x = (short) hs.get(TestAccessMode.GET).invokeExact(array, i); + assertEquals(x, (short)0x4567, "getAndSet short value"); + } + + hs.get(TestAccessMode.SET).invokeExact(array, i, (short)0x0123); + + // get and add, add and get + { + short o = (short) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(array, i, (short)0x89AB); + assertEquals(o, (short)0x0123, "getAndAdd short"); + short c = (short) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(array, i, (short)0x89AB); + assertEquals(c, (short)((short)0x0123 + (short)0x89AB + (short)0x89AB), "getAndAdd short value"); + } } } @@ -279,29 +580,7 @@ public class VarHandleTestMethodHandleAccessShort extends VarHandleBaseTest { short[] array = new short[10]; final int i = 0; - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { - checkUOE(am, () -> { - boolean r = (boolean) hs.get(am).invokeExact(array, i, (short)1, (short)2); - }); - } - for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { - checkUOE(am, () -> { - short r = (short) hs.get(am).invokeExact(array, i, (short)1, (short)2); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { - checkUOE(am, () -> { - short r = (short) hs.get(am).invokeExact(array, i, (short)1); - }); - } - - for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { - checkUOE(am, () -> { - short o = (short) hs.get(am).invokeExact(array, i, (short)1); - }); - } } static void testArrayIndexOutOfBounds(Handles hs) throws Throwable { @@ -318,11 +597,33 @@ public class VarHandleTestMethodHandleAccessShort extends VarHandleBaseTest { for (TestAccessMode am : testAccessModesOfType(TestAccessType.SET)) { checkIOOBE(am, () -> { - hs.get(am).invokeExact(array, ci, (short)1); + hs.get(am).invokeExact(array, ci, (short)0x0123); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + checkIOOBE(am, () -> { + boolean r = (boolean) hs.get(am).invokeExact(array, ci, (short)0x0123, (short)0x4567); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + checkIOOBE(am, () -> { + short r = (short) hs.get(am).invokeExact(array, ci, (short)0x4567, (short)0x0123); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + checkIOOBE(am, () -> { + short o = (short) hs.get(am).invokeExact(array, ci, (short)0x0123); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + checkIOOBE(am, () -> { + short o = (short) hs.get(am).invokeExact(array, ci, (short)0x89AB); + }); + } } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessString.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessString.java index dc6f8ec1861..079d8053606 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessString.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodHandleAccessString.java @@ -166,17 +166,17 @@ public class VarHandleTestMethodHandleAccessString extends VarHandleBaseTest { } { - String r = (String) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(recv, "bar", "foo"); - assertEquals(r, "bar", "success compareAndExchangeVolatile String"); + String r = (String) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, "bar", "foo"); + assertEquals(r, "bar", "success compareAndExchange String"); String x = (String) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, "foo", "success compareAndExchangeVolatile String value"); + assertEquals(x, "foo", "success compareAndExchange String value"); } { - String r = (String) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(recv, "bar", "baz"); - assertEquals(r, "foo", "failing compareAndExchangeVolatile String"); + String r = (String) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, "bar", "baz"); + assertEquals(r, "foo", "failing compareAndExchange String"); String x = (String) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, "foo", "failing compareAndExchangeVolatile String value"); + assertEquals(x, "foo", "failing compareAndExchange String value"); } { @@ -315,17 +315,17 @@ public class VarHandleTestMethodHandleAccessString extends VarHandleBaseTest { } { - String r = (String) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact("bar", "foo"); - assertEquals(r, "bar", "success compareAndExchangeVolatile String"); + String r = (String) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact("bar", "foo"); + assertEquals(r, "bar", "success compareAndExchange String"); String x = (String) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, "foo", "success compareAndExchangeVolatile String value"); + assertEquals(x, "foo", "success compareAndExchange String value"); } { - String r = (String) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact("bar", "baz"); - assertEquals(r, "foo", "failing compareAndExchangeVolatile String"); + String r = (String) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact("bar", "baz"); + assertEquals(r, "foo", "failing compareAndExchange String"); String x = (String) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, "foo", "failing compareAndExchangeVolatile String value"); + assertEquals(x, "foo", "failing compareAndExchange String value"); } { @@ -467,17 +467,17 @@ public class VarHandleTestMethodHandleAccessString extends VarHandleBaseTest { } { - String r = (String) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(array, i, "bar", "foo"); - assertEquals(r, "bar", "success compareAndExchangeVolatile String"); + String r = (String) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, "bar", "foo"); + assertEquals(r, "bar", "success compareAndExchange String"); String x = (String) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, "foo", "success compareAndExchangeVolatile String value"); + assertEquals(x, "foo", "success compareAndExchange String value"); } { - String r = (String) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(array, i, "bar", "baz"); - assertEquals(r, "foo", "failing compareAndExchangeVolatile String"); + String r = (String) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, "bar", "baz"); + assertEquals(r, "foo", "failing compareAndExchange String"); String x = (String) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, "foo", "failing compareAndExchangeVolatile String value"); + assertEquals(x, "foo", "failing compareAndExchange String value"); } { diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeBoolean.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeBoolean.java index df680146374..624f98a8407 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeBoolean.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeBoolean.java @@ -324,6 +324,263 @@ public class VarHandleTestMethodTypeBoolean extends VarHandleBaseTest { }); + // CompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.compareAndSet(null, true, true); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.compareAndSet(Void.class, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(recv, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(recv, true, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.compareAndSet(0, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(recv, true, true, Void.class); + }); + + + // WeakCompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSet(null, true, true); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSet(Void.class, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(recv, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(recv, true, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSet(0, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(recv, true, true, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetVolatile(null, true, true); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(recv, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(recv, true, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetVolatile(0, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(recv, true, true, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetAcquire(null, true, true); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(recv, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(recv, true, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetAcquire(0, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(recv, true, true, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetRelease(null, true, true); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(recv, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(recv, true, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetRelease(0, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(recv, true, true, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean x = (boolean) vh.compareAndExchange(null, true, true); + }); + checkCCE(() -> { // receiver reference class + boolean x = (boolean) vh.compareAndExchange(Void.class, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean x = (boolean) vh.compareAndExchange(recv, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean x = (boolean) vh.compareAndExchange(recv, true, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + boolean x = (boolean) vh.compareAndExchange(0, true, true); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(recv, true, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) vh.compareAndExchange(recv, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) vh.compareAndExchange(recv, true, true, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean x = (boolean) vh.compareAndExchangeAcquire(null, true, true); + }); + checkCCE(() -> { // receiver reference class + boolean x = (boolean) vh.compareAndExchangeAcquire(Void.class, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean x = (boolean) vh.compareAndExchangeAcquire(recv, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean x = (boolean) vh.compareAndExchangeAcquire(recv, true, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire(0, true, true); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(recv, true, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) vh.compareAndExchangeAcquire(recv, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) vh.compareAndExchangeAcquire(recv, true, true, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean x = (boolean) vh.compareAndExchangeRelease(null, true, true); + }); + checkCCE(() -> { // receiver reference class + boolean x = (boolean) vh.compareAndExchangeRelease(Void.class, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean x = (boolean) vh.compareAndExchangeRelease(recv, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean x = (boolean) vh.compareAndExchangeRelease(recv, true, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + boolean x = (boolean) vh.compareAndExchangeRelease(0, true, true); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(recv, true, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) vh.compareAndExchangeRelease(recv, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) vh.compareAndExchangeRelease(recv, true, true, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean x = (boolean) vh.getAndSet(null, true); + }); + checkCCE(() -> { // receiver reference class + boolean x = (boolean) vh.getAndSet(Void.class, true); + }); + checkWMTE(() -> { // value reference class + boolean x = (boolean) vh.getAndSet(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + boolean x = (boolean) vh.getAndSet(0, true); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(recv, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) vh.getAndSet(recv, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) vh.getAndSet(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) vh.getAndSet(recv, true, Void.class); + }); } @@ -391,6 +648,116 @@ public class VarHandleTestMethodTypeBoolean extends VarHandleBaseTest { }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeBoolean.class, boolean.class, boolean.class)). + invokeExact((VarHandleTestMethodTypeBoolean) null, true, true); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, boolean.class, boolean.class)). + invokeExact(Void.class, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeBoolean.class, Class.class, boolean.class)). + invokeExact(recv, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeBoolean.class, boolean.class, Class.class)). + invokeExact(recv, true, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class , boolean.class, boolean.class)). + invokeExact(0, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeBoolean.class, boolean.class, boolean.class, Class.class)). + invokeExact(recv, true, true, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + checkNPE(() -> { // null receiver + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeBoolean.class, boolean.class, boolean.class)). + invokeExact((VarHandleTestMethodTypeBoolean) null, true, true); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, Class.class, boolean.class, boolean.class)). + invokeExact(Void.class, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeBoolean.class, Class.class, boolean.class)). + invokeExact(recv, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeBoolean.class, boolean.class, Class.class)). + invokeExact(recv, true, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, int.class , boolean.class, boolean.class)). + invokeExact(0, true, true); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeBoolean.class , boolean.class, boolean.class)). + invokeExact(recv, true, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) hs.get(am, methodType(int.class, VarHandleTestMethodTypeBoolean.class , boolean.class, boolean.class)). + invokeExact(recv, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeBoolean.class, boolean.class, boolean.class, Class.class)). + invokeExact(recv, true, true, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + checkNPE(() -> { // null receiver + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeBoolean.class, boolean.class)). + invokeExact((VarHandleTestMethodTypeBoolean) null, true); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, Class.class, boolean.class)). + invokeExact(Void.class, true); + }); + checkWMTE(() -> { // value reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeBoolean.class, Class.class)). + invokeExact(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, int.class, boolean.class)). + invokeExact(0, true); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeBoolean.class, boolean.class)). + invokeExact(recv, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) hs.get(am, methodType(int.class, VarHandleTestMethodTypeBoolean.class, boolean.class)). + invokeExact(recv, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeBoolean.class, boolean.class)). + invokeExact(recv, true, Void.class); + }); + } } @@ -505,6 +872,182 @@ public class VarHandleTestMethodTypeBoolean extends VarHandleBaseTest { }); + // CompareAndSet + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(true, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(true, true, Void.class); + }); + + + // WeakCompareAndSet + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(true, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(true, true, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(true, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(true, true, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(true, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(true, true, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(true, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(true, true, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean x = (boolean) vh.compareAndExchange(Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean x = (boolean) vh.compareAndExchange(true, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(true, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) vh.compareAndExchange(true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) vh.compareAndExchange(true, true, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean x = (boolean) vh.compareAndExchangeAcquire(Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean x = (boolean) vh.compareAndExchangeAcquire(true, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(true, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) vh.compareAndExchangeAcquire(true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) vh.compareAndExchangeAcquire(true, true, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean x = (boolean) vh.compareAndExchangeRelease(Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean x = (boolean) vh.compareAndExchangeRelease(true, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(true, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) vh.compareAndExchangeRelease(true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) vh.compareAndExchangeRelease(true, true, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkWMTE(() -> { // value reference class + boolean x = (boolean) vh.getAndSet(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(true); + }); + checkWMTE(() -> { // primitive class + int x = (int) vh.getAndSet(true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) vh.getAndSet(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) vh.getAndSet(true, Void.class); + }); } @@ -543,6 +1086,82 @@ public class VarHandleTestMethodTypeBoolean extends VarHandleBaseTest { invokeExact(true, Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, boolean.class)). + invokeExact(Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, boolean.class, Class.class)). + invokeExact(true, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, boolean.class, boolean.class, Class.class)). + invokeExact(true, true, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, Class.class, boolean.class)). + invokeExact(Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, boolean.class, Class.class)). + invokeExact(true, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, boolean.class, boolean.class)). + invokeExact(true, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) hs.get(am, methodType(int.class, boolean.class, boolean.class)). + invokeExact(true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) hs.get(am, methodType(boolean.class, boolean.class, boolean.class, Class.class)). + invokeExact(true, true, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + // Incorrect argument types + checkWMTE(() -> { // value reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, Class.class)). + invokeExact(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, boolean.class)). + invokeExact(true); + }); + checkWMTE(() -> { // primitive class + int x = (int) hs.get(am, methodType(int.class, boolean.class)). + invokeExact(true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) hs.get(am, methodType(boolean.class, boolean.class, Class.class)). + invokeExact(true, Void.class); + }); + } } @@ -775,6 +1394,290 @@ public class VarHandleTestMethodTypeBoolean extends VarHandleBaseTest { }); + // CompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.compareAndSet(null, 0, true, true); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.compareAndSet(Void.class, 0, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(array, 0, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(array, 0, true, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.compareAndSet(0, 0, true, true); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.compareAndSet(array, Void.class, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(array, 0, true, true, Void.class); + }); + + + // WeakCompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSet(null, 0, true, true); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSet(Void.class, 0, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(array, 0, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(array, 0, true, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSet(0, 0, true, true); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSet(array, Void.class, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(array, 0, true, true, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetVolatile(null, 0, true, true); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, 0, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(array, 0, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(array, 0, true, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetVolatile(0, 0, true, true); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetVolatile(array, Void.class, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(array, 0, true, true, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetAcquire(null, 0, true, true); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, 0, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(array, 0, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(array, 0, true, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetAcquire(0, 0, true, true); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetAcquire(array, Void.class, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(array, 0, true, true, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetRelease(null, 0, true, true); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, 0, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(array, 0, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(array, 0, true, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetRelease(0, 0, true, true); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetRelease(array, Void.class, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(array, 0, true, true, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean x = (boolean) vh.compareAndExchange(null, 0, true, true); + }); + checkCCE(() -> { // array reference class + boolean x = (boolean) vh.compareAndExchange(Void.class, 0, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean x = (boolean) vh.compareAndExchange(array, 0, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean x = (boolean) vh.compareAndExchange(array, 0, true, Void.class); + }); + checkWMTE(() -> { // array primitive class + boolean x = (boolean) vh.compareAndExchange(0, 0, true, true); + }); + checkWMTE(() -> { // index reference class + boolean x = (boolean) vh.compareAndExchange(array, Void.class, true, true); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(array, 0, true, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) vh.compareAndExchange(array, 0, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) vh.compareAndExchange(array, 0, true, true, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean x = (boolean) vh.compareAndExchangeAcquire(null, 0, true, true); + }); + checkCCE(() -> { // array reference class + boolean x = (boolean) vh.compareAndExchangeAcquire(Void.class, 0, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean x = (boolean) vh.compareAndExchangeAcquire(array, 0, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean x = (boolean) vh.compareAndExchangeAcquire(array, 0, true, Void.class); + }); + checkWMTE(() -> { // array primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire(0, 0, true, true); + }); + checkWMTE(() -> { // index reference class + boolean x = (boolean) vh.compareAndExchangeAcquire(array, Void.class, true, true); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(array, 0, true, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) vh.compareAndExchangeAcquire(array, 0, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) vh.compareAndExchangeAcquire(array, 0, true, true, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean x = (boolean) vh.compareAndExchangeRelease(null, 0, true, true); + }); + checkCCE(() -> { // array reference class + boolean x = (boolean) vh.compareAndExchangeRelease(Void.class, 0, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean x = (boolean) vh.compareAndExchangeRelease(array, 0, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean x = (boolean) vh.compareAndExchangeRelease(array, 0, true, Void.class); + }); + checkWMTE(() -> { // array primitive class + boolean x = (boolean) vh.compareAndExchangeRelease(0, 0, true, true); + }); + checkWMTE(() -> { // index reference class + boolean x = (boolean) vh.compareAndExchangeRelease(array, Void.class, true, true); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(array, 0, true, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) vh.compareAndExchangeRelease(array, 0, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) vh.compareAndExchangeRelease(array, 0, true, true, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkNPE(() -> { // null array + boolean x = (boolean) vh.getAndSet(null, 0, true); + }); + checkCCE(() -> { // array reference class + boolean x = (boolean) vh.getAndSet(Void.class, 0, true); + }); + checkWMTE(() -> { // value reference class + boolean x = (boolean) vh.getAndSet(array, 0, Void.class); + }); + checkWMTE(() -> { // reciarrayever primitive class + boolean x = (boolean) vh.getAndSet(0, 0, true); + }); + checkWMTE(() -> { // index reference class + boolean x = (boolean) vh.getAndSet(array, Void.class, true); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(array, 0, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) vh.getAndSet(array, 0, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) vh.getAndSet(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) vh.getAndSet(array, 0, true, Void.class); + }); } @@ -852,6 +1755,130 @@ public class VarHandleTestMethodTypeBoolean extends VarHandleBaseTest { invokeExact(array, 0, true, Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = (boolean) hs.get(am, methodType(boolean.class, boolean[].class, int.class, boolean.class, boolean.class)). + invokeExact((boolean[]) null, 0, true, true); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, int.class, boolean.class, boolean.class)). + invokeExact(Void.class, 0, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, boolean[].class, int.class, Class.class, boolean.class)). + invokeExact(array, 0, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, boolean[].class, int.class, boolean.class, Class.class)). + invokeExact(array, 0, true, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class, int.class, boolean.class, boolean.class)). + invokeExact(0, 0, true, true); + }); + checkWMTE(() -> { // index reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, boolean[].class, Class.class, boolean.class, boolean.class)). + invokeExact(array, Void.class, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, boolean[].class, int.class, boolean.class, boolean.class, Class.class)). + invokeExact(array, 0, true, true, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean x = (boolean) hs.get(am, methodType(boolean.class, boolean[].class, int.class, boolean.class, boolean.class)). + invokeExact((boolean[]) null, 0, true, true); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, Class.class, int.class, boolean.class, boolean.class)). + invokeExact(Void.class, 0, true, true); + }); + checkWMTE(() -> { // expected reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, boolean[].class, int.class, Class.class, boolean.class)). + invokeExact(array, 0, Void.class, true); + }); + checkWMTE(() -> { // actual reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, boolean[].class, int.class, boolean.class, Class.class)). + invokeExact(array, 0, true, Void.class); + }); + checkWMTE(() -> { // array primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, int.class, int.class, boolean.class, boolean.class)). + invokeExact(0, 0, true, true); + }); + checkWMTE(() -> { // index reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, boolean[].class, Class.class, boolean.class, boolean.class)). + invokeExact(array, Void.class, true, true); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, boolean[].class, int.class, boolean.class, boolean.class)). + invokeExact(array, 0, true, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) hs.get(am, methodType(int.class, boolean[].class, int.class, boolean.class, boolean.class)). + invokeExact(array, 0, true, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) hs.get(am, methodType(boolean.class, boolean[].class, int.class, boolean.class, boolean.class, Class.class)). + invokeExact(array, 0, true, true, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null array + boolean x = (boolean) hs.get(am, methodType(boolean.class, boolean[].class, int.class, boolean.class)). + invokeExact((boolean[]) null, 0, true); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, Class.class, int.class, boolean.class)). + invokeExact(Void.class, 0, true); + }); + checkWMTE(() -> { // value reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, boolean[].class, int.class, Class.class)). + invokeExact(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, int.class, int.class, boolean.class)). + invokeExact(0, 0, true); + }); + checkWMTE(() -> { // index reference class + boolean x = (boolean) hs.get(am, methodType(boolean.class, boolean[].class, Class.class, boolean.class)). + invokeExact(array, Void.class, true); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, boolean[].class, int.class, boolean.class)). + invokeExact(array, 0, true); + }); + checkWMTE(() -> { // primitive class + int x = (int) hs.get(am, methodType(int.class, boolean[].class, int.class, boolean.class)). + invokeExact(array, 0, true); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean x = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean x = (boolean) hs.get(am, methodType(boolean.class, boolean[].class, int.class, boolean.class, Class.class)). + invokeExact(array, 0, true, Void.class); + }); + } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeByte.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeByte.java index 0bfddc7ad27..692d667ac05 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeByte.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeByte.java @@ -43,13 +43,13 @@ import static org.testng.Assert.*; import static java.lang.invoke.MethodType.*; public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { - static final byte static_final_v = (byte)1; + static final byte static_final_v = (byte)0x01; - static byte static_v = (byte)1; + static byte static_v = (byte)0x01; - final byte final_v = (byte)1; + final byte final_v = (byte)0x01; - byte v = (byte)1; + byte v = (byte)0x01; VarHandle vhFinalField; @@ -154,23 +154,23 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { // Set // Incorrect argument types checkNPE(() -> { // null receiver - vh.set(null, (byte)1); + vh.set(null, (byte)0x01); }); checkCCE(() -> { // receiver reference class - vh.set(Void.class, (byte)1); + vh.set(Void.class, (byte)0x01); }); checkWMTE(() -> { // value reference class vh.set(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.set(0, (byte)1); + vh.set(0, (byte)0x01); }); // Incorrect arity checkWMTE(() -> { // 0 vh.set(); }); checkWMTE(() -> { // > - vh.set(recv, (byte)1, Void.class); + vh.set(recv, (byte)0x01, Void.class); }); @@ -204,23 +204,23 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { // SetVolatile // Incorrect argument types checkNPE(() -> { // null receiver - vh.setVolatile(null, (byte)1); + vh.setVolatile(null, (byte)0x01); }); checkCCE(() -> { // receiver reference class - vh.setVolatile(Void.class, (byte)1); + vh.setVolatile(Void.class, (byte)0x01); }); checkWMTE(() -> { // value reference class vh.setVolatile(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setVolatile(0, (byte)1); + vh.setVolatile(0, (byte)0x01); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile(recv, (byte)1, Void.class); + vh.setVolatile(recv, (byte)0x01, Void.class); }); @@ -254,23 +254,23 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { // SetOpaque // Incorrect argument types checkNPE(() -> { // null receiver - vh.setOpaque(null, (byte)1); + vh.setOpaque(null, (byte)0x01); }); checkCCE(() -> { // receiver reference class - vh.setOpaque(Void.class, (byte)1); + vh.setOpaque(Void.class, (byte)0x01); }); checkWMTE(() -> { // value reference class vh.setOpaque(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setOpaque(0, (byte)1); + vh.setOpaque(0, (byte)0x01); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque(recv, (byte)1, Void.class); + vh.setOpaque(recv, (byte)0x01, Void.class); }); @@ -304,27 +304,342 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { // SetRelease // Incorrect argument types checkNPE(() -> { // null receiver - vh.setRelease(null, (byte)1); + vh.setRelease(null, (byte)0x01); }); checkCCE(() -> { // receiver reference class - vh.setRelease(Void.class, (byte)1); + vh.setRelease(Void.class, (byte)0x01); }); checkWMTE(() -> { // value reference class vh.setRelease(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setRelease(0, (byte)1); + vh.setRelease(0, (byte)0x01); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease(recv, (byte)1, Void.class); + vh.setRelease(recv, (byte)0x01, Void.class); }); + // CompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.compareAndSet(null, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.compareAndSet(Void.class, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(recv, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(recv, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.compareAndSet(0, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(recv, (byte)0x01, (byte)0x01, Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSet(null, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSet(Void.class, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(recv, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(recv, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSet(0, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(recv, (byte)0x01, (byte)0x01, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetVolatile(null, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(recv, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(recv, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetVolatile(0, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(recv, (byte)0x01, (byte)0x01, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetAcquire(null, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(recv, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(recv, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetAcquire(0, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(recv, (byte)0x01, (byte)0x01, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetRelease(null, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(recv, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(recv, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetRelease(0, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(recv, (byte)0x01, (byte)0x01, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkNPE(() -> { // null receiver + byte x = (byte) vh.compareAndExchange(null, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + byte x = (byte) vh.compareAndExchange(Void.class, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + byte x = (byte) vh.compareAndExchange(recv, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + byte x = (byte) vh.compareAndExchange(recv, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + byte x = (byte) vh.compareAndExchange(0, (byte)0x01, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(recv, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange(recv, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.compareAndExchange(recv, (byte)0x01, (byte)0x01, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + byte x = (byte) vh.compareAndExchangeAcquire(null, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + byte x = (byte) vh.compareAndExchangeAcquire(Void.class, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + byte x = (byte) vh.compareAndExchangeAcquire(recv, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + byte x = (byte) vh.compareAndExchangeAcquire(recv, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + byte x = (byte) vh.compareAndExchangeAcquire(0, (byte)0x01, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(recv, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire(recv, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.compareAndExchangeAcquire(recv, (byte)0x01, (byte)0x01, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + byte x = (byte) vh.compareAndExchangeRelease(null, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + byte x = (byte) vh.compareAndExchangeRelease(Void.class, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + byte x = (byte) vh.compareAndExchangeRelease(recv, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + byte x = (byte) vh.compareAndExchangeRelease(recv, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + byte x = (byte) vh.compareAndExchangeRelease(0, (byte)0x01, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(recv, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease(recv, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.compareAndExchangeRelease(recv, (byte)0x01, (byte)0x01, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + byte x = (byte) vh.getAndSet(null, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + byte x = (byte) vh.getAndSet(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // value reference class + byte x = (byte) vh.getAndSet(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + byte x = (byte) vh.getAndSet(0, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(recv, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet(recv, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.getAndSet(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.getAndSet(recv, (byte)0x01, Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkNPE(() -> { // null receiver + byte x = (byte) vh.getAndAdd(null, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + byte x = (byte) vh.getAndAdd(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // value reference class + byte x = (byte) vh.getAndAdd(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + byte x = (byte) vh.getAndAdd(0, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd(recv, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd(recv, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.getAndAdd(recv, (byte)0x01, Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkNPE(() -> { // null receiver + byte x = (byte) vh.addAndGet(null, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + byte x = (byte) vh.addAndGet(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // value reference class + byte x = (byte) vh.addAndGet(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + byte x = (byte) vh.addAndGet(0, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet(recv, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet(recv, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.addAndGet(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.addAndGet(recv, (byte)0x01, Void.class); + }); } static void testInstanceFieldWrongMethodType(VarHandleTestMethodTypeByte recv, Handles hs) throws Throwable { @@ -366,11 +681,11 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null receiver hs.get(am, methodType(void.class, VarHandleTestMethodTypeByte.class, byte.class)). - invokeExact((VarHandleTestMethodTypeByte) null, (byte)1); + invokeExact((VarHandleTestMethodTypeByte) null, (byte)0x01); }); hs.checkWMTEOrCCE(() -> { // receiver reference class hs.get(am, methodType(void.class, Class.class, byte.class)). - invokeExact(Void.class, (byte)1); + invokeExact(Void.class, (byte)0x01); }); checkWMTE(() -> { // value reference class hs.get(am, methodType(void.class, VarHandleTestMethodTypeByte.class, Class.class)). @@ -378,7 +693,7 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { }); checkWMTE(() -> { // receiver primitive class hs.get(am, methodType(void.class, int.class, byte.class)). - invokeExact(0, (byte)1); + invokeExact(0, (byte)0x01); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -387,11 +702,157 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, VarHandleTestMethodTypeByte.class, byte.class, Class.class)). - invokeExact(recv, (byte)1, Void.class); + invokeExact(recv, (byte)0x01, Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeByte.class, byte.class, byte.class)). + invokeExact((VarHandleTestMethodTypeByte) null, (byte)0x01, (byte)0x01); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, byte.class, byte.class)). + invokeExact(Void.class, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeByte.class, Class.class, byte.class)). + invokeExact(recv, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeByte.class, byte.class, Class.class)). + invokeExact(recv, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class , byte.class, byte.class)). + invokeExact(0, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeByte.class, byte.class, byte.class, Class.class)). + invokeExact(recv, (byte)0x01, (byte)0x01, Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + checkNPE(() -> { // null receiver + byte x = (byte) hs.get(am, methodType(byte.class, VarHandleTestMethodTypeByte.class, byte.class, byte.class)). + invokeExact((VarHandleTestMethodTypeByte) null, (byte)0x01, (byte)0x01); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + byte x = (byte) hs.get(am, methodType(byte.class, Class.class, byte.class, byte.class)). + invokeExact(Void.class, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + byte x = (byte) hs.get(am, methodType(byte.class, VarHandleTestMethodTypeByte.class, Class.class, byte.class)). + invokeExact(recv, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + byte x = (byte) hs.get(am, methodType(byte.class, VarHandleTestMethodTypeByte.class, byte.class, Class.class)). + invokeExact(recv, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + byte x = (byte) hs.get(am, methodType(byte.class, int.class , byte.class, byte.class)). + invokeExact(0, (byte)0x01, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeByte.class , byte.class, byte.class)). + invokeExact(recv, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeByte.class , byte.class, byte.class)). + invokeExact(recv, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) hs.get(am, methodType(byte.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + byte x = (byte) hs.get(am, methodType(byte.class, VarHandleTestMethodTypeByte.class, byte.class, byte.class, Class.class)). + invokeExact(recv, (byte)0x01, (byte)0x01, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + checkNPE(() -> { // null receiver + byte x = (byte) hs.get(am, methodType(byte.class, VarHandleTestMethodTypeByte.class, byte.class)). + invokeExact((VarHandleTestMethodTypeByte) null, (byte)0x01); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + byte x = (byte) hs.get(am, methodType(byte.class, Class.class, byte.class)). + invokeExact(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // value reference class + byte x = (byte) hs.get(am, methodType(byte.class, VarHandleTestMethodTypeByte.class, Class.class)). + invokeExact(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + byte x = (byte) hs.get(am, methodType(byte.class, int.class, byte.class)). + invokeExact(0, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeByte.class, byte.class)). + invokeExact(recv, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeByte.class, byte.class)). + invokeExact(recv, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) hs.get(am, methodType(byte.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + byte x = (byte) hs.get(am, methodType(byte.class, VarHandleTestMethodTypeByte.class, byte.class)). + invokeExact(recv, (byte)0x01, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + checkNPE(() -> { // null receiver + byte x = (byte) hs.get(am, methodType(byte.class, VarHandleTestMethodTypeByte.class, byte.class)). + invokeExact((VarHandleTestMethodTypeByte) null, (byte)0x01); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + byte x = (byte) hs.get(am, methodType(byte.class, Class.class, byte.class)). + invokeExact(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // value reference class + byte x = (byte) hs.get(am, methodType(byte.class, VarHandleTestMethodTypeByte.class, Class.class)). + invokeExact(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + byte x = (byte) hs.get(am, methodType(byte.class, int.class, byte.class)). + invokeExact(0, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeByte.class, byte.class)). + invokeExact(recv, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeByte.class, byte.class)). + invokeExact(recv, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) hs.get(am, methodType(byte.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + byte x = (byte) hs.get(am, methodType(byte.class, VarHandleTestMethodTypeByte.class, byte.class)). + invokeExact(recv, (byte)0x01, Void.class); + }); + } } @@ -420,7 +881,7 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { vh.set(); }); checkWMTE(() -> { // > - vh.set((byte)1, Void.class); + vh.set((byte)0x01, Void.class); }); @@ -447,7 +908,7 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile((byte)1, Void.class); + vh.setVolatile((byte)0x01, Void.class); }); @@ -474,7 +935,7 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque((byte)1, Void.class); + vh.setOpaque((byte)0x01, Void.class); }); @@ -501,11 +962,227 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease((byte)1, Void.class); + vh.setRelease((byte)0x01, Void.class); }); + // CompareAndSet + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet((byte)0x01, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet((byte)0x01, (byte)0x01, Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet((byte)0x01, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet((byte)0x01, (byte)0x01, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile((byte)0x01, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile((byte)0x01, (byte)0x01, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire((byte)0x01, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire((byte)0x01, (byte)0x01, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease((byte)0x01, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease((byte)0x01, (byte)0x01, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkWMTE(() -> { // expected reference class + byte x = (byte) vh.compareAndExchange(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + byte x = (byte) vh.compareAndExchange((byte)0x01, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange((byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange((byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.compareAndExchange((byte)0x01, (byte)0x01, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkWMTE(() -> { // expected reference class + byte x = (byte) vh.compareAndExchangeAcquire(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + byte x = (byte) vh.compareAndExchangeAcquire((byte)0x01, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire((byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire((byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.compareAndExchangeAcquire((byte)0x01, (byte)0x01, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkWMTE(() -> { // expected reference class + byte x = (byte) vh.compareAndExchangeRelease(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + byte x = (byte) vh.compareAndExchangeRelease((byte)0x01, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease((byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease((byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.compareAndExchangeRelease((byte)0x01, (byte)0x01, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkWMTE(() -> { // value reference class + byte x = (byte) vh.getAndSet(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet((byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet((byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.getAndSet(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.getAndSet((byte)0x01, Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkWMTE(() -> { // value reference class + byte x = (byte) vh.getAndAdd(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd((byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd((byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.getAndAdd((byte)0x01, Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkWMTE(() -> { // value reference class + byte x = (byte) vh.addAndGet(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet((byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet((byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.addAndGet(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.addAndGet((byte)0x01, Void.class); + }); } static void testStaticFieldWrongMethodType(Handles hs) throws Throwable { @@ -540,16 +1217,117 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, byte.class, Class.class)). - invokeExact((byte)1, Void.class); + invokeExact((byte)0x01, Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, byte.class)). + invokeExact(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, byte.class, Class.class)). + invokeExact((byte)0x01, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, byte.class, byte.class, Class.class)). + invokeExact((byte)0x01, (byte)0x01, Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + // Incorrect argument types + checkWMTE(() -> { // expected reference class + byte x = (byte) hs.get(am, methodType(byte.class, Class.class, byte.class)). + invokeExact(Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + byte x = (byte) hs.get(am, methodType(byte.class, byte.class, Class.class)). + invokeExact((byte)0x01, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, byte.class, byte.class)). + invokeExact((byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, byte.class, byte.class)). + invokeExact((byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) hs.get(am, methodType(byte.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + byte x = (byte) hs.get(am, methodType(byte.class, byte.class, byte.class, Class.class)). + invokeExact((byte)0x01, (byte)0x01, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + // Incorrect argument types + checkWMTE(() -> { // value reference class + byte x = (byte) hs.get(am, methodType(byte.class, Class.class)). + invokeExact(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, byte.class)). + invokeExact((byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, byte.class)). + invokeExact((byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) hs.get(am, methodType(byte.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + byte x = (byte) hs.get(am, methodType(byte.class, byte.class, Class.class)). + invokeExact((byte)0x01, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + // Incorrect argument types + checkWMTE(() -> { // value reference class + byte x = (byte) hs.get(am, methodType(byte.class, Class.class)). + invokeExact(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, byte.class)). + invokeExact((byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, byte.class)). + invokeExact((byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) hs.get(am, methodType(byte.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + byte x = (byte) hs.get(am, methodType(byte.class, byte.class, Class.class)). + invokeExact((byte)0x01, Void.class); + }); + } } static void testArrayWrongMethodType(VarHandle vh) throws Throwable { byte[] array = new byte[10]; - Arrays.fill(array, (byte)1); + Arrays.fill(array, (byte)0x01); // Get // Incorrect argument types @@ -584,26 +1362,26 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { // Set // Incorrect argument types checkNPE(() -> { // null array - vh.set(null, 0, (byte)1); + vh.set(null, 0, (byte)0x01); }); checkCCE(() -> { // array reference class - vh.set(Void.class, 0, (byte)1); + vh.set(Void.class, 0, (byte)0x01); }); checkWMTE(() -> { // value reference class vh.set(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.set(0, 0, (byte)1); + vh.set(0, 0, (byte)0x01); }); checkWMTE(() -> { // index reference class - vh.set(array, Void.class, (byte)1); + vh.set(array, Void.class, (byte)0x01); }); // Incorrect arity checkWMTE(() -> { // 0 vh.set(); }); checkWMTE(() -> { // > - vh.set(array, 0, (byte)1, Void.class); + vh.set(array, 0, (byte)0x01, Void.class); }); @@ -640,26 +1418,26 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { // SetVolatile // Incorrect argument types checkNPE(() -> { // null array - vh.setVolatile(null, 0, (byte)1); + vh.setVolatile(null, 0, (byte)0x01); }); checkCCE(() -> { // array reference class - vh.setVolatile(Void.class, 0, (byte)1); + vh.setVolatile(Void.class, 0, (byte)0x01); }); checkWMTE(() -> { // value reference class vh.setVolatile(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setVolatile(0, 0, (byte)1); + vh.setVolatile(0, 0, (byte)0x01); }); checkWMTE(() -> { // index reference class - vh.setVolatile(array, Void.class, (byte)1); + vh.setVolatile(array, Void.class, (byte)0x01); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile(array, 0, (byte)1, Void.class); + vh.setVolatile(array, 0, (byte)0x01, Void.class); }); @@ -696,26 +1474,26 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { // SetOpaque // Incorrect argument types checkNPE(() -> { // null array - vh.setOpaque(null, 0, (byte)1); + vh.setOpaque(null, 0, (byte)0x01); }); checkCCE(() -> { // array reference class - vh.setOpaque(Void.class, 0, (byte)1); + vh.setOpaque(Void.class, 0, (byte)0x01); }); checkWMTE(() -> { // value reference class vh.setOpaque(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setOpaque(0, 0, (byte)1); + vh.setOpaque(0, 0, (byte)0x01); }); checkWMTE(() -> { // index reference class - vh.setOpaque(array, Void.class, (byte)1); + vh.setOpaque(array, Void.class, (byte)0x01); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque(array, 0, (byte)1, Void.class); + vh.setOpaque(array, 0, (byte)0x01, Void.class); }); @@ -752,35 +1530,383 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { // SetRelease // Incorrect argument types checkNPE(() -> { // null array - vh.setRelease(null, 0, (byte)1); + vh.setRelease(null, 0, (byte)0x01); }); checkCCE(() -> { // array reference class - vh.setRelease(Void.class, 0, (byte)1); + vh.setRelease(Void.class, 0, (byte)0x01); }); checkWMTE(() -> { // value reference class vh.setRelease(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setRelease(0, 0, (byte)1); + vh.setRelease(0, 0, (byte)0x01); }); checkWMTE(() -> { // index reference class - vh.setRelease(array, Void.class, (byte)1); + vh.setRelease(array, Void.class, (byte)0x01); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease(array, 0, (byte)1, Void.class); + vh.setRelease(array, 0, (byte)0x01, Void.class); }); + // CompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.compareAndSet(null, 0, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.compareAndSet(Void.class, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(array, 0, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(array, 0, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.compareAndSet(0, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.compareAndSet(array, Void.class, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(array, 0, (byte)0x01, (byte)0x01, Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSet(null, 0, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSet(Void.class, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(array, 0, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(array, 0, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSet(0, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSet(array, Void.class, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(array, 0, (byte)0x01, (byte)0x01, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetVolatile(null, 0, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(array, 0, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(array, 0, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetVolatile(0, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetVolatile(array, Void.class, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(array, 0, (byte)0x01, (byte)0x01, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetAcquire(null, 0, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(array, 0, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(array, 0, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetAcquire(0, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetAcquire(array, Void.class, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(array, 0, (byte)0x01, (byte)0x01, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetRelease(null, 0, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(array, 0, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(array, 0, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetRelease(0, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetRelease(array, Void.class, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(array, 0, (byte)0x01, (byte)0x01, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkNPE(() -> { // null receiver + byte x = (byte) vh.compareAndExchange(null, 0, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // array reference class + byte x = (byte) vh.compareAndExchange(Void.class, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + byte x = (byte) vh.compareAndExchange(array, 0, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + byte x = (byte) vh.compareAndExchange(array, 0, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // array primitive class + byte x = (byte) vh.compareAndExchange(0, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + byte x = (byte) vh.compareAndExchange(array, Void.class, (byte)0x01, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(array, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange(array, 0, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.compareAndExchange(array, 0, (byte)0x01, (byte)0x01, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + byte x = (byte) vh.compareAndExchangeAcquire(null, 0, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // array reference class + byte x = (byte) vh.compareAndExchangeAcquire(Void.class, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + byte x = (byte) vh.compareAndExchangeAcquire(array, 0, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + byte x = (byte) vh.compareAndExchangeAcquire(array, 0, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // array primitive class + byte x = (byte) vh.compareAndExchangeAcquire(0, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + byte x = (byte) vh.compareAndExchangeAcquire(array, Void.class, (byte)0x01, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(array, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire(array, 0, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.compareAndExchangeAcquire(array, 0, (byte)0x01, (byte)0x01, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + byte x = (byte) vh.compareAndExchangeRelease(null, 0, (byte)0x01, (byte)0x01); + }); + checkCCE(() -> { // array reference class + byte x = (byte) vh.compareAndExchangeRelease(Void.class, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + byte x = (byte) vh.compareAndExchangeRelease(array, 0, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + byte x = (byte) vh.compareAndExchangeRelease(array, 0, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // array primitive class + byte x = (byte) vh.compareAndExchangeRelease(0, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + byte x = (byte) vh.compareAndExchangeRelease(array, Void.class, (byte)0x01, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(array, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease(array, 0, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.compareAndExchangeRelease(array, 0, (byte)0x01, (byte)0x01, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkNPE(() -> { // null array + byte x = (byte) vh.getAndSet(null, 0, (byte)0x01); + }); + checkCCE(() -> { // array reference class + byte x = (byte) vh.getAndSet(Void.class, 0, (byte)0x01); + }); + checkWMTE(() -> { // value reference class + byte x = (byte) vh.getAndSet(array, 0, Void.class); + }); + checkWMTE(() -> { // reciarrayever primitive class + byte x = (byte) vh.getAndSet(0, 0, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + byte x = (byte) vh.getAndSet(array, Void.class, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(array, 0, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet(array, 0, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.getAndSet(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.getAndSet(array, 0, (byte)0x01, Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkNPE(() -> { // null array + byte x = (byte) vh.getAndAdd(null, 0, (byte)0x01); + }); + checkCCE(() -> { // array reference class + byte x = (byte) vh.getAndAdd(Void.class, 0, (byte)0x01); + }); + checkWMTE(() -> { // value reference class + byte x = (byte) vh.getAndAdd(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + byte x = (byte) vh.getAndAdd(0, 0, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + byte x = (byte) vh.getAndAdd(array, Void.class, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd(array, 0, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd(array, 0, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.getAndAdd(array, 0, (byte)0x01, Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkNPE(() -> { // null array + byte x = (byte) vh.addAndGet(null, 0, (byte)0x01); + }); + checkCCE(() -> { // array reference class + byte x = (byte) vh.addAndGet(Void.class, 0, (byte)0x01); + }); + checkWMTE(() -> { // value reference class + byte x = (byte) vh.addAndGet(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + byte x = (byte) vh.addAndGet(0, 0, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + byte x = (byte) vh.addAndGet(array, Void.class, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet(array, 0, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet(array, 0, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) vh.addAndGet(); + }); + checkWMTE(() -> { // > + byte x = (byte) vh.addAndGet(array, 0, (byte)0x01, Void.class); + }); } static void testArrayWrongMethodType(Handles hs) throws Throwable { byte[] array = new byte[10]; - Arrays.fill(array, (byte)1); + Arrays.fill(array, (byte)0x01); for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET)) { // Incorrect argument types @@ -824,11 +1950,11 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null array hs.get(am, methodType(void.class, byte[].class, int.class, byte.class)). - invokeExact((byte[]) null, 0, (byte)1); + invokeExact((byte[]) null, 0, (byte)0x01); }); hs.checkWMTEOrCCE(() -> { // array reference class hs.get(am, methodType(void.class, Class.class, int.class, byte.class)). - invokeExact(Void.class, 0, (byte)1); + invokeExact(Void.class, 0, (byte)0x01); }); checkWMTE(() -> { // value reference class hs.get(am, methodType(void.class, byte[].class, int.class, Class.class)). @@ -836,11 +1962,11 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { }); checkWMTE(() -> { // receiver primitive class hs.get(am, methodType(void.class, int.class, int.class, byte.class)). - invokeExact(0, 0, (byte)1); + invokeExact(0, 0, (byte)0x01); }); checkWMTE(() -> { // index reference class hs.get(am, methodType(void.class, byte[].class, Class.class, byte.class)). - invokeExact(array, Void.class, (byte)1); + invokeExact(array, Void.class, (byte)0x01); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -849,10 +1975,175 @@ public class VarHandleTestMethodTypeByte extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, byte[].class, int.class, Class.class)). - invokeExact(array, 0, (byte)1, Void.class); + invokeExact(array, 0, (byte)0x01, Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = (boolean) hs.get(am, methodType(boolean.class, byte[].class, int.class, byte.class, byte.class)). + invokeExact((byte[]) null, 0, (byte)0x01, (byte)0x01); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, int.class, byte.class, byte.class)). + invokeExact(Void.class, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, byte[].class, int.class, Class.class, byte.class)). + invokeExact(array, 0, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, byte[].class, int.class, byte.class, Class.class)). + invokeExact(array, 0, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class, int.class, byte.class, byte.class)). + invokeExact(0, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, byte[].class, Class.class, byte.class, byte.class)). + invokeExact(array, Void.class, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, byte[].class, int.class, byte.class, byte.class, Class.class)). + invokeExact(array, 0, (byte)0x01, (byte)0x01, Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + byte x = (byte) hs.get(am, methodType(byte.class, byte[].class, int.class, byte.class, byte.class)). + invokeExact((byte[]) null, 0, (byte)0x01, (byte)0x01); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + byte x = (byte) hs.get(am, methodType(byte.class, Class.class, int.class, byte.class, byte.class)). + invokeExact(Void.class, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // expected reference class + byte x = (byte) hs.get(am, methodType(byte.class, byte[].class, int.class, Class.class, byte.class)). + invokeExact(array, 0, Void.class, (byte)0x01); + }); + checkWMTE(() -> { // actual reference class + byte x = (byte) hs.get(am, methodType(byte.class, byte[].class, int.class, byte.class, Class.class)). + invokeExact(array, 0, (byte)0x01, Void.class); + }); + checkWMTE(() -> { // array primitive class + byte x = (byte) hs.get(am, methodType(byte.class, int.class, int.class, byte.class, byte.class)). + invokeExact(0, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + byte x = (byte) hs.get(am, methodType(byte.class, byte[].class, Class.class, byte.class, byte.class)). + invokeExact(array, Void.class, (byte)0x01, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, byte[].class, int.class, byte.class, byte.class)). + invokeExact(array, 0, (byte)0x01, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, byte[].class, int.class, byte.class, byte.class)). + invokeExact(array, 0, (byte)0x01, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) hs.get(am, methodType(byte.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + byte x = (byte) hs.get(am, methodType(byte.class, byte[].class, int.class, byte.class, byte.class, Class.class)). + invokeExact(array, 0, (byte)0x01, (byte)0x01, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null array + byte x = (byte) hs.get(am, methodType(byte.class, byte[].class, int.class, byte.class)). + invokeExact((byte[]) null, 0, (byte)0x01); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + byte x = (byte) hs.get(am, methodType(byte.class, Class.class, int.class, byte.class)). + invokeExact(Void.class, 0, (byte)0x01); + }); + checkWMTE(() -> { // value reference class + byte x = (byte) hs.get(am, methodType(byte.class, byte[].class, int.class, Class.class)). + invokeExact(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + byte x = (byte) hs.get(am, methodType(byte.class, int.class, int.class, byte.class)). + invokeExact(0, 0, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + byte x = (byte) hs.get(am, methodType(byte.class, byte[].class, Class.class, byte.class)). + invokeExact(array, Void.class, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, byte[].class, int.class, byte.class)). + invokeExact(array, 0, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, byte[].class, int.class, byte.class)). + invokeExact(array, 0, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) hs.get(am, methodType(byte.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + byte x = (byte) hs.get(am, methodType(byte.class, byte[].class, int.class, byte.class, Class.class)). + invokeExact(array, 0, (byte)0x01, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + // Incorrect argument types + checkNPE(() -> { // null array + byte x = (byte) hs.get(am, methodType(byte.class, byte[].class, int.class, byte.class)). + invokeExact((byte[]) null, 0, (byte)0x01); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + byte x = (byte) hs.get(am, methodType(byte.class, Class.class, int.class, byte.class)). + invokeExact(Void.class, 0, (byte)0x01); + }); + checkWMTE(() -> { // value reference class + byte x = (byte) hs.get(am, methodType(byte.class, byte[].class, int.class, Class.class)). + invokeExact(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + byte x = (byte) hs.get(am, methodType(byte.class, int.class, int.class, byte.class)). + invokeExact(0, 0, (byte)0x01); + }); + checkWMTE(() -> { // index reference class + byte x = (byte) hs.get(am, methodType(byte.class, byte[].class, Class.class, byte.class)). + invokeExact(array, Void.class, (byte)0x01); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, byte[].class, int.class, byte.class)). + invokeExact(array, 0, (byte)0x01); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, byte[].class, int.class, byte.class)). + invokeExact(array, 0, (byte)0x01); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + byte x = (byte) hs.get(am, methodType(byte.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + byte x = (byte) hs.get(am, methodType(byte.class, byte[].class, int.class, byte.class, Class.class)). + invokeExact(array, 0, (byte)0x01, Void.class); + }); + } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeChar.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeChar.java index 8d5166d8644..268e521f294 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeChar.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeChar.java @@ -43,13 +43,13 @@ import static org.testng.Assert.*; import static java.lang.invoke.MethodType.*; public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { - static final char static_final_v = 'a'; + static final char static_final_v = '\u0123'; - static char static_v = 'a'; + static char static_v = '\u0123'; - final char final_v = 'a'; + final char final_v = '\u0123'; - char v = 'a'; + char v = '\u0123'; VarHandle vhFinalField; @@ -154,23 +154,23 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { // Set // Incorrect argument types checkNPE(() -> { // null receiver - vh.set(null, 'a'); + vh.set(null, '\u0123'); }); checkCCE(() -> { // receiver reference class - vh.set(Void.class, 'a'); + vh.set(Void.class, '\u0123'); }); checkWMTE(() -> { // value reference class vh.set(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.set(0, 'a'); + vh.set(0, '\u0123'); }); // Incorrect arity checkWMTE(() -> { // 0 vh.set(); }); checkWMTE(() -> { // > - vh.set(recv, 'a', Void.class); + vh.set(recv, '\u0123', Void.class); }); @@ -204,23 +204,23 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { // SetVolatile // Incorrect argument types checkNPE(() -> { // null receiver - vh.setVolatile(null, 'a'); + vh.setVolatile(null, '\u0123'); }); checkCCE(() -> { // receiver reference class - vh.setVolatile(Void.class, 'a'); + vh.setVolatile(Void.class, '\u0123'); }); checkWMTE(() -> { // value reference class vh.setVolatile(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setVolatile(0, 'a'); + vh.setVolatile(0, '\u0123'); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile(recv, 'a', Void.class); + vh.setVolatile(recv, '\u0123', Void.class); }); @@ -254,23 +254,23 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { // SetOpaque // Incorrect argument types checkNPE(() -> { // null receiver - vh.setOpaque(null, 'a'); + vh.setOpaque(null, '\u0123'); }); checkCCE(() -> { // receiver reference class - vh.setOpaque(Void.class, 'a'); + vh.setOpaque(Void.class, '\u0123'); }); checkWMTE(() -> { // value reference class vh.setOpaque(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setOpaque(0, 'a'); + vh.setOpaque(0, '\u0123'); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque(recv, 'a', Void.class); + vh.setOpaque(recv, '\u0123', Void.class); }); @@ -304,27 +304,342 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { // SetRelease // Incorrect argument types checkNPE(() -> { // null receiver - vh.setRelease(null, 'a'); + vh.setRelease(null, '\u0123'); }); checkCCE(() -> { // receiver reference class - vh.setRelease(Void.class, 'a'); + vh.setRelease(Void.class, '\u0123'); }); checkWMTE(() -> { // value reference class vh.setRelease(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setRelease(0, 'a'); + vh.setRelease(0, '\u0123'); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease(recv, 'a', Void.class); + vh.setRelease(recv, '\u0123', Void.class); }); + // CompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.compareAndSet(null, '\u0123', '\u0123'); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.compareAndSet(Void.class, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(recv, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(recv, '\u0123', Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.compareAndSet(0, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(recv, '\u0123', '\u0123', Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSet(null, '\u0123', '\u0123'); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSet(Void.class, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(recv, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(recv, '\u0123', Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSet(0, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(recv, '\u0123', '\u0123', Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetVolatile(null, '\u0123', '\u0123'); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(recv, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(recv, '\u0123', Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetVolatile(0, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(recv, '\u0123', '\u0123', Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetAcquire(null, '\u0123', '\u0123'); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(recv, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(recv, '\u0123', Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetAcquire(0, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(recv, '\u0123', '\u0123', Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetRelease(null, '\u0123', '\u0123'); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(recv, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(recv, '\u0123', Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetRelease(0, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(recv, '\u0123', '\u0123', Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkNPE(() -> { // null receiver + char x = (char) vh.compareAndExchange(null, '\u0123', '\u0123'); + }); + checkCCE(() -> { // receiver reference class + char x = (char) vh.compareAndExchange(Void.class, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + char x = (char) vh.compareAndExchange(recv, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + char x = (char) vh.compareAndExchange(recv, '\u0123', Void.class); + }); + checkWMTE(() -> { // reciever primitive class + char x = (char) vh.compareAndExchange(0, '\u0123', '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(recv, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange(recv, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + char x = (char) vh.compareAndExchange(recv, '\u0123', '\u0123', Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + char x = (char) vh.compareAndExchangeAcquire(null, '\u0123', '\u0123'); + }); + checkCCE(() -> { // receiver reference class + char x = (char) vh.compareAndExchangeAcquire(Void.class, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + char x = (char) vh.compareAndExchangeAcquire(recv, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + char x = (char) vh.compareAndExchangeAcquire(recv, '\u0123', Void.class); + }); + checkWMTE(() -> { // reciever primitive class + char x = (char) vh.compareAndExchangeAcquire(0, '\u0123', '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(recv, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire(recv, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + char x = (char) vh.compareAndExchangeAcquire(recv, '\u0123', '\u0123', Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + char x = (char) vh.compareAndExchangeRelease(null, '\u0123', '\u0123'); + }); + checkCCE(() -> { // receiver reference class + char x = (char) vh.compareAndExchangeRelease(Void.class, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + char x = (char) vh.compareAndExchangeRelease(recv, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + char x = (char) vh.compareAndExchangeRelease(recv, '\u0123', Void.class); + }); + checkWMTE(() -> { // reciever primitive class + char x = (char) vh.compareAndExchangeRelease(0, '\u0123', '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(recv, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease(recv, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + char x = (char) vh.compareAndExchangeRelease(recv, '\u0123', '\u0123', Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + char x = (char) vh.getAndSet(null, '\u0123'); + }); + checkCCE(() -> { // receiver reference class + char x = (char) vh.getAndSet(Void.class, '\u0123'); + }); + checkWMTE(() -> { // value reference class + char x = (char) vh.getAndSet(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + char x = (char) vh.getAndSet(0, '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(recv, '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet(recv, '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.getAndSet(); + }); + checkWMTE(() -> { // > + char x = (char) vh.getAndSet(recv, '\u0123', Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkNPE(() -> { // null receiver + char x = (char) vh.getAndAdd(null, '\u0123'); + }); + checkCCE(() -> { // receiver reference class + char x = (char) vh.getAndAdd(Void.class, '\u0123'); + }); + checkWMTE(() -> { // value reference class + char x = (char) vh.getAndAdd(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + char x = (char) vh.getAndAdd(0, '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd(recv, '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd(recv, '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + char x = (char) vh.getAndAdd(recv, '\u0123', Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkNPE(() -> { // null receiver + char x = (char) vh.addAndGet(null, '\u0123'); + }); + checkCCE(() -> { // receiver reference class + char x = (char) vh.addAndGet(Void.class, '\u0123'); + }); + checkWMTE(() -> { // value reference class + char x = (char) vh.addAndGet(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + char x = (char) vh.addAndGet(0, '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet(recv, '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet(recv, '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.addAndGet(); + }); + checkWMTE(() -> { // > + char x = (char) vh.addAndGet(recv, '\u0123', Void.class); + }); } static void testInstanceFieldWrongMethodType(VarHandleTestMethodTypeChar recv, Handles hs) throws Throwable { @@ -366,11 +681,11 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null receiver hs.get(am, methodType(void.class, VarHandleTestMethodTypeChar.class, char.class)). - invokeExact((VarHandleTestMethodTypeChar) null, 'a'); + invokeExact((VarHandleTestMethodTypeChar) null, '\u0123'); }); hs.checkWMTEOrCCE(() -> { // receiver reference class hs.get(am, methodType(void.class, Class.class, char.class)). - invokeExact(Void.class, 'a'); + invokeExact(Void.class, '\u0123'); }); checkWMTE(() -> { // value reference class hs.get(am, methodType(void.class, VarHandleTestMethodTypeChar.class, Class.class)). @@ -378,7 +693,7 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { }); checkWMTE(() -> { // receiver primitive class hs.get(am, methodType(void.class, int.class, char.class)). - invokeExact(0, 'a'); + invokeExact(0, '\u0123'); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -387,11 +702,157 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, VarHandleTestMethodTypeChar.class, char.class, Class.class)). - invokeExact(recv, 'a', Void.class); + invokeExact(recv, '\u0123', Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeChar.class, char.class, char.class)). + invokeExact((VarHandleTestMethodTypeChar) null, '\u0123', '\u0123'); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, char.class, char.class)). + invokeExact(Void.class, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeChar.class, Class.class, char.class)). + invokeExact(recv, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeChar.class, char.class, Class.class)). + invokeExact(recv, '\u0123', Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class , char.class, char.class)). + invokeExact(0, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeChar.class, char.class, char.class, Class.class)). + invokeExact(recv, '\u0123', '\u0123', Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + checkNPE(() -> { // null receiver + char x = (char) hs.get(am, methodType(char.class, VarHandleTestMethodTypeChar.class, char.class, char.class)). + invokeExact((VarHandleTestMethodTypeChar) null, '\u0123', '\u0123'); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + char x = (char) hs.get(am, methodType(char.class, Class.class, char.class, char.class)). + invokeExact(Void.class, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + char x = (char) hs.get(am, methodType(char.class, VarHandleTestMethodTypeChar.class, Class.class, char.class)). + invokeExact(recv, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + char x = (char) hs.get(am, methodType(char.class, VarHandleTestMethodTypeChar.class, char.class, Class.class)). + invokeExact(recv, '\u0123', Void.class); + }); + checkWMTE(() -> { // reciever primitive class + char x = (char) hs.get(am, methodType(char.class, int.class , char.class, char.class)). + invokeExact(0, '\u0123', '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeChar.class , char.class, char.class)). + invokeExact(recv, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeChar.class , char.class, char.class)). + invokeExact(recv, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) hs.get(am, methodType(char.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + char x = (char) hs.get(am, methodType(char.class, VarHandleTestMethodTypeChar.class, char.class, char.class, Class.class)). + invokeExact(recv, '\u0123', '\u0123', Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + checkNPE(() -> { // null receiver + char x = (char) hs.get(am, methodType(char.class, VarHandleTestMethodTypeChar.class, char.class)). + invokeExact((VarHandleTestMethodTypeChar) null, '\u0123'); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + char x = (char) hs.get(am, methodType(char.class, Class.class, char.class)). + invokeExact(Void.class, '\u0123'); + }); + checkWMTE(() -> { // value reference class + char x = (char) hs.get(am, methodType(char.class, VarHandleTestMethodTypeChar.class, Class.class)). + invokeExact(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + char x = (char) hs.get(am, methodType(char.class, int.class, char.class)). + invokeExact(0, '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeChar.class, char.class)). + invokeExact(recv, '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeChar.class, char.class)). + invokeExact(recv, '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) hs.get(am, methodType(char.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + char x = (char) hs.get(am, methodType(char.class, VarHandleTestMethodTypeChar.class, char.class)). + invokeExact(recv, '\u0123', Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + checkNPE(() -> { // null receiver + char x = (char) hs.get(am, methodType(char.class, VarHandleTestMethodTypeChar.class, char.class)). + invokeExact((VarHandleTestMethodTypeChar) null, '\u0123'); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + char x = (char) hs.get(am, methodType(char.class, Class.class, char.class)). + invokeExact(Void.class, '\u0123'); + }); + checkWMTE(() -> { // value reference class + char x = (char) hs.get(am, methodType(char.class, VarHandleTestMethodTypeChar.class, Class.class)). + invokeExact(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + char x = (char) hs.get(am, methodType(char.class, int.class, char.class)). + invokeExact(0, '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeChar.class, char.class)). + invokeExact(recv, '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeChar.class, char.class)). + invokeExact(recv, '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) hs.get(am, methodType(char.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + char x = (char) hs.get(am, methodType(char.class, VarHandleTestMethodTypeChar.class, char.class)). + invokeExact(recv, '\u0123', Void.class); + }); + } } @@ -420,7 +881,7 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { vh.set(); }); checkWMTE(() -> { // > - vh.set('a', Void.class); + vh.set('\u0123', Void.class); }); @@ -447,7 +908,7 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile('a', Void.class); + vh.setVolatile('\u0123', Void.class); }); @@ -474,7 +935,7 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque('a', Void.class); + vh.setOpaque('\u0123', Void.class); }); @@ -501,11 +962,227 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease('a', Void.class); + vh.setRelease('\u0123', Void.class); }); + // CompareAndSet + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet('\u0123', Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet('\u0123', '\u0123', Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet('\u0123', Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet('\u0123', '\u0123', Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile('\u0123', Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile('\u0123', '\u0123', Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire('\u0123', Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire('\u0123', '\u0123', Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease('\u0123', Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease('\u0123', '\u0123', Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkWMTE(() -> { // expected reference class + char x = (char) vh.compareAndExchange(Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + char x = (char) vh.compareAndExchange('\u0123', Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange('\u0123', '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange('\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + char x = (char) vh.compareAndExchange('\u0123', '\u0123', Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkWMTE(() -> { // expected reference class + char x = (char) vh.compareAndExchangeAcquire(Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + char x = (char) vh.compareAndExchangeAcquire('\u0123', Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire('\u0123', '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire('\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + char x = (char) vh.compareAndExchangeAcquire('\u0123', '\u0123', Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkWMTE(() -> { // expected reference class + char x = (char) vh.compareAndExchangeRelease(Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + char x = (char) vh.compareAndExchangeRelease('\u0123', Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease('\u0123', '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease('\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + char x = (char) vh.compareAndExchangeRelease('\u0123', '\u0123', Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkWMTE(() -> { // value reference class + char x = (char) vh.getAndSet(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet('\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet('\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.getAndSet(); + }); + checkWMTE(() -> { // > + char x = (char) vh.getAndSet('\u0123', Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkWMTE(() -> { // value reference class + char x = (char) vh.getAndAdd(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd('\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd('\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + char x = (char) vh.getAndAdd('\u0123', Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkWMTE(() -> { // value reference class + char x = (char) vh.addAndGet(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet('\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet('\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.addAndGet(); + }); + checkWMTE(() -> { // > + char x = (char) vh.addAndGet('\u0123', Void.class); + }); } static void testStaticFieldWrongMethodType(Handles hs) throws Throwable { @@ -540,16 +1217,117 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, char.class, Class.class)). - invokeExact('a', Void.class); + invokeExact('\u0123', Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, char.class)). + invokeExact(Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, char.class, Class.class)). + invokeExact('\u0123', Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, char.class, char.class, Class.class)). + invokeExact('\u0123', '\u0123', Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + // Incorrect argument types + checkWMTE(() -> { // expected reference class + char x = (char) hs.get(am, methodType(char.class, Class.class, char.class)). + invokeExact(Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + char x = (char) hs.get(am, methodType(char.class, char.class, Class.class)). + invokeExact('\u0123', Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, char.class, char.class)). + invokeExact('\u0123', '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, char.class, char.class)). + invokeExact('\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) hs.get(am, methodType(char.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + char x = (char) hs.get(am, methodType(char.class, char.class, char.class, Class.class)). + invokeExact('\u0123', '\u0123', Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + // Incorrect argument types + checkWMTE(() -> { // value reference class + char x = (char) hs.get(am, methodType(char.class, Class.class)). + invokeExact(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, char.class)). + invokeExact('\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, char.class)). + invokeExact('\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) hs.get(am, methodType(char.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + char x = (char) hs.get(am, methodType(char.class, char.class, Class.class)). + invokeExact('\u0123', Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + // Incorrect argument types + checkWMTE(() -> { // value reference class + char x = (char) hs.get(am, methodType(char.class, Class.class)). + invokeExact(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, char.class)). + invokeExact('\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, char.class)). + invokeExact('\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) hs.get(am, methodType(char.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + char x = (char) hs.get(am, methodType(char.class, char.class, Class.class)). + invokeExact('\u0123', Void.class); + }); + } } static void testArrayWrongMethodType(VarHandle vh) throws Throwable { char[] array = new char[10]; - Arrays.fill(array, 'a'); + Arrays.fill(array, '\u0123'); // Get // Incorrect argument types @@ -584,26 +1362,26 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { // Set // Incorrect argument types checkNPE(() -> { // null array - vh.set(null, 0, 'a'); + vh.set(null, 0, '\u0123'); }); checkCCE(() -> { // array reference class - vh.set(Void.class, 0, 'a'); + vh.set(Void.class, 0, '\u0123'); }); checkWMTE(() -> { // value reference class vh.set(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.set(0, 0, 'a'); + vh.set(0, 0, '\u0123'); }); checkWMTE(() -> { // index reference class - vh.set(array, Void.class, 'a'); + vh.set(array, Void.class, '\u0123'); }); // Incorrect arity checkWMTE(() -> { // 0 vh.set(); }); checkWMTE(() -> { // > - vh.set(array, 0, 'a', Void.class); + vh.set(array, 0, '\u0123', Void.class); }); @@ -640,26 +1418,26 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { // SetVolatile // Incorrect argument types checkNPE(() -> { // null array - vh.setVolatile(null, 0, 'a'); + vh.setVolatile(null, 0, '\u0123'); }); checkCCE(() -> { // array reference class - vh.setVolatile(Void.class, 0, 'a'); + vh.setVolatile(Void.class, 0, '\u0123'); }); checkWMTE(() -> { // value reference class vh.setVolatile(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setVolatile(0, 0, 'a'); + vh.setVolatile(0, 0, '\u0123'); }); checkWMTE(() -> { // index reference class - vh.setVolatile(array, Void.class, 'a'); + vh.setVolatile(array, Void.class, '\u0123'); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile(array, 0, 'a', Void.class); + vh.setVolatile(array, 0, '\u0123', Void.class); }); @@ -696,26 +1474,26 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { // SetOpaque // Incorrect argument types checkNPE(() -> { // null array - vh.setOpaque(null, 0, 'a'); + vh.setOpaque(null, 0, '\u0123'); }); checkCCE(() -> { // array reference class - vh.setOpaque(Void.class, 0, 'a'); + vh.setOpaque(Void.class, 0, '\u0123'); }); checkWMTE(() -> { // value reference class vh.setOpaque(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setOpaque(0, 0, 'a'); + vh.setOpaque(0, 0, '\u0123'); }); checkWMTE(() -> { // index reference class - vh.setOpaque(array, Void.class, 'a'); + vh.setOpaque(array, Void.class, '\u0123'); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque(array, 0, 'a', Void.class); + vh.setOpaque(array, 0, '\u0123', Void.class); }); @@ -752,35 +1530,383 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { // SetRelease // Incorrect argument types checkNPE(() -> { // null array - vh.setRelease(null, 0, 'a'); + vh.setRelease(null, 0, '\u0123'); }); checkCCE(() -> { // array reference class - vh.setRelease(Void.class, 0, 'a'); + vh.setRelease(Void.class, 0, '\u0123'); }); checkWMTE(() -> { // value reference class vh.setRelease(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setRelease(0, 0, 'a'); + vh.setRelease(0, 0, '\u0123'); }); checkWMTE(() -> { // index reference class - vh.setRelease(array, Void.class, 'a'); + vh.setRelease(array, Void.class, '\u0123'); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease(array, 0, 'a', Void.class); + vh.setRelease(array, 0, '\u0123', Void.class); }); + // CompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.compareAndSet(null, 0, '\u0123', '\u0123'); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.compareAndSet(Void.class, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(array, 0, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(array, 0, '\u0123', Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.compareAndSet(0, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.compareAndSet(array, Void.class, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(array, 0, '\u0123', '\u0123', Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSet(null, 0, '\u0123', '\u0123'); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSet(Void.class, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(array, 0, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(array, 0, '\u0123', Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSet(0, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSet(array, Void.class, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(array, 0, '\u0123', '\u0123', Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetVolatile(null, 0, '\u0123', '\u0123'); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(array, 0, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(array, 0, '\u0123', Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetVolatile(0, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetVolatile(array, Void.class, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(array, 0, '\u0123', '\u0123', Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetAcquire(null, 0, '\u0123', '\u0123'); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(array, 0, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(array, 0, '\u0123', Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetAcquire(0, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetAcquire(array, Void.class, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(array, 0, '\u0123', '\u0123', Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetRelease(null, 0, '\u0123', '\u0123'); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(array, 0, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(array, 0, '\u0123', Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetRelease(0, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetRelease(array, Void.class, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(array, 0, '\u0123', '\u0123', Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkNPE(() -> { // null receiver + char x = (char) vh.compareAndExchange(null, 0, '\u0123', '\u0123'); + }); + checkCCE(() -> { // array reference class + char x = (char) vh.compareAndExchange(Void.class, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + char x = (char) vh.compareAndExchange(array, 0, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + char x = (char) vh.compareAndExchange(array, 0, '\u0123', Void.class); + }); + checkWMTE(() -> { // array primitive class + char x = (char) vh.compareAndExchange(0, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // index reference class + char x = (char) vh.compareAndExchange(array, Void.class, '\u0123', '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(array, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange(array, 0, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + char x = (char) vh.compareAndExchange(array, 0, '\u0123', '\u0123', Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + char x = (char) vh.compareAndExchangeAcquire(null, 0, '\u0123', '\u0123'); + }); + checkCCE(() -> { // array reference class + char x = (char) vh.compareAndExchangeAcquire(Void.class, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + char x = (char) vh.compareAndExchangeAcquire(array, 0, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + char x = (char) vh.compareAndExchangeAcquire(array, 0, '\u0123', Void.class); + }); + checkWMTE(() -> { // array primitive class + char x = (char) vh.compareAndExchangeAcquire(0, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // index reference class + char x = (char) vh.compareAndExchangeAcquire(array, Void.class, '\u0123', '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(array, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire(array, 0, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + char x = (char) vh.compareAndExchangeAcquire(array, 0, '\u0123', '\u0123', Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + char x = (char) vh.compareAndExchangeRelease(null, 0, '\u0123', '\u0123'); + }); + checkCCE(() -> { // array reference class + char x = (char) vh.compareAndExchangeRelease(Void.class, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + char x = (char) vh.compareAndExchangeRelease(array, 0, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + char x = (char) vh.compareAndExchangeRelease(array, 0, '\u0123', Void.class); + }); + checkWMTE(() -> { // array primitive class + char x = (char) vh.compareAndExchangeRelease(0, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // index reference class + char x = (char) vh.compareAndExchangeRelease(array, Void.class, '\u0123', '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(array, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease(array, 0, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + char x = (char) vh.compareAndExchangeRelease(array, 0, '\u0123', '\u0123', Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkNPE(() -> { // null array + char x = (char) vh.getAndSet(null, 0, '\u0123'); + }); + checkCCE(() -> { // array reference class + char x = (char) vh.getAndSet(Void.class, 0, '\u0123'); + }); + checkWMTE(() -> { // value reference class + char x = (char) vh.getAndSet(array, 0, Void.class); + }); + checkWMTE(() -> { // reciarrayever primitive class + char x = (char) vh.getAndSet(0, 0, '\u0123'); + }); + checkWMTE(() -> { // index reference class + char x = (char) vh.getAndSet(array, Void.class, '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(array, 0, '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet(array, 0, '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.getAndSet(); + }); + checkWMTE(() -> { // > + char x = (char) vh.getAndSet(array, 0, '\u0123', Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkNPE(() -> { // null array + char x = (char) vh.getAndAdd(null, 0, '\u0123'); + }); + checkCCE(() -> { // array reference class + char x = (char) vh.getAndAdd(Void.class, 0, '\u0123'); + }); + checkWMTE(() -> { // value reference class + char x = (char) vh.getAndAdd(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + char x = (char) vh.getAndAdd(0, 0, '\u0123'); + }); + checkWMTE(() -> { // index reference class + char x = (char) vh.getAndAdd(array, Void.class, '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd(array, 0, '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd(array, 0, '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + char x = (char) vh.getAndAdd(array, 0, '\u0123', Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkNPE(() -> { // null array + char x = (char) vh.addAndGet(null, 0, '\u0123'); + }); + checkCCE(() -> { // array reference class + char x = (char) vh.addAndGet(Void.class, 0, '\u0123'); + }); + checkWMTE(() -> { // value reference class + char x = (char) vh.addAndGet(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + char x = (char) vh.addAndGet(0, 0, '\u0123'); + }); + checkWMTE(() -> { // index reference class + char x = (char) vh.addAndGet(array, Void.class, '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet(array, 0, '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet(array, 0, '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) vh.addAndGet(); + }); + checkWMTE(() -> { // > + char x = (char) vh.addAndGet(array, 0, '\u0123', Void.class); + }); } static void testArrayWrongMethodType(Handles hs) throws Throwable { char[] array = new char[10]; - Arrays.fill(array, 'a'); + Arrays.fill(array, '\u0123'); for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET)) { // Incorrect argument types @@ -824,11 +1950,11 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null array hs.get(am, methodType(void.class, char[].class, int.class, char.class)). - invokeExact((char[]) null, 0, 'a'); + invokeExact((char[]) null, 0, '\u0123'); }); hs.checkWMTEOrCCE(() -> { // array reference class hs.get(am, methodType(void.class, Class.class, int.class, char.class)). - invokeExact(Void.class, 0, 'a'); + invokeExact(Void.class, 0, '\u0123'); }); checkWMTE(() -> { // value reference class hs.get(am, methodType(void.class, char[].class, int.class, Class.class)). @@ -836,11 +1962,11 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { }); checkWMTE(() -> { // receiver primitive class hs.get(am, methodType(void.class, int.class, int.class, char.class)). - invokeExact(0, 0, 'a'); + invokeExact(0, 0, '\u0123'); }); checkWMTE(() -> { // index reference class hs.get(am, methodType(void.class, char[].class, Class.class, char.class)). - invokeExact(array, Void.class, 'a'); + invokeExact(array, Void.class, '\u0123'); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -849,10 +1975,175 @@ public class VarHandleTestMethodTypeChar extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, char[].class, int.class, Class.class)). - invokeExact(array, 0, 'a', Void.class); + invokeExact(array, 0, '\u0123', Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = (boolean) hs.get(am, methodType(boolean.class, char[].class, int.class, char.class, char.class)). + invokeExact((char[]) null, 0, '\u0123', '\u0123'); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, int.class, char.class, char.class)). + invokeExact(Void.class, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, char[].class, int.class, Class.class, char.class)). + invokeExact(array, 0, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, char[].class, int.class, char.class, Class.class)). + invokeExact(array, 0, '\u0123', Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class, int.class, char.class, char.class)). + invokeExact(0, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // index reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, char[].class, Class.class, char.class, char.class)). + invokeExact(array, Void.class, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, char[].class, int.class, char.class, char.class, Class.class)). + invokeExact(array, 0, '\u0123', '\u0123', Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + char x = (char) hs.get(am, methodType(char.class, char[].class, int.class, char.class, char.class)). + invokeExact((char[]) null, 0, '\u0123', '\u0123'); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + char x = (char) hs.get(am, methodType(char.class, Class.class, int.class, char.class, char.class)). + invokeExact(Void.class, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // expected reference class + char x = (char) hs.get(am, methodType(char.class, char[].class, int.class, Class.class, char.class)). + invokeExact(array, 0, Void.class, '\u0123'); + }); + checkWMTE(() -> { // actual reference class + char x = (char) hs.get(am, methodType(char.class, char[].class, int.class, char.class, Class.class)). + invokeExact(array, 0, '\u0123', Void.class); + }); + checkWMTE(() -> { // array primitive class + char x = (char) hs.get(am, methodType(char.class, int.class, int.class, char.class, char.class)). + invokeExact(0, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // index reference class + char x = (char) hs.get(am, methodType(char.class, char[].class, Class.class, char.class, char.class)). + invokeExact(array, Void.class, '\u0123', '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, char[].class, int.class, char.class, char.class)). + invokeExact(array, 0, '\u0123', '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, char[].class, int.class, char.class, char.class)). + invokeExact(array, 0, '\u0123', '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) hs.get(am, methodType(char.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + char x = (char) hs.get(am, methodType(char.class, char[].class, int.class, char.class, char.class, Class.class)). + invokeExact(array, 0, '\u0123', '\u0123', Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null array + char x = (char) hs.get(am, methodType(char.class, char[].class, int.class, char.class)). + invokeExact((char[]) null, 0, '\u0123'); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + char x = (char) hs.get(am, methodType(char.class, Class.class, int.class, char.class)). + invokeExact(Void.class, 0, '\u0123'); + }); + checkWMTE(() -> { // value reference class + char x = (char) hs.get(am, methodType(char.class, char[].class, int.class, Class.class)). + invokeExact(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + char x = (char) hs.get(am, methodType(char.class, int.class, int.class, char.class)). + invokeExact(0, 0, '\u0123'); + }); + checkWMTE(() -> { // index reference class + char x = (char) hs.get(am, methodType(char.class, char[].class, Class.class, char.class)). + invokeExact(array, Void.class, '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, char[].class, int.class, char.class)). + invokeExact(array, 0, '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, char[].class, int.class, char.class)). + invokeExact(array, 0, '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) hs.get(am, methodType(char.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + char x = (char) hs.get(am, methodType(char.class, char[].class, int.class, char.class, Class.class)). + invokeExact(array, 0, '\u0123', Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + // Incorrect argument types + checkNPE(() -> { // null array + char x = (char) hs.get(am, methodType(char.class, char[].class, int.class, char.class)). + invokeExact((char[]) null, 0, '\u0123'); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + char x = (char) hs.get(am, methodType(char.class, Class.class, int.class, char.class)). + invokeExact(Void.class, 0, '\u0123'); + }); + checkWMTE(() -> { // value reference class + char x = (char) hs.get(am, methodType(char.class, char[].class, int.class, Class.class)). + invokeExact(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + char x = (char) hs.get(am, methodType(char.class, int.class, int.class, char.class)). + invokeExact(0, 0, '\u0123'); + }); + checkWMTE(() -> { // index reference class + char x = (char) hs.get(am, methodType(char.class, char[].class, Class.class, char.class)). + invokeExact(array, Void.class, '\u0123'); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, char[].class, int.class, char.class)). + invokeExact(array, 0, '\u0123'); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, char[].class, int.class, char.class)). + invokeExact(array, 0, '\u0123'); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + char x = (char) hs.get(am, methodType(char.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + char x = (char) hs.get(am, methodType(char.class, char[].class, int.class, char.class, Class.class)). + invokeExact(array, 0, '\u0123', Void.class); + }); + } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeDouble.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeDouble.java index f3531016262..e3bf8363a15 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeDouble.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeDouble.java @@ -324,7 +324,322 @@ public class VarHandleTestMethodTypeDouble extends VarHandleBaseTest { }); + // CompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.compareAndSet(null, 1.0d, 1.0d); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.compareAndSet(Void.class, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(recv, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(recv, 1.0d, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.compareAndSet(0, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(recv, 1.0d, 1.0d, Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSet(null, 1.0d, 1.0d); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSet(Void.class, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(recv, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(recv, 1.0d, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSet(0, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(recv, 1.0d, 1.0d, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetVolatile(null, 1.0d, 1.0d); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(recv, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(recv, 1.0d, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetVolatile(0, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(recv, 1.0d, 1.0d, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetAcquire(null, 1.0d, 1.0d); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(recv, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(recv, 1.0d, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetAcquire(0, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(recv, 1.0d, 1.0d, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetRelease(null, 1.0d, 1.0d); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(recv, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(recv, 1.0d, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetRelease(0, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(recv, 1.0d, 1.0d, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkNPE(() -> { // null receiver + double x = (double) vh.compareAndExchange(null, 1.0d, 1.0d); + }); + checkCCE(() -> { // receiver reference class + double x = (double) vh.compareAndExchange(Void.class, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + double x = (double) vh.compareAndExchange(recv, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + double x = (double) vh.compareAndExchange(recv, 1.0d, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + double x = (double) vh.compareAndExchange(0, 1.0d, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(recv, 1.0d, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange(recv, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + double x = (double) vh.compareAndExchange(recv, 1.0d, 1.0d, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + double x = (double) vh.compareAndExchangeAcquire(null, 1.0d, 1.0d); + }); + checkCCE(() -> { // receiver reference class + double x = (double) vh.compareAndExchangeAcquire(Void.class, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + double x = (double) vh.compareAndExchangeAcquire(recv, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + double x = (double) vh.compareAndExchangeAcquire(recv, 1.0d, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + double x = (double) vh.compareAndExchangeAcquire(0, 1.0d, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(recv, 1.0d, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire(recv, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + double x = (double) vh.compareAndExchangeAcquire(recv, 1.0d, 1.0d, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + double x = (double) vh.compareAndExchangeRelease(null, 1.0d, 1.0d); + }); + checkCCE(() -> { // receiver reference class + double x = (double) vh.compareAndExchangeRelease(Void.class, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + double x = (double) vh.compareAndExchangeRelease(recv, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + double x = (double) vh.compareAndExchangeRelease(recv, 1.0d, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + double x = (double) vh.compareAndExchangeRelease(0, 1.0d, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(recv, 1.0d, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease(recv, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + double x = (double) vh.compareAndExchangeRelease(recv, 1.0d, 1.0d, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + double x = (double) vh.getAndSet(null, 1.0d); + }); + checkCCE(() -> { // receiver reference class + double x = (double) vh.getAndSet(Void.class, 1.0d); + }); + checkWMTE(() -> { // value reference class + double x = (double) vh.getAndSet(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + double x = (double) vh.getAndSet(0, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(recv, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet(recv, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.getAndSet(); + }); + checkWMTE(() -> { // > + double x = (double) vh.getAndSet(recv, 1.0d, Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkNPE(() -> { // null receiver + double x = (double) vh.getAndAdd(null, 1.0d); + }); + checkCCE(() -> { // receiver reference class + double x = (double) vh.getAndAdd(Void.class, 1.0d); + }); + checkWMTE(() -> { // value reference class + double x = (double) vh.getAndAdd(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + double x = (double) vh.getAndAdd(0, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd(recv, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd(recv, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + double x = (double) vh.getAndAdd(recv, 1.0d, Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkNPE(() -> { // null receiver + double x = (double) vh.addAndGet(null, 1.0d); + }); + checkCCE(() -> { // receiver reference class + double x = (double) vh.addAndGet(Void.class, 1.0d); + }); + checkWMTE(() -> { // value reference class + double x = (double) vh.addAndGet(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + double x = (double) vh.addAndGet(0, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet(recv, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet(recv, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.addAndGet(); + }); + checkWMTE(() -> { // > + double x = (double) vh.addAndGet(recv, 1.0d, Void.class); + }); } static void testInstanceFieldWrongMethodType(VarHandleTestMethodTypeDouble recv, Handles hs) throws Throwable { @@ -391,7 +706,153 @@ public class VarHandleTestMethodTypeDouble extends VarHandleBaseTest { }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeDouble.class, double.class, double.class)). + invokeExact((VarHandleTestMethodTypeDouble) null, 1.0d, 1.0d); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, double.class, double.class)). + invokeExact(Void.class, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeDouble.class, Class.class, double.class)). + invokeExact(recv, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeDouble.class, double.class, Class.class)). + invokeExact(recv, 1.0d, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class , double.class, double.class)). + invokeExact(0, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeDouble.class, double.class, double.class, Class.class)). + invokeExact(recv, 1.0d, 1.0d, Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + checkNPE(() -> { // null receiver + double x = (double) hs.get(am, methodType(double.class, VarHandleTestMethodTypeDouble.class, double.class, double.class)). + invokeExact((VarHandleTestMethodTypeDouble) null, 1.0d, 1.0d); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + double x = (double) hs.get(am, methodType(double.class, Class.class, double.class, double.class)). + invokeExact(Void.class, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + double x = (double) hs.get(am, methodType(double.class, VarHandleTestMethodTypeDouble.class, Class.class, double.class)). + invokeExact(recv, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + double x = (double) hs.get(am, methodType(double.class, VarHandleTestMethodTypeDouble.class, double.class, Class.class)). + invokeExact(recv, 1.0d, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + double x = (double) hs.get(am, methodType(double.class, int.class , double.class, double.class)). + invokeExact(0, 1.0d, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeDouble.class , double.class, double.class)). + invokeExact(recv, 1.0d, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeDouble.class , double.class, double.class)). + invokeExact(recv, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) hs.get(am, methodType(double.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + double x = (double) hs.get(am, methodType(double.class, VarHandleTestMethodTypeDouble.class, double.class, double.class, Class.class)). + invokeExact(recv, 1.0d, 1.0d, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + checkNPE(() -> { // null receiver + double x = (double) hs.get(am, methodType(double.class, VarHandleTestMethodTypeDouble.class, double.class)). + invokeExact((VarHandleTestMethodTypeDouble) null, 1.0d); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + double x = (double) hs.get(am, methodType(double.class, Class.class, double.class)). + invokeExact(Void.class, 1.0d); + }); + checkWMTE(() -> { // value reference class + double x = (double) hs.get(am, methodType(double.class, VarHandleTestMethodTypeDouble.class, Class.class)). + invokeExact(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + double x = (double) hs.get(am, methodType(double.class, int.class, double.class)). + invokeExact(0, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeDouble.class, double.class)). + invokeExact(recv, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeDouble.class, double.class)). + invokeExact(recv, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) hs.get(am, methodType(double.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + double x = (double) hs.get(am, methodType(double.class, VarHandleTestMethodTypeDouble.class, double.class)). + invokeExact(recv, 1.0d, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + checkNPE(() -> { // null receiver + double x = (double) hs.get(am, methodType(double.class, VarHandleTestMethodTypeDouble.class, double.class)). + invokeExact((VarHandleTestMethodTypeDouble) null, 1.0d); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + double x = (double) hs.get(am, methodType(double.class, Class.class, double.class)). + invokeExact(Void.class, 1.0d); + }); + checkWMTE(() -> { // value reference class + double x = (double) hs.get(am, methodType(double.class, VarHandleTestMethodTypeDouble.class, Class.class)). + invokeExact(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + double x = (double) hs.get(am, methodType(double.class, int.class, double.class)). + invokeExact(0, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeDouble.class, double.class)). + invokeExact(recv, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeDouble.class, double.class)). + invokeExact(recv, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) hs.get(am, methodType(double.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + double x = (double) hs.get(am, methodType(double.class, VarHandleTestMethodTypeDouble.class, double.class)). + invokeExact(recv, 1.0d, Void.class); + }); + } } @@ -505,7 +966,223 @@ public class VarHandleTestMethodTypeDouble extends VarHandleBaseTest { }); + // CompareAndSet + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(1.0d, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(1.0d, 1.0d, Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(1.0d, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(1.0d, 1.0d, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(1.0d, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(1.0d, 1.0d, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(1.0d, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(1.0d, 1.0d, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(1.0d, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(1.0d, 1.0d, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkWMTE(() -> { // expected reference class + double x = (double) vh.compareAndExchange(Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + double x = (double) vh.compareAndExchange(1.0d, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(1.0d, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange(1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + double x = (double) vh.compareAndExchange(1.0d, 1.0d, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkWMTE(() -> { // expected reference class + double x = (double) vh.compareAndExchangeAcquire(Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + double x = (double) vh.compareAndExchangeAcquire(1.0d, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(1.0d, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire(1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + double x = (double) vh.compareAndExchangeAcquire(1.0d, 1.0d, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkWMTE(() -> { // expected reference class + double x = (double) vh.compareAndExchangeRelease(Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + double x = (double) vh.compareAndExchangeRelease(1.0d, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(1.0d, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease(1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + double x = (double) vh.compareAndExchangeRelease(1.0d, 1.0d, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkWMTE(() -> { // value reference class + double x = (double) vh.getAndSet(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet(1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.getAndSet(); + }); + checkWMTE(() -> { // > + double x = (double) vh.getAndSet(1.0d, Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkWMTE(() -> { // value reference class + double x = (double) vh.getAndAdd(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd(1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd(1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + double x = (double) vh.getAndAdd(1.0d, Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkWMTE(() -> { // value reference class + double x = (double) vh.addAndGet(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet(1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet(1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.addAndGet(); + }); + checkWMTE(() -> { // > + double x = (double) vh.addAndGet(1.0d, Void.class); + }); } static void testStaticFieldWrongMethodType(Handles hs) throws Throwable { @@ -543,7 +1220,108 @@ public class VarHandleTestMethodTypeDouble extends VarHandleBaseTest { invokeExact(1.0d, Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, double.class)). + invokeExact(Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, double.class, Class.class)). + invokeExact(1.0d, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, double.class, double.class, Class.class)). + invokeExact(1.0d, 1.0d, Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + // Incorrect argument types + checkWMTE(() -> { // expected reference class + double x = (double) hs.get(am, methodType(double.class, Class.class, double.class)). + invokeExact(Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + double x = (double) hs.get(am, methodType(double.class, double.class, Class.class)). + invokeExact(1.0d, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, double.class, double.class)). + invokeExact(1.0d, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, double.class, double.class)). + invokeExact(1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) hs.get(am, methodType(double.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + double x = (double) hs.get(am, methodType(double.class, double.class, double.class, Class.class)). + invokeExact(1.0d, 1.0d, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + // Incorrect argument types + checkWMTE(() -> { // value reference class + double x = (double) hs.get(am, methodType(double.class, Class.class)). + invokeExact(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, double.class)). + invokeExact(1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, double.class)). + invokeExact(1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) hs.get(am, methodType(double.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + double x = (double) hs.get(am, methodType(double.class, double.class, Class.class)). + invokeExact(1.0d, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + // Incorrect argument types + checkWMTE(() -> { // value reference class + double x = (double) hs.get(am, methodType(double.class, Class.class)). + invokeExact(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, double.class)). + invokeExact(1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, double.class)). + invokeExact(1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) hs.get(am, methodType(double.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + double x = (double) hs.get(am, methodType(double.class, double.class, Class.class)). + invokeExact(1.0d, Void.class); + }); + } } @@ -775,7 +1553,355 @@ public class VarHandleTestMethodTypeDouble extends VarHandleBaseTest { }); + // CompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.compareAndSet(null, 0, 1.0d, 1.0d); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.compareAndSet(Void.class, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(array, 0, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(array, 0, 1.0d, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.compareAndSet(0, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.compareAndSet(array, Void.class, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(array, 0, 1.0d, 1.0d, Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSet(null, 0, 1.0d, 1.0d); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSet(Void.class, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(array, 0, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(array, 0, 1.0d, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSet(0, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSet(array, Void.class, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(array, 0, 1.0d, 1.0d, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetVolatile(null, 0, 1.0d, 1.0d); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(array, 0, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(array, 0, 1.0d, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetVolatile(0, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetVolatile(array, Void.class, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(array, 0, 1.0d, 1.0d, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetAcquire(null, 0, 1.0d, 1.0d); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(array, 0, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(array, 0, 1.0d, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetAcquire(0, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetAcquire(array, Void.class, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(array, 0, 1.0d, 1.0d, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetRelease(null, 0, 1.0d, 1.0d); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(array, 0, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(array, 0, 1.0d, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetRelease(0, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetRelease(array, Void.class, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(array, 0, 1.0d, 1.0d, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkNPE(() -> { // null receiver + double x = (double) vh.compareAndExchange(null, 0, 1.0d, 1.0d); + }); + checkCCE(() -> { // array reference class + double x = (double) vh.compareAndExchange(Void.class, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + double x = (double) vh.compareAndExchange(array, 0, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + double x = (double) vh.compareAndExchange(array, 0, 1.0d, Void.class); + }); + checkWMTE(() -> { // array primitive class + double x = (double) vh.compareAndExchange(0, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // index reference class + double x = (double) vh.compareAndExchange(array, Void.class, 1.0d, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(array, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange(array, 0, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + double x = (double) vh.compareAndExchange(array, 0, 1.0d, 1.0d, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + double x = (double) vh.compareAndExchangeAcquire(null, 0, 1.0d, 1.0d); + }); + checkCCE(() -> { // array reference class + double x = (double) vh.compareAndExchangeAcquire(Void.class, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + double x = (double) vh.compareAndExchangeAcquire(array, 0, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + double x = (double) vh.compareAndExchangeAcquire(array, 0, 1.0d, Void.class); + }); + checkWMTE(() -> { // array primitive class + double x = (double) vh.compareAndExchangeAcquire(0, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // index reference class + double x = (double) vh.compareAndExchangeAcquire(array, Void.class, 1.0d, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(array, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire(array, 0, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + double x = (double) vh.compareAndExchangeAcquire(array, 0, 1.0d, 1.0d, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + double x = (double) vh.compareAndExchangeRelease(null, 0, 1.0d, 1.0d); + }); + checkCCE(() -> { // array reference class + double x = (double) vh.compareAndExchangeRelease(Void.class, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + double x = (double) vh.compareAndExchangeRelease(array, 0, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + double x = (double) vh.compareAndExchangeRelease(array, 0, 1.0d, Void.class); + }); + checkWMTE(() -> { // array primitive class + double x = (double) vh.compareAndExchangeRelease(0, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // index reference class + double x = (double) vh.compareAndExchangeRelease(array, Void.class, 1.0d, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(array, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease(array, 0, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + double x = (double) vh.compareAndExchangeRelease(array, 0, 1.0d, 1.0d, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkNPE(() -> { // null array + double x = (double) vh.getAndSet(null, 0, 1.0d); + }); + checkCCE(() -> { // array reference class + double x = (double) vh.getAndSet(Void.class, 0, 1.0d); + }); + checkWMTE(() -> { // value reference class + double x = (double) vh.getAndSet(array, 0, Void.class); + }); + checkWMTE(() -> { // reciarrayever primitive class + double x = (double) vh.getAndSet(0, 0, 1.0d); + }); + checkWMTE(() -> { // index reference class + double x = (double) vh.getAndSet(array, Void.class, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(array, 0, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet(array, 0, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.getAndSet(); + }); + checkWMTE(() -> { // > + double x = (double) vh.getAndSet(array, 0, 1.0d, Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkNPE(() -> { // null array + double x = (double) vh.getAndAdd(null, 0, 1.0d); + }); + checkCCE(() -> { // array reference class + double x = (double) vh.getAndAdd(Void.class, 0, 1.0d); + }); + checkWMTE(() -> { // value reference class + double x = (double) vh.getAndAdd(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + double x = (double) vh.getAndAdd(0, 0, 1.0d); + }); + checkWMTE(() -> { // index reference class + double x = (double) vh.getAndAdd(array, Void.class, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd(array, 0, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd(array, 0, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + double x = (double) vh.getAndAdd(array, 0, 1.0d, Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkNPE(() -> { // null array + double x = (double) vh.addAndGet(null, 0, 1.0d); + }); + checkCCE(() -> { // array reference class + double x = (double) vh.addAndGet(Void.class, 0, 1.0d); + }); + checkWMTE(() -> { // value reference class + double x = (double) vh.addAndGet(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + double x = (double) vh.addAndGet(0, 0, 1.0d); + }); + checkWMTE(() -> { // index reference class + double x = (double) vh.addAndGet(array, Void.class, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet(array, 0, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet(array, 0, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) vh.addAndGet(); + }); + checkWMTE(() -> { // > + double x = (double) vh.addAndGet(array, 0, 1.0d, Void.class); + }); } static void testArrayWrongMethodType(Handles hs) throws Throwable { @@ -852,7 +1978,172 @@ public class VarHandleTestMethodTypeDouble extends VarHandleBaseTest { invokeExact(array, 0, 1.0d, Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = (boolean) hs.get(am, methodType(boolean.class, double[].class, int.class, double.class, double.class)). + invokeExact((double[]) null, 0, 1.0d, 1.0d); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, int.class, double.class, double.class)). + invokeExact(Void.class, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, double[].class, int.class, Class.class, double.class)). + invokeExact(array, 0, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, double[].class, int.class, double.class, Class.class)). + invokeExact(array, 0, 1.0d, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class, int.class, double.class, double.class)). + invokeExact(0, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // index reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, double[].class, Class.class, double.class, double.class)). + invokeExact(array, Void.class, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, double[].class, int.class, double.class, double.class, Class.class)). + invokeExact(array, 0, 1.0d, 1.0d, Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + double x = (double) hs.get(am, methodType(double.class, double[].class, int.class, double.class, double.class)). + invokeExact((double[]) null, 0, 1.0d, 1.0d); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + double x = (double) hs.get(am, methodType(double.class, Class.class, int.class, double.class, double.class)). + invokeExact(Void.class, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // expected reference class + double x = (double) hs.get(am, methodType(double.class, double[].class, int.class, Class.class, double.class)). + invokeExact(array, 0, Void.class, 1.0d); + }); + checkWMTE(() -> { // actual reference class + double x = (double) hs.get(am, methodType(double.class, double[].class, int.class, double.class, Class.class)). + invokeExact(array, 0, 1.0d, Void.class); + }); + checkWMTE(() -> { // array primitive class + double x = (double) hs.get(am, methodType(double.class, int.class, int.class, double.class, double.class)). + invokeExact(0, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // index reference class + double x = (double) hs.get(am, methodType(double.class, double[].class, Class.class, double.class, double.class)). + invokeExact(array, Void.class, 1.0d, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, double[].class, int.class, double.class, double.class)). + invokeExact(array, 0, 1.0d, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, double[].class, int.class, double.class, double.class)). + invokeExact(array, 0, 1.0d, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) hs.get(am, methodType(double.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + double x = (double) hs.get(am, methodType(double.class, double[].class, int.class, double.class, double.class, Class.class)). + invokeExact(array, 0, 1.0d, 1.0d, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null array + double x = (double) hs.get(am, methodType(double.class, double[].class, int.class, double.class)). + invokeExact((double[]) null, 0, 1.0d); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + double x = (double) hs.get(am, methodType(double.class, Class.class, int.class, double.class)). + invokeExact(Void.class, 0, 1.0d); + }); + checkWMTE(() -> { // value reference class + double x = (double) hs.get(am, methodType(double.class, double[].class, int.class, Class.class)). + invokeExact(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + double x = (double) hs.get(am, methodType(double.class, int.class, int.class, double.class)). + invokeExact(0, 0, 1.0d); + }); + checkWMTE(() -> { // index reference class + double x = (double) hs.get(am, methodType(double.class, double[].class, Class.class, double.class)). + invokeExact(array, Void.class, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, double[].class, int.class, double.class)). + invokeExact(array, 0, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, double[].class, int.class, double.class)). + invokeExact(array, 0, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) hs.get(am, methodType(double.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + double x = (double) hs.get(am, methodType(double.class, double[].class, int.class, double.class, Class.class)). + invokeExact(array, 0, 1.0d, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + // Incorrect argument types + checkNPE(() -> { // null array + double x = (double) hs.get(am, methodType(double.class, double[].class, int.class, double.class)). + invokeExact((double[]) null, 0, 1.0d); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + double x = (double) hs.get(am, methodType(double.class, Class.class, int.class, double.class)). + invokeExact(Void.class, 0, 1.0d); + }); + checkWMTE(() -> { // value reference class + double x = (double) hs.get(am, methodType(double.class, double[].class, int.class, Class.class)). + invokeExact(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + double x = (double) hs.get(am, methodType(double.class, int.class, int.class, double.class)). + invokeExact(0, 0, 1.0d); + }); + checkWMTE(() -> { // index reference class + double x = (double) hs.get(am, methodType(double.class, double[].class, Class.class, double.class)). + invokeExact(array, Void.class, 1.0d); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, double[].class, int.class, double.class)). + invokeExact(array, 0, 1.0d); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, double[].class, int.class, double.class)). + invokeExact(array, 0, 1.0d); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + double x = (double) hs.get(am, methodType(double.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + double x = (double) hs.get(am, methodType(double.class, double[].class, int.class, double.class, Class.class)). + invokeExact(array, 0, 1.0d, Void.class); + }); + } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeFloat.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeFloat.java index b07049d64b0..34617e2102e 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeFloat.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeFloat.java @@ -324,7 +324,322 @@ public class VarHandleTestMethodTypeFloat extends VarHandleBaseTest { }); + // CompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.compareAndSet(null, 1.0f, 1.0f); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.compareAndSet(Void.class, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(recv, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(recv, 1.0f, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.compareAndSet(0, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(recv, 1.0f, 1.0f, Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSet(null, 1.0f, 1.0f); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSet(Void.class, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(recv, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(recv, 1.0f, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSet(0, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(recv, 1.0f, 1.0f, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetVolatile(null, 1.0f, 1.0f); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(recv, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(recv, 1.0f, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetVolatile(0, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(recv, 1.0f, 1.0f, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetAcquire(null, 1.0f, 1.0f); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(recv, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(recv, 1.0f, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetAcquire(0, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(recv, 1.0f, 1.0f, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetRelease(null, 1.0f, 1.0f); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(recv, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(recv, 1.0f, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetRelease(0, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(recv, 1.0f, 1.0f, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkNPE(() -> { // null receiver + float x = (float) vh.compareAndExchange(null, 1.0f, 1.0f); + }); + checkCCE(() -> { // receiver reference class + float x = (float) vh.compareAndExchange(Void.class, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + float x = (float) vh.compareAndExchange(recv, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + float x = (float) vh.compareAndExchange(recv, 1.0f, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + float x = (float) vh.compareAndExchange(0, 1.0f, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(recv, 1.0f, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange(recv, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + float x = (float) vh.compareAndExchange(recv, 1.0f, 1.0f, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + float x = (float) vh.compareAndExchangeAcquire(null, 1.0f, 1.0f); + }); + checkCCE(() -> { // receiver reference class + float x = (float) vh.compareAndExchangeAcquire(Void.class, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + float x = (float) vh.compareAndExchangeAcquire(recv, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + float x = (float) vh.compareAndExchangeAcquire(recv, 1.0f, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + float x = (float) vh.compareAndExchangeAcquire(0, 1.0f, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(recv, 1.0f, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire(recv, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + float x = (float) vh.compareAndExchangeAcquire(recv, 1.0f, 1.0f, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + float x = (float) vh.compareAndExchangeRelease(null, 1.0f, 1.0f); + }); + checkCCE(() -> { // receiver reference class + float x = (float) vh.compareAndExchangeRelease(Void.class, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + float x = (float) vh.compareAndExchangeRelease(recv, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + float x = (float) vh.compareAndExchangeRelease(recv, 1.0f, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + float x = (float) vh.compareAndExchangeRelease(0, 1.0f, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(recv, 1.0f, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease(recv, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + float x = (float) vh.compareAndExchangeRelease(recv, 1.0f, 1.0f, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + float x = (float) vh.getAndSet(null, 1.0f); + }); + checkCCE(() -> { // receiver reference class + float x = (float) vh.getAndSet(Void.class, 1.0f); + }); + checkWMTE(() -> { // value reference class + float x = (float) vh.getAndSet(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + float x = (float) vh.getAndSet(0, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(recv, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet(recv, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.getAndSet(); + }); + checkWMTE(() -> { // > + float x = (float) vh.getAndSet(recv, 1.0f, Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkNPE(() -> { // null receiver + float x = (float) vh.getAndAdd(null, 1.0f); + }); + checkCCE(() -> { // receiver reference class + float x = (float) vh.getAndAdd(Void.class, 1.0f); + }); + checkWMTE(() -> { // value reference class + float x = (float) vh.getAndAdd(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + float x = (float) vh.getAndAdd(0, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd(recv, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd(recv, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + float x = (float) vh.getAndAdd(recv, 1.0f, Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkNPE(() -> { // null receiver + float x = (float) vh.addAndGet(null, 1.0f); + }); + checkCCE(() -> { // receiver reference class + float x = (float) vh.addAndGet(Void.class, 1.0f); + }); + checkWMTE(() -> { // value reference class + float x = (float) vh.addAndGet(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + float x = (float) vh.addAndGet(0, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet(recv, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet(recv, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.addAndGet(); + }); + checkWMTE(() -> { // > + float x = (float) vh.addAndGet(recv, 1.0f, Void.class); + }); } static void testInstanceFieldWrongMethodType(VarHandleTestMethodTypeFloat recv, Handles hs) throws Throwable { @@ -391,7 +706,153 @@ public class VarHandleTestMethodTypeFloat extends VarHandleBaseTest { }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeFloat.class, float.class, float.class)). + invokeExact((VarHandleTestMethodTypeFloat) null, 1.0f, 1.0f); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, float.class, float.class)). + invokeExact(Void.class, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeFloat.class, Class.class, float.class)). + invokeExact(recv, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeFloat.class, float.class, Class.class)). + invokeExact(recv, 1.0f, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class , float.class, float.class)). + invokeExact(0, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeFloat.class, float.class, float.class, Class.class)). + invokeExact(recv, 1.0f, 1.0f, Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + checkNPE(() -> { // null receiver + float x = (float) hs.get(am, methodType(float.class, VarHandleTestMethodTypeFloat.class, float.class, float.class)). + invokeExact((VarHandleTestMethodTypeFloat) null, 1.0f, 1.0f); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + float x = (float) hs.get(am, methodType(float.class, Class.class, float.class, float.class)). + invokeExact(Void.class, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + float x = (float) hs.get(am, methodType(float.class, VarHandleTestMethodTypeFloat.class, Class.class, float.class)). + invokeExact(recv, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + float x = (float) hs.get(am, methodType(float.class, VarHandleTestMethodTypeFloat.class, float.class, Class.class)). + invokeExact(recv, 1.0f, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + float x = (float) hs.get(am, methodType(float.class, int.class , float.class, float.class)). + invokeExact(0, 1.0f, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeFloat.class , float.class, float.class)). + invokeExact(recv, 1.0f, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeFloat.class , float.class, float.class)). + invokeExact(recv, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) hs.get(am, methodType(float.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + float x = (float) hs.get(am, methodType(float.class, VarHandleTestMethodTypeFloat.class, float.class, float.class, Class.class)). + invokeExact(recv, 1.0f, 1.0f, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + checkNPE(() -> { // null receiver + float x = (float) hs.get(am, methodType(float.class, VarHandleTestMethodTypeFloat.class, float.class)). + invokeExact((VarHandleTestMethodTypeFloat) null, 1.0f); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + float x = (float) hs.get(am, methodType(float.class, Class.class, float.class)). + invokeExact(Void.class, 1.0f); + }); + checkWMTE(() -> { // value reference class + float x = (float) hs.get(am, methodType(float.class, VarHandleTestMethodTypeFloat.class, Class.class)). + invokeExact(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + float x = (float) hs.get(am, methodType(float.class, int.class, float.class)). + invokeExact(0, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeFloat.class, float.class)). + invokeExact(recv, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeFloat.class, float.class)). + invokeExact(recv, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) hs.get(am, methodType(float.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + float x = (float) hs.get(am, methodType(float.class, VarHandleTestMethodTypeFloat.class, float.class)). + invokeExact(recv, 1.0f, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + checkNPE(() -> { // null receiver + float x = (float) hs.get(am, methodType(float.class, VarHandleTestMethodTypeFloat.class, float.class)). + invokeExact((VarHandleTestMethodTypeFloat) null, 1.0f); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + float x = (float) hs.get(am, methodType(float.class, Class.class, float.class)). + invokeExact(Void.class, 1.0f); + }); + checkWMTE(() -> { // value reference class + float x = (float) hs.get(am, methodType(float.class, VarHandleTestMethodTypeFloat.class, Class.class)). + invokeExact(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + float x = (float) hs.get(am, methodType(float.class, int.class, float.class)). + invokeExact(0, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeFloat.class, float.class)). + invokeExact(recv, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeFloat.class, float.class)). + invokeExact(recv, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) hs.get(am, methodType(float.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + float x = (float) hs.get(am, methodType(float.class, VarHandleTestMethodTypeFloat.class, float.class)). + invokeExact(recv, 1.0f, Void.class); + }); + } } @@ -505,7 +966,223 @@ public class VarHandleTestMethodTypeFloat extends VarHandleBaseTest { }); + // CompareAndSet + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(1.0f, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(1.0f, 1.0f, Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(1.0f, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(1.0f, 1.0f, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(1.0f, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(1.0f, 1.0f, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(1.0f, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(1.0f, 1.0f, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(1.0f, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(1.0f, 1.0f, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkWMTE(() -> { // expected reference class + float x = (float) vh.compareAndExchange(Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + float x = (float) vh.compareAndExchange(1.0f, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(1.0f, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange(1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + float x = (float) vh.compareAndExchange(1.0f, 1.0f, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkWMTE(() -> { // expected reference class + float x = (float) vh.compareAndExchangeAcquire(Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + float x = (float) vh.compareAndExchangeAcquire(1.0f, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(1.0f, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire(1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + float x = (float) vh.compareAndExchangeAcquire(1.0f, 1.0f, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkWMTE(() -> { // expected reference class + float x = (float) vh.compareAndExchangeRelease(Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + float x = (float) vh.compareAndExchangeRelease(1.0f, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(1.0f, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease(1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + float x = (float) vh.compareAndExchangeRelease(1.0f, 1.0f, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkWMTE(() -> { // value reference class + float x = (float) vh.getAndSet(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet(1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.getAndSet(); + }); + checkWMTE(() -> { // > + float x = (float) vh.getAndSet(1.0f, Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkWMTE(() -> { // value reference class + float x = (float) vh.getAndAdd(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd(1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd(1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + float x = (float) vh.getAndAdd(1.0f, Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkWMTE(() -> { // value reference class + float x = (float) vh.addAndGet(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet(1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet(1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.addAndGet(); + }); + checkWMTE(() -> { // > + float x = (float) vh.addAndGet(1.0f, Void.class); + }); } static void testStaticFieldWrongMethodType(Handles hs) throws Throwable { @@ -543,7 +1220,108 @@ public class VarHandleTestMethodTypeFloat extends VarHandleBaseTest { invokeExact(1.0f, Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, float.class)). + invokeExact(Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, float.class, Class.class)). + invokeExact(1.0f, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, float.class, float.class, Class.class)). + invokeExact(1.0f, 1.0f, Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + // Incorrect argument types + checkWMTE(() -> { // expected reference class + float x = (float) hs.get(am, methodType(float.class, Class.class, float.class)). + invokeExact(Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + float x = (float) hs.get(am, methodType(float.class, float.class, Class.class)). + invokeExact(1.0f, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, float.class, float.class)). + invokeExact(1.0f, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, float.class, float.class)). + invokeExact(1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) hs.get(am, methodType(float.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + float x = (float) hs.get(am, methodType(float.class, float.class, float.class, Class.class)). + invokeExact(1.0f, 1.0f, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + // Incorrect argument types + checkWMTE(() -> { // value reference class + float x = (float) hs.get(am, methodType(float.class, Class.class)). + invokeExact(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, float.class)). + invokeExact(1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, float.class)). + invokeExact(1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) hs.get(am, methodType(float.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + float x = (float) hs.get(am, methodType(float.class, float.class, Class.class)). + invokeExact(1.0f, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + // Incorrect argument types + checkWMTE(() -> { // value reference class + float x = (float) hs.get(am, methodType(float.class, Class.class)). + invokeExact(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, float.class)). + invokeExact(1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, float.class)). + invokeExact(1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) hs.get(am, methodType(float.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + float x = (float) hs.get(am, methodType(float.class, float.class, Class.class)). + invokeExact(1.0f, Void.class); + }); + } } @@ -775,7 +1553,355 @@ public class VarHandleTestMethodTypeFloat extends VarHandleBaseTest { }); + // CompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.compareAndSet(null, 0, 1.0f, 1.0f); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.compareAndSet(Void.class, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(array, 0, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(array, 0, 1.0f, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.compareAndSet(0, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.compareAndSet(array, Void.class, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(array, 0, 1.0f, 1.0f, Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSet(null, 0, 1.0f, 1.0f); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSet(Void.class, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(array, 0, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(array, 0, 1.0f, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSet(0, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSet(array, Void.class, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(array, 0, 1.0f, 1.0f, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetVolatile(null, 0, 1.0f, 1.0f); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(array, 0, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(array, 0, 1.0f, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetVolatile(0, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetVolatile(array, Void.class, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(array, 0, 1.0f, 1.0f, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetAcquire(null, 0, 1.0f, 1.0f); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(array, 0, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(array, 0, 1.0f, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetAcquire(0, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetAcquire(array, Void.class, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(array, 0, 1.0f, 1.0f, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetRelease(null, 0, 1.0f, 1.0f); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(array, 0, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(array, 0, 1.0f, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetRelease(0, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetRelease(array, Void.class, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(array, 0, 1.0f, 1.0f, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkNPE(() -> { // null receiver + float x = (float) vh.compareAndExchange(null, 0, 1.0f, 1.0f); + }); + checkCCE(() -> { // array reference class + float x = (float) vh.compareAndExchange(Void.class, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + float x = (float) vh.compareAndExchange(array, 0, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + float x = (float) vh.compareAndExchange(array, 0, 1.0f, Void.class); + }); + checkWMTE(() -> { // array primitive class + float x = (float) vh.compareAndExchange(0, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // index reference class + float x = (float) vh.compareAndExchange(array, Void.class, 1.0f, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(array, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange(array, 0, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + float x = (float) vh.compareAndExchange(array, 0, 1.0f, 1.0f, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + float x = (float) vh.compareAndExchangeAcquire(null, 0, 1.0f, 1.0f); + }); + checkCCE(() -> { // array reference class + float x = (float) vh.compareAndExchangeAcquire(Void.class, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + float x = (float) vh.compareAndExchangeAcquire(array, 0, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + float x = (float) vh.compareAndExchangeAcquire(array, 0, 1.0f, Void.class); + }); + checkWMTE(() -> { // array primitive class + float x = (float) vh.compareAndExchangeAcquire(0, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // index reference class + float x = (float) vh.compareAndExchangeAcquire(array, Void.class, 1.0f, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(array, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire(array, 0, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + float x = (float) vh.compareAndExchangeAcquire(array, 0, 1.0f, 1.0f, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + float x = (float) vh.compareAndExchangeRelease(null, 0, 1.0f, 1.0f); + }); + checkCCE(() -> { // array reference class + float x = (float) vh.compareAndExchangeRelease(Void.class, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + float x = (float) vh.compareAndExchangeRelease(array, 0, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + float x = (float) vh.compareAndExchangeRelease(array, 0, 1.0f, Void.class); + }); + checkWMTE(() -> { // array primitive class + float x = (float) vh.compareAndExchangeRelease(0, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // index reference class + float x = (float) vh.compareAndExchangeRelease(array, Void.class, 1.0f, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(array, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease(array, 0, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + float x = (float) vh.compareAndExchangeRelease(array, 0, 1.0f, 1.0f, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkNPE(() -> { // null array + float x = (float) vh.getAndSet(null, 0, 1.0f); + }); + checkCCE(() -> { // array reference class + float x = (float) vh.getAndSet(Void.class, 0, 1.0f); + }); + checkWMTE(() -> { // value reference class + float x = (float) vh.getAndSet(array, 0, Void.class); + }); + checkWMTE(() -> { // reciarrayever primitive class + float x = (float) vh.getAndSet(0, 0, 1.0f); + }); + checkWMTE(() -> { // index reference class + float x = (float) vh.getAndSet(array, Void.class, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(array, 0, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet(array, 0, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.getAndSet(); + }); + checkWMTE(() -> { // > + float x = (float) vh.getAndSet(array, 0, 1.0f, Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkNPE(() -> { // null array + float x = (float) vh.getAndAdd(null, 0, 1.0f); + }); + checkCCE(() -> { // array reference class + float x = (float) vh.getAndAdd(Void.class, 0, 1.0f); + }); + checkWMTE(() -> { // value reference class + float x = (float) vh.getAndAdd(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + float x = (float) vh.getAndAdd(0, 0, 1.0f); + }); + checkWMTE(() -> { // index reference class + float x = (float) vh.getAndAdd(array, Void.class, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd(array, 0, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd(array, 0, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + float x = (float) vh.getAndAdd(array, 0, 1.0f, Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkNPE(() -> { // null array + float x = (float) vh.addAndGet(null, 0, 1.0f); + }); + checkCCE(() -> { // array reference class + float x = (float) vh.addAndGet(Void.class, 0, 1.0f); + }); + checkWMTE(() -> { // value reference class + float x = (float) vh.addAndGet(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + float x = (float) vh.addAndGet(0, 0, 1.0f); + }); + checkWMTE(() -> { // index reference class + float x = (float) vh.addAndGet(array, Void.class, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet(array, 0, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet(array, 0, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) vh.addAndGet(); + }); + checkWMTE(() -> { // > + float x = (float) vh.addAndGet(array, 0, 1.0f, Void.class); + }); } static void testArrayWrongMethodType(Handles hs) throws Throwable { @@ -852,7 +1978,172 @@ public class VarHandleTestMethodTypeFloat extends VarHandleBaseTest { invokeExact(array, 0, 1.0f, Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = (boolean) hs.get(am, methodType(boolean.class, float[].class, int.class, float.class, float.class)). + invokeExact((float[]) null, 0, 1.0f, 1.0f); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, int.class, float.class, float.class)). + invokeExact(Void.class, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, float[].class, int.class, Class.class, float.class)). + invokeExact(array, 0, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, float[].class, int.class, float.class, Class.class)). + invokeExact(array, 0, 1.0f, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class, int.class, float.class, float.class)). + invokeExact(0, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // index reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, float[].class, Class.class, float.class, float.class)). + invokeExact(array, Void.class, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, float[].class, int.class, float.class, float.class, Class.class)). + invokeExact(array, 0, 1.0f, 1.0f, Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + float x = (float) hs.get(am, methodType(float.class, float[].class, int.class, float.class, float.class)). + invokeExact((float[]) null, 0, 1.0f, 1.0f); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + float x = (float) hs.get(am, methodType(float.class, Class.class, int.class, float.class, float.class)). + invokeExact(Void.class, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // expected reference class + float x = (float) hs.get(am, methodType(float.class, float[].class, int.class, Class.class, float.class)). + invokeExact(array, 0, Void.class, 1.0f); + }); + checkWMTE(() -> { // actual reference class + float x = (float) hs.get(am, methodType(float.class, float[].class, int.class, float.class, Class.class)). + invokeExact(array, 0, 1.0f, Void.class); + }); + checkWMTE(() -> { // array primitive class + float x = (float) hs.get(am, methodType(float.class, int.class, int.class, float.class, float.class)). + invokeExact(0, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // index reference class + float x = (float) hs.get(am, methodType(float.class, float[].class, Class.class, float.class, float.class)). + invokeExact(array, Void.class, 1.0f, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, float[].class, int.class, float.class, float.class)). + invokeExact(array, 0, 1.0f, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, float[].class, int.class, float.class, float.class)). + invokeExact(array, 0, 1.0f, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) hs.get(am, methodType(float.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + float x = (float) hs.get(am, methodType(float.class, float[].class, int.class, float.class, float.class, Class.class)). + invokeExact(array, 0, 1.0f, 1.0f, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null array + float x = (float) hs.get(am, methodType(float.class, float[].class, int.class, float.class)). + invokeExact((float[]) null, 0, 1.0f); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + float x = (float) hs.get(am, methodType(float.class, Class.class, int.class, float.class)). + invokeExact(Void.class, 0, 1.0f); + }); + checkWMTE(() -> { // value reference class + float x = (float) hs.get(am, methodType(float.class, float[].class, int.class, Class.class)). + invokeExact(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + float x = (float) hs.get(am, methodType(float.class, int.class, int.class, float.class)). + invokeExact(0, 0, 1.0f); + }); + checkWMTE(() -> { // index reference class + float x = (float) hs.get(am, methodType(float.class, float[].class, Class.class, float.class)). + invokeExact(array, Void.class, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, float[].class, int.class, float.class)). + invokeExact(array, 0, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, float[].class, int.class, float.class)). + invokeExact(array, 0, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) hs.get(am, methodType(float.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + float x = (float) hs.get(am, methodType(float.class, float[].class, int.class, float.class, Class.class)). + invokeExact(array, 0, 1.0f, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + // Incorrect argument types + checkNPE(() -> { // null array + float x = (float) hs.get(am, methodType(float.class, float[].class, int.class, float.class)). + invokeExact((float[]) null, 0, 1.0f); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + float x = (float) hs.get(am, methodType(float.class, Class.class, int.class, float.class)). + invokeExact(Void.class, 0, 1.0f); + }); + checkWMTE(() -> { // value reference class + float x = (float) hs.get(am, methodType(float.class, float[].class, int.class, Class.class)). + invokeExact(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + float x = (float) hs.get(am, methodType(float.class, int.class, int.class, float.class)). + invokeExact(0, 0, 1.0f); + }); + checkWMTE(() -> { // index reference class + float x = (float) hs.get(am, methodType(float.class, float[].class, Class.class, float.class)). + invokeExact(array, Void.class, 1.0f); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, float[].class, int.class, float.class)). + invokeExact(array, 0, 1.0f); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, float[].class, int.class, float.class)). + invokeExact(array, 0, 1.0f); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + float x = (float) hs.get(am, methodType(float.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + float x = (float) hs.get(am, methodType(float.class, float[].class, int.class, float.class, Class.class)). + invokeExact(array, 0, 1.0f, Void.class); + }); + } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeInt.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeInt.java index 67fca94c49a..33b33970f80 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeInt.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeInt.java @@ -43,13 +43,13 @@ import static org.testng.Assert.*; import static java.lang.invoke.MethodType.*; public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { - static final int static_final_v = 1; + static final int static_final_v = 0x01234567; - static int static_v = 1; + static int static_v = 0x01234567; - final int final_v = 1; + final int final_v = 0x01234567; - int v = 1; + int v = 0x01234567; VarHandle vhFinalField; @@ -154,23 +154,23 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // Set // Incorrect argument types checkNPE(() -> { // null receiver - vh.set(null, 1); + vh.set(null, 0x01234567); }); checkCCE(() -> { // receiver reference class - vh.set(Void.class, 1); + vh.set(Void.class, 0x01234567); }); checkWMTE(() -> { // value reference class vh.set(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.set(0, 1); + vh.set(0, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 vh.set(); }); checkWMTE(() -> { // > - vh.set(recv, 1, Void.class); + vh.set(recv, 0x01234567, Void.class); }); @@ -204,23 +204,23 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // SetVolatile // Incorrect argument types checkNPE(() -> { // null receiver - vh.setVolatile(null, 1); + vh.setVolatile(null, 0x01234567); }); checkCCE(() -> { // receiver reference class - vh.setVolatile(Void.class, 1); + vh.setVolatile(Void.class, 0x01234567); }); checkWMTE(() -> { // value reference class vh.setVolatile(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setVolatile(0, 1); + vh.setVolatile(0, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile(recv, 1, Void.class); + vh.setVolatile(recv, 0x01234567, Void.class); }); @@ -254,23 +254,23 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // SetOpaque // Incorrect argument types checkNPE(() -> { // null receiver - vh.setOpaque(null, 1); + vh.setOpaque(null, 0x01234567); }); checkCCE(() -> { // receiver reference class - vh.setOpaque(Void.class, 1); + vh.setOpaque(Void.class, 0x01234567); }); checkWMTE(() -> { // value reference class vh.setOpaque(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setOpaque(0, 1); + vh.setOpaque(0, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque(recv, 1, Void.class); + vh.setOpaque(recv, 0x01234567, Void.class); }); @@ -304,341 +304,341 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // SetRelease // Incorrect argument types checkNPE(() -> { // null receiver - vh.setRelease(null, 1); + vh.setRelease(null, 0x01234567); }); checkCCE(() -> { // receiver reference class - vh.setRelease(Void.class, 1); + vh.setRelease(Void.class, 0x01234567); }); checkWMTE(() -> { // value reference class vh.setRelease(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setRelease(0, 1); + vh.setRelease(0, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease(recv, 1, Void.class); + vh.setRelease(recv, 0x01234567, Void.class); }); // CompareAndSet // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.compareAndSet(null, 1, 1); + boolean r = vh.compareAndSet(null, 0x01234567, 0x01234567); }); checkCCE(() -> { // receiver reference class - boolean r = vh.compareAndSet(Void.class, 1, 1); + boolean r = vh.compareAndSet(Void.class, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - boolean r = vh.compareAndSet(recv, Void.class, 1); + boolean r = vh.compareAndSet(recv, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.compareAndSet(recv, 1, Void.class); + boolean r = vh.compareAndSet(recv, 0x01234567, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.compareAndSet(0, 1, 1); + boolean r = vh.compareAndSet(0, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.compareAndSet(); }); checkWMTE(() -> { // > - boolean r = vh.compareAndSet(recv, 1, 1, Void.class); + boolean r = vh.compareAndSet(recv, 0x01234567, 0x01234567, Void.class); }); // WeakCompareAndSet // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSet(null, 1, 1); + boolean r = vh.weakCompareAndSet(null, 0x01234567, 0x01234567); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSet(Void.class, 1, 1); + boolean r = vh.weakCompareAndSet(Void.class, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSet(recv, Void.class, 1); + boolean r = vh.weakCompareAndSet(recv, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSet(recv, 1, Void.class); + boolean r = vh.weakCompareAndSet(recv, 0x01234567, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSet(0, 1, 1); + boolean r = vh.weakCompareAndSet(0, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSet(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSet(recv, 1, 1, Void.class); + boolean r = vh.weakCompareAndSet(recv, 0x01234567, 0x01234567, Void.class); }); // WeakCompareAndSetVolatile // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSetVolatile(null, 1, 1); + boolean r = vh.weakCompareAndSetVolatile(null, 0x01234567, 0x01234567); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSetVolatile(Void.class, 1, 1); + boolean r = vh.weakCompareAndSetVolatile(Void.class, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetVolatile(recv, Void.class, 1); + boolean r = vh.weakCompareAndSetVolatile(recv, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetVolatile(recv, 1, Void.class); + boolean r = vh.weakCompareAndSetVolatile(recv, 0x01234567, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSetVolatile(0, 1, 1); + boolean r = vh.weakCompareAndSetVolatile(0, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetVolatile(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetVolatile(recv, 1, 1, Void.class); + boolean r = vh.weakCompareAndSetVolatile(recv, 0x01234567, 0x01234567, Void.class); }); // WeakCompareAndSetAcquire // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSetAcquire(null, 1, 1); + boolean r = vh.weakCompareAndSetAcquire(null, 0x01234567, 0x01234567); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSetAcquire(Void.class, 1, 1); + boolean r = vh.weakCompareAndSetAcquire(Void.class, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetAcquire(recv, Void.class, 1); + boolean r = vh.weakCompareAndSetAcquire(recv, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetAcquire(recv, 1, Void.class); + boolean r = vh.weakCompareAndSetAcquire(recv, 0x01234567, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSetAcquire(0, 1, 1); + boolean r = vh.weakCompareAndSetAcquire(0, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetAcquire(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetAcquire(recv, 1, 1, Void.class); + boolean r = vh.weakCompareAndSetAcquire(recv, 0x01234567, 0x01234567, Void.class); }); // WeakCompareAndSetRelease // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSetRelease(null, 1, 1); + boolean r = vh.weakCompareAndSetRelease(null, 0x01234567, 0x01234567); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSetRelease(Void.class, 1, 1); + boolean r = vh.weakCompareAndSetRelease(Void.class, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetRelease(recv, Void.class, 1); + boolean r = vh.weakCompareAndSetRelease(recv, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetRelease(recv, 1, Void.class); + boolean r = vh.weakCompareAndSetRelease(recv, 0x01234567, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSetRelease(0, 1, 1); + boolean r = vh.weakCompareAndSetRelease(0, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetRelease(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetRelease(recv, 1, 1, Void.class); + boolean r = vh.weakCompareAndSetRelease(recv, 0x01234567, 0x01234567, Void.class); }); - // CompareAndExchangeVolatile + // CompareAndExchange // Incorrect argument types checkNPE(() -> { // null receiver - int x = (int) vh.compareAndExchangeVolatile(null, 1, 1); + int x = (int) vh.compareAndExchange(null, 0x01234567, 0x01234567); }); checkCCE(() -> { // receiver reference class - int x = (int) vh.compareAndExchangeVolatile(Void.class, 1, 1); + int x = (int) vh.compareAndExchange(Void.class, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - int x = (int) vh.compareAndExchangeVolatile(recv, Void.class, 1); + int x = (int) vh.compareAndExchange(recv, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - int x = (int) vh.compareAndExchangeVolatile(recv, 1, Void.class); + int x = (int) vh.compareAndExchange(recv, 0x01234567, Void.class); }); checkWMTE(() -> { // reciever primitive class - int x = (int) vh.compareAndExchangeVolatile(0, 1, 1); + int x = (int) vh.compareAndExchange(0, 0x01234567, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeVolatile(recv, 1, 1); + Void r = (Void) vh.compareAndExchange(recv, 0x01234567, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeVolatile(recv, 1, 1); + boolean x = (boolean) vh.compareAndExchange(recv, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 - int x = (int) vh.compareAndExchangeVolatile(); + int x = (int) vh.compareAndExchange(); }); checkWMTE(() -> { // > - int x = (int) vh.compareAndExchangeVolatile(recv, 1, 1, Void.class); + int x = (int) vh.compareAndExchange(recv, 0x01234567, 0x01234567, Void.class); }); - // CompareAndExchangeVolatileAcquire + // CompareAndExchangeAcquire // Incorrect argument types checkNPE(() -> { // null receiver - int x = (int) vh.compareAndExchangeAcquire(null, 1, 1); + int x = (int) vh.compareAndExchangeAcquire(null, 0x01234567, 0x01234567); }); checkCCE(() -> { // receiver reference class - int x = (int) vh.compareAndExchangeAcquire(Void.class, 1, 1); + int x = (int) vh.compareAndExchangeAcquire(Void.class, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - int x = (int) vh.compareAndExchangeAcquire(recv, Void.class, 1); + int x = (int) vh.compareAndExchangeAcquire(recv, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - int x = (int) vh.compareAndExchangeAcquire(recv, 1, Void.class); + int x = (int) vh.compareAndExchangeAcquire(recv, 0x01234567, Void.class); }); checkWMTE(() -> { // reciever primitive class - int x = (int) vh.compareAndExchangeAcquire(0, 1, 1); + int x = (int) vh.compareAndExchangeAcquire(0, 0x01234567, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeAcquire(recv, 1, 1); + Void r = (Void) vh.compareAndExchangeAcquire(recv, 0x01234567, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeAcquire(recv, 1, 1); + boolean x = (boolean) vh.compareAndExchangeAcquire(recv, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.compareAndExchangeAcquire(); }); checkWMTE(() -> { // > - int x = (int) vh.compareAndExchangeAcquire(recv, 1, 1, Void.class); + int x = (int) vh.compareAndExchangeAcquire(recv, 0x01234567, 0x01234567, Void.class); }); // CompareAndExchangeRelease // Incorrect argument types checkNPE(() -> { // null receiver - int x = (int) vh.compareAndExchangeRelease(null, 1, 1); + int x = (int) vh.compareAndExchangeRelease(null, 0x01234567, 0x01234567); }); checkCCE(() -> { // receiver reference class - int x = (int) vh.compareAndExchangeRelease(Void.class, 1, 1); + int x = (int) vh.compareAndExchangeRelease(Void.class, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - int x = (int) vh.compareAndExchangeRelease(recv, Void.class, 1); + int x = (int) vh.compareAndExchangeRelease(recv, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - int x = (int) vh.compareAndExchangeRelease(recv, 1, Void.class); + int x = (int) vh.compareAndExchangeRelease(recv, 0x01234567, Void.class); }); checkWMTE(() -> { // reciever primitive class - int x = (int) vh.compareAndExchangeRelease(0, 1, 1); + int x = (int) vh.compareAndExchangeRelease(0, 0x01234567, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeRelease(recv, 1, 1); + Void r = (Void) vh.compareAndExchangeRelease(recv, 0x01234567, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeRelease(recv, 1, 1); + boolean x = (boolean) vh.compareAndExchangeRelease(recv, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.compareAndExchangeRelease(); }); checkWMTE(() -> { // > - int x = (int) vh.compareAndExchangeRelease(recv, 1, 1, Void.class); + int x = (int) vh.compareAndExchangeRelease(recv, 0x01234567, 0x01234567, Void.class); }); // GetAndSet // Incorrect argument types checkNPE(() -> { // null receiver - int x = (int) vh.getAndSet(null, 1); + int x = (int) vh.getAndSet(null, 0x01234567); }); checkCCE(() -> { // receiver reference class - int x = (int) vh.getAndSet(Void.class, 1); + int x = (int) vh.getAndSet(Void.class, 0x01234567); }); checkWMTE(() -> { // value reference class int x = (int) vh.getAndSet(recv, Void.class); }); checkWMTE(() -> { // reciever primitive class - int x = (int) vh.getAndSet(0, 1); + int x = (int) vh.getAndSet(0, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.getAndSet(recv, 1); + Void r = (Void) vh.getAndSet(recv, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.getAndSet(recv, 1); + boolean x = (boolean) vh.getAndSet(recv, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.getAndSet(); }); checkWMTE(() -> { // > - int x = (int) vh.getAndSet(recv, 1, Void.class); + int x = (int) vh.getAndSet(recv, 0x01234567, Void.class); }); // GetAndAdd // Incorrect argument types checkNPE(() -> { // null receiver - int x = (int) vh.getAndAdd(null, 1); + int x = (int) vh.getAndAdd(null, 0x01234567); }); checkCCE(() -> { // receiver reference class - int x = (int) vh.getAndAdd(Void.class, 1); + int x = (int) vh.getAndAdd(Void.class, 0x01234567); }); checkWMTE(() -> { // value reference class int x = (int) vh.getAndAdd(recv, Void.class); }); checkWMTE(() -> { // reciever primitive class - int x = (int) vh.getAndAdd(0, 1); + int x = (int) vh.getAndAdd(0, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.getAndAdd(recv, 1); + Void r = (Void) vh.getAndAdd(recv, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.getAndAdd(recv, 1); + boolean x = (boolean) vh.getAndAdd(recv, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.getAndAdd(); }); checkWMTE(() -> { // > - int x = (int) vh.getAndAdd(recv, 1, Void.class); + int x = (int) vh.getAndAdd(recv, 0x01234567, Void.class); }); // AddAndGet // Incorrect argument types checkNPE(() -> { // null receiver - int x = (int) vh.addAndGet(null, 1); + int x = (int) vh.addAndGet(null, 0x01234567); }); checkCCE(() -> { // receiver reference class - int x = (int) vh.addAndGet(Void.class, 1); + int x = (int) vh.addAndGet(Void.class, 0x01234567); }); checkWMTE(() -> { // value reference class int x = (int) vh.addAndGet(recv, Void.class); }); checkWMTE(() -> { // reciever primitive class - int x = (int) vh.addAndGet(0, 1); + int x = (int) vh.addAndGet(0, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.addAndGet(recv, 1); + Void r = (Void) vh.addAndGet(recv, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.addAndGet(recv, 1); + boolean x = (boolean) vh.addAndGet(recv, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.addAndGet(); }); checkWMTE(() -> { // > - int x = (int) vh.addAndGet(recv, 1, Void.class); + int x = (int) vh.addAndGet(recv, 0x01234567, Void.class); }); } @@ -681,11 +681,11 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null receiver hs.get(am, methodType(void.class, VarHandleTestMethodTypeInt.class, int.class)). - invokeExact((VarHandleTestMethodTypeInt) null, 1); + invokeExact((VarHandleTestMethodTypeInt) null, 0x01234567); }); hs.checkWMTEOrCCE(() -> { // receiver reference class hs.get(am, methodType(void.class, Class.class, int.class)). - invokeExact(Void.class, 1); + invokeExact(Void.class, 0x01234567); }); checkWMTE(() -> { // value reference class hs.get(am, methodType(void.class, VarHandleTestMethodTypeInt.class, Class.class)). @@ -693,7 +693,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // receiver primitive class hs.get(am, methodType(void.class, int.class, int.class)). - invokeExact(0, 1); + invokeExact(0, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -702,7 +702,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, VarHandleTestMethodTypeInt.class, int.class, Class.class)). - invokeExact(recv, 1, Void.class); + invokeExact(recv, 0x01234567, Void.class); }); } @@ -710,23 +710,23 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null receiver boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeInt.class, int.class, int.class)). - invokeExact((VarHandleTestMethodTypeInt) null, 1, 1); + invokeExact((VarHandleTestMethodTypeInt) null, 0x01234567, 0x01234567); }); hs.checkWMTEOrCCE(() -> { // receiver reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, int.class, int.class)). - invokeExact(Void.class, 1, 1); + invokeExact(Void.class, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeInt.class, Class.class, int.class)). - invokeExact(recv, Void.class, 1); + invokeExact(recv, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeInt.class, int.class, Class.class)). - invokeExact(recv, 1, Void.class); + invokeExact(recv, 0x01234567, Void.class); }); checkWMTE(() -> { // receiver primitive class boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class , int.class, int.class)). - invokeExact(0, 1, 1); + invokeExact(0, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -735,39 +735,39 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeInt.class, int.class, int.class, Class.class)). - invokeExact(recv, 1, 1, Void.class); + invokeExact(recv, 0x01234567, 0x01234567, Void.class); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { checkNPE(() -> { // null receiver int x = (int) hs.get(am, methodType(int.class, VarHandleTestMethodTypeInt.class, int.class, int.class)). - invokeExact((VarHandleTestMethodTypeInt) null, 1, 1); + invokeExact((VarHandleTestMethodTypeInt) null, 0x01234567, 0x01234567); }); hs.checkWMTEOrCCE(() -> { // receiver reference class int x = (int) hs.get(am, methodType(int.class, Class.class, int.class, int.class)). - invokeExact(Void.class, 1, 1); + invokeExact(Void.class, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class int x = (int) hs.get(am, methodType(int.class, VarHandleTestMethodTypeInt.class, Class.class, int.class)). - invokeExact(recv, Void.class, 1); + invokeExact(recv, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class int x = (int) hs.get(am, methodType(int.class, VarHandleTestMethodTypeInt.class, int.class, Class.class)). - invokeExact(recv, 1, Void.class); + invokeExact(recv, 0x01234567, Void.class); }); checkWMTE(() -> { // reciever primitive class int x = (int) hs.get(am, methodType(int.class, int.class , int.class, int.class)). - invokeExact(0, 1, 1); + invokeExact(0, 0x01234567, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeInt.class , int.class, int.class)). - invokeExact(recv, 1, 1); + invokeExact(recv, 0x01234567, 0x01234567); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeInt.class , int.class, int.class)). - invokeExact(recv, 1, 1); + invokeExact(recv, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -776,18 +776,18 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > int x = (int) hs.get(am, methodType(int.class, VarHandleTestMethodTypeInt.class, int.class, int.class, Class.class)). - invokeExact(recv, 1, 1, Void.class); + invokeExact(recv, 0x01234567, 0x01234567, Void.class); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { checkNPE(() -> { // null receiver int x = (int) hs.get(am, methodType(int.class, VarHandleTestMethodTypeInt.class, int.class)). - invokeExact((VarHandleTestMethodTypeInt) null, 1); + invokeExact((VarHandleTestMethodTypeInt) null, 0x01234567); }); hs.checkWMTEOrCCE(() -> { // receiver reference class int x = (int) hs.get(am, methodType(int.class, Class.class, int.class)). - invokeExact(Void.class, 1); + invokeExact(Void.class, 0x01234567); }); checkWMTE(() -> { // value reference class int x = (int) hs.get(am, methodType(int.class, VarHandleTestMethodTypeInt.class, Class.class)). @@ -795,16 +795,16 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // reciever primitive class int x = (int) hs.get(am, methodType(int.class, int.class, int.class)). - invokeExact(0, 1); + invokeExact(0, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeInt.class, int.class)). - invokeExact(recv, 1); + invokeExact(recv, 0x01234567); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeInt.class, int.class)). - invokeExact(recv, 1); + invokeExact(recv, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -813,18 +813,18 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > int x = (int) hs.get(am, methodType(int.class, VarHandleTestMethodTypeInt.class, int.class)). - invokeExact(recv, 1, Void.class); + invokeExact(recv, 0x01234567, Void.class); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { checkNPE(() -> { // null receiver int x = (int) hs.get(am, methodType(int.class, VarHandleTestMethodTypeInt.class, int.class)). - invokeExact((VarHandleTestMethodTypeInt) null, 1); + invokeExact((VarHandleTestMethodTypeInt) null, 0x01234567); }); hs.checkWMTEOrCCE(() -> { // receiver reference class int x = (int) hs.get(am, methodType(int.class, Class.class, int.class)). - invokeExact(Void.class, 1); + invokeExact(Void.class, 0x01234567); }); checkWMTE(() -> { // value reference class int x = (int) hs.get(am, methodType(int.class, VarHandleTestMethodTypeInt.class, Class.class)). @@ -832,16 +832,16 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // reciever primitive class int x = (int) hs.get(am, methodType(int.class, int.class, int.class)). - invokeExact(0, 1); + invokeExact(0, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeInt.class, int.class)). - invokeExact(recv, 1); + invokeExact(recv, 0x01234567); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeInt.class, int.class)). - invokeExact(recv, 1); + invokeExact(recv, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -850,7 +850,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > int x = (int) hs.get(am, methodType(int.class, VarHandleTestMethodTypeInt.class, int.class)). - invokeExact(recv, 1, Void.class); + invokeExact(recv, 0x01234567, Void.class); }); } } @@ -881,7 +881,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { vh.set(); }); checkWMTE(() -> { // > - vh.set(1, Void.class); + vh.set(0x01234567, Void.class); }); @@ -908,7 +908,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile(1, Void.class); + vh.setVolatile(0x01234567, Void.class); }); @@ -935,7 +935,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque(1, Void.class); + vh.setOpaque(0x01234567, Void.class); }); @@ -962,164 +962,164 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease(1, Void.class); + vh.setRelease(0x01234567, Void.class); }); // CompareAndSet // Incorrect argument types checkWMTE(() -> { // expected reference class - boolean r = vh.compareAndSet(Void.class, 1); + boolean r = vh.compareAndSet(Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.compareAndSet(1, Void.class); + boolean r = vh.compareAndSet(0x01234567, Void.class); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.compareAndSet(); }); checkWMTE(() -> { // > - boolean r = vh.compareAndSet(1, 1, Void.class); + boolean r = vh.compareAndSet(0x01234567, 0x01234567, Void.class); }); // WeakCompareAndSet // Incorrect argument types checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSet(Void.class, 1); + boolean r = vh.weakCompareAndSet(Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSet(1, Void.class); + boolean r = vh.weakCompareAndSet(0x01234567, Void.class); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSet(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSet(1, 1, Void.class); + boolean r = vh.weakCompareAndSet(0x01234567, 0x01234567, Void.class); }); // WeakCompareAndSetVolatile // Incorrect argument types checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetVolatile(Void.class, 1); + boolean r = vh.weakCompareAndSetVolatile(Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetVolatile(1, Void.class); + boolean r = vh.weakCompareAndSetVolatile(0x01234567, Void.class); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetVolatile(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetVolatile(1, 1, Void.class); + boolean r = vh.weakCompareAndSetVolatile(0x01234567, 0x01234567, Void.class); }); // WeakCompareAndSetAcquire // Incorrect argument types checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetAcquire(Void.class, 1); + boolean r = vh.weakCompareAndSetAcquire(Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetAcquire(1, Void.class); + boolean r = vh.weakCompareAndSetAcquire(0x01234567, Void.class); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetAcquire(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetAcquire(1, 1, Void.class); + boolean r = vh.weakCompareAndSetAcquire(0x01234567, 0x01234567, Void.class); }); // WeakCompareAndSetRelease // Incorrect argument types checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetRelease(Void.class, 1); + boolean r = vh.weakCompareAndSetRelease(Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetRelease(1, Void.class); + boolean r = vh.weakCompareAndSetRelease(0x01234567, Void.class); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetRelease(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetRelease(1, 1, Void.class); + boolean r = vh.weakCompareAndSetRelease(0x01234567, 0x01234567, Void.class); }); - // CompareAndExchangeVolatile + // CompareAndExchange // Incorrect argument types checkWMTE(() -> { // expected reference class - int x = (int) vh.compareAndExchangeVolatile(Void.class, 1); + int x = (int) vh.compareAndExchange(Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - int x = (int) vh.compareAndExchangeVolatile(1, Void.class); + int x = (int) vh.compareAndExchange(0x01234567, Void.class); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeVolatile(1, 1); + Void r = (Void) vh.compareAndExchange(0x01234567, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeVolatile(1, 1); + boolean x = (boolean) vh.compareAndExchange(0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 - int x = (int) vh.compareAndExchangeVolatile(); + int x = (int) vh.compareAndExchange(); }); checkWMTE(() -> { // > - int x = (int) vh.compareAndExchangeVolatile(1, 1, Void.class); + int x = (int) vh.compareAndExchange(0x01234567, 0x01234567, Void.class); }); // CompareAndExchangeAcquire // Incorrect argument types checkWMTE(() -> { // expected reference class - int x = (int) vh.compareAndExchangeAcquire(Void.class, 1); + int x = (int) vh.compareAndExchangeAcquire(Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - int x = (int) vh.compareAndExchangeAcquire(1, Void.class); + int x = (int) vh.compareAndExchangeAcquire(0x01234567, Void.class); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeAcquire(1, 1); + Void r = (Void) vh.compareAndExchangeAcquire(0x01234567, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeAcquire(1, 1); + boolean x = (boolean) vh.compareAndExchangeAcquire(0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.compareAndExchangeAcquire(); }); checkWMTE(() -> { // > - int x = (int) vh.compareAndExchangeAcquire(1, 1, Void.class); + int x = (int) vh.compareAndExchangeAcquire(0x01234567, 0x01234567, Void.class); }); // CompareAndExchangeRelease // Incorrect argument types checkWMTE(() -> { // expected reference class - int x = (int) vh.compareAndExchangeRelease(Void.class, 1); + int x = (int) vh.compareAndExchangeRelease(Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - int x = (int) vh.compareAndExchangeRelease(1, Void.class); + int x = (int) vh.compareAndExchangeRelease(0x01234567, Void.class); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeRelease(1, 1); + Void r = (Void) vh.compareAndExchangeRelease(0x01234567, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeRelease(1, 1); + boolean x = (boolean) vh.compareAndExchangeRelease(0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.compareAndExchangeRelease(); }); checkWMTE(() -> { // > - int x = (int) vh.compareAndExchangeRelease(1, 1, Void.class); + int x = (int) vh.compareAndExchangeRelease(0x01234567, 0x01234567, Void.class); }); @@ -1130,17 +1130,17 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.getAndSet(1); + Void r = (Void) vh.getAndSet(0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.getAndSet(1); + boolean x = (boolean) vh.getAndSet(0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.getAndSet(); }); checkWMTE(() -> { // > - int x = (int) vh.getAndSet(1, Void.class); + int x = (int) vh.getAndSet(0x01234567, Void.class); }); // GetAndAdd @@ -1150,17 +1150,17 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.getAndAdd(1); + Void r = (Void) vh.getAndAdd(0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.getAndAdd(1); + boolean x = (boolean) vh.getAndAdd(0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.getAndAdd(); }); checkWMTE(() -> { // > - int x = (int) vh.getAndAdd(1, Void.class); + int x = (int) vh.getAndAdd(0x01234567, Void.class); }); @@ -1171,17 +1171,17 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.addAndGet(1); + Void r = (Void) vh.addAndGet(0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.addAndGet(1); + boolean x = (boolean) vh.addAndGet(0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.addAndGet(); }); checkWMTE(() -> { // > - int x = (int) vh.addAndGet(1, Void.class); + int x = (int) vh.addAndGet(0x01234567, Void.class); }); } @@ -1217,18 +1217,18 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, int.class, Class.class)). - invokeExact(1, Void.class); + invokeExact(0x01234567, Void.class); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { // Incorrect argument types checkWMTE(() -> { // expected reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, int.class)). - invokeExact(Void.class, 1); + invokeExact(Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class, Class.class)). - invokeExact(1, Void.class); + invokeExact(0x01234567, Void.class); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -1237,7 +1237,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class, int.class, Class.class)). - invokeExact(1, 1, Void.class); + invokeExact(0x01234567, 0x01234567, Void.class); }); } @@ -1245,20 +1245,20 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // Incorrect argument types checkWMTE(() -> { // expected reference class int x = (int) hs.get(am, methodType(int.class, Class.class, int.class)). - invokeExact(Void.class, 1); + invokeExact(Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class int x = (int) hs.get(am, methodType(int.class, int.class, Class.class)). - invokeExact(1, Void.class); + invokeExact(0x01234567, Void.class); }); // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, int.class, int.class)). - invokeExact(1, 1); + invokeExact(0x01234567, 0x01234567); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, int.class, int.class)). - invokeExact(1, 1); + invokeExact(0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -1267,7 +1267,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > int x = (int) hs.get(am, methodType(int.class, int.class, int.class, Class.class)). - invokeExact(1, 1, Void.class); + invokeExact(0x01234567, 0x01234567, Void.class); }); } @@ -1280,11 +1280,11 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, int.class)). - invokeExact(1); + invokeExact(0x01234567); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, int.class)). - invokeExact(1); + invokeExact(0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -1293,7 +1293,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > int x = (int) hs.get(am, methodType(int.class, int.class, Class.class)). - invokeExact(1, Void.class); + invokeExact(0x01234567, Void.class); }); } @@ -1306,11 +1306,11 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, int.class)). - invokeExact(1); + invokeExact(0x01234567); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, int.class)). - invokeExact(1); + invokeExact(0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -1319,7 +1319,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > int x = (int) hs.get(am, methodType(int.class, int.class, Class.class)). - invokeExact(1, Void.class); + invokeExact(0x01234567, Void.class); }); } } @@ -1327,7 +1327,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { static void testArrayWrongMethodType(VarHandle vh) throws Throwable { int[] array = new int[10]; - Arrays.fill(array, 1); + Arrays.fill(array, 0x01234567); // Get // Incorrect argument types @@ -1362,26 +1362,26 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // Set // Incorrect argument types checkNPE(() -> { // null array - vh.set(null, 0, 1); + vh.set(null, 0, 0x01234567); }); checkCCE(() -> { // array reference class - vh.set(Void.class, 0, 1); + vh.set(Void.class, 0, 0x01234567); }); checkWMTE(() -> { // value reference class vh.set(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.set(0, 0, 1); + vh.set(0, 0, 0x01234567); }); checkWMTE(() -> { // index reference class - vh.set(array, Void.class, 1); + vh.set(array, Void.class, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 vh.set(); }); checkWMTE(() -> { // > - vh.set(array, 0, 1, Void.class); + vh.set(array, 0, 0x01234567, Void.class); }); @@ -1418,26 +1418,26 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // SetVolatile // Incorrect argument types checkNPE(() -> { // null array - vh.setVolatile(null, 0, 1); + vh.setVolatile(null, 0, 0x01234567); }); checkCCE(() -> { // array reference class - vh.setVolatile(Void.class, 0, 1); + vh.setVolatile(Void.class, 0, 0x01234567); }); checkWMTE(() -> { // value reference class vh.setVolatile(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setVolatile(0, 0, 1); + vh.setVolatile(0, 0, 0x01234567); }); checkWMTE(() -> { // index reference class - vh.setVolatile(array, Void.class, 1); + vh.setVolatile(array, Void.class, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile(array, 0, 1, Void.class); + vh.setVolatile(array, 0, 0x01234567, Void.class); }); @@ -1474,26 +1474,26 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // SetOpaque // Incorrect argument types checkNPE(() -> { // null array - vh.setOpaque(null, 0, 1); + vh.setOpaque(null, 0, 0x01234567); }); checkCCE(() -> { // array reference class - vh.setOpaque(Void.class, 0, 1); + vh.setOpaque(Void.class, 0, 0x01234567); }); checkWMTE(() -> { // value reference class vh.setOpaque(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setOpaque(0, 0, 1); + vh.setOpaque(0, 0, 0x01234567); }); checkWMTE(() -> { // index reference class - vh.setOpaque(array, Void.class, 1); + vh.setOpaque(array, Void.class, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque(array, 0, 1, Void.class); + vh.setOpaque(array, 0, 0x01234567, Void.class); }); @@ -1530,383 +1530,383 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // SetRelease // Incorrect argument types checkNPE(() -> { // null array - vh.setRelease(null, 0, 1); + vh.setRelease(null, 0, 0x01234567); }); checkCCE(() -> { // array reference class - vh.setRelease(Void.class, 0, 1); + vh.setRelease(Void.class, 0, 0x01234567); }); checkWMTE(() -> { // value reference class vh.setRelease(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setRelease(0, 0, 1); + vh.setRelease(0, 0, 0x01234567); }); checkWMTE(() -> { // index reference class - vh.setRelease(array, Void.class, 1); + vh.setRelease(array, Void.class, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease(array, 0, 1, Void.class); + vh.setRelease(array, 0, 0x01234567, Void.class); }); // CompareAndSet // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.compareAndSet(null, 0, 1, 1); + boolean r = vh.compareAndSet(null, 0, 0x01234567, 0x01234567); }); checkCCE(() -> { // receiver reference class - boolean r = vh.compareAndSet(Void.class, 0, 1, 1); + boolean r = vh.compareAndSet(Void.class, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - boolean r = vh.compareAndSet(array, 0, Void.class, 1); + boolean r = vh.compareAndSet(array, 0, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.compareAndSet(array, 0, 1, Void.class); + boolean r = vh.compareAndSet(array, 0, 0x01234567, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.compareAndSet(0, 0, 1, 1); + boolean r = vh.compareAndSet(0, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // index reference class - boolean r = vh.compareAndSet(array, Void.class, 1, 1); + boolean r = vh.compareAndSet(array, Void.class, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.compareAndSet(); }); checkWMTE(() -> { // > - boolean r = vh.compareAndSet(array, 0, 1, 1, Void.class); + boolean r = vh.compareAndSet(array, 0, 0x01234567, 0x01234567, Void.class); }); // WeakCompareAndSet // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSet(null, 0, 1, 1); + boolean r = vh.weakCompareAndSet(null, 0, 0x01234567, 0x01234567); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSet(Void.class, 0, 1, 1); + boolean r = vh.weakCompareAndSet(Void.class, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSet(array, 0, Void.class, 1); + boolean r = vh.weakCompareAndSet(array, 0, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSet(array, 0, 1, Void.class); + boolean r = vh.weakCompareAndSet(array, 0, 0x01234567, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSet(0, 0, 1, 1); + boolean r = vh.weakCompareAndSet(0, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // index reference class - boolean r = vh.weakCompareAndSet(array, Void.class, 1, 1); + boolean r = vh.weakCompareAndSet(array, Void.class, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSet(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSet(array, 0, 1, 1, Void.class); + boolean r = vh.weakCompareAndSet(array, 0, 0x01234567, 0x01234567, Void.class); }); // WeakCompareAndSetVolatile // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSetVolatile(null, 0, 1, 1); + boolean r = vh.weakCompareAndSetVolatile(null, 0, 0x01234567, 0x01234567); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSetVolatile(Void.class, 0, 1, 1); + boolean r = vh.weakCompareAndSetVolatile(Void.class, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetVolatile(array, 0, Void.class, 1); + boolean r = vh.weakCompareAndSetVolatile(array, 0, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetVolatile(array, 0, 1, Void.class); + boolean r = vh.weakCompareAndSetVolatile(array, 0, 0x01234567, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSetVolatile(0, 0, 1, 1); + boolean r = vh.weakCompareAndSetVolatile(0, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // index reference class - boolean r = vh.weakCompareAndSetVolatile(array, Void.class, 1, 1); + boolean r = vh.weakCompareAndSetVolatile(array, Void.class, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetVolatile(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetVolatile(array, 0, 1, 1, Void.class); + boolean r = vh.weakCompareAndSetVolatile(array, 0, 0x01234567, 0x01234567, Void.class); }); // WeakCompareAndSetAcquire // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSetAcquire(null, 0, 1, 1); + boolean r = vh.weakCompareAndSetAcquire(null, 0, 0x01234567, 0x01234567); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSetAcquire(Void.class, 0, 1, 1); + boolean r = vh.weakCompareAndSetAcquire(Void.class, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetAcquire(array, 0, Void.class, 1); + boolean r = vh.weakCompareAndSetAcquire(array, 0, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetAcquire(array, 0, 1, Void.class); + boolean r = vh.weakCompareAndSetAcquire(array, 0, 0x01234567, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSetAcquire(0, 0, 1, 1); + boolean r = vh.weakCompareAndSetAcquire(0, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // index reference class - boolean r = vh.weakCompareAndSetAcquire(array, Void.class, 1, 1); + boolean r = vh.weakCompareAndSetAcquire(array, Void.class, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetAcquire(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetAcquire(array, 0, 1, 1, Void.class); + boolean r = vh.weakCompareAndSetAcquire(array, 0, 0x01234567, 0x01234567, Void.class); }); // WeakCompareAndSetRelease // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSetRelease(null, 0, 1, 1); + boolean r = vh.weakCompareAndSetRelease(null, 0, 0x01234567, 0x01234567); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSetRelease(Void.class, 0, 1, 1); + boolean r = vh.weakCompareAndSetRelease(Void.class, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetRelease(array, 0, Void.class, 1); + boolean r = vh.weakCompareAndSetRelease(array, 0, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetRelease(array, 0, 1, Void.class); + boolean r = vh.weakCompareAndSetRelease(array, 0, 0x01234567, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSetRelease(0, 0, 1, 1); + boolean r = vh.weakCompareAndSetRelease(0, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // index reference class - boolean r = vh.weakCompareAndSetRelease(array, Void.class, 1, 1); + boolean r = vh.weakCompareAndSetRelease(array, Void.class, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetRelease(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetRelease(array, 0, 1, 1, Void.class); + boolean r = vh.weakCompareAndSetRelease(array, 0, 0x01234567, 0x01234567, Void.class); }); - // CompareAndExchangeVolatile + // CompareAndExchange // Incorrect argument types checkNPE(() -> { // null receiver - int x = (int) vh.compareAndExchangeVolatile(null, 0, 1, 1); + int x = (int) vh.compareAndExchange(null, 0, 0x01234567, 0x01234567); }); checkCCE(() -> { // array reference class - int x = (int) vh.compareAndExchangeVolatile(Void.class, 0, 1, 1); + int x = (int) vh.compareAndExchange(Void.class, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - int x = (int) vh.compareAndExchangeVolatile(array, 0, Void.class, 1); + int x = (int) vh.compareAndExchange(array, 0, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - int x = (int) vh.compareAndExchangeVolatile(array, 0, 1, Void.class); + int x = (int) vh.compareAndExchange(array, 0, 0x01234567, Void.class); }); checkWMTE(() -> { // array primitive class - int x = (int) vh.compareAndExchangeVolatile(0, 0, 1, 1); + int x = (int) vh.compareAndExchange(0, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // index reference class - int x = (int) vh.compareAndExchangeVolatile(array, Void.class, 1, 1); + int x = (int) vh.compareAndExchange(array, Void.class, 0x01234567, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeVolatile(array, 0, 1, 1); + Void r = (Void) vh.compareAndExchange(array, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeVolatile(array, 0, 1, 1); + boolean x = (boolean) vh.compareAndExchange(array, 0, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 - int x = (int) vh.compareAndExchangeVolatile(); + int x = (int) vh.compareAndExchange(); }); checkWMTE(() -> { // > - int x = (int) vh.compareAndExchangeVolatile(array, 0, 1, 1, Void.class); + int x = (int) vh.compareAndExchange(array, 0, 0x01234567, 0x01234567, Void.class); }); // CompareAndExchangeAcquire // Incorrect argument types checkNPE(() -> { // null receiver - int x = (int) vh.compareAndExchangeAcquire(null, 0, 1, 1); + int x = (int) vh.compareAndExchangeAcquire(null, 0, 0x01234567, 0x01234567); }); checkCCE(() -> { // array reference class - int x = (int) vh.compareAndExchangeAcquire(Void.class, 0, 1, 1); + int x = (int) vh.compareAndExchangeAcquire(Void.class, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - int x = (int) vh.compareAndExchangeAcquire(array, 0, Void.class, 1); + int x = (int) vh.compareAndExchangeAcquire(array, 0, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - int x = (int) vh.compareAndExchangeAcquire(array, 0, 1, Void.class); + int x = (int) vh.compareAndExchangeAcquire(array, 0, 0x01234567, Void.class); }); checkWMTE(() -> { // array primitive class - int x = (int) vh.compareAndExchangeAcquire(0, 0, 1, 1); + int x = (int) vh.compareAndExchangeAcquire(0, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // index reference class - int x = (int) vh.compareAndExchangeAcquire(array, Void.class, 1, 1); + int x = (int) vh.compareAndExchangeAcquire(array, Void.class, 0x01234567, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeAcquire(array, 0, 1, 1); + Void r = (Void) vh.compareAndExchangeAcquire(array, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeAcquire(array, 0, 1, 1); + boolean x = (boolean) vh.compareAndExchangeAcquire(array, 0, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.compareAndExchangeAcquire(); }); checkWMTE(() -> { // > - int x = (int) vh.compareAndExchangeAcquire(array, 0, 1, 1, Void.class); + int x = (int) vh.compareAndExchangeAcquire(array, 0, 0x01234567, 0x01234567, Void.class); }); // CompareAndExchangeRelease // Incorrect argument types checkNPE(() -> { // null receiver - int x = (int) vh.compareAndExchangeRelease(null, 0, 1, 1); + int x = (int) vh.compareAndExchangeRelease(null, 0, 0x01234567, 0x01234567); }); checkCCE(() -> { // array reference class - int x = (int) vh.compareAndExchangeRelease(Void.class, 0, 1, 1); + int x = (int) vh.compareAndExchangeRelease(Void.class, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class - int x = (int) vh.compareAndExchangeRelease(array, 0, Void.class, 1); + int x = (int) vh.compareAndExchangeRelease(array, 0, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class - int x = (int) vh.compareAndExchangeRelease(array, 0, 1, Void.class); + int x = (int) vh.compareAndExchangeRelease(array, 0, 0x01234567, Void.class); }); checkWMTE(() -> { // array primitive class - int x = (int) vh.compareAndExchangeRelease(0, 0, 1, 1); + int x = (int) vh.compareAndExchangeRelease(0, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // index reference class - int x = (int) vh.compareAndExchangeRelease(array, Void.class, 1, 1); + int x = (int) vh.compareAndExchangeRelease(array, Void.class, 0x01234567, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeRelease(array, 0, 1, 1); + Void r = (Void) vh.compareAndExchangeRelease(array, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeRelease(array, 0, 1, 1); + boolean x = (boolean) vh.compareAndExchangeRelease(array, 0, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.compareAndExchangeRelease(); }); checkWMTE(() -> { // > - int x = (int) vh.compareAndExchangeRelease(array, 0, 1, 1, Void.class); + int x = (int) vh.compareAndExchangeRelease(array, 0, 0x01234567, 0x01234567, Void.class); }); // GetAndSet // Incorrect argument types checkNPE(() -> { // null array - int x = (int) vh.getAndSet(null, 0, 1); + int x = (int) vh.getAndSet(null, 0, 0x01234567); }); checkCCE(() -> { // array reference class - int x = (int) vh.getAndSet(Void.class, 0, 1); + int x = (int) vh.getAndSet(Void.class, 0, 0x01234567); }); checkWMTE(() -> { // value reference class int x = (int) vh.getAndSet(array, 0, Void.class); }); checkWMTE(() -> { // reciarrayever primitive class - int x = (int) vh.getAndSet(0, 0, 1); + int x = (int) vh.getAndSet(0, 0, 0x01234567); }); checkWMTE(() -> { // index reference class - int x = (int) vh.getAndSet(array, Void.class, 1); + int x = (int) vh.getAndSet(array, Void.class, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.getAndSet(array, 0, 1); + Void r = (Void) vh.getAndSet(array, 0, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.getAndSet(array, 0, 1); + boolean x = (boolean) vh.getAndSet(array, 0, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.getAndSet(); }); checkWMTE(() -> { // > - int x = (int) vh.getAndSet(array, 0, 1, Void.class); + int x = (int) vh.getAndSet(array, 0, 0x01234567, Void.class); }); // GetAndAdd // Incorrect argument types checkNPE(() -> { // null array - int x = (int) vh.getAndAdd(null, 0, 1); + int x = (int) vh.getAndAdd(null, 0, 0x01234567); }); checkCCE(() -> { // array reference class - int x = (int) vh.getAndAdd(Void.class, 0, 1); + int x = (int) vh.getAndAdd(Void.class, 0, 0x01234567); }); checkWMTE(() -> { // value reference class int x = (int) vh.getAndAdd(array, 0, Void.class); }); checkWMTE(() -> { // array primitive class - int x = (int) vh.getAndAdd(0, 0, 1); + int x = (int) vh.getAndAdd(0, 0, 0x01234567); }); checkWMTE(() -> { // index reference class - int x = (int) vh.getAndAdd(array, Void.class, 1); + int x = (int) vh.getAndAdd(array, Void.class, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.getAndAdd(array, 0, 1); + Void r = (Void) vh.getAndAdd(array, 0, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.getAndAdd(array, 0, 1); + boolean x = (boolean) vh.getAndAdd(array, 0, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.getAndAdd(); }); checkWMTE(() -> { // > - int x = (int) vh.getAndAdd(array, 0, 1, Void.class); + int x = (int) vh.getAndAdd(array, 0, 0x01234567, Void.class); }); // AddAndGet // Incorrect argument types checkNPE(() -> { // null array - int x = (int) vh.addAndGet(null, 0, 1); + int x = (int) vh.addAndGet(null, 0, 0x01234567); }); checkCCE(() -> { // array reference class - int x = (int) vh.addAndGet(Void.class, 0, 1); + int x = (int) vh.addAndGet(Void.class, 0, 0x01234567); }); checkWMTE(() -> { // value reference class int x = (int) vh.addAndGet(array, 0, Void.class); }); checkWMTE(() -> { // array primitive class - int x = (int) vh.addAndGet(0, 0, 1); + int x = (int) vh.addAndGet(0, 0, 0x01234567); }); checkWMTE(() -> { // index reference class - int x = (int) vh.addAndGet(array, Void.class, 1); + int x = (int) vh.addAndGet(array, Void.class, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.addAndGet(array, 0, 1); + Void r = (Void) vh.addAndGet(array, 0, 0x01234567); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.addAndGet(array, 0, 1); + boolean x = (boolean) vh.addAndGet(array, 0, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 int x = (int) vh.addAndGet(); }); checkWMTE(() -> { // > - int x = (int) vh.addAndGet(array, 0, 1, Void.class); + int x = (int) vh.addAndGet(array, 0, 0x01234567, Void.class); }); } static void testArrayWrongMethodType(Handles hs) throws Throwable { int[] array = new int[10]; - Arrays.fill(array, 1); + Arrays.fill(array, 0x01234567); for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET)) { // Incorrect argument types @@ -1950,11 +1950,11 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null array hs.get(am, methodType(void.class, int[].class, int.class, int.class)). - invokeExact((int[]) null, 0, 1); + invokeExact((int[]) null, 0, 0x01234567); }); hs.checkWMTEOrCCE(() -> { // array reference class hs.get(am, methodType(void.class, Class.class, int.class, int.class)). - invokeExact(Void.class, 0, 1); + invokeExact(Void.class, 0, 0x01234567); }); checkWMTE(() -> { // value reference class hs.get(am, methodType(void.class, int[].class, int.class, Class.class)). @@ -1962,11 +1962,11 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // receiver primitive class hs.get(am, methodType(void.class, int.class, int.class, int.class)). - invokeExact(0, 0, 1); + invokeExact(0, 0, 0x01234567); }); checkWMTE(() -> { // index reference class hs.get(am, methodType(void.class, int[].class, Class.class, int.class)). - invokeExact(array, Void.class, 1); + invokeExact(array, Void.class, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -1975,34 +1975,34 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, int[].class, int.class, Class.class)). - invokeExact(array, 0, 1, Void.class); + invokeExact(array, 0, 0x01234567, Void.class); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { // Incorrect argument types checkNPE(() -> { // null receiver boolean r = (boolean) hs.get(am, methodType(boolean.class, int[].class, int.class, int.class, int.class)). - invokeExact((int[]) null, 0, 1, 1); + invokeExact((int[]) null, 0, 0x01234567, 0x01234567); }); hs.checkWMTEOrCCE(() -> { // receiver reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, int.class, int.class, int.class)). - invokeExact(Void.class, 0, 1, 1); + invokeExact(Void.class, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, int[].class, int.class, Class.class, int.class)). - invokeExact(array, 0, Void.class, 1); + invokeExact(array, 0, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, int[].class, int.class, int.class, Class.class)). - invokeExact(array, 0, 1, Void.class); + invokeExact(array, 0, 0x01234567, Void.class); }); checkWMTE(() -> { // receiver primitive class boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class, int.class, int.class, int.class)). - invokeExact(0, 0, 1, 1); + invokeExact(0, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // index reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, int[].class, Class.class, int.class, int.class)). - invokeExact(array, Void.class, 1, 1); + invokeExact(array, Void.class, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -2011,7 +2011,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > boolean r = (boolean) hs.get(am, methodType(boolean.class, int[].class, int.class, int.class, int.class, Class.class)). - invokeExact(array, 0, 1, 1, Void.class); + invokeExact(array, 0, 0x01234567, 0x01234567, Void.class); }); } @@ -2019,36 +2019,36 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null receiver int x = (int) hs.get(am, methodType(int.class, int[].class, int.class, int.class, int.class)). - invokeExact((int[]) null, 0, 1, 1); + invokeExact((int[]) null, 0, 0x01234567, 0x01234567); }); hs.checkWMTEOrCCE(() -> { // array reference class int x = (int) hs.get(am, methodType(int.class, Class.class, int.class, int.class, int.class)). - invokeExact(Void.class, 0, 1, 1); + invokeExact(Void.class, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // expected reference class int x = (int) hs.get(am, methodType(int.class, int[].class, int.class, Class.class, int.class)). - invokeExact(array, 0, Void.class, 1); + invokeExact(array, 0, Void.class, 0x01234567); }); checkWMTE(() -> { // actual reference class int x = (int) hs.get(am, methodType(int.class, int[].class, int.class, int.class, Class.class)). - invokeExact(array, 0, 1, Void.class); + invokeExact(array, 0, 0x01234567, Void.class); }); checkWMTE(() -> { // array primitive class int x = (int) hs.get(am, methodType(int.class, int.class, int.class, int.class, int.class)). - invokeExact(0, 0, 1, 1); + invokeExact(0, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // index reference class int x = (int) hs.get(am, methodType(int.class, int[].class, Class.class, int.class, int.class)). - invokeExact(array, Void.class, 1, 1); + invokeExact(array, Void.class, 0x01234567, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, int[].class, int.class, int.class, int.class)). - invokeExact(array, 0, 1, 1); + invokeExact(array, 0, 0x01234567, 0x01234567); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, int[].class, int.class, int.class, int.class)). - invokeExact(array, 0, 1, 1); + invokeExact(array, 0, 0x01234567, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -2057,7 +2057,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > int x = (int) hs.get(am, methodType(int.class, int[].class, int.class, int.class, int.class, Class.class)). - invokeExact(array, 0, 1, 1, Void.class); + invokeExact(array, 0, 0x01234567, 0x01234567, Void.class); }); } @@ -2065,11 +2065,11 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null array int x = (int) hs.get(am, methodType(int.class, int[].class, int.class, int.class)). - invokeExact((int[]) null, 0, 1); + invokeExact((int[]) null, 0, 0x01234567); }); hs.checkWMTEOrCCE(() -> { // array reference class int x = (int) hs.get(am, methodType(int.class, Class.class, int.class, int.class)). - invokeExact(Void.class, 0, 1); + invokeExact(Void.class, 0, 0x01234567); }); checkWMTE(() -> { // value reference class int x = (int) hs.get(am, methodType(int.class, int[].class, int.class, Class.class)). @@ -2077,20 +2077,20 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // array primitive class int x = (int) hs.get(am, methodType(int.class, int.class, int.class, int.class)). - invokeExact(0, 0, 1); + invokeExact(0, 0, 0x01234567); }); checkWMTE(() -> { // index reference class int x = (int) hs.get(am, methodType(int.class, int[].class, Class.class, int.class)). - invokeExact(array, Void.class, 1); + invokeExact(array, Void.class, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, int[].class, int.class, int.class)). - invokeExact(array, 0, 1); + invokeExact(array, 0, 0x01234567); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, int[].class, int.class, int.class)). - invokeExact(array, 0, 1); + invokeExact(array, 0, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -2099,7 +2099,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > int x = (int) hs.get(am, methodType(int.class, int[].class, int.class, int.class, Class.class)). - invokeExact(array, 0, 1, Void.class); + invokeExact(array, 0, 0x01234567, Void.class); }); } @@ -2107,11 +2107,11 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null array int x = (int) hs.get(am, methodType(int.class, int[].class, int.class, int.class)). - invokeExact((int[]) null, 0, 1); + invokeExact((int[]) null, 0, 0x01234567); }); hs.checkWMTEOrCCE(() -> { // array reference class int x = (int) hs.get(am, methodType(int.class, Class.class, int.class, int.class)). - invokeExact(Void.class, 0, 1); + invokeExact(Void.class, 0, 0x01234567); }); checkWMTE(() -> { // value reference class int x = (int) hs.get(am, methodType(int.class, int[].class, int.class, Class.class)). @@ -2119,20 +2119,20 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // array primitive class int x = (int) hs.get(am, methodType(int.class, int.class, int.class, int.class)). - invokeExact(0, 0, 1); + invokeExact(0, 0, 0x01234567); }); checkWMTE(() -> { // index reference class int x = (int) hs.get(am, methodType(int.class, int[].class, Class.class, int.class)). - invokeExact(array, Void.class, 1); + invokeExact(array, Void.class, 0x01234567); }); // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, int[].class, int.class, int.class)). - invokeExact(array, 0, 1); + invokeExact(array, 0, 0x01234567); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, int[].class, int.class, int.class)). - invokeExact(array, 0, 1); + invokeExact(array, 0, 0x01234567); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -2141,7 +2141,7 @@ public class VarHandleTestMethodTypeInt extends VarHandleBaseTest { }); checkWMTE(() -> { // > int x = (int) hs.get(am, methodType(int.class, int[].class, int.class, int.class, Class.class)). - invokeExact(array, 0, 1, Void.class); + invokeExact(array, 0, 0x01234567, Void.class); }); } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeLong.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeLong.java index 0972e663cc7..654619335fe 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeLong.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeLong.java @@ -43,13 +43,13 @@ import static org.testng.Assert.*; import static java.lang.invoke.MethodType.*; public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { - static final long static_final_v = 1L; + static final long static_final_v = 0x0123456789ABCDEFL; - static long static_v = 1L; + static long static_v = 0x0123456789ABCDEFL; - final long final_v = 1L; + final long final_v = 0x0123456789ABCDEFL; - long v = 1L; + long v = 0x0123456789ABCDEFL; VarHandle vhFinalField; @@ -154,23 +154,23 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // Set // Incorrect argument types checkNPE(() -> { // null receiver - vh.set(null, 1L); + vh.set(null, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - vh.set(Void.class, 1L); + vh.set(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class vh.set(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.set(0, 1L); + vh.set(0, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 vh.set(); }); checkWMTE(() -> { // > - vh.set(recv, 1L, Void.class); + vh.set(recv, 0x0123456789ABCDEFL, Void.class); }); @@ -204,23 +204,23 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // SetVolatile // Incorrect argument types checkNPE(() -> { // null receiver - vh.setVolatile(null, 1L); + vh.setVolatile(null, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - vh.setVolatile(Void.class, 1L); + vh.setVolatile(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class vh.setVolatile(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setVolatile(0, 1L); + vh.setVolatile(0, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile(recv, 1L, Void.class); + vh.setVolatile(recv, 0x0123456789ABCDEFL, Void.class); }); @@ -254,23 +254,23 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // SetOpaque // Incorrect argument types checkNPE(() -> { // null receiver - vh.setOpaque(null, 1L); + vh.setOpaque(null, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - vh.setOpaque(Void.class, 1L); + vh.setOpaque(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class vh.setOpaque(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setOpaque(0, 1L); + vh.setOpaque(0, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque(recv, 1L, Void.class); + vh.setOpaque(recv, 0x0123456789ABCDEFL, Void.class); }); @@ -304,341 +304,341 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // SetRelease // Incorrect argument types checkNPE(() -> { // null receiver - vh.setRelease(null, 1L); + vh.setRelease(null, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - vh.setRelease(Void.class, 1L); + vh.setRelease(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class vh.setRelease(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setRelease(0, 1L); + vh.setRelease(0, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease(recv, 1L, Void.class); + vh.setRelease(recv, 0x0123456789ABCDEFL, Void.class); }); // CompareAndSet // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.compareAndSet(null, 1L, 1L); + boolean r = vh.compareAndSet(null, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - boolean r = vh.compareAndSet(Void.class, 1L, 1L); + boolean r = vh.compareAndSet(Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - boolean r = vh.compareAndSet(recv, Void.class, 1L); + boolean r = vh.compareAndSet(recv, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.compareAndSet(recv, 1L, Void.class); + boolean r = vh.compareAndSet(recv, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.compareAndSet(0, 1L, 1L); + boolean r = vh.compareAndSet(0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.compareAndSet(); }); checkWMTE(() -> { // > - boolean r = vh.compareAndSet(recv, 1L, 1L, Void.class); + boolean r = vh.compareAndSet(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // WeakCompareAndSet // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSet(null, 1L, 1L); + boolean r = vh.weakCompareAndSet(null, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSet(Void.class, 1L, 1L); + boolean r = vh.weakCompareAndSet(Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSet(recv, Void.class, 1L); + boolean r = vh.weakCompareAndSet(recv, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSet(recv, 1L, Void.class); + boolean r = vh.weakCompareAndSet(recv, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSet(0, 1L, 1L); + boolean r = vh.weakCompareAndSet(0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSet(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSet(recv, 1L, 1L, Void.class); + boolean r = vh.weakCompareAndSet(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // WeakCompareAndSetVolatile // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSetVolatile(null, 1L, 1L); + boolean r = vh.weakCompareAndSetVolatile(null, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSetVolatile(Void.class, 1L, 1L); + boolean r = vh.weakCompareAndSetVolatile(Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetVolatile(recv, Void.class, 1L); + boolean r = vh.weakCompareAndSetVolatile(recv, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetVolatile(recv, 1L, Void.class); + boolean r = vh.weakCompareAndSetVolatile(recv, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSetVolatile(0, 1L, 1L); + boolean r = vh.weakCompareAndSetVolatile(0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetVolatile(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetVolatile(recv, 1L, 1L, Void.class); + boolean r = vh.weakCompareAndSetVolatile(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // WeakCompareAndSetAcquire // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSetAcquire(null, 1L, 1L); + boolean r = vh.weakCompareAndSetAcquire(null, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSetAcquire(Void.class, 1L, 1L); + boolean r = vh.weakCompareAndSetAcquire(Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetAcquire(recv, Void.class, 1L); + boolean r = vh.weakCompareAndSetAcquire(recv, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetAcquire(recv, 1L, Void.class); + boolean r = vh.weakCompareAndSetAcquire(recv, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSetAcquire(0, 1L, 1L); + boolean r = vh.weakCompareAndSetAcquire(0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetAcquire(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetAcquire(recv, 1L, 1L, Void.class); + boolean r = vh.weakCompareAndSetAcquire(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // WeakCompareAndSetRelease // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSetRelease(null, 1L, 1L); + boolean r = vh.weakCompareAndSetRelease(null, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSetRelease(Void.class, 1L, 1L); + boolean r = vh.weakCompareAndSetRelease(Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetRelease(recv, Void.class, 1L); + boolean r = vh.weakCompareAndSetRelease(recv, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetRelease(recv, 1L, Void.class); + boolean r = vh.weakCompareAndSetRelease(recv, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSetRelease(0, 1L, 1L); + boolean r = vh.weakCompareAndSetRelease(0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetRelease(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetRelease(recv, 1L, 1L, Void.class); + boolean r = vh.weakCompareAndSetRelease(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); - // CompareAndExchangeVolatile + // CompareAndExchange // Incorrect argument types checkNPE(() -> { // null receiver - long x = (long) vh.compareAndExchangeVolatile(null, 1L, 1L); + long x = (long) vh.compareAndExchange(null, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - long x = (long) vh.compareAndExchangeVolatile(Void.class, 1L, 1L); + long x = (long) vh.compareAndExchange(Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - long x = (long) vh.compareAndExchangeVolatile(recv, Void.class, 1L); + long x = (long) vh.compareAndExchange(recv, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - long x = (long) vh.compareAndExchangeVolatile(recv, 1L, Void.class); + long x = (long) vh.compareAndExchange(recv, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // reciever primitive class - long x = (long) vh.compareAndExchangeVolatile(0, 1L, 1L); + long x = (long) vh.compareAndExchange(0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeVolatile(recv, 1L, 1L); + Void r = (Void) vh.compareAndExchange(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeVolatile(recv, 1L, 1L); + boolean x = (boolean) vh.compareAndExchange(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 - long x = (long) vh.compareAndExchangeVolatile(); + long x = (long) vh.compareAndExchange(); }); checkWMTE(() -> { // > - long x = (long) vh.compareAndExchangeVolatile(recv, 1L, 1L, Void.class); + long x = (long) vh.compareAndExchange(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); - // CompareAndExchangeVolatileAcquire + // CompareAndExchangeAcquire // Incorrect argument types checkNPE(() -> { // null receiver - long x = (long) vh.compareAndExchangeAcquire(null, 1L, 1L); + long x = (long) vh.compareAndExchangeAcquire(null, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - long x = (long) vh.compareAndExchangeAcquire(Void.class, 1L, 1L); + long x = (long) vh.compareAndExchangeAcquire(Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - long x = (long) vh.compareAndExchangeAcquire(recv, Void.class, 1L); + long x = (long) vh.compareAndExchangeAcquire(recv, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - long x = (long) vh.compareAndExchangeAcquire(recv, 1L, Void.class); + long x = (long) vh.compareAndExchangeAcquire(recv, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // reciever primitive class - long x = (long) vh.compareAndExchangeAcquire(0, 1L, 1L); + long x = (long) vh.compareAndExchangeAcquire(0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeAcquire(recv, 1L, 1L); + Void r = (Void) vh.compareAndExchangeAcquire(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeAcquire(recv, 1L, 1L); + boolean x = (boolean) vh.compareAndExchangeAcquire(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.compareAndExchangeAcquire(); }); checkWMTE(() -> { // > - long x = (long) vh.compareAndExchangeAcquire(recv, 1L, 1L, Void.class); + long x = (long) vh.compareAndExchangeAcquire(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // CompareAndExchangeRelease // Incorrect argument types checkNPE(() -> { // null receiver - long x = (long) vh.compareAndExchangeRelease(null, 1L, 1L); + long x = (long) vh.compareAndExchangeRelease(null, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - long x = (long) vh.compareAndExchangeRelease(Void.class, 1L, 1L); + long x = (long) vh.compareAndExchangeRelease(Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - long x = (long) vh.compareAndExchangeRelease(recv, Void.class, 1L); + long x = (long) vh.compareAndExchangeRelease(recv, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - long x = (long) vh.compareAndExchangeRelease(recv, 1L, Void.class); + long x = (long) vh.compareAndExchangeRelease(recv, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // reciever primitive class - long x = (long) vh.compareAndExchangeRelease(0, 1L, 1L); + long x = (long) vh.compareAndExchangeRelease(0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeRelease(recv, 1L, 1L); + Void r = (Void) vh.compareAndExchangeRelease(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeRelease(recv, 1L, 1L); + boolean x = (boolean) vh.compareAndExchangeRelease(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.compareAndExchangeRelease(); }); checkWMTE(() -> { // > - long x = (long) vh.compareAndExchangeRelease(recv, 1L, 1L, Void.class); + long x = (long) vh.compareAndExchangeRelease(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // GetAndSet // Incorrect argument types checkNPE(() -> { // null receiver - long x = (long) vh.getAndSet(null, 1L); + long x = (long) vh.getAndSet(null, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - long x = (long) vh.getAndSet(Void.class, 1L); + long x = (long) vh.getAndSet(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class long x = (long) vh.getAndSet(recv, Void.class); }); checkWMTE(() -> { // reciever primitive class - long x = (long) vh.getAndSet(0, 1L); + long x = (long) vh.getAndSet(0, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.getAndSet(recv, 1L); + Void r = (Void) vh.getAndSet(recv, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.getAndSet(recv, 1L); + boolean x = (boolean) vh.getAndSet(recv, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.getAndSet(); }); checkWMTE(() -> { // > - long x = (long) vh.getAndSet(recv, 1L, Void.class); + long x = (long) vh.getAndSet(recv, 0x0123456789ABCDEFL, Void.class); }); // GetAndAdd // Incorrect argument types checkNPE(() -> { // null receiver - long x = (long) vh.getAndAdd(null, 1L); + long x = (long) vh.getAndAdd(null, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - long x = (long) vh.getAndAdd(Void.class, 1L); + long x = (long) vh.getAndAdd(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class long x = (long) vh.getAndAdd(recv, Void.class); }); checkWMTE(() -> { // reciever primitive class - long x = (long) vh.getAndAdd(0, 1L); + long x = (long) vh.getAndAdd(0, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.getAndAdd(recv, 1L); + Void r = (Void) vh.getAndAdd(recv, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.getAndAdd(recv, 1L); + boolean x = (boolean) vh.getAndAdd(recv, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.getAndAdd(); }); checkWMTE(() -> { // > - long x = (long) vh.getAndAdd(recv, 1L, Void.class); + long x = (long) vh.getAndAdd(recv, 0x0123456789ABCDEFL, Void.class); }); // AddAndGet // Incorrect argument types checkNPE(() -> { // null receiver - long x = (long) vh.addAndGet(null, 1L); + long x = (long) vh.addAndGet(null, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - long x = (long) vh.addAndGet(Void.class, 1L); + long x = (long) vh.addAndGet(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class long x = (long) vh.addAndGet(recv, Void.class); }); checkWMTE(() -> { // reciever primitive class - long x = (long) vh.addAndGet(0, 1L); + long x = (long) vh.addAndGet(0, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.addAndGet(recv, 1L); + Void r = (Void) vh.addAndGet(recv, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.addAndGet(recv, 1L); + boolean x = (boolean) vh.addAndGet(recv, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.addAndGet(); }); checkWMTE(() -> { // > - long x = (long) vh.addAndGet(recv, 1L, Void.class); + long x = (long) vh.addAndGet(recv, 0x0123456789ABCDEFL, Void.class); }); } @@ -681,11 +681,11 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null receiver hs.get(am, methodType(void.class, VarHandleTestMethodTypeLong.class, long.class)). - invokeExact((VarHandleTestMethodTypeLong) null, 1L); + invokeExact((VarHandleTestMethodTypeLong) null, 0x0123456789ABCDEFL); }); hs.checkWMTEOrCCE(() -> { // receiver reference class hs.get(am, methodType(void.class, Class.class, long.class)). - invokeExact(Void.class, 1L); + invokeExact(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class hs.get(am, methodType(void.class, VarHandleTestMethodTypeLong.class, Class.class)). @@ -693,7 +693,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // receiver primitive class hs.get(am, methodType(void.class, int.class, long.class)). - invokeExact(0, 1L); + invokeExact(0, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -702,7 +702,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, VarHandleTestMethodTypeLong.class, long.class, Class.class)). - invokeExact(recv, 1L, Void.class); + invokeExact(recv, 0x0123456789ABCDEFL, Void.class); }); } @@ -710,23 +710,23 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null receiver boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeLong.class, long.class, long.class)). - invokeExact((VarHandleTestMethodTypeLong) null, 1L, 1L); + invokeExact((VarHandleTestMethodTypeLong) null, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); hs.checkWMTEOrCCE(() -> { // receiver reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, long.class, long.class)). - invokeExact(Void.class, 1L, 1L); + invokeExact(Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeLong.class, Class.class, long.class)). - invokeExact(recv, Void.class, 1L); + invokeExact(recv, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeLong.class, long.class, Class.class)). - invokeExact(recv, 1L, Void.class); + invokeExact(recv, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // receiver primitive class boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class , long.class, long.class)). - invokeExact(0, 1L, 1L); + invokeExact(0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -735,39 +735,39 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeLong.class, long.class, long.class, Class.class)). - invokeExact(recv, 1L, 1L, Void.class); + invokeExact(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { checkNPE(() -> { // null receiver long x = (long) hs.get(am, methodType(long.class, VarHandleTestMethodTypeLong.class, long.class, long.class)). - invokeExact((VarHandleTestMethodTypeLong) null, 1L, 1L); + invokeExact((VarHandleTestMethodTypeLong) null, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); hs.checkWMTEOrCCE(() -> { // receiver reference class long x = (long) hs.get(am, methodType(long.class, Class.class, long.class, long.class)). - invokeExact(Void.class, 1L, 1L); + invokeExact(Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class long x = (long) hs.get(am, methodType(long.class, VarHandleTestMethodTypeLong.class, Class.class, long.class)). - invokeExact(recv, Void.class, 1L); + invokeExact(recv, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class long x = (long) hs.get(am, methodType(long.class, VarHandleTestMethodTypeLong.class, long.class, Class.class)). - invokeExact(recv, 1L, Void.class); + invokeExact(recv, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // reciever primitive class long x = (long) hs.get(am, methodType(long.class, int.class , long.class, long.class)). - invokeExact(0, 1L, 1L); + invokeExact(0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeLong.class , long.class, long.class)). - invokeExact(recv, 1L, 1L); + invokeExact(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeLong.class , long.class, long.class)). - invokeExact(recv, 1L, 1L); + invokeExact(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -776,18 +776,18 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > long x = (long) hs.get(am, methodType(long.class, VarHandleTestMethodTypeLong.class, long.class, long.class, Class.class)). - invokeExact(recv, 1L, 1L, Void.class); + invokeExact(recv, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { checkNPE(() -> { // null receiver long x = (long) hs.get(am, methodType(long.class, VarHandleTestMethodTypeLong.class, long.class)). - invokeExact((VarHandleTestMethodTypeLong) null, 1L); + invokeExact((VarHandleTestMethodTypeLong) null, 0x0123456789ABCDEFL); }); hs.checkWMTEOrCCE(() -> { // receiver reference class long x = (long) hs.get(am, methodType(long.class, Class.class, long.class)). - invokeExact(Void.class, 1L); + invokeExact(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class long x = (long) hs.get(am, methodType(long.class, VarHandleTestMethodTypeLong.class, Class.class)). @@ -795,16 +795,16 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // reciever primitive class long x = (long) hs.get(am, methodType(long.class, int.class, long.class)). - invokeExact(0, 1L); + invokeExact(0, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeLong.class, long.class)). - invokeExact(recv, 1L); + invokeExact(recv, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeLong.class, long.class)). - invokeExact(recv, 1L); + invokeExact(recv, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -813,18 +813,18 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > long x = (long) hs.get(am, methodType(long.class, VarHandleTestMethodTypeLong.class, long.class)). - invokeExact(recv, 1L, Void.class); + invokeExact(recv, 0x0123456789ABCDEFL, Void.class); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { checkNPE(() -> { // null receiver long x = (long) hs.get(am, methodType(long.class, VarHandleTestMethodTypeLong.class, long.class)). - invokeExact((VarHandleTestMethodTypeLong) null, 1L); + invokeExact((VarHandleTestMethodTypeLong) null, 0x0123456789ABCDEFL); }); hs.checkWMTEOrCCE(() -> { // receiver reference class long x = (long) hs.get(am, methodType(long.class, Class.class, long.class)). - invokeExact(Void.class, 1L); + invokeExact(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class long x = (long) hs.get(am, methodType(long.class, VarHandleTestMethodTypeLong.class, Class.class)). @@ -832,16 +832,16 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // reciever primitive class long x = (long) hs.get(am, methodType(long.class, int.class, long.class)). - invokeExact(0, 1L); + invokeExact(0, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeLong.class, long.class)). - invokeExact(recv, 1L); + invokeExact(recv, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeLong.class, long.class)). - invokeExact(recv, 1L); + invokeExact(recv, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -850,7 +850,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > long x = (long) hs.get(am, methodType(long.class, VarHandleTestMethodTypeLong.class, long.class)). - invokeExact(recv, 1L, Void.class); + invokeExact(recv, 0x0123456789ABCDEFL, Void.class); }); } } @@ -881,7 +881,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { vh.set(); }); checkWMTE(() -> { // > - vh.set(1L, Void.class); + vh.set(0x0123456789ABCDEFL, Void.class); }); @@ -908,7 +908,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile(1L, Void.class); + vh.setVolatile(0x0123456789ABCDEFL, Void.class); }); @@ -935,7 +935,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque(1L, Void.class); + vh.setOpaque(0x0123456789ABCDEFL, Void.class); }); @@ -962,164 +962,164 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease(1L, Void.class); + vh.setRelease(0x0123456789ABCDEFL, Void.class); }); // CompareAndSet // Incorrect argument types checkWMTE(() -> { // expected reference class - boolean r = vh.compareAndSet(Void.class, 1L); + boolean r = vh.compareAndSet(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.compareAndSet(1L, Void.class); + boolean r = vh.compareAndSet(0x0123456789ABCDEFL, Void.class); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.compareAndSet(); }); checkWMTE(() -> { // > - boolean r = vh.compareAndSet(1L, 1L, Void.class); + boolean r = vh.compareAndSet(0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // WeakCompareAndSet // Incorrect argument types checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSet(Void.class, 1L); + boolean r = vh.weakCompareAndSet(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSet(1L, Void.class); + boolean r = vh.weakCompareAndSet(0x0123456789ABCDEFL, Void.class); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSet(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSet(1L, 1L, Void.class); + boolean r = vh.weakCompareAndSet(0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // WeakCompareAndSetVolatile // Incorrect argument types checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetVolatile(Void.class, 1L); + boolean r = vh.weakCompareAndSetVolatile(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetVolatile(1L, Void.class); + boolean r = vh.weakCompareAndSetVolatile(0x0123456789ABCDEFL, Void.class); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetVolatile(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetVolatile(1L, 1L, Void.class); + boolean r = vh.weakCompareAndSetVolatile(0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // WeakCompareAndSetAcquire // Incorrect argument types checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetAcquire(Void.class, 1L); + boolean r = vh.weakCompareAndSetAcquire(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetAcquire(1L, Void.class); + boolean r = vh.weakCompareAndSetAcquire(0x0123456789ABCDEFL, Void.class); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetAcquire(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetAcquire(1L, 1L, Void.class); + boolean r = vh.weakCompareAndSetAcquire(0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // WeakCompareAndSetRelease // Incorrect argument types checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetRelease(Void.class, 1L); + boolean r = vh.weakCompareAndSetRelease(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetRelease(1L, Void.class); + boolean r = vh.weakCompareAndSetRelease(0x0123456789ABCDEFL, Void.class); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetRelease(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetRelease(1L, 1L, Void.class); + boolean r = vh.weakCompareAndSetRelease(0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); - // CompareAndExchangeVolatile + // CompareAndExchange // Incorrect argument types checkWMTE(() -> { // expected reference class - long x = (long) vh.compareAndExchangeVolatile(Void.class, 1L); + long x = (long) vh.compareAndExchange(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - long x = (long) vh.compareAndExchangeVolatile(1L, Void.class); + long x = (long) vh.compareAndExchange(0x0123456789ABCDEFL, Void.class); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeVolatile(1L, 1L); + Void r = (Void) vh.compareAndExchange(0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeVolatile(1L, 1L); + boolean x = (boolean) vh.compareAndExchange(0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 - long x = (long) vh.compareAndExchangeVolatile(); + long x = (long) vh.compareAndExchange(); }); checkWMTE(() -> { // > - long x = (long) vh.compareAndExchangeVolatile(1L, 1L, Void.class); + long x = (long) vh.compareAndExchange(0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // CompareAndExchangeAcquire // Incorrect argument types checkWMTE(() -> { // expected reference class - long x = (long) vh.compareAndExchangeAcquire(Void.class, 1L); + long x = (long) vh.compareAndExchangeAcquire(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - long x = (long) vh.compareAndExchangeAcquire(1L, Void.class); + long x = (long) vh.compareAndExchangeAcquire(0x0123456789ABCDEFL, Void.class); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeAcquire(1L, 1L); + Void r = (Void) vh.compareAndExchangeAcquire(0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeAcquire(1L, 1L); + boolean x = (boolean) vh.compareAndExchangeAcquire(0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.compareAndExchangeAcquire(); }); checkWMTE(() -> { // > - long x = (long) vh.compareAndExchangeAcquire(1L, 1L, Void.class); + long x = (long) vh.compareAndExchangeAcquire(0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // CompareAndExchangeRelease // Incorrect argument types checkWMTE(() -> { // expected reference class - long x = (long) vh.compareAndExchangeRelease(Void.class, 1L); + long x = (long) vh.compareAndExchangeRelease(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - long x = (long) vh.compareAndExchangeRelease(1L, Void.class); + long x = (long) vh.compareAndExchangeRelease(0x0123456789ABCDEFL, Void.class); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeRelease(1L, 1L); + Void r = (Void) vh.compareAndExchangeRelease(0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeRelease(1L, 1L); + boolean x = (boolean) vh.compareAndExchangeRelease(0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.compareAndExchangeRelease(); }); checkWMTE(() -> { // > - long x = (long) vh.compareAndExchangeRelease(1L, 1L, Void.class); + long x = (long) vh.compareAndExchangeRelease(0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); @@ -1130,17 +1130,17 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.getAndSet(1L); + Void r = (Void) vh.getAndSet(0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.getAndSet(1L); + boolean x = (boolean) vh.getAndSet(0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.getAndSet(); }); checkWMTE(() -> { // > - long x = (long) vh.getAndSet(1L, Void.class); + long x = (long) vh.getAndSet(0x0123456789ABCDEFL, Void.class); }); // GetAndAdd @@ -1150,17 +1150,17 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.getAndAdd(1L); + Void r = (Void) vh.getAndAdd(0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.getAndAdd(1L); + boolean x = (boolean) vh.getAndAdd(0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.getAndAdd(); }); checkWMTE(() -> { // > - long x = (long) vh.getAndAdd(1L, Void.class); + long x = (long) vh.getAndAdd(0x0123456789ABCDEFL, Void.class); }); @@ -1171,17 +1171,17 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.addAndGet(1L); + Void r = (Void) vh.addAndGet(0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.addAndGet(1L); + boolean x = (boolean) vh.addAndGet(0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.addAndGet(); }); checkWMTE(() -> { // > - long x = (long) vh.addAndGet(1L, Void.class); + long x = (long) vh.addAndGet(0x0123456789ABCDEFL, Void.class); }); } @@ -1217,18 +1217,18 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, long.class, Class.class)). - invokeExact(1L, Void.class); + invokeExact(0x0123456789ABCDEFL, Void.class); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { // Incorrect argument types checkWMTE(() -> { // expected reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, long.class)). - invokeExact(Void.class, 1L); + invokeExact(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, long.class, Class.class)). - invokeExact(1L, Void.class); + invokeExact(0x0123456789ABCDEFL, Void.class); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -1237,7 +1237,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > boolean r = (boolean) hs.get(am, methodType(boolean.class, long.class, long.class, Class.class)). - invokeExact(1L, 1L, Void.class); + invokeExact(0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); } @@ -1245,20 +1245,20 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // Incorrect argument types checkWMTE(() -> { // expected reference class long x = (long) hs.get(am, methodType(long.class, Class.class, long.class)). - invokeExact(Void.class, 1L); + invokeExact(Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class long x = (long) hs.get(am, methodType(long.class, long.class, Class.class)). - invokeExact(1L, Void.class); + invokeExact(0x0123456789ABCDEFL, Void.class); }); // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, long.class, long.class)). - invokeExact(1L, 1L); + invokeExact(0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, long.class, long.class)). - invokeExact(1L, 1L); + invokeExact(0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -1267,7 +1267,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > long x = (long) hs.get(am, methodType(long.class, long.class, long.class, Class.class)). - invokeExact(1L, 1L, Void.class); + invokeExact(0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); } @@ -1280,11 +1280,11 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, long.class)). - invokeExact(1L); + invokeExact(0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, long.class)). - invokeExact(1L); + invokeExact(0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -1293,7 +1293,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > long x = (long) hs.get(am, methodType(long.class, long.class, Class.class)). - invokeExact(1L, Void.class); + invokeExact(0x0123456789ABCDEFL, Void.class); }); } @@ -1306,11 +1306,11 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, long.class)). - invokeExact(1L); + invokeExact(0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, long.class)). - invokeExact(1L); + invokeExact(0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -1319,7 +1319,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > long x = (long) hs.get(am, methodType(long.class, long.class, Class.class)). - invokeExact(1L, Void.class); + invokeExact(0x0123456789ABCDEFL, Void.class); }); } } @@ -1327,7 +1327,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { static void testArrayWrongMethodType(VarHandle vh) throws Throwable { long[] array = new long[10]; - Arrays.fill(array, 1L); + Arrays.fill(array, 0x0123456789ABCDEFL); // Get // Incorrect argument types @@ -1362,26 +1362,26 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // Set // Incorrect argument types checkNPE(() -> { // null array - vh.set(null, 0, 1L); + vh.set(null, 0, 0x0123456789ABCDEFL); }); checkCCE(() -> { // array reference class - vh.set(Void.class, 0, 1L); + vh.set(Void.class, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class vh.set(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.set(0, 0, 1L); + vh.set(0, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - vh.set(array, Void.class, 1L); + vh.set(array, Void.class, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 vh.set(); }); checkWMTE(() -> { // > - vh.set(array, 0, 1L, Void.class); + vh.set(array, 0, 0x0123456789ABCDEFL, Void.class); }); @@ -1418,26 +1418,26 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // SetVolatile // Incorrect argument types checkNPE(() -> { // null array - vh.setVolatile(null, 0, 1L); + vh.setVolatile(null, 0, 0x0123456789ABCDEFL); }); checkCCE(() -> { // array reference class - vh.setVolatile(Void.class, 0, 1L); + vh.setVolatile(Void.class, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class vh.setVolatile(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setVolatile(0, 0, 1L); + vh.setVolatile(0, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - vh.setVolatile(array, Void.class, 1L); + vh.setVolatile(array, Void.class, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile(array, 0, 1L, Void.class); + vh.setVolatile(array, 0, 0x0123456789ABCDEFL, Void.class); }); @@ -1474,26 +1474,26 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // SetOpaque // Incorrect argument types checkNPE(() -> { // null array - vh.setOpaque(null, 0, 1L); + vh.setOpaque(null, 0, 0x0123456789ABCDEFL); }); checkCCE(() -> { // array reference class - vh.setOpaque(Void.class, 0, 1L); + vh.setOpaque(Void.class, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class vh.setOpaque(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setOpaque(0, 0, 1L); + vh.setOpaque(0, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - vh.setOpaque(array, Void.class, 1L); + vh.setOpaque(array, Void.class, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque(array, 0, 1L, Void.class); + vh.setOpaque(array, 0, 0x0123456789ABCDEFL, Void.class); }); @@ -1530,383 +1530,383 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // SetRelease // Incorrect argument types checkNPE(() -> { // null array - vh.setRelease(null, 0, 1L); + vh.setRelease(null, 0, 0x0123456789ABCDEFL); }); checkCCE(() -> { // array reference class - vh.setRelease(Void.class, 0, 1L); + vh.setRelease(Void.class, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class vh.setRelease(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setRelease(0, 0, 1L); + vh.setRelease(0, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - vh.setRelease(array, Void.class, 1L); + vh.setRelease(array, Void.class, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease(array, 0, 1L, Void.class); + vh.setRelease(array, 0, 0x0123456789ABCDEFL, Void.class); }); // CompareAndSet // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.compareAndSet(null, 0, 1L, 1L); + boolean r = vh.compareAndSet(null, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - boolean r = vh.compareAndSet(Void.class, 0, 1L, 1L); + boolean r = vh.compareAndSet(Void.class, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - boolean r = vh.compareAndSet(array, 0, Void.class, 1L); + boolean r = vh.compareAndSet(array, 0, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.compareAndSet(array, 0, 1L, Void.class); + boolean r = vh.compareAndSet(array, 0, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.compareAndSet(0, 0, 1L, 1L); + boolean r = vh.compareAndSet(0, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - boolean r = vh.compareAndSet(array, Void.class, 1L, 1L); + boolean r = vh.compareAndSet(array, Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.compareAndSet(); }); checkWMTE(() -> { // > - boolean r = vh.compareAndSet(array, 0, 1L, 1L, Void.class); + boolean r = vh.compareAndSet(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // WeakCompareAndSet // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSet(null, 0, 1L, 1L); + boolean r = vh.weakCompareAndSet(null, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSet(Void.class, 0, 1L, 1L); + boolean r = vh.weakCompareAndSet(Void.class, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSet(array, 0, Void.class, 1L); + boolean r = vh.weakCompareAndSet(array, 0, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSet(array, 0, 1L, Void.class); + boolean r = vh.weakCompareAndSet(array, 0, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSet(0, 0, 1L, 1L); + boolean r = vh.weakCompareAndSet(0, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - boolean r = vh.weakCompareAndSet(array, Void.class, 1L, 1L); + boolean r = vh.weakCompareAndSet(array, Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSet(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSet(array, 0, 1L, 1L, Void.class); + boolean r = vh.weakCompareAndSet(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // WeakCompareAndSetVolatile // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSetVolatile(null, 0, 1L, 1L); + boolean r = vh.weakCompareAndSetVolatile(null, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSetVolatile(Void.class, 0, 1L, 1L); + boolean r = vh.weakCompareAndSetVolatile(Void.class, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetVolatile(array, 0, Void.class, 1L); + boolean r = vh.weakCompareAndSetVolatile(array, 0, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetVolatile(array, 0, 1L, Void.class); + boolean r = vh.weakCompareAndSetVolatile(array, 0, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSetVolatile(0, 0, 1L, 1L); + boolean r = vh.weakCompareAndSetVolatile(0, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - boolean r = vh.weakCompareAndSetVolatile(array, Void.class, 1L, 1L); + boolean r = vh.weakCompareAndSetVolatile(array, Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetVolatile(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetVolatile(array, 0, 1L, 1L, Void.class); + boolean r = vh.weakCompareAndSetVolatile(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // WeakCompareAndSetAcquire // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSetAcquire(null, 0, 1L, 1L); + boolean r = vh.weakCompareAndSetAcquire(null, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSetAcquire(Void.class, 0, 1L, 1L); + boolean r = vh.weakCompareAndSetAcquire(Void.class, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetAcquire(array, 0, Void.class, 1L); + boolean r = vh.weakCompareAndSetAcquire(array, 0, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetAcquire(array, 0, 1L, Void.class); + boolean r = vh.weakCompareAndSetAcquire(array, 0, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSetAcquire(0, 0, 1L, 1L); + boolean r = vh.weakCompareAndSetAcquire(0, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - boolean r = vh.weakCompareAndSetAcquire(array, Void.class, 1L, 1L); + boolean r = vh.weakCompareAndSetAcquire(array, Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetAcquire(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetAcquire(array, 0, 1L, 1L, Void.class); + boolean r = vh.weakCompareAndSetAcquire(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // WeakCompareAndSetRelease // Incorrect argument types checkNPE(() -> { // null receiver - boolean r = vh.weakCompareAndSetRelease(null, 0, 1L, 1L); + boolean r = vh.weakCompareAndSetRelease(null, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // receiver reference class - boolean r = vh.weakCompareAndSetRelease(Void.class, 0, 1L, 1L); + boolean r = vh.weakCompareAndSetRelease(Void.class, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - boolean r = vh.weakCompareAndSetRelease(array, 0, Void.class, 1L); + boolean r = vh.weakCompareAndSetRelease(array, 0, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - boolean r = vh.weakCompareAndSetRelease(array, 0, 1L, Void.class); + boolean r = vh.weakCompareAndSetRelease(array, 0, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // receiver primitive class - boolean r = vh.weakCompareAndSetRelease(0, 0, 1L, 1L); + boolean r = vh.weakCompareAndSetRelease(0, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - boolean r = vh.weakCompareAndSetRelease(array, Void.class, 1L, 1L); + boolean r = vh.weakCompareAndSetRelease(array, Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 boolean r = vh.weakCompareAndSetRelease(); }); checkWMTE(() -> { // > - boolean r = vh.weakCompareAndSetRelease(array, 0, 1L, 1L, Void.class); + boolean r = vh.weakCompareAndSetRelease(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); - // CompareAndExchangeVolatile + // CompareAndExchange // Incorrect argument types checkNPE(() -> { // null receiver - long x = (long) vh.compareAndExchangeVolatile(null, 0, 1L, 1L); + long x = (long) vh.compareAndExchange(null, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // array reference class - long x = (long) vh.compareAndExchangeVolatile(Void.class, 0, 1L, 1L); + long x = (long) vh.compareAndExchange(Void.class, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - long x = (long) vh.compareAndExchangeVolatile(array, 0, Void.class, 1L); + long x = (long) vh.compareAndExchange(array, 0, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - long x = (long) vh.compareAndExchangeVolatile(array, 0, 1L, Void.class); + long x = (long) vh.compareAndExchange(array, 0, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // array primitive class - long x = (long) vh.compareAndExchangeVolatile(0, 0, 1L, 1L); + long x = (long) vh.compareAndExchange(0, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - long x = (long) vh.compareAndExchangeVolatile(array, Void.class, 1L, 1L); + long x = (long) vh.compareAndExchange(array, Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeVolatile(array, 0, 1L, 1L); + Void r = (Void) vh.compareAndExchange(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeVolatile(array, 0, 1L, 1L); + boolean x = (boolean) vh.compareAndExchange(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 - long x = (long) vh.compareAndExchangeVolatile(); + long x = (long) vh.compareAndExchange(); }); checkWMTE(() -> { // > - long x = (long) vh.compareAndExchangeVolatile(array, 0, 1L, 1L, Void.class); + long x = (long) vh.compareAndExchange(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // CompareAndExchangeAcquire // Incorrect argument types checkNPE(() -> { // null receiver - long x = (long) vh.compareAndExchangeAcquire(null, 0, 1L, 1L); + long x = (long) vh.compareAndExchangeAcquire(null, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // array reference class - long x = (long) vh.compareAndExchangeAcquire(Void.class, 0, 1L, 1L); + long x = (long) vh.compareAndExchangeAcquire(Void.class, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - long x = (long) vh.compareAndExchangeAcquire(array, 0, Void.class, 1L); + long x = (long) vh.compareAndExchangeAcquire(array, 0, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - long x = (long) vh.compareAndExchangeAcquire(array, 0, 1L, Void.class); + long x = (long) vh.compareAndExchangeAcquire(array, 0, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // array primitive class - long x = (long) vh.compareAndExchangeAcquire(0, 0, 1L, 1L); + long x = (long) vh.compareAndExchangeAcquire(0, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - long x = (long) vh.compareAndExchangeAcquire(array, Void.class, 1L, 1L); + long x = (long) vh.compareAndExchangeAcquire(array, Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeAcquire(array, 0, 1L, 1L); + Void r = (Void) vh.compareAndExchangeAcquire(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeAcquire(array, 0, 1L, 1L); + boolean x = (boolean) vh.compareAndExchangeAcquire(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.compareAndExchangeAcquire(); }); checkWMTE(() -> { // > - long x = (long) vh.compareAndExchangeAcquire(array, 0, 1L, 1L, Void.class); + long x = (long) vh.compareAndExchangeAcquire(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // CompareAndExchangeRelease // Incorrect argument types checkNPE(() -> { // null receiver - long x = (long) vh.compareAndExchangeRelease(null, 0, 1L, 1L); + long x = (long) vh.compareAndExchangeRelease(null, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkCCE(() -> { // array reference class - long x = (long) vh.compareAndExchangeRelease(Void.class, 0, 1L, 1L); + long x = (long) vh.compareAndExchangeRelease(Void.class, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class - long x = (long) vh.compareAndExchangeRelease(array, 0, Void.class, 1L); + long x = (long) vh.compareAndExchangeRelease(array, 0, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class - long x = (long) vh.compareAndExchangeRelease(array, 0, 1L, Void.class); + long x = (long) vh.compareAndExchangeRelease(array, 0, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // array primitive class - long x = (long) vh.compareAndExchangeRelease(0, 0, 1L, 1L); + long x = (long) vh.compareAndExchangeRelease(0, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - long x = (long) vh.compareAndExchangeRelease(array, Void.class, 1L, 1L); + long x = (long) vh.compareAndExchangeRelease(array, Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeRelease(array, 0, 1L, 1L); + Void r = (Void) vh.compareAndExchangeRelease(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeRelease(array, 0, 1L, 1L); + boolean x = (boolean) vh.compareAndExchangeRelease(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.compareAndExchangeRelease(); }); checkWMTE(() -> { // > - long x = (long) vh.compareAndExchangeRelease(array, 0, 1L, 1L, Void.class); + long x = (long) vh.compareAndExchangeRelease(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); // GetAndSet // Incorrect argument types checkNPE(() -> { // null array - long x = (long) vh.getAndSet(null, 0, 1L); + long x = (long) vh.getAndSet(null, 0, 0x0123456789ABCDEFL); }); checkCCE(() -> { // array reference class - long x = (long) vh.getAndSet(Void.class, 0, 1L); + long x = (long) vh.getAndSet(Void.class, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class long x = (long) vh.getAndSet(array, 0, Void.class); }); checkWMTE(() -> { // reciarrayever primitive class - long x = (long) vh.getAndSet(0, 0, 1L); + long x = (long) vh.getAndSet(0, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - long x = (long) vh.getAndSet(array, Void.class, 1L); + long x = (long) vh.getAndSet(array, Void.class, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.getAndSet(array, 0, 1L); + Void r = (Void) vh.getAndSet(array, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.getAndSet(array, 0, 1L); + boolean x = (boolean) vh.getAndSet(array, 0, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.getAndSet(); }); checkWMTE(() -> { // > - long x = (long) vh.getAndSet(array, 0, 1L, Void.class); + long x = (long) vh.getAndSet(array, 0, 0x0123456789ABCDEFL, Void.class); }); // GetAndAdd // Incorrect argument types checkNPE(() -> { // null array - long x = (long) vh.getAndAdd(null, 0, 1L); + long x = (long) vh.getAndAdd(null, 0, 0x0123456789ABCDEFL); }); checkCCE(() -> { // array reference class - long x = (long) vh.getAndAdd(Void.class, 0, 1L); + long x = (long) vh.getAndAdd(Void.class, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class long x = (long) vh.getAndAdd(array, 0, Void.class); }); checkWMTE(() -> { // array primitive class - long x = (long) vh.getAndAdd(0, 0, 1L); + long x = (long) vh.getAndAdd(0, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - long x = (long) vh.getAndAdd(array, Void.class, 1L); + long x = (long) vh.getAndAdd(array, Void.class, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.getAndAdd(array, 0, 1L); + Void r = (Void) vh.getAndAdd(array, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.getAndAdd(array, 0, 1L); + boolean x = (boolean) vh.getAndAdd(array, 0, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.getAndAdd(); }); checkWMTE(() -> { // > - long x = (long) vh.getAndAdd(array, 0, 1L, Void.class); + long x = (long) vh.getAndAdd(array, 0, 0x0123456789ABCDEFL, Void.class); }); // AddAndGet // Incorrect argument types checkNPE(() -> { // null array - long x = (long) vh.addAndGet(null, 0, 1L); + long x = (long) vh.addAndGet(null, 0, 0x0123456789ABCDEFL); }); checkCCE(() -> { // array reference class - long x = (long) vh.addAndGet(Void.class, 0, 1L); + long x = (long) vh.addAndGet(Void.class, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class long x = (long) vh.addAndGet(array, 0, Void.class); }); checkWMTE(() -> { // array primitive class - long x = (long) vh.addAndGet(0, 0, 1L); + long x = (long) vh.addAndGet(0, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class - long x = (long) vh.addAndGet(array, Void.class, 1L); + long x = (long) vh.addAndGet(array, Void.class, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class - Void r = (Void) vh.addAndGet(array, 0, 1L); + Void r = (Void) vh.addAndGet(array, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.addAndGet(array, 0, 1L); + boolean x = (boolean) vh.addAndGet(array, 0, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 long x = (long) vh.addAndGet(); }); checkWMTE(() -> { // > - long x = (long) vh.addAndGet(array, 0, 1L, Void.class); + long x = (long) vh.addAndGet(array, 0, 0x0123456789ABCDEFL, Void.class); }); } static void testArrayWrongMethodType(Handles hs) throws Throwable { long[] array = new long[10]; - Arrays.fill(array, 1L); + Arrays.fill(array, 0x0123456789ABCDEFL); for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET)) { // Incorrect argument types @@ -1950,11 +1950,11 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null array hs.get(am, methodType(void.class, long[].class, int.class, long.class)). - invokeExact((long[]) null, 0, 1L); + invokeExact((long[]) null, 0, 0x0123456789ABCDEFL); }); hs.checkWMTEOrCCE(() -> { // array reference class hs.get(am, methodType(void.class, Class.class, int.class, long.class)). - invokeExact(Void.class, 0, 1L); + invokeExact(Void.class, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class hs.get(am, methodType(void.class, long[].class, int.class, Class.class)). @@ -1962,11 +1962,11 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // receiver primitive class hs.get(am, methodType(void.class, int.class, int.class, long.class)). - invokeExact(0, 0, 1L); + invokeExact(0, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class hs.get(am, methodType(void.class, long[].class, Class.class, long.class)). - invokeExact(array, Void.class, 1L); + invokeExact(array, Void.class, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -1975,34 +1975,34 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, long[].class, int.class, Class.class)). - invokeExact(array, 0, 1L, Void.class); + invokeExact(array, 0, 0x0123456789ABCDEFL, Void.class); }); } for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { // Incorrect argument types checkNPE(() -> { // null receiver boolean r = (boolean) hs.get(am, methodType(boolean.class, long[].class, int.class, long.class, long.class)). - invokeExact((long[]) null, 0, 1L, 1L); + invokeExact((long[]) null, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); hs.checkWMTEOrCCE(() -> { // receiver reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, int.class, long.class, long.class)). - invokeExact(Void.class, 0, 1L, 1L); + invokeExact(Void.class, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, long[].class, int.class, Class.class, long.class)). - invokeExact(array, 0, Void.class, 1L); + invokeExact(array, 0, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, long[].class, int.class, long.class, Class.class)). - invokeExact(array, 0, 1L, Void.class); + invokeExact(array, 0, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // receiver primitive class boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class, int.class, long.class, long.class)). - invokeExact(0, 0, 1L, 1L); + invokeExact(0, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class boolean r = (boolean) hs.get(am, methodType(boolean.class, long[].class, Class.class, long.class, long.class)). - invokeExact(array, Void.class, 1L, 1L); + invokeExact(array, Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -2011,7 +2011,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > boolean r = (boolean) hs.get(am, methodType(boolean.class, long[].class, int.class, long.class, long.class, Class.class)). - invokeExact(array, 0, 1L, 1L, Void.class); + invokeExact(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); } @@ -2019,36 +2019,36 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null receiver long x = (long) hs.get(am, methodType(long.class, long[].class, int.class, long.class, long.class)). - invokeExact((long[]) null, 0, 1L, 1L); + invokeExact((long[]) null, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); hs.checkWMTEOrCCE(() -> { // array reference class long x = (long) hs.get(am, methodType(long.class, Class.class, int.class, long.class, long.class)). - invokeExact(Void.class, 0, 1L, 1L); + invokeExact(Void.class, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // expected reference class long x = (long) hs.get(am, methodType(long.class, long[].class, int.class, Class.class, long.class)). - invokeExact(array, 0, Void.class, 1L); + invokeExact(array, 0, Void.class, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // actual reference class long x = (long) hs.get(am, methodType(long.class, long[].class, int.class, long.class, Class.class)). - invokeExact(array, 0, 1L, Void.class); + invokeExact(array, 0, 0x0123456789ABCDEFL, Void.class); }); checkWMTE(() -> { // array primitive class long x = (long) hs.get(am, methodType(long.class, int.class, int.class, long.class, long.class)). - invokeExact(0, 0, 1L, 1L); + invokeExact(0, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class long x = (long) hs.get(am, methodType(long.class, long[].class, Class.class, long.class, long.class)). - invokeExact(array, Void.class, 1L, 1L); + invokeExact(array, Void.class, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, long[].class, int.class, long.class, long.class)). - invokeExact(array, 0, 1L, 1L); + invokeExact(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, long[].class, int.class, long.class, long.class)). - invokeExact(array, 0, 1L, 1L); + invokeExact(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -2057,7 +2057,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > long x = (long) hs.get(am, methodType(long.class, long[].class, int.class, long.class, long.class, Class.class)). - invokeExact(array, 0, 1L, 1L, Void.class); + invokeExact(array, 0, 0x0123456789ABCDEFL, 0x0123456789ABCDEFL, Void.class); }); } @@ -2065,11 +2065,11 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null array long x = (long) hs.get(am, methodType(long.class, long[].class, int.class, long.class)). - invokeExact((long[]) null, 0, 1L); + invokeExact((long[]) null, 0, 0x0123456789ABCDEFL); }); hs.checkWMTEOrCCE(() -> { // array reference class long x = (long) hs.get(am, methodType(long.class, Class.class, int.class, long.class)). - invokeExact(Void.class, 0, 1L); + invokeExact(Void.class, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class long x = (long) hs.get(am, methodType(long.class, long[].class, int.class, Class.class)). @@ -2077,20 +2077,20 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // array primitive class long x = (long) hs.get(am, methodType(long.class, int.class, int.class, long.class)). - invokeExact(0, 0, 1L); + invokeExact(0, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class long x = (long) hs.get(am, methodType(long.class, long[].class, Class.class, long.class)). - invokeExact(array, Void.class, 1L); + invokeExact(array, Void.class, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, long[].class, int.class, long.class)). - invokeExact(array, 0, 1L); + invokeExact(array, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, long[].class, int.class, long.class)). - invokeExact(array, 0, 1L); + invokeExact(array, 0, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -2099,7 +2099,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > long x = (long) hs.get(am, methodType(long.class, long[].class, int.class, long.class, Class.class)). - invokeExact(array, 0, 1L, Void.class); + invokeExact(array, 0, 0x0123456789ABCDEFL, Void.class); }); } @@ -2107,11 +2107,11 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null array long x = (long) hs.get(am, methodType(long.class, long[].class, int.class, long.class)). - invokeExact((long[]) null, 0, 1L); + invokeExact((long[]) null, 0, 0x0123456789ABCDEFL); }); hs.checkWMTEOrCCE(() -> { // array reference class long x = (long) hs.get(am, methodType(long.class, Class.class, int.class, long.class)). - invokeExact(Void.class, 0, 1L); + invokeExact(Void.class, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // value reference class long x = (long) hs.get(am, methodType(long.class, long[].class, int.class, Class.class)). @@ -2119,20 +2119,20 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // array primitive class long x = (long) hs.get(am, methodType(long.class, int.class, int.class, long.class)). - invokeExact(0, 0, 1L); + invokeExact(0, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // index reference class long x = (long) hs.get(am, methodType(long.class, long[].class, Class.class, long.class)). - invokeExact(array, Void.class, 1L); + invokeExact(array, Void.class, 0x0123456789ABCDEFL); }); // Incorrect return type checkWMTE(() -> { // reference class Void r = (Void) hs.get(am, methodType(Void.class, long[].class, int.class, long.class)). - invokeExact(array, 0, 1L); + invokeExact(array, 0, 0x0123456789ABCDEFL); }); checkWMTE(() -> { // primitive class boolean x = (boolean) hs.get(am, methodType(boolean.class, long[].class, int.class, long.class)). - invokeExact(array, 0, 1L); + invokeExact(array, 0, 0x0123456789ABCDEFL); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -2141,7 +2141,7 @@ public class VarHandleTestMethodTypeLong extends VarHandleBaseTest { }); checkWMTE(() -> { // > long x = (long) hs.get(am, methodType(long.class, long[].class, int.class, long.class, Class.class)). - invokeExact(array, 0, 1L, Void.class); + invokeExact(array, 0, 0x0123456789ABCDEFL, Void.class); }); } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeShort.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeShort.java index 16efabe0917..82b6f3cab78 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeShort.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeShort.java @@ -43,13 +43,13 @@ import static org.testng.Assert.*; import static java.lang.invoke.MethodType.*; public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { - static final short static_final_v = (short)1; + static final short static_final_v = (short)0x0123; - static short static_v = (short)1; + static short static_v = (short)0x0123; - final short final_v = (short)1; + final short final_v = (short)0x0123; - short v = (short)1; + short v = (short)0x0123; VarHandle vhFinalField; @@ -154,23 +154,23 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { // Set // Incorrect argument types checkNPE(() -> { // null receiver - vh.set(null, (short)1); + vh.set(null, (short)0x0123); }); checkCCE(() -> { // receiver reference class - vh.set(Void.class, (short)1); + vh.set(Void.class, (short)0x0123); }); checkWMTE(() -> { // value reference class vh.set(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.set(0, (short)1); + vh.set(0, (short)0x0123); }); // Incorrect arity checkWMTE(() -> { // 0 vh.set(); }); checkWMTE(() -> { // > - vh.set(recv, (short)1, Void.class); + vh.set(recv, (short)0x0123, Void.class); }); @@ -204,23 +204,23 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { // SetVolatile // Incorrect argument types checkNPE(() -> { // null receiver - vh.setVolatile(null, (short)1); + vh.setVolatile(null, (short)0x0123); }); checkCCE(() -> { // receiver reference class - vh.setVolatile(Void.class, (short)1); + vh.setVolatile(Void.class, (short)0x0123); }); checkWMTE(() -> { // value reference class vh.setVolatile(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setVolatile(0, (short)1); + vh.setVolatile(0, (short)0x0123); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile(recv, (short)1, Void.class); + vh.setVolatile(recv, (short)0x0123, Void.class); }); @@ -254,23 +254,23 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { // SetOpaque // Incorrect argument types checkNPE(() -> { // null receiver - vh.setOpaque(null, (short)1); + vh.setOpaque(null, (short)0x0123); }); checkCCE(() -> { // receiver reference class - vh.setOpaque(Void.class, (short)1); + vh.setOpaque(Void.class, (short)0x0123); }); checkWMTE(() -> { // value reference class vh.setOpaque(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setOpaque(0, (short)1); + vh.setOpaque(0, (short)0x0123); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque(recv, (short)1, Void.class); + vh.setOpaque(recv, (short)0x0123, Void.class); }); @@ -304,27 +304,342 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { // SetRelease // Incorrect argument types checkNPE(() -> { // null receiver - vh.setRelease(null, (short)1); + vh.setRelease(null, (short)0x0123); }); checkCCE(() -> { // receiver reference class - vh.setRelease(Void.class, (short)1); + vh.setRelease(Void.class, (short)0x0123); }); checkWMTE(() -> { // value reference class vh.setRelease(recv, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setRelease(0, (short)1); + vh.setRelease(0, (short)0x0123); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease(recv, (short)1, Void.class); + vh.setRelease(recv, (short)0x0123, Void.class); }); + // CompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.compareAndSet(null, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.compareAndSet(Void.class, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(recv, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(recv, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.compareAndSet(0, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(recv, (short)0x0123, (short)0x0123, Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSet(null, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSet(Void.class, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(recv, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(recv, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSet(0, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(recv, (short)0x0123, (short)0x0123, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetVolatile(null, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(recv, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(recv, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetVolatile(0, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(recv, (short)0x0123, (short)0x0123, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetAcquire(null, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(recv, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(recv, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetAcquire(0, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(recv, (short)0x0123, (short)0x0123, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetRelease(null, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(recv, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(recv, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetRelease(0, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(recv, (short)0x0123, (short)0x0123, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkNPE(() -> { // null receiver + short x = (short) vh.compareAndExchange(null, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + short x = (short) vh.compareAndExchange(Void.class, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + short x = (short) vh.compareAndExchange(recv, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + short x = (short) vh.compareAndExchange(recv, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + short x = (short) vh.compareAndExchange(0, (short)0x0123, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(recv, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange(recv, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + short x = (short) vh.compareAndExchange(recv, (short)0x0123, (short)0x0123, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + short x = (short) vh.compareAndExchangeAcquire(null, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + short x = (short) vh.compareAndExchangeAcquire(Void.class, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + short x = (short) vh.compareAndExchangeAcquire(recv, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + short x = (short) vh.compareAndExchangeAcquire(recv, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + short x = (short) vh.compareAndExchangeAcquire(0, (short)0x0123, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(recv, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire(recv, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + short x = (short) vh.compareAndExchangeAcquire(recv, (short)0x0123, (short)0x0123, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + short x = (short) vh.compareAndExchangeRelease(null, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + short x = (short) vh.compareAndExchangeRelease(Void.class, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + short x = (short) vh.compareAndExchangeRelease(recv, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + short x = (short) vh.compareAndExchangeRelease(recv, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + short x = (short) vh.compareAndExchangeRelease(0, (short)0x0123, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(recv, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease(recv, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + short x = (short) vh.compareAndExchangeRelease(recv, (short)0x0123, (short)0x0123, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + short x = (short) vh.getAndSet(null, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + short x = (short) vh.getAndSet(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // value reference class + short x = (short) vh.getAndSet(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + short x = (short) vh.getAndSet(0, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(recv, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet(recv, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.getAndSet(); + }); + checkWMTE(() -> { // > + short x = (short) vh.getAndSet(recv, (short)0x0123, Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkNPE(() -> { // null receiver + short x = (short) vh.getAndAdd(null, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + short x = (short) vh.getAndAdd(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // value reference class + short x = (short) vh.getAndAdd(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + short x = (short) vh.getAndAdd(0, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd(recv, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd(recv, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + short x = (short) vh.getAndAdd(recv, (short)0x0123, Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkNPE(() -> { // null receiver + short x = (short) vh.addAndGet(null, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + short x = (short) vh.addAndGet(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // value reference class + short x = (short) vh.addAndGet(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + short x = (short) vh.addAndGet(0, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet(recv, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet(recv, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.addAndGet(); + }); + checkWMTE(() -> { // > + short x = (short) vh.addAndGet(recv, (short)0x0123, Void.class); + }); } static void testInstanceFieldWrongMethodType(VarHandleTestMethodTypeShort recv, Handles hs) throws Throwable { @@ -366,11 +681,11 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null receiver hs.get(am, methodType(void.class, VarHandleTestMethodTypeShort.class, short.class)). - invokeExact((VarHandleTestMethodTypeShort) null, (short)1); + invokeExact((VarHandleTestMethodTypeShort) null, (short)0x0123); }); hs.checkWMTEOrCCE(() -> { // receiver reference class hs.get(am, methodType(void.class, Class.class, short.class)). - invokeExact(Void.class, (short)1); + invokeExact(Void.class, (short)0x0123); }); checkWMTE(() -> { // value reference class hs.get(am, methodType(void.class, VarHandleTestMethodTypeShort.class, Class.class)). @@ -378,7 +693,7 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { }); checkWMTE(() -> { // receiver primitive class hs.get(am, methodType(void.class, int.class, short.class)). - invokeExact(0, (short)1); + invokeExact(0, (short)0x0123); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -387,11 +702,157 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, VarHandleTestMethodTypeShort.class, short.class, Class.class)). - invokeExact(recv, (short)1, Void.class); + invokeExact(recv, (short)0x0123, Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeShort.class, short.class, short.class)). + invokeExact((VarHandleTestMethodTypeShort) null, (short)0x0123, (short)0x0123); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, short.class, short.class)). + invokeExact(Void.class, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeShort.class, Class.class, short.class)). + invokeExact(recv, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeShort.class, short.class, Class.class)). + invokeExact(recv, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class , short.class, short.class)). + invokeExact(0, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeShort.class, short.class, short.class, Class.class)). + invokeExact(recv, (short)0x0123, (short)0x0123, Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + checkNPE(() -> { // null receiver + short x = (short) hs.get(am, methodType(short.class, VarHandleTestMethodTypeShort.class, short.class, short.class)). + invokeExact((VarHandleTestMethodTypeShort) null, (short)0x0123, (short)0x0123); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + short x = (short) hs.get(am, methodType(short.class, Class.class, short.class, short.class)). + invokeExact(Void.class, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + short x = (short) hs.get(am, methodType(short.class, VarHandleTestMethodTypeShort.class, Class.class, short.class)). + invokeExact(recv, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + short x = (short) hs.get(am, methodType(short.class, VarHandleTestMethodTypeShort.class, short.class, Class.class)). + invokeExact(recv, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + short x = (short) hs.get(am, methodType(short.class, int.class , short.class, short.class)). + invokeExact(0, (short)0x0123, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeShort.class , short.class, short.class)). + invokeExact(recv, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeShort.class , short.class, short.class)). + invokeExact(recv, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) hs.get(am, methodType(short.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + short x = (short) hs.get(am, methodType(short.class, VarHandleTestMethodTypeShort.class, short.class, short.class, Class.class)). + invokeExact(recv, (short)0x0123, (short)0x0123, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + checkNPE(() -> { // null receiver + short x = (short) hs.get(am, methodType(short.class, VarHandleTestMethodTypeShort.class, short.class)). + invokeExact((VarHandleTestMethodTypeShort) null, (short)0x0123); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + short x = (short) hs.get(am, methodType(short.class, Class.class, short.class)). + invokeExact(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // value reference class + short x = (short) hs.get(am, methodType(short.class, VarHandleTestMethodTypeShort.class, Class.class)). + invokeExact(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + short x = (short) hs.get(am, methodType(short.class, int.class, short.class)). + invokeExact(0, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeShort.class, short.class)). + invokeExact(recv, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeShort.class, short.class)). + invokeExact(recv, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) hs.get(am, methodType(short.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + short x = (short) hs.get(am, methodType(short.class, VarHandleTestMethodTypeShort.class, short.class)). + invokeExact(recv, (short)0x0123, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + checkNPE(() -> { // null receiver + short x = (short) hs.get(am, methodType(short.class, VarHandleTestMethodTypeShort.class, short.class)). + invokeExact((VarHandleTestMethodTypeShort) null, (short)0x0123); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + short x = (short) hs.get(am, methodType(short.class, Class.class, short.class)). + invokeExact(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // value reference class + short x = (short) hs.get(am, methodType(short.class, VarHandleTestMethodTypeShort.class, Class.class)). + invokeExact(recv, Void.class); + }); + checkWMTE(() -> { // reciever primitive class + short x = (short) hs.get(am, methodType(short.class, int.class, short.class)). + invokeExact(0, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, VarHandleTestMethodTypeShort.class, short.class)). + invokeExact(recv, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, VarHandleTestMethodTypeShort.class, short.class)). + invokeExact(recv, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) hs.get(am, methodType(short.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + short x = (short) hs.get(am, methodType(short.class, VarHandleTestMethodTypeShort.class, short.class)). + invokeExact(recv, (short)0x0123, Void.class); + }); + } } @@ -420,7 +881,7 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { vh.set(); }); checkWMTE(() -> { // > - vh.set((short)1, Void.class); + vh.set((short)0x0123, Void.class); }); @@ -447,7 +908,7 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile((short)1, Void.class); + vh.setVolatile((short)0x0123, Void.class); }); @@ -474,7 +935,7 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque((short)1, Void.class); + vh.setOpaque((short)0x0123, Void.class); }); @@ -501,11 +962,227 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease((short)1, Void.class); + vh.setRelease((short)0x0123, Void.class); }); + // CompareAndSet + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet((short)0x0123, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet((short)0x0123, (short)0x0123, Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet((short)0x0123, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet((short)0x0123, (short)0x0123, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile((short)0x0123, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile((short)0x0123, (short)0x0123, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire((short)0x0123, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire((short)0x0123, (short)0x0123, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease((short)0x0123, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease((short)0x0123, (short)0x0123, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkWMTE(() -> { // expected reference class + short x = (short) vh.compareAndExchange(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + short x = (short) vh.compareAndExchange((short)0x0123, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange((short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange((short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + short x = (short) vh.compareAndExchange((short)0x0123, (short)0x0123, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkWMTE(() -> { // expected reference class + short x = (short) vh.compareAndExchangeAcquire(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + short x = (short) vh.compareAndExchangeAcquire((short)0x0123, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire((short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire((short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + short x = (short) vh.compareAndExchangeAcquire((short)0x0123, (short)0x0123, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkWMTE(() -> { // expected reference class + short x = (short) vh.compareAndExchangeRelease(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + short x = (short) vh.compareAndExchangeRelease((short)0x0123, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease((short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease((short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + short x = (short) vh.compareAndExchangeRelease((short)0x0123, (short)0x0123, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkWMTE(() -> { // value reference class + short x = (short) vh.getAndSet(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet((short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet((short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.getAndSet(); + }); + checkWMTE(() -> { // > + short x = (short) vh.getAndSet((short)0x0123, Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkWMTE(() -> { // value reference class + short x = (short) vh.getAndAdd(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd((short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd((short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + short x = (short) vh.getAndAdd((short)0x0123, Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkWMTE(() -> { // value reference class + short x = (short) vh.addAndGet(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet((short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet((short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.addAndGet(); + }); + checkWMTE(() -> { // > + short x = (short) vh.addAndGet((short)0x0123, Void.class); + }); } static void testStaticFieldWrongMethodType(Handles hs) throws Throwable { @@ -540,16 +1217,117 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, short.class, Class.class)). - invokeExact((short)1, Void.class); + invokeExact((short)0x0123, Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, short.class)). + invokeExact(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, short.class, Class.class)). + invokeExact((short)0x0123, Void.class); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, short.class, short.class, Class.class)). + invokeExact((short)0x0123, (short)0x0123, Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + // Incorrect argument types + checkWMTE(() -> { // expected reference class + short x = (short) hs.get(am, methodType(short.class, Class.class, short.class)). + invokeExact(Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + short x = (short) hs.get(am, methodType(short.class, short.class, Class.class)). + invokeExact((short)0x0123, Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, short.class, short.class)). + invokeExact((short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, short.class, short.class)). + invokeExact((short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) hs.get(am, methodType(short.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + short x = (short) hs.get(am, methodType(short.class, short.class, short.class, Class.class)). + invokeExact((short)0x0123, (short)0x0123, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + // Incorrect argument types + checkWMTE(() -> { // value reference class + short x = (short) hs.get(am, methodType(short.class, Class.class)). + invokeExact(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, short.class)). + invokeExact((short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, short.class)). + invokeExact((short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) hs.get(am, methodType(short.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + short x = (short) hs.get(am, methodType(short.class, short.class, Class.class)). + invokeExact((short)0x0123, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + // Incorrect argument types + checkWMTE(() -> { // value reference class + short x = (short) hs.get(am, methodType(short.class, Class.class)). + invokeExact(Void.class); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, short.class)). + invokeExact((short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, short.class)). + invokeExact((short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) hs.get(am, methodType(short.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + short x = (short) hs.get(am, methodType(short.class, short.class, Class.class)). + invokeExact((short)0x0123, Void.class); + }); + } } static void testArrayWrongMethodType(VarHandle vh) throws Throwable { short[] array = new short[10]; - Arrays.fill(array, (short)1); + Arrays.fill(array, (short)0x0123); // Get // Incorrect argument types @@ -584,26 +1362,26 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { // Set // Incorrect argument types checkNPE(() -> { // null array - vh.set(null, 0, (short)1); + vh.set(null, 0, (short)0x0123); }); checkCCE(() -> { // array reference class - vh.set(Void.class, 0, (short)1); + vh.set(Void.class, 0, (short)0x0123); }); checkWMTE(() -> { // value reference class vh.set(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.set(0, 0, (short)1); + vh.set(0, 0, (short)0x0123); }); checkWMTE(() -> { // index reference class - vh.set(array, Void.class, (short)1); + vh.set(array, Void.class, (short)0x0123); }); // Incorrect arity checkWMTE(() -> { // 0 vh.set(); }); checkWMTE(() -> { // > - vh.set(array, 0, (short)1, Void.class); + vh.set(array, 0, (short)0x0123, Void.class); }); @@ -640,26 +1418,26 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { // SetVolatile // Incorrect argument types checkNPE(() -> { // null array - vh.setVolatile(null, 0, (short)1); + vh.setVolatile(null, 0, (short)0x0123); }); checkCCE(() -> { // array reference class - vh.setVolatile(Void.class, 0, (short)1); + vh.setVolatile(Void.class, 0, (short)0x0123); }); checkWMTE(() -> { // value reference class vh.setVolatile(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setVolatile(0, 0, (short)1); + vh.setVolatile(0, 0, (short)0x0123); }); checkWMTE(() -> { // index reference class - vh.setVolatile(array, Void.class, (short)1); + vh.setVolatile(array, Void.class, (short)0x0123); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setVolatile(); }); checkWMTE(() -> { // > - vh.setVolatile(array, 0, (short)1, Void.class); + vh.setVolatile(array, 0, (short)0x0123, Void.class); }); @@ -696,26 +1474,26 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { // SetOpaque // Incorrect argument types checkNPE(() -> { // null array - vh.setOpaque(null, 0, (short)1); + vh.setOpaque(null, 0, (short)0x0123); }); checkCCE(() -> { // array reference class - vh.setOpaque(Void.class, 0, (short)1); + vh.setOpaque(Void.class, 0, (short)0x0123); }); checkWMTE(() -> { // value reference class vh.setOpaque(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setOpaque(0, 0, (short)1); + vh.setOpaque(0, 0, (short)0x0123); }); checkWMTE(() -> { // index reference class - vh.setOpaque(array, Void.class, (short)1); + vh.setOpaque(array, Void.class, (short)0x0123); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setOpaque(); }); checkWMTE(() -> { // > - vh.setOpaque(array, 0, (short)1, Void.class); + vh.setOpaque(array, 0, (short)0x0123, Void.class); }); @@ -752,35 +1530,383 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { // SetRelease // Incorrect argument types checkNPE(() -> { // null array - vh.setRelease(null, 0, (short)1); + vh.setRelease(null, 0, (short)0x0123); }); checkCCE(() -> { // array reference class - vh.setRelease(Void.class, 0, (short)1); + vh.setRelease(Void.class, 0, (short)0x0123); }); checkWMTE(() -> { // value reference class vh.setRelease(array, 0, Void.class); }); checkWMTE(() -> { // receiver primitive class - vh.setRelease(0, 0, (short)1); + vh.setRelease(0, 0, (short)0x0123); }); checkWMTE(() -> { // index reference class - vh.setRelease(array, Void.class, (short)1); + vh.setRelease(array, Void.class, (short)0x0123); }); // Incorrect arity checkWMTE(() -> { // 0 vh.setRelease(); }); checkWMTE(() -> { // > - vh.setRelease(array, 0, (short)1, Void.class); + vh.setRelease(array, 0, (short)0x0123, Void.class); }); + // CompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.compareAndSet(null, 0, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.compareAndSet(Void.class, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.compareAndSet(array, 0, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.compareAndSet(array, 0, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.compareAndSet(0, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.compareAndSet(array, Void.class, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.compareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.compareAndSet(array, 0, (short)0x0123, (short)0x0123, Void.class); + }); + + // WeakCompareAndSet + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSet(null, 0, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSet(Void.class, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSet(array, 0, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSet(array, 0, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSet(0, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSet(array, Void.class, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSet(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSet(array, 0, (short)0x0123, (short)0x0123, Void.class); + }); + + + // WeakCompareAndSetVolatile + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetVolatile(null, 0, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetVolatile(Void.class, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetVolatile(array, 0, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetVolatile(array, 0, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetVolatile(0, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetVolatile(array, Void.class, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetVolatile(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetVolatile(array, 0, (short)0x0123, (short)0x0123, Void.class); + }); + + + // WeakCompareAndSetAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetAcquire(null, 0, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetAcquire(Void.class, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetAcquire(array, 0, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetAcquire(array, 0, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetAcquire(0, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetAcquire(array, Void.class, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetAcquire(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetAcquire(array, 0, (short)0x0123, (short)0x0123, Void.class); + }); + + + // WeakCompareAndSetRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = vh.weakCompareAndSetRelease(null, 0, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // receiver reference class + boolean r = vh.weakCompareAndSetRelease(Void.class, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + boolean r = vh.weakCompareAndSetRelease(array, 0, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = vh.weakCompareAndSetRelease(array, 0, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = vh.weakCompareAndSetRelease(0, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + boolean r = vh.weakCompareAndSetRelease(array, Void.class, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = vh.weakCompareAndSetRelease(); + }); + checkWMTE(() -> { // > + boolean r = vh.weakCompareAndSetRelease(array, 0, (short)0x0123, (short)0x0123, Void.class); + }); + + + // CompareAndExchange + // Incorrect argument types + checkNPE(() -> { // null receiver + short x = (short) vh.compareAndExchange(null, 0, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // array reference class + short x = (short) vh.compareAndExchange(Void.class, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + short x = (short) vh.compareAndExchange(array, 0, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + short x = (short) vh.compareAndExchange(array, 0, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // array primitive class + short x = (short) vh.compareAndExchange(0, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + short x = (short) vh.compareAndExchange(array, Void.class, (short)0x0123, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchange(array, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchange(array, 0, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.compareAndExchange(); + }); + checkWMTE(() -> { // > + short x = (short) vh.compareAndExchange(array, 0, (short)0x0123, (short)0x0123, Void.class); + }); + + + // CompareAndExchangeAcquire + // Incorrect argument types + checkNPE(() -> { // null receiver + short x = (short) vh.compareAndExchangeAcquire(null, 0, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // array reference class + short x = (short) vh.compareAndExchangeAcquire(Void.class, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + short x = (short) vh.compareAndExchangeAcquire(array, 0, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + short x = (short) vh.compareAndExchangeAcquire(array, 0, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // array primitive class + short x = (short) vh.compareAndExchangeAcquire(0, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + short x = (short) vh.compareAndExchangeAcquire(array, Void.class, (short)0x0123, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeAcquire(array, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeAcquire(array, 0, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.compareAndExchangeAcquire(); + }); + checkWMTE(() -> { // > + short x = (short) vh.compareAndExchangeAcquire(array, 0, (short)0x0123, (short)0x0123, Void.class); + }); + + + // CompareAndExchangeRelease + // Incorrect argument types + checkNPE(() -> { // null receiver + short x = (short) vh.compareAndExchangeRelease(null, 0, (short)0x0123, (short)0x0123); + }); + checkCCE(() -> { // array reference class + short x = (short) vh.compareAndExchangeRelease(Void.class, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + short x = (short) vh.compareAndExchangeRelease(array, 0, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + short x = (short) vh.compareAndExchangeRelease(array, 0, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // array primitive class + short x = (short) vh.compareAndExchangeRelease(0, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + short x = (short) vh.compareAndExchangeRelease(array, Void.class, (short)0x0123, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.compareAndExchangeRelease(array, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.compareAndExchangeRelease(array, 0, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.compareAndExchangeRelease(); + }); + checkWMTE(() -> { // > + short x = (short) vh.compareAndExchangeRelease(array, 0, (short)0x0123, (short)0x0123, Void.class); + }); + + + // GetAndSet + // Incorrect argument types + checkNPE(() -> { // null array + short x = (short) vh.getAndSet(null, 0, (short)0x0123); + }); + checkCCE(() -> { // array reference class + short x = (short) vh.getAndSet(Void.class, 0, (short)0x0123); + }); + checkWMTE(() -> { // value reference class + short x = (short) vh.getAndSet(array, 0, Void.class); + }); + checkWMTE(() -> { // reciarrayever primitive class + short x = (short) vh.getAndSet(0, 0, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + short x = (short) vh.getAndSet(array, Void.class, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndSet(array, 0, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndSet(array, 0, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.getAndSet(); + }); + checkWMTE(() -> { // > + short x = (short) vh.getAndSet(array, 0, (short)0x0123, Void.class); + }); + + // GetAndAdd + // Incorrect argument types + checkNPE(() -> { // null array + short x = (short) vh.getAndAdd(null, 0, (short)0x0123); + }); + checkCCE(() -> { // array reference class + short x = (short) vh.getAndAdd(Void.class, 0, (short)0x0123); + }); + checkWMTE(() -> { // value reference class + short x = (short) vh.getAndAdd(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + short x = (short) vh.getAndAdd(0, 0, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + short x = (short) vh.getAndAdd(array, Void.class, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.getAndAdd(array, 0, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.getAndAdd(array, 0, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.getAndAdd(); + }); + checkWMTE(() -> { // > + short x = (short) vh.getAndAdd(array, 0, (short)0x0123, Void.class); + }); + + + // AddAndGet + // Incorrect argument types + checkNPE(() -> { // null array + short x = (short) vh.addAndGet(null, 0, (short)0x0123); + }); + checkCCE(() -> { // array reference class + short x = (short) vh.addAndGet(Void.class, 0, (short)0x0123); + }); + checkWMTE(() -> { // value reference class + short x = (short) vh.addAndGet(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + short x = (short) vh.addAndGet(0, 0, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + short x = (short) vh.addAndGet(array, Void.class, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) vh.addAndGet(array, 0, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) vh.addAndGet(array, 0, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) vh.addAndGet(); + }); + checkWMTE(() -> { // > + short x = (short) vh.addAndGet(array, 0, (short)0x0123, Void.class); + }); } static void testArrayWrongMethodType(Handles hs) throws Throwable { short[] array = new short[10]; - Arrays.fill(array, (short)1); + Arrays.fill(array, (short)0x0123); for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET)) { // Incorrect argument types @@ -824,11 +1950,11 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { // Incorrect argument types checkNPE(() -> { // null array hs.get(am, methodType(void.class, short[].class, int.class, short.class)). - invokeExact((short[]) null, 0, (short)1); + invokeExact((short[]) null, 0, (short)0x0123); }); hs.checkWMTEOrCCE(() -> { // array reference class hs.get(am, methodType(void.class, Class.class, int.class, short.class)). - invokeExact(Void.class, 0, (short)1); + invokeExact(Void.class, 0, (short)0x0123); }); checkWMTE(() -> { // value reference class hs.get(am, methodType(void.class, short[].class, int.class, Class.class)). @@ -836,11 +1962,11 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { }); checkWMTE(() -> { // receiver primitive class hs.get(am, methodType(void.class, int.class, int.class, short.class)). - invokeExact(0, 0, (short)1); + invokeExact(0, 0, (short)0x0123); }); checkWMTE(() -> { // index reference class hs.get(am, methodType(void.class, short[].class, Class.class, short.class)). - invokeExact(array, Void.class, (short)1); + invokeExact(array, Void.class, (short)0x0123); }); // Incorrect arity checkWMTE(() -> { // 0 @@ -849,10 +1975,175 @@ public class VarHandleTestMethodTypeShort extends VarHandleBaseTest { }); checkWMTE(() -> { // > hs.get(am, methodType(void.class, short[].class, int.class, Class.class)). - invokeExact(array, 0, (short)1, Void.class); + invokeExact(array, 0, (short)0x0123, Void.class); + }); + } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + boolean r = (boolean) hs.get(am, methodType(boolean.class, short[].class, int.class, short.class, short.class)). + invokeExact((short[]) null, 0, (short)0x0123, (short)0x0123); + }); + hs.checkWMTEOrCCE(() -> { // receiver reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, Class.class, int.class, short.class, short.class)). + invokeExact(Void.class, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, short[].class, int.class, Class.class, short.class)). + invokeExact(array, 0, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, short[].class, int.class, short.class, Class.class)). + invokeExact(array, 0, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // receiver primitive class + boolean r = (boolean) hs.get(am, methodType(boolean.class, int.class, int.class, short.class, short.class)). + invokeExact(0, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + boolean r = (boolean) hs.get(am, methodType(boolean.class, short[].class, Class.class, short.class, short.class)). + invokeExact(array, Void.class, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + boolean r = (boolean) hs.get(am, methodType(boolean.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + boolean r = (boolean) hs.get(am, methodType(boolean.class, short[].class, int.class, short.class, short.class, Class.class)). + invokeExact(array, 0, (short)0x0123, (short)0x0123, Void.class); }); } + for (TestAccessMode am : testAccessModesOfType(TestAccessType.COMPARE_AND_EXCHANGE)) { + // Incorrect argument types + checkNPE(() -> { // null receiver + short x = (short) hs.get(am, methodType(short.class, short[].class, int.class, short.class, short.class)). + invokeExact((short[]) null, 0, (short)0x0123, (short)0x0123); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + short x = (short) hs.get(am, methodType(short.class, Class.class, int.class, short.class, short.class)). + invokeExact(Void.class, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // expected reference class + short x = (short) hs.get(am, methodType(short.class, short[].class, int.class, Class.class, short.class)). + invokeExact(array, 0, Void.class, (short)0x0123); + }); + checkWMTE(() -> { // actual reference class + short x = (short) hs.get(am, methodType(short.class, short[].class, int.class, short.class, Class.class)). + invokeExact(array, 0, (short)0x0123, Void.class); + }); + checkWMTE(() -> { // array primitive class + short x = (short) hs.get(am, methodType(short.class, int.class, int.class, short.class, short.class)). + invokeExact(0, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + short x = (short) hs.get(am, methodType(short.class, short[].class, Class.class, short.class, short.class)). + invokeExact(array, Void.class, (short)0x0123, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, short[].class, int.class, short.class, short.class)). + invokeExact(array, 0, (short)0x0123, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, short[].class, int.class, short.class, short.class)). + invokeExact(array, 0, (short)0x0123, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) hs.get(am, methodType(short.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + short x = (short) hs.get(am, methodType(short.class, short[].class, int.class, short.class, short.class, Class.class)). + invokeExact(array, 0, (short)0x0123, (short)0x0123, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_SET)) { + // Incorrect argument types + checkNPE(() -> { // null array + short x = (short) hs.get(am, methodType(short.class, short[].class, int.class, short.class)). + invokeExact((short[]) null, 0, (short)0x0123); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + short x = (short) hs.get(am, methodType(short.class, Class.class, int.class, short.class)). + invokeExact(Void.class, 0, (short)0x0123); + }); + checkWMTE(() -> { // value reference class + short x = (short) hs.get(am, methodType(short.class, short[].class, int.class, Class.class)). + invokeExact(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + short x = (short) hs.get(am, methodType(short.class, int.class, int.class, short.class)). + invokeExact(0, 0, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + short x = (short) hs.get(am, methodType(short.class, short[].class, Class.class, short.class)). + invokeExact(array, Void.class, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, short[].class, int.class, short.class)). + invokeExact(array, 0, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, short[].class, int.class, short.class)). + invokeExact(array, 0, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) hs.get(am, methodType(short.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + short x = (short) hs.get(am, methodType(short.class, short[].class, int.class, short.class, Class.class)). + invokeExact(array, 0, (short)0x0123, Void.class); + }); + } + + for (TestAccessMode am : testAccessModesOfType(TestAccessType.GET_AND_ADD)) { + // Incorrect argument types + checkNPE(() -> { // null array + short x = (short) hs.get(am, methodType(short.class, short[].class, int.class, short.class)). + invokeExact((short[]) null, 0, (short)0x0123); + }); + hs.checkWMTEOrCCE(() -> { // array reference class + short x = (short) hs.get(am, methodType(short.class, Class.class, int.class, short.class)). + invokeExact(Void.class, 0, (short)0x0123); + }); + checkWMTE(() -> { // value reference class + short x = (short) hs.get(am, methodType(short.class, short[].class, int.class, Class.class)). + invokeExact(array, 0, Void.class); + }); + checkWMTE(() -> { // array primitive class + short x = (short) hs.get(am, methodType(short.class, int.class, int.class, short.class)). + invokeExact(0, 0, (short)0x0123); + }); + checkWMTE(() -> { // index reference class + short x = (short) hs.get(am, methodType(short.class, short[].class, Class.class, short.class)). + invokeExact(array, Void.class, (short)0x0123); + }); + // Incorrect return type + checkWMTE(() -> { // reference class + Void r = (Void) hs.get(am, methodType(Void.class, short[].class, int.class, short.class)). + invokeExact(array, 0, (short)0x0123); + }); + checkWMTE(() -> { // primitive class + boolean x = (boolean) hs.get(am, methodType(boolean.class, short[].class, int.class, short.class)). + invokeExact(array, 0, (short)0x0123); + }); + // Incorrect arity + checkWMTE(() -> { // 0 + short x = (short) hs.get(am, methodType(short.class)). + invokeExact(); + }); + checkWMTE(() -> { // > + short x = (short) hs.get(am, methodType(short.class, short[].class, int.class, short.class, Class.class)). + invokeExact(array, 0, (short)0x0123, Void.class); + }); + } } } diff --git a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeString.java b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeString.java index 2cc853349ce..41d0e6b4702 100644 --- a/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeString.java +++ b/jdk/test/java/lang/invoke/VarHandles/VarHandleTestMethodTypeString.java @@ -454,40 +454,40 @@ public class VarHandleTestMethodTypeString extends VarHandleBaseTest { }); - // CompareAndExchangeVolatile + // CompareAndExchange // Incorrect argument types checkNPE(() -> { // null receiver - String x = (String) vh.compareAndExchangeVolatile(null, "foo", "foo"); + String x = (String) vh.compareAndExchange(null, "foo", "foo"); }); checkCCE(() -> { // receiver reference class - String x = (String) vh.compareAndExchangeVolatile(Void.class, "foo", "foo"); + String x = (String) vh.compareAndExchange(Void.class, "foo", "foo"); }); checkCCE(() -> { // expected reference class - String x = (String) vh.compareAndExchangeVolatile(recv, Void.class, "foo"); + String x = (String) vh.compareAndExchange(recv, Void.class, "foo"); }); checkCCE(() -> { // actual reference class - String x = (String) vh.compareAndExchangeVolatile(recv, "foo", Void.class); + String x = (String) vh.compareAndExchange(recv, "foo", Void.class); }); checkWMTE(() -> { // reciever primitive class - String x = (String) vh.compareAndExchangeVolatile(0, "foo", "foo"); + String x = (String) vh.compareAndExchange(0, "foo", "foo"); }); // Incorrect return type checkCCE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeVolatile(recv, "foo", "foo"); + Void r = (Void) vh.compareAndExchange(recv, "foo", "foo"); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeVolatile(recv, "foo", "foo"); + boolean x = (boolean) vh.compareAndExchange(recv, "foo", "foo"); }); // Incorrect arity checkWMTE(() -> { // 0 - String x = (String) vh.compareAndExchangeVolatile(); + String x = (String) vh.compareAndExchange(); }); checkWMTE(() -> { // > - String x = (String) vh.compareAndExchangeVolatile(recv, "foo", "foo", Void.class); + String x = (String) vh.compareAndExchange(recv, "foo", "foo", Void.class); }); - // CompareAndExchangeVolatileAcquire + // CompareAndExchangeAcquire // Incorrect argument types checkNPE(() -> { // null receiver String x = (String) vh.compareAndExchangeAcquire(null, "foo", "foo"); @@ -957,27 +957,27 @@ public class VarHandleTestMethodTypeString extends VarHandleBaseTest { }); - // CompareAndExchangeVolatile + // CompareAndExchange // Incorrect argument types checkCCE(() -> { // expected reference class - String x = (String) vh.compareAndExchangeVolatile(Void.class, "foo"); + String x = (String) vh.compareAndExchange(Void.class, "foo"); }); checkCCE(() -> { // actual reference class - String x = (String) vh.compareAndExchangeVolatile("foo", Void.class); + String x = (String) vh.compareAndExchange("foo", Void.class); }); // Incorrect return type checkCCE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeVolatile("foo", "foo"); + Void r = (Void) vh.compareAndExchange("foo", "foo"); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeVolatile("foo", "foo"); + boolean x = (boolean) vh.compareAndExchange("foo", "foo"); }); // Incorrect arity checkWMTE(() -> { // 0 - String x = (String) vh.compareAndExchangeVolatile(); + String x = (String) vh.compareAndExchange(); }); checkWMTE(() -> { // > - String x = (String) vh.compareAndExchangeVolatile("foo", "foo", Void.class); + String x = (String) vh.compareAndExchange("foo", "foo", Void.class); }); @@ -1539,39 +1539,39 @@ public class VarHandleTestMethodTypeString extends VarHandleBaseTest { }); - // CompareAndExchangeVolatile + // CompareAndExchange // Incorrect argument types checkNPE(() -> { // null receiver - String x = (String) vh.compareAndExchangeVolatile(null, 0, "foo", "foo"); + String x = (String) vh.compareAndExchange(null, 0, "foo", "foo"); }); checkCCE(() -> { // array reference class - String x = (String) vh.compareAndExchangeVolatile(Void.class, 0, "foo", "foo"); + String x = (String) vh.compareAndExchange(Void.class, 0, "foo", "foo"); }); checkCCE(() -> { // expected reference class - String x = (String) vh.compareAndExchangeVolatile(array, 0, Void.class, "foo"); + String x = (String) vh.compareAndExchange(array, 0, Void.class, "foo"); }); checkCCE(() -> { // actual reference class - String x = (String) vh.compareAndExchangeVolatile(array, 0, "foo", Void.class); + String x = (String) vh.compareAndExchange(array, 0, "foo", Void.class); }); checkWMTE(() -> { // array primitive class - String x = (String) vh.compareAndExchangeVolatile(0, 0, "foo", "foo"); + String x = (String) vh.compareAndExchange(0, 0, "foo", "foo"); }); checkWMTE(() -> { // index reference class - String x = (String) vh.compareAndExchangeVolatile(array, Void.class, "foo", "foo"); + String x = (String) vh.compareAndExchange(array, Void.class, "foo", "foo"); }); // Incorrect return type checkCCE(() -> { // reference class - Void r = (Void) vh.compareAndExchangeVolatile(array, 0, "foo", "foo"); + Void r = (Void) vh.compareAndExchange(array, 0, "foo", "foo"); }); checkWMTE(() -> { // primitive class - boolean x = (boolean) vh.compareAndExchangeVolatile(array, 0, "foo", "foo"); + boolean x = (boolean) vh.compareAndExchange(array, 0, "foo", "foo"); }); // Incorrect arity checkWMTE(() -> { // 0 - String x = (String) vh.compareAndExchangeVolatile(); + String x = (String) vh.compareAndExchange(); }); checkWMTE(() -> { // > - String x = (String) vh.compareAndExchangeVolatile(array, 0, "foo", "foo", Void.class); + String x = (String) vh.compareAndExchange(array, 0, "foo", "foo", Void.class); }); diff --git a/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestAccess.java.template b/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestAccess.java.template index 5dfd82f6cd7..a0b48a90bda 100644 --- a/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestAccess.java.template +++ b/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestAccess.java.template @@ -101,7 +101,7 @@ public class VarHandleTestAccess$Type$ extends VarHandleBaseTest { #if[CAS] assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); @@ -111,7 +111,7 @@ public class VarHandleTestAccess$Type$ extends VarHandleBaseTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_SET)); #else[CAS] assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); + assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); @@ -283,7 +283,7 @@ public class VarHandleTestAccess$Type$ extends VarHandleBaseTest { }); checkUOE(() -> { - $type$ r = ($type$) vh.compareAndExchangeVolatile(recv, $value1$, $value2$); + $type$ r = ($type$) vh.compareAndExchange(recv, $value1$, $value2$); }); checkUOE(() -> { @@ -377,7 +377,7 @@ public class VarHandleTestAccess$Type$ extends VarHandleBaseTest { }); checkUOE(() -> { - $type$ r = ($type$) vh.compareAndExchangeVolatile($value1$, $value2$); + $type$ r = ($type$) vh.compareAndExchange($value1$, $value2$); }); checkUOE(() -> { @@ -470,17 +470,17 @@ public class VarHandleTestAccess$Type$ extends VarHandleBaseTest { } { - $type$ r = ($type$) vh.compareAndExchangeVolatile(recv, $value2$, $value1$); - assertEquals(r, $value2$, "success compareAndExchangeVolatile $type$"); + $type$ r = ($type$) vh.compareAndExchange(recv, $value2$, $value1$); + assertEquals(r, $value2$, "success compareAndExchange $type$"); $type$ x = ($type$) vh.get(recv); - assertEquals(x, $value1$, "success compareAndExchangeVolatile $type$ value"); + assertEquals(x, $value1$, "success compareAndExchange $type$ value"); } { - $type$ r = ($type$) vh.compareAndExchangeVolatile(recv, $value2$, $value3$); - assertEquals(r, $value1$, "failing compareAndExchangeVolatile $type$"); + $type$ r = ($type$) vh.compareAndExchange(recv, $value2$, $value3$); + assertEquals(r, $value1$, "failing compareAndExchange $type$"); $type$ x = ($type$) vh.get(recv); - assertEquals(x, $value1$, "failing compareAndExchangeVolatile $type$ value"); + assertEquals(x, $value1$, "failing compareAndExchange $type$ value"); } { @@ -568,7 +568,7 @@ public class VarHandleTestAccess$Type$ extends VarHandleBaseTest { $type$ o = ($type$) vh.getAndAdd(recv, $value3$); assertEquals(o, $value1$, "getAndAdd $type$"); $type$ c = ($type$) vh.addAndGet(recv, $value3$); - assertEquals(c, $value1$ + $value3$ + $value3$, "getAndAdd $type$ value"); + assertEquals(c, ($type$)($value1$ + $value3$ + $value3$), "getAndAdd $type$ value"); } #end[AtomicAdd] } @@ -580,7 +580,7 @@ public class VarHandleTestAccess$Type$ extends VarHandleBaseTest { }); checkUOE(() -> { - $type$ r = ($type$) vh.compareAndExchangeVolatile(recv, $value1$, $value2$); + $type$ r = ($type$) vh.compareAndExchange(recv, $value1$, $value2$); }); checkUOE(() -> { @@ -673,17 +673,17 @@ public class VarHandleTestAccess$Type$ extends VarHandleBaseTest { } { - $type$ r = ($type$) vh.compareAndExchangeVolatile($value2$, $value1$); - assertEquals(r, $value2$, "success compareAndExchangeVolatile $type$"); + $type$ r = ($type$) vh.compareAndExchange($value2$, $value1$); + assertEquals(r, $value2$, "success compareAndExchange $type$"); $type$ x = ($type$) vh.get(); - assertEquals(x, $value1$, "success compareAndExchangeVolatile $type$ value"); + assertEquals(x, $value1$, "success compareAndExchange $type$ value"); } { - $type$ r = ($type$) vh.compareAndExchangeVolatile($value2$, $value3$); - assertEquals(r, $value1$, "failing compareAndExchangeVolatile $type$"); + $type$ r = ($type$) vh.compareAndExchange($value2$, $value3$); + assertEquals(r, $value1$, "failing compareAndExchange $type$"); $type$ x = ($type$) vh.get(); - assertEquals(x, $value1$, "failing compareAndExchangeVolatile $type$ value"); + assertEquals(x, $value1$, "failing compareAndExchange $type$ value"); } { @@ -771,7 +771,7 @@ public class VarHandleTestAccess$Type$ extends VarHandleBaseTest { $type$ o = ($type$) vh.getAndAdd( $value3$); assertEquals(o, $value1$, "getAndAdd $type$"); $type$ c = ($type$) vh.addAndGet($value3$); - assertEquals(c, $value1$ + $value3$ + $value3$, "getAndAdd $type$ value"); + assertEquals(c, ($type$)($value1$ + $value3$ + $value3$), "getAndAdd $type$ value"); } #end[AtomicAdd] } @@ -783,7 +783,7 @@ public class VarHandleTestAccess$Type$ extends VarHandleBaseTest { }); checkUOE(() -> { - $type$ r = ($type$) vh.compareAndExchangeVolatile($value1$, $value2$); + $type$ r = ($type$) vh.compareAndExchange($value1$, $value2$); }); checkUOE(() -> { @@ -879,17 +879,17 @@ public class VarHandleTestAccess$Type$ extends VarHandleBaseTest { } { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, i, $value2$, $value1$); - assertEquals(r, $value2$, "success compareAndExchangeVolatile $type$"); + $type$ r = ($type$) vh.compareAndExchange(array, i, $value2$, $value1$); + assertEquals(r, $value2$, "success compareAndExchange $type$"); $type$ x = ($type$) vh.get(array, i); - assertEquals(x, $value1$, "success compareAndExchangeVolatile $type$ value"); + assertEquals(x, $value1$, "success compareAndExchange $type$ value"); } { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, i, $value2$, $value3$); - assertEquals(r, $value1$, "failing compareAndExchangeVolatile $type$"); + $type$ r = ($type$) vh.compareAndExchange(array, i, $value2$, $value3$); + assertEquals(r, $value1$, "failing compareAndExchange $type$"); $type$ x = ($type$) vh.get(array, i); - assertEquals(x, $value1$, "failing compareAndExchangeVolatile $type$ value"); + assertEquals(x, $value1$, "failing compareAndExchange $type$ value"); } { @@ -977,7 +977,7 @@ public class VarHandleTestAccess$Type$ extends VarHandleBaseTest { $type$ o = ($type$) vh.getAndAdd(array, i, $value3$); assertEquals(o, $value1$, "getAndAdd $type$"); $type$ c = ($type$) vh.addAndGet(array, i, $value3$); - assertEquals(c, $value1$ + $value3$ + $value3$, "getAndAdd $type$ value"); + assertEquals(c, ($type$)($value1$ + $value3$ + $value3$), "getAndAdd $type$ value"); } #end[AtomicAdd] } @@ -993,7 +993,7 @@ public class VarHandleTestAccess$Type$ extends VarHandleBaseTest { }); checkUOE(() -> { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, i, $value1$, $value2$); + $type$ r = ($type$) vh.compareAndExchange(array, i, $value1$, $value2$); }); checkUOE(() -> { @@ -1080,7 +1080,7 @@ public class VarHandleTestAccess$Type$ extends VarHandleBaseTest { }); checkIOOBE(() -> { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, ci, $value2$, $value1$); + $type$ r = ($type$) vh.compareAndExchange(array, ci, $value2$, $value1$); }); checkIOOBE(() -> { diff --git a/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestByteArrayView.java.template b/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestByteArrayView.java.template index 615bb528e06..a7aef2b898c 100644 --- a/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestByteArrayView.java.template +++ b/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestByteArrayView.java.template @@ -90,7 +90,7 @@ public class VarHandleTestByteArrayAs$Type$ extends VarHandleBaseByteArrayTest { #if[CAS] assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); + assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); @@ -100,7 +100,7 @@ public class VarHandleTestByteArrayAs$Type$ extends VarHandleBaseByteArrayTest { assertTrue(vh.isAccessModeSupported(VarHandle.AccessMode.GET_AND_SET)); #else[CAS] assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_SET)); - assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_VOLATILE)); + assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_ACQUIRE)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.COMPARE_AND_EXCHANGE_RELEASE)); assertFalse(vh.isAccessModeSupported(VarHandle.AccessMode.WEAK_COMPARE_AND_SET)); @@ -207,7 +207,7 @@ public class VarHandleTestByteArrayAs$Type$ extends VarHandleBaseByteArrayTest { }); checkUOE(() -> { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + $type$ r = ($type$) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkUOE(() -> { @@ -281,7 +281,7 @@ public class VarHandleTestByteArrayAs$Type$ extends VarHandleBaseByteArrayTest { }); checkROBE(() -> { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + $type$ r = ($type$) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkROBE(() -> { @@ -318,7 +318,7 @@ public class VarHandleTestByteArrayAs$Type$ extends VarHandleBaseByteArrayTest { }); checkUOE(() -> { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + $type$ r = ($type$) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkUOE(() -> { @@ -375,7 +375,7 @@ public class VarHandleTestByteArrayAs$Type$ extends VarHandleBaseByteArrayTest { }); checkUOE(() -> { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + $type$ r = ($type$) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkUOE(() -> { @@ -465,7 +465,7 @@ public class VarHandleTestByteArrayAs$Type$ extends VarHandleBaseByteArrayTest { }); checkIOOBE(() -> { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + $type$ r = ($type$) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkIOOBE(() -> { @@ -561,7 +561,7 @@ public class VarHandleTestByteArrayAs$Type$ extends VarHandleBaseByteArrayTest { }); checkIOOBE(() -> { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + $type$ r = ($type$) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkIOOBE(() -> { @@ -648,7 +648,7 @@ public class VarHandleTestByteArrayAs$Type$ extends VarHandleBaseByteArrayTest { }); checkISE(() -> { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + $type$ r = ($type$) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkISE(() -> { @@ -738,7 +738,7 @@ public class VarHandleTestByteArrayAs$Type$ extends VarHandleBaseByteArrayTest { }); checkISE(() -> { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, ci, VALUE_2, VALUE_1); + $type$ r = ($type$) vh.compareAndExchange(array, ci, VALUE_2, VALUE_1); }); checkISE(() -> { @@ -844,17 +844,17 @@ public class VarHandleTestByteArrayAs$Type$ extends VarHandleBaseByteArrayTest { } { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_1); - assertEquals(r, VALUE_2, "success compareAndExchangeVolatile $type$"); + $type$ r = ($type$) vh.compareAndExchange(array, i, VALUE_2, VALUE_1); + assertEquals(r, VALUE_2, "success compareAndExchange $type$"); $type$ x = ($type$) vh.get(array, i); - assertEquals(x, VALUE_1, "success compareAndExchangeVolatile $type$ value"); + assertEquals(x, VALUE_1, "success compareAndExchange $type$ value"); } { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_3); - assertEquals(r, VALUE_1, "failing compareAndExchangeVolatile $type$"); + $type$ r = ($type$) vh.compareAndExchange(array, i, VALUE_2, VALUE_3); + assertEquals(r, VALUE_1, "failing compareAndExchange $type$"); $type$ x = ($type$) vh.get(array, i); - assertEquals(x, VALUE_1, "failing compareAndExchangeVolatile $type$ value"); + assertEquals(x, VALUE_1, "failing compareAndExchange $type$ value"); } { @@ -1006,17 +1006,17 @@ public class VarHandleTestByteArrayAs$Type$ extends VarHandleBaseByteArrayTest { } { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_1); - assertEquals(r, VALUE_2, "success compareAndExchangeVolatile $type$"); + $type$ r = ($type$) vh.compareAndExchange(array, i, VALUE_2, VALUE_1); + assertEquals(r, VALUE_2, "success compareAndExchange $type$"); $type$ x = ($type$) vh.get(array, i); - assertEquals(x, VALUE_1, "success compareAndExchangeVolatile $type$ value"); + assertEquals(x, VALUE_1, "success compareAndExchange $type$ value"); } { - $type$ r = ($type$) vh.compareAndExchangeVolatile(array, i, VALUE_2, VALUE_3); - assertEquals(r, VALUE_1, "failing compareAndExchangeVolatile $type$"); + $type$ r = ($type$) vh.compareAndExchange(array, i, VALUE_2, VALUE_3); + assertEquals(r, VALUE_1, "failing compareAndExchange $type$"); $type$ x = ($type$) vh.get(array, i); - assertEquals(x, VALUE_1, "failing compareAndExchangeVolatile $type$ value"); + assertEquals(x, VALUE_1, "failing compareAndExchange $type$ value"); } { diff --git a/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestMethodHandleAccess.java.template b/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestMethodHandleAccess.java.template index e4bd78e8f45..6df8b203e3a 100644 --- a/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestMethodHandleAccess.java.template +++ b/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestMethodHandleAccess.java.template @@ -167,17 +167,17 @@ public class VarHandleTestMethodHandleAccess$Type$ extends VarHandleBaseTest { } { - $type$ r = ($type$) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(recv, $value2$, $value1$); - assertEquals(r, $value2$, "success compareAndExchangeVolatile $type$"); + $type$ r = ($type$) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, $value2$, $value1$); + assertEquals(r, $value2$, "success compareAndExchange $type$"); $type$ x = ($type$) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, $value1$, "success compareAndExchangeVolatile $type$ value"); + assertEquals(x, $value1$, "success compareAndExchange $type$ value"); } { - $type$ r = ($type$) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(recv, $value2$, $value3$); - assertEquals(r, $value1$, "failing compareAndExchangeVolatile $type$"); + $type$ r = ($type$) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(recv, $value2$, $value3$); + assertEquals(r, $value1$, "failing compareAndExchange $type$"); $type$ x = ($type$) hs.get(TestAccessMode.GET).invokeExact(recv); - assertEquals(x, $value1$, "failing compareAndExchangeVolatile $type$ value"); + assertEquals(x, $value1$, "failing compareAndExchange $type$ value"); } { @@ -265,7 +265,7 @@ public class VarHandleTestMethodHandleAccess$Type$ extends VarHandleBaseTest { $type$ o = ($type$) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(recv, $value3$); assertEquals(o, $value1$, "getAndAdd $type$"); $type$ c = ($type$) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(recv, $value3$); - assertEquals(c, $value1$ + $value3$ + $value3$, "getAndAdd $type$ value"); + assertEquals(c, ($type$)($value1$ + $value3$ + $value3$), "getAndAdd $type$ value"); } #end[AtomicAdd] } @@ -350,17 +350,17 @@ public class VarHandleTestMethodHandleAccess$Type$ extends VarHandleBaseTest { } { - $type$ r = ($type$) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact($value2$, $value1$); - assertEquals(r, $value2$, "success compareAndExchangeVolatile $type$"); + $type$ r = ($type$) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact($value2$, $value1$); + assertEquals(r, $value2$, "success compareAndExchange $type$"); $type$ x = ($type$) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, $value1$, "success compareAndExchangeVolatile $type$ value"); + assertEquals(x, $value1$, "success compareAndExchange $type$ value"); } { - $type$ r = ($type$) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact($value2$, $value3$); - assertEquals(r, $value1$, "failing compareAndExchangeVolatile $type$"); + $type$ r = ($type$) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact($value2$, $value3$); + assertEquals(r, $value1$, "failing compareAndExchange $type$"); $type$ x = ($type$) hs.get(TestAccessMode.GET).invokeExact(); - assertEquals(x, $value1$, "failing compareAndExchangeVolatile $type$ value"); + assertEquals(x, $value1$, "failing compareAndExchange $type$ value"); } { @@ -448,7 +448,7 @@ public class VarHandleTestMethodHandleAccess$Type$ extends VarHandleBaseTest { $type$ o = ($type$) hs.get(TestAccessMode.GET_AND_ADD).invokeExact( $value3$); assertEquals(o, $value1$, "getAndAdd $type$"); $type$ c = ($type$) hs.get(TestAccessMode.ADD_AND_GET).invokeExact($value3$); - assertEquals(c, $value1$ + $value3$ + $value3$, "getAndAdd $type$ value"); + assertEquals(c, ($type$)($value1$ + $value3$ + $value3$), "getAndAdd $type$ value"); } #end[AtomicAdd] } @@ -536,17 +536,17 @@ public class VarHandleTestMethodHandleAccess$Type$ extends VarHandleBaseTest { } { - $type$ r = ($type$) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(array, i, $value2$, $value1$); - assertEquals(r, $value2$, "success compareAndExchangeVolatile $type$"); + $type$ r = ($type$) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, $value2$, $value1$); + assertEquals(r, $value2$, "success compareAndExchange $type$"); $type$ x = ($type$) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, $value1$, "success compareAndExchangeVolatile $type$ value"); + assertEquals(x, $value1$, "success compareAndExchange $type$ value"); } { - $type$ r = ($type$) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE_VOLATILE).invokeExact(array, i, $value2$, $value3$); - assertEquals(r, $value1$, "failing compareAndExchangeVolatile $type$"); + $type$ r = ($type$) hs.get(TestAccessMode.COMPARE_AND_EXCHANGE).invokeExact(array, i, $value2$, $value3$); + assertEquals(r, $value1$, "failing compareAndExchange $type$"); $type$ x = ($type$) hs.get(TestAccessMode.GET).invokeExact(array, i); - assertEquals(x, $value1$, "failing compareAndExchangeVolatile $type$ value"); + assertEquals(x, $value1$, "failing compareAndExchange $type$ value"); } { @@ -634,7 +634,7 @@ public class VarHandleTestMethodHandleAccess$Type$ extends VarHandleBaseTest { $type$ o = ($type$) hs.get(TestAccessMode.GET_AND_ADD).invokeExact(array, i, $value3$); assertEquals(o, $value1$, "getAndAdd $type$"); $type$ c = ($type$) hs.get(TestAccessMode.ADD_AND_GET).invokeExact(array, i, $value3$); - assertEquals(c, $value1$ + $value3$ + $value3$, "getAndAdd $type$ value"); + assertEquals(c, ($type$)($value1$ + $value3$ + $value3$), "getAndAdd $type$ value"); } #end[AtomicAdd] } diff --git a/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestMethodType.java.template b/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestMethodType.java.template index 5bec8b46a10..15c4610df43 100644 --- a/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestMethodType.java.template +++ b/jdk/test/java/lang/invoke/VarHandles/X-VarHandleTestMethodType.java.template @@ -455,40 +455,40 @@ public class VarHandleTestMethodType$Type$ extends VarHandleBaseTest { }); - // CompareAndExchangeVolatile + // CompareAndExchange // Incorrect argument types checkNPE(() -> { // null receiver - $type$ x = ($type$) vh.compareAndExchangeVolatile(null, $value1$, $value1$); + $type$ x = ($type$) vh.compareAndExchange(null, $value1$, $value1$); }); checkCCE(() -> { // receiver reference class - $type$ x = ($type$) vh.compareAndExchangeVolatile(Void.class, $value1$, $value1$); + $type$ x = ($type$) vh.compareAndExchange(Void.class, $value1$, $value1$); }); check{#if[String]?CCE:WMTE}(() -> { // expected reference class - $type$ x = ($type$) vh.compareAndExchangeVolatile(recv, Void.class, $value1$); + $type$ x = ($type$) vh.compareAndExchange(recv, Void.class, $value1$); }); check{#if[String]?CCE:WMTE}(() -> { // actual reference class - $type$ x = ($type$) vh.compareAndExchangeVolatile(recv, $value1$, Void.class); + $type$ x = ($type$) vh.compareAndExchange(recv, $value1$, Void.class); }); checkWMTE(() -> { // reciever primitive class - $type$ x = ($type$) vh.compareAndExchangeVolatile(0, $value1$, $value1$); + $type$ x = ($type$) vh.compareAndExchange(0, $value1$, $value1$); }); // Incorrect return type check{#if[String]?CCE:WMTE}(() -> { // reference class - Void r = (Void) vh.compareAndExchangeVolatile(recv, $value1$, $value1$); + Void r = (Void) vh.compareAndExchange(recv, $value1$, $value1$); }); checkWMTE(() -> { // primitive class - $wrong_primitive_type$ x = ($wrong_primitive_type$) vh.compareAndExchangeVolatile(recv, $value1$, $value1$); + $wrong_primitive_type$ x = ($wrong_primitive_type$) vh.compareAndExchange(recv, $value1$, $value1$); }); // Incorrect arity checkWMTE(() -> { // 0 - $type$ x = ($type$) vh.compareAndExchangeVolatile(); + $type$ x = ($type$) vh.compareAndExchange(); }); checkWMTE(() -> { // > - $type$ x = ($type$) vh.compareAndExchangeVolatile(recv, $value1$, $value1$, Void.class); + $type$ x = ($type$) vh.compareAndExchange(recv, $value1$, $value1$, Void.class); }); - // CompareAndExchangeVolatileAcquire + // CompareAndExchangeAcquire // Incorrect argument types checkNPE(() -> { // null receiver $type$ x = ($type$) vh.compareAndExchangeAcquire(null, $value1$, $value1$); @@ -1060,27 +1060,27 @@ public class VarHandleTestMethodType$Type$ extends VarHandleBaseTest { }); - // CompareAndExchangeVolatile + // CompareAndExchange // Incorrect argument types check{#if[String]?CCE:WMTE}(() -> { // expected reference class - $type$ x = ($type$) vh.compareAndExchangeVolatile(Void.class, $value1$); + $type$ x = ($type$) vh.compareAndExchange(Void.class, $value1$); }); check{#if[String]?CCE:WMTE}(() -> { // actual reference class - $type$ x = ($type$) vh.compareAndExchangeVolatile($value1$, Void.class); + $type$ x = ($type$) vh.compareAndExchange($value1$, Void.class); }); // Incorrect return type check{#if[String]?CCE:WMTE}(() -> { // reference class - Void r = (Void) vh.compareAndExchangeVolatile($value1$, $value1$); + Void r = (Void) vh.compareAndExchange($value1$, $value1$); }); checkWMTE(() -> { // primitive class - $wrong_primitive_type$ x = ($wrong_primitive_type$) vh.compareAndExchangeVolatile($value1$, $value1$); + $wrong_primitive_type$ x = ($wrong_primitive_type$) vh.compareAndExchange($value1$, $value1$); }); // Incorrect arity checkWMTE(() -> { // 0 - $type$ x = ($type$) vh.compareAndExchangeVolatile(); + $type$ x = ($type$) vh.compareAndExchange(); }); checkWMTE(() -> { // > - $type$ x = ($type$) vh.compareAndExchangeVolatile($value1$, $value1$, Void.class); + $type$ x = ($type$) vh.compareAndExchange($value1$, $value1$, Void.class); }); @@ -1715,39 +1715,39 @@ public class VarHandleTestMethodType$Type$ extends VarHandleBaseTest { }); - // CompareAndExchangeVolatile + // CompareAndExchange // Incorrect argument types checkNPE(() -> { // null receiver - $type$ x = ($type$) vh.compareAndExchangeVolatile(null, 0, $value1$, $value1$); + $type$ x = ($type$) vh.compareAndExchange(null, 0, $value1$, $value1$); }); checkCCE(() -> { // array reference class - $type$ x = ($type$) vh.compareAndExchangeVolatile(Void.class, 0, $value1$, $value1$); + $type$ x = ($type$) vh.compareAndExchange(Void.class, 0, $value1$, $value1$); }); check{#if[String]?CCE:WMTE}(() -> { // expected reference class - $type$ x = ($type$) vh.compareAndExchangeVolatile(array, 0, Void.class, $value1$); + $type$ x = ($type$) vh.compareAndExchange(array, 0, Void.class, $value1$); }); check{#if[String]?CCE:WMTE}(() -> { // actual reference class - $type$ x = ($type$) vh.compareAndExchangeVolatile(array, 0, $value1$, Void.class); + $type$ x = ($type$) vh.compareAndExchange(array, 0, $value1$, Void.class); }); checkWMTE(() -> { // array primitive class - $type$ x = ($type$) vh.compareAndExchangeVolatile(0, 0, $value1$, $value1$); + $type$ x = ($type$) vh.compareAndExchange(0, 0, $value1$, $value1$); }); checkWMTE(() -> { // index reference class - $type$ x = ($type$) vh.compareAndExchangeVolatile(array, Void.class, $value1$, $value1$); + $type$ x = ($type$) vh.compareAndExchange(array, Void.class, $value1$, $value1$); }); // Incorrect return type check{#if[String]?CCE:WMTE}(() -> { // reference class - Void r = (Void) vh.compareAndExchangeVolatile(array, 0, $value1$, $value1$); + Void r = (Void) vh.compareAndExchange(array, 0, $value1$, $value1$); }); checkWMTE(() -> { // primitive class - $wrong_primitive_type$ x = ($wrong_primitive_type$) vh.compareAndExchangeVolatile(array, 0, $value1$, $value1$); + $wrong_primitive_type$ x = ($wrong_primitive_type$) vh.compareAndExchange(array, 0, $value1$, $value1$); }); // Incorrect arity checkWMTE(() -> { // 0 - $type$ x = ($type$) vh.compareAndExchangeVolatile(); + $type$ x = ($type$) vh.compareAndExchange(); }); checkWMTE(() -> { // > - $type$ x = ($type$) vh.compareAndExchangeVolatile(array, 0, $value1$, $value1$, Void.class); + $type$ x = ($type$) vh.compareAndExchange(array, 0, $value1$, $value1$, Void.class); }); diff --git a/jdk/test/java/lang/invoke/VarHandles/generate-vh-tests.sh b/jdk/test/java/lang/invoke/VarHandles/generate-vh-tests.sh index 436d2d371d9..02ae5ae304f 100644 --- a/jdk/test/java/lang/invoke/VarHandles/generate-vh-tests.sh +++ b/jdk/test/java/lang/invoke/VarHandles/generate-vh-tests.sh @@ -14,14 +14,10 @@ do Type="$(tr '[:lower:]' '[:upper:]' <<< ${type:0:1})${type:1}" args="-K$type -Dtype=$type -DType=$Type" - case $type in - String|int|long) - args="$args -KCAS" - ;; - esac + args="$args -KCAS" case $type in - int|long) + byte|short|char|int|long|float|double) args="$args -KAtomicAdd" ;; esac @@ -36,29 +32,29 @@ do wrong_primitive_type=int ;; byte) - value1=(byte)1 - value2=(byte)2 - value3=(byte)3 + value1=(byte)0x01 + value2=(byte)0x23 + value3=(byte)0x45 ;; short) - value1=(short)1 - value2=(short)2 - value3=(short)3 + value1=(short)0x0123 + value2=(short)0x4567 + value3=(short)0x89AB ;; char) - value1=\'a\' - value2=\'b\' - value3=\'c\' + value1=\'\\\\u0123\' + value2=\'\\\\u4567\' + value3=\'\\\\u89AB\' ;; int) - value1=1 - value2=2 - value3=3 + value1=0x01234567 + value2=0x89ABCDEF + value3=0xCAFEBABE ;; long) - value1=1L - value2=2L - value3=3L + value1=0x0123456789ABCDEFL + value2=0xCAFEBABECAFEBABEL + value3=0xDEADBEEFDEADBEEFL ;; float) value1=1.0f diff --git a/jdk/test/java/nio/file/FileStore/Basic.java b/jdk/test/java/nio/file/FileStore/Basic.java index f81d3d95a8b..14479e3cc9b 100644 --- a/jdk/test/java/nio/file/FileStore/Basic.java +++ b/jdk/test/java/nio/file/FileStore/Basic.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -124,6 +124,12 @@ public class Basic { // ignore exception as the store could have been // deleted since the iterator was instantiated System.err.format("%s was not found\n", store); + } catch (AccessDeniedException ade) { + // ignore exception as the lack of ability to access the + // store due to lack of file permission or similar does not + // reflect whether the space attributes would be accessible + // were access to be permitted + System.err.format("%s is inaccessible\n", store); } // two distinct FileStores should not be equal diff --git a/jdk/test/java/security/SignedObject/Chain.java b/jdk/test/java/security/SignedObject/Chain.java index e6c423cbb02..13939996edb 100644 --- a/jdk/test/java/security/SignedObject/Chain.java +++ b/jdk/test/java/security/SignedObject/Chain.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -33,6 +33,7 @@ import java.util.Arrays; /* * @test * @bug 8050374 + * @key intermittent * @summary Verify a chain of signed objects */ public class Chain { diff --git a/jdk/test/java/util/Spliterator/SpliteratorLateBindingFailFastTest.java b/jdk/test/java/util/Spliterator/SpliteratorLateBindingFailFastTest.java index dc961b15e5a..0aecca604bd 100644 --- a/jdk/test/java/util/Spliterator/SpliteratorLateBindingFailFastTest.java +++ b/jdk/test/java/util/Spliterator/SpliteratorLateBindingFailFastTest.java @@ -24,11 +24,13 @@ import org.testng.annotations.DataProvider; import org.testng.annotations.Test; +import java.util.AbstractList; import java.util.ArrayList; import java.util.Arrays; import java.util.Collection; import java.util.Collections; import java.util.ConcurrentModificationException; +import java.util.Iterator; import java.util.HashMap; import java.util.HashSet; import java.util.LinkedHashMap; @@ -37,6 +39,7 @@ import java.util.LinkedList; import java.util.List; import java.util.Map; import java.util.PriorityQueue; +import java.util.RandomAccess; import java.util.Set; import java.util.Spliterator; import java.util.Stack; @@ -191,6 +194,46 @@ public class SpliteratorLateBindingFailFastTest { db.addList(Vector::new); + class AbstractRandomAccessListImpl extends AbstractList implements RandomAccess { + List l; + + AbstractRandomAccessListImpl(Collection c) { + this.l = new ArrayList<>(c); + } + + @Override + public boolean add(Integer integer) { + modCount++; + return l.add(integer); + } + + @Override + public Iterator iterator() { + return l.iterator(); + } + + @Override + public Integer get(int index) { + return l.get(index); + } + + @Override + public boolean remove(Object o) { + modCount++; + return l.remove(o); + } + + @Override + public int size() { + return l.size(); + } + + @Override + public List subList(int fromIndex, int toIndex) { + return l.subList(fromIndex, toIndex); + } + } + db.addList(AbstractRandomAccessListImpl::new); db.addCollection(HashSet::new); diff --git a/jdk/test/java/util/Spliterator/SpliteratorTraversingAndSplittingTest.java b/jdk/test/java/util/Spliterator/SpliteratorTraversingAndSplittingTest.java index a823ac04833..a8d6a9c6471 100644 --- a/jdk/test/java/util/Spliterator/SpliteratorTraversingAndSplittingTest.java +++ b/jdk/test/java/util/Spliterator/SpliteratorTraversingAndSplittingTest.java @@ -49,8 +49,10 @@ import java.util.LinkedHashMap; import java.util.LinkedHashSet; import java.util.LinkedList; import java.util.List; +import java.util.ListIterator; import java.util.Map; import java.util.PriorityQueue; +import java.util.RandomAccess; import java.util.Set; import java.util.SortedSet; import java.util.Spliterator; @@ -379,6 +381,150 @@ public class SpliteratorTraversingAndSplittingTest { db.addList(Vector::new); + class AbstractRandomAccessListImpl extends AbstractList implements RandomAccess { + Integer[] ia; + + AbstractRandomAccessListImpl(Collection c) { + this.ia = c.toArray(new Integer[c.size()]); + } + + @Override + public Integer get(int index) { + return ia[index]; + } + + @Override + public int size() { + return ia.length; + } + } + db.addList(AbstractRandomAccessListImpl::new); + + class RandomAccessListImpl implements List, RandomAccess { + Integer[] ia; + List l; + + RandomAccessListImpl(Collection c) { + this.ia = c.toArray(new Integer[c.size()]); + this.l = Arrays.asList(ia); + } + + @Override + public Integer get(int index) { + return ia[index]; + } + + @Override + public Integer set(int index, Integer element) { + throw new UnsupportedOperationException(); + } + + @Override + public void add(int index, Integer element) { + throw new UnsupportedOperationException(); + } + + @Override + public Integer remove(int index) { + throw new UnsupportedOperationException(); + } + + @Override + public int indexOf(Object o) { + return l.indexOf(o); + } + + @Override + public int lastIndexOf(Object o) { + return Arrays.asList(ia).lastIndexOf(o); + } + + @Override + public ListIterator listIterator() { + return l.listIterator(); + } + + @Override + public ListIterator listIterator(int index) { + return l.listIterator(index); + } + + @Override + public List subList(int fromIndex, int toIndex) { + return l.subList(fromIndex, toIndex); + } + + @Override + public int size() { + return ia.length; + } + + @Override + public boolean isEmpty() { + return size() != 0; + } + + @Override + public boolean contains(Object o) { + return l.contains(o); + } + + @Override + public Iterator iterator() { + return l.iterator(); + } + + @Override + public Object[] toArray() { + return l.toArray(); + } + + @Override + public T[] toArray(T[] a) { + return l.toArray(a); + } + + @Override + public boolean add(Integer integer) { + throw new UnsupportedOperationException(); + } + + @Override + public boolean remove(Object o) { + throw new UnsupportedOperationException(); + } + + @Override + public boolean containsAll(Collection c) { + return l.containsAll(c); + } + + @Override + public boolean addAll(Collection c) { + throw new UnsupportedOperationException(); + } + + @Override + public boolean addAll(int index, Collection c) { + throw new UnsupportedOperationException(); + } + + @Override + public boolean removeAll(Collection c) { + throw new UnsupportedOperationException(); + } + + @Override + public boolean retainAll(Collection c) { + throw new UnsupportedOperationException(); + } + + @Override + public void clear() { + throw new UnsupportedOperationException(); + } + } + db.addList(RandomAccessListImpl::new); db.addCollection(HashSet::new); diff --git a/jdk/test/java/util/logging/CheckLockLocationTest.java b/jdk/test/java/util/logging/CheckLockLocationTest.java index e482d3ef2f7..dc854aa5d4d 100644 --- a/jdk/test/java/util/logging/CheckLockLocationTest.java +++ b/jdk/test/java/util/logging/CheckLockLocationTest.java @@ -30,13 +30,16 @@ * @run main/othervm CheckLockLocationTest */ import java.io.File; +import java.io.FileOutputStream; import java.io.IOException; +import java.io.OutputStream; import java.nio.file.AccessDeniedException; import java.nio.file.FileSystemException; import java.nio.file.Files; import java.nio.file.NoSuchFileException; import java.nio.file.Path; import java.nio.file.attribute.UserPrincipal; +import java.util.UUID; import java.util.logging.FileHandler; public class CheckLockLocationTest { @@ -78,7 +81,11 @@ public class CheckLockLocationTest { } catch (IOException ex) { throw new RuntimeException("Test failed: should have been able" + " to create FileHandler for " + "%t/" + WRITABLE_DIR - + "/log.log in writable directory.", ex); + + "/log.log in writable directory" + + (!writableDir.canRead() // concurrent tests running or user conf issue? + ? ": directory not readable.\n\tPlease check your " + + "environment and machine configuration." + : "."), ex); } finally { // the above test leaves files in the directory. Get rid of the // files created and the directory @@ -149,8 +156,41 @@ public class CheckLockLocationTest { + " writable working directory " + writableDir.getAbsolutePath() ); } + + if (!writableDir.canRead()) { + throw new RuntimeException("Test setup failed: can't read " + + " writable working directory " + + writableDir.getAbsolutePath() ); + } + // writableDirectory and its contents will be deleted after the test - // that uses it + // that uses it. + + // check that we can write in the new writable dir. + File dummyFile = new File(writableDir, UUID.randomUUID().toString() + ".txt" ); + try { + if (!dummyFile.createNewFile()) { + throw new RuntimeException("Test setup failed: can't create " + + " dummy file in writable working directory " + + dummyFile.getAbsolutePath() ); + } + try (OutputStream os = new FileOutputStream(dummyFile)) { + os.write('A'); + } finally { + dummyFile.delete(); + } + if (dummyFile.canRead()) { + throw new RuntimeException("Test setup failed: can't delete " + + " dummy file in writable working directory " + + dummyFile.getAbsolutePath() ); + } + System.out.println("Successfully created and deleted dummy file: " + + dummyFile.getAbsolutePath()); + } catch(IOException x) { + throw new RuntimeException("Test setup failed: can't write " + + " or delete dummy file in writable working directory " + + dummyFile.getAbsolutePath(), x); + } // Create a plain file which we will attempt to use as a directory // (%t/not-a-dir) diff --git a/jdk/test/javax/imageio/plugins/jpeg/JpegMultipleEOI.jpg b/jdk/test/javax/imageio/plugins/jpeg/JpegMultipleEOI.jpg new file mode 100644 index 00000000000..9d7d2c88d65 Binary files /dev/null and b/jdk/test/javax/imageio/plugins/jpeg/JpegMultipleEOI.jpg differ diff --git a/jdk/test/javax/imageio/plugins/jpeg/JpegMultipleEOITest.java b/jdk/test/javax/imageio/plugins/jpeg/JpegMultipleEOITest.java new file mode 100644 index 00000000000..757b71149af --- /dev/null +++ b/jdk/test/javax/imageio/plugins/jpeg/JpegMultipleEOITest.java @@ -0,0 +1,75 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @bug 8152672 + * @summary When jpeg file has more than one set of EOI-SOI markers, + * test verifies whether we calculate EOI markers of all images + * properly skipping EOI markers present in application headers. + * @run main JpegMultipleEOITest + */ + +import java.io.File; +import java.io.IOException; +import java.util.Iterator; +import javax.imageio.ImageIO; +import javax.imageio.ImageReader; +import javax.imageio.stream.ImageInputStream; + +public class JpegMultipleEOITest { + public static void main (String[] args) throws IOException { + Iterator readers = ImageIO.getImageReadersByFormatName("JPEG"); + ImageReader reader = null; + while(readers.hasNext()) { + reader = (ImageReader)readers.next(); + if(reader.canReadRaster()) { + break; + } + } + + if (reader != null) { + String fileName = "JpegMultipleEOI.jpg"; + String sep = System.getProperty("file.separator"); + String dir = System.getProperty("test.src", "."); + String filePath = dir+sep+fileName; + System.out.println("Test file: " + filePath); + File imageFile = new File(filePath); + ImageInputStream stream = ImageIO. + createImageInputStream(imageFile); + reader.setInput(stream); + int pageNum = 1; + try { + // read width of image index 1 + reader.getWidth(pageNum + reader.getMinIndex()); + } catch (IndexOutOfBoundsException e) { + /* + * do nothing, we are supposed to get IndexOutofBoundsException + * as number of image is 1 and we are trying to get width of + * second image. But we should not see IIOException with + * message "Not a JPEG file: starts with 0xff 0xe2" + */ + } + } + } +} diff --git a/jdk/test/javax/net/ssl/HttpsURLConnection/Equals.java b/jdk/test/javax/net/ssl/HttpsURLConnection/Equals.java index 0e40e52ce9b..38ee581bdbc 100644 --- a/jdk/test/javax/net/ssl/HttpsURLConnection/Equals.java +++ b/jdk/test/javax/net/ssl/HttpsURLConnection/Equals.java @@ -23,17 +23,14 @@ /** * @test + * @bug 8055299 * @library /lib/testlibrary * @modules jdk.httpserver * @build jdk.testlibrary.SimpleSSLContext - * @run main Equals - * @bug 8055299 + * @run main/othervm -Djavax.net.debug=ssl,handshake,record Equals */ - import com.sun.net.httpserver.*; - import java.net.*; -import java.util.*; import java.io.*; import javax.net.ssl.*; import java.util.concurrent.*; @@ -43,54 +40,59 @@ public class Equals { static SSLContext ctx; - public static void main (String[] args) throws Exception { + public static void main(String[] args) throws Exception { HttpsServer s2 = null; - ExecutorService executor=null; + ExecutorService executor = null; try { - InetSocketAddress addr = new InetSocketAddress (0); - s2 = HttpsServer.create (addr, 0); - HttpHandler h = new Handler (); - HttpContext c2 = s2.createContext ("/test1", h); + InetSocketAddress addr = new InetSocketAddress(0); + s2 = HttpsServer.create(addr, 0); + HttpHandler h = new Handler(); + HttpContext c2 = s2.createContext("/test1", h); executor = Executors.newCachedThreadPool(); - s2.setExecutor (executor); + s2.setExecutor(executor); ctx = new SimpleSSLContext().get(); - s2.setHttpsConfigurator(new HttpsConfigurator (ctx)); + s2.setHttpsConfigurator(new HttpsConfigurator(ctx)); s2.start(); - int httpsport = s2.getAddress().getPort(); + System.out.printf("%nServer address: %s%n", s2.getAddress()); test(httpsport); - System.out.println ("OK"); + System.out.println("OK"); } finally { - if (s2 != null) + if (s2 != null) { s2.stop(2); - if (executor != null) - executor.shutdown (); + } + if (executor != null) { + executor.shutdown(); + } } } static class Handler implements HttpHandler { + int invocation = 1; - public void handle (HttpExchange t) - throws IOException - { + + public void handle(HttpExchange t) + throws IOException { InputStream is = t.getRequestBody(); - while (is.read () != -1) { + while (is.read() != -1) { } is.close(); - t.sendResponseHeaders (200, 0); + t.sendResponseHeaders(200, 0); t.close(); } } - static void test (int port) throws Exception { - URL url = new URL ("https://localhost:"+port+"/test1/"); + static void test(int port) throws Exception { + System.out.printf("%nClient using port number: %s%n", port); + String spec = String.format("https://localhost:%s/test1/", port); + URL url = new URL(spec); HttpsURLConnection urlcs = (HttpsURLConnection) url.openConnection(); - urlcs.setHostnameVerifier (new HostnameVerifier () { - public boolean verify (String s, SSLSession s1) { + urlcs.setHostnameVerifier(new HostnameVerifier() { + public boolean verify(String s, SSLSession s1) { return true; } }); - urlcs.setSSLSocketFactory (ctx.getSocketFactory()); + urlcs.setSSLSocketFactory(ctx.getSocketFactory()); InputStream is = urlcs.getInputStream(); while (is.read() != -1) { diff --git a/jdk/test/javax/net/ssl/TLSv12/ShortRSAKey512.java b/jdk/test/javax/net/ssl/TLSv12/ShortRSAKey512.java index e4d563afbbb..627536a2417 100644 --- a/jdk/test/javax/net/ssl/TLSv12/ShortRSAKey512.java +++ b/jdk/test/javax/net/ssl/TLSv12/ShortRSAKey512.java @@ -33,7 +33,6 @@ * * SunJSSE does not support dynamic system properties, no way to re-use * system properties in samevm/agentvm mode. - * @key intermittent * @run main/othervm ShortRSAKey512 PKIX * @run main/othervm ShortRSAKey512 SunX509 */ diff --git a/jdk/test/javax/net/ssl/ciphersuites/ECCurvesconstraints.java b/jdk/test/javax/net/ssl/ciphersuites/ECCurvesconstraints.java new file mode 100644 index 00000000000..9e7e692455a --- /dev/null +++ b/jdk/test/javax/net/ssl/ciphersuites/ECCurvesconstraints.java @@ -0,0 +1,408 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +// +// SunJSSE does not support dynamic system properties, no way to re-use +// system properties in samevm/agentvm mode. +// + +/* + * @test + * @bug 8148516 + * @summary Improve the default strength of EC in JDK + * @run main/othervm ECCurvesconstraints PKIX + * @run main/othervm ECCurvesconstraints SunX509 + */ + +import java.net.*; +import java.util.*; +import java.io.*; +import javax.net.ssl.*; +import java.security.Security; +import java.security.KeyStore; +import java.security.KeyFactory; +import java.security.cert.Certificate; +import java.security.cert.X509Certificate; +import java.security.cert.CertificateFactory; +import java.security.spec.*; +import java.security.interfaces.*; +import java.util.Base64; + + +public class ECCurvesconstraints { + + /* + * ============================================================= + * Set the various variables needed for the tests, then + * specify what tests to run on each side. + */ + + /* + * Should we run the client or server in a separate thread? + * Both sides can throw exceptions, but do you have a preference + * as to which side should be the main thread. + */ + static boolean separateServerThread = false; + + /* + * Where do we find the keystores? + */ + // Certificates and key used in the test. + // + // EC curve: secp224k1 + static String trustedCertStr = + "-----BEGIN CERTIFICATE-----\n" + + "MIIBCzCBugIEVz2lcjAKBggqhkjOPQQDAjAaMRgwFgYDVQQDDA93d3cuZXhhbXBs\n" + + "ZS5vcmcwHhcNMTYwNTE5MTEzNzM5WhcNMTcwNTE5MTEzNzM5WjAaMRgwFgYDVQQD\n" + + "DA93d3cuZXhhbXBsZS5vcmcwTjAQBgcqhkjOPQIBBgUrgQQAIAM6AAT68uovMZ8f\n" + + "KARn5NOjvieJaq6h8zHYkM9w5DuN0kkOo4KBhke06EkQj0nvQQcSvppTV6RoDLY4\n" + + "djAKBggqhkjOPQQDAgNAADA9AhwMNIujM0R0llpPH6d89d1S3VRGH/78ovc+zw51\n" + + "Ah0AuZ1YlQkUbrJIzkuPSICxz5UfCWPe+7w4as+wiA==\n" + + "-----END CERTIFICATE-----"; + + // Private key in the format of PKCS#8 + static String targetPrivateKey = + "MIGCAgEAMBAGByqGSM49AgEGBSuBBAAgBGswaQIBAQQdAPbckc86mgW/zexB1Ajq\n" + + "38HntWOjdxL6XSoiAsWgBwYFK4EEACChPAM6AAT68uovMZ8fKARn5NOjvieJaq6h\n" + + "8zHYkM9w5DuN0kkOo4KBhke06EkQj0nvQQcSvppTV6RoDLY4dg=="; + + static String[] serverCerts = {trustedCertStr}; + static String[] serverKeys = {targetPrivateKey}; + static String[] clientCerts = {trustedCertStr}; + static String[] clientKeys = {targetPrivateKey}; + + static char passphrase[] = "passphrase".toCharArray(); + + /* + * Is the server ready to serve? + */ + volatile static boolean serverReady = false; + + /* + * Turn on SSL debugging? + */ + static boolean debug = false; + + /* + * Define the server side of the test. + * + * If the server prematurely exits, serverReady will be set to true + * to avoid infinite hangs. + */ + void doServerSide() throws Exception { + SSLContext context = generateSSLContext(false); + SSLServerSocketFactory sslssf = context.getServerSocketFactory(); + SSLServerSocket sslServerSocket = + (SSLServerSocket)sslssf.createServerSocket(serverPort); + serverPort = sslServerSocket.getLocalPort(); + + /* + * Signal Client, we're ready for his connect. + */ + serverReady = true; + + SSLSocket sslSocket = (SSLSocket)sslServerSocket.accept(); + try { + sslSocket.setSoTimeout(5000); + sslSocket.setSoLinger(true, 5); + + InputStream sslIS = sslSocket.getInputStream(); + OutputStream sslOS = sslSocket.getOutputStream(); + + sslIS.read(); + sslOS.write('A'); + sslOS.flush(); + + throw new Exception("EC curve secp224k1 should be disabled"); + } catch (SSLHandshakeException she) { + // expected exception: no cipher suites in common + System.out.println("Expected exception: " + she); + } finally { + sslSocket.close(); + sslServerSocket.close(); + } + } + + /* + * Define the client side of the test. + * + * If the server prematurely exits, serverReady will be set to true + * to avoid infinite hangs. + */ + void doClientSide() throws Exception { + + /* + * Wait for server to get started. + */ + while (!serverReady) { + Thread.sleep(50); + } + + SSLContext context = generateSSLContext(true); + SSLSocketFactory sslsf = context.getSocketFactory(); + + SSLSocket sslSocket = + (SSLSocket)sslsf.createSocket("localhost", serverPort); + + try { + sslSocket.setSoTimeout(5000); + sslSocket.setSoLinger(true, 5); + + InputStream sslIS = sslSocket.getInputStream(); + OutputStream sslOS = sslSocket.getOutputStream(); + + sslOS.write('B'); + sslOS.flush(); + sslIS.read(); + + throw new Exception("EC curve secp224k1 should be disabled"); + } catch (SSLHandshakeException she) { + // expected exception: Received fatal alert + System.out.println("Expected exception: " + she); + } finally { + sslSocket.close(); + } + } + + /* + * ============================================================= + * The remainder is just support stuff + */ + private static String tmAlgorithm; // trust manager + + private static void parseArguments(String[] args) { + tmAlgorithm = args[0]; + } + + private static SSLContext generateSSLContext(boolean isClient) + throws Exception { + + // generate certificate from cert string + CertificateFactory cf = CertificateFactory.getInstance("X.509"); + + // create a key store + KeyStore ks = KeyStore.getInstance("JKS"); + ks.load(null, null); + + // import the trused cert + ByteArrayInputStream is = + new ByteArrayInputStream(trustedCertStr.getBytes()); + Certificate trusedCert = cf.generateCertificate(is); + is.close(); + + ks.setCertificateEntry("Export Signer", trusedCert); + + String[] certStrs = null; + String[] keyStrs = null; + if (isClient) { + certStrs = clientCerts; + keyStrs = clientKeys; + } else { + certStrs = serverCerts; + keyStrs = serverKeys; + } + + for (int i = 0; i < certStrs.length; i++) { + // generate the private key. + String keySpecStr = keyStrs[i]; + PKCS8EncodedKeySpec priKeySpec = new PKCS8EncodedKeySpec( + Base64.getMimeDecoder().decode(keySpecStr)); + KeyFactory kf = KeyFactory.getInstance("EC"); + ECPrivateKey priKey = + (ECPrivateKey)kf.generatePrivate(priKeySpec); + + // generate certificate chain + String keyCertStr = certStrs[i]; + is = new ByteArrayInputStream(keyCertStr.getBytes()); + Certificate keyCert = cf.generateCertificate(is); + is.close(); + + Certificate[] chain = new Certificate[2]; + chain[0] = keyCert; + chain[1] = trusedCert; + + // import the key entry. + ks.setKeyEntry("key-entry-" + i, priKey, passphrase, chain); + } + + // create SSL context + TrustManagerFactory tmf = TrustManagerFactory.getInstance(tmAlgorithm); + tmf.init(ks); + + SSLContext ctx = SSLContext.getInstance("TLS"); + KeyManagerFactory kmf = KeyManagerFactory.getInstance("NewSunX509"); + kmf.init(ks, passphrase); + + ctx.init(kmf.getKeyManagers(), tmf.getTrustManagers(), null); + ks = null; + + return ctx; + } + + // use any free port by default + volatile int serverPort = 0; + + volatile Exception serverException = null; + volatile Exception clientException = null; + + public static void main(String[] args) throws Exception { + if (debug) { + System.setProperty("javax.net.debug", "all"); + } + + /* + * Get the customized arguments. + */ + parseArguments(args); + + /* + * Start the tests. + */ + new ECCurvesconstraints(); + } + + Thread clientThread = null; + Thread serverThread = null; + + /* + * Primary constructor, used to drive remainder of the test. + * + * Fork off the other side, then do your work. + */ + ECCurvesconstraints() throws Exception { + try { + if (separateServerThread) { + startServer(true); + startClient(false); + } else { + startClient(true); + startServer(false); + } + } catch (Exception e) { + // swallow for now. Show later + } + + /* + * Wait for other side to close down. + */ + if (separateServerThread) { + serverThread.join(); + } else { + clientThread.join(); + } + + /* + * When we get here, the test is pretty much over. + * Which side threw the error? + */ + Exception local; + Exception remote; + String whichRemote; + + if (separateServerThread) { + remote = serverException; + local = clientException; + whichRemote = "server"; + } else { + remote = clientException; + local = serverException; + whichRemote = "client"; + } + + /* + * If both failed, return the curthread's exception, but also + * print the remote side Exception + */ + if ((local != null) && (remote != null)) { + System.out.println(whichRemote + " also threw:"); + remote.printStackTrace(); + System.out.println(); + throw local; + } + + if (remote != null) { + throw remote; + } + + if (local != null) { + throw local; + } + } + + void startServer(boolean newThread) throws Exception { + if (newThread) { + serverThread = new Thread() { + public void run() { + try { + doServerSide(); + } catch (Exception e) { + /* + * Our server thread just died. + * + * Release the client, if not active already... + */ + System.err.println("Server died, because of " + e); + serverReady = true; + serverException = e; + } + } + }; + serverThread.start(); + } else { + try { + doServerSide(); + } catch (Exception e) { + serverException = e; + } finally { + serverReady = true; + } + } + } + + void startClient(boolean newThread) throws Exception { + if (newThread) { + clientThread = new Thread() { + public void run() { + try { + doClientSide(); + } catch (Exception e) { + /* + * Our client thread just died. + */ + System.err.println("Client died, because of " + e); + clientException = e; + } + } + }; + clientThread.start(); + } else { + try { + doClientSide(); + } catch (Exception e) { + clientException = e; + } + } + } +} diff --git a/jdk/test/javax/net/ssl/templates/SSLSocketSSLEngineTemplate.java b/jdk/test/javax/net/ssl/templates/SSLSocketSSLEngineTemplate.java index 091ed4d1e5e..ed74e10f640 100644 --- a/jdk/test/javax/net/ssl/templates/SSLSocketSSLEngineTemplate.java +++ b/jdk/test/javax/net/ssl/templates/SSLSocketSSLEngineTemplate.java @@ -31,7 +31,6 @@ * @bug 7105780 * @summary Add SSLSocket client/SSLEngine server to templates directory. * @run main/othervm SSLSocketSSLEngineTemplate - * @key intermittent */ /** diff --git a/jdk/test/javax/swing/JColorChooser/Test8152419.java b/jdk/test/javax/swing/JColorChooser/Test8152419.java new file mode 100644 index 00000000000..65615acbdee --- /dev/null +++ b/jdk/test/javax/swing/JColorChooser/Test8152419.java @@ -0,0 +1,170 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + + /* +* @test +* @bug 8152419 +* @summary To Verify JColorChooser tab selection +* @run main/manual Test8152419 + */ + +import java.awt.Color; +import java.awt.GridBagConstraints; +import java.awt.GridBagLayout; +import java.awt.event.ActionEvent; +import java.awt.event.ActionListener; +import java.util.concurrent.CountDownLatch; +import javax.swing.JButton; +import javax.swing.JColorChooser; +import javax.swing.JFrame; +import javax.swing.JPanel; +import javax.swing.JTextArea; +import javax.swing.SwingUtilities; +import javax.swing.UIManager; +import javax.swing.border.EmptyBorder; + +public class Test8152419 { + + public static void main(String args[]) throws Exception { + final CountDownLatch latch = new CountDownLatch(1); + + JColorChooserTest test = new JColorChooserTest(latch); + Thread T1 = new Thread(test); + T1.start(); + + // wait for latch to complete + try { + latch.await(); + } catch (InterruptedException ie) { + throw ie; + } + + if (test.testResult == false) { + throw new RuntimeException("User Clicked Fail!"); + } + } +} + +class JColorChooserTest implements Runnable { + + private static GridBagLayout layout; + private static JPanel mainControlPanel; + private static JPanel resultButtonPanel; + private static JTextArea instructionTextArea; + private static JButton passButton; + private static JButton failButton; + private static JFrame mainFrame; + private static JColorChooser colorChooser; + private final CountDownLatch latch; + public volatile boolean testResult = false; + + public JColorChooserTest(CountDownLatch latch) throws Exception { + this.latch = latch; + } + + @Override + public void run() { + + try { + createUI(); + } catch (Exception ex) { + if (mainFrame != null) { + mainFrame.dispose(); + } + latch.countDown(); + throw new RuntimeException("createUI Failed: " + ex.getMessage()); + } + + } + + public final void createUI() throws Exception { + + SwingUtilities.invokeAndWait(new Runnable() { + @Override + public void run() { + mainFrame = new JFrame("JColorChooser Test"); + layout = new GridBagLayout(); + mainControlPanel = new JPanel(layout); + resultButtonPanel = new JPanel(layout); + + GridBagConstraints gbc = new GridBagConstraints(); + String instructions + = "INSTRUCTIONS:" + + "\n Select HSV, HSL, RGB or CMYK tab." + + "\n If able to shift and view JColorChooser tabs" + + "\n then click Pass, else Fail."; + + instructionTextArea = new JTextArea(); + instructionTextArea.setText(instructions); + instructionTextArea.setEnabled(true); + + gbc.gridx = 0; + gbc.gridy = 0; + gbc.fill = GridBagConstraints.HORIZONTAL; + mainControlPanel.add(instructionTextArea, gbc); + + UIManager.put("FormattedTextField.border", + new EmptyBorder(0, 10, 0, 10)); + colorChooser = new JColorChooser(Color.BLUE); + gbc.gridx = 0; + gbc.gridy = 1; + mainControlPanel.add(colorChooser, gbc); + + passButton = new JButton("Pass"); + passButton.setActionCommand("Pass"); + passButton.addActionListener((ActionEvent e) -> { + testResult = true; + mainFrame.dispose(); + latch.countDown(); + + }); + failButton = new JButton("Fail"); + failButton.setActionCommand("Fail"); + failButton.addActionListener(new ActionListener() { + @Override + public void actionPerformed(ActionEvent e) { + testResult = false; + mainFrame.dispose(); + latch.countDown(); + } + }); + gbc.gridx = 0; + gbc.gridy = 0; + resultButtonPanel.add(passButton, gbc); + gbc.gridx = 1; + gbc.gridy = 0; + resultButtonPanel.add(failButton, gbc); + + gbc.gridx = 0; + gbc.gridy = 2; + mainControlPanel.add(resultButtonPanel, gbc); + + mainFrame.add(mainControlPanel); + mainFrame.pack(); + mainFrame.setVisible(true); + } + }); + + } +} + diff --git a/jdk/test/javax/swing/JComboBox/8041909/ActionListenerExceptionTest.java b/jdk/test/javax/swing/JComboBox/8041909/ActionListenerExceptionTest.java new file mode 100644 index 00000000000..c7ea83f3b02 --- /dev/null +++ b/jdk/test/javax/swing/JComboBox/8041909/ActionListenerExceptionTest.java @@ -0,0 +1,178 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + + /* @test + * @bug 8041909 + * @summary Test to check JComboBox does not lose its ability to invoke + * registerd ActionListener in case of exception in ActionListener + * @run main ActionListenerExceptionTest + */ + +import java.awt.AWTEvent; +import java.awt.AWTException; +import java.awt.Dimension; +import java.awt.EventQueue; +import java.awt.Point; +import java.awt.Robot; +import java.awt.Toolkit; +import java.awt.event.ActionEvent; +import java.awt.event.ActionListener; +import java.awt.event.InputEvent; +import java.util.logging.Level; +import java.util.logging.Logger; +import javax.swing.JComboBox; +import javax.swing.JComponent; +import javax.swing.JFrame; +import javax.swing.JPopupMenu; +import javax.swing.SwingUtilities; + +public class ActionListenerExceptionTest { + + static final int TOTAL_MENU_ITEMS = 3; + private volatile int count = 0; + private JFrame frame; + private JComboBox combo; + + private int menuItemHeight = 0; + private int yPos = 0; + private Point cbPos = null; + private Dimension cbSize = null; + + + public static void main(String[] args) throws Exception { + + // See EvenQueueProxy class description below. + EventQueue queue = Toolkit.getDefaultToolkit().getSystemEventQueue(); + queue.push(new EventQueueProxy()); + + ActionListenerExceptionTest testObject = new ActionListenerExceptionTest(); + + testObject.createGUI(); + + testObject.test(); + + testObject.disposeGUI(); + + if (testObject.getCount() != TOTAL_MENU_ITEMS) { + throw new RuntimeException("ActionListener is not invoked expected number of times"); + } + } + + private void createGUI() throws Exception { + SwingUtilities.invokeAndWait(new Runnable() { + public void run() { + frame = new JFrame(); + frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + + combo = new JComboBox(new String[]{"One", "Two", "Three"}); + combo.addActionListener(new ActionListener() { + + @Override + public void actionPerformed(ActionEvent e) { + count++; + throw new RuntimeException(); + } + }); + combo.setSize(200, 20); + frame.add(combo); + frame.pack(); + frame.setLocationRelativeTo(null); + frame.setVisible(true); + + } + }); + } + + private void disposeGUI() throws Exception { + SwingUtilities.invokeAndWait(new Runnable() { + public void run() { + frame.dispose(); + } + }); + } + + private void test() throws Exception { + Robot testRobot = new Robot(); + testRobot.delay(200); // delay to make test frame visible on screen + + SwingUtilities.invokeAndWait(new Runnable() { + public void run() { + cbPos = combo.getLocationOnScreen(); + cbSize = combo.getSize(); + } + }); + + Point center = new Point((cbPos.x + cbSize.width / 2), (cbPos.y + cbSize.height - 5)); + testRobot.mouseMove(center.x, center.y); + testRobot.delay(100); + + testRobot.mousePress(InputEvent.BUTTON1_DOWN_MASK); + testRobot.mouseRelease(InputEvent.BUTTON1_DOWN_MASK); + testRobot.delay(500); // delay to make popup visible + + SwingUtilities.invokeAndWait(new Runnable() { + public void run() { + Object comp = combo.getUI().getAccessibleChild(combo, 0); + JComponent scrollPane = (JComponent) ((JPopupMenu) comp).getComponent(0); + + menuItemHeight = scrollPane.getSize().height / TOTAL_MENU_ITEMS; + yPos = scrollPane.getLocationOnScreen().y + menuItemHeight / 2; + } + }); + + for (int i = 0; i < TOTAL_MENU_ITEMS; i++) { + + testRobot.mouseMove(center.x, yPos); + + testRobot.mousePress(InputEvent.BUTTON1_DOWN_MASK); + testRobot.delay(100); + testRobot.mouseRelease(InputEvent.BUTTON1_DOWN_MASK); + testRobot.delay(200); + + yPos += menuItemHeight; + } + + } + + private int getCount() { + return count; + } +} + +// Proxy class to invoke dispatchEvent and catch exceptions +// +// This is needed in order to test Exceptions from ActionListener +// Without this, jtreg reports test failure at first exception from ActionListener and +// we cannot test whether ActionListener is invoked again +class EventQueueProxy extends EventQueue { + + protected void dispatchEvent(AWTEvent evt) { + try { + super.dispatchEvent(evt); + } catch (Exception e) { + System.out.println("Intentionally consumed Exception from ActionListener"); + e.printStackTrace(); + } + } +} + diff --git a/jdk/test/javax/swing/JEditorPane/8158734/bug8158734.java b/jdk/test/javax/swing/JEditorPane/8158734/bug8158734.java new file mode 100644 index 00000000000..3514303f9c3 --- /dev/null +++ b/jdk/test/javax/swing/JEditorPane/8158734/bug8158734.java @@ -0,0 +1,115 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* @test + @bug 8158734 + @summary JEditorPane.createEditorKitForContentType throws NPE after 6882559 + @author Mikhail Cherkasov + @run main bug8158734 +*/ + +import javax.swing.*; +import javax.swing.text.*; +import java.io.*; +import java.lang.reflect.InvocationTargetException; + + +public class bug8158734 { + + public static final String TYPE = "test/test"; + public static final String TYPE_2 = "test2/test2"; + + static boolean myClassloaderWasUsed = false; + + static class MyEditorKit extends EditorKit { + @Override + public String getContentType() { + return null; + } + + @Override + public ViewFactory getViewFactory() { + return null; + } + + @Override + public Action[] getActions() { + return new Action[0]; + } + + @Override + public Caret createCaret() { + return null; + } + + @Override + public Document createDefaultDocument() { + return null; + } + + @Override + public void read(InputStream in, Document doc, int pos) throws IOException, BadLocationException { + } + + @Override + public void write(OutputStream out, Document doc, int pos, int len) throws IOException, BadLocationException { + + } + + @Override + public void read(Reader in, Document doc, int pos) throws IOException, BadLocationException { + } + + @Override + public void write(Writer out, Document doc, int pos, int len) throws IOException, BadLocationException { + } + } + + static class MyClassloader extends ClassLoader { + @Override + public Class loadClass(String name) throws ClassNotFoundException { + myClassloaderWasUsed = true; + return super.loadClass(name); + } + } + + public static void main(String[] args) throws InvocationTargetException, InterruptedException { + SwingUtilities.invokeAndWait(new Runnable() { + @Override + public void run() { + JEditorPane c = new JEditorPane(); + c.setContentType(TYPE); + + final MyClassloader loader = new MyClassloader(); + JEditorPane.registerEditorKitForContentType(TYPE_2, MyEditorKit.class.getName(), loader); + JEditorPane.registerEditorKitForContentType(TYPE_2, MyEditorKit.class.getName(), null); + JEditorPane.createEditorKitForContentType(TYPE_2); + + if (myClassloaderWasUsed) { + throw new RuntimeException("Class loader has not been removed for '" + TYPE_2 + "' type"); + } + } + }); + + } +} \ No newline at end of file diff --git a/jdk/test/javax/swing/JInternalFrame/8160248/JInternalFrameDraggingTest.java b/jdk/test/javax/swing/JInternalFrame/8160248/JInternalFrameDraggingTest.java new file mode 100644 index 00000000000..24d9fc09301 --- /dev/null +++ b/jdk/test/javax/swing/JInternalFrame/8160248/JInternalFrameDraggingTest.java @@ -0,0 +1,136 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +import java.awt.BorderLayout; +import java.awt.Color; +import java.awt.Point; +import java.awt.Rectangle; +import java.awt.Robot; +import java.awt.event.InputEvent; +import java.awt.image.BufferedImage; +import javax.swing.JDesktopPane; +import javax.swing.JFrame; +import javax.swing.JInternalFrame; +import javax.swing.SwingUtilities; + +/** + * @test + * @bug 8160248 8160332 + * @summary Dragged internal frame leaves artifacts for floating point ui scale + * @run main/othervm -Dsun.java2d.uiScale=1.2 JInternalFrameDraggingTest + * @run main/othervm -Dsun.java2d.uiScale=1.5 JInternalFrameDraggingTest + * @run main/othervm -Dsun.java2d.uiScale=1 JInternalFrameDraggingTest + * @run main/othervm -Dsun.java2d.uiScale=2.5 JInternalFrameDraggingTest + */ +public class JInternalFrameDraggingTest { + + private static JFrame frame; + private static JDesktopPane desktopPane; + private static JInternalFrame internalFrame; + private static int FRAME_SIZE = 500; + private static Color BACKGROUND_COLOR = Color.ORANGE; + + public static void main(String[] args) throws Exception { + + Robot robot = new Robot(); + robot.setAutoDelay(20); + SwingUtilities.invokeAndWait(JInternalFrameDraggingTest::createAndShowGUI); + robot.waitForIdle(); + + final int translate = FRAME_SIZE / 4; + moveFrame(robot, translate, translate / 2, translate / 2); + robot.waitForIdle(); + + Point p = getDesktopPaneLocation(); + int size = translate / 2; + Rectangle rect = new Rectangle(p.x, p.y, size, size); + BufferedImage img = robot.createScreenCapture(rect); + + int testRGB = BACKGROUND_COLOR.getRGB(); + for (int i = 0; i < size; i++) { + int rgbCW = img.getRGB(i, size / 2); + int rgbCH = img.getRGB(size / 2, i); + if (rgbCW != testRGB || rgbCH != testRGB) { + throw new RuntimeException("Background color is wrong!"); + } + } + } + + private static void createAndShowGUI() { + + frame = new JFrame(); + frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + frame.setLayout(new BorderLayout()); + + desktopPane = new JDesktopPane(); + desktopPane.setBackground(BACKGROUND_COLOR); + + frame.add(desktopPane, BorderLayout.CENTER); + frame.setSize(FRAME_SIZE, FRAME_SIZE); + frame.setVisible(true); + + internalFrame = new JInternalFrame("Test"); + internalFrame.setSize(FRAME_SIZE / 2, FRAME_SIZE / 2); + desktopPane.add(internalFrame); + internalFrame.setVisible(true); + internalFrame.setResizable(true); + + frame.setVisible(true); + } + + private static void moveFrame(Robot robot, int w, int h, int N) throws Exception { + Point p = getInternalFrameLocation(); + int xs = p.x + 100; + int ys = p.y + 15; + robot.mouseMove(xs, ys); + try { + robot.mousePress(InputEvent.BUTTON1_MASK); + + int dx = w / N; + int dy = h / N; + + int y = ys; + for (int x = xs; x < xs + w; x += dx, y += dy) { + robot.mouseMove(x, y); + } + } finally { + robot.mouseRelease(InputEvent.BUTTON1_MASK); + } + } + + private static Point getInternalFrameLocation() throws Exception { + final Point[] points = new Point[1]; + SwingUtilities.invokeAndWait(() -> { + points[0] = internalFrame.getLocationOnScreen(); + }); + return points[0]; + } + + private static Point getDesktopPaneLocation() throws Exception { + final Point[] points = new Point[1]; + SwingUtilities.invokeAndWait(() -> { + points[0] = desktopPane.getLocationOnScreen(); + }); + return points[0]; + } +} diff --git a/jdk/test/javax/swing/JInternalFrame/Test6325652.java b/jdk/test/javax/swing/JInternalFrame/Test6325652.java index 1191b42175c..bcd2f4d20ae 100644 --- a/jdk/test/javax/swing/JInternalFrame/Test6325652.java +++ b/jdk/test/javax/swing/JInternalFrame/Test6325652.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2009,2016 Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,9 +23,8 @@ /* * @test - * @bug 6325652 + * @bug 6325652 8159152 * @summary Tests keyboard shortcuts - * @author Sergey Malenkov * @library .. */ diff --git a/jdk/test/javax/swing/JMenuItem/8152981/MenuItemIconTest.java b/jdk/test/javax/swing/JMenuItem/8152981/MenuItemIconTest.java index 1a872a5ee85..451da3cec4c 100644 --- a/jdk/test/javax/swing/JMenuItem/8152981/MenuItemIconTest.java +++ b/jdk/test/javax/swing/JMenuItem/8152981/MenuItemIconTest.java @@ -23,7 +23,7 @@ /* * @test - * @bug 8152981 + * @bug 8152981 8159135 * @summary Double icons with JMenuItem setHorizontalTextPosition on Win 10 * @requires (os.family == "windows") * @run main MenuItemIconTest @@ -89,7 +89,7 @@ public class MenuItemIconTest { robot.delay(2000); robot.mouseMove(x, y); Color c = robot.getPixelColor(x, y); - if (c.getRed() == 255) { + if (Color.RED.equals(c)) { errorMessage = "Test Failed"; } robot.delay(5000); diff --git a/jdk/test/javax/swing/JMenuItem/8158566/CloseOnMouseClickPropertyTest.java b/jdk/test/javax/swing/JMenuItem/8158566/CloseOnMouseClickPropertyTest.java new file mode 100644 index 00000000000..5846371fa35 --- /dev/null +++ b/jdk/test/javax/swing/JMenuItem/8158566/CloseOnMouseClickPropertyTest.java @@ -0,0 +1,160 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +import java.awt.Point; +import java.awt.Rectangle; +import java.awt.Robot; +import java.awt.event.InputEvent; +import javax.swing.JCheckBoxMenuItem; +import javax.swing.JComponent; +import javax.swing.JFrame; +import javax.swing.JMenu; +import javax.swing.JMenuBar; +import javax.swing.JMenuItem; +import javax.swing.JRadioButtonMenuItem; +import javax.swing.SwingUtilities; +import javax.swing.UIManager; + +/* + * @test + * @bug 8158566 8160879 8160977 + * @summary Provide a Swing property which modifies MenuItemUI behaviour + */ +public class CloseOnMouseClickPropertyTest { + + private static JFrame frame; + private static JMenu menu; + + public static void main(String[] args) throws Exception { + + for (UIManager.LookAndFeelInfo info : UIManager.getInstalledLookAndFeels()) { + UIManager.setLookAndFeel(info.getClassName()); + test(true); + + setProperty(false); + test(false); + + setProperty(true); + test(true); + } + } + + private static void setProperty(boolean closeOnMouseClick) { + UIManager.put("CheckBoxMenuItem.closeOnMouseClick", closeOnMouseClick); + UIManager.put("RadioButtonMenuItem.closeOnMouseClick", closeOnMouseClick); + } + + private static void test(boolean closeOnMouseClick) throws Exception { + for (TestType testType : TestType.values()) { + test(testType, closeOnMouseClick); + } + } + + private static void test(TestType testType, boolean closeOnMouseClick) + throws Exception { + + Robot robot = new Robot(); + robot.setAutoDelay(50); + SwingUtilities.invokeAndWait(() -> createAndShowGUI(testType)); + robot.waitForIdle(); + + Point point = getClickPoint(true); + robot.mouseMove(point.x, point.y); + robot.mousePress(InputEvent.BUTTON1_MASK); + robot.mouseRelease(InputEvent.BUTTON1_MASK); + robot.waitForIdle(); + + point = getClickPoint(false); + robot.mouseMove(point.x, point.y); + robot.mousePress(InputEvent.BUTTON1_MASK); + robot.mouseRelease(InputEvent.BUTTON1_MASK); + robot.waitForIdle(); + + SwingUtilities.invokeAndWait(() -> { + JMenuItem menuItem = menu.getItem(0); + boolean isShowing = menuItem.isShowing(); + frame.dispose(); + + if (TestType.MENU_ITEM.equals(testType)) { + if (isShowing) { + throw new RuntimeException("Menu Item is not closed!"); + } + } else { + if (isShowing ^ !closeOnMouseClick) { + throw new RuntimeException("Property is not taken into account:" + + " closeOnMouseClick"); + } + } + }); + } + + private static void createAndShowGUI(TestType testType) { + + frame = new JFrame(); + frame.setSize(300, 300); + frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + + JMenuBar menuBar = new JMenuBar(); + menu = new JMenu("Menu"); + menu.add(getMenuItem(testType)); + menuBar.add(menu); + frame.setJMenuBar(menuBar); + frame.setVisible(true); + } + + private static JMenuItem getMenuItem(TestType testType) { + switch (testType) { + case CHECK_BOX_MENU_ITEM: + return new JCheckBoxMenuItem("Check Box"); + case RADIO_BUTTON_MENU_ITEM: + return new JRadioButtonMenuItem("Radio Button"); + default: + return new JMenuItem("Menu Item"); + } + } + + private static Point getClickPoint(boolean parent) throws Exception { + Point points[] = new Point[1]; + + SwingUtilities.invokeAndWait(() -> { + + JComponent comp = parent ? menu : menu.getItem(0); + + Point point = comp.getLocationOnScreen(); + Rectangle bounds = comp.getBounds(); + point.x += bounds.getWidth() / 2; + point.y += bounds.getHeight() / 2; + + points[0] = point; + }); + + return points[0]; + } + + enum TestType { + + MENU_ITEM, + CHECK_BOX_MENU_ITEM, + RADIO_BUTTON_MENU_ITEM + } +} diff --git a/jdk/test/javax/swing/JTable/LostTextTest.java b/jdk/test/javax/swing/JTable/LostTextTest.java new file mode 100644 index 00000000000..50613d7ccd3 --- /dev/null +++ b/jdk/test/javax/swing/JTable/LostTextTest.java @@ -0,0 +1,174 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +/* + * @test + * @bug 8159068 + * @summary Verifies if Jtable rendering is ok. + * @run main/manual LostTextTest + */ +import java.awt.BorderLayout; +import java.awt.Component; +import java.awt.FlowLayout; +import java.util.concurrent.CountDownLatch; +import java.util.concurrent.TimeUnit; +import javax.swing.JButton; +import javax.swing.JDialog; +import javax.swing.JFrame; +import javax.swing.JPanel; +import javax.swing.JTable; +import javax.swing.JTextArea; +import javax.swing.SwingUtilities; +import javax.swing.table.DefaultTableModel; +import javax.swing.table.TableModel; + +public class LostTextTest { + + static DefaultTableModel model; + + public static void main(String[] args) throws Exception { + final CountDownLatch latch = new CountDownLatch(1); + + LostText test = new LostText(latch); + Thread T1 = new Thread(test); + T1.start(); + + // wait for latch to complete + boolean ret = false; + try { + ret = latch.await(30, TimeUnit.SECONDS); + } catch (InterruptedException ie) { + throw ie; + } + if (!ret) { + test.dispose(); + throw new RuntimeException(" User has not executed the test"); + } + + if (test.testResult == false) { + throw new RuntimeException("Some text were not rendered properly" + + " during painting of Jtable rows "); + } + } +} + +class LostText implements Runnable { + static JFrame f; + static JDialog dialog; + static DefaultTableModel model; + public boolean testResult = false; + private final CountDownLatch latch; + + public LostText(CountDownLatch latch) throws Exception { + this.latch = latch; + } + + @Override + public void run() { + try { + createUI(); + lostTextTest(); + } catch (Exception ex) { + if (f != null) { + f.dispose(); + } + latch.countDown(); + throw new RuntimeException("createUI Failed: " + ex.getMessage()); + } + + } + + public void dispose() { + dialog.dispose(); + f.dispose(); + } + + private static void lostTextTest() throws Exception { + SwingUtilities.invokeAndWait(new Runnable() { + @Override + public void run() { + f = new JFrame(); + f.add(getComp()); + f.setSize(300, 300); + f.setLocationRelativeTo(null); + f.setVisible(true); + } + + private Component getComp() { + JTable jTable = new JTable(testSelectionWithFilterTable()); + return jTable; + } + }); + } + + private static TableModel testSelectionWithFilterTable() { + model = new DefaultTableModel(0, 1); + int last = 10; + for (int i = 0; i <= last; i++) { + model.addRow(new Object[]{i}); + } + return model; + } + + private final void createUI() throws Exception { + SwingUtilities.invokeAndWait(new Runnable() { + @Override + public void run() { + + String description + = " INSTRUCTIONS:\n" + + " A JTable will be shown.\n" + + " Try to select different rows via mouse or keyboard.\n " + + " Please verify if text are painted properly.\n" + + " If any moment any part of the rows will not be\n " + + " painted properly and if some text are missing in JTable,\n " + + " then press fail else press pass"; + + dialog = new JDialog(); + dialog.setTitle("textselectionTest"); + JTextArea textArea = new JTextArea(description); + textArea.setEditable(false); + final JButton passButton = new JButton("PASS"); + passButton.addActionListener((e) -> { + testResult = true; + dispose(); + latch.countDown(); + }); + final JButton failButton = new JButton("FAIL"); + failButton.addActionListener((e) -> { + testResult = false; + dispose(); + latch.countDown(); + }); + JPanel mainPanel = new JPanel(new BorderLayout()); + mainPanel.add(textArea, BorderLayout.CENTER); + JPanel buttonPanel = new JPanel(new FlowLayout()); + buttonPanel.add(passButton); + buttonPanel.add(failButton); + mainPanel.add(buttonPanel, BorderLayout.SOUTH); + dialog.add(mainPanel); + dialog.pack(); + dialog.setVisible(true); + } + }); + } +} diff --git a/jdk/test/javax/swing/LookAndFeel/8145547/DemandGTK.java b/jdk/test/javax/swing/LookAndFeel/8145547/DemandGTK.java index 67ec62c88c6..6c4876245d2 100644 --- a/jdk/test/javax/swing/LookAndFeel/8145547/DemandGTK.java +++ b/jdk/test/javax/swing/LookAndFeel/8145547/DemandGTK.java @@ -27,7 +27,7 @@ regardless of jdk.gtk.version flag values. @bug 8156121 @key headful - @requires (os.name == "linux" | os.name == "solaris") + @requires (os.family == "linux" | os.family == "solaris") @run main/othervm -Djdk.gtk.version=2 DemandGTK @run main/othervm -Djdk.gtk.version=3 DemandGTK */ diff --git a/jdk/test/javax/swing/ProgressMonitor/ProgressMonitorEscapeKeyPress.java b/jdk/test/javax/swing/ProgressMonitor/ProgressMonitorEscapeKeyPress.java new file mode 100644 index 00000000000..1d96765ce2f --- /dev/null +++ b/jdk/test/javax/swing/ProgressMonitor/ProgressMonitorEscapeKeyPress.java @@ -0,0 +1,124 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* @test + * @bug 8065861 + * @summary Test to check pressing Escape key sets 'canceled' property of ProgressMonitor + * @run main ProgressMonitorEscapeKeyPress + */ + +import java.awt.AWTException; +import java.awt.EventQueue; +import java.awt.Robot; +import java.awt.event.KeyEvent; +import javax.swing.JFrame; +import javax.swing.ProgressMonitor; +import javax.swing.SwingUtilities; + +public class ProgressMonitorEscapeKeyPress { + + static ProgressMonitor monitor; + static int counter = 0; + static TestThread robotThread; + static JFrame frame; + + + public static void main(String[] args) throws Exception { + + createTestUI(); + + monitor = new ProgressMonitor(frame, "Progress", null, 0, 100); + + robotThread = new TestThread(); + robotThread.start(); + + for (counter = 0; counter <= 100; counter += 10) { + Thread.sleep(1000); + + EventQueue.invokeAndWait(new Runnable() { + @Override + public void run() { + if (!monitor.isCanceled()) { + monitor.setProgress(counter); + System.out.println("Progress bar is in progress"); + } + } + }); + + if (monitor.isCanceled()) { + break; + } + } + + disposeTestUI(); + + if (counter >= monitor.getMaximum()) { + throw new RuntimeException("Escape key did not cancel the ProgressMonitor"); + } + } + + private static void createTestUI() throws Exception { + SwingUtilities.invokeAndWait(new Runnable() { + @Override + public void run() { + frame = new JFrame("Test"); + frame.setSize(300, 300); + frame.setLocationByPlatform(true); + frame.setVisible(true); + }}); + } + + + private static void disposeTestUI() throws Exception { + SwingUtilities.invokeAndWait(() -> { + frame.dispose(); + }); + } +} + + +class TestThread extends Thread { + + Robot testRobot; + + TestThread() throws AWTException { + super(); + testRobot = new Robot(); + } + + @Override + public void run() { + try { + // Sleep for 5 seconds - so that the ProgressMonitor starts + Thread.sleep(5000); + + // Press and release Escape key + testRobot.keyPress(KeyEvent.VK_ESCAPE); + testRobot.delay(20); + testRobot.keyRelease(KeyEvent.VK_ESCAPE); + } catch (InterruptedException ex) { + throw new RuntimeException("Exception in TestThread"); + } + } +} + diff --git a/jdk/test/javax/swing/plaf/basic/BasicComboPopup/8154069/Bug8154069.java b/jdk/test/javax/swing/plaf/basic/BasicComboPopup/8154069/Bug8154069.java new file mode 100644 index 00000000000..35250a58705 --- /dev/null +++ b/jdk/test/javax/swing/plaf/basic/BasicComboPopup/8154069/Bug8154069.java @@ -0,0 +1,97 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @bug 8154069 + * @summary Jaws reads wrong values from comboboxes when no element is selected + * @run main Bug8154069 + */ + +import javax.accessibility.Accessible; +import javax.accessibility.AccessibleContext; +import javax.accessibility.AccessibleSelection; +import javax.swing.JComboBox; +import javax.swing.JFrame; +import javax.swing.SwingUtilities; +import javax.swing.UIManager; +import javax.swing.plaf.nimbus.NimbusLookAndFeel; + +public class Bug8154069 { + + private static JFrame frame; + private static volatile Exception exception = null; + + public static void main(String args[]) throws Exception { + try { + try { + UIManager.setLookAndFeel(new NimbusLookAndFeel()); + } catch (Exception e) { + throw new RuntimeException(e); + } + + SwingUtilities.invokeAndWait(() -> { + frame = new JFrame(); + String[] petStrings = { "Bird", "Cat" }; + JComboBox cb = new JComboBox<>(petStrings); + cb.setSelectedIndex(1); // select Cat + frame.add(cb); + frame.pack(); + try { + cb.setSelectedIndex(-1); + int i = cb.getSelectedIndex(); + if (i != -1) { + throw new RuntimeException("getSelectedIndex is not -1"); + } + Object o = cb.getSelectedItem(); + if (o != null) { + throw new RuntimeException("getSelectedItem is not null"); + } + AccessibleContext ac = cb.getAccessibleContext(); + AccessibleSelection as = ac.getAccessibleSelection(); + int count = as.getAccessibleSelectionCount(); + if (count != 0) { + throw new RuntimeException("getAccessibleSelection count is not 0"); + } + Accessible a = as.getAccessibleSelection(0); + if (a != null) { + throw new RuntimeException("getAccessibleSelection(0) is not null"); + } + } catch (Exception e) { + exception = e; + } + }); + if (exception != null) { + System.out.println("Test failed: " + exception.getMessage()); + throw exception; + } else { + System.out.println("Test passed."); + } + } finally { + SwingUtilities.invokeAndWait(() -> { + frame.dispose(); + }); + } + } + +} diff --git a/jdk/test/javax/swing/plaf/nimbus/8057791/bug8057791.java b/jdk/test/javax/swing/plaf/nimbus/8057791/bug8057791.java new file mode 100644 index 00000000000..cc31544abc6 --- /dev/null +++ b/jdk/test/javax/swing/plaf/nimbus/8057791/bug8057791.java @@ -0,0 +1,100 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* @test + @bug 8057791 + @summary Selection in JList is drawn with wrong colors in Nimbus L&F + @author Anton Litvinov + @run main bug8057791 + */ + +import java.awt.Color; +import java.awt.Graphics; +import java.awt.Rectangle; +import java.awt.image.BufferedImage; +import java.lang.reflect.InvocationTargetException; +import java.util.HashSet; +import javax.swing.DefaultListModel; +import javax.swing.JList; +import javax.swing.SwingUtilities; +import javax.swing.UIManager; +import javax.swing.UnsupportedLookAndFeelException; +import javax.swing.plaf.nimbus.NimbusLookAndFeel; + +public class bug8057791 { + public static void main(String[] args) { + try { + UIManager.setLookAndFeel(new NimbusLookAndFeel()); + + SwingUtilities.invokeAndWait(new Runnable() { + @Override + public void run() { + final int listWidth = 50; + final int listHeight = 50; + final int selCellIndex = 0; + + JList list = new JList(); + list.setSize(listWidth, listHeight); + DefaultListModel listModel = new DefaultListModel(); + listModel.add(selCellIndex, "E"); + list.setModel(listModel); + list.setSelectedIndex(selCellIndex); + + BufferedImage img = new BufferedImage(listWidth, listHeight, + BufferedImage.TYPE_INT_ARGB); + Graphics g = img.getGraphics(); + list.paint(g); + g.dispose(); + + Rectangle cellRect = list.getCellBounds(selCellIndex, selCellIndex); + HashSet cellColors = new HashSet(); + int uniqueColorIndex = 0; + for (int x = cellRect.x; x < (cellRect.x + cellRect.width); x++) { + for (int y = cellRect.y; y < (cellRect.y + cellRect.height); y++) { + Color cellColor = new Color(img.getRGB(x, y), true); + if (cellColors.add(cellColor)) { + System.err.println(String.format("Cell color #%d: %s", + uniqueColorIndex++, cellColor)); + } + } + } + + Color selForegroundColor = list.getSelectionForeground(); + Color selBackgroundColor = list.getSelectionBackground(); + if (!cellColors.contains(new Color(selForegroundColor.getRGB(), true))) { + throw new RuntimeException(String.format( + "Selected cell is drawn without selection foreground color '%s'.", + selForegroundColor)); + } + if (!cellColors.contains(new Color(selBackgroundColor.getRGB(), true))) { + throw new RuntimeException(String.format( + "Selected cell is drawn without selection background color '%s'.", + selBackgroundColor)); + } + } + }); + } catch (UnsupportedLookAndFeelException | InterruptedException | InvocationTargetException e) { + throw new RuntimeException(e); + } + } +} diff --git a/jdk/test/javax/swing/text/Utilities/8142966/SwingFontMetricsTest.java b/jdk/test/javax/swing/text/Utilities/8142966/SwingFontMetricsTest.java new file mode 100644 index 00000000000..d7e8749c32e --- /dev/null +++ b/jdk/test/javax/swing/text/Utilities/8142966/SwingFontMetricsTest.java @@ -0,0 +1,73 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +import java.awt.Font; +import java.awt.Graphics; +import java.util.concurrent.CountDownLatch; +import java.util.concurrent.TimeUnit; +import javax.swing.JFrame; +import javax.swing.JLabel; +import javax.swing.SwingUtilities; + +/** + * @test + * @bug 8142966 + * @summary Wrong cursor position in text components on HiDPI display + * @run main/othervm -Dsun.java2d.uiScale=2 SwingFontMetricsTest + */ +public class SwingFontMetricsTest { + + private static final String LOWER_CASE_TEXT = "the quick brown fox jumps over the lazy dog"; + private static final String UPPER_CASE_TEXT = LOWER_CASE_TEXT.toUpperCase(); + private static final String TEXT = LOWER_CASE_TEXT + UPPER_CASE_TEXT; + private static boolean passed = false; + private static CountDownLatch latch = new CountDownLatch(1); + + public static void main(String[] args) throws Exception { + SwingUtilities.invokeAndWait(SwingFontMetricsTest::createAndShowGUI); + latch.await(5, TimeUnit.SECONDS); + + if (!passed) { + throw new RuntimeException("Test Failed!"); + } + } + + private static void createAndShowGUI() { + final JFrame frame = new JFrame(); + frame.setSize(300, 300); + frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + JLabel label = new JLabel(TEXT) { + @Override + public void paint(Graphics g) { + super.paint(g); + Font font = getFont(); + int width1 = getFontMetrics(font).stringWidth(TEXT); + int width2 = g.getFontMetrics(font).stringWidth(TEXT); + passed = (width1 == width2); + latch.countDown(); + frame.dispose(); + } + }; + frame.add(label); + frame.setVisible(true); + } +} diff --git a/jdk/test/sun/awt/shell/BadHiDPIIcon.java b/jdk/test/sun/awt/shell/BadHiDPIIcon.java new file mode 100644 index 00000000000..b0a276b3aa8 --- /dev/null +++ b/jdk/test/sun/awt/shell/BadHiDPIIcon.java @@ -0,0 +1,61 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @bug 8151385 + * @summary JOptionPane icons are cropped on Windows 10 with HiDPI display + * @author Hendrik Schreiber + * @requires os.family == "windows" + * @modules java.desktop/sun.awt.shell + * @run main BadHiDPIIcon + */ +import java.awt.Image; +import java.awt.image.BufferedImage; +import java.awt.image.MultiResolutionImage; +import sun.awt.shell.ShellFolder; + +public class BadHiDPIIcon { + + public static void main(String[] args) { + // the error icon is round and in all four corner transparent + // we check that all corners are identical + Image icon = (Image) ShellFolder.get("optionPaneIcon Error"); + final BufferedImage image = getBufferedImage(icon); + final int upperLeft = image.getRGB(0, 0); + final int upperRight = image.getRGB(image.getWidth() - 1, 0); + final int lowerLeft = image.getRGB(0, image.getHeight() - 1); + final int lowerRight = image.getRGB(image.getWidth() - 1, image.getHeight() - 1); + if (upperLeft != upperRight || upperLeft != lowerLeft || upperLeft != lowerRight) { + throw new RuntimeException("optionPaneIcon Error is not a round icon with transparent background."); + } + } + + private static BufferedImage getBufferedImage(Image image) { + if (image instanceof MultiResolutionImage) { + MultiResolutionImage mrImage = (MultiResolutionImage) image; + return (BufferedImage) mrImage.getResolutionVariant(32, 32); + } + return (BufferedImage) image; + } +} diff --git a/jdk/test/sun/security/ec/TestEC.java b/jdk/test/sun/security/ec/TestEC.java index 43599ab5af4..4b055706b19 100644 --- a/jdk/test/sun/security/ec/TestEC.java +++ b/jdk/test/sun/security/ec/TestEC.java @@ -36,7 +36,7 @@ * @library ../../../java/security/testlibrary * @modules jdk.crypto.pkcs11/sun.security.pkcs11.wrapper * @compile -XDignore.symbol.file TestEC.java - * @run main/othervm TestEC + * @run main/othervm -Djdk.tls.namedGroups="secp256r1,sect193r1" TestEC */ import java.security.NoSuchProviderException; diff --git a/jdk/test/sun/security/krb5/auto/KDC.java b/jdk/test/sun/security/krb5/auto/KDC.java index b426d3d45b9..e47c3e9e5c1 100644 --- a/jdk/test/sun/security/krb5/auto/KDC.java +++ b/jdk/test/sun/security/krb5/auto/KDC.java @@ -246,7 +246,7 @@ public class KDC { * @throws java.io.IOException for any socket creation error */ public static KDC create(String realm) throws IOException { - return create(realm, "kdc." + realm.toLowerCase(), 0, true); + return create(realm, "kdc." + realm.toLowerCase(Locale.US), 0, true); } public static KDC existing(String realm, String kdc, int port) { diff --git a/jdk/test/sun/security/krb5/auto/NewSalt.java b/jdk/test/sun/security/krb5/auto/NewSalt.java index 2a0a17fcd9f..6a2d0bafe76 100644 --- a/jdk/test/sun/security/krb5/auto/NewSalt.java +++ b/jdk/test/sun/security/krb5/auto/NewSalt.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,6 +30,7 @@ * @run main/othervm -Donlyonepreauth NewSalt */ +import java.util.Locale; import sun.security.jgss.GSSUtil; import sun.security.krb5.Config; @@ -51,9 +52,9 @@ public class NewSalt { } // Use a different case of name. KDC will return correct salt - Context c1 = Context.fromUserPass(OneKDC.USER.toUpperCase(), + Context c1 = Context.fromUserPass(OneKDC.USER.toUpperCase(Locale.US), OneKDC.PASS, true); - Context c2 = Context.fromUserPass(OneKDC.USER2.toUpperCase(), + Context c2 = Context.fromUserPass(OneKDC.USER2.toUpperCase(Locale.US), OneKDC.PASS2, true); c1.startAsClient(OneKDC.USER2, GSSUtil.GSS_KRB5_MECH_OID); diff --git a/jdk/test/sun/security/krb5/auto/OneKDC.java b/jdk/test/sun/security/krb5/auto/OneKDC.java index 75266289c37..6d7362ff4c5 100644 --- a/jdk/test/sun/security/krb5/auto/OneKDC.java +++ b/jdk/test/sun/security/krb5/auto/OneKDC.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,6 +25,7 @@ import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.security.Security; +import java.util.Locale; import javax.security.auth.callback.Callback; import javax.security.auth.callback.CallbackHandler; import javax.security.auth.callback.NameCallback; @@ -52,9 +53,10 @@ public class OneKDC extends KDC { public static final String KTAB = "localkdc.ktab"; public static final String JAAS_CONF = "localkdc-jaas.conf"; public static final String REALM = "RABBIT.HOLE"; - public static String SERVER = "server/host." + REALM.toLowerCase(); - public static String BACKEND = "backend/host." + REALM.toLowerCase(); - public static String KDCHOST = "kdc." + REALM.toLowerCase(); + public static final String REALM_LOWER_CASE = REALM.toLowerCase(Locale.US); + public static String SERVER = "server/host." + REALM_LOWER_CASE; + public static String BACKEND = "backend/host." + REALM_LOWER_CASE; + public static String KDCHOST = "kdc." + REALM_LOWER_CASE; /** * Creates the KDC and starts it. * @param etype Encryption type, null if not specified diff --git a/jdk/test/sun/security/krb5/auto/SSL.java b/jdk/test/sun/security/krb5/auto/SSL.java index 471f63c7e44..329a561659f 100644 --- a/jdk/test/sun/security/krb5/auto/SSL.java +++ b/jdk/test/sun/security/krb5/auto/SSL.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2009, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -78,7 +78,8 @@ public class SSL extends SecurityManager { ServicePermission p = (ServicePermission)perm; // ServicePermissions required to create GSSName are ignored if (!p.getActions().isEmpty()) { - permChecks = permChecks + p.getActions().toUpperCase().charAt(0); + permChecks = permChecks + + p.getActions().toUpperCase(Locale.US).charAt(0); } } @@ -94,7 +95,7 @@ public class SSL extends SecurityManager { System.setSecurityManager(new SSL()); KDC kdc = KDC.create(OneKDC.REALM); - server = "host." + OneKDC.REALM.toLowerCase(Locale.US); + server = "host." + OneKDC.REALM_LOWER_CASE; if (args.length > 2) { sniHostname = "test." + server; diff --git a/jdk/test/sun/security/krb5/auto/SaslBasic.java b/jdk/test/sun/security/krb5/auto/SaslBasic.java index 3fdd3534ed4..fccaf2b930a 100644 --- a/jdk/test/sun/security/krb5/auto/SaslBasic.java +++ b/jdk/test/sun/security/krb5/auto/SaslBasic.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -34,7 +34,6 @@ import com.sun.security.jgss.InquireType; import java.io.IOException; import java.util.Arrays; import java.util.HashMap; -import java.util.Locale; import javax.security.auth.callback.Callback; import javax.security.auth.callback.CallbackHandler; import javax.security.auth.callback.UnsupportedCallbackException; @@ -46,7 +45,7 @@ public class SaslBasic { public static void main(String[] args) throws Exception { boolean bound = args[0].equals("bound"); - String name = "host." + OneKDC.REALM.toLowerCase(Locale.US); + String name = "host." + OneKDC.REALM_LOWER_CASE; new OneKDC(null).writeJAASConf(); System.setProperty("javax.security.auth.useSubjectCredsOnly", "false"); diff --git a/jdk/test/sun/security/krb5/auto/SaslGSS.java b/jdk/test/sun/security/krb5/auto/SaslGSS.java index ec541935308..45fcdd4eb0a 100644 --- a/jdk/test/sun/security/krb5/auto/SaslGSS.java +++ b/jdk/test/sun/security/krb5/auto/SaslGSS.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -41,7 +41,6 @@ import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.PrintStream; import java.util.HashMap; -import java.util.Locale; import java.util.logging.ConsoleHandler; import java.util.logging.Handler; import java.util.logging.Level; @@ -54,7 +53,7 @@ public class SaslGSS { public static void main(String[] args) throws Exception { - String name = "host." + OneKDC.REALM.toLowerCase(Locale.US); + String name = "host." + OneKDC.REALM_LOWER_CASE; new OneKDC(null).writeJAASConf(); System.setProperty("javax.security.auth.useSubjectCredsOnly", "false"); diff --git a/jdk/test/sun/security/krb5/config/Semicolon.java b/jdk/test/sun/security/krb5/config/Semicolon.java new file mode 100644 index 00000000000..3eb3068786a --- /dev/null +++ b/jdk/test/sun/security/krb5/config/Semicolon.java @@ -0,0 +1,41 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @bug 8160518 + * @summary Semicolon is not recognized as comment starting character + * @modules java.security.jgss/sun.security.krb5 + * @run main/othervm Semicolon + */ + +import sun.security.krb5.Config; + +public class Semicolon { + public static void main(String[] args) throws Throwable { + System.setProperty("java.security.krb5.conf", + System.getProperty("test.src", ".") + "/comments.conf"); + Config config = Config.getInstance(); + config.getBooleanObject("section", "value"); + } +} diff --git a/jdk/test/sun/security/krb5/config/comments.conf b/jdk/test/sun/security/krb5/config/comments.conf new file mode 100644 index 00000000000..21879ded696 --- /dev/null +++ b/jdk/test/sun/security/krb5/config/comments.conf @@ -0,0 +1,12 @@ +[section] + +# comment + # comment + # comment + # comment +; comment + ; comment + ; comment + ; comment + +value = true diff --git a/jdk/test/sun/security/mscapi/SignUsingNONEwithRSA.java b/jdk/test/sun/security/mscapi/SignUsingNONEwithRSA.java index ec8c0c5f9e1..e5d3d44aa53 100644 --- a/jdk/test/sun/security/mscapi/SignUsingNONEwithRSA.java +++ b/jdk/test/sun/security/mscapi/SignUsingNONEwithRSA.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -21,12 +21,21 @@ * questions. */ -/** - * @see SignUsingNONEwithRSA.sh + /* + * @test + * @bug 6578658 + * @modules java.base/sun.security.x509 + * java.base/sun.security.tools.keytool + * @requires os.family == "windows" + * @summary Sign using the NONEwithRSA signature algorithm from SunMSCAPI */ import java.security.*; +import java.security.cert.X509Certificate; +import java.security.interfaces.RSAPrivateCrtKey; import java.util.*; +import sun.security.tools.keytool.CertAndKeyGen; +import sun.security.x509.X500Name; public class SignUsingNONEwithRSA { @@ -92,24 +101,42 @@ public class SignUsingNONEwithRSA { System.out.println(" " + provider.getName()); } } - System.out.println("-------------------------------------------------"); + System.out.println( + "Creating a temporary RSA keypair in the Windows-My store"); + KeyStore ks = KeyStore.getInstance("Windows-MY"); + ks.load(null, null); + CertAndKeyGen ckg = new CertAndKeyGen("RSA", "SHA1withRSA"); + ckg.generate(1024); + RSAPrivateCrtKey k = (RSAPrivateCrtKey) ckg.getPrivateKey(); + ks.setKeyEntry("6578658", k, null, new X509Certificate[]{ + ckg.getSelfCertificate(new X500Name("cn=6578658,c=US"), 1000) + }); + ks.store(null, null); - KeyPair keys = getKeysFromKeyStore(); - signAllUsing("SunMSCAPI", keys.getPrivate()); - System.out.println("-------------------------------------------------"); + System.out.println("---------------------------------------------"); - verifyAllUsing("SunMSCAPI", keys.getPublic()); - System.out.println("-------------------------------------------------"); + try { + KeyPair keys = getKeysFromKeyStore(); + signAllUsing("SunMSCAPI", keys.getPrivate()); + System.out.println("---------------------------------------------"); - verifyAllUsing("SunJCE", keys.getPublic()); - System.out.println("-------------------------------------------------"); + verifyAllUsing("SunMSCAPI", keys.getPublic()); + System.out.println("---------------------------------------------"); - keys = generateKeys(); - signAllUsing("SunJCE", keys.getPrivate()); - System.out.println("-------------------------------------------------"); + verifyAllUsing("SunJCE", keys.getPublic()); + System.out.println("---------------------------------------------"); - verifyAllUsing("SunMSCAPI", keys.getPublic()); - System.out.println("-------------------------------------------------"); + keys = generateKeys(); + signAllUsing("SunJCE", keys.getPrivate()); + System.out.println("---------------------------------------------"); + + verifyAllUsing("SunMSCAPI", keys.getPublic()); + System.out.println("---------------------------------------------"); + } finally { + System.out.println( + "Deleting temporary RSA keypair from Windows-My store"); + ks.deleteEntry("6578658"); + } } diff --git a/jdk/test/sun/security/mscapi/SignUsingNONEwithRSA.sh b/jdk/test/sun/security/mscapi/SignUsingNONEwithRSA.sh deleted file mode 100644 index cbd7629f73d..00000000000 --- a/jdk/test/sun/security/mscapi/SignUsingNONEwithRSA.sh +++ /dev/null @@ -1,85 +0,0 @@ -#!/bin/sh - -# -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - - -# @test -# @bug 6578658 -# @requires os.family == "windows" -# @run shell SignUsingNONEwithRSA.sh -# @summary Sign using the NONEwithRSA signature algorithm from SunMSCAPI -# @key intermittent - -# set a few environment variables so that the shell-script can run stand-alone -# in the source directory -if [ "${TESTSRC}" = "" ] ; then - TESTSRC="." -fi - -if [ "${TESTCLASSES}" = "" ] ; then - TESTCLASSES="." -fi - -if [ "${TESTJAVA}" = "" ] ; then - echo "TESTJAVA not set. Test cannot execute." - echo "FAILED!!!" - exit 1 -fi - -OS=`uname -s` -case "$OS" in - Windows* | CYGWIN* ) - - echo "Creating a temporary RSA keypair in the Windows-My store..." - ${TESTJAVA}/bin/keytool ${TESTTOOLVMOPTS} \ - -genkeypair \ - -storetype Windows-My \ - -keyalg RSA \ - -alias 6578658 \ - -dname "cn=6578658,c=US" \ - -noprompt - - echo - echo "Running the test..." - ${TESTJAVA}/bin/javac ${TESTTOOLVMOPTS} ${TESTJAVACOPTS} -d . ${TESTSRC}\\SignUsingNONEwithRSA.java - ${TESTJAVA}/bin/java ${TESTVMOPTS} SignUsingNONEwithRSA - - rc=$? - - echo - echo "Removing the temporary RSA keypair from the Windows-My store..." - ${TESTJAVA}/bin/keytool ${TESTTOOLVMOPTS} \ - -delete \ - -storetype Windows-My \ - -alias 6578658 - - echo done. - exit $rc - ;; - - * ) - echo "This test is not intended for '$OS' - passing test" - exit 0 - ;; -esac diff --git a/jdk/test/sun/security/pkcs11/sslecc/ClientJSSEServerJSSE.java b/jdk/test/sun/security/pkcs11/sslecc/ClientJSSEServerJSSE.java index 4a31b67c296..1fab350dc9d 100644 --- a/jdk/test/sun/security/pkcs11/sslecc/ClientJSSEServerJSSE.java +++ b/jdk/test/sun/security/pkcs11/sslecc/ClientJSSEServerJSSE.java @@ -33,8 +33,10 @@ * @author Andreas Sterbenz * @library .. * @library ../../../../java/security/testlibrary - * @run main/othervm ClientJSSEServerJSSE - * @run main/othervm ClientJSSEServerJSSE sm policy + * @run main/othervm -Djdk.tls.namedGroups="secp256r1,sect193r1" + * ClientJSSEServerJSSE + * @run main/othervm -Djdk.tls.namedGroups="secp256r1,sect193r1" + * ClientJSSEServerJSSE sm policy */ import java.security.Provider; diff --git a/jdk/test/sun/security/provider/NSASuiteB/TestDSAGenParameterSpec.java b/jdk/test/sun/security/provider/NSASuiteB/TestDSAGenParameterSpec.java index f2be9ed9ad8..0ba2a0c5d61 100644 --- a/jdk/test/sun/security/provider/NSASuiteB/TestDSAGenParameterSpec.java +++ b/jdk/test/sun/security/provider/NSASuiteB/TestDSAGenParameterSpec.java @@ -35,7 +35,6 @@ import java.security.spec.InvalidParameterSpecException; /* * @test * @bug 8075286 - * @key intermittent * @summary Verify that DSAGenParameterSpec can and can only be used to generate * DSA within some certain range of key sizes as described in the class * specification (L, N) as (1024, 160), (2048, 224), (2048, 256) and diff --git a/jdk/test/sun/security/tools/keytool/DefaultSignatureAlgorithm.java b/jdk/test/sun/security/tools/keytool/DefaultSignatureAlgorithm.java index ad6297f2b21..90cfad8898c 100644 --- a/jdk/test/sun/security/tools/keytool/DefaultSignatureAlgorithm.java +++ b/jdk/test/sun/security/tools/keytool/DefaultSignatureAlgorithm.java @@ -26,6 +26,17 @@ * @bug 8138766 * @summary New default -sigalg for keytool * @modules java.base/sun.security.tools.keytool + * @run main/othervm DefaultSignatureAlgorithm RSA 1024 SHA256withRSA + * @run main/othervm DefaultSignatureAlgorithm RSA 3072 SHA256withRSA + * @run main/othervm DefaultSignatureAlgorithm RSA 3073 SHA384withRSA + * @run main/othervm DefaultSignatureAlgorithm DSA 1024 SHA256withDSA + * @run main/othervm/timeout=700 DefaultSignatureAlgorithm DSA 3072 + * SHA256withDSA + * @run main/othervm DefaultSignatureAlgorithm EC 192 SHA256withECDSA + * @run main/othervm DefaultSignatureAlgorithm EC 384 SHA384withECDSA + * @run main/othervm DefaultSignatureAlgorithm EC 571 SHA512withECDSA + * @run main/othervm DefaultSignatureAlgorithm EC 571 SHA256withECDSA + * SHA256withECDSA */ import sun.security.tools.keytool.Main; @@ -36,29 +47,17 @@ import java.security.cert.X509Certificate; public class DefaultSignatureAlgorithm { - private static int counter = 0; - public static void main(String[] args) throws Exception { - - // Calculating large RSA keys are too slow. - run("RSA", 1024, null, "SHA256withRSA"); - run("RSA", 3072, null, "SHA256withRSA"); - run("RSA", 3073, null, "SHA384withRSA"); - - run("DSA", 1024, null, "SHA256withDSA"); - run("DSA", 3072, null, "SHA256withDSA"); - - run("EC", 192, null, "SHA256withECDSA"); - run("EC", 384, null, "SHA384withECDSA"); - run("EC", 571, null, "SHA512withECDSA"); - - // If you specify one, it will be used. - run("EC", 571, "SHA256withECDSA", "SHA256withECDSA"); + if(args == null || args.length < 3) { + throw new RuntimeException("Invalid arguments provided."); + } + String sigAlg = (args.length == 4) ? args[3] : null; + run(args[0], Integer.valueOf(args[1]), args[2], sigAlg); } private static void run(String keyAlg, int keySize, - String sigAlg, String expectedSigAlg) throws Exception { - String alias = keyAlg + keySize + (counter++); + String expectedSigAlg, String sigAlg) throws Exception { + String alias = keyAlg + keySize + System.currentTimeMillis(); String cmd = "-keystore ks -storepass changeit" + " -keypass changeit -alias " + alias + " -keyalg " + keyAlg + " -keysize " + keySize + diff --git a/jdk/test/sun/security/tools/keytool/PrintSSL.java b/jdk/test/sun/security/tools/keytool/PrintSSL.java index 6d43877fd58..04684f65998 100644 --- a/jdk/test/sun/security/tools/keytool/PrintSSL.java +++ b/jdk/test/sun/security/tools/keytool/PrintSSL.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -21,36 +21,74 @@ * questions. */ -// Read printssl.sh, this Java program starts an SSL server +/* + * @test + * @bug 6480981 8160624 + * @modules java.base/sun.security.tools.keytool + * @summary keytool should be able to import certificates from remote SSL server + * @run main/othervm PrintSSL + */ +import java.io.IOException; import java.net.ServerSocket; +import java.util.concurrent.CountDownLatch; import javax.net.ssl.SSLServerSocketFactory; import javax.net.ssl.SSLSocket; public class PrintSSL { + public static void main(String[] args) throws Exception { - System.setProperty("javax.net.ssl.keyStorePassword", "passphrase"); - System.setProperty("javax.net.ssl.keyStore", - System.getProperty("test.src", "./") - + "/../../../../javax/net/ssl/etc/keystore"); - SSLServerSocketFactory sslssf = - (SSLServerSocketFactory) SSLServerSocketFactory.getDefault(); - final ServerSocket server = sslssf.createServerSocket(0); - System.out.println(server.getLocalPort()); - System.out.flush(); - Thread t = new Thread() { - public void run() { - try { - Thread.sleep(30000); - server.close(); - } catch (Exception e) { - ; - } - throw new RuntimeException("Timeout"); - } - }; - t.setDaemon(true); - t.start(); - ((SSLSocket)server.accept()).startHandshake(); + + int port = new Server().start(); + if(port == -1) { + throw new RuntimeException("Unable start ssl server."); + } + String vmOpt = System.getProperty("TESTTOOLVMOPTS"); + String cmd = String.format( + "-debug %s -printcert -sslserver localhost:%s", + ((vmOpt == null) ? "" : vmOpt ), port); + sun.security.tools.keytool.Main.main(cmd.split("\\s+")); } + + private static class Server implements Runnable { + + private volatile int serverPort = -1; + private final CountDownLatch untilServerReady = new CountDownLatch(1); + + public int start() throws InterruptedException { + + Thread server = new Thread(this); + server.setDaemon(true); + server.start(); + untilServerReady.await(); + return this.getServerPort(); + } + + @Override + public void run() { + + System.setProperty("javax.net.ssl.keyStorePassword", "passphrase"); + System.setProperty("javax.net.ssl.keyStore", + System.getProperty("test.src", "./") + + "/../../../../javax/net/ssl/etc/keystore"); + SSLServerSocketFactory sslssf = + (SSLServerSocketFactory) SSLServerSocketFactory.getDefault(); + try (ServerSocket server = sslssf.createServerSocket(0)) { + this.serverPort = server.getLocalPort(); + System.out.printf("%nServer started on: %s%n", getServerPort()); + untilServerReady.countDown(); + ((SSLSocket)server.accept()).startHandshake(); + } catch (Throwable e) { + e.printStackTrace(System.out); + untilServerReady.countDown(); + } + + } + + public int getServerPort() { + return this.serverPort; + } + + } + } diff --git a/jdk/test/sun/security/tools/keytool/printssl.sh b/jdk/test/sun/security/tools/keytool/printssl.sh deleted file mode 100644 index 600ae7cea33..00000000000 --- a/jdk/test/sun/security/tools/keytool/printssl.sh +++ /dev/null @@ -1,72 +0,0 @@ -# -# Copyright (c) 2008, 2014, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# @test -# @bug 6480981 -# @summary keytool should be able to import certificates from remote SSL servers - -if [ "${TESTSRC}" = "" ] ; then - TESTSRC="." -fi -if [ "${TESTJAVA}" = "" ] ; then - echo "TESTJAVA not set. Test cannot execute." - echo "FAILED!!!" - exit 1 -fi -if [ "${COMPILEJAVA}" = "" ]; then - COMPILEJAVA="${TESTJAVA}" -fi - -# set platform-dependent variables -OS=`uname -s` -case "$OS" in - SunOS | Linux | Darwin | AIX ) - FS="/" - ;; - CYGWIN* ) - FS="/" - ;; - Windows_* ) - FS="\\" - ;; - * ) - echo "Unrecognized operating system!" - exit 1; - ;; -esac - -${COMPILEJAVA}${FS}bin${FS}javac ${TESTJAVACOPTS} ${TESTTOOLVMOPTS} -d . ${TESTSRC}${FS}PrintSSL.java || exit 10 -${TESTJAVA}${FS}bin${FS}java ${TESTVMOPTS} -Dtest.src=$TESTSRC PrintSSL | ( - read PORT - if [ "$PORT" = "" ]; then - echo "Server not started" - exit 2 - else - ${TESTJAVA}${FS}bin${FS}keytool ${TESTTOOLVMOPTS} -printcert -sslserver localhost:$PORT - fi -) -status=$? - -rm PrintSSL*.class - -exit $status diff --git a/jdk/test/sun/security/x509/URICertStore/AIA b/jdk/test/sun/security/x509/URICertStore/AIA new file mode 100644 index 00000000000..96fdd0918a0 --- /dev/null +++ b/jdk/test/sun/security/x509/URICertStore/AIA @@ -0,0 +1 @@ +127.0.0.1 ldap.host.for.aia \ No newline at end of file diff --git a/jdk/test/sun/security/x509/URICertStore/CRLDP b/jdk/test/sun/security/x509/URICertStore/CRLDP new file mode 100644 index 00000000000..fafba2bef2c --- /dev/null +++ b/jdk/test/sun/security/x509/URICertStore/CRLDP @@ -0,0 +1 @@ +127.0.0.1 ldap.host.for.crldp \ No newline at end of file diff --git a/jdk/test/sun/security/x509/URICertStore/ExtensionsWithLDAP.java b/jdk/test/sun/security/x509/URICertStore/ExtensionsWithLDAP.java index e495a4ac5d1..17e2e7caa53 100644 --- a/jdk/test/sun/security/x509/URICertStore/ExtensionsWithLDAP.java +++ b/jdk/test/sun/security/x509/URICertStore/ExtensionsWithLDAP.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,33 +23,34 @@ * questions. */ +import java.io.ByteArrayInputStream; +import java.io.File; import java.io.IOException; -import java.io.StringBufferInputStream; -import java.net.InetAddress; -import java.net.UnknownHostException; -import java.security.cert.CertificateException; -import java.security.cert.CertificateFactory; +import java.net.InetSocketAddress; +import java.net.Socket; +import java.nio.file.Path; +import java.nio.file.Paths; import java.security.cert.CertPath; import java.security.cert.CertPathValidator; import java.security.cert.CertPathValidatorException; +import java.security.cert.CertificateException; +import java.security.cert.CertificateFactory; import java.security.cert.PKIXParameters; import java.security.cert.TrustAnchor; import java.security.cert.X509Certificate; -import java.text.DateFormat; -import java.text.ParseException; import java.util.ArrayList; import java.util.Arrays; -import java.util.Date; import java.util.HashSet; import java.util.List; -import java.util.Locale; import java.util.Set; +import java.util.function.Consumer; /* * @test * @bug 8134708 * @summary Check if LDAP resources from CRLDP and AIA extensions can be loaded - * @run main/othervm ExtensionsWithLDAP + * @run main/othervm ExtensionsWithLDAP CRLDP ldap.host.for.crldp + * @run main/othervm ExtensionsWithLDAP AIA ldap.host.for.aia */ public class ExtensionsWithLDAP { @@ -125,29 +126,18 @@ public class ExtensionsWithLDAP { + "hnxn9+e0Ah+t8dS5EKfn44w5bI5PCu2bqxs6RCTxNjcY\n" + "-----END CERTIFICATE-----"; - - private static final String LDAP_HOST_CRLDP = "ldap.host.for.crldp"; - private static final String LDAP_HOST_AIA = "ldap.host.for.aia"; - - // a date within the certificates validity period - static final Date validationDate; - static { - try { - validationDate = DateFormat.getDateInstance( - DateFormat.MEDIUM, Locale.US).parse("Sep 02, 2015"); - } catch (ParseException e) { - throw new RuntimeException("Couldn't parse date", e); - } - } - public static void main(String[] args) throws Exception { + String extension = args[0]; + String targetHost = args[1]; + // enable CRLDP and AIA extensions System.setProperty("com.sun.security.enableCRLDP", "true"); System.setProperty("com.sun.security.enableAIAcaIssuers", "true"); - // register a local name service - String hostsFileName = System.getProperty("test.src", ".") + "/ExtensionsWithLDAPHosts"; - System.setProperty("jdk.net.hosts.file", hostsFileName); + Path hostsFilePath = Paths.get(System.getProperty("test.src", ".") + + File.separator + extension); + System.setProperty("jdk.net.hosts.file", + hostsFilePath.toFile().getAbsolutePath()); X509Certificate trustedCert = loadCertificate(CA_CERT); X509Certificate eeCert = loadCertificate(EE_CERT); @@ -158,31 +148,29 @@ public class ExtensionsWithLDAP { CertPath cp = (CertPath) CertificateFactory.getInstance("X509") .generateCertPath(Arrays.asList(eeCert)); - PKIXParameters params = new PKIXParameters(trustedCertsSet); - params.setDate(validationDate); - - // certpath validator should try to parse CRLDP and AIA extensions, - // and load CRLs/certs which they point to - // if a local name service catched requests for resolving host names - // which extensions contain, then it means that certpath validator - // tried to load CRLs/certs which they point to - try { - CertPathValidator.getInstance("PKIX").validate(cp, params); + // CertPath validator should try to parse CRLDP and AIA extensions, + // and load CRLs/certs which they point to. + // If proxy server catches requests for resolving host names + // which extensions contain, then it means that CertPath validator + // tried to load CRLs/certs which they point to. + List hosts = new ArrayList<>(); + Consumer socketConsumer = (Socket socket) -> { + InetSocketAddress remoteAddress + = (InetSocketAddress) socket.getRemoteSocketAddress(); + hosts.add(remoteAddress.getHostName()); + }; + try (SocksProxy proxy = SocksProxy.startProxy(socketConsumer)) { + CertPathValidator.getInstance("PKIX").validate(cp, + new PKIXParameters(trustedCertsSet)); throw new RuntimeException("CertPathValidatorException not thrown"); } catch (CertPathValidatorException cpve) { System.out.println("Expected exception: " + cpve); } - // check if it tried to resolve a host name from CRLDP extension - if (!LocalNameService.requestedHosts.contains(LDAP_HOST_CRLDP)) { + if (!hosts.contains(targetHost)) { throw new RuntimeException( - "A hostname from CRLDP extension not requested"); - } - - // check if it tried to resolve a host name from AIA extension - if (!LocalNameService.requestedHosts.contains(LDAP_HOST_AIA)) { - throw new RuntimeException( - "A hostname from AIA extension not requested"); + String.format("The %s from %s extension is not requested", + targetHost, extension)); } System.out.println("Test passed"); @@ -192,15 +180,9 @@ public class ExtensionsWithLDAP { public static X509Certificate loadCertificate(String s) throws IOException, CertificateException { - try (StringBufferInputStream is = new StringBufferInputStream(s)) { + try (ByteArrayInputStream is = new ByteArrayInputStream(s.getBytes())) { return (X509Certificate) CertificateFactory.getInstance("X509") .generateCertificate(is); } } - - // a local name service which log requested host names - public static class LocalNameService { - - static final List requestedHosts = new ArrayList<>(); - } - } +} diff --git a/jdk/test/sun/security/x509/URICertStore/SocksProxy.java b/jdk/test/sun/security/x509/URICertStore/SocksProxy.java new file mode 100644 index 00000000000..50c6e89c787 --- /dev/null +++ b/jdk/test/sun/security/x509/URICertStore/SocksProxy.java @@ -0,0 +1,94 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +import java.io.IOException; +import java.net.ServerSocket; +import java.net.Socket; +import java.util.Objects; +import java.util.function.Consumer; + +import javax.net.ServerSocketFactory; + +/* + * A simple socks4 proxy for traveling socket. + */ +class SocksProxy implements Runnable, AutoCloseable { + + private ServerSocket server; + private Consumer socketConsumer; + + private SocksProxy(ServerSocket server, Consumer socketConsumer) { + this.server = server; + this.socketConsumer = socketConsumer; + } + + static SocksProxy startProxy(Consumer socketConsumer) + throws IOException { + Objects.requireNonNull(socketConsumer, "socketConsumer cannot be null"); + + ServerSocket server + = ServerSocketFactory.getDefault().createServerSocket(0); + + System.setProperty("socksProxyHost", "127.0.0.1"); + System.setProperty("socksProxyPort", + String.valueOf(server.getLocalPort())); + System.setProperty("socksProxyVersion", "4"); + + SocksProxy proxy = new SocksProxy(server, socketConsumer); + Thread proxyThread = new Thread(proxy, "Proxy"); + proxyThread.setDaemon(true); + proxyThread.start(); + + return proxy; + } + + @Override + public void run() { + while (!server.isClosed()) { + try(Socket socket = server.accept()) { + System.out.println("Server: accepted connection"); + if (socketConsumer != null) { + socketConsumer.accept(socket); + } + } catch (IOException e) { + if (!server.isClosed()) { + throw new RuntimeException( + "Server: accept connection failed", e); + } else { + System.out.println("Server is closed."); + } + } + } + } + + @Override + public void close() throws Exception { + if (!server.isClosed()) { + server.close(); + } + } + + int getPort() { + return server.getLocalPort(); + } +} diff --git a/jdk/test/tools/jlink/IntegrationTest.java b/jdk/test/tools/jlink/IntegrationTest.java index 0eb82a0415e..e41399709db 100644 --- a/jdk/test/tools/jlink/IntegrationTest.java +++ b/jdk/test/tools/jlink/IntegrationTest.java @@ -105,60 +105,6 @@ public class IntegrationTest { } } - public static class MyPlugin1 implements Plugin { - - Integer index; - Set after; - Set before; - - private MyPlugin1(Integer index, Set after, Set before) { - this.index = index; - this.after = after; - this.before = before; - } - - @Override - public Set isAfter() { - return after; - } - - @Override - public Set isBefore() { - return before; - } - - @Override - public String getName() { - return NAME + index; - } - - @Override - public void visit(ModulePool in, ModulePool out) { - System.err.println(NAME + index); - ordered.add(index); - in.transformAndCopy((file) -> { - return file; - }, out); - } - - @Override - public String getDescription() { - return null; - } - - @Override - public String getOption() { - return null; - } - static final String NAME = "myprovider"; - static final String INDEX = "INDEX"; - - @Override - public void configure(Map config) { - throw new UnsupportedOperationException("Shouldn't be called"); - } - } - public static void main(String[] args) throws Exception { Helper helper = Helper.newHelper(); @@ -168,8 +114,6 @@ public class IntegrationTest { } apitest(); test(); - testOrder(); - testCycleOrder(); } private static void apitest() throws Exception { @@ -262,109 +206,4 @@ public class IntegrationTest { } } - - private static void testOrder() throws Exception { - Jlink jlink = new Jlink(); - Path output = Paths.get("integrationout2"); - List modulePaths = new ArrayList<>(); - File jmods - = JImageGenerator.getJModsDir(new File(System.getProperty("test.jdk"))); - modulePaths.add(jmods.toPath()); - Set mods = new HashSet<>(); - mods.add("java.management"); - Set limits = new HashSet<>(); - limits.add("java.management"); - JlinkConfiguration config = new Jlink.JlinkConfiguration(output, - modulePaths, mods, limits, null); - - List lst = new ArrayList<>(); - - // Order is Plug1>Plug2>Plug3 - // Plug1 - - - // TRANSFORMER 3, must be after 2. - { - Set after = new HashSet<>(); - after.add(MyPlugin1.NAME+"2"); - lst.add(new MyPlugin1(3, after, Collections.emptySet())); - } - - // TRANSFORMER 2, must be after 1. - { - Set after = new HashSet<>(); - after.add(MyPlugin1.NAME+"1"); - lst.add(new MyPlugin1(2, after, Collections.emptySet())); - } - - // TRANSFORMER 1 - { - Set before = new HashSet<>(); - before.add(MyPlugin1.NAME+"2"); - lst.add(new MyPlugin1(1, Collections.emptySet(), before)); - } - - // Image builder - DefaultImageBuilder builder = new DefaultImageBuilder(output); - PluginsConfiguration plugins - = new Jlink.PluginsConfiguration(lst, builder, null); - - jlink.build(config, plugins); - - if (ordered.isEmpty()) { - throw new AssertionError("Plugins not called"); - } - List clone = new ArrayList<>(); - clone.addAll(ordered); - Collections.sort(clone); - if (!clone.equals(ordered)) { - throw new AssertionError("Ordered is not properly sorted" + ordered); - } - } - - private static void testCycleOrder() throws Exception { - Jlink jlink = new Jlink(); - Path output = Paths.get("integrationout3"); - List modulePaths = new ArrayList<>(); - File jmods - = JImageGenerator.getJModsDir(new File(System.getProperty("test.jdk"))); - modulePaths.add(jmods.toPath()); - Set mods = new HashSet<>(); - mods.add("java.management"); - Set limits = new HashSet<>(); - limits.add("java.management"); - JlinkConfiguration config = new Jlink.JlinkConfiguration(output, - modulePaths, mods, limits, null); - - List lst = new ArrayList<>(); - - // packager 1 - { - Set before = new HashSet<>(); - before.add(MyPlugin1.NAME+"2"); - lst.add(new MyPlugin1(1, Collections.emptySet(), before)); - } - - // packager 2 - { - Set before = new HashSet<>(); - before.add(MyPlugin1.NAME+"1"); - lst.add(new MyPlugin1(2, Collections.emptySet(), before)); - } - - // Image builder - DefaultImageBuilder builder = new DefaultImageBuilder(output); - PluginsConfiguration plugins - = new Jlink.PluginsConfiguration(lst, builder, null); - boolean failed = false; - try { - jlink.build(config, plugins); - failed = true; - } catch (Exception ex) { - // XXX OK - } - if (failed) { - throw new AssertionError("Should have failed"); - } - } } diff --git a/jdk/test/tools/jlink/JLinkOptimTest.java b/jdk/test/tools/jlink/JLinkOptimTest.java deleted file mode 100644 index d4612fbe845..00000000000 --- a/jdk/test/tools/jlink/JLinkOptimTest.java +++ /dev/null @@ -1,354 +0,0 @@ - -import java.lang.reflect.Method; -import java.net.URI; -import java.nio.file.FileSystem; -import java.nio.file.FileSystems; -import java.nio.file.Files; -import java.nio.file.Path; -import java.nio.file.Paths; -import java.util.ArrayList; -import java.util.Collections; -import java.util.HashMap; -import java.util.Iterator; -import java.util.List; -import java.util.Map; -import java.util.stream.Stream; -import jdk.internal.org.objectweb.asm.ClassReader; -import jdk.internal.org.objectweb.asm.Opcodes; -import jdk.internal.org.objectweb.asm.tree.AbstractInsnNode; -import jdk.internal.org.objectweb.asm.tree.ClassNode; -import jdk.internal.org.objectweb.asm.tree.MethodInsnNode; -import jdk.internal.org.objectweb.asm.tree.MethodNode; -import jdk.internal.org.objectweb.asm.tree.TryCatchBlockNode; -import jdk.tools.jlink.internal.PluginRepository; -import jdk.tools.jlink.internal.ModulePoolImpl; -import jdk.tools.jlink.internal.plugins.OptimizationPlugin; -import jdk.tools.jlink.internal.plugins.asm.AsmModulePool; -import jdk.tools.jlink.internal.plugins.asm.AsmPlugin; -import jdk.tools.jlink.internal.plugins.asm.AsmPools; -import jdk.tools.jlink.internal.plugins.optim.ControlFlow; -import jdk.tools.jlink.internal.plugins.optim.ControlFlow.Block; -import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.plugin.ModulePool; - -import tests.Helper; -import tests.JImageGenerator; - -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - - /* - * @test - * @summary Test image creation with class optimization - * @author Jean-Francois Denise - * @library ../lib - * @modules java.base/jdk.internal.jimage - * jdk.jdeps/com.sun.tools.classfile - * jdk.jlink/jdk.tools.jlink.internal - * jdk.jlink/jdk.tools.jmod - * jdk.jlink/jdk.tools.jimage - * jdk.jlink/jdk.tools.jlink.internal.plugins - * jdk.jlink/jdk.tools.jlink.internal.plugins.asm - * jdk.jlink/jdk.tools.jlink.internal.plugins.optim - * java.base/jdk.internal.org.objectweb.asm - * java.base/jdk.internal.org.objectweb.asm.tree - * java.base/jdk.internal.org.objectweb.asm.util - * jdk.compiler - * @build tests.* - * @run main JLinkOptimTest - */ -public class JLinkOptimTest { - - private static final String EXPECTED = "expected"; - private static Helper helper; - - public static class ControlFlowPlugin extends AsmPlugin { - - private boolean called; - private int numMethods; - private int numBlocks; - - private static final String NAME = "test-optim"; - - private ControlFlowPlugin() { - } - - @Override - public void visit(AsmPools pools) { - called = true; - for (AsmModulePool p : pools.getModulePools()) { - - p.visitClassReaders((reader) -> { - ClassNode cn = new ClassNode(); - if ((reader.getAccess() & Opcodes.ACC_INTERFACE) == 0) { - reader.accept(cn, ClassReader.EXPAND_FRAMES); - for (MethodNode m : cn.methods) { - if ((m.access & Opcodes.ACC_ABSTRACT) == 0 - && (m.access & Opcodes.ACC_NATIVE) == 0) { - numMethods += 1; - try { - ControlFlow f - = ControlFlow.createControlFlow(cn.name, m); - for (Block b : f.getBlocks()) { - numBlocks += 1; - f.getClosure(b); - } - } catch (Throwable ex) { - //ex.printStackTrace(); - throw new RuntimeException("Exception in " - + cn.name + "." + m.name, ex); - } - } - } - } - return null; - }); - } - } - - @Override - public String getName() { - return NAME; - } - } - - private static void testForName() throws Exception { - String moduleName = "optimplugin"; - Path src = Paths.get(System.getProperty("test.src")).resolve(moduleName); - Path classes = helper.getJmodClassesDir().resolve(moduleName); - JImageGenerator.compile(src, classes); - - FileSystem fs = FileSystems.getFileSystem(URI.create("jrt:/")); - Path root = fs.getPath("/modules/java.base"); - // Access module-info.class to be reused as fake module-info.class - List javabaseResources = new ArrayList<>(); - try (Stream stream = Files.walk(root)) { - for (Iterator iterator = stream.iterator(); iterator.hasNext();) { - Path p = iterator.next(); - if (Files.isRegularFile(p)) { - try { - javabaseResources.add(ModuleEntry.create(p.toString(). - substring("/modules".length()), Files.readAllBytes(p))); - } catch (Exception ex) { - throw new RuntimeException(ex); - } - } - } - } - - //forName folding - ModulePoolImpl pool = new ModulePoolImpl(); - byte[] content = Files.readAllBytes(classes. - resolve("optim").resolve("ForNameTestCase.class")); - byte[] content2 = Files.readAllBytes(classes. - resolve("optim").resolve("AType.class")); - byte[] mcontent = Files.readAllBytes(classes.resolve("module-info.class")); - - pool.add(ModuleEntry.create("/optimplugin/optim/ForNameTestCase.class", content)); - pool.add(ModuleEntry.create("/optimplugin/optim/AType.class", content2)); - pool.add(ModuleEntry.create("/optimplugin/module-info.class", mcontent)); - - for (ModuleEntry r : javabaseResources) { - pool.add(r); - } - - OptimizationPlugin plugin = new OptimizationPlugin(); - Map optional = new HashMap<>(); - optional.put(OptimizationPlugin.NAME, OptimizationPlugin.FORNAME_REMOVAL); - optional.put(OptimizationPlugin.LOG, "forName.log"); - plugin.configure(optional); - ModulePool out = new ModulePoolImpl(); - plugin.visit(pool, out); - - ModuleEntry result = out.entries().iterator().next(); - - ClassReader optimReader = new ClassReader(result.getBytes()); - ClassNode optimClass = new ClassNode(); - optimReader.accept(optimClass, ClassReader.EXPAND_FRAMES); - - if (!optimClass.name.equals("optim/ForNameTestCase")) { - throw new Exception("Invalid class " + optimClass.name); - } - if (optimClass.methods.size() < 2) { - throw new Exception("Not enough methods in new class"); - } - for (MethodNode mn : optimClass.methods) { - if (!mn.name.contains("forName") && !mn.name.contains("")) { - continue; - } - if (mn.name.startsWith("negative")) { - checkForName(mn); - } else { - checkNoForName(mn); - } - } - Map newClasses = new HashMap<>(); - newClasses.put("optim.ForNameTestCase", result.getBytes()); - newClasses.put("optim.AType", content2); - MemClassLoader loader = new MemClassLoader(newClasses); - Class loaded = loader.loadClass("optim.ForNameTestCase"); - if (loaded.getDeclaredMethods().length < 2) { - throw new Exception("Not enough methods in new class"); - } - for (Method m : loaded.getDeclaredMethods()) { - if (m.getName().contains("Exception")) { - try { - m.invoke(null); - } catch (Exception ex) { - //ex.getCause().printStackTrace(); - if (!ex.getCause().getMessage().equals(EXPECTED)) { - throw new Exception("Unexpected exception " + ex); - } - } - } else if (!m.getName().startsWith("negative")) { - Class clazz = (Class) m.invoke(null); - if (clazz != String.class && clazz != loader.findClass("optim.AType")) { - throw new Exception("Invalid class " + clazz); - } - } - } - } - - private static void checkNoForName(MethodNode m) throws Exception { - Iterator it = m.instructions.iterator(); - while (it.hasNext()) { - AbstractInsnNode n = it.next(); - if (n instanceof MethodInsnNode) { - MethodInsnNode met = (MethodInsnNode) n; - if (met.name.equals("forName") - && met.owner.equals("java/lang/Class") - && met.desc.equals("(Ljava/lang/String;)Ljava/lang/Class;")) { - throw new Exception("forName not removed in " + m.name); - } - } - } - for (TryCatchBlockNode tcb : m.tryCatchBlocks) { - if (tcb.type.equals(ClassNotFoundException.class.getName().replaceAll("\\.", "/"))) { - throw new Exception("ClassNotFoundException Block not removed for " + m.name); - } - } - } - - private static void checkForName(MethodNode m) throws Exception { - Iterator it = m.instructions.iterator(); - boolean found = false; - while (it.hasNext()) { - AbstractInsnNode n = it.next(); - if (n instanceof MethodInsnNode) { - MethodInsnNode met = (MethodInsnNode) n; - if (met.name.equals("forName") - && met.owner.equals("java/lang/Class") - && met.desc.equals("(Ljava/lang/String;)Ljava/lang/Class;")) { - found = true; - break; - } - } - } - if (!found) { - throw new Exception("forName removed but shouldn't have"); - } - found = false; - for (TryCatchBlockNode tcb : m.tryCatchBlocks) { - if (tcb.type.equals(ClassNotFoundException.class.getName().replaceAll("\\.", "/"))) { - found = true; - break; - } - } - if (!found) { - throw new Exception("tryCatchBlocks removed but shouldn't have"); - } - } - - static class MemClassLoader extends ClassLoader { - - private final Map classes; - private final Map> cache = new HashMap<>(); - - MemClassLoader(Map classes) { - super(null); - this.classes = classes; - } - - @Override - public Class findClass(String name) throws ClassNotFoundException { - Class clazz = cache.get(name); - if (clazz == null) { - byte[] b = classes.get(name); - if (b == null) { - return super.findClass(name); - } else { - clazz = defineClass(name, b, 0, b.length); - cache.put(name, clazz); - } - } - return clazz; - } - } - - public static void main(String[] args) throws Exception { - helper = Helper.newHelper(); - if (helper == null) { - System.err.println("Test not run"); - return; - } - - testForName(); - - helper.generateDefaultModules(); - helper.generateDefaultJModule("optim1", "java.se"); - { - String[] userOptions = {"--class-optim=all:log=./class-optim-log.txt"}; - - Path imageDir = helper.generateDefaultImage(userOptions, "optim1").assertSuccess(); - helper.checkImage(imageDir, "optim1", null, null); - } - - { - String[] userOptions = {"--class-optim=forName-folding:log=./class-optim-log.txt"}; - Path imageDir = helper.generateDefaultImage(userOptions, "optim1").assertSuccess(); - helper.checkImage(imageDir, "optim1", null, null); - } - - { - ControlFlowPlugin plugin = new ControlFlowPlugin(); - PluginRepository.registerPlugin(plugin); - String[] userOptions = {"--test-optim"}; - Path imageDir = helper.generateDefaultImage(userOptions, "optim1").assertSuccess(); - helper.checkImage(imageDir, "optim1", null, null); - //System.out.println("Num methods analyzed " + provider.numMethods - // + "num blocks " + provider.numBlocks); - if (!plugin.called) { - throw new Exception("Plugin not called"); - } - if (plugin.numMethods < 1000) { - throw new Exception("Not enough method called, should be " - + "around 10000 but is " + plugin.numMethods); - } - if (plugin.numBlocks < 100000) { - throw new Exception("Not enough blocks, should be " - + "around 640000 but is " + plugin.numMethods); - } - } - } - -} diff --git a/jdk/test/tools/jlink/asmplugin/AddForgetResourcesTest.java b/jdk/test/tools/jlink/asmplugin/AddForgetResourcesTest.java deleted file mode 100644 index 4385534e07f..00000000000 --- a/jdk/test/tools/jlink/asmplugin/AddForgetResourcesTest.java +++ /dev/null @@ -1,509 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - * Asm plugin testing. - * @test - * @summary Test resource transformation. - * @author Andrei Eremeev - * @modules java.base/jdk.internal.org.objectweb.asm - * jdk.jlink/jdk.tools.jlink.internal - * jdk.jlink/jdk.tools.jlink.internal.plugins.asm - * jdk.jdeps/com.sun.tools.classfile - * @build AsmPluginTestBase - * @run main AddForgetResourcesTest -*/ - -import java.io.ByteArrayInputStream; -import java.io.IOException; -import java.nio.ByteBuffer; -import java.util.Collection; -import java.util.List; -import java.util.Map; - -import com.sun.tools.classfile.ClassFile; -import com.sun.tools.classfile.Method; -import java.io.UncheckedIOException; -import java.util.Set; -import jdk.internal.org.objectweb.asm.ClassReader; -import jdk.internal.org.objectweb.asm.ClassVisitor; -import jdk.internal.org.objectweb.asm.ClassWriter; -import jdk.internal.org.objectweb.asm.Opcodes; -import jdk.tools.jlink.internal.plugins.asm.AsmGlobalPool; -import jdk.tools.jlink.internal.plugins.asm.AsmModulePool; -import jdk.tools.jlink.internal.plugins.asm.AsmPool.ResourceFile; -import jdk.tools.jlink.internal.plugins.asm.AsmPool.WritableClassPool; -import jdk.tools.jlink.internal.plugins.asm.AsmPool.WritableResourcePool; -import jdk.tools.jlink.internal.plugins.asm.AsmPools; -import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.plugin.ModulePool; - -public class AddForgetResourcesTest extends AsmPluginTestBase { - - public static void main(String[] args) throws Exception { - if (!isImageBuild()) { - System.err.println("Test not run. Not image build."); - return; - } - new AddForgetResourcesTest().test(); - } - - @Override - public void test() throws Exception { - TestPlugin[] plugins = new TestPlugin[] { - new AddClassesPlugin(), - new AddResourcesPlugin(), - new ReplaceClassesPlugin(), - new ReplaceResourcesPlugin(), - new ForgetClassesPlugin(), - new ForgetResourcesPlugin(), - new AddForgetClassesPlugin(), - new AddForgetResourcesPlugin(), - new ComboPlugin() - }; - for (TestPlugin p : plugins) { - ModulePool out = p.visit(getPool()); - p.test(getPool(), out); - } - } - - private static final String SUFFIX = "HELLOWORLD"; - - private static class RenameClassVisitor extends ClassVisitor { - - public RenameClassVisitor(ClassWriter cv) { - super(Opcodes.ASM5, cv); - } - - @Override - public void visit(int version, int access, String name, String signature, String superName, String[] interfaces) { - super.visit(version, access, name + SUFFIX, signature, superName, interfaces); - } - } - - private static class AddMethodClassVisitor extends ClassVisitor { - - public AddMethodClassVisitor(ClassWriter cv) { - super(Opcodes.ASM5, cv); - } - - @Override - public void visit(int version, int access, String name, String signature, String superName, String[] interfaces) { - this.visitMethod(0, SUFFIX, "()V", null, null); - super.visit(version, access, name, signature, superName, interfaces); - } - } - - private class AddClassesPlugin extends TestPlugin { - - private int expected = 0; - - @Override - public void visit() { - AsmPools pools = getPools(); - AsmGlobalPool globalPool = pools.getGlobalPool(); - WritableClassPool transformedClasses = globalPool.getTransformedClasses(); - expected = globalPool.getClasses().size(); - for (ModuleEntry res : globalPool.getClasses()) { - ClassReader reader = globalPool.getClassReader(res); - String className = reader.getClassName(); - if (!className.endsWith("module-info")) { - ClassWriter writer = new ClassWriter(reader, ClassWriter.COMPUTE_FRAMES); - reader.accept(new RenameClassVisitor(writer), ClassReader.EXPAND_FRAMES); - transformedClasses.addClass(writer); - ++expected; - } - } - } - - @Override - public void test(ModulePool inResources, ModulePool outResources) { - Collection inClasses = extractClasses(inResources); - Collection outClasses = extractClasses(outResources); - if (expected != outClasses.size()) { - throw new AssertionError("Classes were not added. Expected: " + expected - + ", got: " + outClasses.size()); - } - for (ModuleEntry in : inClasses) { - String path = in.getPath(); - if (!outClasses.contains(in)) { - throw new AssertionError("Class not found: " + path); - } - if (path.endsWith("module-info.class")) { - continue; - } - String modifiedPath = path.replace(".class", SUFFIX + ".class"); - if (!outClasses.contains(ModuleEntry.create(modifiedPath, new byte[0]))) { - throw new AssertionError("Class not found: " + modifiedPath); - } - } - } - } - - private class AddResourcesPlugin extends TestPlugin { - - @Override - public void visit() { - AsmPools pools = getPools(); - AsmGlobalPool globalPool = pools.getGlobalPool(); - for (ModuleEntry res : globalPool.getResourceFiles()) { - String path = res.getPath(); - String moduleName = getModule(path); - AsmModulePool modulePool = pools.getModulePool(moduleName); - WritableResourcePool resourcePool = modulePool.getTransformedResourceFiles(); - resourcePool.addResourceFile(new ResourceFile(removeModule(res.getPath()) + SUFFIX, - res.getBytes())); - } - } - - @Override - public void test(ModulePool in, ModulePool out) throws Exception { - Collection inResources = extractResources(in); - Collection outResources = extractResources(out); - if (2 * inResources.size() != outResources.size()) { - throw new AssertionError("Classes were not added. Expected: " + (2 * inResources.size()) - + ", got: " + outResources.size()); - } - for (ModuleEntry r : inResources) { - String path = r.getPath(); - if (!outResources.contains(r)) { - throw new AssertionError("Class not found: " + path); - } - String modifiedPath = path + SUFFIX; - if (!outResources.contains(ModuleEntry.create(modifiedPath, new byte[0]))) { - throw new AssertionError("Class not found: " + modifiedPath); - } - } - } - } - - private class ReplaceClassesPlugin extends TestPlugin { - - @Override - public void visit() { - AsmPools pools = getPools(); - AsmGlobalPool globalPool = pools.getGlobalPool(); - WritableClassPool transformedClasses = globalPool.getTransformedClasses(); - for (ModuleEntry res : globalPool.getClasses()) { - ClassReader reader = globalPool.getClassReader(res); - ClassWriter writer = new ClassWriter(reader, ClassWriter.COMPUTE_FRAMES); - reader.accept(new AddMethodClassVisitor(writer), ClassReader.EXPAND_FRAMES); - transformedClasses.addClass(writer); - } - } - - @Override - public void test(ModulePool inResources, ModulePool outResources) throws Exception { - Collection inClasses = extractClasses(inResources); - Collection outClasses = extractClasses(outResources); - if (inClasses.size() != outClasses.size()) { - throw new AssertionError("Number of classes. Expected: " + (inClasses.size()) - + ", got: " + outClasses.size()); - } - for (ModuleEntry out : outClasses) { - String path = out.getPath(); - if (!inClasses.contains(out)) { - throw new AssertionError("Class not found: " + path); - } - ClassFile cf = ClassFile.read(new ByteArrayInputStream(out.getBytes())); - if (path.endsWith("module-info.class")) { - continue; - } - boolean failed = true; - for (Method m : cf.methods) { - if (m.getName(cf.constant_pool).equals(SUFFIX)) { - failed = false; - } - } - if (failed) { - throw new AssertionError("Not found method with name " + SUFFIX + " in class " + path); - } - } - } - } - - private class ReplaceResourcesPlugin extends TestPlugin { - - @Override - public void visit() { - AsmPools pools = getPools(); - AsmGlobalPool globalPool = pools.getGlobalPool(); - for (ModuleEntry res : globalPool.getResourceFiles()) { - String path = res.getPath(); - AsmModulePool modulePool = pools.getModulePool(getModule(path)); - modulePool.getTransformedResourceFiles().addResourceFile(new ResourceFile(removeModule(path), - "HUI".getBytes())); - } - } - - @Override - public void test(ModulePool in, ModulePool out) throws Exception { - Collection inResources = extractResources(in); - Collection outResources = extractResources(out); - if (inResources.size() != outResources.size()) { - throw new AssertionError("Number of resources. Expected: " + inResources.size() - + ", got: " + outResources.size()); - } - for (ModuleEntry r : outResources) { - String path = r.getPath(); - if (!inResources.contains(r)) { - throw new AssertionError("Resource not found: " + path); - } - String content = new String(r.getBytes()); - if (!"HUI".equals(content)) { - throw new AssertionError("Content expected: 'HUI', got: " + content); - } - } - } - } - - private class ForgetClassesPlugin extends TestPlugin { - - private int expected = 0; - - @Override - public void visit() { - AsmPools pools = getPools(); - AsmGlobalPool globalPool = pools.getGlobalPool(); - WritableClassPool transformedClasses = globalPool.getTransformedClasses(); - int i = 0; - for (ModuleEntry res : globalPool.getClasses()) { - String path = removeModule(res.getPath()); - String className = path.replace(".class", ""); - if ((i & 1) == 0 && !className.endsWith("module-info")) { - transformedClasses.forgetClass(className); - } else { - ++expected; - } - i ^= 1; - } - } - - @Override - public void test(ModulePool inResources, ModulePool outResources) throws Exception { - Collection outClasses = extractClasses(outResources); - if (expected != outClasses.size()) { - throw new AssertionError("Number of classes. Expected: " + expected + - ", got: " + outClasses.size()); - } - } - } - - private class ForgetResourcesPlugin extends TestPlugin { - - private int expectedAmount = 0; - - @Override - public void visit() { - AsmPools pools = getPools(); - AsmGlobalPool globalPool = pools.getGlobalPool(); - int i = 0; - for (ModuleEntry res : globalPool.getResourceFiles()) { - String path = res.getPath(); - if (!path.contains("META-INF/services")) { - if ((i & 1) == 0) { - AsmModulePool modulePool = pools.getModulePool(getModule(path)); - modulePool.getTransformedResourceFiles().forgetResourceFile(removeModule(res.getPath())); - } else { - ++expectedAmount; - } - i ^= 1; - } else { - ++expectedAmount; - } - } - } - - @Override - public void test(ModulePool in, ModulePool out) throws Exception { - Collection outResources = extractResources(out); - if (expectedAmount != outResources.size()) { - throw new AssertionError("Number of classes. Expected: " + expectedAmount - + ", got: " + outResources.size()); - } - } - } - - private class AddForgetClassesPlugin extends TestPlugin { - - private int expected = 0; - - @Override - public void visit() { - AsmPools pools = getPools(); - AsmGlobalPool globalPool = pools.getGlobalPool(); - WritableClassPool transformedClasses = globalPool.getTransformedClasses(); - int i = 0; - for (ModuleEntry res : globalPool.getClasses()) { - ClassReader reader = globalPool.getClassReader(res); - String className = reader.getClassName(); - ClassWriter writer = new ClassWriter(reader, ClassWriter.COMPUTE_FRAMES); - if (!className.endsWith("module-info")) { - reader.accept(new RenameClassVisitor(writer), ClassReader.EXPAND_FRAMES); - transformedClasses.addClass(writer); - ++expected; - } - - if ((i & 1) == 0 && !className.endsWith("module-info")) { - transformedClasses.forgetClass(className); - } else { - ++expected; - } - i ^= 1; - } - } - - @Override - public void test(ModulePool inResources, ModulePool outResources) throws Exception { - Collection outClasses = extractClasses(outResources); - if (expected != outClasses.size()) { - throw new AssertionError("Number of classes. Expected: " + expected - + ", got: " + outClasses.size()); - } - } - } - - private class AddForgetResourcesPlugin extends TestPlugin { - - private int expectedAmount = 0; - - @Override - public void visit() { - AsmPools pools = getPools(); - AsmGlobalPool globalPool = pools.getGlobalPool(); - int i = 0; - for (ModuleEntry res : globalPool.getResourceFiles()) { - String path = res.getPath(); - String moduleName = getModule(path); - if (!path.contains("META-INF")) { - AsmModulePool modulePool = pools.getModulePool(moduleName); - WritableResourcePool transformedResourceFiles = modulePool.getTransformedResourceFiles(); - String newPath = removeModule(path) + SUFFIX; - transformedResourceFiles.addResourceFile(new ResourceFile(newPath, res.getBytes())); - if ((i & 1) == 0) { - transformedResourceFiles.forgetResourceFile(newPath); - } else { - ++expectedAmount; - } - i ^= 1; - } - ++expectedAmount; - } - } - - @Override - public void test(ModulePool inResources, ModulePool out) throws Exception { - Collection outResources = extractResources(out); - if (expectedAmount != outResources.size()) { - throw new AssertionError("Number of classes. Expected: " + expectedAmount - + ", got: " + outResources.size()); - } - } - } - - private class ComboPlugin extends TestPlugin { - - private class RenameClassVisitor extends ClassVisitor { - - public RenameClassVisitor(ClassWriter cv) { - super(Opcodes.ASM5, cv); - } - - @Override - public void visit(int version, int access, String name, String signature, String superName, String[] interfaces) { - super.visit(version, access, name + SUFFIX, signature, superName, interfaces); - } - } - - @Override - public void visit() { - try { - renameClasses(); - renameResources(); - } catch (IOException ex) { - throw new UncheckedIOException(ex); - } - } - - @Override - public void test(ModulePool inResources, ModulePool outResources) throws Exception { - if (!isVisitCalled()) { - throw new AssertionError("Resources not visited"); - } - AsmGlobalPool globalPool = getPools().getGlobalPool(); - if (globalPool.getTransformedClasses().getClasses().size() != getClasses().size()) { - throw new AssertionError("Number of transformed classes not equal to expected"); - } - // Check that only renamed classes and resource files are in the result. - outResources.entries().forEach(r -> { - String resourceName = r.getPath(); - if (resourceName.endsWith(".class") && !resourceName.endsWith("module-info.class")) { - if (!resourceName.endsWith(SUFFIX + ".class")) { - throw new AssertionError("Class not renamed " + resourceName); - } - } else if (resourceName.contains("META-INF/services/") && MODULES.containsKey(r.getModule())) { - String newClassName = new String(r.getBytes()); - if(!newClassName.endsWith(SUFFIX)) { - throw new AssertionError("Resource file not renamed " + resourceName); - } - } - }); - } - - private void renameResources() throws IOException { - AsmPools pools = getPools(); - // Rename the resource Files - for (Map.Entry> mod : MODULES.entrySet()) { - String moduleName = mod.getKey(); - AsmModulePool modulePool = pools.getModulePool(moduleName); - for (ModuleEntry res : modulePool.getResourceFiles()) { - ResourceFile resFile = modulePool.getResourceFile(res); - if (resFile.getPath().startsWith("META-INF/services/")) { - String newContent = new String(resFile.getContent()) + SUFFIX; - ResourceFile newResourceFile = new ResourceFile(resFile.getPath(), - newContent.getBytes()); - modulePool.getTransformedResourceFiles().addResourceFile(newResourceFile); - } - } - } - } - - private void renameClasses() throws IOException { - AsmPools pools = getPools(); - AsmGlobalPool globalPool = pools.getGlobalPool(); - WritableClassPool transformedClasses = globalPool.getTransformedClasses(); - for (ModuleEntry res : globalPool.getClasses()) { - if (res.getPath().endsWith("module-info.class")) { - continue; - } - ClassReader reader = globalPool.getClassReader(res); - ClassWriter writer = new ClassWriter(reader, ClassWriter.COMPUTE_FRAMES); - RenameClassVisitor visitor = new RenameClassVisitor(writer); - reader.accept(visitor, ClassReader.EXPAND_FRAMES); - - transformedClasses.forgetClass(reader.getClassName()); - transformedClasses.addClass(writer); - } - } - } -} diff --git a/jdk/test/tools/jlink/asmplugin/AsmPluginTestBase.java b/jdk/test/tools/jlink/asmplugin/AsmPluginTestBase.java deleted file mode 100644 index c51419e682c..00000000000 --- a/jdk/test/tools/jlink/asmplugin/AsmPluginTestBase.java +++ /dev/null @@ -1,249 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ -import java.io.IOException; -import java.net.URI; -import java.nio.file.FileSystem; -import java.nio.file.FileSystems; -import java.nio.file.Files; -import java.nio.file.Path; -import java.nio.file.Paths; -import java.util.ArrayList; -import java.util.Collection; -import java.util.Collections; -import java.util.HashMap; -import java.util.Iterator; -import java.util.List; -import java.util.Map; -import java.util.Set; -import java.util.function.Predicate; -import java.util.stream.Collectors; -import java.util.stream.Stream; -import jdk.tools.jlink.internal.ModulePoolImpl; -import jdk.tools.jlink.internal.StringTable; - -import jdk.tools.jlink.internal.plugins.asm.AsmPlugin; -import jdk.tools.jlink.internal.plugins.asm.AsmPools; -import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.plugin.ModulePool; - -public abstract class AsmPluginTestBase { - - protected static final String TEST_MODULE = "jlink.test"; - protected static final Map> MODULES; - - private static final Predicate isClass = r -> r.getPath().endsWith(".class"); - private final List classes; - private final List resources; - private final ModulePool pool; - - static { - Map> map = new HashMap<>(); - map.put("jdk.localedata", new ArrayList<>()); - map.put("java.base", new ArrayList<>()); - map.put(TEST_MODULE, new ArrayList<>()); - MODULES = Collections.unmodifiableMap(map); - } - - public static boolean isImageBuild() { - Path javaHome = Paths.get(System.getProperty("test.jdk")); - Path jmods = javaHome.resolve("jmods"); - return Files.exists(jmods); - } - - public AsmPluginTestBase() { - try { - List classes = new ArrayList<>(); - List resources = new ArrayList<>(); - - pool = new ModulePoolImpl(); - - FileSystem fs = FileSystems.getFileSystem(URI.create("jrt:/")); - Path root = fs.getPath("/modules"); - - List moduleInfos = new ArrayList<>(); - try (Stream stream = Files.walk(root)) { - for (Iterator iterator = stream.iterator(); iterator.hasNext(); ) { - Path p = iterator.next(); - if (Files.isRegularFile(p)) { - String module = p.toString().substring("/modules/".length()); - module = module.substring(0, module.indexOf("/")); - if (MODULES.keySet().contains(module)) { - try { - boolean isModuleInfo = p.endsWith("module-info.class"); - if (isModuleInfo) { - moduleInfos.add(Files.readAllBytes(p)); - } - byte[] content = Files.readAllBytes(p); - if (p.toString().endsWith(".class") && !isModuleInfo) { - classes.add(toClassName(p)); - } else if (!isModuleInfo) { - MODULES.get(module).add(toResourceFile(p)); - } - resources.add(toPath(p.toString())); - ModuleEntry res = ModuleEntry.create(toPath(p.toString()), content); - pool.add(res); - } catch (Exception ex) { - throw new RuntimeException(ex); - } - } - } - } - } - // There is more than 10 classes in java.base... - if (classes.size() < 10 || pool.getEntryCount() < 10) { - throw new AssertionError("Not expected resource or class number"); - } - - //Add a fake resource file - String content = "java.lang.Object"; - String path = "META-INF/services/com.foo.BarProvider"; - ModuleEntry resFile = ModuleEntry.create("/" + TEST_MODULE + "/" + - path, content.getBytes()); - pool.add(resFile); - ModuleEntry fakeInfoFile = ModuleEntry.create("/" + TEST_MODULE - + "/module-info.class", moduleInfos.get(0)); - pool.add(fakeInfoFile); - MODULES.get(TEST_MODULE).add(path); - for(Map.Entry> entry : MODULES.entrySet()) { - if (entry.getValue().isEmpty()) { - throw new AssertionError("No resource file for " + entry.getKey()); - } - } - this.classes = Collections.unmodifiableList(classes); - this.resources = Collections.unmodifiableList(resources); - } catch (Exception e) { - throw new ExceptionInInitializerError(e); - } - } - - public List getClasses() { - return classes; - } - - public List getResources() { - return resources; - } - - public ModulePool getPool() { - return pool; - } - - public abstract void test() throws Exception; - - public Collection extractClasses(ModulePool pool) { - return pool.entries() - .filter(isClass) - .collect(Collectors.toSet()); - } - - public Collection extractResources(ModulePool pool) { - return pool.entries() - .filter(isClass.negate()) - .collect(Collectors.toSet()); - } - - public String getModule(String path) { - int index = path.indexOf("/", 1); - return path.substring(1, index); - } - - public String removeModule(String path) { - int index = path.indexOf("/", 1); - return path.substring(index + 1); - } - - private String toPath(String p) { - return p.substring("/modules".length()); - } - - private String toClassName(Path p) { - String path = p.toString(); - path = path.substring("/modules/".length()); - // remove module - if (!path.endsWith("module-info.class")) { - path = path.substring(path.indexOf("/") + 1); - } - path = path.substring(0, path.length() - ".class".length()); - - return path; - } - - private String toResourceFile(Path p) { - String path = p.toString(); - path = path.substring("/modules/".length()); - // remove module - path = path.substring(path.indexOf("/") + 1); - - return path; - } - - public abstract class TestPlugin extends AsmPlugin { - - private AsmPools pools; - - public AsmPools getPools() { - return pools; - } - - public boolean isVisitCalled() { - return pools != null; - } - - public ModulePool visit(ModulePool inResources) throws IOException { - try { - ModulePool outResources = new ModulePoolImpl(inResources.getByteOrder(), new StringTable() { - @Override - public int addString(String str) { - return -1; - } - - @Override - public String getString(int id) { - return null; - } - }); - visit(inResources, outResources); - return outResources; - } catch (Exception e) { - throw new IOException(e); - } - } - - @Override - public void visit(AsmPools pools) { - if (isVisitCalled()) { - throw new AssertionError("Visit was called twice"); - } - this.pools = pools; - visit(); - } - - public abstract void visit(); - public abstract void test(ModulePool inResources, ModulePool outResources) throws Exception; - - @Override - public String getName() { - return "test-plugin"; - } - } -} diff --git a/jdk/test/tools/jlink/asmplugin/BasicTest.java b/jdk/test/tools/jlink/asmplugin/BasicTest.java deleted file mode 100644 index afc5fd5f634..00000000000 --- a/jdk/test/tools/jlink/asmplugin/BasicTest.java +++ /dev/null @@ -1,177 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - * Asm plugin testing. - * @test - * @summary Test basic functionality. - * @author Jean-Francois Denise - * @modules java.base/jdk.internal.org.objectweb.asm - * jdk.jlink/jdk.tools.jlink.internal - * jdk.jlink/jdk.tools.jlink.internal.plugins.asm - * @build AsmPluginTestBase - * @run main BasicTest - */ - -import java.io.IOException; -import java.io.UncheckedIOException; -import java.util.ArrayList; -import java.util.HashSet; -import java.util.List; -import java.util.Set; -import java.util.logging.Level; -import java.util.logging.Logger; - -import jdk.internal.org.objectweb.asm.ClassReader; -import jdk.tools.jlink.internal.plugins.asm.AsmModulePool; -import jdk.tools.jlink.internal.plugins.asm.AsmPool; -import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.plugin.ModulePool; - -public class BasicTest extends AsmPluginTestBase { - - public static void main(String[] args) throws Exception { - if (!isImageBuild()) { - System.err.println("Test not run. Not image build."); - return; - } - new BasicTest().test(); - } - - @Override - public void test() throws Exception { - BasicPlugin basicPlugin = new BasicPlugin(getClasses()); - ModulePool res = basicPlugin.visit(getPool()); - basicPlugin.test(getPool(), res); - } - - private class BasicPlugin extends TestPlugin { - - private final List classes; - - public BasicPlugin(List classes) { - this.classes = classes; - } - - @Override - public void visit() { - for (String m : MODULES.keySet()) { - AsmModulePool pool = getPools().getModulePool(m); - if (pool == null) { - throw new AssertionError(m + " pool not found"); - } - if(!pool.getModuleName().equals(m)) { - throw new AssertionError("Invalid module name " + - pool.getModuleName() + " should be "+ m); - } - if (pool.getClasses().size() == 0 && !m.equals(TEST_MODULE)) { - throw new AssertionError("Empty pool " + m); - } - pool.addPackage("toto"); - if (!pool.getTransformedClasses().getClasses().isEmpty()) { - throw new AssertionError("Should be empty"); - } - for(String res : MODULES.get(m)) { - AsmPool.ResourceFile resFile = pool.getResourceFile(res); - if(resFile == null) { - throw new AssertionError("No resource file for " + res); - } - } - } - try { - testPools(); - testVisitor(); - } catch (IOException ex) { - throw new UncheckedIOException(ex); - } - } - - @Override - public void test(ModulePool inResources, ModulePool outResources) throws Exception { - if (!isVisitCalled()) { - throw new AssertionError("Resources not visited"); - } - if (inResources.getEntryCount() != outResources.getEntryCount()) { - throw new AssertionError("Input size " + inResources.getEntryCount() + - " != to " + outResources.getEntryCount()); - } - } - - private void testVisitor() throws IOException { - List seen = new ArrayList<>(); - getPools().getGlobalPool().visitClassReaders((reader) -> { - String className = reader.getClassName(); - // Wrong naming of module-info.class in ASM - if (className.endsWith("module-info")) { - return null; - } - if (!classes.contains(className)) { - throw new AssertionError("Class is not expected " + className); - } - if (getPools().getGlobalPool().getClassReader(className) == null) { - throw new AssertionError("Class not found in pool " + className); - } - seen.add(className); - return null; - }); - - if (!seen.equals(classes)) { - throw new AssertionError("Expected and seen are not equal"); - } - } - - private void testPools() throws IOException { - Set remain = new HashSet<>(classes); - for (ModuleEntry res : getPools().getGlobalPool().getClasses()) { - ClassReader reader = getPools().getGlobalPool().getClassReader(res); - String className = reader.getClassName(); - // Wrong naming of module-info.class in ASM - if (className.endsWith("module-info")) { - continue; - } - if (!classes.contains(className)) { - throw new AssertionError("Class is not expected " + className); - } - if (getPools().getGlobalPool().getClassReader(className) == null) { - throw new AssertionError("Class " + className + " not found in pool "); - } - // Check the module pool - boolean found = false; - for(AsmModulePool mp : getPools().getModulePools()) { - if(mp.getClassReader(className) != null) { - found = true; - break; - } - } - if(!found) { - throw new AssertionError("No modular pool for " + - className); - } - remain.remove(className); - } - if (!remain.isEmpty()) { - throw new AssertionError("Remaining classes " + remain); - } - } - } -} diff --git a/jdk/test/tools/jlink/asmplugin/IdentityPluginTest.java b/jdk/test/tools/jlink/asmplugin/IdentityPluginTest.java deleted file mode 100644 index 416d3581552..00000000000 --- a/jdk/test/tools/jlink/asmplugin/IdentityPluginTest.java +++ /dev/null @@ -1,121 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - * Asm plugin testing. - * @test - * @summary Test basic functionality. - * @author Jean-Francois Denise - * @modules java.base/jdk.internal.org.objectweb.asm - * jdk.jlink/jdk.tools.jlink.internal - * jdk.jlink/jdk.tools.jlink.internal.plugins.asm - * @build AsmPluginTestBase - * @run main IdentityPluginTest - */ - -import java.io.ByteArrayInputStream; -import java.io.IOException; -import java.io.UncheckedIOException; - -import jdk.internal.org.objectweb.asm.ClassReader; -import jdk.internal.org.objectweb.asm.ClassVisitor; -import jdk.internal.org.objectweb.asm.ClassWriter; -import jdk.internal.org.objectweb.asm.Opcodes; -import jdk.tools.jlink.internal.plugins.asm.AsmPool.WritableClassPool; -import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.plugin.ModulePool; - -public class IdentityPluginTest extends AsmPluginTestBase { - - public static void main(String[] args) throws Exception { - if (!isImageBuild()) { - System.err.println("Test not run. Not image build."); - return; - } - new IdentityPluginTest().test(); - } - - public void test() throws Exception { - IdentityPlugin asm = new IdentityPlugin(); - ModulePool resourcePool = asm.visit(getPool()); - asm.test(getPool(), resourcePool); - } - - private class IdentityPlugin extends TestPlugin { - - @Override - public void visit() { - for (ModuleEntry res : getPools().getGlobalPool().getClasses()) { - if (res.getPath().endsWith("module-info.class")) { - continue; - } - ClassReader reader = getPools().getGlobalPool().getClassReader(res); - ClassWriter writer = new ClassWriter(reader, ClassWriter.COMPUTE_FRAMES); - IdentityClassVisitor visitor = new IdentityClassVisitor(writer); - reader.accept(visitor, ClassReader.EXPAND_FRAMES); - getPools().getGlobalPool().getTransformedClasses().addClass(writer); - } - } - - @Override - public void test(ModulePool inResources, ModulePool outResources) throws IOException { - if (outResources.isEmpty()) { - throw new AssertionError("Empty result"); - } - if (!isVisitCalled()) { - throw new AssertionError("Resources not visited"); - } - WritableClassPool transformedClasses = getPools().getGlobalPool().getTransformedClasses(); - if (transformedClasses.getClasses().size() != getClasses().size()) { - throw new AssertionError("Number of transformed classes not equal to expected"); - } - for (String className : getClasses()) { - if (transformedClasses.getClassReader(className) == null) { - throw new AssertionError("Class not transformed " + className); - } - } - outResources.entries().forEach(r -> { - if (r.getPath().endsWith(".class") && !r.getPath().endsWith("module-info.class")) { - try { - ClassReader reader = new ClassReader(new ByteArrayInputStream(r.getBytes())); - ClassWriter w = new ClassWriter(reader, ClassWriter.COMPUTE_FRAMES); - reader.accept(w, ClassReader.EXPAND_FRAMES); - } catch (IOException exp) { - throw new UncheckedIOException(exp); - } - } - }); - } - - @Override - public String getName() { - return "identity-plugin"; - } - } - - private static class IdentityClassVisitor extends ClassVisitor { - public IdentityClassVisitor(ClassWriter cv) { - super(Opcodes.ASM5, cv); - } - } -} diff --git a/jdk/test/tools/jlink/asmplugin/NegativeTest.java b/jdk/test/tools/jlink/asmplugin/NegativeTest.java deleted file mode 100644 index 6263fcaaa4a..00000000000 --- a/jdk/test/tools/jlink/asmplugin/NegativeTest.java +++ /dev/null @@ -1,172 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - * Asm plugin testing. - * @test - * @summary Test basic functionality. - * @author Andrei Eremeev - * @modules java.base/jdk.internal.org.objectweb.asm - * jdk.jlink/jdk.tools.jlink.internal - * jdk.jlink/jdk.tools.jlink.internal.plugins.asm - * @build AsmPluginTestBase - * @run main NegativeTest - */ - -import java.io.IOException; -import java.io.UncheckedIOException; -import java.nio.ByteOrder; -import java.util.Map; -import java.util.Set; -import jdk.internal.org.objectweb.asm.ClassReader; -import jdk.internal.org.objectweb.asm.ClassVisitor; -import jdk.internal.org.objectweb.asm.ClassWriter; -import jdk.internal.org.objectweb.asm.Opcodes; -import jdk.tools.jlink.plugin.Plugin; -import jdk.tools.jlink.internal.ModulePoolImpl; -import jdk.tools.jlink.internal.StringTable; -import jdk.tools.jlink.internal.plugins.asm.AsmGlobalPool; -import jdk.tools.jlink.internal.plugins.asm.AsmModulePool; -import jdk.tools.jlink.internal.plugins.asm.AsmPlugin; -import jdk.tools.jlink.internal.plugins.asm.AsmPool.ResourceFile; -import jdk.tools.jlink.internal.plugins.asm.AsmPools; -import jdk.tools.jlink.plugin.PluginException; -import jdk.tools.jlink.plugin.ModulePool; - -public class NegativeTest extends AsmPluginTestBase { - public static void main(String[] args) throws Exception { - if (!isImageBuild()) { - System.err.println("Test not run. Not image build."); - return; - } - new NegativeTest().test(); - } - - @Override - public void test() throws Exception { - testNull(); - testUnknownPackage(); - } - - private void testUnknownPackage() throws Exception { - AsmPlugin t = new AsmPlugin() { - @Override - public void visit(AsmPools pools) { - try { - AsmGlobalPool globalPool = pools.getGlobalPool(); - AsmModulePool javabase = pools.getModulePool("java.base"); - ClassReader cr = new ClassReader(NegativeTest.class.getResourceAsStream("NegativeTest.class")); - ClassWriter cw = new ClassWriter(cr, ClassWriter.COMPUTE_FRAMES); - cr.accept(new RenameClassVisitor(cw), ClassReader.EXPAND_FRAMES); - action(() -> globalPool.getTransformedClasses().addClass(cw), - "Unknown package", PluginException.class); - action(() -> javabase.getTransformedClasses().addClass(cw), - "Unknown package", PluginException.class); - - ResourceFile newResFile = new ResourceFile("java/aaa/file", new byte[0]); - action(() -> globalPool.getTransformedResourceFiles().addResourceFile(newResFile), - "Unknown package", PluginException.class); - action(() -> javabase.getTransformedResourceFiles().addResourceFile(newResFile), - "Unknown package", PluginException.class); - - action(() -> globalPool.getTransformedClasses().forgetClass("java/aaa/file"), - "Unknown package", PluginException.class); - action(() -> javabase.getTransformedClasses().forgetClass("java/aaa/file"), - "Unknown package", PluginException.class); - action(() -> globalPool.getTransformedResourceFiles().forgetResourceFile("java/aaa/file"), - "Unknown package", PluginException.class); - action(() -> javabase.getTransformedResourceFiles().forgetResourceFile("java/aaa/file"), - "Unknown package", PluginException.class); - } catch (IOException ex) { - throw new UncheckedIOException(ex); - } - } - }; - ModulePool resources = new ModulePoolImpl(ByteOrder.BIG_ENDIAN, new StringTable() { - @Override - public int addString(String str) { - return -1; - } - - @Override - public String getString(int id) { - throw new UnsupportedOperationException("Not supported yet."); - } - }); - t.visit(getPool(), resources); - } - - private static class RenameClassVisitor extends ClassVisitor { - - public RenameClassVisitor(ClassWriter cv) { - super(Opcodes.ASM5, cv); - } - - @Override - public void visit(int version, int access, String name, String signature, String superName, String[] interfaces) { - super.visit(version, access, "RENAMED", signature, superName, interfaces); - } - } - - private void testNull() throws Exception { - AsmPlugin t = new AsmPlugin() { - @Override - public void visit(AsmPools pools) { - action(() -> pools.getModulePool(null), "Module name is null", NullPointerException.class); - action(() -> pools.fillOutputResources(null), "Output resource is null", NullPointerException.class); - } - }; - ModulePool resources = new ModulePoolImpl(ByteOrder.BIG_ENDIAN, new StringTable() { - @Override - public int addString(String str) { - return -1; - } - - @Override - public String getString(int id) { - throw new UnsupportedOperationException("Not supported yet."); - } - }); - action(() -> t.visit(null, resources), "Input resource is null", NullPointerException.class); - action(() -> t.visit(resources, null), "Output resource is null", NullPointerException.class); - t.visit(resources, resources); - } - - private void action(Action action, String message, Class expected) { - try { - System.err.println("Testing: " + message); - action.call(); - throw new AssertionError(message + ": should have failed"); - } catch (Exception e) { - if (!expected.isInstance(e)) { - throw new RuntimeException(e); - } else { - System.err.println("Got exception as expected: " + e); - } - } - } - - private interface Action { - void call() throws Exception; - } -} diff --git a/jdk/test/tools/jlink/asmplugin/PackageMappingTest.java b/jdk/test/tools/jlink/asmplugin/PackageMappingTest.java deleted file mode 100644 index bd0a8fdbf4d..00000000000 --- a/jdk/test/tools/jlink/asmplugin/PackageMappingTest.java +++ /dev/null @@ -1,197 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - * Asm plugin testing. - * @test - * @summary Test plugins - * @author Andrei Eremeev - * @modules jdk.jlink/jdk.tools.jlink.internal - * jdk.jlink/jdk.tools.jlink.internal.plugins.asm - * @run main PackageMappingTest - */ -import java.io.IOException; -import java.nio.ByteBuffer; -import java.util.ArrayList; -import java.util.Arrays; -import java.util.HashMap; -import java.util.HashSet; -import java.util.List; -import java.util.Map; -import java.util.Objects; -import java.util.Set; -import java.util.function.Function; -import java.util.stream.Collectors; - -import jdk.tools.jlink.internal.plugins.asm.AsmGlobalPool; -import jdk.tools.jlink.internal.plugins.asm.AsmModulePool; -import jdk.tools.jlink.internal.plugins.asm.AsmPool.ResourceFile; -import jdk.tools.jlink.internal.plugins.asm.AsmPool.WritableResourcePool; -import jdk.tools.jlink.plugin.PluginException; -import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.plugin.ModulePool; - -public class PackageMappingTest extends AsmPluginTestBase { - - private final List newFiles = Arrays.asList( - "/java.base/a1/bbb/c", - "/" + TEST_MODULE + "/a2/bbb/d" - ); - - public static void main(String[] args) throws Exception { - if (!isImageBuild()) { - System.err.println("Test not run. Not image build."); - return; - } - new PackageMappingTest().test(); - } - - public void test() throws Exception { - TestPlugin[] plugins = new TestPlugin[]{ - new PackageMappingPlugin(newFiles, false), - new PackageMappingPlugin(newFiles, true) - }; - for (TestPlugin p : plugins) { - ModulePool pool = p.visit(getPool()); - p.test(getPool(), pool); - } - } - - public class PackageMappingPlugin extends TestPlugin { - - private final Map> newFiles; - private final boolean testGlobal; - - private String getModuleName(String res) { - return res.substring(1, res.indexOf("/", 1)); - } - - private PackageMappingPlugin(List files, boolean testGlobal) { - this.newFiles = new HashMap<>(); - this.testGlobal = testGlobal; - for (String file : files) { - String moduleName = getModuleName(file); - String path = file.substring(1 + moduleName.length() + 1); - newFiles.computeIfAbsent(moduleName, $ -> new ArrayList<>()).add( - new ResourceFile(path, new byte[0])); - } - } - - @Override - public void visit() { - testMapToUnknownModule(); - testMapPackageTwice(); - testPackageMapping(); - } - - @Override - public void test(ModulePool inResources, ModulePool outResources) { - Set in = getPools().getGlobalPool().getResourceFiles().stream() - .map(ModuleEntry::getPath) - .collect(Collectors.toSet()); - Set out = extractResources(outResources).stream() - .map(ModuleEntry::getPath) - .collect(Collectors.toSet()); - in.addAll(PackageMappingTest.this.newFiles); - if (!Objects.equals(in, out)) { - throw new AssertionError("Expected: " + in + ", got: " + outResources); - } - } - - private void testPackageMapping() { - AsmGlobalPool globalPool = getPools().getGlobalPool(); - try { - Map> mappedPackages = new HashMap<>(); - Function> produceSet = $ -> new HashSet<>(); - for (Map.Entry> entry : newFiles.entrySet()) { - String moduleName = entry.getKey(); - Set module = mappedPackages.computeIfAbsent(moduleName, produceSet); - AsmModulePool modulePool = getPools().getModulePool(moduleName); - for (ResourceFile r : entry.getValue()) { - String name = r.getPath(); - String packageName = name.substring(0, name.lastIndexOf('/')); - if (module.add(packageName)) { - globalPool.addPackageModuleMapping(packageName, moduleName); - } - WritableResourcePool transformedResourceFiles = testGlobal - ? globalPool.getTransformedResourceFiles() - : modulePool.getTransformedResourceFiles(); - transformedResourceFiles.addResourceFile(r); - } - try { - modulePool.getTransformedResourceFiles().addResourceFile( - new ResourceFile("a3/bbb", new byte[0])); - throw new AssertionError("Exception expected"); - } catch (Exception ex) { - // expected - } - } - try { - globalPool.getTransformedResourceFiles().addResourceFile( - new ResourceFile("a3/bbb", new byte[0])); - throw new AssertionError("Exception expected"); - } catch (Exception ex) { - // expected - } - } catch (Exception e) { - throw new RuntimeException(e); - } - } - - private void testMapPackageTwice() { - try { - AsmGlobalPool globalPool = getPools().getGlobalPool(); - globalPool.addPackageModuleMapping("a/p1", TEST_MODULE); - globalPool.addPackageModuleMapping("a/p1", TEST_MODULE); - throw new AssertionError("Exception expected after mapping a package twice to the same module"); - } catch (Exception e) { - if (e instanceof PluginException) { - // expected - String message = e.getMessage(); - if (!(TEST_MODULE + " module already contains package a.p1").equals(message)) { - throw new AssertionError(e); - } - } else { - throw new AssertionError(e); - } - } - } - - private void testMapToUnknownModule() { - AsmModulePool unknownModule = getPools().getModulePool("UNKNOWN"); - if (unknownModule != null) { - throw new AssertionError("getModulePool returned not null value: " + unknownModule.getModuleName()); - } - try { - AsmGlobalPool globalPool = getPools().getGlobalPool(); - globalPool.addPackageModuleMapping("a/b", "UNKNOWN"); - throw new AssertionError("Exception expected after mapping a package to unknown module"); - } catch (Exception e) { - String message = e.getMessage(); - if (message == null || !message.startsWith("Unknown module UNKNOWN")) { - throw new AssertionError(e); - } - } - } - } -} diff --git a/jdk/test/tools/jlink/asmplugin/SortingTest.java b/jdk/test/tools/jlink/asmplugin/SortingTest.java deleted file mode 100644 index 26974b3b065..00000000000 --- a/jdk/test/tools/jlink/asmplugin/SortingTest.java +++ /dev/null @@ -1,183 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - * Asm plugin testing. - * @test - * @summary Test resource sorting. - * @author Jean-Francois Denise - * @modules jdk.jlink/jdk.tools.jlink.internal - * jdk.jlink/jdk.tools.jlink.internal.plugins.asm - * @build AsmPluginTestBase - * @run main SortingTest - */ - -import java.io.IOException; -import java.util.ArrayList; -import java.util.List; -import java.util.Optional; -import java.util.stream.Collectors; - -import jdk.tools.jlink.internal.plugins.asm.AsmModulePool; -import jdk.tools.jlink.plugin.PluginException; -import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.plugin.ModulePool; - -public class SortingTest extends AsmPluginTestBase { - - public static void main(String[] args) throws Exception { - if (!isImageBuild()) { - System.err.println("Test not run. Not image build."); - return; - } - new SortingTest().test(); - } - - @Override - public void test() { - try { - classSorting(); - moduleSorting(); - } catch (Exception ex) { - throw new PluginException(ex); - } - } - - private void classSorting() throws Exception { - List sorted = new ArrayList<>(getResources()); - sorted.sort(null); - ClassSorterPlugin sorterPlugin = new ClassSorterPlugin(sorted); - ModulePool resourcePool = sorterPlugin.visit(getPool()); - sorterPlugin.test(getPool(), resourcePool); - } - - private String getModuleName(String p) { - return p.substring(1, p.indexOf('/', 1)); - } - - private void moduleSorting() throws Exception { - List sorted = new ArrayList<>(getResources()); - sorted.sort((s1, s2) -> -getModuleName(s1).compareTo(getModuleName(s2))); - ModuleSorterPlugin sorterPlugin = new ModuleSorterPlugin(); - ModulePool resourcePool = sorterPlugin.visit(getPool()); - sorterPlugin.test(getPool(), resourcePool); - } - - private class ModuleSorterPlugin extends TestPlugin { - - @Override - public void visit() { - for (AsmModulePool modulePool : getPools().getModulePools()) { - modulePool.setSorter(resources -> { - List sort = resources.entries() - .map(ModuleEntry::getPath) - .collect(Collectors.toList()); - sort.sort(null); - return sort; - }); - } - getPools().setModuleSorter(modules -> { - modules.sort((s1, s2) -> -s1.compareTo(s2)); - return modules; - }); - } - - @Override - public void test(ModulePool inResources, ModulePool outResources) throws Exception { - if (!isVisitCalled()) { - throw new AssertionError("Resources not visited"); - } - List sortedResourcePaths = outResources.entries() - .map(ModuleEntry::getPath) - .collect(Collectors.toList()); - - List defaultResourceOrder = new ArrayList<>(); - inResources.entries().forEach(r -> { - if (!inResources.contains(r)) { - throw new AssertionError("Resource " + r.getPath() + " not in result pool"); - } - defaultResourceOrder.add(r.getPath()); - }); - // Check that default sorting is not equal to sorted one - if (defaultResourceOrder.equals(sortedResourcePaths)) { - throw new AssertionError("Sorting not applied, default ordering"); - } - // Check module order. - for (int i = 0; i < sortedResourcePaths.size() - 1; ++i) { - String first = sortedResourcePaths.get(i); - String p1 = getModuleName(first); - String second = sortedResourcePaths.get(i + 1); - String p2 = getModuleName(second); - if (p1.compareTo(p2) < 0 || p1.compareTo(p2) == 0 && - removeModule(first).compareTo(removeModule(second)) >= 0) { - throw new AssertionError("Modules are not sorted properly: resources: " + first + " " + second); - } - } - } - } - - private class ClassSorterPlugin extends TestPlugin { - - private final List expectedClassesOrder; - - private ClassSorterPlugin(List expectedClassesOrder) { - this.expectedClassesOrder = expectedClassesOrder; - } - - @Override - public void visit() { - getPools().getGlobalPool().setSorter( - (resources) -> expectedClassesOrder.stream() - .map(resources::findEntry) - .map(Optional::get) - .map(ModuleEntry::getPath) - .collect(Collectors.toList())); - } - - @Override - public void test(ModulePool inResources, ModulePool outResources) throws Exception { - if (!isVisitCalled()) { - throw new AssertionError("Resources not visited"); - } - List sortedResourcePaths = outResources.entries() - .map(ModuleEntry::getPath) - .collect(Collectors.toList()); - - List defaultResourceOrder = new ArrayList<>(); - getPool().entries().forEach(r -> { - if (!getPool().contains(r)) { - throw new AssertionError("Resource " + r.getPath() + " not in result pool"); - } - defaultResourceOrder.add(r.getPath()); - }); - // Check that default sorting is not equal to sorted one - if (defaultResourceOrder.equals(sortedResourcePaths)) { - throw new AssertionError("Sorting not applied, default ordering"); - } - // Check that sorted is equal to result. - if (!expectedClassesOrder.equals(sortedResourcePaths)) { - throw new AssertionError("Sorting not properly applied"); - } - } - } -} diff --git a/jdk/test/tools/jlink/asmplugin/VisitorTest.java b/jdk/test/tools/jlink/asmplugin/VisitorTest.java deleted file mode 100644 index 500d415bc50..00000000000 --- a/jdk/test/tools/jlink/asmplugin/VisitorTest.java +++ /dev/null @@ -1,219 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - * Asm plugin testing. - * @test - * @summary Test visitors. - * @author Andrei Eremeev - * @modules java.base/jdk.internal.org.objectweb.asm - * jdk.jlink/jdk.tools.jlink.internal - * jdk.jlink/jdk.tools.jlink.internal.plugins.asm - * @build AsmPluginTestBase - * @run main VisitorTest - */ - -import java.io.IOException; -import java.util.Collection; -import java.util.function.Function; - -import jdk.internal.org.objectweb.asm.ClassReader; -import jdk.internal.org.objectweb.asm.ClassVisitor; -import jdk.internal.org.objectweb.asm.ClassWriter; -import jdk.internal.org.objectweb.asm.Opcodes; -import jdk.tools.jlink.internal.plugins.asm.AsmPool; -import jdk.tools.jlink.internal.plugins.asm.AsmPool.ClassReaderVisitor; -import jdk.tools.jlink.internal.plugins.asm.AsmPool.ResourceFile; -import jdk.tools.jlink.internal.plugins.asm.AsmPool.ResourceFileVisitor; -import jdk.tools.jlink.internal.plugins.asm.AsmPools; -import jdk.tools.jlink.plugin.ModuleEntry; -import jdk.tools.jlink.plugin.ModulePool; - -public class VisitorTest extends AsmPluginTestBase { - - public static void main(String[] args) throws Exception { - if (!isImageBuild()) { - System.err.println("Test not run. Not image build."); - return; - } - new VisitorTest().test(); - } - - @Override - public void test() throws Exception { - TestPlugin[] plugins = new TestPlugin[] { - new ClassVisitorPlugin("Class-global-pool", AsmPools::getGlobalPool), - new ClassVisitorPlugin("Class-module-pool", pools -> pools.getModulePool("java.base")), - new ResourceVisitorPlugin("Resource-global-pool", AsmPools::getGlobalPool), - new ResourceVisitorPlugin("Resource-module-pool", pools -> pools.getModulePool("java.base")) - }; - for (TestPlugin p : plugins) { - System.err.println("Testing: " + p.getName()); - ModulePool out = p.visit(getPool()); - p.test(getPool(), out); - } - } - - private static class CustomClassReaderVisitor implements ClassReaderVisitor { - private int amount = 0; - private int changed = 0; - - @Override - public ClassWriter visit(ClassReader reader) { - if ((amount++ % 2) == 0) { - String className = reader.getClassName(); - if (className.endsWith("module-info")) { - return null; - } - ClassWriter cw = new ClassWriter(reader, ClassWriter.COMPUTE_FRAMES); - reader.accept(new ClassVisitor(Opcodes.ASM5, cw) { - @Override - public void visit(int i, int i1, String s, String s1, String s2, String[] strings) { - super.visit(i, i1, s + "Changed", s1, s2, strings); - } - }, ClassReader.EXPAND_FRAMES); - ++changed; - return cw; - } else { - return null; - } - } - - public int getAmount() { - return amount; - } - - public int getNumberOfChanged() { - return changed; - } - } - - private static class CustomResourceFileVisitor implements ResourceFileVisitor { - private int amount = 0; - private int changed = 0; - - @Override - public ResourceFile visit(ResourceFile resourceFile) { - if ((amount++ % 2) == 0) { - ++changed; - return new ResourceFile(resourceFile.getPath() + "Changed", resourceFile.getContent()); - } else { - return null; - } - } - - public int getAmount() { - return amount; - } - - public int getNumberOfChanged() { - return changed; - } - } - - public class ClassVisitorPlugin extends TestPlugin { - - private final String name; - private final Function getPool; - private final CustomClassReaderVisitor classReaderVisitor = new CustomClassReaderVisitor(); - - public ClassVisitorPlugin(String name, Function getPool) { - this.name = name; - this.getPool = getPool; - } - - @Override - public void visit() { - AsmPool pool = getPool.apply(getPools()); - pool.visitClassReaders(classReaderVisitor); - } - - @Override - public void test(ModulePool in, ModulePool out) throws Exception { - Collection inClasses = getPool.apply(getPools()).getClasses(); - if (inClasses.size() != classReaderVisitor.getAmount()) { - throw new AssertionError("Testing " + name + ". Number of visited classes. Expected: " + - inClasses.size() + ", got: " + classReaderVisitor.getAmount()); - } - Collection outClasses = extractClasses(out); - int changedClasses = 0; - for (ModuleEntry r : outClasses) { - if (r.getPath().endsWith("Changed.class")) { - ++changedClasses; - } - } - if (changedClasses != classReaderVisitor.getNumberOfChanged()) { - throw new AssertionError("Testing " + name + ". Changed classes. Expected: " + changedClasses + - ", got: " + classReaderVisitor.getNumberOfChanged()); - } - } - - @Override - public String getName() { - return name; - } - } - - public class ResourceVisitorPlugin extends TestPlugin { - - private final String name; - private final Function getPool; - private final CustomResourceFileVisitor resourceFileVisitor = new CustomResourceFileVisitor(); - - public ResourceVisitorPlugin(String name, Function getPool) { - this.name = name; - this.getPool = getPool; - } - - @Override - public void visit() { - AsmPool pool = getPool.apply(getPools()); - pool.visitResourceFiles(resourceFileVisitor); - } - - @Override - public void test(ModulePool in, ModulePool out) throws Exception { - Collection inResources = getPool.apply(getPools()).getResourceFiles(); - if (inResources.size() != resourceFileVisitor.getAmount()) { - throw new AssertionError("Testing " + name + ". Number of visited resources. Expected: " + - inResources.size() + ", got: " + resourceFileVisitor.getAmount()); - } - Collection outResources = extractResources(out); - int changedClasses = 0; - for (ModuleEntry r : outResources) { - if (r.getPath().endsWith("Changed")) { - ++changedClasses; - } - } - if (changedClasses != resourceFileVisitor.getNumberOfChanged()) { - throw new AssertionError("Testing " + name + ". Changed classes. Expected: " + changedClasses + - ", got: " + resourceFileVisitor.getNumberOfChanged()); - } - } - - @Override - public String getName() { - return name; - } - } -} diff --git a/jdk/test/tools/jlink/plugins/PluginOrderTest.java b/jdk/test/tools/jlink/plugins/PluginOrderTest.java deleted file mode 100644 index 0116882c78f..00000000000 --- a/jdk/test/tools/jlink/plugins/PluginOrderTest.java +++ /dev/null @@ -1,271 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - - /* - * @test - * @summary Test order of plugins - * @author Jean-Francois Denise - * @library ../../lib - * @modules java.base/jdk.internal.jimage - * jdk.jdeps/com.sun.tools.classfile - * jdk.jlink/jdk.tools.jlink.internal - * jdk.jlink/jdk.tools.jmod - * jdk.jlink/jdk.tools.jimage - * jdk.compiler - * @build tests.* - * @run main/othervm PluginOrderTest - */ -import java.util.ArrayList; -import java.util.Collections; -import java.util.HashSet; -import java.util.List; -import java.util.Map; -import java.util.Set; - -import jdk.tools.jlink.internal.PluginOrderingGraph; -import jdk.tools.jlink.plugin.Plugin; -import jdk.tools.jlink.plugin.Plugin.Category; -import jdk.tools.jlink.plugin.ModulePool; - -public class PluginOrderTest { - - public static void main(String[] args) throws Exception { - - validGraph0(); - validGraph1(); - - boolean failed = false; - - try { - withCycles0(); - failed = true; - } catch (Exception ex) { - //ok - System.err.println(ex.getMessage()); - } - if (failed) { - throw new Exception("Should have failed"); - } - - try { - withCycles1(); - failed = true; - } catch (Exception ex) { - //ok - System.err.println(ex.getMessage()); - } - if (failed) { - throw new Exception("Should have failed"); - } - - try { - withCycles2(); - failed = true; - } catch (Exception ex) { - //ok - System.err.println(ex.getMessage()); - } - if (failed) { - throw new Exception("Should have failed"); - } - } - - private static void validGraph0() throws Exception { - Set set = new HashSet<>(); - set.add("plug2"); - List plugins = new ArrayList<>(); - plugins.add(new Plug("plug2", Collections.emptySet(), Collections.emptySet(), - Category.TRANSFORMER)); - plugins.add(new Plug("plug1", set, Collections.emptySet(), Category.TRANSFORMER)); - List ordered = PluginOrderingGraph.sort(plugins); - if (ordered.get(0) != plugins.get(1) || ordered.get(1) != plugins.get(0)) { - throw new Exception("Invalid sorting"); - } - } - - private static void validGraph1() { - Set lst1 = new HashSet<>(); - lst1.add("plug2"); - lst1.add("plug3"); - Plugin p1 = new Plug("plug1", lst1, Collections.emptySet(), Category.TRANSFORMER); - - Plugin p2 = new Plug("plug2", Collections.emptySet(), Collections.emptySet(), Category.TRANSFORMER); - - Set lst3 = new HashSet<>(); - lst3.add("plug4"); - lst3.add("plug6"); - Plugin p3 = new Plug("plug3", lst3, Collections.emptySet(), Category.TRANSFORMER); - - Plugin p4 = new Plug("plug4", Collections.emptySet(), Collections.emptySet(), Category.TRANSFORMER); - - Set lst5 = new HashSet<>(); - lst5.add("plug3"); - lst5.add("plug1"); - lst5.add("plug2"); - lst5.add("plug6"); - Plugin p5 = new Plug("plug5", lst5, Collections.emptySet(), Category.TRANSFORMER); - - Set lst6 = new HashSet<>(); - lst6.add("plug4"); - lst6.add("plug2"); - Plugin p6 = new Plug("plug6", lst6, Collections.emptySet(), Category.TRANSFORMER); - - Plugin p7 = new Plug("plug7", Collections.emptySet(), Collections.emptySet(), Category.TRANSFORMER); - - Plugin p8 = new Plug("plug8", Collections.emptySet(), Collections.emptySet(), Category.TRANSFORMER); - - List plugins = new ArrayList<>(); - plugins.add(p1); - plugins.add(p2); - plugins.add(p3); - plugins.add(p4); - plugins.add(p5); - plugins.add(p6); - plugins.add(p7); - plugins.add(p8); - - PluginOrderingGraph.sort(plugins); - } - - private static void withCycles0() throws Exception { - Set set2 = new HashSet<>(); - set2.add("plug1"); - List plugins = new ArrayList<>(); - plugins.add(new Plug("plug2", set2, Collections.emptySet(), - Category.TRANSFORMER)); - - Set set1 = new HashSet<>(); - set1.add("plug2"); - plugins.add(new Plug("plug1", set1, Collections.emptySet(), Category.TRANSFORMER)); - PluginOrderingGraph.sort(plugins); - - } - - private static void withCycles2() { - Set lst1 = new HashSet<>(); - lst1.add("plug2"); - lst1.add("plug3"); - Plugin p1 = new Plug("plug1", lst1, Collections.emptySet(), Category.TRANSFORMER); - - Plugin p2 = new Plug("plug2", Collections.emptySet(), Collections.emptySet(), Category.TRANSFORMER); - - Set lst3 = new HashSet<>(); - lst3.add("plug4"); - lst3.add("plug6"); - Plugin p3 = new Plug("plug3", lst3, Collections.emptySet(), Category.TRANSFORMER); - - Plugin p4 = new Plug("plug4", Collections.emptySet(), Collections.emptySet(), Category.TRANSFORMER); - - Set lst5 = new HashSet<>(); - lst5.add("plug3"); - lst5.add("plug1"); - lst5.add("plug2"); - Plugin p5 = new Plug("plug5", lst5, Collections.emptySet(), Category.TRANSFORMER); - - Set lst6 = new HashSet<>(); - lst6.add("plug4"); - lst6.add("plug1"); - Plugin p6 = new Plug("plug6", lst6, Collections.emptySet(), Category.TRANSFORMER); - - Plugin p7 = new Plug("plug7", Collections.emptySet(), Collections.emptySet(), Category.TRANSFORMER); - - Plugin p8 = new Plug("plug8", Collections.emptySet(), Collections.emptySet(), Category.TRANSFORMER); - - List plugins = new ArrayList<>(); - plugins.add(p1); - plugins.add(p2); - plugins.add(p3); - plugins.add(p4); - plugins.add(p5); - plugins.add(p6); - plugins.add(p7); - plugins.add(p8); - PluginOrderingGraph.sort(plugins); - } - - private static void withCycles1() { - Set lst1 = new HashSet<>(); - lst1.add("plug2"); - lst1.add("plug3"); - Plugin p = new Plug("plug1", lst1, Collections.emptySet(), Category.TRANSFORMER); - Plugin p2 = new Plug("plug2", Collections.emptySet(), Collections.emptySet(), Category.TRANSFORMER); - - Set lst3 = new HashSet<>(); - lst3.add("plug2"); - - Set lst4 = new HashSet<>(); - lst4.add("plug1"); - - Plugin p3 = new Plug("plug3", lst4, lst3, Category.TRANSFORMER); - List plugins = new ArrayList<>(); - plugins.add(p); - plugins.add(p2); - plugins.add(p3); - PluginOrderingGraph.sort(plugins); - } - - private static class Plug implements Plugin { - - private final Set isBefore; - private final Set isAfter; - private final Category category; - private final String name; - - private Plug(String name, Set isBefore, Set isAfter, Category category) { - this.name = name; - this.isBefore = isBefore; - this.isAfter = isAfter; - this.category = category; - } - - @Override - public Set isAfter() { - return isAfter; - } - - @Override - public Set isBefore() { - return isBefore; - } - - @Override - public String toString() { - return name; - } - - @Override - public void visit(ModulePool in, ModulePool out) { - - } - - @Override - public Category getType() { - return category; - } - - @Override - public String getName() { - return name; - } - } -} diff --git a/make/CompileJavaModules.gmk b/make/CompileJavaModules.gmk index ed603cd8717..a53f2b13887 100644 --- a/make/CompileJavaModules.gmk +++ b/make/CompileJavaModules.gmk @@ -205,11 +205,6 @@ ifdef BUILD_HEADLESS_ONLY java.desktop_EXCLUDES += sun/applet endif -# Why is this in the open source tree? -ifdef OPENJDK - java.desktop_EXCLUDES += sun/dc -endif - # Used on windows and macosx ifeq ($(filter $(OPENJDK_TARGET_OS), windows macosx), ) java.desktop_EXCLUDE_FILES += sun/awt/AWTCharset.java diff --git a/make/Images.gmk b/make/Images.gmk index 385b741bb58..7ba95286f91 100644 --- a/make/Images.gmk +++ b/make/Images.gmk @@ -207,12 +207,6 @@ ifneq ($(OPENJDK_TARGET_OS), windows) tnameserv.1 \ unpack200.1 - ifndef OPENJDK - ifneq ($(OPENJDK_TARGET_OS), solaris) - JRE_MAN_PAGES += javaws.1 - endif - endif - JDK_MAN_PAGES += \ $(JRE_MAN_PAGES) \ appletviewer.1 \ diff --git a/make/Javadoc.gmk b/make/Javadoc.gmk index 4d946139940..f194dd95f89 100644 --- a/make/Javadoc.gmk +++ b/make/Javadoc.gmk @@ -290,19 +290,15 @@ $(call CopyrightLine,$(COPYRIGHT_URL),$(FIRST_COPYRIGHT_YEAR),)\ # Common javadoc options used by all bundles -ifdef OPENJDK - ADDITIONAL_JAVADOCFLAGS = \ - -Xdocrootparent $(DOCS_BASE_URL) -else - ADDITIONAL_JAVADOCFLAGS = -endif +# This flag may be overridden from a custom makefile +DOCROOTPARENT_FLAG = -Xdocrootparent $(DOCS_BASE_URL) define COMMON_JAVADOCFLAGS $(call OptionOnly,-XDignore.symbol.file=true) ; \ $(call OptionOnly,-quiet) ; \ $(call OptionOnly,-use) ; \ $(call OptionOnly,-keywords) ; \ - $(call OptionOnly,$(ADDITIONAL_JAVADOCFLAGS)) + $(call OptionOnly,$(DOCROOTPARENT_FLAG)) endef # Common javadoc tags used by all bundles @@ -1038,8 +1034,6 @@ ALL_OTHER_TARGETS += mgmtdocs MGMT_DOCDIR := $(JRE_API_DOCSDIR)/management/extension MGMT2COREAPI := ../../$(JDKJRE2COREAPI) -JVM_MIB_NAME := JVM-MANAGEMENT-MIB.mib -JVM_MIB_SRC := $(JDK_TOPDIR)/src/closed/jdk.snmp/share/classes/sun/management/snmp/$(JVM_MIB_NAME) MGMT_DOCTITLE := Monitoring and Management Interface for the Java$(TRADEMARK) Platform MGMT_WINDOWTITLE := Monitoring and Management Interface for the Java Platform MGMT_HEADER := Monitoring and Management Interface for the Java Platform @@ -1063,11 +1057,6 @@ $(MGMT_INDEX_FILE): GET2DOCSDIR=$(MGMT2COREAPI)/.. # Run javadoc if the index file is out of date or missing $(MGMT_INDEX_FILE): $(MGMT_OPTIONS_FILE) $(MGMT_PACKAGES_FILE) $(COREAPI_INDEX_FILE) $(prep-javadoc) - @if [ -f $(JVM_MIB_SRC) ] ; then \ - $(CP) $(JVM_MIB_SRC) $(@D)/.. ; \ - else \ - $(ECHO) "WARNING: File $(JVM_MIB_NAME) not available."; \ - fi $(call JavadocSummary,$(MGMT_OPTIONS_FILE),$(MGMT_PACKAGES_FILE)) $(JAVADOC_CMD_SMALL) -d $(@D) \ @$(MGMT_OPTIONS_FILE) @$(MGMT_PACKAGES_FILE) @@ -1223,8 +1212,7 @@ JSHELLAPI_DOCTITLE := JShell API JSHELLAPI_WINDOWTITLE := JShell API JSHELLAPI_HEADER := JSHELL API JSHELLAPI_BOTTOM := $(call CommonBottom,$(JSHELLAPI_FIRST_COPYRIGHT_YEAR)) -JSHELLAPI_GROUPNAME := Packages -JSHELLAPI_REGEXP := jdk.jshell.* +JSHELLAPI_OVERVIEW := $(LANGTOOLS_TOPDIR)/src/jdk.jshell/share/classes/jdk/jshell/overview.html # JSHELLAPI_PKGS is located in NON_CORE_PKGS.gmk JSHELLAPI_INDEX_HTML = $(JSHELLAPI_DOCDIR)/index.html @@ -1256,11 +1244,11 @@ $(JSHELLAPI_OPTIONS_FILE): $(call OptionPair,-modulesourcepath,$(RELEASEDOCS_MODULESOURCEPATH)) ; \ $(call OptionPair,-addmods,$(JSHELLAPI_MODULES)) ; \ $(call OptionPair,-encoding,ascii) ; \ + $(call OptionPair,-overview,$(JSHELLAPI_OVERVIEW)) ; \ $(call OptionPair,-doctitle,$(JSHELLAPI_DOCTITLE)) ; \ $(call OptionPair,-windowtitle,$(JSHELLAPI_WINDOWTITLE) $(DRAFT_WINTITLE)); \ $(call OptionPair,-header,$(JSHELLAPI_HEADER)$(DRAFT_HEADER)) ; \ $(call OptionPair,-bottom,$(JSHELLAPI_BOTTOM)$(DRAFT_BOTTOM)) ; \ - $(call OptionTrip,-group,$(JSHELLAPI_GROUPNAME),$(JSHELLAPI_REGEXP)); \ $(call OptionTrip,-linkoffline,$(JSHELLAPI2COREAPI),$(COREAPI_DOCSDIR)/); \ ) >> $@ @@ -1705,3 +1693,7 @@ $(JAVADOC_ARCHIVE): $(COREAPI_INDEX_FILE) ############################################################# .PHONY: all docs coredocs otherdocs \ $(ALL_OTHER_TARGETS) zip-docs + +################################################################################ + +$(eval $(call IncludeCustomExtension, , Javadoc-post.gmk)) diff --git a/make/Main.gmk b/make/Main.gmk index 8c9bd9e5676..d2c74611d4f 100644 --- a/make/Main.gmk +++ b/make/Main.gmk @@ -933,10 +933,6 @@ create-main-targets-include: ################################################################################ - -# workaround issue when building open targets when closed jib-profiles.js is used -installer: product-images test-image - .PHONY: $(ALL_TARGETS) FRC: # Force target diff --git a/make/common/NON_CORE_PKGS.gmk b/make/common/NON_CORE_PKGS.gmk index b6ef5a9d450..ad546a4456d 100644 --- a/make/common/NON_CORE_PKGS.gmk +++ b/make/common/NON_CORE_PKGS.gmk @@ -81,7 +81,9 @@ ATTACH_PKGS = com.sun.tools.attach \ JCONSOLE_PKGS = com.sun.tools.jconsole -JSHELLAPI_PKGS = jdk.jshell +JSHELLAPI_PKGS = jdk.jshell \ + jdk.jshell.spi \ + jdk.jshell.execution TREEAPI_PKGS = com.sun.source.doctree \ com.sun.source.tree \ diff --git a/test/jtreg-ext/requires/VMProps.java b/test/jtreg-ext/requires/VMProps.java index 7bb67f32828..945d754199e 100644 --- a/test/jtreg-ext/requires/VMProps.java +++ b/test/jtreg-ext/requires/VMProps.java @@ -34,6 +34,7 @@ import java.util.Map; import java.util.concurrent.Callable; import java.util.regex.Matcher; import java.util.regex.Pattern; +import sun.hotspot.gc.GC; /** * The Class to be invoked by jtreg prior Test Suite execution to @@ -56,11 +57,12 @@ public class VMProps implements Callable> { map.put("vm.bits", vmBits()); map.put("vm.flightRecorder", vmFlightRecorder()); map.put("vm.simpleArch", vmArch()); + vmGC(map); // vm.gc.X = true/false + dump(map); return map; } - /** * @return vm.simpleArch value of "os.simpleArch" property of tested JDK. */ @@ -146,6 +148,24 @@ public class VMProps implements Callable> { return "false"; } + /** + * For all existing GC sets vm.gc.X property. + * Example vm.gc.G1=true means: + * VM supports G1 + * User either set G1 explicitely (-XX:+UseG1GC) or did not set any GC + * @param map - property-value pairs + */ + protected void vmGC(Map map){ + GC currentGC = GC.current(); + boolean isByErgo = GC.currentSetByErgo(); + List supportedGC = GC.allSupported(); + for (GC gc: GC.values()) { + boolean isSupported = supportedGC.contains(gc); + boolean isAcceptable = isSupported && (gc == currentGC || isByErgo); + map.put("vm.gc." + gc.name(), "" + isAcceptable); + } + } + /** * Dumps the map to the file if the file name is given as the property. * This functionality could be helpful to know context in the real