diff --git a/src/hotspot/os/linux/os_linux.cpp b/src/hotspot/os/linux/os_linux.cpp
index 32b6bcb23f4..1a582c9d444 100644
--- a/src/hotspot/os/linux/os_linux.cpp
+++ b/src/hotspot/os/linux/os_linux.cpp
@@ -4699,19 +4699,46 @@ int os::active_processor_count() {
return active_cpus;
}
+static bool should_warn_invalid_processor_id() {
+ if (os::processor_count() == 1) {
+ // Don't warn if we only have one processor
+ return false;
+ }
+
+ static volatile int warn_once = 1;
+
+ if (Atomic::load(&warn_once) == 0 ||
+ Atomic::xchg(&warn_once, 0) == 0) {
+ // Don't warn more than once
+ return false;
+ }
+
+ return true;
+}
+
uint os::processor_id() {
const int id = Linux::sched_getcpu();
-#ifndef PRODUCT
- if (UseDebuggerErgo1 && id >= _processor_count) {
- // Some debuggers limit the processor count without limiting
- // the returned processor ids. Fake the processor id.
- return 0;
+ if (id < processor_count()) {
+ return (uint)id;
}
-#endif
- assert(id >= 0 && id < _processor_count, "Invalid processor id [%d]", id);
- return (uint)id;
+ // Some environments (e.g. openvz containers and the rr debugger) incorrectly
+ // report a processor id that is higher than the number of processors available.
+ // This is problematic, for example, when implementing CPU-local data structures,
+ // where the processor id is used to index into an array of length processor_count().
+ // If this happens we return 0 here. This is is safe since we always have at least
+ // one processor, but it's not optimal for performance if we're actually executing
+ // in an environment with more than one processor.
+ if (should_warn_invalid_processor_id()) {
+ log_warning(os)("Invalid processor id reported by the operating system "
+ "(got processor id %d, valid processor id range is 0-%d)",
+ id, processor_count() - 1);
+ log_warning(os)("Falling back to assuming processor id is 0. "
+ "This could have a negative impact on performance.");
+ }
+
+ return 0;
}
void os::set_native_thread_name(const char *name) {
diff --git a/src/hotspot/share/gc/parallel/mutableSpace.cpp b/src/hotspot/share/gc/parallel/mutableSpace.cpp
index e0748fe85bc..62b52fecd9d 100644
--- a/src/hotspot/share/gc/parallel/mutableSpace.cpp
+++ b/src/hotspot/share/gc/parallel/mutableSpace.cpp
@@ -133,7 +133,11 @@ void MutableSpace::initialize(MemRegion mr,
}
set_bottom(mr.start());
- set_end(mr.end());
+ // When expanding concurrently with callers of cas_allocate, setting end
+ // makes the new space available for allocation by other threads. So this
+ // assignment must follow all other configuration and initialization that
+ // might be done for expansion.
+ Atomic::release_store(end_addr(), mr.end());
if (clear_space) {
clear(mangle_space);
diff --git a/src/hotspot/share/gc/parallel/psOldGen.cpp b/src/hotspot/share/gc/parallel/psOldGen.cpp
index 187922d7e14..1b97f949628 100644
--- a/src/hotspot/share/gc/parallel/psOldGen.cpp
+++ b/src/hotspot/share/gc/parallel/psOldGen.cpp
@@ -35,7 +35,6 @@
#include "logging/log.hpp"
#include "oops/oop.inline.hpp"
#include "runtime/java.hpp"
-#include "runtime/orderAccess.hpp"
#include "utilities/align.hpp"
PSOldGen::PSOldGen(ReservedSpace rs, size_t initial_size, size_t min_size,
@@ -354,9 +353,9 @@ void PSOldGen::post_resize() {
WorkGang* workers = Thread::current()->is_VM_thread() ?
&ParallelScavengeHeap::heap()->workers() : NULL;
- // Ensure the space bounds are updated and made visible to other
- // threads after the other data structures have been resized.
- OrderAccess::storestore();
+ // The update of the space's end is done by this call. As that
+ // makes the new space available for concurrent allocation, this
+ // must be the last step when expanding.
object_space()->initialize(new_memregion,
SpaceDecorator::DontClear,
SpaceDecorator::DontMangle,
diff --git a/src/hotspot/share/gc/shenandoah/c2/shenandoahSupport.cpp b/src/hotspot/share/gc/shenandoah/c2/shenandoahSupport.cpp
index f1b97c6ec20..8b7e5c10f6d 100644
--- a/src/hotspot/share/gc/shenandoah/c2/shenandoahSupport.cpp
+++ b/src/hotspot/share/gc/shenandoah/c2/shenandoahSupport.cpp
@@ -2285,7 +2285,7 @@ void MemoryGraphFixer::collect_memory_nodes() {
uint last = _phase->C->unique();
#ifdef ASSERT
- uint8_t max_depth = 0;
+ uint16_t max_depth = 0;
for (LoopTreeIterator iter(_phase->ltree_root()); !iter.done(); iter.next()) {
IdealLoopTree* lpt = iter.current();
max_depth = MAX2(max_depth, lpt->_nest);
diff --git a/src/hotspot/share/opto/loopnode.cpp b/src/hotspot/share/opto/loopnode.cpp
index 3be00bc8991..38d98fb0fcb 100644
--- a/src/hotspot/share/opto/loopnode.cpp
+++ b/src/hotspot/share/opto/loopnode.cpp
@@ -291,6 +291,7 @@ IdealLoopTree* PhaseIdealLoop::insert_outer_loop(IdealLoopTree* loop, LoopNode*
loop->_parent = outer_ilt;
loop->_next = NULL;
loop->_nest++;
+ assert(loop->_nest <= SHRT_MAX, "sanity");
return outer_ilt;
}
@@ -2614,6 +2615,7 @@ bool IdealLoopTree::is_member(const IdealLoopTree *l) const {
//------------------------------set_nest---------------------------------------
// Set loop tree nesting depth. Accumulate _has_call bits.
int IdealLoopTree::set_nest( uint depth ) {
+ assert(depth <= SHRT_MAX, "sanity");
_nest = depth;
int bits = _has_call;
if( _child ) bits |= _child->set_nest(depth+1);
diff --git a/src/hotspot/share/opto/loopnode.hpp b/src/hotspot/share/opto/loopnode.hpp
index 741d3a82919..b8e50ef4cb8 100644
--- a/src/hotspot/share/opto/loopnode.hpp
+++ b/src/hotspot/share/opto/loopnode.hpp
@@ -611,7 +611,7 @@ public:
Node_List _body; // Loop body for inner loops
- uint8_t _nest; // Nesting depth
+ uint16_t _nest; // Nesting depth
uint8_t _irreducible:1, // True if irreducible
_has_call:1, // True if has call safepoint
_has_sfpt:1, // True if has non-call safepoint
diff --git a/src/hotspot/share/opto/vector.cpp b/src/hotspot/share/opto/vector.cpp
index e9ac28545aa..49293c4a26b 100644
--- a/src/hotspot/share/opto/vector.cpp
+++ b/src/hotspot/share/opto/vector.cpp
@@ -24,6 +24,7 @@
#include "precompiled.hpp"
#include "ci/ciSymbols.hpp"
+#include "gc/shared/barrierSet.hpp"
#include "opto/castnode.hpp"
#include "opto/graphKit.hpp"
#include "opto/phaseX.hpp"
@@ -413,15 +414,17 @@ void PhaseVector::expand_vunbox_node(VectorUnboxNode* vec_unbox) {
Node* mem = vec_unbox->mem();
Node* ctrl = vec_unbox->in(0);
- Node* vec_field_ld = LoadNode::make(gvn,
- ctrl,
- mem,
- vec_adr,
- vec_adr->bottom_type()->is_ptr(),
- TypeOopPtr::make_from_klass(field->type()->as_klass()),
- T_OBJECT,
- MemNode::unordered);
- vec_field_ld = gvn.transform(vec_field_ld);
+ Node* vec_field_ld;
+ {
+ DecoratorSet decorators = MO_UNORDERED | IN_HEAP;
+ C2AccessValuePtr addr(vec_adr, vec_adr->bottom_type()->is_ptr());
+ MergeMemNode* local_mem = MergeMemNode::make(mem);
+ gvn.record_for_igvn(local_mem);
+ BarrierSetC2* bs = BarrierSet::barrier_set()->barrier_set_c2();
+ C2OptAccess access(gvn, ctrl, local_mem, decorators, T_OBJECT, obj, addr);
+ const Type* type = TypeOopPtr::make_from_klass(field->type()->as_klass());
+ vec_field_ld = bs->load_at(access, type);
+ }
// For proper aliasing, attach concrete payload type.
ciKlass* payload_klass = ciTypeArrayKlass::make(bt);
diff --git a/src/hotspot/share/runtime/stubRoutines.cpp b/src/hotspot/share/runtime/stubRoutines.cpp
index c715e93df2a..8a4afc0fc6f 100644
--- a/src/hotspot/share/runtime/stubRoutines.cpp
+++ b/src/hotspot/share/runtime/stubRoutines.cpp
@@ -483,6 +483,7 @@ address StubRoutines::select_fill_function(BasicType t, bool aligned, const char
case T_NARROWOOP:
case T_NARROWKLASS:
case T_ADDRESS:
+ case T_VOID:
// Currently unsupported
return NULL;
diff --git a/src/java.base/share/classes/java/lang/String.java b/src/java.base/share/classes/java/lang/String.java
index 5c175b125dc..5d5316f5f06 100644
--- a/src/java.base/share/classes/java/lang/String.java
+++ b/src/java.base/share/classes/java/lang/String.java
@@ -4397,7 +4397,7 @@ public final class String
*/
void getBytes(byte[] dst, int srcPos, int dstBegin, byte coder, int length) {
if (coder() == coder) {
- System.arraycopy(value, srcPos, dst, dstBegin << coder, length << coder());
+ System.arraycopy(value, srcPos << coder, dst, dstBegin << coder, length << coder);
} else { // this.coder == LATIN && coder == UTF16
StringLatin1.inflate(value, srcPos, dst, dstBegin, length);
}
diff --git a/src/java.base/share/man/java.1 b/src/java.base/share/man/java.1
index 8dddc7e1b14..e815315ec15 100644
--- a/src/java.base/share/man/java.1
+++ b/src/java.base/share/man/java.1
@@ -22,7 +22,7 @@
.\"t
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JAVA" "1" "2020" "JDK 17" "JDK Commands"
+.TH "JAVA" "1" "2021" "JDK 17" "JDK Commands"
.hy
.SH NAME
.PP
@@ -4095,6 +4095,22 @@ The replacement Unified Logging syntax is
\f[CB]\-Xlog:class+loader+constraints=info\f[R].
See \f[B]Enable Logging with the JVM Unified Logging Framework\f[R].
.RE
+.SH REMOVED JAVA OPTIONS
+.PP
+These \f[CB]java\f[R] options have been removed in JDK 16 and using them
+results in an error of:
+.RS
+.PP
+\f[CB]Unrecognized\ VM\ option\f[R] \f[I]option\-name\f[R]
+.RE
+.TP
+.B \f[CB]\-XX:+UseParallelOldGC\f[R]
+Enables the use of the parallel garbage collector for full GCs.
+By default, this option is disabled.
+Enabling it automatically enables the \f[CB]\-XX:+UseParallelGC\f[R]
+option.
+.RS
+.RE
.PP
For the lists and descriptions of options removed in previous releases
see the \f[I]Removed Java Options\f[R] section in:
diff --git a/src/java.base/share/man/keytool.1 b/src/java.base/share/man/keytool.1
index 8067f45fdd2..26fa9a4483b 100644
--- a/src/java.base/share/man/keytool.1
+++ b/src/java.base/share/man/keytool.1
@@ -22,7 +22,7 @@
.\"t
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "KEYTOOL" "1" "2020" "JDK 16" "JDK Commands"
+.TH "KEYTOOL" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/java.rmi/share/man/rmid.1 b/src/java.rmi/share/man/rmid.1
index 45e75ef4a7f..a2e90aa33ba 100644
--- a/src/java.rmi/share/man/rmid.1
+++ b/src/java.rmi/share/man/rmid.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "RMID" "1" "2020" "JDK 16" "JDK Commands"
+.TH "RMID" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/java.rmi/share/man/rmiregistry.1 b/src/java.rmi/share/man/rmiregistry.1
index 9e33a66e5c5..9bb958cedc1 100644
--- a/src/java.rmi/share/man/rmiregistry.1
+++ b/src/java.rmi/share/man/rmiregistry.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "RMIREGISTRY" "1" "2020" "JDK 16" "JDK Commands"
+.TH "RMIREGISTRY" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/java.scripting/share/man/jrunscript.1 b/src/java.scripting/share/man/jrunscript.1
index 627555c93ce..9bc5e4bfb63 100644
--- a/src/java.scripting/share/man/jrunscript.1
+++ b/src/java.scripting/share/man/jrunscript.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JRUNSCRIPT" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JRUNSCRIPT" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.compiler/share/man/javac.1 b/src/jdk.compiler/share/man/javac.1
index 1e2b536b35a..b6316aba28a 100644
--- a/src/jdk.compiler/share/man/javac.1
+++ b/src/jdk.compiler/share/man/javac.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JAVAC" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JAVAC" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.compiler/share/man/serialver.1 b/src/jdk.compiler/share/man/serialver.1
index 140b940aad6..c051ec84abe 100644
--- a/src/jdk.compiler/share/man/serialver.1
+++ b/src/jdk.compiler/share/man/serialver.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "SERIALVER" "1" "2020" "JDK 16" "JDK Commands"
+.TH "SERIALVER" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.hotspot.agent/share/man/jhsdb.1 b/src/jdk.hotspot.agent/share/man/jhsdb.1
index c5891964668..5e6700ec25c 100644
--- a/src/jdk.hotspot.agent/share/man/jhsdb.1
+++ b/src/jdk.hotspot.agent/share/man/jhsdb.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JHSDB" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JHSDB" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jartool/share/man/jar.1 b/src/jdk.jartool/share/man/jar.1
index b1861c59330..a8077290fc6 100644
--- a/src/jdk.jartool/share/man/jar.1
+++ b/src/jdk.jartool/share/man/jar.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JAR" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JAR" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jartool/share/man/jarsigner.1 b/src/jdk.jartool/share/man/jarsigner.1
index 74001244a9f..661c6236846 100644
--- a/src/jdk.jartool/share/man/jarsigner.1
+++ b/src/jdk.jartool/share/man/jarsigner.1
@@ -22,7 +22,7 @@
.\"t
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JARSIGNER" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JARSIGNER" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
@@ -960,15 +960,6 @@ incurs higher overhead.
.RS
.RE
.TP
-.B \f[CB]\-directsign\f[R]
-By default, jarsigner stores the hash of the \f[CB]\&.SF\f[R] file and
-possibly other information in a SignerInfo signedAttributes field, and
-then calculates the signature on this field.
-If this option is set, no SignerInfo signedAttributes field is generated
-and the signature is calculated on the \f[CB]\&.SF\f[R] file directly.
-.RS
-.RE
-.TP
.B \f[CB]\-sectionsonly\f[R]
If the \f[CB]\-sectionsonly\f[R] option appears on the command line, then
the \f[CB]\&.SF\f[R] file (signature file) generated when a JAR file is
diff --git a/src/jdk.javadoc/share/man/javadoc.1 b/src/jdk.javadoc/share/man/javadoc.1
index 14139d20ef2..bdeed2067ee 100644
--- a/src/jdk.javadoc/share/man/javadoc.1
+++ b/src/jdk.javadoc/share/man/javadoc.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JAVADOC" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JAVADOC" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
@@ -596,7 +596,7 @@ it does, you must enclose the title in quotation marks.
Additional quotation marks within the \f[CB]title\f[R] tag must be
escaped.
For example,
-\f[CB]javadoc\ \-header\ "My\ Library
v1.0"\ com.mypackage.\f[R]
+\f[CB]javadoc\ \-doctitle\ "My\ Library
v1.0"\ com.mypackage.\f[R]
.RS
.RE
.TP
diff --git a/src/jdk.jcmd/share/man/jcmd.1 b/src/jdk.jcmd/share/man/jcmd.1
index 5ab057c1453..a5773391e82 100644
--- a/src/jdk.jcmd/share/man/jcmd.1
+++ b/src/jdk.jcmd/share/man/jcmd.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JCMD" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JCMD" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jcmd/share/man/jinfo.1 b/src/jdk.jcmd/share/man/jinfo.1
index f7f79ab296e..cfbe379b4c6 100644
--- a/src/jdk.jcmd/share/man/jinfo.1
+++ b/src/jdk.jcmd/share/man/jinfo.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JINFO" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JINFO" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jcmd/share/man/jmap.1 b/src/jdk.jcmd/share/man/jmap.1
index b5284e0f9e0..4a0dc53d66f 100644
--- a/src/jdk.jcmd/share/man/jmap.1
+++ b/src/jdk.jcmd/share/man/jmap.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JMAP" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JMAP" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jcmd/share/man/jps.1 b/src/jdk.jcmd/share/man/jps.1
index 75acc38ced0..0812a58603b 100644
--- a/src/jdk.jcmd/share/man/jps.1
+++ b/src/jdk.jcmd/share/man/jps.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JPS" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JPS" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jcmd/share/man/jstack.1 b/src/jdk.jcmd/share/man/jstack.1
index 98269bcaf8c..0885ddccfe0 100644
--- a/src/jdk.jcmd/share/man/jstack.1
+++ b/src/jdk.jcmd/share/man/jstack.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JSTACK" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JSTACK" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jcmd/share/man/jstat.1 b/src/jdk.jcmd/share/man/jstat.1
index 143d3ce8d4f..62b1fc98e72 100644
--- a/src/jdk.jcmd/share/man/jstat.1
+++ b/src/jdk.jcmd/share/man/jstat.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JSTAT" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JSTAT" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jconsole/share/man/jconsole.1 b/src/jdk.jconsole/share/man/jconsole.1
index 277cf034433..940a9d05471 100644
--- a/src/jdk.jconsole/share/man/jconsole.1
+++ b/src/jdk.jconsole/share/man/jconsole.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JCONSOLE" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JCONSOLE" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jdeps/share/man/javap.1 b/src/jdk.jdeps/share/man/javap.1
index 3bef06a924e..153448b8c63 100644
--- a/src/jdk.jdeps/share/man/javap.1
+++ b/src/jdk.jdeps/share/man/javap.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JAVAP" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JAVAP" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jdeps/share/man/jdeprscan.1 b/src/jdk.jdeps/share/man/jdeprscan.1
index 3dd4cd9097e..67f46c9edfe 100644
--- a/src/jdk.jdeps/share/man/jdeprscan.1
+++ b/src/jdk.jdeps/share/man/jdeprscan.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JDEPRSCAN" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JDEPRSCAN" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jdeps/share/man/jdeps.1 b/src/jdk.jdeps/share/man/jdeps.1
index 3dd37bd7150..1ca6c7e155b 100644
--- a/src/jdk.jdeps/share/man/jdeps.1
+++ b/src/jdk.jdeps/share/man/jdeps.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JDEPS" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JDEPS" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jdi/share/man/jdb.1 b/src/jdk.jdi/share/man/jdb.1
index 00969b55e45..eb8cf1bab79 100644
--- a/src/jdk.jdi/share/man/jdb.1
+++ b/src/jdk.jdi/share/man/jdb.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JDB" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JDB" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecording.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecording.java
index 1c27a85b812..def3545b746 100644
--- a/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecording.java
+++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecording.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2016, 2020, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2016, 2021, 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,6 +41,7 @@ import java.time.LocalDateTime;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Date;
+import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.LinkedList;
import java.util.List;
@@ -851,4 +852,18 @@ public final class PlatformRecording implements AutoCloseable {
}
}
+
+ public void removePath(SafePath path) {
+ synchronized (recorder) {
+ Iterator it = chunks.iterator();
+ while (it.hasNext()) {
+ RepositoryChunk c = it.next();
+ if (c.getFile().equals(path)) {
+ it.remove();
+ removed(c);
+ return;
+ }
+ }
+ }
+ }
}
diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/Repository.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/Repository.java
index 258b5bf52fa..06a17489400 100644
--- a/src/jdk.jfr/share/classes/jdk/jfr/internal/Repository.java
+++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/Repository.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2012, 2020, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2012, 2021, 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.HashSet;
import java.util.Set;
import jdk.jfr.internal.SecuritySupport.SafePath;
+import jdk.jfr.internal.management.ChunkFilename;
public final class Repository {
@@ -45,6 +46,7 @@ public final class Repository {
private final Set cleanupDirectories = new HashSet<>();
private SafePath baseLocation;
private SafePath repository;
+ private ChunkFilename chunkFilename;
private Repository() {
}
@@ -61,6 +63,7 @@ public final class Repository {
// Probe to see if repository can be created, needed for fail fast
// during JVM startup or JFR.configure
this.repository = createRepository(baseLocation);
+ this.chunkFilename = null;
try {
// Remove so we don't "leak" repositories, if JFR is never started
// and shutdown hook not added.
@@ -84,8 +87,13 @@ public final class Repository {
jvm.setRepositoryLocation(repository.toString());
SecuritySupport.setProperty(JFR_REPOSITORY_LOCATION_PROPERTY, repository.toString());
cleanupDirectories.add(repository);
+ chunkFilename = null;
}
- return new RepositoryChunk(repository, timestamp);
+ if (chunkFilename == null) {
+ chunkFilename = ChunkFilename.newPriviliged(repository.toPath());
+ }
+ String filename = chunkFilename.next(timestamp.toLocalDateTime());
+ return new RepositoryChunk(new SafePath(filename), timestamp.toInstant());
} catch (Exception e) {
String errorMsg = String.format("Could not create chunk in repository %s, %s: %s", repository, e.getClass(), e.getMessage());
Logger.log(LogTag.JFR, LogLevel.ERROR, errorMsg);
diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/RepositoryChunk.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/RepositoryChunk.java
index 27513ef1f9f..8ccd536a228 100644
--- a/src/jdk.jfr/share/classes/jdk/jfr/internal/RepositoryChunk.java
+++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/RepositoryChunk.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2012, 2020, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2012, 2021, 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
@@ -47,7 +47,6 @@ final class RepositoryChunk {
}
};
- private final SafePath repositoryPath;
private final SafePath chunkFile;
private final Instant startTime;
private final RandomAccessFile unFinishedRAF;
@@ -56,28 +55,12 @@ final class RepositoryChunk {
private int refCount = 0;
private long size;
- RepositoryChunk(SafePath path, ZonedDateTime timestamp) throws Exception {
- this.startTime = timestamp.toInstant();
- this.repositoryPath = path;
- this.chunkFile = findFileName(repositoryPath, timestamp.toLocalDateTime());
+ RepositoryChunk(SafePath path, Instant startTime) throws Exception {
+ this.startTime = startTime;
+ this.chunkFile = path;
this.unFinishedRAF = SecuritySupport.createRandomAccessFile(chunkFile);
}
- private static SafePath findFileName(SafePath directory, LocalDateTime time) throws Exception {
- String filename = Utils.formatDateTime(time);
- Path p = directory.toPath().resolve(filename + FILE_EXTENSION);
- for (int i = 1; i < MAX_CHUNK_NAMES; i++) {
- SafePath s = new SafePath(p);
- if (!SecuritySupport.exists(s)) {
- return s;
- }
- String extendedName = String.format("%s_%02d%s", filename, i, FILE_EXTENSION);
- p = directory.toPath().resolve(extendedName);
- }
- p = directory.toPath().resolve(filename + "_" + System.currentTimeMillis() + FILE_EXTENSION);
- return new SafePath(p);
- }
-
void finish(Instant endTime) {
try {
finishWithException(endTime);
diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/SecuritySupport.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/SecuritySupport.java
index 73b9a9fed8c..661d3a5b516 100644
--- a/src/jdk.jfr/share/classes/jdk/jfr/internal/SecuritySupport.java
+++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/SecuritySupport.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2016, 2020, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2016, 2021, 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
@@ -500,6 +500,11 @@ public final class SecuritySupport {
public long fileSize(Path p) throws IOException {
return doPrivilegedIOWithReturn( () -> Files.size(p));
}
+
+ @Override
+ public boolean exists(Path p) throws IOException {
+ return doPrivilegedIOWithReturn( () -> Files.exists(p));
+ }
}
diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/Utils.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/Utils.java
index 49953c3ba5b..81fa5519dfa 100644
--- a/src/jdk.jfr/share/classes/jdk/jfr/internal/Utils.java
+++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/Utils.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2016, 2020, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2016, 2021, 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
@@ -184,7 +184,7 @@ public final class Utils {
// This method reduces the number of loaded classes
// compared to DateTimeFormatter
- static String formatDateTime(LocalDateTime time) {
+ public static String formatDateTime(LocalDateTime time) {
StringBuilder sb = new StringBuilder(19);
sb.append(time.getYear() / 100);
appendPadded(sb, time.getYear() % 100, true);
diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/consumer/FileAccess.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/consumer/FileAccess.java
index 92572548260..198131b61aa 100644
--- a/src/jdk.jfr/share/classes/jdk/jfr/internal/consumer/FileAccess.java
+++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/consumer/FileAccess.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2019, 2020, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2019, 2021, 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
@@ -46,6 +46,8 @@ public abstract class FileAccess {
public abstract long fileSize(Path p) throws IOException;
+ public abstract boolean exists(Path s) throws IOException;
+
private static class UnPrivileged extends FileAccess {
@Override
public RandomAccessFile openRAF(File f, String mode) throws IOException {
@@ -71,5 +73,10 @@ public abstract class FileAccess {
public long fileSize(Path p) throws IOException {
return Files.size(p);
}
+
+ @Override
+ public boolean exists(Path p) {
+ return Files.exists(p);
+ }
}
}
diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/consumer/OngoingStream.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/consumer/OngoingStream.java
index a462bde64da..040bcf587b3 100644
--- a/src/jdk.jfr/share/classes/jdk/jfr/internal/consumer/OngoingStream.java
+++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/consumer/OngoingStream.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2020, 2021, 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
@@ -119,8 +119,7 @@ public final class OngoingStream extends EventByteStream {
throw new IOException("No progress");
}
startTimeNanos += header.getDurationNanos();
- Instant timestamp = Utils.epochNanosToInstant(startTimeNanos);
- ManagementSupport.removeBefore(recording, timestamp);
+ ManagementSupport.removePath(recording, path);
closeInput();
} else {
header.refresh();
diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/management/ChunkFilename.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/management/ChunkFilename.java
new file mode 100644
index 00000000000..3be5b69c61b
--- /dev/null
+++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/management/ChunkFilename.java
@@ -0,0 +1,90 @@
+/*
+ * Copyright (c) 2021, 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.jfr.internal.management;
+
+import java.nio.file.Paths;
+import java.nio.file.Path;
+import java.time.LocalDateTime;
+import java.time.ZoneId;
+import java.io.IOException;
+import java.util.HashSet;
+import java.util.Set;
+
+import jdk.jfr.internal.SecuritySupport;
+import jdk.jfr.internal.SecuritySupport.SafePath;
+import jdk.jfr.internal.Utils;
+import jdk.jfr.internal.consumer.FileAccess;
+
+// Allows a remote streaming client to create chunk files
+// with same naming scheme as the JVM.
+public final class ChunkFilename {
+ private static final int MAX_CHUNK_NAMES = 100_000;
+ private static final String FILE_EXTENSION = ".jfr";
+
+ private final Path directory;
+ private final FileAccess fileAcess;
+
+ private Path lastPath;
+ private int counter;
+
+ public static ChunkFilename newUnpriviliged(Path directory) {
+ return new ChunkFilename(directory, FileAccess.UNPRIVILEGED);
+ }
+
+ public static ChunkFilename newPriviliged(Path directory) {
+ return new ChunkFilename(directory, SecuritySupport.PRIVILEGED);
+ }
+
+ private ChunkFilename(Path directory, FileAccess fileAccess) {
+ // Avoid malicious implementations of Path interface
+ this.directory = Paths.get(directory.toString());
+ this.fileAcess = fileAccess;
+ }
+
+ public String next(LocalDateTime time) throws IOException {
+ String filename = Utils.formatDateTime(time);
+ Path p = directory.resolve(filename + FILE_EXTENSION);
+
+ // If less than one file per second (typically case)
+ if (lastPath == null || !p.equals(lastPath)) {
+ if (!fileAcess.exists(p)) {
+ counter = 1; // reset counter
+ lastPath = p;
+ return p.toString();
+ }
+ }
+
+ // If more than one file per second
+ while (counter < MAX_CHUNK_NAMES) {
+ String extendedName = String.format("%s_%02d%s", filename, counter, FILE_EXTENSION);
+ p = directory.resolve(extendedName);
+ counter++;
+ if (!fileAcess.exists(p)) {
+ return p.toString();
+ }
+ }
+ throw new IOException("Unable to find unused filename after " + counter + " attempts");
+ }
+}
diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/management/ManagementSupport.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/management/ManagementSupport.java
index 6505364dd93..43e2b046b53 100644
--- a/src/jdk.jfr/share/classes/jdk/jfr/internal/management/ManagementSupport.java
+++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/management/ManagementSupport.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2016, 2021, 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
@@ -49,6 +49,7 @@ import jdk.jfr.internal.Logger;
import jdk.jfr.internal.MetadataRepository;
import jdk.jfr.internal.PlatformRecording;
import jdk.jfr.internal.PrivateAccess;
+import jdk.jfr.internal.SecuritySupport.SafePath;
import jdk.jfr.internal.Utils;
import jdk.jfr.internal.WriteableUserPath;
import jdk.jfr.internal.consumer.EventDirectoryStream;
@@ -141,7 +142,12 @@ public final class ManagementSupport {
public static void removeBefore(Recording recording, Instant timestamp) {
PlatformRecording pr = PrivateAccess.getInstance().getPlatformRecording(recording);
pr.removeBefore(timestamp);
+ }
+ // Needed callback to detect when a chunk has been parsed.
+ public static void removePath(Recording recording, Path path) {
+ PlatformRecording pr = PrivateAccess.getInstance().getPlatformRecording(recording);
+ pr.removePath(new SafePath(path));
}
// Needed callback to detect when a chunk has been parsed.
diff --git a/src/jdk.jfr/share/man/jfr.1 b/src/jdk.jfr/share/man/jfr.1
index 0fb8912b671..588a3bd45f1 100644
--- a/src/jdk.jfr/share/man/jfr.1
+++ b/src/jdk.jfr/share/man/jfr.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JFR" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JFR" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jlink/share/man/jlink.1 b/src/jdk.jlink/share/man/jlink.1
index a782d558b43..2f4b37d740d 100644
--- a/src/jdk.jlink/share/man/jlink.1
+++ b/src/jdk.jlink/share/man/jlink.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JLINK" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JLINK" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jlink/share/man/jmod.1 b/src/jdk.jlink/share/man/jmod.1
index d46f8708478..bfc290f6b72 100644
--- a/src/jdk.jlink/share/man/jmod.1
+++ b/src/jdk.jlink/share/man/jmod.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JMOD" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JMOD" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jshell/share/man/jshell.1 b/src/jdk.jshell/share/man/jshell.1
index 01d6a24b30a..72b5a5ea129 100644
--- a/src/jdk.jshell/share/man/jshell.1
+++ b/src/jdk.jshell/share/man/jshell.1
@@ -22,7 +22,7 @@
.\"t
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JSHELL" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JSHELL" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.jstatd/share/man/jstatd.1 b/src/jdk.jstatd/share/man/jstatd.1
index 88d3222c364..4299af92283 100644
--- a/src/jdk.jstatd/share/man/jstatd.1
+++ b/src/jdk.jstatd/share/man/jstatd.1
@@ -21,7 +21,7 @@
.\"
.\" Automatically generated by Pandoc 2.3.1
.\"
-.TH "JSTATD" "1" "2020" "JDK 16" "JDK Commands"
+.TH "JSTATD" "1" "2021" "JDK 16" "JDK Commands"
.hy
.SH NAME
.PP
diff --git a/src/jdk.management.jfr/share/classes/jdk/management/jfr/DiskRepository.java b/src/jdk.management.jfr/share/classes/jdk/management/jfr/DiskRepository.java
index 0bf2a145b23..b6408a122ca 100644
--- a/src/jdk.management.jfr/share/classes/jdk/management/jfr/DiskRepository.java
+++ b/src/jdk.management.jfr/share/classes/jdk/management/jfr/DiskRepository.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2020, 2021, 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 @@ import java.io.RandomAccessFile;
import java.nio.ByteBuffer;
import java.nio.file.Files;
import java.nio.file.Path;
+import java.nio.file.Paths;
import java.time.Duration;
import java.time.Instant;
import java.time.LocalDateTime;
@@ -40,19 +41,20 @@ import java.util.Deque;
import java.util.Iterator;
import java.util.Objects;
+import jdk.jfr.internal.management.ChunkFilename;
import jdk.jfr.internal.management.ManagementSupport;
final class DiskRepository implements Closeable {
final static class DiskChunk {
final Path path;
- final Instant startTime;
+ final long startTimeNanos;
Instant endTime;
long size;
DiskChunk(Path path, long startNanos) {
this.path = path;
- this.startTime = ManagementSupport.epochNanosToInstant(startNanos);
+ this.startTimeNanos = startNanos;
}
}
@@ -80,6 +82,7 @@ final class DiskRepository implements Closeable {
private final boolean deleteDirectory;
private final ByteBuffer buffer = ByteBuffer.allocate(256);
private final Path directory;
+ private final ChunkFilename chunkFilename;
private RandomAccessFile raf;
private RandomAccessFile previousRAF;
@@ -103,6 +106,7 @@ final class DiskRepository implements Closeable {
public DiskRepository(Path path, boolean deleteDirectory) throws IOException {
this.directory = path;
this.deleteDirectory = deleteDirectory;
+ this.chunkFilename = ChunkFilename.newUnpriviliged(path);
}
public synchronized void write(byte[] bytes) throws IOException {
@@ -295,8 +299,8 @@ final class DiskRepository implements Closeable {
previousRAFstate = state;
currentChunk.size = Files.size(currentChunk.path);
long durationNanos = buffer.getLong(HEADER_FILE_DURATION);
- Duration d = Duration.ofNanos(durationNanos);
- currentChunk.endTime = currentChunk.startTime.plus(d);
+ long endTimeNanos = currentChunk.startTimeNanos + durationNanos;
+ currentChunk.endTime = ManagementSupport.epochNanosToInstant(endTimeNanos);
}
raf.seek(position);
}
@@ -325,44 +329,8 @@ final class DiskRepository implements Closeable {
int nanoOfSecond = (int) (nanos % 1_000_000_000);
ZoneOffset z = OffsetDateTime.now().getOffset();
LocalDateTime d = LocalDateTime.ofEpochSecond(epochSecond, nanoOfSecond, z);
- String filename = formatDateTime(d);
- Path p1 = directory.resolve(filename + ".jfr");
- if (!Files.exists(p1)) {
- return new DiskChunk(p1, nanos);
- }
- for (int i = 1; i < 100; i++) {
- String s = Integer.toString(i);
- if (i < 10) {
- s = "0" + s;
- }
- Path p2 = directory.resolve(filename + "_" + s + ".jfr");
- if (!Files.exists(p2)) {
- return new DiskChunk(p2, nanos);
- }
- }
- throw new IOException("Could not create chunk for path " + p1);
- }
-
- static String formatDateTime(LocalDateTime time) {
- StringBuilder sb = new StringBuilder(19);
- sb.append(time.getYear() / 100);
- appendPadded(sb, time.getYear() % 100, true);
- appendPadded(sb, time.getMonth().getValue(), true);
- appendPadded(sb, time.getDayOfMonth(), true);
- appendPadded(sb, time.getHour(), true);
- appendPadded(sb, time.getMinute(), true);
- appendPadded(sb, time.getSecond(), false);
- return sb.toString();
- }
-
- private static void appendPadded(StringBuilder text, int number, boolean separator) {
- if (number < 10) {
- text.append('0');
- }
- text.append(number);
- if (separator) {
- text.append('_');
- }
+ String filename = chunkFilename.next(d);
+ return new DiskChunk(Paths.get(filename), nanos);
}
@Override
@@ -423,11 +391,11 @@ final class DiskRepository implements Closeable {
cleanUpDeadChunk(count + 10);
}
- public synchronized void onChunkComplete(Instant timestamp) {
+ public synchronized void onChunkComplete(long endTimeNanos) {
int count = 0;
while (!activeChunks.isEmpty()) {
DiskChunk oldestChunk = activeChunks.peek();
- if (oldestChunk.startTime.isBefore(timestamp)) {
+ if (oldestChunk.startTimeNanos < endTimeNanos) {
removeOldestChunk();
count++;
} else {
diff --git a/src/jdk.management.jfr/share/classes/jdk/management/jfr/DownLoadThread.java b/src/jdk.management.jfr/share/classes/jdk/management/jfr/DownLoadThread.java
index 68d2fc5f6c8..5ce66692537 100644
--- a/src/jdk.management.jfr/share/classes/jdk/management/jfr/DownLoadThread.java
+++ b/src/jdk.management.jfr/share/classes/jdk/management/jfr/DownLoadThread.java
@@ -29,13 +29,16 @@ import java.time.Instant;
import java.util.HashMap;
import java.util.Map;
+import jdk.jfr.internal.management.ManagementSupport;
+
final class DownLoadThread extends Thread {
private final RemoteRecordingStream stream;
private final Instant startTime;
private final Instant endTime;
private final DiskRepository diskRepository;
- DownLoadThread(RemoteRecordingStream stream) {
+ DownLoadThread(RemoteRecordingStream stream, String name) {
+ super(name);
this.stream = stream;
this.startTime = stream.startTime;
this.endTime = stream.endTime;
@@ -65,7 +68,7 @@ final class DownLoadThread extends Thread {
}
}
} catch (IOException ioe) {
- // ignore
+ ManagementSupport.logDebug(ioe.getMessage());
} finally {
diskRepository.complete();
}
diff --git a/src/jdk.management.jfr/share/classes/jdk/management/jfr/RemoteRecordingStream.java b/src/jdk.management.jfr/share/classes/jdk/management/jfr/RemoteRecordingStream.java
index c5af59d1776..c35a66b7913 100644
--- a/src/jdk.management.jfr/share/classes/jdk/management/jfr/RemoteRecordingStream.java
+++ b/src/jdk.management.jfr/share/classes/jdk/management/jfr/RemoteRecordingStream.java
@@ -133,8 +133,7 @@ public final class RemoteRecordingStream implements EventStream {
@Override
public void accept(Long endNanos) {
- Instant t = ManagementSupport.epochNanosToInstant(endNanos);
- repository.onChunkComplete(t);
+ repository.onChunkComplete(endNanos);
}
}
@@ -552,8 +551,8 @@ public final class RemoteRecordingStream implements EventStream {
}
private void startDownload() {
- Thread downLoadThread = new DownLoadThread(this);
- downLoadThread.setName("JFR: Download Thread " + creationTime);
+ String name = "JFR: Download Thread " + creationTime;
+ Thread downLoadThread = new DownLoadThread(this, name);
downLoadThread.start();
}
diff --git a/test/hotspot/jtreg/compiler/loopopts/TestLoopLimitNodeElimination.java b/test/hotspot/jtreg/compiler/loopopts/TestLoopLimitNodeElimination.java
new file mode 100644
index 00000000000..930d38a4e19
--- /dev/null
+++ b/test/hotspot/jtreg/compiler/loopopts/TestLoopLimitNodeElimination.java
@@ -0,0 +1,75 @@
+/*
+ * Copyright (c) 2021, 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 8260370
+ * @summary C2: LoopLimit node is not eliminated
+ *
+ * @run main/othervm
+ * -Xcomp
+ * -XX:CompileOnly=compiler/loopopts/TestLoopLimitNodeElimination
+ * compiler.loopopts.TestLoopLimitNodeElimination
+ */
+
+package compiler.loopopts;
+
+// the test code is derived from a randomly generated test
+public class TestLoopLimitNodeElimination {
+ private static class MyException extends RuntimeException { }
+ private static final int ITERATIONS = 100000;
+ private static final int SIZE = 400;
+
+ private static int counter = 0;
+
+ int[] array1 = new int[SIZE];
+
+ void test() {
+ int[] array2 = new int[SIZE];
+ array1[2] = 0;
+ array1 = array1;
+ for (long i = 301; i > 2; i -= 2) {
+ int j = 1;
+ do {
+ for (int k = (int) i; k < 1; k++) { }
+ } while (++j < 4);
+ }
+
+ counter++;
+ if (counter == ITERATIONS) {
+ throw new MyException();
+ }
+ }
+
+ public static void main(String[] args) {
+ try {
+ var test = new TestLoopLimitNodeElimination();
+ while (true) {
+ test.test();
+ }
+ } catch (MyException e) {
+ // expected
+ }
+ }
+}
+
diff --git a/test/hotspot/jtreg/compiler/loopopts/TestNestedIrreducibleLoops.jasm b/test/hotspot/jtreg/compiler/loopopts/TestNestedIrreducibleLoops.jasm
new file mode 100644
index 00000000000..ad79289ded4
--- /dev/null
+++ b/test/hotspot/jtreg/compiler/loopopts/TestNestedIrreducibleLoops.jasm
@@ -0,0 +1,1939 @@
+/*
+ * Copyright (c) 2021, 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.
+ *
+ */
+
+super public class TestNestedIrreducibleLoops
+ version 45:3
+{
+ Field loopCounter:I;
+ Field start:I;
+
+ public Method "":"()V"
+ stack 1 locals 1
+ {
+ aload_0;
+ invokespecial Method java/lang/Object."":"()V";
+ return;
+ }
+ static Method addi:"(I)I"
+ stack 2 locals 1
+ {
+ iload_0;
+ iconst_1;
+ iadd;
+ ireturn;
+ }
+ Method test:"()I"
+ stack 2 locals 8
+ {
+ iconst_0;
+ istore_1;
+ iconst_0;
+ istore_2;
+ iconst_0;
+ istore_3;
+ iconst_m1;
+ istore 5;
+ iconst_2;
+ istore 6;
+ aload_0;
+ getfield Field start:"I";
+ ifne L3135;
+ goto L31;
+ L22: iinc 2, 1;
+ iload_2;
+ iload 6;
+ if_icmpgt L3135;
+ L31: iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpeq L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmplt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iload_1;
+ iconst_3;
+ if_icmpgt L3135;
+ iconst_0;
+ istore 7;
+ L3084: iload 7;
+ iload 6;
+ if_icmpge L3104;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ ifeq L3104;
+ iinc 7, 1;
+ goto L3084;
+ L3104: iload_1;
+ iload 6;
+ if_icmpge L3135;
+ iload_1;
+ invokestatic Method addi:"(I)I";
+ bipush 84;
+ if_icmpne L3135;
+ iload_1;
+ bipush 88;
+ iadd;
+ iload 6;
+ if_icmpge L3135;
+ iconst_1;
+ ireturn;
+ L3130: iload 5;
+ iflt L3153;
+ L3135: iload_1;
+ invokestatic Method addi:"(I)I";
+ istore_1;
+ iinc 3, 1;
+ iload_3;
+ aload_0;
+ getfield Field loopCounter:"I";
+ if_icmplt L3130;
+ iconst_0;
+ ireturn;
+ L3153: iload 5;
+ iflt L22;
+ iconst_0;
+ ireturn;
+ }
+
+} // end Class TestNestedIrreducibleLoops
diff --git a/test/hotspot/jtreg/compiler/loopopts/TestNestedIrreducibleLoopsMain.java b/test/hotspot/jtreg/compiler/loopopts/TestNestedIrreducibleLoopsMain.java
new file mode 100644
index 00000000000..65b26bf76c1
--- /dev/null
+++ b/test/hotspot/jtreg/compiler/loopopts/TestNestedIrreducibleLoopsMain.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright (c) 2021, 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 8253353
+ * @summary Tests custom bytecode with deep nested irreducible loops.
+ *
+ * @compile TestNestedIrreducibleLoops.jasm
+ * @run main/othervm -Xbatch -XX:CompileCommand=dontinline,TestNestedIrreducibleLoops::*
+ * -XX:CompileCommand=exclude,TestNestedIrreducibleLoopsMain::main
+ * TestNestedIrreducibleLoopsMain
+ */
+
+public class TestNestedIrreducibleLoopsMain {
+ public static void main(String[] args) {
+ TestNestedIrreducibleLoops t = new TestNestedIrreducibleLoops();
+ t.loopCounter = 3;
+ int j;
+ for (int i = 0; i < 11000; i++) {
+ t.start = i & 0x3ff;
+ j = t.test(); // Produces deep nested irreducible loops
+ }
+ }
+}
diff --git a/test/hotspot/jtreg/compiler/vectorapi/TestLoopStoreVector.java b/test/hotspot/jtreg/compiler/vectorapi/TestLoopStoreVector.java
new file mode 100644
index 00000000000..02ae5684869
--- /dev/null
+++ b/test/hotspot/jtreg/compiler/vectorapi/TestLoopStoreVector.java
@@ -0,0 +1,81 @@
+/*
+ * Copyright (c) 2021, Huawei Technologies Co. Ltd. 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 compiler.vectorapi;
+
+import jdk.incubator.vector.IntVector;
+import jdk.incubator.vector.LongVector;
+import jdk.incubator.vector.VectorSpecies;
+
+/*
+ * @test
+ * @bug 8260339
+ * @summary StoreVectorNode is not considered with -XX:+OptimizeFill
+ * @modules jdk.incubator.vector
+ *
+ * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+OptimizeFill compiler.vectorapi.TestLoopStoreVector
+ */
+
+public class TestLoopStoreVector {
+ static final VectorSpecies SPECIESi = IntVector.SPECIES_PREFERRED;
+ static final VectorSpecies SPECIESl = LongVector.SPECIES_PREFERRED;
+
+ static final int INVOC_COUNT = 5000;
+ static final int size = 64;
+
+ static int[] ai = {20, 21, 02, 14, 83, 119, 101, 101, 116, 121, 44, 32,
+ 73, 32, 76, 79, 86, 69, 32, 89, 79, 85, 32, 102, 111,
+ 114, 101, 118, 101, 114, 33, 32, 32, 32, 45, 45, 32,
+ 32, 32, 66, 121, 32, 87, 97, 110, 103, 72, 117, 97,
+ 110, 103,46, 76, 105, 102, 101, 32, 105, 115, 32, 116,
+ 104, 101, 32};
+ static long[] al = {102, 108, 111, 119, 101, 114, 32, 102, 111, 114, 32,
+ 119, 104, 105, 99, 104, 32, 108, 111, 118, 101, 32,
+ 105, 115, 32, 116, 104, 101, 32, 104, 111, 110, 101,
+ 121, 46, 32, 87, 101, 32, 119, 105, 108, 108, 32, 115,
+ 116, 105, 99, 107, 32, 116, 111, 103, 101, 116, 104,
+ 101, 114, 32, 33, 33, 33, 33, 32};
+
+ public static void testVectorCastL2I(long[] input, int[] output, VectorSpecies speciesl, VectorSpecies speciesi) {
+ LongVector av = LongVector.fromArray(speciesl, input, 0);
+ IntVector bv = (IntVector) av.castShape(speciesi, 0);
+ bv.intoArray(output, 0);
+ }
+
+ public static int test0() {
+ for (int i = 0; i < 1000; i++) {
+ testVectorCastL2I(al, ai, SPECIESl, SPECIESi);
+ }
+ return 0;
+ }
+
+ public static void main(String[] args) {
+ for (int i = 0; i < INVOC_COUNT; i++) {
+ test0();
+ }
+ for (int i = 0; i < 64; i++) {
+ System.out.print(ai[i] + " ");
+ }
+ System.out.println("");
+ }
+}
diff --git a/test/hotspot/jtreg/compiler/vectorapi/VectorRebracket128Test.java b/test/hotspot/jtreg/compiler/vectorapi/VectorRebracket128Test.java
new file mode 100644
index 00000000000..6b266db08b6
--- /dev/null
+++ b/test/hotspot/jtreg/compiler/vectorapi/VectorRebracket128Test.java
@@ -0,0 +1,162 @@
+/*
+ * Copyright (c) 2021, 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 jdk.incubator.vector.*;
+import jdk.internal.vm.annotation.ForceInline;
+import org.testng.Assert;
+import org.testng.annotations.Test;
+import org.testng.annotations.DataProvider;
+
+import java.lang.invoke.MethodHandles;
+import java.lang.invoke.VarHandle;
+import java.nio.ByteOrder;
+import java.util.Arrays;
+import java.util.List;
+import java.util.function.IntFunction;
+import java.util.function.IntUnaryOperator;
+import jdk.incubator.vector.VectorShape;
+import jdk.incubator.vector.VectorSpecies;
+import jdk.internal.vm.annotation.ForceInline;
+
+/*
+ * @test
+ * @bug 8260473
+ * @requires vm.gc.Z
+ * @modules jdk.incubator.vector
+ * @modules java.base/jdk.internal.vm.annotation
+ * @run testng/othervm -XX:CompileCommand=compileonly,jdk/incubator/vector/ByteVector.fromByteBuffer
+ * -XX:-TieredCompilation -XX:CICompilerCount=1 -XX:+UseZGC -Xbatch -Xmx256m VectorRebracket128Test
+ */
+
+@Test
+public class VectorRebracket128Test {
+ static final int INVOC_COUNT = Integer.getInteger("jtreg.compiler.vectorapi.vectorrebracket128test.loop-iterations", 1000);
+ static final int NUM_ITER = 200 * INVOC_COUNT;
+
+ static final VectorSpecies ispec128 = IntVector.SPECIES_128;
+ static final VectorSpecies fspec128 = FloatVector.SPECIES_128;
+ static final VectorSpecies lspec128 = LongVector.SPECIES_128;
+ static final VectorSpecies dspec128 = DoubleVector.SPECIES_128;
+ static final VectorSpecies bspec128 = ByteVector.SPECIES_128;
+ static final VectorSpecies sspec128 = ShortVector.SPECIES_128;
+
+ static IntFunction withToString(String s, IntFunction f) {
+ return new IntFunction() {
+ @Override
+ public T apply(int v) {
+ return f.apply(v);
+ }
+
+ @Override
+ public String toString() {
+ return s;
+ }
+ };
+ }
+
+ interface ToByteF {
+ byte apply(int i);
+ }
+
+ static byte[] fill_byte(int s , ToByteF f) {
+ return fill_byte(new byte[s], f);
+ }
+
+ static byte[] fill_byte(byte[] a, ToByteF f) {
+ for (int i = 0; i < a.length; i++) {
+ a[i] = f.apply(i);
+ }
+ return a;
+ }
+
+ static final List> BYTE_GENERATORS = List.of(
+ withToString("byte(i)", (int s) -> {
+ return fill_byte(s, i -> (byte)(i+1));
+ })
+ );
+
+ @DataProvider
+ public Object[][] byteUnaryOpProvider() {
+ return BYTE_GENERATORS.stream().
+ map(f -> new Object[]{f}).
+ toArray(Object[][]::new);
+ }
+
+ static
+ void checkPartialResult(VectorSpecies> a, VectorSpecies> b,
+ byte[] input, byte[] output, byte[] expected,
+ int part, int origin) {
+ if (Arrays.equals(expected, output)) {
+ return;
+ }
+ int block;
+ block = Math.min(a.vectorByteSize(), b.vectorByteSize());
+
+ System.out.println("input: "+Arrays.toString(input));
+ System.out.println("Failing with "+a+"->"+b+
+ " (reinterpret)"+
+ ", block=" + block +
+ ", part=" + part +
+ ", origin=" + origin);
+ System.out.println("expect: "+Arrays.toString(expected));
+ System.out.println("output: "+Arrays.toString(output));
+ Assert.assertEquals(expected, output);
+ }
+
+ @ForceInline
+ static
+ void testVectorRebracket(VectorSpecies a, VectorSpecies b, byte[] input, byte[] output) {
+ Vector av = a.fromByteArray(input, 0, ByteOrder.nativeOrder());
+ int block;
+ assert(input.length == output.length);
+
+ block = Math.min(a.vectorByteSize(), b.vectorByteSize());
+ if (false)
+ System.out.println("testing "+a+"->"+b+
+ (false?" (lanewise)":" (reinterpret)")+
+ ", block=" + block);
+ byte[] expected;
+ int origin;
+
+ int part = 0;
+ Vector bv = av.reinterpretShape(b, part);
+ bv.intoByteArray(output, 0, ByteOrder.nativeOrder());
+ // in-place copy, no resize
+ expected = input;
+ origin = 0;
+ checkPartialResult(a, b, input, output, expected,
+ part, origin);
+
+ }
+
+ @Test(dataProvider = "byteUnaryOpProvider")
+ static void testRebracket128(IntFunction fa) {
+ byte[] barr = fa.apply(128/Byte.SIZE);
+ byte[] bout = new byte[barr.length];
+ for (int i = 0; i < NUM_ITER; i++) {
+ testVectorRebracket(bspec128, bspec128, barr, bout);
+ testVectorRebracket(bspec128, sspec128, barr, bout);
+ testVectorRebracket(bspec128, ispec128, barr, bout);
+ }
+ }
+
+}
diff --git a/test/jdk/ProblemList.txt b/test/jdk/ProblemList.txt
index 95a89dbe497..297e13c5e99 100644
--- a/test/jdk/ProblemList.txt
+++ b/test/jdk/ProblemList.txt
@@ -828,7 +828,6 @@ javax/script/Test7.java 8239361 generic-
jdk/jfr/event/runtime/TestNetworkUtilizationEvent.java 8228990,8229370 generic-all
jdk/jfr/event/compiler/TestCodeSweeper.java 8225209 generic-all
jdk/jfr/event/os/TestThreadContextSwitches.java 8247776 windows-all
-jdk/jfr/jmx/streaming/TestRotate.java 8257215 generic-all
jdk/jfr/startupargs/TestStartName.java 8214685 windows-x64
jdk/jfr/startupargs/TestStartDuration.java 8214685 windows-x64
diff --git a/test/jdk/java/lang/StringBuilder/Insert.java b/test/jdk/java/lang/StringBuilder/Insert.java
index d4b1ef28d86..ad1c7df20e2 100644
--- a/test/jdk/java/lang/StringBuilder/Insert.java
+++ b/test/jdk/java/lang/StringBuilder/Insert.java
@@ -27,9 +27,10 @@ import static org.testng.Assert.assertEquals;
/**
* @test
- * @run testng Insert
* @bug 4914802 8257511
* @summary Test StringBuilder.insert sanity tests
+ * @run testng/othervm -XX:-CompactStrings Insert
+ * @run testng/othervm -XX:+CompactStrings Insert
*/
@Test
public class Insert {
diff --git a/test/jdk/jdk/jfr/jmx/streaming/TestRotate.java b/test/jdk/jdk/jfr/jmx/streaming/TestRotate.java
index 05a0bab74da..d7ec6398ecf 100644
--- a/test/jdk/jdk/jfr/jmx/streaming/TestRotate.java
+++ b/test/jdk/jdk/jfr/jmx/streaming/TestRotate.java
@@ -44,7 +44,7 @@ import jdk.management.jfr.RemoteRecordingStream;
* @summary Tests that streaming can work over chunk rotations
* @requires vm.hasJFR
* @library /test/lib /test/jdk
- * @run main/othervm jdk.jfr.jmx.streaming.TestRotate
+ * @run main/othervm -Xlog:jfr=debug jdk.jfr.jmx.streaming.TestRotate
*/
public class TestRotate {