From 3a48e68b1afb3a0fb9b2a8ef78124a065b9cc0f4 Mon Sep 17 00:00:00 2001 From: Thomas Schatzl Date: Wed, 24 Oct 2018 16:22:34 +0200 Subject: [PATCH 01/84] 8212753: Improve oopDesc::forward_to_atomic Avoid multiple unnecessary reloads of the mark oop in oopDesc::forward_to_atomic Reviewed-by: kbarrett, mdoerr --- src/hotspot/share/gc/cms/parNewGeneration.cpp | 4 +-- .../share/gc/g1/g1ParScanThreadState.cpp | 4 +-- src/hotspot/share/oops/oop.hpp | 2 +- src/hotspot/share/oops/oop.inline.hpp | 33 ++++++++----------- 4 files changed, 19 insertions(+), 24 deletions(-) diff --git a/src/hotspot/share/gc/cms/parNewGeneration.cpp b/src/hotspot/share/gc/cms/parNewGeneration.cpp index 5190162d661..db73e7ae397 100644 --- a/src/hotspot/share/gc/cms/parNewGeneration.cpp +++ b/src/hotspot/share/gc/cms/parNewGeneration.cpp @@ -1118,7 +1118,7 @@ oop ParNewGeneration::copy_to_survivor_space(ParScanThreadState* par_scan_state, // Attempt to install a null forwarding pointer (atomically), // to claim the right to install the real forwarding pointer. - forward_ptr = old->forward_to_atomic(ClaimedForwardPtr); + forward_ptr = old->forward_to_atomic(ClaimedForwardPtr, m); if (forward_ptr != NULL) { // someone else beat us to it. return real_forwardee(old); @@ -1144,7 +1144,7 @@ oop ParNewGeneration::copy_to_survivor_space(ParScanThreadState* par_scan_state, // Is in to-space; do copying ourselves. Copy::aligned_disjoint_words((HeapWord*)old, (HeapWord*)new_obj, sz); assert(CMSHeap::heap()->is_in_reserved(new_obj), "illegal forwarding pointer value."); - forward_ptr = old->forward_to_atomic(new_obj); + forward_ptr = old->forward_to_atomic(new_obj, m); // Restore the mark word copied above. new_obj->set_mark_raw(m); // Increment age if obj still in new generation diff --git a/src/hotspot/share/gc/g1/g1ParScanThreadState.cpp b/src/hotspot/share/gc/g1/g1ParScanThreadState.cpp index 517cba5e3cb..b9c52345d80 100644 --- a/src/hotspot/share/gc/g1/g1ParScanThreadState.cpp +++ b/src/hotspot/share/gc/g1/g1ParScanThreadState.cpp @@ -265,7 +265,7 @@ oop G1ParScanThreadState::copy_to_survivor_space(InCSetState const state, Prefetch::write(obj_ptr, PrefetchCopyIntervalInBytes); const oop obj = oop(obj_ptr); - const oop forward_ptr = old->forward_to_atomic(obj, memory_order_relaxed); + const oop forward_ptr = old->forward_to_atomic(obj, old_mark, memory_order_relaxed); if (forward_ptr == NULL) { Copy::aligned_disjoint_words((HeapWord*) old, obj_ptr, word_sz); @@ -355,7 +355,7 @@ void G1ParScanThreadStateSet::flush() { oop G1ParScanThreadState::handle_evacuation_failure_par(oop old, markOop m) { assert(_g1h->is_in_cset(old), "Object " PTR_FORMAT " should be in the CSet", p2i(old)); - oop forward_ptr = old->forward_to_atomic(old, memory_order_relaxed); + oop forward_ptr = old->forward_to_atomic(old, m, memory_order_relaxed); if (forward_ptr == NULL) { // Forward-to-self succeeded. We are the "owner" of the object. HeapRegion* r = _g1h->heap_region_containing(old); diff --git a/src/hotspot/share/oops/oop.hpp b/src/hotspot/share/oops/oop.hpp index 9002037aa84..f673c98b452 100644 --- a/src/hotspot/share/oops/oop.hpp +++ b/src/hotspot/share/oops/oop.hpp @@ -273,7 +273,7 @@ class oopDesc { // Exactly one thread succeeds in inserting the forwarding pointer, and // this call returns "NULL" for that thread; any other thread has the // value of the forwarding pointer returned and does not modify "this". - inline oop forward_to_atomic(oop p, atomic_memory_order order = memory_order_conservative); + inline oop forward_to_atomic(oop p, markOop compare, atomic_memory_order order = memory_order_conservative); inline oop forwardee() const; inline oop forwardee_acquire() const; diff --git a/src/hotspot/share/oops/oop.inline.hpp b/src/hotspot/share/oops/oop.inline.hpp index 93dbe9e9b2a..6f4406edd11 100644 --- a/src/hotspot/share/oops/oop.inline.hpp +++ b/src/hotspot/share/oops/oop.inline.hpp @@ -370,26 +370,21 @@ bool oopDesc::cas_forward_to(oop p, markOop compare, atomic_memory_order order) return cas_set_mark_raw(m, compare, order) == compare; } -oop oopDesc::forward_to_atomic(oop p, atomic_memory_order order) { - markOop oldMark = mark_raw(); - markOop forwardPtrMark = markOopDesc::encode_pointer_as_mark(p); - markOop curMark; - - assert(forwardPtrMark->decode_pointer() == p, "encoding must be reversable"); - assert(sizeof(markOop) == sizeof(intptr_t), "CAS below requires this."); - - while (!oldMark->is_marked()) { - curMark = cas_set_mark_raw(forwardPtrMark, oldMark, order); - assert(is_forwarded(), "object should have been forwarded"); - if (curMark == oldMark) { - return NULL; - } - // If the CAS was unsuccessful then curMark->is_marked() - // should return true as another thread has CAS'd in another - // forwarding pointer. - oldMark = curMark; +oop oopDesc::forward_to_atomic(oop p, markOop compare, atomic_memory_order order) { + // CMS forwards some non-heap value into the mark oop to reserve oops during + // promotion, so the next two asserts do not hold. + assert(UseConcMarkSweepGC || check_obj_alignment(p), + "forwarding to something not aligned"); + assert(UseConcMarkSweepGC || Universe::heap()->is_in_reserved(p), + "forwarding to something not in heap"); + markOop m = markOopDesc::encode_pointer_as_mark(p); + assert(m->decode_pointer() == p, "encoding must be reversable"); + markOop old_mark = cas_set_mark_raw(m, compare, order); + if (old_mark == compare) { + return NULL; + } else { + return (oop)old_mark->decode_pointer(); } - return forwardee(); } // Note that the forwardee is not the same thing as the displaced_mark. From 5d9ffc2d031836baffce681e51f0fb35261bdb49 Mon Sep 17 00:00:00 2001 From: Eric Caspole Date: Wed, 24 Oct 2018 11:02:55 -0400 Subject: [PATCH 02/84] 8212706: nmethod jvmci_installed_code_name need to be XML escaped Call text instead of print to escape chars properly Reviewed-by: thartmann --- src/hotspot/share/code/nmethod.cpp | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/hotspot/share/code/nmethod.cpp b/src/hotspot/share/code/nmethod.cpp index 8368f074dfe..59597907f6b 100644 --- a/src/hotspot/share/code/nmethod.cpp +++ b/src/hotspot/share/code/nmethod.cpp @@ -790,7 +790,9 @@ void nmethod::log_identity(xmlStream* log) const { char buffer[O_BUFLEN]; char* jvmci_name = jvmci_installed_code_name(buffer, O_BUFLEN); if (jvmci_name != NULL) { - log->print(" jvmci_installed_code_name='%s'", jvmci_name); + log->print(" jvmci_installed_code_name='"); + log->text("%s", jvmci_name); + log->print("'"); } #endif } From daf4ad38ab986d4d291e9b624a4708858c19ca44 Mon Sep 17 00:00:00 2001 From: "Daniel D. Daugherty" Date: Wed, 24 Oct 2018 11:04:25 -0400 Subject: [PATCH 03/84] 8212220: add code to verify results to metaspace/stressDictionary/StressDictionary.java Also change the test's default timeout to 5 minutes. Reviewed-by: dholmes, stuefe --- .../stressDictionary/StressDictionary.java | 47 ++++++++++++++++++- 1 file changed, 45 insertions(+), 2 deletions(-) diff --git a/test/hotspot/jtreg/vmTestbase/metaspace/stressDictionary/StressDictionary.java b/test/hotspot/jtreg/vmTestbase/metaspace/stressDictionary/StressDictionary.java index e5884c28bc2..71dd3069643 100644 --- a/test/hotspot/jtreg/vmTestbase/metaspace/stressDictionary/StressDictionary.java +++ b/test/hotspot/jtreg/vmTestbase/metaspace/stressDictionary/StressDictionary.java @@ -29,7 +29,7 @@ * * @library /vmTestbase /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm metaspace.stressDictionary.StressDictionary -stressTime 30 + * @run main/othervm/timeout=300 metaspace.stressDictionary.StressDictionary -stressTime 30 */ package metaspace.stressDictionary; @@ -123,11 +123,54 @@ public class StressDictionary extends GCTestBase { tasks.add(this.new RegularWorker()); } ExecutorService executorService = Executors.newCachedThreadPool(); + List> results = null; try { - executorService.invokeAll(tasks); + results = executorService.invokeAll(tasks); } catch (InterruptedException e) { e.printStackTrace(); } + + int act_results = results.size(); + int exp_results = NUMBER_OF_CORRUPTING_THREADS + + NUMBER_OF_NOT_CORRUPTING_THREADS; + if (act_results == exp_results) { + System.err.println("INFO: There are " + act_results + " results."); + } else { + throw new RuntimeException("Wrong # of results from invokeAll(); " + + "exp_results=" + exp_results + "; " + + "act_results=" + act_results + "."); + } + + int cancelled_cnt = 0; + int not_done_cnt = 0; + for (int i = 0; i < act_results; i++) { + if (!results.get(i).isDone()) { + not_done_cnt++; + System.err.println("ERROR: task #" + i + " is not done."); + } + if (results.get(i).isCancelled()) { + cancelled_cnt++; + System.err.println("ERROR: task #" + i + " was canceled."); + } + } + + if (cancelled_cnt == 0) { + System.err.println("INFO: no tasks were cancelled."); + } + if (not_done_cnt == 0) { + System.err.println("INFO: all tasks are done."); + } + if (cancelled_cnt != 0 && not_done_cnt != 0) { + throw new RuntimeException(cancelled_cnt + + " tasks were cancelled and " + + not_done_cnt + + " tasks are not done."); + } else if (cancelled_cnt != 0) { + throw new RuntimeException(cancelled_cnt + + " tasks were cancelled."); + } else if (not_done_cnt != 0) { + throw new RuntimeException(not_done_cnt + " tasks are not done."); + } } private byte[] generateAndCompile() { From 8636d3f9a5d2572415e71322457e1f643df750c0 Mon Sep 17 00:00:00 2001 From: Ekaterina Pavlova Date: Wed, 24 Oct 2018 09:56:03 -0700 Subject: [PATCH 04/84] 8212877: Restore JTREG_VERBOSE value for mach5 testing Reviewed-by: dholmes --- make/conf/jib-profiles.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/make/conf/jib-profiles.js b/make/conf/jib-profiles.js index 6e7e1439582..6147b41838e 100644 --- a/make/conf/jib-profiles.js +++ b/make/conf/jib-profiles.js @@ -759,7 +759,7 @@ var getJibProfilesProfiles = function (input, common, data) { testedProfile + ".test" ], src: "src.conf", - make_args: [ "run-test-prebuilt", "LOG_CMDLINES=true" ], + make_args: [ "run-test-prebuilt", "LOG_CMDLINES=true", "JTREG_VERBOSE=fail,error,time" ], environment: { "BOOT_JDK": common.boot_jdk_home, "JDK_IMAGE_DIR": input.get(testedProfile + ".jdk", "home_path"), From 49049808863ad7d327991db54b818cc70e4bf7f5 Mon Sep 17 00:00:00 2001 From: Serguei Spitsyn Date: Wed, 24 Oct 2018 13:11:54 -0700 Subject: [PATCH 05/84] 8024368: private methods are allocated vtable slots Stop allocating vtable slots for private methods Reviewed-by: dholmes, acorn, lfoltan --- src/hotspot/share/oops/klassVtable.cpp | 38 +++++++++----------------- 1 file changed, 13 insertions(+), 25 deletions(-) diff --git a/src/hotspot/share/oops/klassVtable.cpp b/src/hotspot/share/oops/klassVtable.cpp index 81e6ca97348..8f5fd36ae5f 100644 --- a/src/hotspot/share/oops/klassVtable.cpp +++ b/src/hotspot/share/oops/klassVtable.cpp @@ -84,6 +84,7 @@ void klassVtable::compute_vtable_size_and_num_mirandas( methodHandle mh(THREAD, methods->at(i)); if (needs_new_vtable_entry(mh, super, classloader, classname, class_flags, major_version, THREAD)) { + assert(!methods->at(i)->is_private(), "private methods should not need a vtable entry"); vtable_length += vtableEntry::size(); // we need a new entry } } @@ -283,7 +284,7 @@ void klassVtable::initialize_vtable(bool checkconstraints, TRAPS) { // If none found, return a null superk, else return the superk of the method this does override // For public and protected methods: if they override a superclass, they will // also be overridden themselves appropriately. -// Private methods do not override and are not overridden. +// Private methods do not override, and are not overridden and are not in the vtable. // Package Private methods are trickier: // e.g. P1.A, pub m // P2.B extends A, package private m @@ -390,8 +391,9 @@ bool klassVtable::update_inherited_vtable(InstanceKlass* klass, const methodHand target_method()->set_vtable_index(Method::nonvirtual_vtable_index); } - // Static and methods are never in - if (target_method()->is_static() || target_method()->name() == vmSymbols::object_initializer_name()) { + // Private, static and methods are never in + if (target_method()->is_private() || target_method()->is_static() || + (target_method()->name()->fast_compare(vmSymbols::object_initializer_name()) == 0)) { return false; } @@ -411,10 +413,7 @@ bool klassVtable::update_inherited_vtable(InstanceKlass* klass, const methodHand // valid itable index, if so, don't change it. // Overpass methods in an interface will be assigned an itable index later // by an inheriting class. - // Private interface methods have no itable index and are always invoked nonvirtually, - // so they retain their nonvirtual_vtable_index value, and therefore can_be_statically_bound() - // will return true. - if ((!is_default || !target_method()->has_itable_index()) && !target_method()->is_private()) { + if ((!is_default || !target_method()->has_itable_index())) { target_method()->set_vtable_index(Method::pending_itable_index); } } @@ -425,14 +424,6 @@ bool klassVtable::update_inherited_vtable(InstanceKlass* klass, const methodHand return allocate_new; } - // private methods in classes always have a new entry in the vtable - // specification interpretation since classic has - // private methods not overriding - // JDK8 adds private methods in interfaces which require invokespecial - if (target_method()->is_private()) { - return allocate_new; - } - // search through the vtable and update overridden entries // Since check_signature_loaders acquires SystemDictionary_lock // which can block for gc, once we are in this loop, use handles @@ -555,6 +546,7 @@ bool klassVtable::update_inherited_vtable(InstanceKlass* klass, const methodHand } void klassVtable::put_method_at(Method* m, int index) { + assert(!m->is_private(), "private methods should not be in vtable"); if (is_preinitialized_vtable()) { // At runtime initialize_vtable is rerun as part of link_class_impl() // for shared class loaded by the non-boot loader to obtain the loader @@ -606,9 +598,11 @@ bool klassVtable::needs_new_vtable_entry(const methodHandle& target_method, // a final method never needs a new entry; final methods can be statically // resolved and they have to be present in the vtable only if they override // a super's method, in which case they re-use its entry + (target_method()->is_private()) || + // private methods don't need to be in vtable (target_method()->is_static()) || // static methods don't need to be in vtable - (target_method()->name() == vmSymbols::object_initializer_name()) + (target_method()->name()->fast_compare(vmSymbols::object_initializer_name()) == 0) // is never called dynamically-bound ) { return false; @@ -619,7 +613,7 @@ bool klassVtable::needs_new_vtable_entry(const methodHandle& target_method, if (target_method()->method_holder() != NULL && target_method()->method_holder()->is_interface() && !target_method()->is_abstract()) { - assert(target_method()->is_default_method() || target_method()->is_private(), + assert(target_method()->is_default_method(), "unexpected interface method type"); return false; } @@ -629,12 +623,6 @@ bool klassVtable::needs_new_vtable_entry(const methodHandle& target_method, return true; } - // private methods in classes always have a new entry in the vtable. - // Specification interpretation since classic has private methods not overriding. - if (target_method()->is_private()) { - return true; - } - // Package private methods always need a new entry to root their own // overriding. This allows transitive overriding to work. if (target_method()->is_package_private()) { @@ -660,8 +648,8 @@ bool klassVtable::needs_new_vtable_entry(const methodHandle& target_method, // make sure you use that class for is_override InstanceKlass* superk = super_method->method_holder(); // we want only instance method matches - // pretend private methods are not in the super vtable - // since we do override around them: e.g. a.m pub/b.m private/c.m pub, + // ignore private methods found via lookup_method since they do not participate in overriding, + // and since we do override around them: e.g. a.m pub/b.m private/c.m pub, // ignore private, c.m pub does override a.m pub // For classes that were not javac'd together, we also do transitive overriding around // methods that have less accessibility From 566bfeb438d599022ea31748afccff0e88e26ff6 Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Wed, 24 Oct 2018 15:45:09 -0700 Subject: [PATCH 06/84] 8212880: Cannot access ftp: site for fdlibm.tar Reviewed-by: jjg, lancea, bpb --- src/java.base/share/classes/java/lang/StrictMath.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/java.base/share/classes/java/lang/StrictMath.java b/src/java.base/share/classes/java/lang/StrictMath.java index 400b3b25f34..6ff35ebd79a 100644 --- a/src/java.base/share/classes/java/lang/StrictMath.java +++ b/src/java.base/share/classes/java/lang/StrictMath.java @@ -40,7 +40,7 @@ import jdk.internal.HotSpotIntrinsicCandidate; * algorithms are available from the well-known network library * {@code netlib} as the package "Freely Distributable Math * Library," {@code fdlibm}. These + * href="https://www.netlib.org/fdlibm/">{@code fdlibm}. These * algorithms, which are written in the C programming language, are * then to be understood as executed with all floating-point * operations following the rules of Java floating-point arithmetic. From d9095c4a72fe31825b018db50f4cc447dfa43765 Mon Sep 17 00:00:00 2001 From: Liam Miller-Cushon Date: Mon, 17 Sep 2018 11:09:43 -0700 Subject: [PATCH 07/84] 8198945: Invalid RuntimeVisibleTypeAnnotations for annotation on anonymous class type parameter Reviewed-by: wmdietl, abuckley, martin --- .../sun/tools/javac/code/TypeAnnotations.java | 46 ++- .../com/sun/tools/javac/comp/Annotate.java | 4 +- .../sun/tools/javac/parser/JavacParser.java | 22 +- .../classfile/AnonymousClassTest.java | 271 ++++++++++++++++++ 4 files changed, 297 insertions(+), 46 deletions(-) create mode 100644 test/langtools/tools/javac/annotations/typeAnnotations/classfile/AnonymousClassTest.java diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/code/TypeAnnotations.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/code/TypeAnnotations.java index 0f77ad316cd..ee20b35467e 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/code/TypeAnnotations.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/code/TypeAnnotations.java @@ -1297,15 +1297,26 @@ public class TypeAnnotations { super.visitTypeParameter(tree); } - private void copyNewClassAnnotationsToOwner(JCNewClass tree) { + private void propagateNewClassAnnotationsToOwner(JCNewClass tree) { Symbol sym = tree.def.sym; - final TypeAnnotationPosition pos = - TypeAnnotationPosition.newObj(tree.pos); - ListBuffer newattrs = new ListBuffer<>(); + // The anonymous class' synthetic class declaration is itself an inner class, + // so the type path is one INNER_TYPE entry deeper than that of the + // lexically enclosing class. + List depth = + locateNestedTypes(sym.owner.enclClass().type, new ListBuffer<>()) + .append(TypePathEntry.INNER_TYPE).toList(); + TypeAnnotationPosition pos = + TypeAnnotationPosition.newObj(depth, /* currentLambda= */ null, tree.pos); + ListBuffer newattrs = new ListBuffer<>(); + List expectedLocation = + locateNestedTypes(tree.clazz.type, new ListBuffer<>()).toList(); for (Attribute.TypeCompound old : sym.getRawTypeAttributes()) { - newattrs.append(new Attribute.TypeCompound(old.type, old.values, - pos)); + // Only propagate type annotations from the top-level supertype, + // (including if the supertype is an inner class). + if (old.position.location.equals(expectedLocation)) { + newattrs.append(new Attribute.TypeCompound(old.type, old.values, pos)); + } } sym.owner.appendUniqueTypeAttributes(newattrs.toList()); @@ -1313,27 +1324,8 @@ public class TypeAnnotations { @Override public void visitNewClass(JCNewClass tree) { - if (tree.def != null && - !tree.def.mods.annotations.isEmpty()) { - JCClassDecl classdecl = tree.def; - TypeAnnotationPosition pos; - - if (classdecl.extending == tree.clazz) { - pos = TypeAnnotationPosition.classExtends(tree.pos); - } else if (classdecl.implementing.contains(tree.clazz)) { - final int index = classdecl.implementing.indexOf(tree.clazz); - pos = TypeAnnotationPosition.classExtends(index, tree.pos); - } else { - // In contrast to CLASS elsewhere, typarams cannot occur here. - throw new AssertionError("Could not determine position of tree " + tree); - } - Type before = classdecl.sym.type; - separateAnnotationsKinds(classdecl, tree.clazz.type, classdecl.sym, pos); - copyNewClassAnnotationsToOwner(tree); - // classdecl.sym.type now contains an annotated type, which - // is not what we want there. - // TODO: should we put this type somewhere in the superclass/interface? - classdecl.sym.type = before; + if (tree.def != null && tree.def.sym != null) { + propagateNewClassAnnotationsToOwner(tree); } scan(tree.encl); diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Annotate.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Annotate.java index b0954b51c5f..424da7c13fb 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Annotate.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Annotate.java @@ -1115,7 +1115,9 @@ public class Annotate { public void visitNewClass(JCNewClass tree) { scan(tree.encl); scan(tree.typeargs); - scan(tree.clazz); + if (tree.def == null) { + scan(tree.clazz); + } scan(tree.args); // the anonymous class instantiation if any will be visited separately. } diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/JavacParser.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/JavacParser.java index df992908488..217c4a609bf 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/JavacParser.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/JavacParser.java @@ -2255,25 +2255,11 @@ public class JavacParser implements Parser { } return e; } else if (token.kind == LPAREN) { - JCNewClass newClass = classCreatorRest(newpos, null, typeArgs, t); - if (newClass.def != null) { - assert newClass.def.mods.annotations.isEmpty(); - if (newAnnotations.nonEmpty()) { - // Add type and declaration annotations to the new class; - // com.sun.tools.javac.code.TypeAnnotations.TypeAnnotationPositions.visitNewClass(JCNewClass) - // will later remove all type annotations and only leave the - // declaration annotations. - newClass.def.mods.pos = earlier(newClass.def.mods.pos, newAnnotations.head.pos); - newClass.def.mods.annotations = newAnnotations; - } - } else { - // handle type annotations for instantiations - if (newAnnotations.nonEmpty()) { - t = insertAnnotationsToMostInner(t, newAnnotations, false); - newClass.clazz = t; - } + // handle type annotations for instantiations and anonymous classes + if (newAnnotations.nonEmpty()) { + t = insertAnnotationsToMostInner(t, newAnnotations, false); } - return newClass; + return classCreatorRest(newpos, null, typeArgs, t); } else { setErrorEndPos(token.pos); reportSyntaxError(token.pos, Errors.Expected2(LPAREN, LBRACKET)); diff --git a/test/langtools/tools/javac/annotations/typeAnnotations/classfile/AnonymousClassTest.java b/test/langtools/tools/javac/annotations/typeAnnotations/classfile/AnonymousClassTest.java new file mode 100644 index 00000000000..dd4503bdaa5 --- /dev/null +++ b/test/langtools/tools/javac/annotations/typeAnnotations/classfile/AnonymousClassTest.java @@ -0,0 +1,271 @@ +/* + * Copyright (c) 2018 Google LLC. 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 8198945 8207018 + * @summary Invalid RuntimeVisibleTypeAnnotations for annotation on anonymous class type parameter + * @library /tools/lib + * @modules jdk.compiler/com.sun.tools.javac.api + * jdk.compiler/com.sun.tools.javac.main + * jdk.jdeps/com.sun.tools.classfile + * jdk.jdeps/com.sun.tools.javap + * @build toolbox.ToolBox toolbox.JavapTask + * @run compile -g AnonymousClassTest.java + * @run main AnonymousClassTest + */ + +import static java.util.stream.Collectors.toSet; + +import com.sun.tools.classfile.Annotation; +import com.sun.tools.classfile.Annotation.Annotation_element_value; +import com.sun.tools.classfile.Annotation.Array_element_value; +import com.sun.tools.classfile.Annotation.Class_element_value; +import com.sun.tools.classfile.Annotation.Enum_element_value; +import com.sun.tools.classfile.Annotation.Primitive_element_value; +import com.sun.tools.classfile.Annotation.element_value; +import com.sun.tools.classfile.Annotation.element_value.Visitor; +import com.sun.tools.classfile.Attribute; +import com.sun.tools.classfile.ClassFile; +import com.sun.tools.classfile.Code_attribute; +import com.sun.tools.classfile.ConstantPool.CONSTANT_Integer_info; +import com.sun.tools.classfile.ConstantPool.InvalidIndex; +import com.sun.tools.classfile.ConstantPoolException; +import com.sun.tools.classfile.Method; +import com.sun.tools.classfile.RuntimeVisibleTypeAnnotations_attribute; +import com.sun.tools.classfile.TypeAnnotation; +import com.sun.tools.classfile.TypeAnnotation.Position; +import java.lang.annotation.ElementType; +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; +import java.lang.annotation.Target; +import java.nio.file.Paths; +import java.util.Arrays; +import java.util.Set; +import java.util.concurrent.Callable; +import toolbox.ToolBox; + +public class AnonymousClassTest { + + @Retention(RetentionPolicy.RUNTIME) + @Target(ElementType.TYPE_USE) + public @interface TA { + int value() default 0; + } + + private void f() { + new @TA(0) Callable<@TA(1) Object>() { + public Object call() { + return null; + } + }; + } + + class Inner { + private void g() { + // The annotation is propagated from the top-level class Object to NEW expression for + // the anonymous class' synthetic class declaration, which is an inner class of an inner + // class. + new @TA(2) Object() {}; + } + } + + private void g() { + new @TA(3) AnonymousClassTest.@TA(4) Inner() {}; + } + + public static void main(String args[]) throws Exception { + testAnonymousClassDeclaration(); + testTopLevelMethod(); + testInnerClassMethod(); + testQualifiedSuperType(); + } + + static void testAnonymousClassDeclaration() throws Exception { + ClassFile cf = ClassFile.read(Paths.get(ToolBox.testClasses, "AnonymousClassTest$1.class")); + RuntimeVisibleTypeAnnotations_attribute rvta = + (RuntimeVisibleTypeAnnotations_attribute) + cf.attributes.get(Attribute.RuntimeVisibleTypeAnnotations); + assertEquals( + Set.of( + "@LAnonymousClassTest$TA;(1) CLASS_EXTENDS, offset=-1, location=[TYPE_ARGUMENT(0)]", + "@LAnonymousClassTest$TA;(0) CLASS_EXTENDS, offset=-1, location=[]"), + Arrays.stream(rvta.annotations) + .map(a -> annotationDebugString(cf, a)) + .collect(toSet())); + } + + static void testTopLevelMethod() throws Exception { + ClassFile cf = ClassFile.read(Paths.get(ToolBox.testClasses, "AnonymousClassTest.class")); + Method method = findMethod(cf, "f"); + Set annotations = getRuntimeVisibleTypeAnnotations(method); + assertEquals( + Set.of("@LAnonymousClassTest$TA;(0) NEW, offset=0, location=[INNER_TYPE]"), + annotations.stream().map(a -> annotationDebugString(cf, a)).collect(toSet())); + } + + static void testInnerClassMethod() throws Exception { + ClassFile cf = + ClassFile.read(Paths.get(ToolBox.testClasses, "AnonymousClassTest$Inner.class")); + Method method = findMethod(cf, "g"); + Set annotations = getRuntimeVisibleTypeAnnotations(method); + // The annotation needs two INNER_TYPE type path entries to apply to + // AnonymousClassTest$Inner$1. + assertEquals( + Set.of( + "@LAnonymousClassTest$TA;(2) NEW, offset=0, location=[INNER_TYPE, INNER_TYPE]"), + annotations.stream().map(a -> annotationDebugString(cf, a)).collect(toSet())); + } + + static void testQualifiedSuperType() throws Exception { + { + ClassFile cf = + ClassFile.read(Paths.get(ToolBox.testClasses, "AnonymousClassTest.class")); + Method method = findMethod(cf, "g"); + Set annotations = getRuntimeVisibleTypeAnnotations(method); + // Only @TA(4) is propagated to the anonymous class declaration. + assertEquals( + Set.of("@LAnonymousClassTest$TA;(4) NEW, offset=0, location=[INNER_TYPE]"), + annotations.stream().map(a -> annotationDebugString(cf, a)).collect(toSet())); + } + + { + ClassFile cf = + ClassFile.read(Paths.get(ToolBox.testClasses, "AnonymousClassTest$2.class")); + RuntimeVisibleTypeAnnotations_attribute rvta = + (RuntimeVisibleTypeAnnotations_attribute) + cf.attributes.get(Attribute.RuntimeVisibleTypeAnnotations); + assertEquals( + Set.of( + "@LAnonymousClassTest$TA;(3) CLASS_EXTENDS, offset=-1, location=[]", + "@LAnonymousClassTest$TA;(4) CLASS_EXTENDS, offset=-1, location=[INNER_TYPE]"), + Arrays.stream(rvta.annotations) + .map(a -> annotationDebugString(cf, a)) + .collect(toSet())); + } + } + + // Returns the Method's RuntimeVisibleTypeAnnotations, and asserts that there are no RVTIs + // erroneously associated with the Method instead of its Code attribute. + private static Set getRuntimeVisibleTypeAnnotations(Method method) { + if (method.attributes.get(Attribute.RuntimeVisibleTypeAnnotations) != null) { + throw new AssertionError( + "expected no RuntimeVisibleTypeAnnotations attribute on enclosing method"); + } + Code_attribute code = (Code_attribute) method.attributes.get(Attribute.Code); + RuntimeVisibleTypeAnnotations_attribute rvta = + (RuntimeVisibleTypeAnnotations_attribute) + code.attributes.get(Attribute.RuntimeVisibleTypeAnnotations); + return Set.of(rvta.annotations); + } + + private static Method findMethod(ClassFile cf, String name) { + return Arrays.stream(cf.methods) + .filter( + m -> { + try { + return m.getName(cf.constant_pool).contentEquals(name); + } catch (ConstantPoolException e) { + throw new AssertionError(e); + } + }) + .findFirst() + .get(); + } + + private static void assertEquals(Object expected, Object actual) { + if (!actual.equals(expected)) { + throw new AssertionError(String.format("expected: %s, saw: %s", expected, actual)); + } + } + + private static String annotationDebugString(ClassFile cf, TypeAnnotation annotation) { + Position pos = annotation.position; + String name; + try { + name = cf.constant_pool.getUTF8Info(annotation.annotation.type_index).value; + } catch (Exception e) { + throw new AssertionError(e); + } + return String.format( + "@%s(%s) %s, offset=%d, location=%s", + name, + annotationValueoDebugString(cf, annotation.annotation), + pos.type, + pos.offset, + pos.location); + } + + private static String annotationValueoDebugString(ClassFile cf, Annotation annotation) { + if (annotation.element_value_pairs.length != 1) { + throw new UnsupportedOperationException(); + } + try { + return elementValueDebugString(cf, annotation.element_value_pairs[0].value); + } catch (Exception e) { + throw new AssertionError(e); + } + } + + private static String elementValueDebugString(ClassFile cf, element_value value) { + class Viz implements Visitor { + @Override + public String visitPrimitive(Primitive_element_value ev, Void aVoid) { + try { + switch (ev.tag) { + case 'I': + return Integer.toString( + ((CONSTANT_Integer_info) + cf.constant_pool.get(ev.const_value_index)) + .value); + default: + throw new UnsupportedOperationException(String.format("%c", ev.tag)); + } + } catch (InvalidIndex e) { + throw new AssertionError(e); + } + } + + @Override + public String visitEnum(Enum_element_value ev, Void aVoid) { + throw new UnsupportedOperationException(); + } + + @Override + public String visitClass(Class_element_value ev, Void aVoid) { + throw new UnsupportedOperationException(); + } + + @Override + public String visitAnnotation(Annotation_element_value ev, Void aVoid) { + throw new UnsupportedOperationException(); + } + + @Override + public String visitArray(Array_element_value ev, Void aVoid) { + throw new UnsupportedOperationException(); + } + } + return value.accept(new Viz(), null); + } +} From 02966a7b67c14e1e6442fd586325db8959b0ffc3 Mon Sep 17 00:00:00 2001 From: Jonathan Gibbons Date: Mon, 29 Oct 2018 12:33:41 -0700 Subject: [PATCH 08/84] 8213102: Oracle Unilinks are [301 Moved Permanently] to https://docs.oracle.com Reviewed-by: lancea, mchung --- make/Docs.gmk | 2 +- make/jdk/src/classes/build/tools/taglet/ExtLink.java | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/make/Docs.gmk b/make/Docs.gmk index fdaed245e76..a3adae9117a 100644 --- a/make/Docs.gmk +++ b/make/Docs.gmk @@ -61,7 +61,7 @@ MODULES_SOURCE_PATH := $(call PathList, $(call GetModuleSrcPath) \ $(SUPPORT_OUTPUTDIR)/rmic/* $(TOPDIR)/src/*/share/doc/stub) # URLs -JAVADOC_BASE_URL := https://www.oracle.com/pls/topic/lookup?ctx=javase$(VERSION_NUMBER)&id=homepage +JAVADOC_BASE_URL := https://docs.oracle.com/pls/topic/lookup?ctx=javase$(VERSION_NUMBER)&id=homepage BUG_SUBMIT_URL := https://bugreport.java.com/bugreport/ COPYRIGHT_URL := {@docroot}/../legal/copyright.html LICENSE_URL := https://www.oracle.com/technetwork/java/javase/terms/license/java$(VERSION_NUMBER)speclicense.html diff --git a/make/jdk/src/classes/build/tools/taglet/ExtLink.java b/make/jdk/src/classes/build/tools/taglet/ExtLink.java index f3f9c7c5fc8..be261bc4a46 100644 --- a/make/jdk/src/classes/build/tools/taglet/ExtLink.java +++ b/make/jdk/src/classes/build/tools/taglet/ExtLink.java @@ -48,7 +48,7 @@ import static com.sun.source.doctree.DocTree.Kind.*; * will produce the following html *

* {@code - * Please see a spectacular sight. + * Please see a spectacular sight. * } */ public class ExtLink implements Taglet { @@ -63,7 +63,7 @@ public class ExtLink implements Taglet { static final String TAG_NAME = "extLink"; - static final String URL = "https://www.oracle.com/pls/topic/lookup?ctx=javase" + + static final String URL = "https://docs.oracle.com/pls/topic/lookup?ctx=javase" + SPEC_VERSION + "&id="; static final Pattern TAG_PATTERN = Pattern.compile("(?s)(\\s*)(?\\w+)(\\s+)(?.*)$"); From 93395f6a9e304ea907d6cbed263f1039bd383b9d Mon Sep 17 00:00:00 2001 From: Ioi Lam Date: Wed, 17 Oct 2018 15:57:10 -0700 Subject: [PATCH 09/84] 8212200: assert when shared java.lang.Object is redefined by JVMTI agent Reviewed-by: dholmes, jiangli, hseigel, lfoltan, sspitsyn --- src/hotspot/share/classfile/javaClasses.cpp | 22 +- .../share/classfile/systemDictionary.cpp | 38 ++- .../share/classfile/systemDictionary.hpp | 37 +-- src/hotspot/share/memory/filemap.cpp | 22 ++ src/hotspot/share/memory/heapShared.cpp | 5 + src/hotspot/share/prims/jvmtiExport.cpp | 14 ++ src/hotspot/share/prims/jvmtiExport.hpp | 2 + .../ReplaceCriticalClasses.java | 222 ++++++++++++++++++ .../jvmti/libSimpleClassFileLoadHook.c | 24 +- test/lib/jdk/test/lib/cds/CDSOptions.java | 8 +- test/lib/jdk/test/lib/cds/CDSTestUtils.java | 24 +- 11 files changed, 375 insertions(+), 43 deletions(-) create mode 100644 test/hotspot/jtreg/runtime/SharedArchiveFile/serviceability/ReplaceCriticalClasses.java diff --git a/src/hotspot/share/classfile/javaClasses.cpp b/src/hotspot/share/classfile/javaClasses.cpp index f94f5c655d6..dfa094b3f76 100644 --- a/src/hotspot/share/classfile/javaClasses.cpp +++ b/src/hotspot/share/classfile/javaClasses.cpp @@ -50,6 +50,7 @@ #include "oops/oop.inline.hpp" #include "oops/symbol.hpp" #include "oops/typeArrayOop.inline.hpp" +#include "prims/jvmtiExport.hpp" #include "prims/resolvedMethodTable.hpp" #include "runtime/fieldDescriptor.inline.hpp" #include "runtime/frame.inline.hpp" @@ -125,7 +126,7 @@ static void compute_offset(int &dest_offset, if (ik == NULL) { ResourceMark rm; log_error(class)("Mismatch JDK version for field: %s type: %s", name_symbol->as_C_string(), signature_symbol->as_C_string()); - vm_exit_during_initialization("Invalid layout of preloaded class"); + vm_exit_during_initialization("Invalid layout of well-known class"); } if (!ik->find_local_field(name_symbol, signature_symbol, &fd) || fd.is_static() != is_static) { @@ -138,7 +139,7 @@ static void compute_offset(int &dest_offset, LogStream ls(lt.error()); ik->print_on(&ls); #endif //PRODUCT - vm_exit_during_initialization("Invalid layout of preloaded class: use -Xlog:class+load=info to see the origin of the problem class"); + vm_exit_during_initialization("Invalid layout of well-known class: use -Xlog:class+load=info to see the origin of the problem class"); } dest_offset = fd.offset(); } @@ -151,7 +152,7 @@ static void compute_offset(int& dest_offset, InstanceKlass* ik, if (name == NULL) { ResourceMark rm; log_error(class)("Name %s should be in the SymbolTable since its class is loaded", name_string); - vm_exit_during_initialization("Invalid layout of preloaded class", ik->external_name()); + vm_exit_during_initialization("Invalid layout of well-known class", ik->external_name()); } compute_offset(dest_offset, ik, name, signature_symbol, is_static); } @@ -1196,7 +1197,7 @@ bool java_lang_Class::restore_archived_mirror(Klass *k, Handle class_loader, Handle module, Handle protection_domain, TRAPS) { // Postpone restoring archived mirror until java.lang.Class is loaded. Please - // see more details in SystemDictionary::resolve_preloaded_classes(). + // see more details in SystemDictionary::resolve_well_known_classes(). if (!SystemDictionary::Class_klass_loaded()) { assert(fixup_mirror_list() != NULL, "fixup_mirror_list not initialized"); fixup_mirror_list()->push(k); @@ -4250,12 +4251,19 @@ void JavaClasses::compute_hard_coded_offsets() { // Compute non-hard-coded field offsets of all the classes in this file void JavaClasses::compute_offsets() { if (UseSharedSpaces) { - return; // field offsets are loaded from archive + assert(JvmtiExport::is_early_phase() && !(JvmtiExport::should_post_class_file_load_hook() && + JvmtiExport::has_early_class_hook_env()), + "JavaClasses::compute_offsets() must be called in early JVMTI phase."); + // None of the classes used by the rest of this function can be replaced by + // JMVTI ClassFileLoadHook. + // We are safe to use the archived offsets, which have already been restored + // by JavaClasses::serialize_offsets, without computing the offsets again. + return; } // We have already called the compute_offsets() of the // BASIC_JAVA_CLASSES_DO_PART1 classes (java_lang_String and java_lang_Class) - // earlier inside SystemDictionary::resolve_preloaded_classes() + // earlier inside SystemDictionary::resolve_well_known_classes() BASIC_JAVA_CLASSES_DO_PART2(DO_COMPUTE_OFFSETS); // generated interpreter code wants to know about the offsets we just computed: @@ -4356,7 +4364,7 @@ int InjectedField::compute_offset() { tty->print_cr(" name: %s, sig: %s, flags: %08x", fs.name()->as_C_string(), fs.signature()->as_C_string(), fs.access_flags().as_int()); } #endif //PRODUCT - vm_exit_during_initialization("Invalid layout of preloaded class: use -Xlog:class+load=info to see the origin of the problem class"); + vm_exit_during_initialization("Invalid layout of well-known class: use -Xlog:class+load=info to see the origin of the problem class"); return -1; } diff --git a/src/hotspot/share/classfile/systemDictionary.cpp b/src/hotspot/share/classfile/systemDictionary.cpp index 05262b1f572..0338e0eca6b 100644 --- a/src/hotspot/share/classfile/systemDictionary.cpp +++ b/src/hotspot/share/classfile/systemDictionary.cpp @@ -67,7 +67,7 @@ #include "oops/oop.inline.hpp" #include "oops/symbol.hpp" #include "oops/typeArrayKlass.hpp" -#include "prims/jvmtiEnvBase.hpp" +#include "prims/jvmtiExport.hpp" #include "prims/resolvedMethodTable.hpp" #include "prims/methodHandles.hpp" #include "runtime/arguments.hpp" @@ -1489,8 +1489,7 @@ InstanceKlass* SystemDictionary::load_instance_class(Symbol* class_name, Handle !search_only_bootloader_append, "Attempt to load a class outside of boot loader's module path"); - // Search the shared system dictionary for classes preloaded into the - // shared spaces. + // Search for classes in the CDS archive. InstanceKlass* k = NULL; { #if INCLUDE_CDS @@ -1958,7 +1957,7 @@ void SystemDictionary::initialize(TRAPS) { // Allocate private object used as system class loader lock _system_loader_lock_obj = oopFactory::new_intArray(0, CHECK); // Initialize basic classes - resolve_preloaded_classes(CHECK); + resolve_well_known_classes(CHECK); } // Compact table of directions on the initialization of klasses: @@ -1971,6 +1970,19 @@ static const short wk_init_info[] = { 0 }; +#ifdef ASSERT +bool SystemDictionary::is_well_known_klass(Symbol* class_name) { + int sid; + for (int i = 0; (sid = wk_init_info[i]) != 0; i++) { + Symbol* symbol = vmSymbols::symbol_at((vmSymbols::SID)sid); + if (class_name == symbol) { + return true; + } + } + return false; +} +#endif + bool SystemDictionary::resolve_wk_klass(WKID id, TRAPS) { assert(id >= (int)FIRST_WKID && id < (int)WKID_LIMIT, "oob"); int sid = wk_init_info[id - FIRST_WKID]; @@ -2002,8 +2014,8 @@ void SystemDictionary::resolve_wk_klasses_until(WKID limit_id, WKID &start_id, T start_id = limit_id; } -void SystemDictionary::resolve_preloaded_classes(TRAPS) { - assert(WK_KLASS(Object_klass) == NULL, "preloaded classes should only be initialized once"); +void SystemDictionary::resolve_well_known_classes(TRAPS) { + assert(WK_KLASS(Object_klass) == NULL, "well-known classes should only be initialized once"); // Create the ModuleEntry for java.base. This call needs to be done here, // after vmSymbols::initialize() is called but before any classes are pre-loaded. @@ -2071,7 +2083,8 @@ void SystemDictionary::resolve_preloaded_classes(TRAPS) { WKID jsr292_group_end = WK_KLASS_ENUM_NAME(VolatileCallSite_klass); resolve_wk_klasses_until(jsr292_group_start, scan, CHECK); resolve_wk_klasses_through(jsr292_group_end, scan, CHECK); - resolve_wk_klasses_until(NOT_JVMCI(WKID_LIMIT) JVMCI_ONLY(FIRST_JVMCI_WKID), scan, CHECK); + WKID last = NOT_JVMCI(WKID_LIMIT) JVMCI_ONLY(FIRST_JVMCI_WKID); + resolve_wk_klasses_until(last, scan, CHECK); _box_klasses[T_BOOLEAN] = WK_KLASS(Boolean_klass); _box_klasses[T_CHAR] = WK_KLASS(Character_klass); @@ -2088,6 +2101,17 @@ void SystemDictionary::resolve_preloaded_classes(TRAPS) { Method* method = InstanceKlass::cast(ClassLoader_klass())->find_method(vmSymbols::checkPackageAccess_name(), vmSymbols::class_protectiondomain_signature()); _has_checkPackageAccess = (method != NULL); } + +#ifdef ASSERT + if (UseSharedSpaces) { + assert(JvmtiExport::is_early_phase(), + "All well known classes must be resolved in JVMTI early phase"); + for (int i = FIRST_WKID; i < last; i++) { + InstanceKlass* k = _well_known_klasses[i]; + assert(k->is_shared(), "must not be replaced by JVMTI class file load hook"); + } + } +#endif } // Tells if a given klass is a box (wrapper class, such as java.lang.Integer). diff --git a/src/hotspot/share/classfile/systemDictionary.hpp b/src/hotspot/share/classfile/systemDictionary.hpp index d34240701b1..fbace1976f1 100644 --- a/src/hotspot/share/classfile/systemDictionary.hpp +++ b/src/hotspot/share/classfile/systemDictionary.hpp @@ -85,19 +85,20 @@ class ProtectionDomainCacheEntry; class GCTimer; class OopStorage; -// Certain classes are preloaded, such as java.lang.Object and java.lang.String. -// They are all "well-known", in the sense that no class loader is allowed -// to provide a different definition. -// -// These klasses must all have names defined in vmSymbols. - #define WK_KLASS_ENUM_NAME(kname) kname##_knum +// Certain classes, such as java.lang.Object and java.lang.String, +// are "well-known", in the sense that no class loader is allowed +// to provide a different definition. +// // Each well-known class has a short klass name (like object_klass), // and a vmSymbol name (like java_lang_Object). -// The order of these definitions is significant; it is the order in which -// preloading is actually performed by resolve_preloaded_classes. - +// +// The order of these definitions is significant: the classes are +// resolved during early VM start-up by resolve_well_known_classes +// in this order. Changing the order may require careful restructuring +// of the VM start-up sequence. +// #define WK_KLASSES_DO(do_klass) \ /* well-known classes */ \ do_klass(Object_klass, java_lang_Object ) \ @@ -127,7 +128,7 @@ class OopStorage; do_klass(IllegalMonitorStateException_klass, java_lang_IllegalMonitorStateException ) \ do_klass(Reference_klass, java_lang_ref_Reference ) \ \ - /* Preload ref klasses and set reference types */ \ + /* ref klasses and set reference types */ \ do_klass(SoftReference_klass, java_lang_ref_SoftReference ) \ do_klass(WeakReference_klass, java_lang_ref_WeakReference ) \ do_klass(FinalReference_klass, java_lang_ref_FinalReference ) \ @@ -200,7 +201,7 @@ class OopStorage; /* support for stack dump lock analysis */ \ do_klass(java_util_concurrent_locks_AbstractOwnableSynchronizer_klass, java_util_concurrent_locks_AbstractOwnableSynchronizer) \ \ - /* Preload boxing klasses */ \ + /* boxing klasses */ \ do_klass(Boolean_klass, java_lang_Boolean ) \ do_klass(Character_klass, java_lang_Character ) \ do_klass(Float_klass, java_lang_Float ) \ @@ -391,7 +392,8 @@ public: // Initialization static void initialize(TRAPS); - // Checked fast access to commonly used classes - mostly preloaded + // Checked fast access to the well-known classes -- so that you don't try to use them + // before they are resolved. static InstanceKlass* check_klass(InstanceKlass* k) { assert(k != NULL, "klass not loaded"); return k; @@ -435,6 +437,12 @@ public: return check_klass(_box_klasses[t]); } static BasicType box_klass_type(Klass* k); // inverse of box_klass +#ifdef ASSERT + static bool is_well_known_klass(Klass* k) { + return is_well_known_klass(k->name()); + } + static bool is_well_known_klass(Symbol* class_name); +#endif protected: // Returns the class loader data to be used when looking up/updating the @@ -695,8 +703,8 @@ protected: ClassLoaderData* loader_data, TRAPS); - // Resolve preloaded classes so they can be used like SystemDictionary::String_klass() - static void resolve_preloaded_classes(TRAPS); + // Resolve well-known classes so they can be used like SystemDictionary::String_klass() + static void resolve_well_known_classes(TRAPS); // Class loader constraints static void check_constraints(unsigned int hash, @@ -707,7 +715,6 @@ protected: InstanceKlass* k, Handle loader, TRAPS); - // Variables holding commonly used klasses (preloaded) static InstanceKlass* _well_known_klasses[]; // table of box klasses (int_klass, etc.) diff --git a/src/hotspot/share/memory/filemap.cpp b/src/hotspot/share/memory/filemap.cpp index 63778deb8f1..5f287f301cd 100644 --- a/src/hotspot/share/memory/filemap.cpp +++ b/src/hotspot/share/memory/filemap.cpp @@ -914,6 +914,19 @@ void FileMapInfo::map_heap_regions_impl() { return; } + if (JvmtiExport::should_post_class_file_load_hook() && JvmtiExport::has_early_class_hook_env()) { + ShouldNotReachHere(); // CDS should have been disabled. + // The archived objects are mapped at JVM start-up, but we don't know if + // j.l.String or j.l.Class might be replaced by the ClassFileLoadHook, + // which would make the archived String or mirror objects invalid. Let's be safe and not + // use the archived objects. These 2 classes are loaded during the JVMTI "early" stage. + // + // If JvmtiExport::has_early_class_hook_env() is false, the classes of some objects + // in the archived subgraphs may be replaced by the ClassFileLoadHook. But that's OK + // because we won't install an archived object subgraph if the klass of any of the + // referenced objects are replaced. See HeapShared::initialize_from_archived_subgraph(). + } + MemRegion heap_reserved = Universe::heap()->reserved_region(); log_info(cds)("CDS archive was created with max heap size = " SIZE_FORMAT "M, and the following configuration:", @@ -1224,6 +1237,15 @@ bool FileMapInfo::_validating_shared_path_table = false; bool FileMapInfo::initialize() { assert(UseSharedSpaces, "UseSharedSpaces expected."); + if (JvmtiExport::should_post_class_file_load_hook() && JvmtiExport::has_early_class_hook_env()) { + // CDS assumes that no classes resolved in SystemDictionary::resolve_well_known_classes + // are replaced at runtime by JVMTI ClassFileLoadHook. All of those classes are resolved + // during the JVMTI "early" stage, so we can still use CDS if + // JvmtiExport::has_early_class_hook_env() is false. + FileMapInfo::fail_continue("CDS is disabled because early JVMTI ClassFileLoadHook is in use."); + return false; + } + if (!open_for_read()) { return false; } diff --git a/src/hotspot/share/memory/heapShared.cpp b/src/hotspot/share/memory/heapShared.cpp index 69e10b1767e..4c9d55ccf8a 100644 --- a/src/hotspot/share/memory/heapShared.cpp +++ b/src/hotspot/share/memory/heapShared.cpp @@ -417,6 +417,11 @@ void HeapShared::initialize_from_archived_subgraph(Klass* k) { Klass* resolved_k = SystemDictionary::resolve_or_null( (obj_k)->name(), THREAD); if (resolved_k != obj_k) { + assert(!SystemDictionary::is_well_known_klass(resolved_k), + "shared well-known classes must not be replaced by JVMTI ClassFileLoadHook"); + ResourceMark rm(THREAD); + log_info(cds, heap)("Failed to load subgraph because %s was not loaded from archive", + resolved_k->external_name()); return; } if ((obj_k)->is_instance_klass()) { diff --git a/src/hotspot/share/prims/jvmtiExport.cpp b/src/hotspot/share/prims/jvmtiExport.cpp index 07f381e1c48..3379dcc1b7e 100644 --- a/src/hotspot/share/prims/jvmtiExport.cpp +++ b/src/hotspot/share/prims/jvmtiExport.cpp @@ -994,6 +994,20 @@ class JvmtiClassFileLoadHookPoster : public StackObj { } }; +bool JvmtiExport::is_early_phase() { + return JvmtiEnvBase::get_phase() <= JVMTI_PHASE_PRIMORDIAL; +} + +bool JvmtiExport::has_early_class_hook_env() { + JvmtiEnvIterator it; + for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) { + if (env->early_class_hook_env()) { + return true; + } + } + return false; +} + bool JvmtiExport::_should_post_class_file_load_hook = false; // this entry is for class file load hook on class load, redefine and retransform diff --git a/src/hotspot/share/prims/jvmtiExport.hpp b/src/hotspot/share/prims/jvmtiExport.hpp index 42c9000693a..7e8fc7e584e 100644 --- a/src/hotspot/share/prims/jvmtiExport.hpp +++ b/src/hotspot/share/prims/jvmtiExport.hpp @@ -328,6 +328,8 @@ class JvmtiExport : public AllStatic { JVMTI_ONLY(return _should_post_class_file_load_hook); NOT_JVMTI(return false;) } + static bool is_early_phase(); + static bool has_early_class_hook_env(); // Return true if the class was modified by the hook. static bool post_class_file_load_hook(Symbol* h_name, Handle class_loader, Handle h_protection_domain, diff --git a/test/hotspot/jtreg/runtime/SharedArchiveFile/serviceability/ReplaceCriticalClasses.java b/test/hotspot/jtreg/runtime/SharedArchiveFile/serviceability/ReplaceCriticalClasses.java new file mode 100644 index 00000000000..696d2afaeba --- /dev/null +++ b/test/hotspot/jtreg/runtime/SharedArchiveFile/serviceability/ReplaceCriticalClasses.java @@ -0,0 +1,222 @@ +/* + * Copyright (c) 2018, 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 Tests how CDS works when critical library classes are replaced with JVMTI ClassFileLoadHook + * @library /test/lib + * @requires vm.cds + * @build sun.hotspot.WhiteBox + * @run driver ClassFileInstaller -jar whitebox.jar sun.hotspot.WhiteBox + * @run main/othervm/native ReplaceCriticalClasses + */ + +import java.util.regex.Matcher; +import java.util.regex.Pattern; +import jdk.test.lib.cds.CDSTestUtils; +import jdk.test.lib.cds.CDSOptions; +import jdk.test.lib.process.OutputAnalyzer; +import sun.hotspot.WhiteBox; + +public class ReplaceCriticalClasses { + public static void main(String args[]) throws Throwable { + if (args.length == 0) { + launchChildProcesses(); + } else if (args.length == 3 && args[0].equals("child")) { + Class klass = Class.forName(args[2].replace("/", ".")); + if (args[1].equals("-shared")) { + testInChild(true, klass); + } else if (args[1].equals("-notshared")) { + testInChild(false, klass); + } else { + throw new RuntimeException("Unknown child exec option " + args[1]); + } + return; + } else { + throw new RuntimeException("Usage: @run main/othervm/native ReplaceCriticalClasses"); + } + } + + static void launchChildProcesses() throws Throwable { + String tests[] = { + // CDS should be disabled -- these critical classes will be replaced + // because JvmtiExport::early_class_hook_env() is true. + "-early -notshared java/lang/Object", + "-early -notshared java/lang/String", + "-early -notshared java/lang/Cloneable", + "-early -notshared java/io/Serializable", + + // CDS should not be disabled -- these critical classes cannot be replaced because + // JvmtiExport::early_class_hook_env() is false. + "java/lang/Object", + "java/lang/String", + "java/lang/Cloneable", + "java/io/Serializable", + + // Try to replace classes that are used by the archived subgraph graphs. + "-subgraph java/util/ArrayList", + "-subgraph java/lang/module/ResolvedModule", + + // Replace classes that are loaded after JVMTI_PHASE_PRIMORDIAL. It's OK to replace such + // classes even when CDS is enabled. Nothing bad should happen. + "-notshared jdk/internal/vm/PostVMInitHook", + "-notshared java/util/Locale", + "-notshared sun/util/locale/BaseLocale", + "-notshared java/lang/Readable", + }; + + int n = 0; + for (String s : tests) { + System.out.println("Test case[" + (n++) + "] = \"" + s + "\""); + String args[] = s.split("\\s+"); // split by space character + launchChild(args); + } + } + + static void launchChild(String args[]) throws Throwable { + if (args.length < 1) { + throw new RuntimeException("Invalid test case. Should be <-early> <-subgraph> <-notshared> klassName"); + } + String klassName = null; + String early = ""; + boolean subgraph = false; + String shared = "-shared"; + + for (int i=0; i { + if (expectDisable) { + out.shouldContain("UseSharedSpaces: CDS is disabled because early JVMTI ClassFileLoadHook is in use."); + System.out.println("CDS disabled as expected"); + } + if (checkSubgraph) { + // As of 2018/10/21 the classes in the archived subgraphs won't be + // replaced because all archived subgraphs were loaded in JVMTI_PHASE_PRIMORDIAL. + // + // This is the first class to be loaded after JVMTI has exited JVMTI_PHASE_PRIMORDIAL. + // Make sure no subgraphs are loaded afterwards. + // + // Can't use out.shouldNotMatch() because that doesn't match across multiple lines. + String firstNonPrimordialClass = "jdk.jfr.internal.EventWriter"; + String regexp = firstNonPrimordialClass + ".*initialize_from_archived_subgraph"; + Pattern regex = Pattern.compile(regexp, Pattern.DOTALL); + Matcher matcher = regex.matcher(out.getStdout()); + if (matcher.find()) { + out.reportDiagnosticSummary(); + throw new RuntimeException("'" + regexp + + "' found in stdout: '" + matcher.group() + "' \n"); + } + } + }); + } + + static void testInChild(boolean shouldBeShared, Class klass) { + WhiteBox wb = WhiteBox.getWhiteBox(); + + if (shouldBeShared && !wb.isSharedClass(klass)) { + throw new RuntimeException(klass + " should be shared but but actually is not."); + } + if (!shouldBeShared && wb.isSharedClass(klass)) { + throw new RuntimeException(klass + " should not be shared but actually is."); + } + System.out.println("wb.isSharedClass(klass): " + wb.isSharedClass(klass) + " == " + shouldBeShared); + + String strings[] = { + // interned strings from j.l.Object + "@", + "nanosecond timeout value out of range", + "timeoutMillis value is negative", + + // interned strings from j.l.Integer + "0", + "0X", + "0x", + "int" + }; + + // Make sure the interned string table is same + for (String s : strings) { + String i = s.intern(); + if (s != i) { + throw new RuntimeException("Interned string mismatch: \"" + s + "\" @ " + System.identityHashCode(s) + + " vs \"" + i + "\" @ " + System.identityHashCode(i)); + } + } + // We have tried to use ClassFileLoadHook to replace critical library classes (which may + // may not have succeeded, depending on whether the agent has requested + // can_generate_all_class_hook_events/can_generate_early_class_hook_events capabilities). + // + // In any case, the JVM should have started properly (perhaps with CDS disabled) and + // the above operations should succeed. + System.out.println("If I can come to here without crashing, things should be OK"); + } +} diff --git a/test/hotspot/jtreg/testlibrary/jvmti/libSimpleClassFileLoadHook.c b/test/hotspot/jtreg/testlibrary/jvmti/libSimpleClassFileLoadHook.c index 2424e87c880..a95d7b28a89 100644 --- a/test/hotspot/jtreg/testlibrary/jvmti/libSimpleClassFileLoadHook.c +++ b/test/hotspot/jtreg/testlibrary/jvmti/libSimpleClassFileLoadHook.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2018, 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,17 +91,23 @@ ClassFileLoadHook(jvmtiEnv *jvmti_env, JNIEnv *env, jclass class_beeing_redefine *new_class_data_len = class_data_len; *new_class_data = new_data; - fprintf(stderr, "Rewriting done. Replaced %d occurrence(s)\n", count); + fprintf(stderr, "Rewriting done. Replaced %d occurrence(s) of \"%s\" to \"%s\"\n", count, FROM, TO); } } } +static int early = 0; + static jint init_options(char *options) { char* class_name; char* from; char* to; fprintf(stderr, "Agent library loaded with options = %s\n", options); + if (options != NULL && strncmp(options, "-early,", 7) == 0) { + early = 1; + options += 7; + } if ((class_name = options) != NULL && (from = strchr(class_name, ',')) != NULL && (from[1] != 0)) { *from = 0; @@ -132,6 +138,7 @@ static jint init_options(char *options) { static jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { int rc; + jvmtiCapabilities caps; if ((rc = (*jvm)->GetEnv(jvm, (void **)&jvmti, JVMTI_VERSION_1_1)) != JNI_OK) { fprintf(stderr, "Unable to create jvmtiEnv, GetEnv failed, error = %d\n", rc); @@ -141,6 +148,19 @@ static jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { return JNI_ERR; } + memset(&caps, 0, sizeof(caps)); + + caps.can_redefine_classes = 1; + if (early) { + fprintf(stderr, "can_generate_all_class_hook_events/can_generate_early_vmstart/can_generate_early_class_hook_events == 1\n"); + caps.can_generate_all_class_hook_events = 1; + caps.can_generate_early_class_hook_events = 1; + } + if ((rc = (*jvmti)->AddCapabilities(jvmti, &caps)) != JNI_OK) { + fprintf(stderr, "AddCapabilities failed, error = %d\n", rc); + return JNI_ERR; + } + (void) memset(&callbacks, 0, sizeof(callbacks)); callbacks.ClassFileLoadHook = &ClassFileLoadHook; if ((rc = (*jvmti)->SetEventCallbacks(jvmti, &callbacks, sizeof(callbacks))) != JNI_OK) { diff --git a/test/lib/jdk/test/lib/cds/CDSOptions.java b/test/lib/jdk/test/lib/cds/CDSOptions.java index dbf7b8c9ff1..3f457e20744 100644 --- a/test/lib/jdk/test/lib/cds/CDSOptions.java +++ b/test/lib/jdk/test/lib/cds/CDSOptions.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2018, 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,6 +31,7 @@ public class CDSOptions { public String archiveName; public ArrayList prefix = new ArrayList(); public ArrayList suffix = new ArrayList(); + public boolean useSystemArchive = false; // Indicate whether to append "-version" when using CDS Archive. // Most of tests will use '-version' @@ -68,4 +69,9 @@ public class CDSOptions { this.useVersion = use; return this; } + + public CDSOptions setUseSystemArchive(boolean use) { + this.useSystemArchive = use; + return this; + } } diff --git a/test/lib/jdk/test/lib/cds/CDSTestUtils.java b/test/lib/jdk/test/lib/cds/CDSTestUtils.java index 2989aad607c..2c84bb7e1d8 100644 --- a/test/lib/jdk/test/lib/cds/CDSTestUtils.java +++ b/test/lib/jdk/test/lib/cds/CDSTestUtils.java @@ -82,21 +82,21 @@ public class CDSTestUtils { * * Instead, the test case should be written as * - * CCDSTestUtils.run(args).assertNormalExit("Hi"); + * CDSTestUtils.run(args).assertNormalExit("Hi"); * * EXAMPLES/HOWTO * * 1. For simple substring matching: * - * CCDSTestUtils.run(args).assertNormalExit("Hi"); - * CCDSTestUtils.run(args).assertNormalExit("a", "b", "x"); - * CCDSTestUtils.run(args).assertAbnormalExit("failure 1", "failure2"); + * CDSTestUtils.run(args).assertNormalExit("Hi"); + * CDSTestUtils.run(args).assertNormalExit("a", "b", "x"); + * CDSTestUtils.run(args).assertAbnormalExit("failure 1", "failure2"); * * 2. For more complex output matching: using Lambda expressions * - * CCDSTestUtils.run(args) + * CDSTestUtils.run(args) * .assertNormalExit(output -> output.shouldNotContain("this should not be printed"); - * CCDSTestUtils.run(args) + * CDSTestUtils.run(args) * .assertAbnormalExit(output -> { * output.shouldNotContain("this should not be printed"); * output.shouldHaveExitValue(123); @@ -104,13 +104,13 @@ public class CDSTestUtils { * * 3. Chaining several checks: * - * CCDSTestUtils.run(args) + * CDSTestUtils.run(args) * .assertNormalExit(output -> output.shouldNotContain("this should not be printed") * .assertNormalExit("should have this", "should have that"); * * 4. [Rare use case] if a test sometimes exit normally, and sometimes abnormally: * - * CCDSTestUtils.run(args) + * CDSTestUtils.run(args) * .ifNormalExit("ths string is printed when exiting with 0") * .ifAbNormalExit("ths string is printed when exiting with 1"); * @@ -388,9 +388,11 @@ public class CDSTestUtils { cmd.add("-Xshare:" + opts.xShareMode); cmd.add("-Dtest.timeout.factor=" + TestTimeoutFactor); - if (opts.archiveName == null) - opts.archiveName = getDefaultArchiveName(); - cmd.add("-XX:SharedArchiveFile=" + opts.archiveName); + if (!opts.useSystemArchive) { + if (opts.archiveName == null) + opts.archiveName = getDefaultArchiveName(); + cmd.add("-XX:SharedArchiveFile=" + opts.archiveName); + } if (opts.useVersion) cmd.add("-version"); From 801895a09e557d7a037b3a5cae48f7937f494670 Mon Sep 17 00:00:00 2001 From: Jesper Wilhelmsson Date: Wed, 24 Oct 2018 18:14:28 -0700 Subject: [PATCH 10/84] Added tag jdk-12+17 for changeset eefa65e142af --- .hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/.hgtags b/.hgtags index bed6dcf27f1..64dc8b9c149 100644 --- a/.hgtags +++ b/.hgtags @@ -519,3 +519,4 @@ f0f5d23449d31f1b3580c8a73313918cafeaefd7 jdk-12+11 6f04692c7d5137ee34a6bd94c0c8a6c9219cb127 jdk-12+14 f8626bcc169813a4b2a15880386b952719d1d6d1 jdk-12+15 199658d1ef860cdc17055b4fd3e94b057f292fe9 jdk-12+16 +eefa65e142af305923d2adcd596fab9c639723a1 jdk-12+17 From 6ce0aeb00b10738b25f0f53ff785bfc099ef28c4 Mon Sep 17 00:00:00 2001 From: Amy Lu Date: Thu, 25 Oct 2018 11:00:40 +0800 Subject: [PATCH 11/84] 8210908: Refactor java/util/prefs/PrefsSpi.sh to plain java test Reviewed-by: bchristi --- test/jdk/java/util/prefs/PrefsSpi.java | 4 +- test/jdk/java/util/prefs/PrefsSpi.sh | 104 ----------------- test/jdk/java/util/prefs/PrefsSpiTest.java | 108 ++++++++++++++++++ test/jdk/java/util/prefs/StubPreferences.java | 37 ++++++ .../util/prefs/StubPreferencesFactory.java | 30 +++++ 5 files changed, 177 insertions(+), 106 deletions(-) delete mode 100644 test/jdk/java/util/prefs/PrefsSpi.sh create mode 100644 test/jdk/java/util/prefs/PrefsSpiTest.java create mode 100644 test/jdk/java/util/prefs/StubPreferences.java create mode 100644 test/jdk/java/util/prefs/StubPreferencesFactory.java diff --git a/test/jdk/java/util/prefs/PrefsSpi.java b/test/jdk/java/util/prefs/PrefsSpi.java index b1893dd50a6..332e7954c6c 100644 --- a/test/jdk/java/util/prefs/PrefsSpi.java +++ b/test/jdk/java/util/prefs/PrefsSpi.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2009, 2018, 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 @@ import java.util.prefs.Preferences; /* - * main class used by regtest PrefsSpi.sh + * main class used by regtest PrefsSpiTest.java */ public class PrefsSpi { diff --git a/test/jdk/java/util/prefs/PrefsSpi.sh b/test/jdk/java/util/prefs/PrefsSpi.sh deleted file mode 100644 index 54b67afdf0d..00000000000 --- a/test/jdk/java/util/prefs/PrefsSpi.sh +++ /dev/null @@ -1,104 +0,0 @@ -#!/bin/sh - -# -# Copyright (c) 2009, 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 4991526 6514993 7197662 -# @summary Unit test for Preferences jar providers -# -# @build PrefsSpi -# @run shell PrefsSpi.sh -# @author Martin Buchholz - -# Command-line usage: sh PrefsSpi.sh /path/to/build - -if [ -z "$TESTJAVA" ]; then - if [ $# -lt 1 ]; then exit 1; fi - TESTJAVA="$1"; shift - TESTSRC="`pwd`" - TESTCLASSES="`pwd`" -fi -if [ -z "$COMPILEJAVA" ]; then - COMPILEJAVA="${TESTJAVA}" -fi - - java="$TESTJAVA/bin/java" -javac="$COMPILEJAVA/bin/javac" - jar="$COMPILEJAVA/bin/jar" - -Die() { printf "%s\n" "$*"; exit 1; } - -Sys() { - printf "%s\n" "$*"; "$@"; rc="$?"; - test "$rc" -eq 0 || Die "Command \"$*\" failed with exitValue $rc"; -} - -cat > StubPreferences.java <<'EOF' -import java.util.prefs.*; - -public class StubPreferences extends AbstractPreferences { - public StubPreferences() { super(null, ""); } - public String getSpi(String x) { return null; } - public void putSpi(String x, String y) { } - public void removeSpi(String x) { } - public AbstractPreferences childSpi(String x) { return null; } - public void removeNodeSpi() { } - public String[] keysSpi() { return null; } - public String[] childrenNamesSpi() { return null; } - public void syncSpi() { } - public void flushSpi() { } -} -EOF - -cat > StubPreferencesFactory.java <<'EOF' -import java.util.prefs.*; - -public class StubPreferencesFactory implements PreferencesFactory { - public Preferences userRoot() { return new StubPreferences(); } - public Preferences systemRoot() { return new StubPreferences(); } -} -EOF - -Sys rm -rf jarDir extDir -Sys mkdir -p jarDir/META-INF/services extDir -echo "StubPreferencesFactory" \ - > "jarDir/META-INF/services/java.util.prefs.PreferencesFactory" -Sys "$javac" ${TESTJAVACOPTS} ${TESTTOOLVMOPTS} -d jarDir StubPreferencesFactory.java StubPreferences.java - -(cd jarDir && "$jar" ${TESTTOOLVMOPTS} "cf" "../extDir/PrefsSpi.jar" ".") - -case "`uname`" in Windows*|CYGWIN* ) CPS=';';; *) CPS=':';; esac - -Sys "$java" ${TESTVMOPTS} "-cp" "$TESTCLASSES${CPS}extDir/PrefsSpi.jar" \ - -Djava.util.prefs.PreferencesFactory=StubPreferencesFactory \ - -Djava.util.prefs.userRoot=. \ - PrefsSpi "StubPreferences" -Sys "$java" ${TESTVMOPTS} "-cp" "$TESTCLASSES" \ - -Djava.util.prefs.userRoot=. \ - PrefsSpi "java.util.prefs.*" -Sys "$java" ${TESTVMOPTS} "-cp" "$TESTCLASSES${CPS}extDir/PrefsSpi.jar" \ - -Djava.util.prefs.userRoot=. \ - PrefsSpi "StubPreferences" - -rm -rf jarDir extDir diff --git a/test/jdk/java/util/prefs/PrefsSpiTest.java b/test/jdk/java/util/prefs/PrefsSpiTest.java new file mode 100644 index 00000000000..0369c60cae2 --- /dev/null +++ b/test/jdk/java/util/prefs/PrefsSpiTest.java @@ -0,0 +1,108 @@ +/* + * Copyright (c) 2018, 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 4991526 6514993 7197662 + * @summary Unit test for Preferences jar providers + * @library /test/lib + * @build jdk.test.lib.util.JarUtils jdk.test.lib.process.* + * PrefsSpi StubPreferencesFactory StubPreferences + * @run testng PrefsSpiTest + */ + +import java.io.File; +import java.nio.file.Files; +import java.nio.file.Path; +import java.util.ArrayList; +import java.util.List; + +import jdk.test.lib.JDKToolFinder; +import jdk.test.lib.Utils; +import jdk.test.lib.process.ProcessTools; +import jdk.test.lib.util.JarUtils; + +import org.testng.annotations.BeforeClass; +import org.testng.annotations.DataProvider; +import org.testng.annotations.Test; + +import static java.nio.file.StandardCopyOption.REPLACE_EXISTING; +import static java.nio.file.StandardOpenOption.CREATE; +import static java.util.Arrays.asList; + +import static jdk.test.lib.Utils.TEST_CLASSES; +import static jdk.test.lib.Utils.TEST_CLASS_PATH; + +public class PrefsSpiTest { + + private static final Path SPIJAR = Path.of("extDir", "PrefsSpi.jar"); + private static final String SPIJAR_CP = TEST_CLASS_PATH + + File.pathSeparator + SPIJAR.toString(); + + @BeforeClass + public void initialize() throws Exception { + Path xdir = Path.of("jarDir"); + + Path config = xdir.resolve("META-INF/services/java.util.prefs.PreferencesFactory"); + Files.createDirectories(config.getParent()); + Files.write(config, "StubPreferencesFactory".getBytes(), CREATE); + + String[] files = {"StubPreferencesFactory.class", "StubPreferences.class"}; + for (String f : files) { + Path source = Path.of(TEST_CLASSES, f); + Path target = xdir.resolve(source.getFileName()); + Files.copy(source, target, REPLACE_EXISTING); + } + + JarUtils.createJarFile(SPIJAR, xdir); + } + + @DataProvider + public Object[][] testCases() { + return new Object[][]{ + // CLI options, runtime arguments + {List.of("-cp", SPIJAR_CP, + "-Djava.util.prefs.PreferencesFactory=StubPreferencesFactory"), + "StubPreferences"}, + {List.of("-cp", TEST_CLASS_PATH), "java.util.prefs.*"}, + {List.of("-cp", SPIJAR_CP), "StubPreferences"} + }; + } + + @Test(dataProvider = "testCases") + public void testProvider(List opts, String pattern) throws Throwable { + List args = new ArrayList<>(); + args.add(JDKToolFinder.getJDKTool("java")); + args.addAll(asList(Utils.getTestJavaOpts())); + args.addAll(opts); + args.add("-Djava.util.prefs.userRoot=."); + args.add(PrefsSpi.class.getName()); + args.add(pattern); + + ProcessTools.executeCommand(args.stream() + .filter(t -> !t.isEmpty()) + .toArray(String[]::new)) + .shouldHaveExitValue(0); + } + +} diff --git a/test/jdk/java/util/prefs/StubPreferences.java b/test/jdk/java/util/prefs/StubPreferences.java new file mode 100644 index 00000000000..859ff71fff1 --- /dev/null +++ b/test/jdk/java/util/prefs/StubPreferences.java @@ -0,0 +1,37 @@ +/* + * Copyright (c) 2018, 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.prefs.AbstractPreferences; + +public class StubPreferences extends AbstractPreferences { + public StubPreferences() { super(null, ""); } + public String getSpi(String x) { return null; } + public void putSpi(String x, String y) { } + public void removeSpi(String x) { } + public AbstractPreferences childSpi(String x) { return null; } + public void removeNodeSpi() { } + public String[] keysSpi() { return null; } + public String[] childrenNamesSpi() { return null; } + public void syncSpi() { } + public void flushSpi() { } +} diff --git a/test/jdk/java/util/prefs/StubPreferencesFactory.java b/test/jdk/java/util/prefs/StubPreferencesFactory.java new file mode 100644 index 00000000000..c67c9934129 --- /dev/null +++ b/test/jdk/java/util/prefs/StubPreferencesFactory.java @@ -0,0 +1,30 @@ +/* + * Copyright (c) 2018, 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.prefs.Preferences; +import java.util.prefs.PreferencesFactory; + +public class StubPreferencesFactory implements PreferencesFactory { + public Preferences userRoot() { return new StubPreferences(); } + public Preferences systemRoot() { return new StubPreferences(); } +} From f095a9ee49ba0e36e0503b6db1dce81df66f5356 Mon Sep 17 00:00:00 2001 From: Amy Lu Date: Thu, 25 Oct 2018 11:05:24 +0800 Subject: [PATCH 12/84] 8209768: Refactor java/util/prefs/CheckUserPrefsStorage.sh to plain java test Reviewed-by: bchristi, weijun --- .../java/util/prefs/CheckUserPrefFirst.java | 6 +- .../java/util/prefs/CheckUserPrefLater.java | 5 +- .../util/prefs/CheckUserPrefsStorage.java | 50 ++++++++++++++ .../java/util/prefs/CheckUserPrefsStorage.sh | 68 ------------------- 4 files changed, 54 insertions(+), 75 deletions(-) create mode 100644 test/jdk/java/util/prefs/CheckUserPrefsStorage.java delete mode 100644 test/jdk/java/util/prefs/CheckUserPrefsStorage.sh diff --git a/test/jdk/java/util/prefs/CheckUserPrefFirst.java b/test/jdk/java/util/prefs/CheckUserPrefFirst.java index 768ea81e329..a402fdaeb4d 100644 --- a/test/jdk/java/util/prefs/CheckUserPrefFirst.java +++ b/test/jdk/java/util/prefs/CheckUserPrefFirst.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2018, 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,9 +24,7 @@ import java.util.prefs.Preferences; /** - * - * @author khazra - * First class called by CheckUserPrefsStorage.sh to create and + * First class called by CheckUserPrefsStorage.java to create and * store a user preference */ diff --git a/test/jdk/java/util/prefs/CheckUserPrefLater.java b/test/jdk/java/util/prefs/CheckUserPrefLater.java index 88a0637a68f..8de7afeef61 100644 --- a/test/jdk/java/util/prefs/CheckUserPrefLater.java +++ b/test/jdk/java/util/prefs/CheckUserPrefLater.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2018, 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,9 +24,8 @@ import java.util.prefs.Preferences; /** - * CheckUserPrefsStorage.sh uses this to check that preferences stored + * CheckUserPrefsStorage.java uses this to check that preferences stored * by CheckUserPrefFirst.java can be retrieved - * @author khazra */ public class CheckUserPrefLater { diff --git a/test/jdk/java/util/prefs/CheckUserPrefsStorage.java b/test/jdk/java/util/prefs/CheckUserPrefsStorage.java new file mode 100644 index 00000000000..51ecae932d1 --- /dev/null +++ b/test/jdk/java/util/prefs/CheckUserPrefsStorage.java @@ -0,0 +1,50 @@ +/* + * Copyright (c) 2018, 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 7198073 7197662 + * @summary Tests that user preferences are stored in the permanent storage + * @library /test/lib + * @build jdk.test.lib.process.* CheckUserPrefFirst CheckUserPrefLater + * @run main CheckUserPrefsStorage + */ + +import jdk.test.lib.process.ProcessTools; + +public class CheckUserPrefsStorage { + + public static void main(String[] args) throws Throwable { + // First to create and store a user preference + run("CheckUserPrefFirst"); + // Then check that preferences stored by CheckUserPrefFirst can be retrieved + run("CheckUserPrefLater"); + } + + public static void run(String testName) throws Exception { + ProcessTools.executeTestJvm("-Djava.util.prefs.userRoot=.", testName) + .outputTo(System.out) + .errorTo(System.out) + .shouldHaveExitValue(0); + } +} diff --git a/test/jdk/java/util/prefs/CheckUserPrefsStorage.sh b/test/jdk/java/util/prefs/CheckUserPrefsStorage.sh deleted file mode 100644 index bfb4a2a54c7..00000000000 --- a/test/jdk/java/util/prefs/CheckUserPrefsStorage.sh +++ /dev/null @@ -1,68 +0,0 @@ -# -# Copyright (c) 2012, 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 7198073 7197662 -# @build CheckUserPrefFirst CheckUserPrefLater -# @run shell CheckUserPrefsStorage.sh -# @summary Tests that user preferences are stored in the -# permanent storage -# - -OS=`uname -s` -case "$OS" in - SunOS | Linux | Darwin | AIX ) - PS=":" - FS="/" - ;; - CYGWIN* ) - PS=";" - FS="/" - ;; - Windows* ) - PS=";" - FS="\\" - ;; - * ) - echo "Unrecognized system!" - exit 1; - ;; -esac - -# run CheckUserPrefFirst - creates and stores a user pref -${TESTJAVA}${FS}bin${FS}java ${TESTVMOPTS} -cp ${TESTCLASSES} -Djava.util.prefs.userRoot=. CheckUserPrefFirst -result=$? -if [ "$result" -ne "0" ]; then - exit 1 -fi - -# run CheckUserPrefLater - Looks for the stored pref -${TESTJAVA}${FS}bin${FS}java ${TESTVMOPTS} -cp ${TESTCLASSES} -Djava.util.prefs.userRoot=. CheckUserPrefLater -result=$? -if [ "$result" -ne "0" ]; then - exit 1 -fi - -# no failures, exit. -exit 0 - From 0d815c2677414d0dbae6b3b5965b393ef656253e Mon Sep 17 00:00:00 2001 From: Robert Field Date: Wed, 24 Oct 2018 21:17:30 -0700 Subject: [PATCH 13/84] 8211694: JShell: Redeclared variable should be reset Reviewed-by: sundar --- .../share/classes/jdk/jshell/Eval.java | 49 ++++++++++-------- .../share/classes/jdk/jshell/Snippet.java | 2 +- test/langtools/jdk/jshell/SnippetTest.java | 2 +- test/langtools/jdk/jshell/ToolBasicTest.java | 17 +++++-- test/langtools/jdk/jshell/VariablesTest.java | 50 ++++++++++++++++++- 5 files changed, 92 insertions(+), 28 deletions(-) diff --git a/src/jdk.jshell/share/classes/jdk/jshell/Eval.java b/src/jdk.jshell/share/classes/jdk/jshell/Eval.java index 9f64a9326da..e14eccf00d0 100644 --- a/src/jdk.jshell/share/classes/jdk/jshell/Eval.java +++ b/src/jdk.jshell/share/classes/jdk/jshell/Eval.java @@ -361,6 +361,33 @@ class Eval { winit = winit == null ? Wrap.rangeWrap(compileSource, rinit) : winit; nameMax = rinit.begin - 1; } else { + String sinit; + switch (typeName) { + case "byte": + case "short": + case "int": + sinit = "0"; + break; + case "long": + sinit = "0L"; + break; + case "float": + sinit = "0.0f"; + break; + case "double": + sinit = "0.0d"; + break; + case "boolean": + sinit = "false"; + break; + case "char": + sinit = "'\\u0000'"; + break; + default: + sinit = "null"; + break; + } + winit = Wrap.simpleWrap(sinit); subkind = SubKind.VAR_DECLARATION_SUBKIND; } int nameStart = compileSource.lastIndexOf(name, nameMax); @@ -861,28 +888,6 @@ class Eval { state.debug(ex, "termination"); state.closeDown(); } - } else if (si.subKind() == SubKind.VAR_DECLARATION_SUBKIND) { - switch (((VarSnippet) si).typeName()) { - case "byte": - case "short": - case "int": - case "long": - value = "0"; - break; - case "float": - case "double": - value = "0.0"; - break; - case "boolean": - value = "false"; - break; - case "char": - value = "''"; - break; - default: - value = "null"; - break; - } } } return events(c, outs, value, exception); diff --git a/src/jdk.jshell/share/classes/jdk/jshell/Snippet.java b/src/jdk.jshell/share/classes/jdk/jshell/Snippet.java index ea620f6cac2..55fd5bfe42b 100644 --- a/src/jdk.jshell/share/classes/jdk/jshell/Snippet.java +++ b/src/jdk.jshell/share/classes/jdk/jshell/Snippet.java @@ -250,7 +250,7 @@ public abstract class Snippet { * @jls 8.3. VariableDeclarator without VariableInitializer in * FieldDeclaration. */ - VAR_DECLARATION_SUBKIND(Kind.VAR), + VAR_DECLARATION_SUBKIND(Kind.VAR, true, true), /** * A variable declaration with an initializer expression. A diff --git a/test/langtools/jdk/jshell/SnippetTest.java b/test/langtools/jdk/jshell/SnippetTest.java index 070db2fea2d..3ccd0e42f4b 100644 --- a/test/langtools/jdk/jshell/SnippetTest.java +++ b/test/langtools/jdk/jshell/SnippetTest.java @@ -73,7 +73,7 @@ public class SnippetTest extends KullaTesting { } public void testVarDeclarationKey() { - assertVarKeyMatch("int a;", false, "a", VAR_DECLARATION_SUBKIND, "int", added(VALID)); + assertVarKeyMatch("int a;", true, "a", VAR_DECLARATION_SUBKIND, "int", added(VALID)); } public void testVarDeclarationWithInitializerKey() { diff --git a/test/langtools/jdk/jshell/ToolBasicTest.java b/test/langtools/jdk/jshell/ToolBasicTest.java index 37dce8268ec..75ba06611ba 100644 --- a/test/langtools/jdk/jshell/ToolBasicTest.java +++ b/test/langtools/jdk/jshell/ToolBasicTest.java @@ -23,7 +23,7 @@ /* * @test - * @bug 8143037 8142447 8144095 8140265 8144906 8146138 8147887 8147886 8148316 8148317 8143955 8157953 8080347 8154714 8166649 8167643 8170162 8172102 8165405 8174796 8174797 8175304 8167554 8180508 8166232 8196133 8199912 + * @bug 8143037 8142447 8144095 8140265 8144906 8146138 8147887 8147886 8148316 8148317 8143955 8157953 8080347 8154714 8166649 8167643 8170162 8172102 8165405 8174796 8174797 8175304 8167554 8180508 8166232 8196133 8199912 8211694 * @summary Tests for Basic tests for REPL tool * @modules jdk.compiler/com.sun.tools.javac.api * jdk.compiler/com.sun.tools.javac.main @@ -833,8 +833,8 @@ public class ToolBasicTest extends ReplToolTesting { a -> assertCommandOutputStartsWith(a, "import jdk.internal.misc.VM;", "| Error:") ); test(false, new String[]{"--no-startup", - "-R--add-exports", "-Rjava.base/jdk.internal.misc=ALL-UNNAMED", - "-C--add-exports", "-Cjava.base/jdk.internal.misc=ALL-UNNAMED"}, + "-R--add-exports", "-Rjava.base/jdk.internal.misc=ALL-UNNAMED", + "-C--add-exports", "-Cjava.base/jdk.internal.misc=ALL-UNNAMED"}, a -> assertImport(a, "import jdk.internal.misc.VM;", "", "jdk.internal.misc.VM"), a -> assertCommand(a, "System.err.println(VM.isBooted())", "", "", null, "", "true\n") ); @@ -844,4 +844,15 @@ public class ToolBasicTest extends ReplToolTesting { ); } + public void testRedeclareVariableNoInit() { + test( + a -> assertCommand(a, "Integer a;", "a ==> null"), + a -> assertCommand(a, "a instanceof Integer;", "$2 ==> false"), + a -> assertCommand(a, "a = 1;", "a ==> 1"), + a -> assertCommand(a, "Integer a;", "a ==> null"), + a -> assertCommand(a, "a instanceof Integer;", "$5 ==> false"), + a -> assertCommand(a, "a", "a ==> null") + ); + } + } diff --git a/test/langtools/jdk/jshell/VariablesTest.java b/test/langtools/jdk/jshell/VariablesTest.java index 6fafca7dc67..51d8c79000f 100644 --- a/test/langtools/jdk/jshell/VariablesTest.java +++ b/test/langtools/jdk/jshell/VariablesTest.java @@ -23,7 +23,7 @@ /* * @test - * @bug 8144903 8177466 8191842 + * @bug 8144903 8177466 8191842 8211694 * @summary Tests for EvaluationState.variables * @library /tools/lib * @modules jdk.compiler/com.sun.tools.javac.api @@ -466,6 +466,54 @@ public class VariablesTest extends KullaTesting { assertVarDisplayName("var v6 = new Runnable() { public void run() { } };", ""); } + public void varDeclNoInit() { + assertVarDeclNoInit("byte", "b", "0"); + assertVarDeclNoInit("short", "h", "0"); + assertVarDeclNoInit("int", "i", "0"); + assertVarDeclNoInit("long", "l", "0"); + assertVarDeclNoInit("float", "f", "0.0"); + assertVarDeclNoInit("double", "d", "0.0"); + assertVarDeclNoInit("boolean", "n", "false"); + assertVarDeclNoInit("char", "c", "'\\000'"); + assertVarDeclNoInit("Object", "o", "null"); + assertVarDeclNoInit("String", "s", "null"); + } + + public void varDeclRedefNoInit() { + assertVarDeclRedefNoInit("byte", "b", "1", "0"); + assertVarDeclRedefNoInit("short", "h", "2", "0"); + assertVarDeclRedefNoInit("int", "i", "3", "0"); + assertVarDeclRedefNoInit("long", "l", "4L", IGNORE_VALUE, "0"); + assertVarDeclRedefNoInit("float", "f", "3.14f", IGNORE_VALUE, "0.0"); + assertVarDeclRedefNoInit("double", "d", "3.1415926", "0.0"); + assertVarDeclRedefNoInit("boolean", "n", "true", "false"); + assertVarDeclRedefNoInit("char", "c", "'x'", "'\\000'"); + assertVarDeclRedefNoInit("Object", "o", "new Object()", IGNORE_VALUE, "null"); + assertVarDeclRedefNoInit("String", "s", "\"hi\"", "null"); + } + + private void assertVarDeclRedefNoInit(String typeName, String name, String value, String dvalue) { + assertVarDeclRedefNoInit(typeName, name, value, value, dvalue); + } + + private void assertVarDeclRedefNoInit(String typeName, String name, String value, String rvalue, String dvalue) { + VarSnippet vs = varKey(assertEval(typeName + " " + name + " = " + value + ";", rvalue)); + assertVarDeclNoInit(typeName, name, dvalue, + ste(vs, VALID, VALID, false, null), + ste(vs, VALID, OVERWRITTEN, false, MAIN_SNIPPET)); + } + + private VarSnippet assertVarDeclNoInit(String typeName, String name, String dvalue) { + return assertVarDeclNoInit(typeName, name, dvalue, added(VALID)); + } + + private VarSnippet assertVarDeclNoInit(String typeName, String name, String dvalue, STEInfo mainInfo, STEInfo... updates) { + VarSnippet vs = varKey(assertEval(typeName + " " + name + ";", dvalue, mainInfo, updates)); + assertEquals(vs.typeName(), typeName); + assertEval(name, dvalue, added(VALID)); + return vs; + } + private void assertVarDisplayName(String var, String typeName) { assertEquals(varKey(assertEval(var)).typeName(), typeName); } From ae21c81dd7ddc9eefeebb35c18d45f991b607bf3 Mon Sep 17 00:00:00 2001 From: Michael McMahon Date: Thu, 25 Oct 2018 12:09:41 +0100 Subject: [PATCH 14/84] 8212926: HttpClient does not retrieve files with large sizes over HTTP/1.1 Reviewed-by: chegar, dfuchs --- .../jdk/internal/net/http/Http1Response.java | 17 +- .../internal/net/http/ResponseContent.java | 14 +- .../net/httpclient/LargeResponseContent.java | 177 ++++++++++++++++++ 3 files changed, 192 insertions(+), 16 deletions(-) create mode 100644 test/jdk/java/net/httpclient/LargeResponseContent.java diff --git a/src/java.net.http/share/classes/jdk/internal/net/http/Http1Response.java b/src/java.net.http/share/classes/jdk/internal/net/http/Http1Response.java index 16bfe54c603..4647d134933 100644 --- a/src/java.net.http/share/classes/jdk/internal/net/http/Http1Response.java +++ b/src/java.net.http/share/classes/jdk/internal/net/http/Http1Response.java @@ -236,20 +236,20 @@ class Http1Response { * Return known fixed content length or -1 if chunked, or -2 if no content-length * information in which case, connection termination delimits the response body */ - int fixupContentLen(int clen) { + long fixupContentLen(long clen) { if (request.method().equalsIgnoreCase("HEAD") || responseCode == HTTP_NOT_MODIFIED) { - return 0; + return 0L; } - if (clen == -1) { + if (clen == -1L) { if (headers.firstValue("Transfer-encoding").orElse("") .equalsIgnoreCase("chunked")) { - return -1; + return -1L; } if (responseCode == 101) { // this is a h2c or websocket upgrade, contentlength must be zero - return 0; + return 0L; } - return -2; + return -2L; } return clen; } @@ -383,9 +383,8 @@ class Http1Response { final CompletableFuture cf = new MinimalFuture<>(); - int clen0 = (int)headers.firstValueAsLong("Content-Length").orElse(-1); - - final int clen = fixupContentLen(clen0); + long clen0 = headers.firstValueAsLong("Content-Length").orElse(-1L); + final long clen = fixupContentLen(clen0); // expect-continue reads headers and body twice. // if we reach here, we must reset the headersReader state. diff --git a/src/java.net.http/share/classes/jdk/internal/net/http/ResponseContent.java b/src/java.net.http/share/classes/jdk/internal/net/http/ResponseContent.java index c1555e1836d..b8dab248d54 100644 --- a/src/java.net.http/share/classes/jdk/internal/net/http/ResponseContent.java +++ b/src/java.net.http/share/classes/jdk/internal/net/http/ResponseContent.java @@ -46,7 +46,7 @@ import static java.lang.String.format; class ResponseContent { final HttpResponse.BodySubscriber pusher; - final int contentLength; + final long contentLength; final HttpHeaders headers; // this needs to run before we complete the body // so that connection can be returned to pool @@ -54,7 +54,7 @@ class ResponseContent { private final String dbgTag; ResponseContent(HttpConnection connection, - int contentLength, + long contentLength, HttpHeaders h, HttpResponse.BodySubscriber userSubscriber, Runnable onFinished) @@ -474,14 +474,14 @@ class ResponseContent { } class FixedLengthBodyParser implements BodyParser { - final int contentLength; + final long contentLength; final Consumer onComplete; final Logger debug = Utils.getDebugLogger(this::dbgString, Utils.DEBUG); final String dbgTag = ResponseContent.this.dbgTag + "/FixedLengthBodyParser"; - volatile int remaining; + volatile long remaining; volatile Throwable closedExceptionally; volatile AbstractSubscription sub; - FixedLengthBodyParser(int contentLength, Consumer onComplete) { + FixedLengthBodyParser(long contentLength, Consumer onComplete) { this.contentLength = this.remaining = contentLength; this.onComplete = onComplete; } @@ -527,7 +527,7 @@ class ResponseContent { } boolean completed = false; try { - int unfulfilled = remaining; + long unfulfilled = remaining; if (debug.on()) debug.log("Parser got %d bytes (%d remaining / %d)", b.remaining(), unfulfilled, contentLength); @@ -541,7 +541,7 @@ class ResponseContent { // demand. boolean hasDemand = sub.demand().tryDecrement(); assert hasDemand; - int amount = Math.min(b.remaining(), unfulfilled); + int amount = (int)Math.min(b.remaining(), unfulfilled); // safe cast unfulfilled = remaining -= amount; ByteBuffer buffer = Utils.sliceWithLimitedCapacity(b, amount); pusher.onNext(List.of(buffer.asReadOnlyBuffer())); diff --git a/test/jdk/java/net/httpclient/LargeResponseContent.java b/test/jdk/java/net/httpclient/LargeResponseContent.java new file mode 100644 index 00000000000..6a7b0874c52 --- /dev/null +++ b/test/jdk/java/net/httpclient/LargeResponseContent.java @@ -0,0 +1,177 @@ +/* + * Copyright (c) 2018, 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.io.InputStream; +import java.io.OutputStream; +import java.net.InetAddress; +import java.net.InetSocketAddress; +import java.net.ServerSocket; +import java.net.Socket; +import java.net.URI; +import java.net.http.HttpClient; +import java.net.http.HttpHeaders; +import java.net.http.HttpRequest; +import java.net.http.HttpResponse; +import java.nio.ByteBuffer; +import java.nio.charset.StandardCharsets; +import java.util.List; +import java.util.concurrent.CompletableFuture; +import java.util.concurrent.CompletionStage; +import java.util.concurrent.Flow; + +/** + * @test + * @bug 8212926 + * @summary Basic tests for response timeouts + * @run main/othervm LargeResponseContent + */ + +public class LargeResponseContent { + final ServerSocket server; + final int port; + + public LargeResponseContent() throws Exception { + server = new ServerSocket(0, 10, InetAddress.getLoopbackAddress()); + Thread serverThread = new Thread(this::handleConnection); + serverThread.setDaemon(false); + port = server.getLocalPort(); + serverThread.start(); + } + + void runClient() throws IOException, InterruptedException { + URI uri = URI.create("http://127.0.0.1:" + Integer.toString(port) + "/foo"); + HttpClient client = HttpClient.newHttpClient(); + HttpRequest request = HttpRequest.newBuilder(uri) + .GET() + .build(); + HttpResponse response = client.send(request, new ClientHandler()); + System.out.println("Response code = " + response.statusCode()); + long blen = response.body(); + if (blen != CONTENT_LEN) + throw new RuntimeException("wrong content length"); + } + + public static void main(String[] args) throws Exception { + System.out.println ("CONTENT_LEN = " + CONTENT_LEN); + System.out.println ("CLEN_STR = " + CLEN_STR); + LargeResponseContent test = new LargeResponseContent(); + test.runClient(); + } + + static class ClientHandler implements HttpResponse.BodyHandler { + + @Override + public HttpResponse.BodySubscriber apply(HttpResponse.ResponseInfo responseInfo) { + HttpHeaders headers = responseInfo.headers(); + headers.firstValue("content-length"); + long clen = headers.firstValueAsLong("content-length").orElse(-1); + if (clen != CONTENT_LEN) + return new Subscriber(new RuntimeException("Wrong content length received")); + return new Subscriber(null); + } + } + + static class Subscriber implements HttpResponse.BodySubscriber { + final CompletableFuture cf = new CompletableFuture<>(); + volatile Flow.Subscription subscription; + volatile long counter = 0; + + Subscriber(Throwable t) { + if (t != null) + cf.completeExceptionally(t); + } + + @Override + public CompletionStage getBody() { + return cf; + } + + @Override + public void onSubscribe(Flow.Subscription subscription) { + this.subscription = subscription; + subscription.request(Long.MAX_VALUE); + } + + @Override + public void onNext(List item) { + long v = 0; + for (ByteBuffer b : item) + v+= b.remaining(); + counter += v; + } + + @Override + public void onError(Throwable throwable) { + throwable.printStackTrace(); + } + + @Override + public void onComplete() { + cf.complete(counter); + } + } + + static final long CONTENT_LEN = Integer.MAX_VALUE + 1000L; + static final String CLEN_STR = Long.valueOf(CONTENT_LEN).toString(); + + static String RESPONSE = "HTTP/1.1 200 OK\r\n" + + "Content-length: " + CLEN_STR + "\r\n" + + "\r\n"; + + + void readHeaders(InputStream is) throws IOException { + String s = ""; + byte[] buf = new byte[128]; + while (!s.endsWith("\r\n\r\n")) { + int c = is.read(buf); + String f = new String(buf, 0, c, StandardCharsets.ISO_8859_1); + s = s + f; + } + } + + public void handleConnection() { + long remaining = CONTENT_LEN; + try { + Socket socket = server.accept(); + InputStream is = socket.getInputStream(); + readHeaders(is); // read first byte + OutputStream os = socket.getOutputStream(); + os.write(RESPONSE.getBytes()); + byte[] buf = new byte[64 * 1024]; + while (remaining > 0) { + int amount = (int)Math.min(remaining, buf.length); + os.write(buf, 0, amount); + remaining -= amount; + } + System.out.println("Server: finished writing"); + os.close(); + + } catch (IOException e) { + long sent = CONTENT_LEN - remaining; + System.out.println("Sent " + sent); + e.printStackTrace(); + } + } +} + From be312edc2a08fabc3026e4ecd0179bebc5bc9a60 Mon Sep 17 00:00:00 2001 From: Jean Christophe Beyler Date: Thu, 25 Oct 2018 08:18:42 -0700 Subject: [PATCH 15/84] 8212770: Remove spaces before/after () for vmTestbase/jvmti/[s-u] Remove spaces before/after () Reviewed-by: amenkov, cjplummer --- .../allocation/AP04/ap04t002/ap04t002.cpp | 100 +++++++++--------- .../allocation/AP04/ap04t003/ap04t003.cpp | 84 +++++++-------- .../allocation/AP05/ap05t001/ap05t001.cpp | 52 ++++----- .../allocation/AP05/ap05t002/ap05t002.cpp | 44 ++++---- .../allocation/AP06/ap06t001/ap06t001.cpp | 42 ++++---- .../allocation/AP07/ap07t001/ap07t001.cpp | 52 ++++----- .../allocation/AP07/ap07t002/ap07t002.cpp | 50 ++++----- .../allocation/AP09/ap09t001/ap09t001.cpp | 52 ++++----- .../allocation/AP12/ap12t001/ap12t001.cpp | 2 +- .../bcinstr/BI01/bi01t001/bi01t001.cpp | 2 +- .../bcinstr/BI01/bi01t002/bi01t002.cpp | 2 +- .../events/EM01/em01t002/em01t002.cpp | 2 +- .../events/EM06/em06t001/em06t001.cpp | 2 +- .../extension/EX03/ex03t001/ex03t001.cpp | 2 +- .../hotswap/HS103/hs103t002/hs103t002.cpp | 8 +- .../hotswap/HS104/hs104t001/hs104t001.cpp | 12 +-- .../hotswap/HS104/hs104t002/hs104t002.cpp | 10 +- .../hotswap/HS202/hs202t001/hs202t001.cpp | 16 +-- .../hotswap/HS202/hs202t002/hs202t002.cpp | 10 +- .../hotswap/HS203/hs203t001/hs203t001.cpp | 16 +-- .../hotswap/HS203/hs203t002/hs203t002.cpp | 18 ++-- .../hotswap/HS203/hs203t003/hs203t003.cpp | 46 ++++---- .../hotswap/HS203/hs203t004/hs203t004.cpp | 40 +++---- .../hotswap/HS204/hs204t001/hs204t001.cpp | 22 ++-- .../hotswap/HS204/hs204t002/hs204t002.cpp | 14 +-- .../hotswap/HS204/hs204t003/hs204t003.cpp | 51 +++++---- .../hotswap/HS204/hs204t004/hs204t004.cpp | 18 ++-- .../hotswap/HS301/hs301t001/hs301t001.cpp | 10 +- .../hotswap/HS301/hs301t002/hs301t002.cpp | 8 +- .../hotswap/HS301/hs301t003/hs301t003.cpp | 14 +-- .../hotswap/HS301/hs301t004/hs301t004.cpp | 16 +-- .../hotswap/HS301/hs301t005/hs301t005.cpp | 8 +- .../hotswap/HS302/hs302t001/hs302t001.cpp | 12 +-- .../hotswap/HS302/hs302t002/hs302t002.cpp | 12 +-- .../hotswap/HS302/hs302t003/hs302t003.cpp | 12 +-- .../hotswap/HS302/hs302t004/hs302t004.cpp | 10 +- .../hotswap/HS302/hs302t005/hs302t005.cpp | 10 +- .../hotswap/HS302/hs302t006/hs302t006.cpp | 10 +- .../hotswap/HS302/hs302t007/hs302t007.cpp | 10 +- .../hotswap/HS302/hs302t008/hs302t008.cpp | 10 +- .../hotswap/HS302/hs302t009/hs302t009.cpp | 10 +- .../hotswap/HS302/hs302t010/hs302t010.cpp | 10 +- .../hotswap/HS302/hs302t011/hs302t011.cpp | 10 +- .../hotswap/HS302/hs302t012/hs302t012.cpp | 10 +- .../sampling/SP02/sp02t003/sp02t003.cpp | 2 +- .../followref001/followref001.cpp | 8 +- .../followref002/followref002.cpp | 10 +- .../followref003/followref003.cpp | 12 +-- .../followref004/followref004.cpp | 16 +-- .../followref005/followref005.cpp | 10 +- .../followref006/followref006.cpp | 18 ++-- 51 files changed, 512 insertions(+), 515 deletions(-) diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP04/ap04t002/ap04t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP04/ap04t002/ap04t002.cpp index bb146389062..f42bb0d8680 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP04/ap04t002/ap04t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP04/ap04t002/ap04t002.cpp @@ -102,10 +102,10 @@ static int getCounter(volatile int* counterPtr) { /***********************************************************************/ jvmtiIterationControl JNICALL -heapObjectCallback( jlong class_tag, - jlong size, - jlong* tag_ptr, - void* user_data) { +heapObjectCallback(jlong class_tag, + jlong size, + jlong* tag_ptr, + void* user_data) { int count = 0; @@ -126,11 +126,11 @@ heapObjectCallback( jlong class_tag, /* jvmtiHeapRootCallback */ jvmtiIterationControl JNICALL -heapRootCallback( jvmtiHeapRootKind root_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - void* user_data) { +heapRootCallback(jvmtiHeapRootKind root_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + void* user_data) { int count = 0; @@ -151,15 +151,15 @@ heapRootCallback( jvmtiHeapRootKind root_kind, /* jvmtiStackReferenceCallback */ jvmtiIterationControl JNICALL -stackReferenceCallback( jvmtiHeapRootKind root_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong thread_tag, - jint depth, - jmethodID method, - jint slot, - void* user_data) { +stackReferenceCallback(jvmtiHeapRootKind root_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong thread_tag, + jint depth, + jmethodID method, + jint slot, + void* user_data) { int count = 0; @@ -181,13 +181,13 @@ stackReferenceCallback( jvmtiHeapRootKind root_kind, /* jvmtiObjectReferenceCallback */ jvmtiIterationControl JNICALL -objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong referrer_tag, - jint referrer_index, - void* user_data) { +objectReferenceCallback(jvmtiObjectReferenceKind reference_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong referrer_tag, + jint referrer_index, + void* user_data) { int count = 0; @@ -210,16 +210,16 @@ objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, /***********************************************************************/ void JNICALL -FieldModification( jvmtiEnv *jvmti_env, - JNIEnv *env, - jthread thr, - jmethodID method, - jlocation location, - jclass field_klass, - jobject obj, - jfieldID field, - char sig, - jvalue new_value ) { +FieldModification(jvmtiEnv *jvmti_env, + JNIEnv *env, + jthread thr, + jmethodID method, + jlocation location, + jclass field_klass, + jobject obj, + jfieldID field, + char sig, + jvalue new_value) { increaseCounter(&modificationCount); } @@ -227,10 +227,10 @@ FieldModification( jvmtiEnv *jvmti_env, /***********************************************************************/ JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP04_ap04t002_setTag( JNIEnv* jni, - jclass klass, - jobject target, /* object to be tagged */ - jlong tag ) { +Java_nsk_jvmti_scenarios_allocation_AP04_ap04t002_setTag(JNIEnv* jni, + jclass klass, + jobject target, /* object to be tagged */ + jlong tag) { if (!NSK_JVMTI_VERIFY(jvmti->SetTag(target, tag))) { nsk_jvmti_setFailStatus(); @@ -238,8 +238,8 @@ Java_nsk_jvmti_scenarios_allocation_AP04_ap04t002_setTag( JNIEnv* jni, } JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP04_ap04t002_runIterateOverHeap( JNIEnv* jni, - jclass klass ) { +Java_nsk_jvmti_scenarios_allocation_AP04_ap04t002_runIterateOverHeap(JNIEnv* jni, + jclass klass) { int count = 0; setCounter(&errorCount, 0); @@ -267,8 +267,8 @@ Java_nsk_jvmti_scenarios_allocation_AP04_ap04t002_runIterateOverHeap( JNIEnv* jn } JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP04_ap04t002_runIterateOverReachableObjects( JNIEnv* jni, - jclass klass ) { +Java_nsk_jvmti_scenarios_allocation_AP04_ap04t002_runIterateOverReachableObjects(JNIEnv* jni, + jclass klass) { int count = 0; setCounter(&errorCount, 0); @@ -297,8 +297,8 @@ Java_nsk_jvmti_scenarios_allocation_AP04_ap04t002_runIterateOverReachableObjects } JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP04_ap04t002_runIterateOverInstancesOfClass( JNIEnv* jni, - jclass klass ) { +Java_nsk_jvmti_scenarios_allocation_AP04_ap04t002_runIterateOverInstancesOfClass(JNIEnv* jni, + jclass klass) { int count = 0; setCounter(&errorCount, 0); @@ -327,13 +327,13 @@ Java_nsk_jvmti_scenarios_allocation_AP04_ap04t002_runIterateOverInstancesOfClass } JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP04_ap04t002_runIterateOverObjectsReachableFromObject( JNIEnv* jni, - jclass klass ) { +Java_nsk_jvmti_scenarios_allocation_AP04_ap04t002_runIterateOverObjectsReachableFromObject(JNIEnv* jni, + jclass klass) { jobject root = NULL; int count = 0; if (!NSK_JNI_VERIFY(jni, (root = - jni->GetStaticObjectField(debugeeClass, rootFieldID)) != NULL )) { + jni->GetStaticObjectField(debugeeClass, rootFieldID)) != NULL)) { NSK_COMPLAIN0("GetStaticObjectField returned NULL for 'root' field value\n\n"); nsk_jvmti_setFailStatus(); return; @@ -382,14 +382,14 @@ agentProc(jvmtiEnv* jvmti, JNIEnv* jni, void* arg) { NSK_DISPLAY1("Find ID of 'root' field: %s\n", ROOT_SIGNATURE); if (!NSK_JNI_VERIFY(jni, (rootFieldID = - jni->GetStaticFieldID(debugeeClass, "root", ROOT_SIGNATURE)) != NULL )) { + jni->GetStaticFieldID(debugeeClass, "root", ROOT_SIGNATURE)) != NULL)) { nsk_jvmti_setFailStatus(); return; } NSK_DISPLAY0("Find ID of 'modified' field\n"); if (!NSK_JNI_VERIFY(jni, (modifiedFieldID = - jni->GetStaticFieldID(debugeeClass, "modified", "I")) != NULL )) { + jni->GetStaticFieldID(debugeeClass, "modified", "I")) != NULL)) { nsk_jvmti_setFailStatus(); return; } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP04/ap04t003/ap04t003.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP04/ap04t003/ap04t003.cpp index b9d43e569d6..1444d017de8 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP04/ap04t003/ap04t003.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP04/ap04t003/ap04t003.cpp @@ -120,10 +120,10 @@ void notifyThread() { } jvmtiIterationControl JNICALL -heapObjectCallback( jlong class_tag, - jlong size, - jlong* tag_ptr, - void* user_data) { +heapObjectCallback(jlong class_tag, + jlong size, + jlong* tag_ptr, + void* user_data) { if (getCounter(&iterationCount) == 0) { notifyThread(); @@ -139,11 +139,11 @@ heapObjectCallback( jlong class_tag, /* jvmtiHeapRootCallback */ jvmtiIterationControl JNICALL -heapRootCallback( jvmtiHeapRootKind root_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - void* user_data) { +heapRootCallback(jvmtiHeapRootKind root_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + void* user_data) { if (getCounter(&iterationCount) == 0) { notifyThread(); @@ -159,15 +159,15 @@ heapRootCallback( jvmtiHeapRootKind root_kind, /* jvmtiStackReferenceCallback */ jvmtiIterationControl JNICALL -stackReferenceCallback( jvmtiHeapRootKind root_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong thread_tag, - jint depth, - jmethodID method, - jint slot, - void* user_data) { +stackReferenceCallback(jvmtiHeapRootKind root_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong thread_tag, + jint depth, + jmethodID method, + jint slot, + void* user_data) { if (getCounter(&iterationCount) == 0) { notifyThread(); @@ -184,13 +184,13 @@ stackReferenceCallback( jvmtiHeapRootKind root_kind, /* jvmtiObjectReferenceCallback */ jvmtiIterationControl JNICALL -objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong referrer_tag, - jint referrer_index, - void* user_data) { +objectReferenceCallback(jvmtiObjectReferenceKind reference_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong referrer_tag, + jint referrer_index, + void* user_data) { if (getCounter(&iterationCount) == 0) { notifyThread(); @@ -339,17 +339,17 @@ static jthread newThreadObj(JNIEnv* jni) { jmethodID cid; jthread result = NULL; - if (!NSK_JNI_VERIFY(jni, (thrClass = jni->FindClass("java/lang/Thread")) != NULL )) { + if (!NSK_JNI_VERIFY(jni, (thrClass = jni->FindClass("java/lang/Thread")) != NULL)) { nsk_jvmti_setFailStatus(); return result; } - if (!NSK_JNI_VERIFY(jni, (cid = jni->GetMethodID(thrClass, "", "()V")) != NULL )) { + if (!NSK_JNI_VERIFY(jni, (cid = jni->GetMethodID(thrClass, "", "()V")) != NULL)) { nsk_jvmti_setFailStatus(); return result; } - if (!NSK_JNI_VERIFY(jni, (result = jni->NewObject(thrClass, cid)) != NULL )) { + if (!NSK_JNI_VERIFY(jni, (result = jni->NewObject(thrClass, cid)) != NULL)) { nsk_jvmti_setFailStatus(); return result; } @@ -402,10 +402,10 @@ static void afterIteration (JNIEnv* jni) { /***********************************************************************/ JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_setTag( JNIEnv* jni, - jclass klass, - jobject target, /* object to be tagged */ - jlong tag ) { +Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_setTag(JNIEnv* jni, + jclass klass, + jobject target, /* object to be tagged */ + jlong tag) { if (!NSK_JVMTI_VERIFY(jvmti->SetTag(target, tag))) { nsk_jvmti_setFailStatus(); @@ -413,8 +413,8 @@ Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_setTag( JNIEnv* jni, } JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_runIterateOverHeap( JNIEnv* jni, - jclass klass ) { +Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_runIterateOverHeap(JNIEnv* jni, + jclass klass) { int modified = 0; int found = 0; @@ -443,8 +443,8 @@ Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_runIterateOverHeap( JNIEnv* jn } JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_runIterateOverReachableObjects( JNIEnv* jni, - jclass klass ) { +Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_runIterateOverReachableObjects(JNIEnv* jni, + jclass klass) { int modified = 0; int found = 0; @@ -474,8 +474,8 @@ Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_runIterateOverReachableObjects } JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_runIterateOverInstancesOfClass( JNIEnv* jni, - jclass klass ) { +Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_runIterateOverInstancesOfClass(JNIEnv* jni, + jclass klass) { int modified = 0; int found = 0; @@ -505,14 +505,14 @@ Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_runIterateOverInstancesOfClass } JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_runIterateOverObjectsReachableFromObject( JNIEnv* jni, - jclass klass ) { +Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_runIterateOverObjectsReachableFromObject(JNIEnv* jni, + jclass klass) { jobject root = NULL; int modified = 0; int found = 0; if (!NSK_JNI_VERIFY(jni, (root = - jni->GetStaticObjectField(debugeeClass, rootFieldID)) != NULL )) { + jni->GetStaticObjectField(debugeeClass, rootFieldID)) != NULL)) { NSK_COMPLAIN0("GetStaticObjectField returned NULL for 'root' field value\n\n"); nsk_jvmti_setFailStatus(); return; @@ -561,7 +561,7 @@ agentProc(jvmtiEnv* jvmti, JNIEnv* jni, void* arg) { NSK_DISPLAY1("Find ID of 'root' field: %s\n", ROOT_SIGNATURE); if (!NSK_JNI_VERIFY(jni, (rootFieldID = - jni->GetStaticFieldID(debugeeClass, "root", ROOT_SIGNATURE)) != NULL )) { + jni->GetStaticFieldID(debugeeClass, "root", ROOT_SIGNATURE)) != NULL)) { nsk_jvmti_setFailStatus(); return; } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP05/ap05t001/ap05t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP05/ap05t001/ap05t001.cpp index 7c87491cb10..b2b5f5cbb1b 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP05/ap05t001/ap05t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP05/ap05t001/ap05t001.cpp @@ -51,38 +51,38 @@ static int staticFieldsCount = 0, instanceFieldsCount = 0; /* jvmtiHeapRootCallback */ jvmtiIterationControl JNICALL -heapRootCallback( jvmtiHeapRootKind root_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - void* user_data) { +heapRootCallback(jvmtiHeapRootKind root_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + void* user_data) { return JVMTI_ITERATION_CONTINUE; } /* jvmtiStackReferenceCallback */ jvmtiIterationControl JNICALL -stackReferenceCallback( jvmtiHeapRootKind root_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong thread_tag, - jint depth, - jmethodID method, - jint slot, - void* user_data) { +stackReferenceCallback(jvmtiHeapRootKind root_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong thread_tag, + jint depth, + jmethodID method, + jint slot, + void* user_data) { return JVMTI_ITERATION_CONTINUE; } /* jvmtiObjectReferenceCallback */ jvmtiIterationControl JNICALL -objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong referrer_tag, - jint referrer_index, - void* user_data) { +objectReferenceCallback(jvmtiObjectReferenceKind reference_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong referrer_tag, + jint referrer_index, + void* user_data) { if (*tag_ptr == REFERREE_TAG && (referrer_tag == CLS_TAG || referrer_tag == REFERRER_TAG)) { NSK_DISPLAY4("objectReferenceCallback: reference kind=%s, referrer_index=%d, referrer_tag=%d, referree_tag=%d\n", @@ -100,10 +100,10 @@ objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, /************************/ JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP05_ap05t001_setTag( JNIEnv* jni, - jobject obj, - jobject target, - jlong tag ) { +Java_nsk_jvmti_scenarios_allocation_AP05_ap05t001_setTag(JNIEnv* jni, + jobject obj, + jobject target, + jlong tag) { if (!NSK_JVMTI_VERIFY(jvmti->SetTag(target, tag))) { nsk_jvmti_setFailStatus(); @@ -111,7 +111,7 @@ Java_nsk_jvmti_scenarios_allocation_AP05_ap05t001_setTag( JNIEnv* jni, } JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP05_ap05t001_setReferrer( JNIEnv* jni, jclass klass, jobject ref) { +Java_nsk_jvmti_scenarios_allocation_AP05_ap05t001_setReferrer(JNIEnv* jni, jclass klass, jobject ref) { if (!NSK_JNI_VERIFY(jni, (referrer = jni->NewGlobalRef(ref)) != NULL)) nsk_jvmti_setFailStatus(); } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP05/ap05t002/ap05t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP05/ap05t002/ap05t002.cpp index 4b18a8e4c86..2d625ee9e96 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP05/ap05t002/ap05t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP05/ap05t002/ap05t002.cpp @@ -48,7 +48,7 @@ static int caseNumber = 0, forthRef = 0, backRef = 0; /* jvmtiHeapRootCallback */ jvmtiIterationControl JNICALL -heapRootCallback( jvmtiHeapRootKind root_kind, +heapRootCallback(jvmtiHeapRootKind root_kind, jlong class_tag, jlong size, jlong* tag_ptr, @@ -58,28 +58,28 @@ heapRootCallback( jvmtiHeapRootKind root_kind, /* jvmtiStackReferenceCallback */ jvmtiIterationControl JNICALL -stackReferenceCallback( jvmtiHeapRootKind root_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong thread_tag, - jint depth, - jmethodID method, - jint slot, - void* user_data) { +stackReferenceCallback(jvmtiHeapRootKind root_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong thread_tag, + jint depth, + jmethodID method, + jint slot, + void* user_data) { return JVMTI_ITERATION_CONTINUE; } /* jvmtiObjectReferenceCallback */ jvmtiIterationControl JNICALL -objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong referrer_tag, - jint referrer_index, - void* user_data) { +objectReferenceCallback(jvmtiObjectReferenceKind reference_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong referrer_tag, + jint referrer_index, + void* user_data) { if (*tag_ptr != 0 && referrer_tag != 0) { NSK_DISPLAY4("objectReferenceCallback: reference kind=%s, referrer_index=%d, referrer_tag=%d, referree_tag=%d\n", @@ -98,10 +98,10 @@ objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, /************************/ JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP05_ap05t002_setTag( JNIEnv* jni, - jobject obj, - jobject target, - jlong tag ) { +Java_nsk_jvmti_scenarios_allocation_AP05_ap05t002_setTag(JNIEnv* jni, + jobject obj, + jobject target, + jlong tag) { if (!NSK_JVMTI_VERIFY(jvmti->SetTag(target, tag))) { nsk_jvmti_setFailStatus(); @@ -109,7 +109,7 @@ Java_nsk_jvmti_scenarios_allocation_AP05_ap05t002_setTag( JNIEnv* jni, } JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP05_ap05t002_setReferrer( JNIEnv* jni, jclass klass, jobject ref, jint caseNum) { +Java_nsk_jvmti_scenarios_allocation_AP05_ap05t002_setReferrer(JNIEnv* jni, jclass klass, jobject ref, jint caseNum) { caseNumber = caseNum; if (!NSK_JNI_VERIFY(jni, (referrer = jni->NewGlobalRef(ref)) != NULL)) nsk_jvmti_setFailStatus(); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP06/ap06t001/ap06t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP06/ap06t001/ap06t001.cpp index 4511679bb57..b624c673683 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP06/ap06t001/ap06t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP06/ap06t001/ap06t001.cpp @@ -50,7 +50,7 @@ static const char* THREAD_CLS_SIGNATURE = "Lnsk/jvmti/scenarios/allocation/AP06/ /* jvmtiHeapRootCallback */ jvmtiIterationControl JNICALL -heapRootCallback( jvmtiHeapRootKind root_kind, +heapRootCallback(jvmtiHeapRootKind root_kind, jlong class_tag, jlong size, jlong* tag_ptr, @@ -75,15 +75,15 @@ heapRootCallback( jvmtiHeapRootKind root_kind, /* jvmtiStackReferenceCallback */ jvmtiIterationControl JNICALL -stackReferenceCallback( jvmtiHeapRootKind root_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong thread_tag, - jint depth, - jmethodID method, - jint slot, - void* user_data) { +stackReferenceCallback(jvmtiHeapRootKind root_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong thread_tag, + jint depth, + jmethodID method, + jint slot, + void* user_data) { if (*tag_ptr == threadTag) { NSK_DISPLAY4("stackReferenceCallback: root kind=%s, " @@ -107,13 +107,13 @@ stackReferenceCallback( jvmtiHeapRootKind root_kind, /* jvmtiObjectReferenceCallback */ jvmtiIterationControl JNICALL -objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong referrer_tag, - jint referrer_index, - void* user_data) { +objectReferenceCallback(jvmtiObjectReferenceKind reference_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong referrer_tag, + jint referrer_index, + void* user_data) { return JVMTI_ITERATION_ABORT; } @@ -122,7 +122,7 @@ objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, /************************/ JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP06_ap06t001Thread_setTag( JNIEnv* jni, jobject obj) { +Java_nsk_jvmti_scenarios_allocation_AP06_ap06t001Thread_setTag(JNIEnv* jni, jobject obj) { if (!NSK_JVMTI_VERIFY(jvmti->SetTag(obj, threadTag))) { nsk_jvmti_setFailStatus(); @@ -180,19 +180,19 @@ agentProc(jvmtiEnv* jvmti, JNIEnv* jni, void* arg) { if (rootJNILocalCount != 1) { nsk_jvmti_setFailStatus(); NSK_COMPLAIN1("JVMTI_HEAP_ROOT_JNI_LOCAL root kind was returned wrong %d times " - "while iteration with IterateOverReachableObjects.\n\n", rootJNILocalCount ); + "while iteration with IterateOverReachableObjects.\n\n", rootJNILocalCount); } if (rootJNIGlobalCount != 1) { nsk_jvmti_setFailStatus(); NSK_COMPLAIN1("JVMTI_HEAP_ROOT_JNI_GLOBAL root kind was returned wrong %d times " - "while iteration with IterateOverReachableObjects.\n\n", rootJNIGlobalCount ); + "while iteration with IterateOverReachableObjects.\n\n", rootJNIGlobalCount); } if (rootThreadCount != 1) { nsk_jvmti_setFailStatus(); NSK_COMPLAIN1("JVMTI_HEAP_ROOT_THREAD root kind was returned wrong %d times " - "while iteration with IterateOverReachableObjects.\n\n", rootThreadCount ); + "while iteration with IterateOverReachableObjects.\n\n", rootThreadCount); } } while (0); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP07/ap07t001/ap07t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP07/ap07t001/ap07t001.cpp index f7a99a4f5d1..52988ac2469 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP07/ap07t001/ap07t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP07/ap07t001/ap07t001.cpp @@ -47,11 +47,11 @@ static const jlong IGNORE_TAG = (jlong)10l; /* jvmtiHeapRootCallback */ jvmtiIterationControl JNICALL -heapRootCallback( jvmtiHeapRootKind root_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - void* user_data) { +heapRootCallback(jvmtiHeapRootKind root_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + void* user_data) { if (*tag_ptr > 0) { NSK_DISPLAY2("heapRootCallback: root kind=%s, tag=%d\n", TranslateRootKind(root_kind), (long)*tag_ptr); @@ -61,15 +61,15 @@ heapRootCallback( jvmtiHeapRootKind root_kind, /* jvmtiStackReferenceCallback */ jvmtiIterationControl JNICALL -stackReferenceCallback( jvmtiHeapRootKind root_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong thread_tag, - jint depth, - jmethodID method, - jint slot, - void* user_data) { +stackReferenceCallback(jvmtiHeapRootKind root_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong thread_tag, + jint depth, + jmethodID method, + jint slot, + void* user_data) { if (*tag_ptr > 0) { NSK_DISPLAY2("stackReferenceCallback: root kind=%s, tag=%d\n", TranslateRootKind(root_kind), (long)*tag_ptr); @@ -80,13 +80,13 @@ stackReferenceCallback( jvmtiHeapRootKind root_kind, /* jvmtiObjectReferenceCallback */ jvmtiIterationControl JNICALL -objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong referrer_tag, - jint referrer_index, - void* user_data) { +objectReferenceCallback(jvmtiObjectReferenceKind reference_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong referrer_tag, + jint referrer_index, + void* user_data) { if (*tag_ptr > 0) { NSK_DISPLAY2("objectReferenceCallback: reference kind=%s, tag=%d\n", TranslateObjectRefKind(reference_kind), (long)*tag_ptr); @@ -106,10 +106,10 @@ objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, /************************/ JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP07_ap07t001_setTag( JNIEnv* jni, - jobject obj, - jobject target, - jlong tag ) { +Java_nsk_jvmti_scenarios_allocation_AP07_ap07t001_setTag(JNIEnv* jni, + jobject obj, + jobject target, + jlong tag) { if (!NSK_JVMTI_VERIFY(jvmti->SetTag(target, tag))) { nsk_jvmti_setFailStatus(); @@ -117,7 +117,7 @@ Java_nsk_jvmti_scenarios_allocation_AP07_ap07t001_setTag( JNIEnv* jni, } JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP07_ap07t001_setRoot( JNIEnv* jni, jobject obj) { +Java_nsk_jvmti_scenarios_allocation_AP07_ap07t001_setRoot(JNIEnv* jni, jobject obj) { if (!NSK_JNI_VERIFY(jni, (root = jni->NewGlobalRef(obj)) != NULL)) nsk_jvmti_setFailStatus(); } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP07/ap07t002/ap07t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP07/ap07t002/ap07t002.cpp index e503a3e5def..4b5e95344f1 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP07/ap07t002/ap07t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP07/ap07t002/ap07t002.cpp @@ -47,11 +47,11 @@ static const jlong IGNORE_TAG = (jlong)10l; /* jvmtiHeapRootCallback */ jvmtiIterationControl JNICALL -heapRootCallback( jvmtiHeapRootKind root_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - void* user_data) { +heapRootCallback(jvmtiHeapRootKind root_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + void* user_data) { if (*tag_ptr > 0) { NSK_DISPLAY2("heapRootCallback: root kind=%s, tag=%d\n", TranslateRootKind(root_kind), (long)*tag_ptr); @@ -61,15 +61,15 @@ heapRootCallback( jvmtiHeapRootKind root_kind, /* jvmtiStackReferenceCallback */ jvmtiIterationControl JNICALL -stackReferenceCallback( jvmtiHeapRootKind root_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong thread_tag, - jint depth, - jmethodID method, - jint slot, - void* user_data) { +stackReferenceCallback(jvmtiHeapRootKind root_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong thread_tag, + jint depth, + jmethodID method, + jint slot, + void* user_data) { if (*tag_ptr > 0) { NSK_DISPLAY2("stackReferenceCallback: root kind=%s, tag=%d\n", TranslateRootKind(root_kind), (long)*tag_ptr); @@ -84,13 +84,13 @@ stackReferenceCallback( jvmtiHeapRootKind root_kind, /* jvmtiObjectReferenceCallback */ jvmtiIterationControl JNICALL -objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong referrer_tag, - jint referrer_index, - void* user_data) { +objectReferenceCallback(jvmtiObjectReferenceKind reference_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong referrer_tag, + jint referrer_index, + void* user_data) { if (*tag_ptr > 0) { NSK_DISPLAY2("objectReferenceCallback: reference kind=%s, tag=%d\n", TranslateObjectRefKind(reference_kind), (long)*tag_ptr); @@ -106,10 +106,10 @@ objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, /************************/ JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP07_ap07t002_setTag( JNIEnv* jni, - jobject obj, - jobject target, - jlong tag ) { +Java_nsk_jvmti_scenarios_allocation_AP07_ap07t002_setTag(JNIEnv* jni, + jobject obj, + jobject target, + jlong tag) { if (!NSK_JVMTI_VERIFY(jvmti->SetTag(target, tag))) { nsk_jvmti_setFailStatus(); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP09/ap09t001/ap09t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP09/ap09t001/ap09t001.cpp index 67ef31f446b..00b866d1e92 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP09/ap09t001/ap09t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP09/ap09t001/ap09t001.cpp @@ -61,38 +61,38 @@ static int interfaceFound = 0; /* jvmtiHeapRootCallback */ jvmtiIterationControl JNICALL -heapRootCallback( jvmtiHeapRootKind root_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - void* user_data) { +heapRootCallback(jvmtiHeapRootKind root_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + void* user_data) { return JVMTI_ITERATION_CONTINUE; } /* jvmtiStackReferenceCallback */ jvmtiIterationControl JNICALL -stackReferenceCallback( jvmtiHeapRootKind root_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong thread_tag, - jint depth, - jmethodID method, - jint slot, - void* user_data) { +stackReferenceCallback(jvmtiHeapRootKind root_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong thread_tag, + jint depth, + jmethodID method, + jint slot, + void* user_data) { return JVMTI_ITERATION_CONTINUE; } /* jvmtiObjectReferenceCallback */ jvmtiIterationControl JNICALL -objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, - jlong class_tag, - jlong size, - jlong* tag_ptr, - jlong referrer_tag, - jint referrer_index, - void* user_data) { +objectReferenceCallback(jvmtiObjectReferenceKind reference_kind, + jlong class_tag, + jlong size, + jlong* tag_ptr, + jlong referrer_tag, + jint referrer_index, + void* user_data) { if (*tag_ptr != 0 && referrer_tag != 0) { NSK_DISPLAY4("objectReferenceCallback: reference kind=%s, referrer_index=%d, referrer_tag=%d, referree_tag=%d\n", @@ -127,10 +127,10 @@ objectReferenceCallback( jvmtiObjectReferenceKind reference_kind, /************************/ JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP09_ap09t001_setTag( JNIEnv* jni, - jobject obj, - jobject target, - jlong tag ) { +Java_nsk_jvmti_scenarios_allocation_AP09_ap09t001_setTag(JNIEnv* jni, + jobject obj, + jobject target, + jlong tag) { if (!NSK_JVMTI_VERIFY(jvmti->SetTag(target, tag))) { nsk_jvmti_setFailStatus(); @@ -138,7 +138,7 @@ Java_nsk_jvmti_scenarios_allocation_AP09_ap09t001_setTag( JNIEnv* jni, } JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP09_ap09t001_setReferrer( JNIEnv* jni, jclass klass, jobject ref) { +Java_nsk_jvmti_scenarios_allocation_AP09_ap09t001_setReferrer(JNIEnv* jni, jclass klass, jobject ref) { if (!NSK_JNI_VERIFY(jni, (referrer = jni->NewGlobalRef(ref)) != NULL)) nsk_jvmti_setFailStatus(); } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP12/ap12t001/ap12t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP12/ap12t001/ap12t001.cpp index 3076676e791..c413d64e4f1 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP12/ap12t001/ap12t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP12/ap12t001/ap12t001.cpp @@ -77,7 +77,7 @@ VMDeath(jvmtiEnv *jvmti_env, JNIEnv *env) { /************************/ JNIEXPORT void JNICALL -Java_nsk_jvmti_scenarios_allocation_AP12_ap12t001_setTag( JNIEnv* jni, jobject obj, jlong tag) { +Java_nsk_jvmti_scenarios_allocation_AP12_ap12t001_setTag(JNIEnv* jni, jobject obj, jlong tag) { if (!NSK_JVMTI_VERIFY(jvmti->SetTag(obj, tag))) { nsk_jvmti_setFailStatus(); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t001/bi01t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t001/bi01t001.cpp index 0da3cf8f1d8..5406d4d2569 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t001/bi01t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t001/bi01t001.cpp @@ -110,7 +110,7 @@ cbClassFileLoadHook(jvmtiEnv *jvmti_env, JNIEnv* jni_env, const unsigned char* class_data, jint* new_class_data_len, unsigned char** new_class_data) { - if ( name == NULL || strcmp(name, TESTED_CLASS_NAME) ) { + if (name == NULL || strcmp(name, TESTED_CLASS_NAME)) { return; } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t002/bi01t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t002/bi01t002.cpp index 4d6869b9777..e94859ee59d 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t002/bi01t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t002/bi01t002.cpp @@ -112,7 +112,7 @@ cbClassFileLoadHook(jvmtiEnv *jvmti_env, JNIEnv* jni_env, const unsigned char* class_data, jint* new_class_data_len, unsigned char** new_class_data) { - if ( name == NULL || strcmp(name, TESTED_CLASS_NAME) ) { + if (name == NULL || strcmp(name, TESTED_CLASS_NAME)) { return; } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM01/em01t002/em01t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM01/em01t002/em01t002.cpp index 5f2bf1b0766..209d361da94 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM01/em01t002/em01t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM01/em01t002/em01t002.cpp @@ -127,7 +127,7 @@ Java_nsk_jvmti_scenarios_events_EM01_em01t002_startThread(JNIEnv *jni_env, return NSK_FALSE; } - if (!NSK_JNI_VERIFY_VOID(jni_env,jni_env->CallVoidMethod(thread, methodID)) ) { + if (!NSK_JNI_VERIFY_VOID(jni_env,jni_env->CallVoidMethod(thread, methodID))) { nsk_jvmti_setFailStatus(); return NSK_FALSE; } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM06/em06t001/em06t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM06/em06t001/em06t001.cpp index e52f45dd10d..62799eb7d17 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM06/em06t001/em06t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM06/em06t001/em06t001.cpp @@ -75,7 +75,7 @@ handler(jvmtiEvent event, jvmtiEnv* jvmti, JNIEnv* jni_env, className = jni_env->GetStringUTFChars(jclassName, 0); - if ( className != NULL && (strcmp(className, EXPECTED_CLASS_NAME)==0) ) { + if (className != NULL && (strcmp(className, EXPECTED_CLASS_NAME)==0)) { if (!NSK_JVMTI_VERIFY(jvmti->RawMonitorEnter(syncLock))) nsk_jvmti_setFailStatus(); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/extension/EX03/ex03t001/ex03t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/extension/EX03/ex03t001/ex03t001.cpp index e4032c74e29..bda59959c84 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/extension/EX03/ex03t001/ex03t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/extension/EX03/ex03t001/ex03t001.cpp @@ -124,7 +124,7 @@ jboolean enableClassUnloadEvent (jboolean enable) { if (!NSK_JVMTI_VERIFY( jvmti->SetExtensionEventCallback(extList[i].extension_event_index, - enable ? (jvmtiExtensionEvent)ClassUnload : NULL ))) { + enable ? (jvmtiExtensionEvent)ClassUnload : NULL))) { nsk_jvmti_setFailStatus(); return JNI_FALSE; } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS103/hs103t002/hs103t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS103/hs103t002/hs103t002.cpp index 3616ee25e52..b946634d348 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS103/hs103t002/hs103t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS103/hs103t002/hs103t002.cpp @@ -73,7 +73,7 @@ JNIEXPORT void JNICALL doRedefineInNativeThread(jvmtiEnv * jvmti, nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); for(i = 0; i < 30; i++) { nsk_printf(" Inside the redefine method..\n"); - if ( nsk_jvmti_redefineClass(jvmti, cla,fileName) == NSK_TRUE) { + if (nsk_jvmti_redefineClass(jvmti, cla,fileName) == NSK_TRUE) { nsk_printf("\nMyClass :: Successfully redefined..\n"); } else { nsk_printf("\nMyClass :: Failed to redefine ..\n"); @@ -112,12 +112,12 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf("Agent:: VM.. Started..\n"); rc = vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if (rc != JNI_OK ) { + if (rc != JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -154,7 +154,7 @@ Java_nsk_jvmti_scenarios_hotswap_HS103_hs103t002_hs103t002_startAgentThread(JNIE if (err == JVMTI_ERROR_INVALID_PRIORITY) { nsk_printf(" JVMTI_ERROR_INVALID_PRIORITY ..\n"); return JNI_ERR; - } else if ( err == JVMTI_ERROR_INVALID_THREAD) { + } else if (err == JVMTI_ERROR_INVALID_THREAD) { nsk_printf(" JVMTI_ERROR_INVALID_THREAD ..\n"); return JNI_ERR; } else if (err == JVMTI_ERROR_NULL_POINTER) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS104/hs104t001/hs104t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS104/hs104t001/hs104t001.cpp index 975511f5d2e..454e01fbe1f 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS104/hs104t001/hs104t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS104/hs104t001/hs104t001.cpp @@ -46,9 +46,9 @@ JNIEXPORT void JNICALL char fileName[512]; nsk_jvmti_getFileName(0, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti, klass, fileName ) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti, klass, fileName) == NSK_TRUE) { nsk_printf("Agent:: Successfully redefined.."); - if ( nsk_jvmti_disableNotification(jvmti,JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_disableNotification(jvmti,JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Agent :: NOTIFICATIONS ARE DISABLED \n"); } else { nsk_printf(" Agent :: Failed to disabled \n"); @@ -75,13 +75,13 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jvmtiEnv * jvmti; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -96,8 +96,8 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, - JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, + JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf("Agent :: NOTIFICATIONS ARE ENABLED \n"); } else { nsk_printf(" Error in Eanableing Notifications.."); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS104/hs104t002/hs104t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS104/hs104t002/hs104t002.cpp index feac4530985..0cba9e432d6 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS104/hs104t002/hs104t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS104/hs104t002/hs104t002.cpp @@ -49,18 +49,18 @@ JNIEXPORT jint JNI_OnLoad_hs104t002(JavaVM *jvm, char *options, void *reserved) } #endif jint Agent_Initialize(JavaVM *vm, char *options, void *reserved){ - if ( ! NSK_VERIFY ( JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1) ) ) { + if (!NSK_VERIFY (JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1))) { nsk_printf("#error Agent :: Could not load JVMTI interface.\n"); return JNI_ERR; } else { jvmtiCapabilities caps; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } memset(&caps, 0, sizeof(caps)); caps.can_redefine_classes = 1; - if (! NSK_JVMTI_VERIFY ( jvmti->AddCapabilities(&caps) )) { + if (!NSK_JVMTI_VERIFY (jvmti->AddCapabilities(&caps))) { nsk_printf("#error Agent :: occured while adding capabilities.\n"); return JNI_ERR; } @@ -74,14 +74,14 @@ Java_nsk_jvmti_scenarios_hotswap_HS104_hs104t002_hs104t002_redefineClasses( jclass cla; char fileName[512]; - if ( ! NSK_JNI_VERIFY(jni, ( cla = jni->FindClass(SEARCH_NAME) ) != NULL ) ) { + if (!NSK_JNI_VERIFY(jni, (cla = jni->FindClass(SEARCH_NAME)) != NULL)) { nsk_printf(" Agent :: Failed to get class.\n"); nsk_jvmti_agentFailed(); return; } nsk_jvmti_getFileName(0, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass( jvmti, cla, fileName) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti, cla, fileName) == NSK_TRUE) { nsk_printf(" Agent :: Redefine successfull.\n"); } else { nsk_printf("# error Agent :: Redefine failed.\n"); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS202/hs202t001/hs202t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS202/hs202t001/hs202t001.cpp index 322a6506e6f..22663efb806 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS202/hs202t001/hs202t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS202/hs202t001/hs202t001.cpp @@ -63,7 +63,7 @@ JNIEXPORT void JNICALL callbackClassPrepare(jvmtiEnv *jvmti, jlocation end; jvmtiError err ; err=jvmti->GetMethodLocation(method, &start, &end); - if ( err != JVMTI_ERROR_NONE ) { + if (err != JVMTI_ERROR_NONE) { nsk_printf(" ## Error occured %s \n",TranslateError(err)); }else { nsk_printf("\n Start = %d and end = %d ", start , end); @@ -73,7 +73,7 @@ JNIEXPORT void JNICALL callbackClassPrepare(jvmtiEnv *jvmti, nsk_printf(" ## Error occured %s \n",TranslateError(err)); } else { nsk_printf(" NO ERRORS "); - if (nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_BREAKPOINT, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_BREAKPOINT, NULL) == NSK_TRUE) { nsk_printf(" Enabled.. notification event ..\n"); } } @@ -116,8 +116,8 @@ void JNICALL callbackBreakpoint(jvmtiEnv *jvmti_env, jlocation location) { jvmtiError err; err = JVMTI_ERROR_NONE; - if ( nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_SINGLE_STEP, NULL) - == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_SINGLE_STEP, NULL) + == NSK_TRUE) { nsk_printf(" Enabled.. notification event .."); } err= jvmti->SetEventNotificationMode(JVMTI_DISABLE, @@ -145,14 +145,14 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jint code; nsk_printf("Agent:: VM.. Started..\n"); code = vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( code != JNI_OK ) { + if (code != JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; memset(&caps, 0, sizeof(caps)); - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -173,7 +173,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" ## Error occured %s \n",TranslateError(rc)); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf("Agent :: NOTIFICATIONS ARE ENABLED \n"); } else { nsk_printf(" Error in Eanableing Notifications.."); @@ -192,7 +192,7 @@ Java_nsk_jvmti_scenarios_hotswap_HS202_hs202t001_hs202t001_popThreadFrame(JNIEnv nsk_printf("Agent:: POPING THE FRAME....\n"); retvalue = JNI_FALSE; jvmti->GetThreadState(thread, &state); - if ( state & JVMTI_THREAD_STATE_SUSPENDED) { + if (state & JVMTI_THREAD_STATE_SUSPENDED) { err = jvmti->PopFrame(thread); if (err == JVMTI_ERROR_NONE) { nsk_printf("Agent:: NO Errors poped very well ..\n"); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS202/hs202t002/hs202t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS202/hs202t002/hs202t002.cpp index 6d3a4002d1e..d8e2ead6b89 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS202/hs202t002/hs202t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS202/hs202t002/hs202t002.cpp @@ -57,7 +57,7 @@ void JNICALL callbackMethodExit(jvmtiEnv *jvmti_env, jmethodID method, jboolean was_popped_by_exception, jvalue return_value) { - if ( was_popped_by_exception ) { + if (was_popped_by_exception) { char * name; char * signature; char * generic ; @@ -70,7 +70,7 @@ void JNICALL callbackMethodExit(jvmtiEnv *jvmti_env, nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); jvmti_env->GetMethodDeclaringClass(method, &cls); - if ( nsk_jvmti_redefineClass(jvmti_env, cls,fileName) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti_env, cls,fileName) == NSK_TRUE) { nsk_printf(" Agent:: redefine class success ..\n"); nsk_printf("Agent::SUSPENDING>> \n"); err=jvmti_env->SuspendThread(thread); @@ -102,14 +102,14 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf("Agent:: VM.. Started..\n"); redefineNumber=0; rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; memset(&caps, 0, sizeof(caps)); - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -143,7 +143,7 @@ Java_nsk_jvmti_scenarios_hotswap_HS202_hs202t002_hs202t002_popThreadFrame(JNIEnv jint state; nsk_printf("Agent:: POPPING THE FRAME..\n"); jvmti->GetThreadState(thread, &state); - if ( state & JVMTI_THREAD_STATE_SUSPENDED) { + if (state & JVMTI_THREAD_STATE_SUSPENDED) { err = jvmti->PopFrame(thread); if (err == JVMTI_ERROR_NONE) { nsk_printf("Agent:: PopFrame succeeded..\n"); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t001/hs203t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t001/hs203t001.cpp index e79c17bd9e8..a6113399498 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t001/hs203t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t001/hs203t001.cpp @@ -71,7 +71,7 @@ JNIEXPORT void JNICALL if (err == JVMTI_ERROR_NONE) { nsk_printf("Agent:: NO ERRORS FOUND \n"); err= jvmti->SetBreakpoint(method, start); - if ( err == JVMTI_ERROR_NONE) { + if (err == JVMTI_ERROR_NONE) { nsk_printf(" Class Name %s \n", className); nsk_printf("Agent:: Breakpoint set \n"); } else { @@ -97,7 +97,7 @@ void JNICALL callbackSingleStep(jvmtiEnv *jvmti, JNIEnv* jni, nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); nsk_printf(" %d..",redefineNumber); - if ( nsk_jvmti_redefineClass(jvmti, threadClass, fileName) == NSK_TRUE) { + if (nsk_jvmti_redefineClass(jvmti, threadClass, fileName) == NSK_TRUE) { nsk_printf("\nMyClass :: Successfully redefined..\n"); } else { nsk_printf("\nMyClass :: Failed to redefine ..\n"); @@ -118,7 +118,7 @@ callbackBreakpoint(jvmtiEnv *jvmti, jmethodID method, jlocation location) { nsk_printf("Agent::... BreakPoint Reached..\n"); - if ( nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_SINGLE_STEP,thread) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_SINGLE_STEP,thread) == NSK_TRUE) { nsk_printf(" .... Enabled..\n"); } return; @@ -139,13 +139,13 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jint rc ; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -166,8 +166,8 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( (nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_CLASS_LOAD, NULL) == NSK_TRUE ) && - (nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_BREAKPOINT,NULL) == NSK_TRUE) ) { + if ((nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_CLASS_LOAD, NULL) == NSK_TRUE) && + (nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_BREAKPOINT,NULL) == NSK_TRUE)) { nsk_printf("Agent :: NOTIFICATIONS ARE ENABLED \n"); } else { nsk_printf(" Error in Eanableing Notifications.."); @@ -189,7 +189,7 @@ Java_nsk_jvmti_scenarios_hotswap_HS203_hs203t001_hs203t001_popThreadFrame(JNIEnv nsk_printf(" Here "); jvmti->GetThreadState(thread, &state); nsk_printf(" Here "); - if ( state & JVMTI_THREAD_STATE_SUSPENDED) { + if (state & JVMTI_THREAD_STATE_SUSPENDED) { err = jvmti->PopFrame(thread); if (err == JVMTI_ERROR_NONE) { nsk_printf("Agent:: NO Errors poped very well ..\n"); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t002/hs203t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t002/hs203t002.cpp index 63def1bd685..9eebae1fd21 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t002/hs203t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t002/hs203t002.cpp @@ -73,7 +73,7 @@ callbackClassLoad(jvmtiEnv *jvmti, if (err == JVMTI_ERROR_NONE) { nsk_printf("Agent:: NO ERRORS FOUND \n"); err= jvmti->SetBreakpoint(method, start); - if ( err == JVMTI_ERROR_NONE) { + if (err == JVMTI_ERROR_NONE) { nsk_printf("Agent:: Breakpoint set \n"); } else { nsk_printf("Agent:: ***ERROR OCCURED ... in SET BREAK POINT ERROR \n"); @@ -98,14 +98,14 @@ void JNICALL callbackSingleStep(jvmtiEnv *jvmti, nsk_printf(" %d..",redefineNumber); nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if( nsk_jvmti_redefineClass(jvmti, threadClass,fileName) == NSK_TRUE ) { + if(nsk_jvmti_redefineClass(jvmti, threadClass,fileName) == NSK_TRUE) { nsk_printf("Agent:: Redefined..\n"); } else { nsk_printf(" Failed to redefine..\n"); return; } err=jvmti->SuspendThread(thread); - if ( err == JVMTI_ERROR_NONE ) { + if (err == JVMTI_ERROR_NONE) { nsk_printf("Agent:: Succeded in suspending..\n"); } else { nsk_printf(" ## Error occured %s \n",TranslateError(err)); @@ -118,7 +118,7 @@ void JNICALL callbackBreakpoint(jvmtiEnv *jvmti, jmethodID method, jlocation location) { nsk_printf("Agent::... BreakPoint Reached..\n"); - if ( nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_SINGLE_STEP,thread) == JNI_OK ) { + if (nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_SINGLE_STEP,thread) == JNI_OK) { nsk_printf(" .... Enabled..\n"); } return; @@ -140,13 +140,13 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jint rc ; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -168,10 +168,10 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( (nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_CLASS_LOAD, + if ((nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_CLASS_LOAD, NULL) == NSK_TRUE) && (nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_BREAKPOINT, - NULL) == NSK_TRUE ) ) { + NULL) == NSK_TRUE)) { nsk_printf("Agent :: NOTIFICATIONS ARE ENABLED \n"); } else { nsk_printf(" Error in Eanableing Notifications.."); @@ -191,7 +191,7 @@ Java_nsk_jvmti_scenarios_hotswap_HS203_hs203t002_hs203t002_popThreadFrame(JNIEnv nsk_printf("Agent:: POPING THE FRAME....\n"); retvalue = JNI_FALSE; jvmti->GetThreadState(thread, &state); - if ( state & JVMTI_THREAD_STATE_SUSPENDED) { + if (state & JVMTI_THREAD_STATE_SUSPENDED) { err = jvmti->PopFrame(thread); if (err == JVMTI_ERROR_NONE) { nsk_printf("Agent:: NO Errors poped very well ..\n"); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t003/hs203t003.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t003/hs203t003.cpp index 421f3b76d3e..fa5f3ae10ed 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t003/hs203t003.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t003/hs203t003.cpp @@ -60,18 +60,18 @@ JNIEXPORT void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, redefineNumber=0; className=NULL; generic=NULL; - if ( ! NSK_JVMTI_VERIFY ( jvmti_env->GetClassSignature(klass, &className, &generic) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti_env->GetClassSignature(klass, &className, &generic))) { nsk_printf("#error Agent :: while getting classname Signature.\n"); nsk_jvmti_agentFailed(); } else { if (strcmp(className,CLASS_NAME) == 0) { jfieldID field; /* get the field id and set watch on that .*/ - if (! NSK_JNI_VERIFY(jni, (field = jni->GetFieldID(klass, FIELDNAME, TYPE)) != NULL) ) { - nsk_printf(" Agent :: (*JNI)->GetFieldID(jni, ... ) returns `null`.\n"); + if (!NSK_JNI_VERIFY(jni, (field = jni->GetFieldID(klass, FIELDNAME, TYPE)) != NULL)) { + nsk_printf(" Agent :: (*JNI)->GetFieldID(jni, ...) returns `null`.\n"); nsk_jvmti_agentFailed(); - } else if ( ! NSK_JVMTI_VERIFY(jvmti_env->SetFieldAccessWatch(klass, field) ) ) { - nsk_printf("#error Agent :: occured while jvmti->SetFieldAccessWatch(... ) .\n"); + } else if (!NSK_JVMTI_VERIFY(jvmti_env->SetFieldAccessWatch(klass, field))) { + nsk_printf("#error Agent :: occured while jvmti->SetFieldAccessWatch(...) .\n"); nsk_jvmti_agentFailed(); } } @@ -93,20 +93,20 @@ JNIEXPORT void JNICALL callbackFieldAccess(jvmtiEnv *jvmti_env, return; } redefineNumber=0; - if (! NSK_JNI_VERIFY(jni, (clas = jni->FindClass(SEARCH_NAME)) != NULL) ) { + if (!NSK_JNI_VERIFY(jni, (clas = jni->FindClass(SEARCH_NAME)) != NULL)) { nsk_printf(" Agent :: (*JNI)->FindClass(jni, %s) returns `null`.\n",SEARCH_NAME); nsk_jvmti_agentFailed(); } else { nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti_env, clas, fileName ) != NSK_TRUE) { + if (nsk_jvmti_redefineClass(jvmti_env, clas, fileName) != NSK_TRUE) { nsk_printf(" Agent :: Failed to redefine.\n"); nsk_jvmti_agentFailed(); } else { nsk_printf(" Agent :: Redefined.\n"); nsk_printf(" Agent :: Suspendeding thread.\n"); /* pop the current working frame. */ - if ( ! NSK_JVMTI_VERIFY(jvmti_env->SuspendThread(thread) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti_env->SuspendThread(thread))) { nsk_printf("#error Agent :: occured suspending Thread.\n"); nsk_jvmti_agentFailed(); } else { @@ -128,13 +128,13 @@ JNIEXPORT jint JNI_OnLoad_hs203t003(JavaVM *jvm, char *options, void *reserved) } #endif jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { - if ( ! NSK_VERIFY ( JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1) ) ) { + if (!NSK_VERIFY(JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1))) { nsk_printf(" Agent :: Could not load JVMTI interface.\n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("#error Agent :: Failed to parse options.\n"); return JNI_ERR; } @@ -144,7 +144,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { caps.can_pop_frame=1; caps.can_generate_all_class_hook_events=1; caps.can_generate_field_access_events=1; - if (! NSK_JVMTI_VERIFY ( jvmti->AddCapabilities(&caps) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti->AddCapabilities(&caps))) { nsk_printf("#error Agent :: while adding capabilities.\n"); return JNI_ERR; } @@ -155,10 +155,10 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf("#error Agent :: while setting event callbacks.\n"); return JNI_ERR; } - if ( ( nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_CLASS_PREPARE, NULL) - == NSK_TRUE ) && - ( nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_FIELD_ACCESS, NULL) - == NSK_TRUE ) ) { + if ((nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_CLASS_PREPARE, NULL) + == NSK_TRUE) && + (nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_FIELD_ACCESS, NULL) + == NSK_TRUE)) { nsk_printf(" Agent :: Notifications are enabled.\n"); } else { nsk_printf("#error Agent :: Eanableing Notifications.\n"); @@ -175,11 +175,11 @@ Java_nsk_jvmti_scenarios_hotswap_HS203_hs203t003_hs203t003_isSuspended(JNIEnv * jboolean retvalue; jint state; retvalue = JNI_FALSE; - if ( ! NSK_JVMTI_VERIFY( jvmti->GetThreadState(thread, &state) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti->GetThreadState(thread, &state))) { nsk_printf(" Agent :: Error while getting thread state.\n"); nsk_jvmti_agentFailed(); } else { - if ( state & JVMTI_THREAD_STATE_SUSPENDED) { + if (state & JVMTI_THREAD_STATE_SUSPENDED) { retvalue = JNI_TRUE; } } @@ -193,18 +193,18 @@ Java_nsk_jvmti_scenarios_hotswap_HS203_hs203t003_hs203t003_popThreadFrame(JNIEnv jboolean retvalue; jint state; retvalue = JNI_FALSE; - if ( ! NSK_JVMTI_VERIFY( jvmti->GetThreadState(thread, &state) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti->GetThreadState(thread, &state))) { nsk_printf(" Agent :: Error while getting thread state.\n"); nsk_jvmti_agentFailed(); } else { - if ( state & JVMTI_THREAD_STATE_SUSPENDED) { - if ( ! NSK_JVMTI_VERIFY ( jvmti->PopFrame(thread) ) ) { + if (state & JVMTI_THREAD_STATE_SUSPENDED) { + if (!NSK_JVMTI_VERIFY(jvmti->PopFrame(thread))) { nsk_printf("#error Agent :: while poping thread's frame.\n"); nsk_jvmti_agentFailed(); } else { nsk_printf(" Agent :: poped thread frame.\n"); - if ( ! NSK_JVMTI_VERIFY ( - jvmti->SetEventNotificationMode(JVMTI_DISABLE, JVMTI_EVENT_FIELD_ACCESS, NULL) ) ) { + if (!NSK_JVMTI_VERIFY( + jvmti->SetEventNotificationMode(JVMTI_DISABLE, JVMTI_EVENT_FIELD_ACCESS, NULL))) { nsk_printf("#error Agent :: failed to disable notification JVMTI_EVENT_FIELD ACCESS.\n"); nsk_jvmti_agentFailed(); } else { @@ -226,7 +226,7 @@ Java_nsk_jvmti_scenarios_hotswap_HS203_hs203t003_hs203t003_resumeThread(JNIEnv * jthread thread) { jboolean retvalue; retvalue = JNI_FALSE; - if ( !NSK_JVMTI_VERIFY( jvmti->ResumeThread(thread) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti->ResumeThread(thread))) { nsk_printf("#error Agent :: while resuming thread.\n"); nsk_jvmti_agentFailed(); } else { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t004/hs203t004.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t004/hs203t004.cpp index 9f9e99a169d..48340005fe9 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t004/hs203t004.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS203/hs203t004/hs203t004.cpp @@ -45,14 +45,14 @@ JNIEXPORT void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, char * className; className=NULL; - if (!NSK_JVMTI_VERIFY (jvmti_env->GetClassSignature(klass, &className, NULL) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti_env->GetClassSignature(klass, &className, NULL))) { NSK_COMPLAIN0("#error Agent :: while getting classname.\n"); nsk_jvmti_agentFailed(); } else { if (strcmp(className, CLASS_NAME) == 0) { if (nsk_jvmti_enableNotification(jvmti_env, JVMTI_EVENT_COMPILED_METHOD_LOAD, NULL) == NSK_TRUE) { NSK_DISPLAY0(" Agent :: notification enabled for COMPILED_METHOD_LOAD.\n"); - if ( ! NSK_JVMTI_VERIFY ( jvmti_env->GenerateEvents(JVMTI_EVENT_COMPILED_METHOD_LOAD) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti_env->GenerateEvents(JVMTI_EVENT_COMPILED_METHOD_LOAD))) { NSK_COMPLAIN0("#error Agent :: occured while enabling compiled method events.\n"); nsk_jvmti_agentFailed(); } @@ -76,7 +76,7 @@ JNIEXPORT void JNICALL callbackCompiledMethodLoad(jvmtiEnv *jvmti_env, const void* compile_info) { jclass threadClass; if (redefineNumber == 0) { - if ( ! NSK_JVMTI_VERIFY ( jvmti_env->GetMethodDeclaringClass(method, &threadClass) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti_env->GetMethodDeclaringClass(method, &threadClass))) { NSK_COMPLAIN0("#error Agent :: while geting the declaring class.\n"); nsk_jvmti_agentFailed(); } else { @@ -86,13 +86,13 @@ JNIEXPORT void JNICALL callbackCompiledMethodLoad(jvmtiEnv *jvmti_env, className = NULL; methodName = NULL; - if ( ! NSK_JVMTI_VERIFY (jvmti_env->GetClassSignature(threadClass, &className, NULL) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti_env->GetClassSignature(threadClass, &className, NULL))) { NSK_COMPLAIN0("#error Agent :: while getting classname.\n"); nsk_jvmti_agentFailed(); return; } - if ( ! NSK_JVMTI_VERIFY (jvmti_env->GetMethodName(method, &methodName, NULL, NULL) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti_env->GetMethodName(method, &methodName, NULL, NULL))) { NSK_COMPLAIN0("#error Agent :: while getting methodname.\n"); nsk_jvmti_agentFailed(); return; @@ -106,7 +106,7 @@ JNIEXPORT void JNICALL callbackCompiledMethodLoad(jvmtiEnv *jvmti_env, nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti_env, threadClass, fileName) == NSK_TRUE) { + if (nsk_jvmti_redefineClass(jvmti_env, threadClass, fileName) == NSK_TRUE) { NSK_DISPLAY0(" Agent :: Successfully redefined.\n"); redefineNumber++; } else { @@ -115,13 +115,13 @@ JNIEXPORT void JNICALL callbackCompiledMethodLoad(jvmtiEnv *jvmti_env, } } - if ( className != NULL ) { + if (className != NULL) { if (!NSK_JVMTI_VERIFY(jvmti_env->Deallocate((unsigned char *)className))) { NSK_COMPLAIN1("#error Agent :: failed to Deallocate className = %s.", className); nsk_jvmti_agentFailed(); } } - if ( methodName != NULL ) { + if (methodName != NULL) { if (!NSK_JVMTI_VERIFY(jvmti_env->Deallocate((unsigned char *)methodName))) { NSK_COMPLAIN1("#error Agent :: failed to Deallocate methodName = %s.", methodName); nsk_jvmti_agentFailed(); @@ -144,14 +144,14 @@ JNIEXPORT jint JNI_OnLoad_hs203t004(JavaVM *jvm, char *options, void *reserved) #endif jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { redefineNumber=0; - if ( ! NSK_VERIFY ( JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1) ) ) { + if (!NSK_VERIFY(JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1))) { NSK_DISPLAY0("#error Agent :: Could not load JVMTI interface.\n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; memset(&caps, 0, sizeof(caps)); - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { NSK_DISPLAY0("#error Agent :: Failed to parse options.\n"); return JNI_ERR; } @@ -160,7 +160,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { caps.can_pop_frame = 1; caps.can_generate_all_class_hook_events = 1; caps.can_generate_compiled_method_load_events = 1; - if (! NSK_JVMTI_VERIFY ( jvmti->AddCapabilities(&caps) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti->AddCapabilities(&caps))) { NSK_DISPLAY0("#error Agent :: occured while adding capabilities.\n"); return JNI_ERR; } @@ -171,7 +171,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { NSK_COMPLAIN0("#error Agent :: occured while setting event callback.\n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { + if (nsk_jvmti_enableNotification(jvmti,JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { NSK_DISPLAY0(" Agent :: Notifications are enabled.\n"); } else { NSK_COMPLAIN0("#error Agent :: Error in enableing Notifications.\n"); @@ -186,7 +186,7 @@ Java_nsk_jvmti_scenarios_hotswap_HS203_hs203t004_hs203t004_suspendThread(JNIEnv jobject clas, jthread thread) { NSK_DISPLAY0(" Agent :: Suspending Thread.\n"); - if ( NSK_JVMTI_VERIFY( jvmti->SuspendThread(thread) ) ) { + if (NSK_JVMTI_VERIFY(jvmti->SuspendThread(thread))) { NSK_DISPLAY0(" Agent :: Succeded in suspending.\n"); } else { NSK_COMPLAIN0("#error Agent :: occured while suspending thread.\n"); @@ -201,20 +201,20 @@ Java_nsk_jvmti_scenarios_hotswap_HS203_hs203t004_hs203t004_popThreadFrame(JNIEnv jboolean retvalue; jint state; - NSK_DISPLAY0(" Agent :: nsk.jvmti.scenarios.hotswap.HS203.hs203t004.popThreadFrame(... ).\n"); + NSK_DISPLAY0(" Agent :: nsk.jvmti.scenarios.hotswap.HS203.hs203t004.popThreadFrame(...).\n"); retvalue = JNI_FALSE; - if ( ! NSK_JVMTI_VERIFY (jvmti->GetThreadState(thread, &state) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti->GetThreadState(thread, &state))) { NSK_COMPLAIN0("#error Agent :: while getting thread's state.\n"); nsk_jvmti_agentFailed(); } else { - if ( state & JVMTI_THREAD_STATE_SUSPENDED) { - if ( ! NSK_JVMTI_VERIFY( jvmti->PopFrame(thread) ) ) { + if (state & JVMTI_THREAD_STATE_SUSPENDED) { + if (!NSK_JVMTI_VERIFY(jvmti->PopFrame(thread))) { NSK_DISPLAY0("#error Agent :: occured while poping thread's frame.\n"); nsk_jvmti_agentFailed(); } else { - if ( NSK_JVMTI_VERIFY( + if (NSK_JVMTI_VERIFY( jvmti->SetEventNotificationMode(JVMTI_DISABLE, - JVMTI_EVENT_COMPILED_METHOD_LOAD, NULL) ) ) { + JVMTI_EVENT_COMPILED_METHOD_LOAD, NULL))) { NSK_DISPLAY0(" Agent :: Disabled JVMTI_EVENT_COMPILED_METHOD_LOAD.\n"); retvalue = JNI_TRUE; } else { @@ -237,7 +237,7 @@ Java_nsk_jvmti_scenarios_hotswap_HS203_hs203t004_hs203t004_resumeThread(JNIEnv * jboolean retvalue; retvalue = JNI_FALSE; - if ( NSK_JVMTI_VERIFY (jvmti->ResumeThread(thread))) { + if (NSK_JVMTI_VERIFY(jvmti->ResumeThread(thread))) { NSK_DISPLAY0(" Agent :: Thread resumed.\n"); retvalue= JNI_TRUE; } else { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t001/hs204t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t001/hs204t001.cpp index 457213cd7b4..158c3e6abae 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t001/hs204t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t001/hs204t001.cpp @@ -51,7 +51,7 @@ static jint newClassSize; char *getClassName(jvmtiEnv *jvmti, jclass klass) { char * className; char * generic; - if( !NSK_JVMTI_VERIFY(jvmti->GetClassSignature(klass, &className, &generic))) { + if(!NSK_JVMTI_VERIFY(jvmti->GetClassSignature(klass, &className, &generic))) { nsk_jvmti_setFailStatus(); } return className; @@ -64,18 +64,18 @@ callbackClassLoad(jvmtiEnv *jvmti_env, jclass klass) { char * name; name = getClassName(jvmti_env,klass); - if( (strcmp(name,CLASS_NAME ) == 0) && (redefineNumber== 1) ) { + if((strcmp(name,CLASS_NAME) == 0) && (redefineNumber== 1)) { char fileName[512]; nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); NSK_DISPLAY1(">>>>>>CallbackClassLoad ... Name=%s... >>\n",name); - if ( nsk_jvmti_redefineClass(jvmti, klass, fileName) == NSK_TRUE) { + if (nsk_jvmti_redefineClass(jvmti, klass, fileName) == NSK_TRUE) { NSK_DISPLAY0("\nMyClass :: Successfully redefined..\n"); redefineNumber++; } else { NSK_COMPLAIN0("\nMyClass :: Failed to redefine ..\n"); } - /* if ( (myTestClass = jni_env->NewGlobalRef(klass) ) == NULL) { + /* if ((myTestClass = jni_env->NewGlobalRef(klass)) == NULL) { NSK_COMPLAIN0("Failed to create global ref..."); } */ @@ -89,18 +89,18 @@ callbackClassPrepare(jvmtiEnv *jvmti_env, jclass klass) { char * name; name = getClassName(jvmti_env, klass); - if ( (strcmp(name, CLASS_NAME) ==0 ) && (redefineNumber == 0) ) { + if ((strcmp(name, CLASS_NAME) ==0) && (redefineNumber == 0)) { char fileName[512]; nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); NSK_DISPLAY1(">>>>>>callbackClassPrepare ... Name=%s... >>\n",name); - if ( nsk_jvmti_redefineClass(jvmti, klass, fileName) == NSK_TRUE) { + if (nsk_jvmti_redefineClass(jvmti, klass, fileName) == NSK_TRUE) { NSK_DISPLAY0("\nMyClass :: Successfully redefined..\n"); redefineNumber++; } else { NSK_COMPLAIN0("\nMyClass :: Failed to redefine ..\n"); } - if( (myTestClass = (jclass) jni_env->NewGlobalRef(klass)) == NULL) { + if((myTestClass = (jclass) jni_env->NewGlobalRef(klass)) == NULL) { NSK_COMPLAIN0("Failed to create global ref..."); } } @@ -117,7 +117,7 @@ callbackClassFileLoadHock(jvmtiEnv *jvmti_env, const unsigned char* class_data, jint* new_class_data_len, unsigned char** new_class_data) { - if (name != NULL && strcmp(name, NAME)==0 && (redefineNumber == 1 )) { + if (name != NULL && strcmp(name, NAME)==0 && (redefineNumber == 1)) { NSK_DISPLAY1(">>>>>>callbackClassFileLoadHock ... Name=%s... >>\n",name); /*redefineClass(jvmti_env, myTestClass);*/ } @@ -174,7 +174,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jint rc ; NSK_DISPLAY0(" VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { NSK_COMPLAIN0(" Could not load JVMTI interface \n"); } else { /* Open simple block for better memor usage. */ @@ -262,7 +262,7 @@ Java_nsk_jvmti_scenarios_hotswap_HS204_hs204t001_hs204t001_suspendThread(JNIEnv nsk_jvmti_setFailStatus(); return NSK_FALSE; } else { - NSK_DISPLAY0(" Sucessfully suspended Thread..\n" ); + NSK_DISPLAY0(" Sucessfully suspended Thread..\n"); } } else { NSK_COMPLAIN0("Was not able to suspend a thread..\n"); @@ -280,7 +280,7 @@ Java_nsk_jvmti_scenarios_hotswap_HS204_hs204t001_hs204t001_popFrame(JNIEnv * env NSK_DISPLAY0("Inside pop_Frame method.....\n"); if (jvmti->GetThreadState(thread, &state) == JVMTI_ERROR_NONE) { NSK_DISPLAY0(" Got the state of thread \n"); - if ( state & JVMTI_THREAD_STATE_SUSPENDED) { + if (state & JVMTI_THREAD_STATE_SUSPENDED) { NSK_DISPLAY0(" Thread is already in suspended mode..\n"); if (!NSK_JVMTI_VERIFY(jvmti->PopFrame(thread))) { NSK_COMPLAIN0(" TEST FAILED: UNABLE TO POP FRAME \n"); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t002/hs204t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t002/hs204t002.cpp index 751b4f7a4ee..32c30c9ff6d 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t002/hs204t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t002/hs204t002.cpp @@ -54,7 +54,7 @@ callbackClassPrepare(jvmtiEnv *jvmti, redefineNumber=0; jvmti->GetClassSignature(klass, &className, &generic); /* printf("Agent::Class Name %s \n",className); */ - if( (strcmp(className, CLASS_NAME) == 0 ) ) { + if((strcmp(className, CLASS_NAME) == 0)) { jclass cls; cls = jni->FindClass(SEARCH_NAME); if (cls == NULL) { @@ -69,7 +69,7 @@ callbackClassPrepare(jvmtiEnv *jvmti, jlocation end; jvmtiError err ; err=jvmti->GetMethodLocation(method, &start, &end); - if ( err != JVMTI_ERROR_NONE) { + if (err != JVMTI_ERROR_NONE) { printf("Agent::Errors in finding start and end for the method \n"); } else { printf("Agent Start = %" LL "d and end = %" LL "d \n", start , end); @@ -77,11 +77,11 @@ callbackClassPrepare(jvmtiEnv *jvmti, err= jvmti->SetBreakpoint(method, start+1); if (err == JVMTI_ERROR_DUPLICATE) { printf("Agent::JVMTI_ERROR_DUPLICATE"); - } else if (err ==JVMTI_ERROR_INVALID_METHODID ) { + } else if (err ==JVMTI_ERROR_INVALID_METHODID) { printf("Agent::JVMTI_ERROR_INVALID_METHODID "); - } else if ( err == JVMTI_ERROR_INVALID_LOCATION) { + } else if (err == JVMTI_ERROR_INVALID_LOCATION) { printf("Agent::JVMTI_ERROR_INVALID_LOCATION "); - } else if ( err == JVMTI_ERROR_NONE) { + } else if (err == JVMTI_ERROR_NONE) { printf("Agent::NO ERRORS "); } else { printf("Agent::VERY VERY INVALID STATE "); @@ -104,7 +104,7 @@ void JNICALL callbackBreakpoint(jvmtiEnv *jvmti_env, sizeof(fileName)/sizeof(char)); cls = jni->FindClass(SEARCH_NAME); printf("Agent:: Break Pont Reached.."); - if ( nsk_jvmti_redefineClass(jvmti, cls, fileName ) == NSK_TRUE) { + if (nsk_jvmti_redefineClass(jvmti, cls, fileName) == NSK_TRUE) { nsk_printf("\nMyClass :: Successfully redefined..\n"); } else { nsk_printf("\nMyClass :: Failed to redefine ..\n"); @@ -128,7 +128,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jint rc ; printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t003/hs204t003.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t003/hs204t003.cpp index bc9cbcee5c3..61d4d6565e5 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t003/hs204t003.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t003/hs204t003.cpp @@ -51,25 +51,22 @@ JNIEXPORT void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, className = NULL; generic = NULL; redefineNumber=0; - if ( !NSK_JVMTI_VERIFY(jvmti_env->GetClassSignature(klass, &className, &generic)) ) { + if (!NSK_JVMTI_VERIFY(jvmti_env->GetClassSignature(klass, &className, &generic))) { NSK_DISPLAY0(" Agent :: Failed get class signature.\n"); nsk_jvmti_agentFailed(); } else { - if( (strcmp(className, CLASS_NAME) == 0 ) ) { + if((strcmp(className, CLASS_NAME) == 0)) { jfieldID fieldId; - if ( ! NSK_JNI_VERIFY(jni, (fieldId = jni->GetStaticFieldID(klass, FIELDNAME, TYPE) ) != NULL ) ) { + if (!NSK_JNI_VERIFY(jni, (fieldId = jni->GetStaticFieldID(klass, FIELDNAME, TYPE)) != NULL)) { NSK_DISPLAY0(" Agent :: Failed to get FieldId.\n"); nsk_jvmti_agentFailed(); } else { - if ( ! NSK_JVMTI_VERIFY(jvmti_env->SetFieldAccessWatch(klass, fieldId) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti_env->SetFieldAccessWatch(klass, fieldId))) { NSK_DISPLAY0(" Agent :: Failed to set watch point on a field.\n"); nsk_jvmti_agentFailed(); } else { nsk_jvmti_enableNotification(jvmti_env, JVMTI_EVENT_FIELD_ACCESS, NULL); - if (! NSK_JNI_VERIFY(jni, - ( watchFieldClass = (jclass) - jni->NewGlobalRef(klass) ) - != NULL ) ) { + if (!NSK_JNI_VERIFY(jni, (watchFieldClass = (jclass) jni->NewGlobalRef(klass)) != NULL)) { NSK_DISPLAY0(" Agent :: Failed to get global reference for class.\n"); nsk_jvmti_agentFailed(); } @@ -80,14 +77,14 @@ JNIEXPORT void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, } } - if ( className != NULL ) { + if (className != NULL) { if (!NSK_JVMTI_VERIFY(jvmti_env->Deallocate((unsigned char *)className))) { NSK_DISPLAY1(" Agent :: #error failed to Deallocate className = %s.", className); nsk_jvmti_agentFailed(); } } - if ( generic != NULL ) { + if (generic != NULL) { if (!NSK_JVMTI_VERIFY(jvmti_env->Deallocate((unsigned char *)generic))) { NSK_DISPLAY1(" Agent :: #error failed to Deallocate class signature = %s.", generic); nsk_jvmti_agentFailed(); @@ -110,18 +107,18 @@ JNIEXPORT void JNICALL callbackFieldAccess(jvmtiEnv *jvmti_env, className = NULL; generic = NULL; - if (redefineNumber != 0 ) { + if (redefineNumber != 0) { return; } - if ( ! NSK_JVMTI_VERIFY(jvmti_env->GetClassSignature(field_klass, &className, &generic)) ) { + if (!NSK_JVMTI_VERIFY(jvmti_env->GetClassSignature(field_klass, &className, &generic))) { NSK_DISPLAY0(" Agent :: Failed get class signature.\n"); nsk_jvmti_agentFailed(); } else { - if( (strcmp(className, CLASS_NAME) == 0 ) ) { + if((strcmp(className, CLASS_NAME) == 0)) { jvmtiThreadInfo info; nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti_env, field_klass, fileName) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti_env, field_klass, fileName) == NSK_TRUE) { NSK_DISPLAY0(" Agent :: Successfully redefined.\n"); redefineNumber++; } else { @@ -129,27 +126,27 @@ JNIEXPORT void JNICALL callbackFieldAccess(jvmtiEnv *jvmti_env, nsk_jvmti_agentFailed(); } NSK_DISPLAY0(" Agent :: Before attempting thread suspend.\n"); - if ( ! NSK_JVMTI_VERIFY(jvmti_env->GetThreadInfo(thread, &info))) { + if (!NSK_JVMTI_VERIFY(jvmti_env->GetThreadInfo(thread, &info))) { NSK_DISPLAY0(" Agent :: error getting thread info "); nsk_jvmti_agentFailed(); } else { NSK_DISPLAY1(" Agent :: Thread Name = %s .\n", info.name); } - if ( ! NSK_JVMTI_VERIFY(jvmti_env->SuspendThread(thread))) { + if (!NSK_JVMTI_VERIFY(jvmti_env->SuspendThread(thread))) { NSK_DISPLAY0(" Agent :: Failed to suspend thread.\n"); nsk_jvmti_agentFailed(); } } } - if ( className != NULL ) { + if (className != NULL) { if (!NSK_JVMTI_VERIFY(jvmti_env->Deallocate((unsigned char *)className))) { NSK_DISPLAY1(" Agent :: #error failed to Deallocate className = %s.", className); nsk_jvmti_agentFailed(); } } - if ( generic != NULL ) { + if (generic != NULL) { if (!NSK_JVMTI_VERIFY(jvmti_env->Deallocate((unsigned char *)generic))) { NSK_DISPLAY1(" Agent :: #error failed to Deallocate class signature = %s.", generic); nsk_jvmti_agentFailed(); @@ -169,7 +166,7 @@ JNIEXPORT jint JNI_OnLoad_hs204t003(JavaVM *jvm, char *options, void *reserved) } #endif jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { - if ( ! NSK_VERIFY ( JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1) ) ) { + if (!NSK_VERIFY (JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1))) { NSK_DISPLAY0("Agent :: Could not load JVMTI interface \n"); return JNI_ERR; } else { @@ -184,14 +181,14 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { caps.can_generate_field_access_events = 1; caps.can_pop_frame = 1; caps.can_suspend = 1; - if ( ! NSK_JVMTI_VERIFY(jvmti->AddCapabilities(&caps)) ) { + if (!NSK_JVMTI_VERIFY(jvmti->AddCapabilities(&caps))) { NSK_DISPLAY0(" Agent :: Failed add required capabilities\n."); return JNI_ERR; } memset(&eventCallbacks, 0, sizeof(eventCallbacks)); eventCallbacks.ClassPrepare = callbackClassPrepare; eventCallbacks.FieldAccess = callbackFieldAccess; - if (!NSK_JVMTI_VERIFY(jvmti->SetEventCallbacks(&eventCallbacks, sizeof(eventCallbacks) ) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti->SetEventCallbacks(&eventCallbacks, sizeof(eventCallbacks)))) { NSK_DISPLAY0(" Agent :: Error occured while setting event call back \n"); return JNI_ERR; } @@ -207,26 +204,26 @@ Java_nsk_jvmti_scenarios_hotswap_HS204_hs204t003_hs204t003_popFrame(JNIEnv * jni jboolean retvalue; jint state; retvalue = JNI_FALSE; - if (! NSK_JVMTI_VERIFY(jvmti->GetThreadState(thread, &state))) { + if (!NSK_JVMTI_VERIFY(jvmti->GetThreadState(thread, &state))) { NSK_DISPLAY0(" Agent :: Error getting thread state.\n"); nsk_jvmti_agentFailed(); } else { - if ( state & JVMTI_THREAD_STATE_SUSPENDED) { + if (state & JVMTI_THREAD_STATE_SUSPENDED) { NSK_DISPLAY0(" Agent :: Thread state = JVMTI_THREAD_STATE_SUSPENDED.\n"); - if ( ! NSK_JVMTI_VERIFY ( jvmti->PopFrame(thread) ) ) { + if (!NSK_JVMTI_VERIFY (jvmti->PopFrame(thread))) { NSK_DISPLAY0("#error Agent :: Jvmti failed to do popFrame.\n"); nsk_jvmti_agentFailed(); } else { - if ( ! NSK_JVMTI_VERIFY ( jvmti->ResumeThread(thread) ) ) { + if (!NSK_JVMTI_VERIFY (jvmti->ResumeThread(thread))) { NSK_DISPLAY0(" Agent :: Error occured in resuming a thread.\n"); nsk_jvmti_agentFailed(); } else { jfieldID fieldId = jni->GetStaticFieldID(watchFieldClass, FIELDNAME, TYPE); - if ( ! NSK_JNI_VERIFY(jni, fieldId != NULL ) ) { + if (!NSK_JNI_VERIFY(jni, fieldId != NULL)) { NSK_DISPLAY0(" Agent :: Failed to get FieldId before droping watchers.\n"); nsk_jvmti_agentFailed(); } else { - if ( ! NSK_JVMTI_VERIFY ( jvmti->ClearFieldAccessWatch(watchFieldClass, fieldId) ) ) { + if (!NSK_JVMTI_VERIFY (jvmti->ClearFieldAccessWatch(watchFieldClass, fieldId))) { NSK_DISPLAY0(" Agent :: failed to drop field watces.\n"); nsk_jvmti_agentFailed(); } else { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t004/hs204t004.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t004/hs204t004.cpp index 6b6591f1412..0d331285d9d 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t004/hs204t004.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS204/hs204t004/hs204t004.cpp @@ -67,7 +67,7 @@ callbackClassLoad(jvmtiEnv *jvmti_env, if (err == JVMTI_ERROR_NONE) { nsk_printf("Agent:: NO ERRORS FOUND \n"); err= jvmti->SetBreakpoint(method, start+1); - if ( err == JVMTI_ERROR_NONE) { + if (err == JVMTI_ERROR_NONE) { nsk_printf("Agent:: Breakpoint set \n"); } else { nsk_printf("Agent:: ***ERROR OCCURED ... in SET BREAK POINT ERROR \n"); @@ -97,7 +97,7 @@ void JNICALL callbackBreakpoint(jvmtiEnv *jvmti_env, /* Redefine the class loader and then pop the frame and resume the thread..*/ nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass( jvmti_env, clas, fileName) == NSK_TRUE) { + if (nsk_jvmti_redefineClass(jvmti_env, clas, fileName) == NSK_TRUE) { nsk_printf("\nMyClass :: Successfully redefined..\n"); } else { nsk_printf("\nMyClass :: Failed to redefine ..\n"); @@ -108,9 +108,9 @@ void JNICALL callbackBreakpoint(jvmtiEnv *jvmti_env, nsk_printf("Agent:: Succeded in suspending..\n"); } else if (err == JVMTI_ERROR_THREAD_SUSPENDED) { nsk_printf("Agent:: JVMTI_ERROR_THREAD_SUSPENDED \n"); - } else if ( err == JVMTI_ERROR_INVALID_THREAD) { + } else if (err == JVMTI_ERROR_INVALID_THREAD) { nsk_printf("Agent:: JVMTI_ERROR_INVALID_THREAD \n"); - } else if ( err == JVMTI_ERROR_THREAD_NOT_ALIVE) { + } else if (err == JVMTI_ERROR_THREAD_NOT_ALIVE) { nsk_printf("Agent:: JVMTI_ERROR_THREAD_NOT_ALIVE \n"); } else { nsk_printf(" Else error "); @@ -133,7 +133,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jint rc ; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { @@ -174,10 +174,10 @@ Java_nsk_jvmti_scenarios_hotswap_HS204_hs204t004_hs204t004_popFrame(JNIEnv * jni nsk_printf("Agent:: POPING THE FRAME....\n"); retvalue = JNI_FALSE; jvmti->GetThreadState(thread, &state); - if ( state & JVMTI_THREAD_STATE_IN_NATIVE) nsk_printf("JVMTI_THREAD_STATE_IN_NATIVE"); - if ( state & JVMTI_THREAD_STATE_INTERRUPTED) nsk_printf( "JVMTI_THREAD_STATE_INTERRUPTED"); - if ( state & JVMTI_THREAD_STATE_WAITING) nsk_printf(" JVMTI_THREAD_STATE_WAITING"); - if ( state & JVMTI_THREAD_STATE_SUSPENDED) { + if (state & JVMTI_THREAD_STATE_IN_NATIVE) nsk_printf("JVMTI_THREAD_STATE_IN_NATIVE"); + if (state & JVMTI_THREAD_STATE_INTERRUPTED) nsk_printf("JVMTI_THREAD_STATE_INTERRUPTED"); + if (state & JVMTI_THREAD_STATE_WAITING) nsk_printf(" JVMTI_THREAD_STATE_WAITING"); + if (state & JVMTI_THREAD_STATE_SUSPENDED) { nsk_printf("Agent:: Thread state .. JVMTI_THREAD_STATE_SUSPENDED \n"); err = jvmti->PopFrame(thread); if (err == JVMTI_ERROR_NONE) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t001/hs301t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t001/hs301t001.cpp index 465a3c17565..2212523c62a 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t001/hs301t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t001/hs301t001.cpp @@ -49,19 +49,19 @@ JNIEXPORT jint JNI_OnLoad_hs301t001(JavaVM *jvm, char *options, void *reserved) #endif jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf("Agent:: Agent_OnLoad .\n"); - if ( ! NSK_VERIFY ( JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1) ) ) { + if (!NSK_VERIFY (JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1))) { nsk_printf("Agent:: Could not load JVMTI interface.\n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options.\n"); return JNI_ERR; } memset(&caps, 0, sizeof(caps)); caps.can_redefine_classes = 1; - if (! NSK_JVMTI_VERIFY ( jvmti->AddCapabilities(&caps) )) { + if (!NSK_JVMTI_VERIFY (jvmti->AddCapabilities(&caps))) { nsk_printf(" Agent:: Error occured while adding capabilities.\n"); return JNI_ERR; } @@ -84,13 +84,13 @@ Java_nsk_jvmti_scenarios_hotswap_HS301_hs301t001_hs301t001_redefine(JNIEnv * jni redefineNumber=0; cls = jni->FindClass(SEARCH_NAME); - if (! NSK_JNI_VERIFY(jni, cls != NULL) ) { + if (!NSK_JNI_VERIFY(jni, cls != NULL)) { nsk_printf("Agent:: (*JNI)->FindClass(jni, %s) returns `null`.\n",SEARCH_NAME); return NSK_FALSE; } ret = JNI_FALSE; nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti, cls, fileName) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti, cls, fileName) == NSK_TRUE) { nsk_printf("Agent:: Redefine successful.\n"); ret = JNI_TRUE; } else { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t002/hs301t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t002/hs301t002.cpp index 742bd36b719..a13a19a7200 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t002/hs301t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t002/hs301t002.cpp @@ -52,18 +52,18 @@ JNIEXPORT jint JNI_OnLoad_hs301t002(JavaVM *jvm, char *options, void *reserved) #endif jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: VM Started.\n"); - if ( ! NSK_VERIFY ( JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1) ) ) { + if (!NSK_VERIFY (JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1))) { nsk_printf(" Agent ::Agent failed to get jvmti env.\n"); return JNI_ERR; } else { jvmtiCapabilities caps; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf(" Agent:: ## error agent Failed to parse options.\n"); return JNI_ERR; } memset(&caps, 0, sizeof(caps)); caps.can_redefine_classes = 1; - if ( ! NSK_JVMTI_VERIFY ( jvmti->AddCapabilities(&caps) ) ) { + if (!NSK_JVMTI_VERIFY (jvmti->AddCapabilities(&caps))) { nsk_printf(" Agent:: Error occured while adding capabilities.\n"); return JNI_ERR; } @@ -90,7 +90,7 @@ Java_nsk_jvmti_scenarios_hotswap_HS301_hs301t002_hs301t002_redefine(JNIEnv * jni } nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti, cls, fileName) == NSK_TRUE) { + if (nsk_jvmti_redefineClass(jvmti, cls, fileName) == NSK_TRUE) { nsk_printf("Agent:: MyClass :: Successfully redefined.\n"); ret = JNI_TRUE; } else { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t003/hs301t003.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t003/hs301t003.cpp index d0fe53d5244..afadfc9c271 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t003/hs301t003.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t003/hs301t003.cpp @@ -36,16 +36,16 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, jclass klass) { char * className; char * generic; - if ( ! NSK_JVMTI_VERIFY ( jvmti_env->GetClassSignature(klass, &className, &generic) ) ) { + if (!NSK_JVMTI_VERIFY (jvmti_env->GetClassSignature(klass, &className, &generic))) { nsk_printf(" Agent:: Error while getting ClassFileName Signature "); } else { - if (strcmp(className, CLASS_NAME ) == 0) { + if (strcmp(className, CLASS_NAME) == 0) { int redefineNumber =0; char fileName[512]; nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); nsk_jvmti_disableNotification(jvmti_env, - JVMTI_EVENT_CLASS_LOAD, NULL ); + JVMTI_EVENT_CLASS_LOAD, NULL); if (nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE) { nsk_printf("\n Redefine successful.\n"); } else { @@ -69,20 +69,20 @@ JNIEXPORT jint JNI_OnLoad_hs301t003(JavaVM *jvm, char *options, void *reserved) jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jvmtiEnv * jvmti; nsk_printf("Agent:: Agent_OnLoad.\n"); - if ( ! NSK_VERIFY ( JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1) ) ) { + if (!NSK_VERIFY (JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1))) { nsk_printf("Agent:: Could not load JVMTI interface.\n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options.\n"); return JNI_ERR; } memset(&caps, 0, sizeof(caps)); caps.can_redefine_classes = 1; caps.can_generate_all_class_hook_events=1; - if (! NSK_JVMTI_VERIFY ( jvmti->AddCapabilities(&caps) ) ) { + if (!NSK_JVMTI_VERIFY (jvmti->AddCapabilities(&caps))) { nsk_printf(" Agent:: Error occured while adding capabilities.\n"); return JNI_ERR; } @@ -92,7 +92,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back.\n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Agent:: Enabled notification.\n"); } else { nsk_printf(" Agent:: Failed to enable notification.\n"); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t004/hs301t004.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t004/hs301t004.cpp index 806986f870c..47aa5fad651 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t004/hs301t004.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t004/hs301t004.cpp @@ -37,17 +37,17 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, char * className; char * generic; int redefineNumber=0; - if (! NSK_JVMTI_VERIFY(jvmti_env->GetClassSignature(klass, &className, &generic)) ) { + if (!NSK_JVMTI_VERIFY(jvmti_env->GetClassSignature(klass, &className, &generic))) { nsk_printf(" Agent :: Error occured in getting class signature.\n"); return; } else { if (strcmp(className, CLASS_NAME) == 0) { int redefineNumber =0; char fileName[512]; - nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL ); + nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL); nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if (nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE) { nsk_printf("Agent:: Redefine successful.\n"); } else { nsk_printf("Agent:: Redefine failed.\n"); @@ -70,30 +70,30 @@ JNIEXPORT jint JNI_OnLoad_hs301t004(JavaVM *jvm, char *options, void *reserved) jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jvmtiEnv * jvmti; nsk_printf("Agent:: VM Started.\n"); - if (! NSK_VERIFY ( JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1) ) ) { + if (!NSK_VERIFY (JNI_OK == vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1))) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } memset(&caps, 0, sizeof(caps)); caps.can_redefine_classes = 1; caps.can_generate_all_class_hook_events=1; - if ( ! NSK_JVMTI_VERIFY (jvmti->AddCapabilities(&caps) )) { + if (!NSK_JVMTI_VERIFY (jvmti->AddCapabilities(&caps))) { nsk_printf(" Agent:: Error occured while adding capabilities.\n"); return JNI_ERR; } memset(&eventCallbacks, 0, sizeof(eventCallbacks)); eventCallbacks.ClassPrepare = &callbackClassPrepare; - if ( ! NSK_JVMTI_VERIFY(jvmti->SetEventCallbacks(&eventCallbacks, sizeof(eventCallbacks)) ) ) { + if (!NSK_JVMTI_VERIFY(jvmti->SetEventCallbacks(&eventCallbacks, sizeof(eventCallbacks)))) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Enabled notification.\n"); } else { nsk_printf(" Failed to enable notifications.\n"); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t005/hs301t005.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t005/hs301t005.cpp index 885c9a34513..a31b41f164d 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t005/hs301t005.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS301/hs301t005/hs301t005.cpp @@ -41,7 +41,7 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti, if (strcmp(className,CLASS_NAME) == 0) { int redefineNumber =0; char fileName[512]; - nsk_jvmti_disableNotification(jvmti, JVMTI_EVENT_CLASS_LOAD, NULL ); + nsk_jvmti_disableNotification(jvmti, JVMTI_EVENT_CLASS_LOAD, NULL); nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); if (nsk_jvmti_redefineClass(jvmti, klass, fileName) == NSK_TRUE) { nsk_printf("\n Redefine successful ..\n"); @@ -67,13 +67,13 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jvmtiEnv * jvmti; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -88,7 +88,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Enabled. noftification.."); } else { nsk_printf(" Failed to Enable .."); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t001/hs302t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t001/hs302t001.cpp index 36f1df03170..2efffed0f20 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t001/hs302t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t001/hs302t001.cpp @@ -39,11 +39,11 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, char * generic; int redefineNumber=0; jvmti_env->GetClassSignature(klass, &className, &generic); - if (strcmp(className,CLASS_NAME) == 0 ) { + if (strcmp(className,CLASS_NAME) == 0) { char fileName[512]; nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL ); - if ( nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE ) { + nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL); + if (nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE) { nsk_printf("Redefine successful ..\n"); } else { nsk_printf("# error :: Redefine failed..\n"); @@ -67,13 +67,13 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jvmtiEnv * jvmti; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -88,7 +88,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Enabled. noftification.."); } else { nsk_printf(" Failed to Enable .."); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t002/hs302t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t002/hs302t002.cpp index b142736ffc2..d60e3d5703d 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t002/hs302t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t002/hs302t002.cpp @@ -42,9 +42,9 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, jvmti_env->GetClassSignature(klass, &className, &generic); if (strcmp(className,CLASS_NAME) == 0) { char fileName[512]; - nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL ); + nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL); nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti_env, klass, fileName ) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE) { nsk_printf("Redefine successful ..\n"); } else { nsk_printf("Redefine failed .. \n"); @@ -69,14 +69,14 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if ( nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -94,8 +94,8 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, - NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, + NULL) == NSK_TRUE) { nsk_printf(" Enabled. noftification.."); } else { nsk_printf(" Failed to Enable .."); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t003/hs302t003.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t003/hs302t003.cpp index d78e2603cd5..4e8617a506f 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t003/hs302t003.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t003/hs302t003.cpp @@ -39,12 +39,12 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, char * generic; int redefineNumber=0; jvmti_env->GetClassSignature(klass, &className, &generic); - if ( strcmp(className,CLASS_NAME) == 0 ) { + if (strcmp(className,CLASS_NAME) == 0) { char fileName[512]; nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL ); - if ( nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE ) { + nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL); + if (nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE) { nsk_printf("Redefine successful ..\n"); } else { nsk_printf("Redefine failed .. \n"); @@ -70,14 +70,14 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -93,7 +93,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Enabled. noftification.."); } else { nsk_printf(" Failed to Enable .."); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t004/hs302t004.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t004/hs302t004.cpp index d95aa136543..077a620f909 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t004/hs302t004.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t004/hs302t004.cpp @@ -42,8 +42,8 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, char fileName[512]; nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL ); - if ( nsk_jvmti_redefineClass(jvmti_env, klass,fileName) == NSK_TRUE ) { + nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL); + if (nsk_jvmti_redefineClass(jvmti_env, klass,fileName) == NSK_TRUE) { nsk_printf("Redefine successful ..\n"); } else { nsk_printf("# error :: Redefine failed..\n"); @@ -67,13 +67,13 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jvmtiEnv * jvmti; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -88,7 +88,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Enabled. noftification.."); } else { nsk_printf(" Failed to Enable .."); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t005/hs302t005.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t005/hs302t005.cpp index 9197ca5b838..d936d8d564b 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t005/hs302t005.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t005/hs302t005.cpp @@ -42,10 +42,10 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, jvmti_env->GetClassSignature(klass, &className, &generic); if (strcmp(className,CLASS_NAME) == 0) { char fileName[512]; - nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL ); + nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL); nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti_env, klass,fileName) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti_env, klass,fileName) == NSK_TRUE) { nsk_printf("Redefine successful ..\n"); } else { nsk_printf("# error :: Redefine failed..\n"); @@ -69,13 +69,13 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jvmtiEnv * jvmti; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -90,7 +90,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Enabled. noftification.."); } else { nsk_printf(" Failed to Enable .."); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t006/hs302t006.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t006/hs302t006.cpp index f256562e61f..533c44a6911 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t006/hs302t006.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t006/hs302t006.cpp @@ -41,10 +41,10 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, jvmti_env->GetClassSignature(klass, &className, &generic); if (strcmp(className,CLASS_NAME) == 0) { char fileName[512]; - nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL ); + nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL); nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE) { nsk_printf("Redefine successful ..\n"); } else { nsk_printf("# error :: Redefine failed..\n"); @@ -68,13 +68,13 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jvmtiEnv * jvmti; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -89,7 +89,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Enabled. noftification.."); } else { nsk_printf(" Failed to Enable .."); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t007/hs302t007.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t007/hs302t007.cpp index a60aee8d5d4..773f2804929 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t007/hs302t007.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t007/hs302t007.cpp @@ -38,10 +38,10 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, jvmti_env->GetClassSignature(klass, &className, &generic); if (strcmp(className,CLASS_NAME) == 0) { char fileName[512]; - nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL ); + nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL); nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE) { nsk_printf("Redefine successful ..\n"); } else { nsk_printf("# error :: Redefine failed..\n"); @@ -65,13 +65,13 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jvmtiEnv * jvmti; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -86,7 +86,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Enabled. noftification.."); } else { nsk_printf(" Failed to Enable .."); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t008/hs302t008.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t008/hs302t008.cpp index accf937838b..f906131be3f 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t008/hs302t008.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t008/hs302t008.cpp @@ -41,10 +41,10 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, jvmti_env->GetClassSignature(klass, &className, &generic); if (strcmp(className,CLASS_NAME) == 0) { char fileName[512]; - nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL ); + nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL); nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE) { nsk_printf("Redefine successful ..\n"); } else { nsk_printf("# error :: Redefine failed..\n"); @@ -68,13 +68,13 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jvmtiEnv * jvmti; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -89,7 +89,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Enabled. noftification.."); } else { nsk_printf(" Failed to Enable .."); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t009/hs302t009.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t009/hs302t009.cpp index 100ffa8b5a3..f60cccfb8f2 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t009/hs302t009.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t009/hs302t009.cpp @@ -42,10 +42,10 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, if (strcmp(className,CLASS_NAME) == 0) { char fileName[512]; - nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL ); + nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL); nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti_env, klass,fileName) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti_env, klass,fileName) == NSK_TRUE) { nsk_printf("Redefine successful ..\n"); } else { nsk_printf("# error :: Redefine failed..\n"); @@ -68,13 +68,13 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jvmtiEnv * jvmti; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -89,7 +89,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Enabled. noftification.."); } else { nsk_printf(" Failed to Enable .."); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t010/hs302t010.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t010/hs302t010.cpp index 7af2220fea5..009efbf1ce8 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t010/hs302t010.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t010/hs302t010.cpp @@ -41,10 +41,10 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, jvmti_env->GetClassSignature(klass, &className, &generic); if (strcmp(className,CLASS_NAME) == 0) { char fileName[512]; - nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL ); + nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL); nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE) { nsk_printf("Redefine successful ..\n"); } else { nsk_printf("# error :: Redefine failed..\n"); @@ -67,13 +67,13 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jvmtiEnv * jvmti; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -88,7 +88,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Enabled. noftification.."); } else { nsk_printf(" Failed to Enable .."); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t011/hs302t011.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t011/hs302t011.cpp index e470adc37d0..3f088cb1558 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t011/hs302t011.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t011/hs302t011.cpp @@ -41,10 +41,10 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, jvmti_env->GetClassSignature(klass, &className, &generic); if (strcmp(className,CLASS_NAME) == 0) { char fileName[512]; - nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL ); + nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL); nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE) { nsk_printf("Redefine successful ..\n"); } else { nsk_printf("# error :: Redefine failed..\n"); @@ -68,13 +68,13 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jvmtiEnv * jvmti; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -89,7 +89,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Enabled. noftification.."); } else { nsk_printf(" Failed to Enable .."); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t012/hs302t012.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t012/hs302t012.cpp index ab78062c98e..97c957b5821 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t012/hs302t012.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/hotswap/HS302/hs302t012/hs302t012.cpp @@ -43,10 +43,10 @@ void JNICALL callbackClassPrepare(jvmtiEnv *jvmti_env, jvmti_env->GetClassSignature(klass, &className, &generic); if (strcmp(className,CLASS_NAME) == 0) { char fileName[512]; - nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL ); + nsk_jvmti_disableNotification(jvmti_env, JVMTI_EVENT_CLASS_PREPARE, NULL); nsk_jvmti_getFileName(redefineNumber, FILE_NAME, fileName, sizeof(fileName)/sizeof(char)); - if ( nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE ) { + if (nsk_jvmti_redefineClass(jvmti_env, klass, fileName) == NSK_TRUE) { nsk_printf("Redefine successful ..\n"); } else { nsk_printf("# error :: Redefine failed..\n"); @@ -70,13 +70,13 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { jint rc ; nsk_printf("Agent:: VM.. Started..\n"); rc=vm->GetEnv((void **)&jvmti, JVMTI_VERSION_1_1); - if ( rc!= JNI_OK ) { + if (rc!= JNI_OK) { nsk_printf("Agent:: Could not load JVMTI interface \n"); return JNI_ERR; } else { jvmtiCapabilities caps; jvmtiEventCallbacks eventCallbacks; - if (nsk_jvmti_parseOptions(options) == NSK_FALSE ) { + if (nsk_jvmti_parseOptions(options) == NSK_FALSE) { nsk_printf("# error agent Failed to parse options \n"); return JNI_ERR; } @@ -91,7 +91,7 @@ jint Agent_Initialize(JavaVM *vm, char *options, void *reserved) { nsk_printf(" Agent:: Error occured while setting event call back \n"); return JNI_ERR; } - if ( nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE ) { + if (nsk_jvmti_enableNotification(jvmti, JVMTI_EVENT_CLASS_PREPARE, NULL) == NSK_TRUE) { nsk_printf(" Enabled. noftification.."); } else { nsk_printf(" Failed to Enable .."); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/sampling/SP02/sp02t003/sp02t003.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/sampling/SP02/sp02t003/sp02t003.cpp index 363594d72a5..6ee9d8582d9 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/sampling/SP02/sp02t003/sp02t003.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/sampling/SP02/sp02t003/sp02t003.cpp @@ -327,7 +327,7 @@ static int checkThreads(int suspended, const char* kind) { (void*)frameStack[j].method, (void*)qMethod); nsk_jvmti_setFailStatus(); } - if ( (suspended == NSK_TRUE) && (frameStack[j].location != qLocation) ) { + if ((suspended == NSK_TRUE) && (frameStack[j].location != qLocation)) { NSK_COMPLAIN6("Different location in stack frame #%d for %s thread #%d (%s):\n" "# GetStackTrace(): %ld\n" "# GetFrameLocation(): %ld\n", diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref001/followref001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref001/followref001.cpp index 797dbc73b6b..16db09a6f47 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref001/followref001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref001/followref001.cpp @@ -681,7 +681,7 @@ jint JNICALL primitiveFieldCallback( ref_kind_str[reference_kind], (long) class_tag, (long) DEREF(tag_ptr), - (int ) value_type); + (int) value_type); fflush(0); return 0; } /* primitiveFieldCallback */ @@ -700,8 +700,8 @@ jint JNICALL arrayPrimitiveValueCallback( " tag=%-3ld, len=%d, type=%c\n", (long) class_tag, (long) DEREF(tag_ptr), - (int ) element_count, - (int ) element_type); + (int) element_count, + (int) element_type); fflush(0); return 0; } /* arrayPrimitiveValueCallback */ @@ -718,7 +718,7 @@ jint JNICALL stringPrimitiveValueCallback( printf("stringPrimitiveValueCallback: class_tag=%-3ld, tag=%-3ld, len=%d\n", (long) class_tag, (long) DEREF(tag_ptr), - (int ) value_length); + (int) value_length); fflush(0); return 0; } /* stringPrimitiveValueCallback */ diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref002/followref002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref002/followref002.cpp index 95d7642fb6c..ee1eff158d6 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref002/followref002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref002/followref002.cpp @@ -457,7 +457,7 @@ jint JNICALL heapReferenceCallback( (long) tag, (long) size, (long) ref_tag, - (int ) referrer_index); + (int) referrer_index); fflush(0); if (tag_ptr == NULL) { @@ -557,7 +557,7 @@ jint JNICALL primitiveFieldCallback( ref_kind_str[reference_kind], (long) class_tag, (long) DEREF(tag_ptr), - (int ) value_type); + (int) value_type); fflush(0); return 0; } @@ -574,8 +574,8 @@ jint JNICALL arrayPrimitiveValueCallback( printf(" arrayPrimitiveValueCallback: class_tag=%-3ld, tag=%-3ld, len=%d, type=%c\n", (long) class_tag, (long) DEREF(tag_ptr), - (int ) element_count, - (int ) element_type); + (int) element_count, + (int) element_type); fflush(0); return 0; } @@ -591,7 +591,7 @@ jint JNICALL stringPrimitiveValueCallback( printf("stringPrimitiveValueCallback: class_tag=%-3ld, tag=%-3ld, len=%d\n", (long) class_tag, (long) DEREF(tag_ptr), - (int ) value_length); + (int) value_length); fflush(0); return 0; } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref003/followref003.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref003/followref003.cpp index 4b324d758dd..d6cb3a4607a 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref003/followref003.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref003/followref003.cpp @@ -661,13 +661,13 @@ jint JNICALL heapReferenceCallback( (long) class_tag, (long) tag, (long) size, - (int ) length, + (int) length, ref_tag, (long) thr_tag, thr_id, method, (long) location, - (int ) index); + (int) index); fflush(0); if (tag_ptr == NULL) { @@ -842,7 +842,7 @@ jint JNICALL primitiveFieldCallback ref_kind_str[ref_kind], (long) class_tag, (long) DEREF(tag_ptr), - (int ) value_type); + (int) value_type); fflush(0); return 0; } @@ -854,8 +854,8 @@ jint JNICALL arrayPrimitiveValueCallback printf(" arrayPrimitiveValueCallback: class_tag=%-3ld, tag=%-3ld, len=%d, type=%c\n", (long) class_tag, (long) DEREF(tag_ptr), - (int ) element_count, - (int ) element_type); + (int) element_count, + (int) element_type); fflush(0); return 0; } @@ -867,7 +867,7 @@ jint JNICALL stringPrimitiveValueCallback printf("stringPrimitiveValueCallback: class_tag=%-3ld, tag=%-3ld, len=%d\n", (long) class_tag, (long) DEREF(tag_ptr), - (int ) value_length); + (int) value_length); fflush(0); return 0; } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref004/followref004.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref004/followref004.cpp index 579cc20072b..a1831044057 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref004/followref004.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref004/followref004.cpp @@ -84,7 +84,7 @@ jint JNICALL primitiveFieldCallback( g_refKindStr[reference_kind], (long) class_tag, (long) DEREF(tag_ptr), - (int ) value_type); + (int) value_type); fflush(0); @@ -109,8 +109,8 @@ jint JNICALL arrayPrimitiveValueCallback( printf(" arrayPrimitiveValueCallback: class_tag=%-3ld, tag=%-3ld, len=%d, type=%c\n", (long) class_tag, (long) DEREF(tag_ptr), - (int ) element_count, - (int ) element_type); + (int) element_count, + (int) element_type); fflush(0); markTagVisited(DEREF(tag_ptr)); @@ -131,7 +131,7 @@ jint JNICALL stringPrimitiveValueCallback( printf("stringPrimitiveValueCallback: class_tag=%-3ld, tag=%-3ld, len=%d\n", (long) class_tag, (long) DEREF(tag_ptr), - (int ) value_length); + (int) value_length); fflush(0); markTagVisited(DEREF(tag_ptr)); @@ -146,16 +146,16 @@ static void createGlobalRefs(JNIEnv * jni) { jclass klass; - if ( ! NSK_JNI_VERIFY(jni, (klass = jni->FindClass(JAVA_LANG_STRING_CLASS_NAME)) != NULL) ) { + if (!NSK_JNI_VERIFY(jni, (klass = jni->FindClass(JAVA_LANG_STRING_CLASS_NAME)) != NULL)) { nsk_jvmti_setFailStatus(); return; } - if ( ! NSK_JNI_VERIFY(jni, (g_jniGlobalRef = jni->NewGlobalRef(klass)) != NULL) ) { + if (!NSK_JNI_VERIFY(jni, (g_jniGlobalRef = jni->NewGlobalRef(klass)) != NULL)) { nsk_jvmti_setFailStatus(); } - if ( ! NSK_JNI_VERIFY(jni, (g_jniWeakGlobalRef = jni->NewWeakGlobalRef(klass)) != NULL) ) { + if (!NSK_JNI_VERIFY(jni, (g_jniWeakGlobalRef = jni->NewWeakGlobalRef(klass)) != NULL)) { nsk_jvmti_setFailStatus(); } @@ -185,7 +185,7 @@ static void JNICALL agentProc(jvmtiEnv* jvmti, JNIEnv* jni, void* arg) &g_heapCallbacks, (const void *) &g_fakeUserData); - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_NONE) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_NONE)) { nsk_jvmti_setFailStatus(); } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref005/followref005.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref005/followref005.cpp index 35f8cf0dd3f..52b313b51c4 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref005/followref005.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref005/followref005.cpp @@ -51,7 +51,7 @@ agentProc(jvmtiEnv* jvmti, JNIEnv* jni, void* arg) { &g_wrongHeapCallbacks, (const void *) &g_fakeUserData); - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_MUST_POSSESS_CAPABILITY ) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_MUST_POSSESS_CAPABILITY)) { NSK_COMPLAIN1("FollowReferences() returned %i", retCode); nsk_jvmti_setFailStatus(); } @@ -61,28 +61,28 @@ agentProc(jvmtiEnv* jvmti, JNIEnv* jni, void* arg) { &g_wrongHeapCallbacks, (const void *) &g_fakeUserData); - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_MUST_POSSESS_CAPABILITY ) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_MUST_POSSESS_CAPABILITY)) { NSK_COMPLAIN1("IterateThroughHeap() returned %i", retCode); nsk_jvmti_setFailStatus(); } retCode = jvmti->GetTag((jobject) &g_wrongHeapCallbacks, &tag); - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_MUST_POSSESS_CAPABILITY ) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_MUST_POSSESS_CAPABILITY)) { NSK_COMPLAIN1("GetTag() returned %i", retCode); nsk_jvmti_setFailStatus(); } retCode = jvmti->SetTag((jobject) &g_wrongHeapCallbacks, tag); - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_MUST_POSSESS_CAPABILITY ) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_MUST_POSSESS_CAPABILITY)) { NSK_COMPLAIN1("SetTag() returned %i", retCode); nsk_jvmti_setFailStatus(); } retCode = jvmti->GetObjectsWithTags(1, &tag, &cnt, &pObjs, &pObjTags); - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_MUST_POSSESS_CAPABILITY ) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_MUST_POSSESS_CAPABILITY)) { NSK_COMPLAIN1("GetObjectsWithTags() returned %i", retCode); nsk_jvmti_setFailStatus(); } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref006/followref006.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref006/followref006.cpp index 054004c2190..cabd4696827 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref006/followref006.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/unit/FollowReferences/followref006/followref006.cpp @@ -55,7 +55,7 @@ static void verifyReturnCodes(JNIEnv* jni, jvmtiEnv* jvmti) &g_wrongHeapCallbacks, (const void *) &g_fakeUserData); - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_INVALID_CLASS ) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_INVALID_CLASS)) { nsk_jvmti_setFailStatus(); } @@ -80,7 +80,7 @@ static void verifyReturnCodes(JNIEnv* jni, jvmtiEnv* jvmti) (const void *) &g_fakeUserData); // Accept both JVMTI_ERROR_INVALID_OBJECT and JVMTI_ERROR_NONE - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_INVALID_OBJECT || retCode == JVMTI_ERROR_NONE ) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_INVALID_OBJECT || retCode == JVMTI_ERROR_NONE)) { nsk_jvmti_setFailStatus(); } @@ -92,7 +92,7 @@ static void verifyReturnCodes(JNIEnv* jni, jvmtiEnv* jvmti) NULL, (const void *) &g_fakeUserData); - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_NULL_POINTER ) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_NULL_POINTER)) { nsk_jvmti_setFailStatus(); } @@ -101,7 +101,7 @@ static void verifyReturnCodes(JNIEnv* jni, jvmtiEnv* jvmti) retCode = jvmti->GetTag((jobject) &g_wrongHeapCallbacks, /* invalid inital object */ &tag); - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_INVALID_OBJECT ) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_INVALID_OBJECT)) { nsk_jvmti_setFailStatus(); } @@ -109,7 +109,7 @@ static void verifyReturnCodes(JNIEnv* jni, jvmtiEnv* jvmti) retCode = jvmti->GetTag(NULL, &tag); - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_INVALID_OBJECT ) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_INVALID_OBJECT)) { nsk_jvmti_setFailStatus(); } @@ -117,7 +117,7 @@ static void verifyReturnCodes(JNIEnv* jni, jvmtiEnv* jvmti) retCode = jvmti->GetTag((jobject) &g_wrongHeapCallbacks, NULL); - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_NULL_POINTER ) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_NULL_POINTER)) { nsk_jvmti_setFailStatus(); } @@ -127,7 +127,7 @@ static void verifyReturnCodes(JNIEnv* jni, jvmtiEnv* jvmti) retCode = jvmti->SetTag((jobject) &g_wrongHeapCallbacks, /* invalid inital object */ tag); - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_INVALID_OBJECT ) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_INVALID_OBJECT)) { nsk_jvmti_setFailStatus(); } @@ -135,7 +135,7 @@ static void verifyReturnCodes(JNIEnv* jni, jvmtiEnv* jvmti) retCode = jvmti->GetTag(NULL, &tag); - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_INVALID_OBJECT ) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_INVALID_OBJECT)) { nsk_jvmti_setFailStatus(); } @@ -162,7 +162,7 @@ static void checkNoObjIterated(JNIEnv* jni, jvmtiEnv* jvmti, const char * szClas &g_wrongHeapCallbacks, (const void *) &g_fakeUserData); - if ( ! NSK_VERIFY(retCode == JVMTI_ERROR_NONE ) ) { + if (!NSK_VERIFY(retCode == JVMTI_ERROR_NONE)) { nsk_jvmti_setFailStatus(); } From fb3ab945a6cb98e87f46fac5bafa899630a90ecb Mon Sep 17 00:00:00 2001 From: Dean Long Date: Thu, 25 Oct 2018 09:20:54 -0700 Subject: [PATCH 16/84] 8212978: Add RedefineMethodUsedByMultipleMethodHandles.java to problem list Reviewed-by: kvn --- test/hotspot/jtreg/ProblemList-graal.txt | 2 ++ 1 file changed, 2 insertions(+) diff --git a/test/hotspot/jtreg/ProblemList-graal.txt b/test/hotspot/jtreg/ProblemList-graal.txt index 775962f9166..f1c54cadafc 100644 --- a/test/hotspot/jtreg/ProblemList-graal.txt +++ b/test/hotspot/jtreg/ProblemList-graal.txt @@ -43,6 +43,8 @@ compiler/intrinsics/mathexact/LongMulOverflowTest.java 8196568 generi compiler/jvmci/SecurityRestrictionsTest.java 8181837 generic-all +compiler/jsr292/RedefineMethodUsedByMultipleMethodHandles.java 8204521 windows-all + compiler/unsafe/UnsafeGetConstantField.java 8181833 generic-all compiler/unsafe/UnsafeGetStableArrayElement.java 8181833 generic-all compiler/unsafe/UnsafeOffHeapBooleanTest.java 8181833 generic-all From 7727e4ca2f21aabcbc2f4ad19a75379a41e89fdc Mon Sep 17 00:00:00 2001 From: Sean Mullan Date: Thu, 25 Oct 2018 13:55:28 -0400 Subject: [PATCH 17/84] 8211883: Disable anon and NULL cipher suites Reviewed-by: jnimeh --- .../share/conf/security/java.security | 2 +- .../net/ssl/SSLSession/JSSERenegotiate.java | 7 ++- .../ssl/ciphersuites/DisabledAlgorithms.java | 43 +++++++++++++++---- .../CustomizedCipherSuites.java | 27 +++++++----- 4 files changed, 57 insertions(+), 22 deletions(-) diff --git a/src/java.base/share/conf/security/java.security b/src/java.base/share/conf/security/java.security index 478339ad8de..8f85a394d87 100644 --- a/src/java.base/share/conf/security/java.security +++ b/src/java.base/share/conf/security/java.security @@ -676,7 +676,7 @@ jdk.jar.disabledAlgorithms=MD2, MD5, RSA keySize < 1024, \ # Example: # jdk.tls.disabledAlgorithms=MD5, SSLv3, DSA, RSA keySize < 2048 jdk.tls.disabledAlgorithms=SSLv3, RC4, DES, MD5withRSA, DH keySize < 1024, \ - EC keySize < 224, 3DES_EDE_CBC + EC keySize < 224, 3DES_EDE_CBC, anon, NULL # # Legacy algorithms for Secure Socket Layer/Transport Layer Security (SSL/TLS) diff --git a/test/jdk/javax/net/ssl/SSLSession/JSSERenegotiate.java b/test/jdk/javax/net/ssl/SSLSession/JSSERenegotiate.java index 40617bfd321..435dd2345d6 100644 --- a/test/jdk/javax/net/ssl/SSLSession/JSSERenegotiate.java +++ b/test/jdk/javax/net/ssl/SSLSession/JSSERenegotiate.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2018, 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,6 +37,7 @@ import java.io.*; import java.net.*; +import java.security.Security; import javax.net.ssl.*; public class JSSERenegotiate { @@ -190,6 +191,10 @@ public class JSSERenegotiate { volatile Exception clientException = null; public static void main(String[] args) throws Exception { + // reset the security property to make sure that the cipher suites + // used in this test are not disabled + Security.setProperty("jdk.tls.disabledAlgorithms", ""); + String keyFilename = System.getProperty("test.src", "./") + "/" + pathToStores + "/" + keyStoreFile; diff --git a/test/jdk/javax/net/ssl/ciphersuites/DisabledAlgorithms.java b/test/jdk/javax/net/ssl/ciphersuites/DisabledAlgorithms.java index e42c9915f79..7bb3e2c8d2b 100644 --- a/test/jdk/javax/net/ssl/ciphersuites/DisabledAlgorithms.java +++ b/test/jdk/javax/net/ssl/ciphersuites/DisabledAlgorithms.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2018, 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 - * @bug 8076221 + * @bug 8076221 8211883 * @summary Check if weak cipher suites are disabled * @modules jdk.crypto.ec * @run main/othervm DisabledAlgorithms default @@ -60,9 +60,9 @@ public class DisabledAlgorithms { System.getProperty("test.src", "./") + "/" + pathToStores + "/" + trustStoreFile; - // supported RC4 cipher suites + // supported RC4, NULL, and anon cipher suites // it does not contain KRB5 cipher suites because they need a KDC - private static final String[] rc4_ciphersuites = new String[] { + private static final String[] rc4_null_anon_ciphersuites = new String[] { "TLS_ECDHE_ECDSA_WITH_RC4_128_SHA", "TLS_ECDHE_RSA_WITH_RC4_128_SHA", "SSL_RSA_WITH_RC4_128_SHA", @@ -70,7 +70,31 @@ public class DisabledAlgorithms { "TLS_ECDH_RSA_WITH_RC4_128_SHA", "SSL_RSA_WITH_RC4_128_MD5", "TLS_ECDH_anon_WITH_RC4_128_SHA", - "SSL_DH_anon_WITH_RC4_128_MD5" + "SSL_DH_anon_WITH_RC4_128_MD5", + "SSL_RSA_WITH_NULL_MD5", + "SSL_RSA_WITH_NULL_SHA", + "TLS_RSA_WITH_NULL_SHA256", + "TLS_ECDH_ECDSA_WITH_NULL_SHA", + "TLS_ECDHE_ECDSA_WITH_NULL_SHA", + "TLS_ECDH_RSA_WITH_NULL_SHA", + "TLS_ECDHE_RSA_WITH_NULL_SHA", + "TLS_ECDH_anon_WITH_NULL_SHA", + "SSL_DH_anon_EXPORT_WITH_DES40_CBC_SHA", + "SSL_DH_anon_EXPORT_WITH_RC4_40_MD5", + "SSL_DH_anon_WITH_3DES_EDE_CBC_SHA", + "SSL_DH_anon_WITH_DES_CBC_SHA", + "SSL_DH_anon_WITH_RC4_128_MD5", + "TLS_DH_anon_WITH_AES_128_CBC_SHA", + "TLS_DH_anon_WITH_AES_128_CBC_SHA256", + "TLS_DH_anon_WITH_AES_128_GCM_SHA256", + "TLS_DH_anon_WITH_AES_256_CBC_SHA", + "TLS_DH_anon_WITH_AES_256_CBC_SHA256", + "TLS_DH_anon_WITH_AES_256_GCM_SHA384", + "TLS_ECDH_anon_WITH_3DES_EDE_CBC_SHA", + "TLS_ECDH_anon_WITH_AES_128_CBC_SHA", + "TLS_ECDH_anon_WITH_AES_256_CBC_SHA", + "TLS_ECDH_anon_WITH_NULL_SHA", + "TLS_ECDH_anon_WITH_RC4_128_SHA" }; public static void main(String[] args) throws Exception { @@ -89,8 +113,9 @@ public class DisabledAlgorithms { System.out.println("jdk.tls.disabledAlgorithms = " + Security.getProperty("jdk.tls.disabledAlgorithms")); - // check if RC4 cipher suites can't be used by default - checkFailure(rc4_ciphersuites); + // check if RC4, NULL, and anon cipher suites + // can't be used by default + checkFailure(rc4_null_anon_ciphersuites); break; case "empty": // reset jdk.tls.disabledAlgorithms @@ -98,9 +123,9 @@ public class DisabledAlgorithms { System.out.println("jdk.tls.disabledAlgorithms = " + Security.getProperty("jdk.tls.disabledAlgorithms")); - // check if RC4 cipher suites can be used + // check if RC4, NULL, and anon cipher suites can be used // if jdk.tls.disabledAlgorithms is empty - checkSuccess(rc4_ciphersuites); + checkSuccess(rc4_null_anon_ciphersuites); break; default: throw new RuntimeException("Wrong parameter: " + args[0]); diff --git a/test/jdk/sun/security/ssl/SSLContextImpl/CustomizedCipherSuites.java b/test/jdk/sun/security/ssl/SSLContextImpl/CustomizedCipherSuites.java index dee2eb6352f..3b55f146bea 100644 --- a/test/jdk/sun/security/ssl/SSLContextImpl/CustomizedCipherSuites.java +++ b/test/jdk/sun/security/ssl/SSLContextImpl/CustomizedCipherSuites.java @@ -74,6 +74,7 @@ * TLS_ECDH_anon_WITH_AES_128_CBC_SHA */ +import java.security.Security; import javax.net.ssl.*; /** @@ -90,14 +91,18 @@ public class CustomizedCipherSuites { private static boolean isClientMode; private static String enabledCipherSuite; - private static String disabledCipherSuite; + private static String notEnabledCipherSuite; public static void main(String[] args) throws Exception { + // reset the security property to make sure the cipher suites + // used in this test are not disabled + Security.setProperty("jdk.tls.disabledAlgorithms", ""); + contextProtocol = trimQuotes(args[0]); isClientMode = Boolean.parseBoolean(args[1]); enabledCipherSuite = trimQuotes(args[2]); - disabledCipherSuite = trimQuotes(args[3]); + notEnabledCipherSuite = trimQuotes(args[3]); // // Create instance of SSLContext with the specified protocol. @@ -206,8 +211,8 @@ public class CustomizedCipherSuites { isMatch = true; } - if (!disabledCipherSuite.isEmpty() && - cipher.equals(disabledCipherSuite)) { + if (!notEnabledCipherSuite.isEmpty() && + cipher.equals(notEnabledCipherSuite)) { isBroken = true; } } @@ -219,7 +224,7 @@ public class CustomizedCipherSuites { if (isBroken) { throw new Exception( - "Cipher suite " + disabledCipherSuite + " should be disabled"); + "Cipher suite " + notEnabledCipherSuite + " should not be enabled"); } } @@ -231,7 +236,7 @@ public class CustomizedCipherSuites { } boolean hasEnabledCipherSuite = enabledCipherSuite.isEmpty(); - boolean hasDisabledCipherSuite = disabledCipherSuite.isEmpty(); + boolean hasNotEnabledCipherSuite = notEnabledCipherSuite.isEmpty(); for (String cipher : ciphers) { System.out.println("\tsupported cipher suite " + cipher); if (!enabledCipherSuite.isEmpty() && @@ -239,9 +244,9 @@ public class CustomizedCipherSuites { hasEnabledCipherSuite = true; } - if (!disabledCipherSuite.isEmpty() && - cipher.equals(disabledCipherSuite)) { - hasDisabledCipherSuite = true; + if (!notEnabledCipherSuite.isEmpty() && + cipher.equals(notEnabledCipherSuite)) { + hasNotEnabledCipherSuite = true; } } @@ -250,9 +255,9 @@ public class CustomizedCipherSuites { "Cipher suite " + enabledCipherSuite + " should be supported"); } - if (!hasDisabledCipherSuite) { + if (!hasNotEnabledCipherSuite) { throw new Exception( - "Cipher suite " + disabledCipherSuite + " should be supported"); + "Cipher suite " + notEnabledCipherSuite + " should not be enabled"); } } From 85598bc90f2c8e6addb337ec1f971065fa99b364 Mon Sep 17 00:00:00 2001 From: Mandy Chung Date: Thu, 25 Oct 2018 10:56:45 -0700 Subject: [PATCH 18/84] 8212948: Remove unused jdk.internal.misc.VMNotification interface Reviewed-by: alanb --- .../jdk/internal/misc/VMNotification.java | 39 ------------------- 1 file changed, 39 deletions(-) delete mode 100644 src/java.base/share/classes/jdk/internal/misc/VMNotification.java diff --git a/src/java.base/share/classes/jdk/internal/misc/VMNotification.java b/src/java.base/share/classes/jdk/internal/misc/VMNotification.java deleted file mode 100644 index 3c7ad9b4891..00000000000 --- a/src/java.base/share/classes/jdk/internal/misc/VMNotification.java +++ /dev/null @@ -1,39 +0,0 @@ -/* - * Copyright (c) 1996, 2004, 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.internal.misc; - -/** @deprecated */ -@Deprecated -public interface VMNotification { - - // when the vm switches allocation states, we get notified - // (possible semantics: if the state changes while in this - // notification, don't recursively notify). - // oldState and newState may be the same if we are just releasing - // suspended threads. - void newAllocState(int oldState, int newState, - boolean threadsSuspended); -} From d523a17e802fc16e99e84f48346d3e648a5c0934 Mon Sep 17 00:00:00 2001 From: Mandy Chung Date: Thu, 25 Oct 2018 10:57:42 -0700 Subject: [PATCH 19/84] 8212795: ThreadInfoCompositeData.toCompositeData fails to map ThreadInfo to CompositeData Reviewed-by: dfuchs --- .../sun/management/LockInfoCompositeData.java | 19 ++---- .../management/MonitorInfoCompositeData.java | 39 ++++------- .../StackTraceElementCompositeData.java | 38 ++++------- .../management/ThreadInfoCompositeData.java | 67 +++++++------------ .../ThreadInfoCompositeData.java | 48 +++++++------ 5 files changed, 85 insertions(+), 126 deletions(-) diff --git a/src/java.management/share/classes/sun/management/LockInfoCompositeData.java b/src/java.management/share/classes/sun/management/LockInfoCompositeData.java index 3f34a9c8859..b62e236a3da 100644 --- a/src/java.management/share/classes/sun/management/LockInfoCompositeData.java +++ b/src/java.management/share/classes/sun/management/LockInfoCompositeData.java @@ -26,6 +26,7 @@ package sun.management; import java.lang.management.LockInfo; +import java.util.Map; import javax.management.openmbean.CompositeType; import javax.management.openmbean.CompositeData; import javax.management.openmbean.CompositeDataSupport; @@ -57,17 +58,13 @@ public class LockInfoCompositeData extends LazyCompositeData { } protected CompositeData getCompositeData() { - // CONTENTS OF THIS ARRAY MUST BE SYNCHRONIZED WITH - // LOCK_INFO_ATTRIBUTES! - final Object[] lockInfoItemValues = { - new String(lock.getClassName()), - lock.getIdentityHashCode(), - }; + Map items = Map.of( + CLASS_NAME, lock.getClassName(), + IDENTITY_HASH_CODE, lock.getIdentityHashCode() + ); try { - return new CompositeDataSupport(LOCK_INFO_COMPOSITE_TYPE, - LOCK_INFO_ATTRIBUTES, - lockInfoItemValues); + return new CompositeDataSupport(LOCK_INFO_COMPOSITE_TYPE, items); } catch (OpenDataException e) { // Should never reach here throw Util.newException(e); @@ -91,10 +88,6 @@ public class LockInfoCompositeData extends LazyCompositeData { private static final String CLASS_NAME = "className"; private static final String IDENTITY_HASH_CODE = "identityHashCode"; - private static final String[] LOCK_INFO_ATTRIBUTES = { - CLASS_NAME, - IDENTITY_HASH_CODE, - }; /* * Returns a LockInfo object mapped from the given CompositeData. diff --git a/src/java.management/share/classes/sun/management/MonitorInfoCompositeData.java b/src/java.management/share/classes/sun/management/MonitorInfoCompositeData.java index 2b0199bfdf1..d10e07d6e31 100644 --- a/src/java.management/share/classes/sun/management/MonitorInfoCompositeData.java +++ b/src/java.management/share/classes/sun/management/MonitorInfoCompositeData.java @@ -26,6 +26,8 @@ package sun.management; import java.lang.management.MonitorInfo; +import java.util.HashMap; +import java.util.Map; import javax.management.openmbean.CompositeType; import javax.management.openmbean.CompositeData; import javax.management.openmbean.CompositeDataSupport; @@ -54,31 +56,18 @@ public class MonitorInfoCompositeData extends LazyCompositeData { } protected CompositeData getCompositeData() { - // CONTENTS OF THIS ARRAY MUST BE SYNCHRONIZED WITH - // MONITOR_INFO_ATTRIBUTES! - - int len = MONITOR_INFO_ATTRIBUTES.length; - Object[] values = new Object[len]; - CompositeData li = LockInfoCompositeData.toCompositeData(lock); - - for (int i = 0; i < len; i++) { - String item = MONITOR_INFO_ATTRIBUTES[i]; - if (item.equals(LOCKED_STACK_FRAME)) { - StackTraceElement ste = lock.getLockedStackFrame(); - values[i] = (ste != null ? StackTraceElementCompositeData. - toCompositeData(ste) - : null); - } else if (item.equals(LOCKED_STACK_DEPTH)) { - values[i] = lock.getLockedStackDepth(); - } else { - values[i] = li.get(item); - } - } + StackTraceElement ste = lock.getLockedStackFrame(); + CompositeData steCData = ste != null ? StackTraceElementCompositeData.toCompositeData(ste) + : null; + // values may be null; can't use Map.of + Map items = new HashMap<>(); + items.put(CLASS_NAME, lock.getClassName()); + items.put(IDENTITY_HASH_CODE, lock.getIdentityHashCode()); + items.put(LOCKED_STACK_FRAME, steCData); + items.put(LOCKED_STACK_DEPTH, lock.getLockedStackDepth()); try { - return new CompositeDataSupport(MONITOR_INFO_COMPOSITE_TYPE, - MONITOR_INFO_ATTRIBUTES, - values); + return new CompositeDataSupport(MONITOR_INFO_COMPOSITE_TYPE, items); } catch (OpenDataException e) { // Should never reach here throw new AssertionError(e); @@ -126,10 +115,6 @@ public class MonitorInfoCompositeData extends LazyCompositeData { return V6_COMPOSITE_TYPE; } - static CompositeType compositeType() { - return MONITOR_INFO_COMPOSITE_TYPE; - } - public static String getClassName(CompositeData cd) { return getString(cd, CLASS_NAME); } diff --git a/src/java.management/share/classes/sun/management/StackTraceElementCompositeData.java b/src/java.management/share/classes/sun/management/StackTraceElementCompositeData.java index 2a2b096bded..050ca5c0be6 100644 --- a/src/java.management/share/classes/sun/management/StackTraceElementCompositeData.java +++ b/src/java.management/share/classes/sun/management/StackTraceElementCompositeData.java @@ -31,6 +31,8 @@ import javax.management.openmbean.CompositeDataSupport; import javax.management.openmbean.OpenDataException; import javax.management.openmbean.OpenType; import java.util.Arrays; +import java.util.HashMap; +import java.util.Map; import java.util.stream.Stream; /** @@ -75,24 +77,19 @@ public class StackTraceElementCompositeData extends LazyCompositeData { } protected CompositeData getCompositeData() { - // CONTENTS OF THIS ARRAY MUST BE SYNCHRONIZED WITH - // STACK_TRACE_ELEMENT_ATTRIBUTES! - final Object[] stackTraceElementItemValues = { - // JDK 5 attributes - ste.getClassName(), - ste.getMethodName(), - ste.getFileName(), - ste.getLineNumber(), - ste.isNativeMethod(), - // JDK 9 attributes - ste.getClassLoaderName(), - ste.getModuleName(), - ste.getModuleVersion(), - }; + // values may be null; so can't use Map.of + Map items = new HashMap<>(); + items.put(CLASS_LOADER_NAME, ste.getClassLoaderName()); + items.put(MODULE_NAME, ste.getModuleName()); + items.put(MODULE_VERSION, ste.getModuleVersion()); + items.put(CLASS_NAME, ste.getClassName()); + items.put(METHOD_NAME, ste.getMethodName()); + items.put(FILE_NAME, ste.getFileName()); + items.put(LINE_NUMBER, ste.getLineNumber()); + items.put(NATIVE_METHOD, ste.isNativeMethod()); + try { - return new CompositeDataSupport(STACK_TRACE_ELEMENT_COMPOSITE_TYPE, - STACK_TRACE_ELEMENT_ATTRIBUTES, - stackTraceElementItemValues); + return new CompositeDataSupport(STACK_TRACE_ELEMENT_COMPOSITE_TYPE, items); } catch (OpenDataException e) { // Should never reach here throw new AssertionError(e); @@ -123,10 +120,6 @@ public class StackTraceElementCompositeData extends LazyCompositeData { MODULE_VERSION, }; - private static final String[] STACK_TRACE_ELEMENT_ATTRIBUTES = - Stream.of(V5_ATTRIBUTES, V9_ATTRIBUTES).flatMap(Arrays::stream) - .toArray(String[]::new); - private static final CompositeType STACK_TRACE_ELEMENT_COMPOSITE_TYPE; private static final CompositeType V5_COMPOSITE_TYPE; static { @@ -153,9 +146,6 @@ public class StackTraceElementCompositeData extends LazyCompositeData { static CompositeType v5CompositeType() { return V5_COMPOSITE_TYPE; } - static CompositeType compositeType() { - return STACK_TRACE_ELEMENT_COMPOSITE_TYPE; - } /** * Validate if the input CompositeData has the expected diff --git a/src/java.management/share/classes/sun/management/ThreadInfoCompositeData.java b/src/java.management/share/classes/sun/management/ThreadInfoCompositeData.java index 86fb97e224f..29a474630fb 100644 --- a/src/java.management/share/classes/sun/management/ThreadInfoCompositeData.java +++ b/src/java.management/share/classes/sun/management/ThreadInfoCompositeData.java @@ -75,8 +75,7 @@ public class ThreadInfoCompositeData extends LazyCompositeData { protected CompositeData getCompositeData() { // Convert StackTraceElement[] to CompositeData[] StackTraceElement[] stackTrace = threadInfo.getStackTrace(); - CompositeData[] stackTraceData = - new CompositeData[stackTrace.length]; + CompositeData[] stackTraceData = new CompositeData[stackTrace.length]; for (int i = 0; i < stackTrace.length; i++) { StackTraceElement ste = stackTrace[i]; stackTraceData[i] = StackTraceElementCompositeData.toCompositeData(ste); @@ -88,48 +87,42 @@ public class ThreadInfoCompositeData extends LazyCompositeData { // Convert LockInfo[] and MonitorInfo[] to CompositeData[] LockInfo[] lockedSyncs = threadInfo.getLockedSynchronizers(); - CompositeData[] lockedSyncsData = - new CompositeData[lockedSyncs.length]; + CompositeData[] lockedSyncsData = new CompositeData[lockedSyncs.length]; for (int i = 0; i < lockedSyncs.length; i++) { LockInfo li = lockedSyncs[i]; lockedSyncsData[i] = LockInfoCompositeData.toCompositeData(li); } MonitorInfo[] lockedMonitors = threadInfo.getLockedMonitors(); - CompositeData[] lockedMonitorsData = - new CompositeData[lockedMonitors.length]; + CompositeData[] lockedMonitorsData = new CompositeData[lockedMonitors.length]; for (int i = 0; i < lockedMonitors.length; i++) { MonitorInfo mi = lockedMonitors[i]; lockedMonitorsData[i] = MonitorInfoCompositeData.toCompositeData(mi); } - // CONTENTS OF THIS ARRAY MUST BE SYNCHRONIZED WITH - // THREAD_INFO_ATTRIBUTES! - final Object[] threadInfoItemValues = { - threadInfo.getThreadId(), - threadInfo.getThreadName(), - threadInfo.getThreadState().name(), - threadInfo.getBlockedTime(), - threadInfo.getBlockedCount(), - threadInfo.getWaitedTime(), - threadInfo.getWaitedCount(), - lockInfoData, - threadInfo.getLockName(), - threadInfo.getLockOwnerId(), - threadInfo.getLockOwnerName(), - stackTraceData, - threadInfo.isSuspended(), - threadInfo.isInNative(), - lockedMonitorsData, - lockedSyncsData, - threadInfo.isDaemon(), - threadInfo.getPriority(), - }; + // values may be null; can't use Map.of + Map items = new HashMap<>(); + items.put(THREAD_ID, threadInfo.getThreadId()); + items.put(THREAD_NAME, threadInfo.getThreadName()); + items.put(THREAD_STATE, threadInfo.getThreadState().name()); + items.put(BLOCKED_TIME, threadInfo.getBlockedTime()); + items.put(BLOCKED_COUNT, threadInfo.getBlockedCount()); + items.put(WAITED_TIME, threadInfo.getWaitedTime()); + items.put(WAITED_COUNT, threadInfo.getWaitedCount()); + items.put(LOCK_INFO, lockInfoData); + items.put(LOCK_NAME, threadInfo.getLockName()); + items.put(LOCK_OWNER_ID, threadInfo.getLockOwnerId()); + items.put(LOCK_OWNER_NAME, threadInfo.getLockOwnerName()); + items.put(STACK_TRACE, stackTraceData); + items.put(SUSPENDED, threadInfo.isSuspended()); + items.put(IN_NATIVE, threadInfo.isInNative()); + items.put(LOCKED_MONITORS, lockedMonitorsData); + items.put(LOCKED_SYNCS, lockedSyncsData); + items.put(DAEMON, threadInfo.isDaemon()); + items.put(PRIORITY, threadInfo.getPriority()); try { - return new CompositeDataSupport(compositeType(), - THREAD_INFO_ATTRIBTUES, - threadInfoItemValues); + return new CompositeDataSupport(ThreadInfoCompositeTypes.ofVersion(RUNTIME_VERSION), items); } catch (OpenDataException e) { // Should never reach here throw new AssertionError(e); @@ -183,10 +176,6 @@ public class ThreadInfoCompositeData extends LazyCompositeData { PRIORITY, }; - private static final String[] THREAD_INFO_ATTRIBTUES = - Stream.of(V5_ATTRIBUTES, V6_ATTRIBUTES, V9_ATTRIBUTES) - .flatMap(Arrays::stream).toArray(String[]::new); - public long threadId() { return getLong(cdata, THREAD_ID); } @@ -365,12 +354,8 @@ public class ThreadInfoCompositeData extends LazyCompositeData { } } - public static CompositeType compositeType() { - return ThreadInfoCompositeTypes.compositeTypes.get(0); - } - + static final int RUNTIME_VERSION = Runtime.version().feature(); static class ThreadInfoCompositeTypes { - static final int CURRENT = Runtime.version().feature(); static final Map compositeTypes = initCompositeTypes(); /* * Returns CompositeType of the given runtime version @@ -382,7 +367,7 @@ public class ThreadInfoCompositeData extends LazyCompositeData { static Map initCompositeTypes() { Map types = new HashMap<>(); CompositeType ctype = initCompositeType(); - types.put(CURRENT, ctype); + types.put(RUNTIME_VERSION, ctype); types.put(5, initV5CompositeType(ctype)); types.put(6, initV6CompositeType(ctype)); return types; diff --git a/test/jdk/java/lang/management/CompositeData/ThreadInfoCompositeData.java b/test/jdk/java/lang/management/CompositeData/ThreadInfoCompositeData.java index bd301d7604f..da36fdd4bcf 100644 --- a/test/jdk/java/lang/management/CompositeData/ThreadInfoCompositeData.java +++ b/test/jdk/java/lang/management/CompositeData/ThreadInfoCompositeData.java @@ -29,8 +29,9 @@ * the input CompositeData is invalid. * @author Mandy Chung * + * @modules java.management/sun.management * @build ThreadInfoCompositeData OpenTypeConverter - * @run main ThreadInfoCompositeData + * @run testng/othervm ThreadInfoCompositeData */ @@ -42,6 +43,9 @@ import java.util.Arrays; import java.util.Objects; import java.util.stream.Stream; +import org.testng.annotations.Test; +import static org.testng.Assert.*; + public class ThreadInfoCompositeData { private static String lockClassName = "myClass"; private static int lockIdentityHashCode = 123456; @@ -50,24 +54,7 @@ public class ThreadInfoCompositeData { private static LockInfo lockInfo = new LockInfo(lockClassName, lockIdentityHashCode); - public static void main(String[] argv) throws Exception { - // A valid CompositeData is passed to ThreadInfo - createGoodCompositeData(); - // A valid CompositeData for JDK 5 ThreadInfo - // is passed to ThreadInfo - createV5ThreadInfo(); - // ThreadInfo of version N can accept lockedMonitors of version >= N - withNewMonitorInfoCompositeData(); - - // An invalid CompositeData is passed to ThreadInfo.from() - badNameCompositeData(); - badTypeCompositeData(); - badMissingCompositeData(); - withV5StackTraceCompositeData(); - withInvalidMonitorInfoCompositeData(); - System.out.println("Test passed"); - } - + @Test public static void createGoodCompositeData() throws Exception { CompositeData cd = Factory.makeThreadInfoCompositeData(); ThreadInfo info = ThreadInfo.from(cd); @@ -77,6 +64,7 @@ public class ThreadInfoCompositeData { /* * An invalid CompositeData with JDK 9 attributes but missing JDK 6 attributes */ + @Test public static void badMissingCompositeData() throws Exception { CompositeData cd = Factory.makeCompositeDataMissingV6(); try { @@ -92,6 +80,7 @@ public class ThreadInfoCompositeData { /* * Current version of ThreadInfo but an older version of StackTraceElement */ + @Test public static void withV5StackTraceCompositeData() throws Exception { CompositeData cd = Factory.makeThreadInfoWithV5StackTrace(); try { @@ -104,6 +93,7 @@ public class ThreadInfoCompositeData { * Current version of ThreadInfo but an older version of MonitorInfo * and the value of "lockedStackFrame" attribute is null. */ + @Test public static void withInvalidMonitorInfoCompositeData() throws Exception { CompositeData cd = Factory.makeThreadInfoWithIncompatibleMonitorInfo(); @@ -128,6 +118,7 @@ public class ThreadInfoCompositeData { /* * ThreadInfo of version N can accept lockedMonitors of version >= N */ + @Test public static void withNewMonitorInfoCompositeData() throws Exception { CompositeData cd = Factory.makeThreadInfoWithNewMonitorInfo(); ThreadInfo info = ThreadInfo.from(cd); @@ -137,11 +128,24 @@ public class ThreadInfoCompositeData { /* * Test CompositeData representing JDK 5 ThreadInfo */ + @Test public static void createV5ThreadInfo() throws Exception { CompositeData cd = Factory.makeThreadInfoV5CompositeData(); ThreadInfo info = ThreadInfo.from(cd); checkThreadInfoV5(info); - } + } + + /* + * Test ThreadInfoCompositeData.toCompositeData + */ + @Test + public static void internalToCompositeData() throws Exception { + CompositeData cd = Factory.makeThreadInfoCompositeData(); + ThreadInfo info = ThreadInfo.from(cd); + cd = sun.management.ThreadInfoCompositeData.toCompositeData(info); + info = ThreadInfo.from(cd); + checkThreadInfo(info); + } static void checkThreadInfoV5(ThreadInfo info) { Object[] values = Factory.VALUES; @@ -262,6 +266,7 @@ public class ThreadInfoCompositeData { } } + @Test public static void badNameCompositeData() throws Exception { CompositeData cd = Factory.makeCompositeDataWithBadNames(); try { @@ -270,6 +275,7 @@ public class ThreadInfoCompositeData { } catch (IllegalArgumentException e) { } } + @Test public static void badTypeCompositeData() throws Exception { CompositeData cd = Factory.makeCompositeDataWithBadTypes(); @@ -300,7 +306,7 @@ public class ThreadInfoCompositeData { private static final int DAEMON = 16; private static final int PRIORITY = 17; - static class Factory { + private static class Factory { static final CompositeType STE_COMPOSITE_TYPE; static final CompositeType LOCK_INFO_COMPOSITE_TYPE; From a7aa770b9afbd43618823f1126376f51647a79ab Mon Sep 17 00:00:00 2001 From: Pavel Punegov Date: Thu, 25 Oct 2018 11:18:24 -0700 Subject: [PATCH 20/84] 8164546: Convert DirectivesParser_test to GTest Reviewed-by: kvn, iignatyev, neliasso --- .../share/compiler/directivesParser.cpp | 156 ------------- .../share/compiler/directivesParser.hpp | 15 +- .../share/utilities/internalVMTests.cpp | 5 - .../gtest/compiler/test_directivesParser.cpp | 211 ++++++++++++++++++ 4 files changed, 217 insertions(+), 170 deletions(-) create mode 100644 test/hotspot/gtest/compiler/test_directivesParser.cpp diff --git a/src/hotspot/share/compiler/directivesParser.cpp b/src/hotspot/share/compiler/directivesParser.cpp index fad2d86961d..31ed599406b 100644 --- a/src/hotspot/share/compiler/directivesParser.cpp +++ b/src/hotspot/share/compiler/directivesParser.cpp @@ -566,159 +566,3 @@ bool DirectivesParser::callback(JSON_TYPE t, JSON_VAL* v, uint rlimit) { } } -#ifndef PRODUCT -void DirectivesParser::test(const char* text, bool should_pass) { - DirectivesParser cd(text, tty, !VerboseInternalVMTests); - if (should_pass) { - assert(cd.valid() == true, "failed on a valid DirectivesParser string"); - if (VerboseInternalVMTests) { - tty->print("-- DirectivesParser test passed as expected --\n"); - } - } else { - assert(cd.valid() == false, "succeeded on an invalid DirectivesParser string"); - if (VerboseInternalVMTests) { - tty->print("-- DirectivesParser test failed as expected --\n"); - } - } - cd.clean_tmp(); -} - -void DirectivesParser::test() { - DirectivesParser::test("{}", false); - DirectivesParser::test("[]", true); - DirectivesParser::test("[{}]", false); - DirectivesParser::test("[{},{}]", false); - DirectivesParser::test("{},{}", false); - - DirectivesParser::test( - "[" "\n" - " {" "\n" - " match: \"foo/bar.*\"," "\n" - " inline : \"+java/util.*\"," "\n" - " PrintAssembly: true," "\n" - " BreakAtExecute: true," "\n" - " }" "\n" - "]" "\n", true); - - DirectivesParser::test( - "[" "\n" - " [" "\n" - " {" "\n" - " match: \"foo/bar.*\"," "\n" - " inline : \"+java/util.*\"," "\n" - " PrintAssembly: true," "\n" - " BreakAtExecute: true," "\n" - " }" "\n" - " ]" "\n" - "]" "\n", false); - - /*DirectivesParser::test( - "[" "\n" - " {" "\n" - " match: \"foo/bar.*\"," "\n" - " c1: {" - " PrintIntrinsics: false," "\n" - " }" "\n" - " }" "\n" - "]" "\n", false);*/ - - DirectivesParser::test( - "[" "\n" - " {" "\n" - " match: \"foo/bar.*\"," "\n" - " c2: {" "\n" - " PrintInlining: false," "\n" - " }" "\n" - " }" "\n" - "]" "\n", true); - - DirectivesParser::test( - "[" "\n" - " {" "\n" - " match: \"foo/bar.*\"," "\n" - " c2: {" "\n" - " VectorizeDebug: 1," "\n" - " VectorizeDebug: -1," "\n" - " }" "\n" - " }" "\n" - "]" "\n", COMPILER2_PRESENT(true) NOT_COMPILER2(false)); - - DirectivesParser::test( - "[" "\n" - " {" "\n" - " match: \"foo/bar.*\"," "\n" - " PrintInlining: [" "\n" - " true," "\n" - " false" "\n" - " ]," "\n" - " }" "\n" - "]" "\n", false); - - DirectivesParser::test( - "[" "\n" - " {" - " // pattern to match against class+method+signature" "\n" - " // leading and trailing wildcard (*) allowed" "\n" - " match: \"foo/bar.*\"," "\n" - "" "\n" - " // override defaults for specified compiler" "\n" - " // we may differentiate between levels too. TBD." "\n" - " c1: {" "\n" - " //override c1 presets " "\n" - " DumpReplay: false," "\n" - " BreakAtCompile: true," "\n" - " }," "\n" - "" "\n" - " c2: {" "\n" - " // control inlining of method" "\n" - " // + force inline, - dont inline" "\n" - " inline : \"+java/util.*\"," "\n" - " PrintInlining: true," "\n" - " }," "\n" - "" "\n" - " // directives outside a specific preset applies to all compilers" "\n" - " inline : [ \"+java/util.*\", \"-com/sun.*\"]," "\n" - " BreakAtExecute: true," "\n" - " Log: true," "\n" - " }," "\n" - " {" "\n" - " // matching several patterns require an array" "\n" - " match: [\"baz.*\",\"frob.*\"]," "\n" - "" "\n" - " // applies to all compilers" "\n" - " // + force inline, - dont inline" "\n" - " inline : [ \"+java/util.*\", \"-com/sun.*\" ]," "\n" - " PrintInlining: true," "\n" - "" "\n" - " // force matching compiles to be blocking/syncronous" "\n" - " PrintNMethods: true" "\n" - " }," "\n" - "]" "\n", true); - - // Test max stack depth - DirectivesParser::test( - "[" "\n" // depth 1: type_dir_array - " {" "\n" // depth 2: type_directives - " match: \"*.*\"," // match required - " c1:" "\n" // depth 3: type_c1 - " {" "\n" - " inline:" "\n" // depth 4: type_inline - " [" "\n" // depth 5: type_value_array - " \"foo\"," "\n" - " \"bar\"," "\n" - " ]" "\n" // depth 3: pop type_value_array and type_inline keys - " }" "\n" // depth 2: pop type_c1 key - " }" "\n" // depth 1: pop type_directives key - "]" "\n", true); // depth 0: pop type_dir_array key - - // Test max stack depth - DirectivesParser::test( - "[{c1:{c1:{c1:{c1:{c1:{c1:{c1:{}}}}}}}}]", false); - -} - -void DirectivesParser_test() { - DirectivesParser::test(); -} - -#endif diff --git a/src/hotspot/share/compiler/directivesParser.hpp b/src/hotspot/share/compiler/directivesParser.hpp index 724ca5597a6..479bfc47068 100644 --- a/src/hotspot/share/compiler/directivesParser.hpp +++ b/src/hotspot/share/compiler/directivesParser.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2018, 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 @@ -48,15 +48,18 @@ static const char* flag_type_names[] = { "unknown" }; +class DirectivesParserTest; + class DirectivesParser : public JSON { -public: + friend class DirectivesParserTest; + public: static bool has_file(); static bool parse_from_flag(); static bool parse_from_file(const char* filename, outputStream* st); static int parse_string(const char* string, outputStream* st); int install_directives(); -private: + private: DirectivesParser(const char* text, outputStream* st, bool silent); ~DirectivesParser(); @@ -134,12 +137,6 @@ private: int _tmp_depth; // Number of directives that has been parsed but not installed. static uint mask(keytype kt); - -#ifndef PRODUCT - static void test(const char* json, bool valid); -public: - static void test(); -#endif }; #endif // SHARE_VM_COMPILER_DIRECTIVESPARSER_HPP diff --git a/src/hotspot/share/utilities/internalVMTests.cpp b/src/hotspot/share/utilities/internalVMTests.cpp index 3351bf2f62f..b324ed1aacd 100644 --- a/src/hotspot/share/utilities/internalVMTests.cpp +++ b/src/hotspot/share/utilities/internalVMTests.cpp @@ -45,11 +45,6 @@ void InternalVMTests::run() { run_unit_test(TestReserveMemorySpecial_test); run_unit_test(TestMetaspaceUtils_test); run_unit_test(GCTimer_test); - // These tests require the "C" locale to correctly parse decimal values - const char* orig_locale = setlocale(LC_NUMERIC, NULL); - setlocale(LC_NUMERIC, "C"); - run_unit_test(DirectivesParser_test); - setlocale(LC_NUMERIC, orig_locale); tty->print_cr("All internal VM tests passed"); } diff --git a/test/hotspot/gtest/compiler/test_directivesParser.cpp b/test/hotspot/gtest/compiler/test_directivesParser.cpp new file mode 100644 index 00000000000..a021f327487 --- /dev/null +++ b/test/hotspot/gtest/compiler/test_directivesParser.cpp @@ -0,0 +1,211 @@ +/* + * Copyright (c) 2016, 2018, 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 + +#include "compiler/directivesParser.hpp" +#include "runtime/interfaceSupport.inline.hpp" +#include "runtime/thread.hpp" +#include "unittest.hpp" + +class DirectivesParserTest : public ::testing::Test{ + protected: + const char* const _locale; + ResourceMark rm; + stringStream stream; + // These tests require the "C" locale to correctly parse decimal values + DirectivesParserTest() : _locale(setlocale(LC_NUMERIC, NULL)) { + setlocale(LC_NUMERIC, "C"); + } + ~DirectivesParserTest() { + setlocale(LC_NUMERIC, _locale); + } + + void test_negative(const char* text) { + JavaThread* THREAD = JavaThread::current(); + ThreadInVMfromNative ThreadInVMfromNative(THREAD); + DirectivesParser cd(text, &stream, false); + cd.clean_tmp(); + EXPECT_FALSE(cd.valid()) << "text: " << std::endl << text << std::endl << stream.as_string(); + } + + void test_positive(const char* text) { + JavaThread* THREAD = JavaThread::current(); + ThreadInVMfromNative ThreadInVMfromNative(THREAD); + DirectivesParser cd(text, &stream, false); + cd.clean_tmp(); + EXPECT_TRUE(cd.valid()) << "text: " << std::endl << text << std::endl << stream.as_string(); + } +}; + +TEST_VM_F(DirectivesParserTest, empty_object) { + test_negative("{}"); +} + +TEST_VM_F(DirectivesParserTest, empty_array) { + test_positive("[]"); +} + +TEST_VM_F(DirectivesParserTest, empty_object_in_array) { + test_negative("[{}]"); +} + +TEST_VM_F(DirectivesParserTest, empty_objects_in_array) { + test_negative("[{},{}]"); +} + +TEST_VM_F(DirectivesParserTest, empty_objects) { + test_negative("{},{}"); +} + +TEST_VM_F(DirectivesParserTest, simple_match) { + test_positive( + "[" "\n" + " {" "\n" + " match: \"foo/bar.*\"," "\n" + " inline : \"+java/util.*\"," "\n" + " PrintAssembly: true," "\n" + " BreakAtExecute: true," "\n" + " }" "\n" + "]" "\n"); + +} + +TEST_VM_F(DirectivesParserTest, nesting_arrays) { + test_negative( + "[" "\n" + " [" "\n" + " {" "\n" + " match: \"foo/bar.*\"," "\n" + " inline : \"+java/util.*\"," "\n" + " PrintAssembly: true," "\n" + " BreakAtExecute: true," "\n" + " }" "\n" + " ]" "\n" + "]" "\n"); +} + +TEST_VM_F(DirectivesParserTest, c1_block) { + test_positive( + "[" "\n" + " {" "\n" + " match: \"foo/bar.*\"," "\n" + " c1: {" + " PrintInlining: false," "\n" + " }" "\n" + " }" "\n" + "]" "\n"); +} + +TEST_VM_F(DirectivesParserTest, c2_block) { + test_positive( + "[" "\n" + " {" "\n" + " match: \"foo/bar.*\"," "\n" + " c2: {" "\n" + " PrintInlining: false," "\n" + " }" "\n" + " }" "\n" + "]" "\n"); +} + +TEST_VM_F(DirectivesParserTest, boolean_array) { + test_negative( + "[" "\n" + " {" "\n" + " match: \"foo/bar.*\"," "\n" + " PrintInlining: [" "\n" + " true," "\n" + " false" "\n" + " ]," "\n" + " }" "\n" + "]" "\n"); +} + +TEST_VM_F(DirectivesParserTest, multiple_objects) { + test_positive( + "[" "\n" + " {" + " // pattern to match against class+method+signature" "\n" + " // leading and trailing wildcard (*) allowed" "\n" + " match: \"foo/bar.*\"," "\n" + "" "\n" + " // override defaults for specified compiler" "\n" + " // we may differentiate between levels too. TBD." "\n" + " c1: {" "\n" + " //override c1 presets " "\n" + " DumpReplay: false," "\n" + " BreakAtCompile: true," "\n" + " }," "\n" + "" "\n" + " c2: {" "\n" + " // control inlining of method" "\n" + " // + force inline, - dont inline" "\n" + " inline : \"+java/util.*\"," "\n" + " PrintInlining: true," "\n" + " }," "\n" + "" "\n" + " // directives outside a specific preset applies to all compilers" "\n" + " inline : [ \"+java/util.*\", \"-com/sun.*\"]," "\n" + " BreakAtExecute: true," "\n" + " Log: true," "\n" + " }," "\n" + " {" "\n" + " // matching several patterns require an array" "\n" + " match: [\"baz.*\",\"frob.*\"]," "\n" + "" "\n" + " // applies to all compilers" "\n" + " // + force inline, - dont inline" "\n" + " inline : [ \"+java/util.*\", \"-com/sun.*\" ]," "\n" + " PrintInlining: true," "\n" + "" "\n" + " // force matching compiles to be blocking/syncronous" "\n" + " PrintNMethods: true" "\n" + " }," "\n" + "]" "\n"); +} + +// Test max stack depth +TEST_VM_F(DirectivesParserTest, correct_max_stack_depth) { + test_positive( + "[" "\n" // depth 1: type_dir_array + " {" "\n" // depth 2: type_directives + " match: \"*.*\"," // match required + " c1:" "\n" // depth 3: type_c1 + " {" "\n" + " inline:" "\n" // depth 4: type_inline + " [" "\n" // depth 5: type_value_array + " \"foo\"," "\n" + " \"bar\"," "\n" + " ]" "\n" // depth 3: pop type_value_array and type_inline keys + " }" "\n" // depth 2: pop type_c1 key + " }" "\n" // depth 1: pop type_directives key + "]" "\n"); // depth 0: pop type_dir_array key +} + +// Test max stack depth +TEST_VM_F(DirectivesParserTest, incorrect_max_stack_depth) { + test_negative("[{c1:{c1:{c1:{c1:{c1:{c1:{c1:{}}}}}}}}]"); +} From b4cb7d6fc7237e6f25ec876887c66d62f1cd6214 Mon Sep 17 00:00:00 2001 From: Alex Menkov Date: Thu, 25 Oct 2018 11:48:18 -0700 Subject: [PATCH 21/84] 8212151: jdi/ExclusiveBind.java times out due to "bind failed: Address already in use" on Solaris-X64 Reviewed-by: sspitsyn, jcbeyler --- test/jdk/com/sun/jdi/ExclusiveBind.java | 112 ++---------- test/jdk/com/sun/jdi/lib/jdb/Debuggee.java | 191 +++++++++++++++++++++ test/jdk/com/sun/jdi/lib/jdb/JdbTest.java | 57 ++---- 3 files changed, 221 insertions(+), 139 deletions(-) create mode 100644 test/jdk/com/sun/jdi/lib/jdb/Debuggee.java diff --git a/test/jdk/com/sun/jdi/ExclusiveBind.java b/test/jdk/com/sun/jdi/ExclusiveBind.java index e7e715a873a..e3df80bbd81 100644 --- a/test/jdk/com/sun/jdi/ExclusiveBind.java +++ b/test/jdk/com/sun/jdi/ExclusiveBind.java @@ -27,113 +27,39 @@ * at the same time. * @library /test/lib * - * @modules java.management - * jdk.jdi - * @build VMConnection ExclusiveBind HelloWorld + * @build ExclusiveBind HelloWorld * @run driver ExclusiveBind */ -import java.net.ServerSocket; -import com.sun.jdi.Bootstrap; -import com.sun.jdi.VirtualMachine; -import com.sun.jdi.connect.Connector; -import com.sun.jdi.connect.AttachingConnector; - -import java.util.ArrayList; -import java.util.Map; -import java.util.List; -import java.util.Iterator; -import java.util.concurrent.TimeUnit; import jdk.test.lib.process.ProcessTools; -import jdk.test.lib.Utils; +import lib.jdb.Debuggee; public class ExclusiveBind { /* - * Find a connector by name - */ - private static Connector findConnector(String name) { - List connectors = Bootstrap.virtualMachineManager().allConnectors(); - Iterator iter = connectors.iterator(); - while (iter.hasNext()) { - Connector connector = (Connector)iter.next(); - if (connector.name().equals(name)) { - return connector; - } - } - return null; - } - - /* - * Launch (in server mode) a debuggee with the given address and - * suspend mode. - */ - private static ProcessBuilder prepareLauncher(String address, boolean suspend, String class_name) throws Exception { - List args = new ArrayList<>(); - for(String dbgOption : VMConnection.getDebuggeeVMOptions().split(" ")) { - if (!dbgOption.trim().isEmpty()) { - args.add(dbgOption); - } - } - String lib = "-agentlib:jdwp=transport=dt_socket,server=y,suspend="; - if (suspend) { - lib += "y"; - } else { - lib += "n"; - } - lib += ",address=" + address; - - args.add(lib); - args.add(class_name); - - return ProcessTools.createJavaProcessBuilder(args.toArray(new String[args.size()])); - } - - /* - * - pick a TCP port - * - Launch a debuggee in server=y,suspend=y,address=${port} - * - Launch a second debuggee in server=y,suspend=n with the same port + * - Launch a debuggee with server=y,suspend=y + * - Parse listening port + * - Launch a second debuggee in server=y,suspend=n with the parsed port * - Second debuggee should fail with an error (address already in use) * - For clean-up we attach to the first debuggee and resume it. */ public static void main(String args[]) throws Exception { - // find a free port - ServerSocket ss = new ServerSocket(0); - int port = ss.getLocalPort(); - ss.close(); - - String address = String.valueOf(port); - // launch the first debuggee - ProcessBuilder process1 = prepareLauncher(address, true, "HelloWorld"); - // start the debuggee and wait for the "ready" message - Process p = ProcessTools.startProcess( - "process1", - process1, - line -> line.equals("Listening for transport dt_socket at address: " + address), - Utils.adjustTimeout(5000), - TimeUnit.MILLISECONDS - ); + try (Debuggee process1 = Debuggee.launcher("HelloWorld").launch("process1")) { + // launch a second debuggee with the same address + ProcessBuilder process2 = Debuggee.launcher("HelloWorld") + .setSuspended(false) + .setAddress(process1.getAddress()) + .prepare(); - // launch a second debuggee with the same address - ProcessBuilder process2 = prepareLauncher(address, false, "HelloWorld"); + // get exit status from second debuggee + int exitCode = ProcessTools.startProcess("process2", process2).waitFor(); - // get exit status from second debuggee - int exitCode = ProcessTools.startProcess("process2", process2).waitFor(); - - // clean-up - attach to first debuggee and resume it - AttachingConnector conn = (AttachingConnector)findConnector("com.sun.jdi.SocketAttach"); - Map conn_args = conn.defaultArguments(); - Connector.IntegerArgument port_arg = - (Connector.IntegerArgument)conn_args.get("port"); - port_arg.setValue(port); - VirtualMachine vm = conn.attach(conn_args); - vm.resume(); - - // if the second debuggee ran to completion then we've got a problem - if (exitCode == 0) { - throw new RuntimeException("Test failed - second debuggee didn't fail to bind"); - } else { - System.out.println("Test passed - second debuggee correctly failed to bind"); + // if the second debuggee ran to completion then we've got a problem + if (exitCode == 0) { + throw new RuntimeException("Test failed - second debuggee didn't fail to bind"); + } else { + System.out.println("Test passed - second debuggee correctly failed to bind"); + } } } } diff --git a/test/jdk/com/sun/jdi/lib/jdb/Debuggee.java b/test/jdk/com/sun/jdi/lib/jdb/Debuggee.java new file mode 100644 index 00000000000..c37fedb4f7f --- /dev/null +++ b/test/jdk/com/sun/jdi/lib/jdb/Debuggee.java @@ -0,0 +1,191 @@ +/* + * Copyright (c) 2018, 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 lib.jdb; + +import jdk.test.lib.Utils; +import jdk.test.lib.process.ProcessTools; + +import java.io.Closeable; +import java.io.IOException; +import java.util.LinkedList; +import java.util.List; +import java.util.concurrent.TimeUnit; +import java.util.concurrent.TimeoutException; +import java.util.regex.Matcher; +import java.util.regex.Pattern; +import java.util.stream.Collectors; + +/** + * Helper class to run java debuggee and parse agent listening transport/address. + * Usage: + * 1) + * Debugee debugee = Debuggee.launcher("MyClass").setTransport("dt_shmem").launch(); + * try { + * String transport = debuggee.getTransport(); + * String addr = debuggee.getAddress(); + * } finally { + * debuggee.shutdown(); + * } + * 2) (using try-with-resource) + * try (Debugee debugee = Debuggee.launcher("MyClass").launch()) { + * String transport = debuggee.getTransport(); + * String addr = debuggee.getAddress(); + * } + * 3) + * ProcessBuilder pb = Debuggee.launcher("MyClass").setSuspended(false).prepare(); + * ProcessTools.executeProcess(pb); + */ +public class Debuggee implements Closeable { + + public static Launcher launcher(String mainClass) { + return new Launcher(mainClass); + } + + public static class Launcher { + private final String mainClass; + private final List options = new LinkedList<>(); + private String transport = "dt_socket"; + private String address = null; + private boolean suspended = true; + private boolean addTestVmAndJavaOptions = true; + + private Launcher(String mainClass) { + this.mainClass = mainClass; + } + public Launcher addOption(String option) { + options.add(option); + return this; + } + public Launcher addOptions(List options) { + this.options.addAll(options); + return this; + } + // default is "dt_socket" + public Launcher setTransport(String value) { + transport = value; + return this; + } + // default is "null" (auto-generate) + public Launcher setAddress(String value) { + address = value; + return this; + } + // default is "true" + public Launcher setSuspended(boolean value) { + suspended = value; + return this; + } + // default is "true" + public Launcher addTestVmAndJavaOptions(boolean value) { + addTestVmAndJavaOptions = value; + return this; + } + + public ProcessBuilder prepare() { + List debuggeeArgs = new LinkedList<>(); + debuggeeArgs.add("-agentlib:jdwp=transport=" + transport + + (address == null ? "" : ",address=" + address) + + ",server=y,suspend=" + (suspended ? "y" : "n")); + debuggeeArgs.addAll(options); + debuggeeArgs.add(mainClass); + return ProcessTools.createJavaProcessBuilder(addTestVmAndJavaOptions, + debuggeeArgs.toArray(new String[0])); + } + + public Debuggee launch(String name) { + return new Debuggee(prepare(), name); + } + public Debuggee launch() { + return launch("debuggee"); + } + } + + // starts the process, waits for "Listening for transport" output and detects transport/address + private Debuggee(ProcessBuilder pb, String name) { + // debuggeeListen[0] - transport, debuggeeListen[1] - address + String[] debuggeeListen = new String[2]; + Pattern listenRegexp = Pattern.compile("Listening for transport \\b(.+)\\b at address: \\b(.+)\\b"); + try { + p = ProcessTools.startProcess(name, pb, + s -> output.add(s), // output consumer + s -> { // warm-up predicate + Matcher m = listenRegexp.matcher(s); + if (!m.matches()) { + return false; + } + debuggeeListen[0] = m.group(1); + debuggeeListen[1] = m.group(2); + return true; + }, + 30, TimeUnit.SECONDS); + transport = debuggeeListen[0]; + address = debuggeeListen[1]; + } catch (IOException | InterruptedException | TimeoutException ex) { + throw new RuntimeException("failed to launch debuggee", ex); + } + } + + private final Process p; + private final List output = new LinkedList<>(); + private final String transport; + private final String address; + + public void shutdown() { + try { + close(); + } catch (IOException ex) { + // ignore + } + } + + // waits until the process shutdown or crash + public boolean waitFor(long timeout, TimeUnit unit) { + try { + return p.waitFor(Utils.adjustTimeout(timeout), unit); + } catch (InterruptedException e) { + return false; + } + } + + // returns the whole debuggee output as a string + public String getOutput() { + return output.stream().collect(Collectors.joining(Utils.NEW_LINE)); + } + + String getTransport() { + return transport; + } + + public String getAddress() { + return address; + } + + @Override + public void close() throws IOException { + if (p.isAlive()) { + p.destroy(); + } + } + +} diff --git a/test/jdk/com/sun/jdi/lib/jdb/JdbTest.java b/test/jdk/com/sun/jdi/lib/jdb/JdbTest.java index 3d407adb319..5c13a17fe4a 100644 --- a/test/jdk/com/sun/jdi/lib/jdb/JdbTest.java +++ b/test/jdk/com/sun/jdi/lib/jdb/JdbTest.java @@ -23,9 +23,7 @@ package lib.jdb; -import jdk.test.lib.Utils; import jdk.test.lib.process.OutputAnalyzer; -import jdk.test.lib.process.ProcessTools; import java.io.IOException; import java.nio.file.Files; @@ -34,9 +32,6 @@ import java.util.Arrays; import java.util.LinkedList; import java.util.List; import java.util.concurrent.TimeUnit; -import java.util.concurrent.TimeoutException; -import java.util.regex.Matcher; -import java.util.regex.Pattern; import java.util.stream.Collectors; public abstract class JdbTest { @@ -76,8 +71,7 @@ public abstract class JdbTest { } protected Jdb jdb; - protected Process debuggee; - private final List debuggeeOutput = new LinkedList<>(); + protected Debuggee debuggee; private final LaunchOptions launchOptions; // returns the whole jdb output as a string @@ -87,7 +81,7 @@ public abstract class JdbTest { // returns the whole debuggee output as a string public String getDebuggeeOutput() { - return debuggeeOutput.stream().collect(Collectors.joining(lineSeparator)); + return debuggee == null ? "" : debuggee.getOutput(); } public void run() { @@ -106,45 +100,22 @@ public abstract class JdbTest { protected void setup() { /* run debuggee as: - java -agentlib:jdwp=transport=dt_socket,address=0,server=n,suspend=y + java -agentlib:jdwp=transport=dt_socket,server=n,suspend=y it reports something like : Listening for transport dt_socket at address: 60810 after that connect jdb by: jdb -connect com.sun.jdi.SocketAttach:port=60810 */ // launch debuggee - List debuggeeArgs = new LinkedList<>(); - // specify address=0 to automatically select free port - debuggeeArgs.add("-agentlib:jdwp=transport=dt_socket,address=0,server=y,suspend=y"); - debuggeeArgs.addAll(launchOptions.debuggeeOptions); - debuggeeArgs.add(launchOptions.debuggeeClass); - ProcessBuilder pbDebuggee = ProcessTools.createJavaProcessBuilder(true, debuggeeArgs.toArray(new String[0])); - - // debuggeeListen[0] - transport, debuggeeListen[1] - address - String[] debuggeeListen = new String[2]; - Pattern listenRegexp = Pattern.compile("Listening for transport \\b(.+)\\b at address: \\b(\\d+)\\b"); - try { - debuggee = ProcessTools.startProcess("debuggee", pbDebuggee, - s -> debuggeeOutput.add(s), // output consumer - s -> { // warm-up predicate - Matcher m = listenRegexp.matcher(s); - if (!m.matches()) { - return false; - } - debuggeeListen[0] = m.group(1); - debuggeeListen[1] = m.group(2); - return true; - }, - 30, TimeUnit.SECONDS); - } catch (IOException | InterruptedException | TimeoutException ex) { - throw new RuntimeException("failed to launch debuggee", ex); - } + debuggee = Debuggee.launcher(launchOptions.debuggeeClass) + .addOptions(launchOptions.debuggeeOptions) + .launch(); // launch jdb try { - jdb = new Jdb("-connect", "com.sun.jdi.SocketAttach:port=" + debuggeeListen[1]); + jdb = new Jdb("-connect", "com.sun.jdi.SocketAttach:port=" + debuggee.getAddress()); } catch (Throwable ex) { // terminate debuggee if something went wrong - debuggee.destroy(); + debuggee.shutdown(); throw ex; } // wait while jdb is initialized @@ -158,15 +129,9 @@ public abstract class JdbTest { jdb.shutdown(); } // shutdown debuggee - if (debuggee != null && debuggee.isAlive()) { - try { - debuggee.waitFor(Utils.adjustTimeout(10), TimeUnit.SECONDS); - } catch (InterruptedException e) { - // ignore - } finally { - if (debuggee.isAlive()) { - debuggee.destroy(); - } + if (debuggee != null) { + if (!debuggee.waitFor(10, TimeUnit.SECONDS)) { + debuggee.shutdown(); } } } From 162e75f4a8e0d8b138f01b11bfa1bf736b896188 Mon Sep 17 00:00:00 2001 From: Abdul Kolarkunnu Date: Thu, 25 Oct 2018 08:59:26 -0700 Subject: [PATCH 22/84] 8212897: Some improvements in the EditorPaneDemotest Reviewed-by: serb --- test/jdk/sanity/client/SwingSet/src/EditorPaneDemoTest.java | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/test/jdk/sanity/client/SwingSet/src/EditorPaneDemoTest.java b/test/jdk/sanity/client/SwingSet/src/EditorPaneDemoTest.java index c9013a0bb23..8aa7635bf63 100644 --- a/test/jdk/sanity/client/SwingSet/src/EditorPaneDemoTest.java +++ b/test/jdk/sanity/client/SwingSet/src/EditorPaneDemoTest.java @@ -24,7 +24,9 @@ import static com.sun.swingset3.demos.editorpane.EditorPaneDemo.DEMO_TITLE; import static com.sun.swingset3.demos.editorpane.EditorPaneDemo.SOURCE_FILES; import static org.jemmy2ext.JemmyExt.EXACT_STRING_COMPARATOR; +import static org.jemmy2ext.JemmyExt.assertNotBlack; +import java.awt.Color; import java.awt.Dimension; import java.awt.Insets; import java.awt.Point; @@ -147,14 +149,14 @@ public class EditorPaneDemoTest { final int xGap = 100, yGap = 40, columns = 2, rows = 5; editorPaneOperator.waitState(comp -> { BufferedImage capturedImage = ImageTool.getImage(imageRect); + assertNotBlack(capturedImage); int x = 0, y = 0, i = 0, j; for (; i < columns; i++) { x += xGap; y = 0; for (j = 0; j < rows; j++) { y += yGap; - if(capturedImage.getRGB(x, y) == - editorPaneOperator.getBackground().getRGB()) { + if(capturedImage.getRGB(x, y) == Color.WHITE.getRGB()) { // saving image for failure case JemmyExt.save(capturedImage, "capturedimage_" + pageName + "_" + UIManager.getLookAndFeel().getClass().getSimpleName() + ".png"); From 589b596becc4147ea4b4b887675e6f7f75a51d80 Mon Sep 17 00:00:00 2001 From: Jean Christophe Beyler Date: Thu, 25 Oct 2018 14:23:26 -0700 Subject: [PATCH 23/84] 8212884: Remove the assignments in ifs for vmTestbase/[a-s] Extract assignments from if statements in vmTestbase Reviewed-by: cjplummer, sspitsyn --- .../VirtualMachine09/agent00.cpp | 6 ++- .../attach002/attach002Agent00.cpp | 13 +++--- .../attach002a/attach002aAgent00.cpp | 9 ++-- .../attach008/attach008Agent00.cpp | 9 ++-- .../attach009/attach009Agent00.cpp | 9 ++-- .../attach012/attach012Agent00.cpp | 9 ++-- .../attach014/attach014Agent00.cpp | 9 ++-- .../attach015/attach015Agent00.cpp | 9 ++-- .../attach015/attach015Agent01.cpp | 9 ++-- .../attach020/attach020Agent00.cpp | 12 ++++-- .../attach021/attach021Agent00.cpp | 13 +++--- .../attach022/attach022Agent00.cpp | 13 +++--- .../attach037/attach037Agent00.cpp | 9 ++-- .../attach038/attach038Agent00.cpp | 9 ++-- .../attach039/attach039Agent00.cpp | 12 ++++-- .../attach040/attach040Agent00.cpp | 9 ++-- .../attach041/attach041Agent00.cpp | 9 ++-- .../attach042/attach042Agent00.cpp | 9 ++-- .../attach045/attach045Agent00.cpp | 9 ++-- .../attach045/attach045Agent01.cpp | 9 ++-- .../attach045/attach045Agent02.cpp | 9 ++-- .../attach045/attach045Agent03.cpp | 9 ++-- .../attach046/attach046Agent00.cpp | 12 ++++-- .../attach050/attach050Agent00.cpp | 9 ++-- .../sharedAgents/simpleAgent00.cpp | 9 ++-- .../jvmti/IterateThroughHeap/abort/Abort.cpp | 3 +- .../callbacks/Callbacks.cpp | 3 +- .../ConcreteKlassFilter.cpp | 3 +- .../filter-tagged/HeapFilter.cpp | 3 +- .../NonConcreteKlassFilter.cpp | 3 +- .../ThreadEnd/threadend002/threadend002.cpp | 3 +- .../allocation/AP04/ap04t003/ap04t003.cpp | 27 +++++++----- .../bcinstr/BI01/bi01t001/bi01t001.cpp | 14 ++++--- .../bcinstr/BI01/bi01t002/bi01t002.cpp | 14 ++++--- .../bcinstr/BI04/bi04t002/bi04t002.cpp | 10 +++-- .../events/EM01/em01t001/em01t001.cpp | 6 ++- .../events/EM01/em01t002/em01t002.cpp | 30 +++++++------ .../events/EM02/em02t001/em02t001.cpp | 42 +++++++++++-------- .../events/EM02/em02t002/em02t002.cpp | 3 +- .../events/EM02/em02t003/em02t003.cpp | 3 +- .../events/EM02/em02t004/em02t004.cpp | 3 +- .../events/EM02/em02t005/em02t005.cpp | 3 +- .../events/EM02/em02t006/em02t006.cpp | 3 +- .../events/EM02/em02t007/em02t007.cpp | 3 +- .../events/EM02/em02t008/em02t008.cpp | 3 +- .../events/EM02/em02t009/em02t009.cpp | 3 +- .../events/EM02/em02t010/em02t010.cpp | 14 ++++--- .../events/EM02/em02t011/em02t011.cpp | 10 +++-- .../events/EM02/em02t012/em02t012.cpp | 6 ++- .../events/EM04/em04t001/em04t001.cpp | 6 ++- 50 files changed, 293 insertions(+), 171 deletions(-) diff --git a/test/hotspot/jtreg/vmTestbase/nsk/aod/VirtualMachine/VirtualMachine09/agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/aod/VirtualMachine/VirtualMachine09/agent00.cpp index 31d75f67539..c63187191d9 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/aod/VirtualMachine/VirtualMachine09/agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/aod/VirtualMachine/VirtualMachine09/agent00.cpp @@ -48,12 +48,14 @@ JNIEXPORT jint JNICALL Agent_OnAttach(JavaVM *vm, char *optionsString, void *res Options* options = NULL; const char* agentName; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; NSK_DISPLAY1("%s: initialization was done\n", agentName); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach002/attach002Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach002/attach002Agent00.cpp index 2b4c34c7b40..f7a24d2ef57 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach002/attach002Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach002/attach002Agent00.cpp @@ -73,8 +73,8 @@ int registerNativeMethods(JNIEnv* jni) { {(char*) "agentGotCapabilities", (char*) "()Z", (void*) Java_nsk_jvmti_AttachOnDemand_attach002_attach002Target_agentGotCapabilities}}; jint nativeMethodsNumber = 1; - if (!NSK_JNI_VERIFY(jni, (appClass = - jni->FindClass(ATTACH002_TARGET_APP_CLASS_NAME)) != NULL)) { + appClass = jni->FindClass(ATTACH002_TARGET_APP_CLASS_NAME); + if (!NSK_JNI_VERIFY(jni, appClass != NULL)) { return NSK_FALSE; } @@ -187,15 +187,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti = NULL; JNIEnv* jni = NULL; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return NSK_FALSE; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_VERIFY(registerNativeMethods(jni))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach002a/attach002aAgent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach002a/attach002aAgent00.cpp index f859058fbb2..26457dfc12e 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach002a/attach002aAgent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach002a/attach002aAgent00.cpp @@ -92,15 +92,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti = NULL; JNIEnv* jni = NULL; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return NSK_FALSE; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; memset(&caps, 0, sizeof(caps)); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach008/attach008Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach008/attach008Agent00.cpp index 8bdf4d083b7..426869cfc66 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach008/attach008Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach008/attach008Agent00.cpp @@ -110,15 +110,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti = NULL; JNIEnv* jni = NULL; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return NSK_FALSE; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; memset(&caps, 0, sizeof(caps)); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach009/attach009Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach009/attach009Agent00.cpp index 6cdfd2e6292..3256b62582f 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach009/attach009Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach009/attach009Agent00.cpp @@ -128,15 +128,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEventCallbacks eventCallbacks; JNIEnv* jni; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return NSK_FALSE; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; memset(&eventCallbacks,0, sizeof(eventCallbacks)); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach012/attach012Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach012/attach012Agent00.cpp index 5ccf7de0bee..64ab7c0974b 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach012/attach012Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach012/attach012Agent00.cpp @@ -54,15 +54,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) const char* agentName; jvmtiCapabilities caps; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return NSK_FALSE; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->GetPotentialCapabilities(&caps))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach014/attach014Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach014/attach014Agent00.cpp index a708c6dc101..ce3fa29a4e2 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach014/attach014Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach014/attach014Agent00.cpp @@ -91,15 +91,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti = NULL; JNIEnv* jni = NULL; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return NSK_FALSE; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; memset(&eventCallbacks,0, sizeof(eventCallbacks)); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach015/attach015Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach015/attach015Agent00.cpp index 93fe6f7e9f9..a28c912880c 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach015/attach015Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach015/attach015Agent00.cpp @@ -84,15 +84,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti = NULL; JNIEnv* jni = NULL; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return NSK_FALSE; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; memset(&eventCallbacks,0, sizeof(eventCallbacks)); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach015/attach015Agent01.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach015/attach015Agent01.cpp index b9429a058e5..78527c41cc8 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach015/attach015Agent01.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach015/attach015Agent01.cpp @@ -84,15 +84,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti = NULL; JNIEnv* jni = NULL; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; memset(&eventCallbacks,0, sizeof(eventCallbacks)); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach020/attach020Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach020/attach020Agent00.cpp index a77f1b46a8b..6b236ea7d7a 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach020/attach020Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach020/attach020Agent00.cpp @@ -115,7 +115,8 @@ void JNICALL auxiliaryThreadFunction(jvmtiEnv* jvmti, JNIEnv* jni, void* arg) { int startAuxiliaryThread(jvmtiEnv* jvmti, JNIEnv* jni) { jthread thread; - if (!NSK_VERIFY((thread = nsk_jvmti_aod_createThread(jni)) != NULL)) + thread = nsk_jvmti_aod_createThread(jni); + if (!NSK_VERIFY(thread != NULL)) return NSK_FALSE; if (!NSK_JVMTI_VERIFY(jvmti->RunAgentThread(thread, auxiliaryThreadFunction, NULL, JVMTI_THREAD_NORM_PRIORITY))) { @@ -145,15 +146,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiCapabilities caps; JNIEnv* jni; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("GCFinishMonitor", &gcFinishMonitor))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach021/attach021Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach021/attach021Agent00.cpp index 59b43e3eb59..a5de99ca2bb 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach021/attach021Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach021/attach021Agent00.cpp @@ -94,8 +94,8 @@ int registerNativeMethods(JNIEnv* jni) { {(char*) "shutdownAgent", (char*) "()V", (void*) Java_nsk_jvmti_AttachOnDemand_attach021_attach021Target_shutdownAgent}}; jint nativeMethodsNumber = 2; - if (!NSK_JNI_VERIFY(jni, (appClass = - jni->FindClass(ATTACH021_TARGET_APP_CLASS_NAME)) != NULL)) { + appClass = jni->FindClass(ATTACH021_TARGET_APP_CLASS_NAME); + if (!NSK_JNI_VERIFY(jni, appClass != NULL)) { return NSK_FALSE; } @@ -124,15 +124,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiCapabilities caps; JNIEnv* jni; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_VERIFY(registerNativeMethods(jni))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach022/attach022Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach022/attach022Agent00.cpp index 3a61c0bccbf..05f43e83233 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach022/attach022Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach022/attach022Agent00.cpp @@ -104,8 +104,8 @@ int registerNativeMethods(JNIEnv* jni) { (void*) Java_nsk_jvmti_AttachOnDemand_attach022_attach022Target_shutdownAgent}}; jint nativeMethodsNumber = 1; - if (!NSK_JNI_VERIFY(jni, (appClass = - jni->FindClass(ATTACH022_TARGET_APP_CLASS_NAME)) != NULL)) { + appClass = jni->FindClass(ATTACH022_TARGET_APP_CLASS_NAME); + if (!NSK_JNI_VERIFY(jni, appClass != NULL)) { return NSK_FALSE; } @@ -176,15 +176,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiCapabilities caps; JNIEnv* jni; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_VERIFY(registerNativeMethods(jni))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach037/attach037Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach037/attach037Agent00.cpp index 452bbb80fc8..32e40e88273 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach037/attach037Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach037/attach037Agent00.cpp @@ -109,15 +109,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti; JNIEnv* jni; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; memset(&caps, 0, sizeof(caps)); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach038/attach038Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach038/attach038Agent00.cpp index 95a9d1e10d1..5edf404506f 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach038/attach038Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach038/attach038Agent00.cpp @@ -105,15 +105,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti; JNIEnv* jni; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; memset(&eventCallbacks,0, sizeof(eventCallbacks)); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach039/attach039Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach039/attach039Agent00.cpp index 4301c20cf0f..9210835590b 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach039/attach039Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach039/attach039Agent00.cpp @@ -65,7 +65,8 @@ void JNICALL startedThreadFunction(jvmtiEnv* jvmti, JNIEnv* jni, void* arg) { int startNewThread(jvmtiEnv* jvmti, JNIEnv* jni) { jthread thread; - if (!NSK_VERIFY((thread = nsk_jvmti_aod_createThreadWithName(jni, STARTED_THREAD_NAME)) != NULL)) + thread = nsk_jvmti_aod_createThreadWithName(jni, STARTED_THREAD_NAME); + if (!NSK_VERIFY(thread != NULL)) return NSK_FALSE; if (!NSK_JVMTI_VERIFY(jvmti->RunAgentThread(thread, startedThreadFunction, NULL, JVMTI_THREAD_NORM_PRIORITY))) { @@ -140,15 +141,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti; JNIEnv* jni; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; memset(&eventCallbacks,0, sizeof(eventCallbacks)); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach040/attach040Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach040/attach040Agent00.cpp index 9c49920874f..b5ec2fbf809 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach040/attach040Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach040/attach040Agent00.cpp @@ -133,15 +133,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti; JNIEnv* jni; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("threadsCounterMonitor", &threadsCounterMonitor))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach041/attach041Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach041/attach041Agent00.cpp index 79288ff446c..608bf556f37 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach041/attach041Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach041/attach041Agent00.cpp @@ -159,15 +159,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti; JNIEnv* jni; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; memset(&eventCallbacks,0, sizeof(eventCallbacks)); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach042/attach042Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach042/attach042Agent00.cpp index 2cff5fd0595..c26fc2488b2 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach042/attach042Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach042/attach042Agent00.cpp @@ -123,15 +123,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti; JNIEnv* jni; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; memset(&eventCallbacks,0, sizeof(eventCallbacks)); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent00.cpp index 3683debe12d..a196150bc81 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent00.cpp @@ -97,15 +97,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti; JNIEnv* jni; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("attach045-agent00-eventsCounterMonitor", &eventsCounterMonitor))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent01.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent01.cpp index 695b50b777c..a7ce1343d9e 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent01.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent01.cpp @@ -108,15 +108,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti; JNIEnv* jni; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("attach045-agent01-eventsCounterMonitor", &eventsCounterMonitor))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent02.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent02.cpp index b9316692bc5..bf323e43b2b 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent02.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent02.cpp @@ -128,15 +128,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiEnv* jvmti; JNIEnv* jni; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("attach045-agent02-eventsCounterMonitor", &eventsCounterMonitor))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent03.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent03.cpp index 16915db6c64..225ee67dd88 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent03.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach045/attach045Agent03.cpp @@ -118,15 +118,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) jvmtiCapabilities caps; JNIEnv* jni; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("attach045-agent03-eventsCounterMonitor", &eventsCounterMonitor))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach046/attach046Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach046/attach046Agent00.cpp index fe96e40f320..0c1e03cf5f0 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach046/attach046Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach046/attach046Agent00.cpp @@ -51,7 +51,8 @@ void JNICALL classLoadHandler( const char* agentName; Options* options; - if (!NSK_VERIFY((options = nsk_jvmti_aod_getMultiagentsOptions(jvmti)) != NULL)) { + options = nsk_jvmti_aod_getMultiagentsOptions(jvmti); + if (!NSK_VERIFY(options != NULL)) { NSK_COMPLAIN0("Failed to get agents's options\n"); nsk_jvmti_aod_disableEvent(jvmti, JVMTI_EVENT_CLASS_LOAD); // can't call nsk_aod_agentFinished because of without options can't get agent's name @@ -100,15 +101,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) Options* options; const char* agentName; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return NSK_FALSE; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; memset(&caps, 0, sizeof(caps)); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach050/attach050Agent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach050/attach050Agent00.cpp index 9704cb47f20..6a7ceeb4c48 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach050/attach050Agent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/attach050/attach050Agent00.cpp @@ -58,15 +58,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) Options* options = NULL; const char* agentName; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; NSK_DISPLAY1("%s: initialization was done\n", agentName); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/sharedAgents/simpleAgent00.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/sharedAgents/simpleAgent00.cpp index c39b71d2e63..d24922f2bfe 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/sharedAgents/simpleAgent00.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/AttachOnDemand/sharedAgents/simpleAgent00.cpp @@ -54,15 +54,18 @@ Agent_OnAttach(JavaVM *vm, char *optionsString, void *reserved) Options* options = NULL; const char* agentName; - if (!NSK_VERIFY((options = (Options*) nsk_aod_createOptions(optionsString)) != NULL)) + options = (Options*) nsk_aod_createOptions(optionsString); + if (!NSK_VERIFY(options != NULL)) return JNI_ERR; agentName = nsk_aod_getOptionValue(options, NSK_AOD_AGENT_NAME_OPTION); - if ((jni = (JNIEnv*) nsk_aod_createJNIEnv(vm)) == NULL) + jni = (JNIEnv*) nsk_aod_createJNIEnv(vm); + if (jni == NULL) return JNI_ERR; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(vm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; NSK_DISPLAY1("%s: initialization was done\n", agentName); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/abort/Abort.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/abort/Abort.cpp index bef827c7565..37b6a6df662 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/abort/Abort.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/abort/Abort.cpp @@ -126,7 +126,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { jvmtiCapabilities caps; jvmtiEventCallbacks event_callbacks; - if(!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) { + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) { return JNI_ERR; } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/callbacks/Callbacks.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/callbacks/Callbacks.cpp index d814bc8108e..92f03f3d319 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/callbacks/Callbacks.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/callbacks/Callbacks.cpp @@ -585,7 +585,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { jvmtiCapabilities caps; jvmtiEventCallbacks event_callbacks; - if(!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) { + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) { return JNI_ERR; } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/concrete-klass-filter/ConcreteKlassFilter.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/concrete-klass-filter/ConcreteKlassFilter.cpp index ebff549c2de..e35a5cf4029 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/concrete-klass-filter/ConcreteKlassFilter.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/concrete-klass-filter/ConcreteKlassFilter.cpp @@ -268,7 +268,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { jvmtiCapabilities caps; jvmtiEventCallbacks event_callbacks; - if(!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) { + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) { return JNI_ERR; } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/filter-tagged/HeapFilter.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/filter-tagged/HeapFilter.cpp index 06ae9b8ebb6..6a206b5ce56 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/filter-tagged/HeapFilter.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/filter-tagged/HeapFilter.cpp @@ -529,7 +529,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { jvmtiEventCallbacks event_callbacks; const char *type; - if(!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) { + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) { return JNI_ERR; } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/non-concrete-klass-filter/NonConcreteKlassFilter.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/non-concrete-klass-filter/NonConcreteKlassFilter.cpp index bc038f96289..d8e1a849a5f 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/non-concrete-klass-filter/NonConcreteKlassFilter.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/IterateThroughHeap/non-concrete-klass-filter/NonConcreteKlassFilter.cpp @@ -208,7 +208,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { jvmtiCapabilities caps; jvmtiEventCallbacks event_callbacks; - if(!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) { + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) { return JNI_ERR; } diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/ThreadEnd/threadend002/threadend002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/ThreadEnd/threadend002/threadend002.cpp index 0d7840435c9..19625d28037 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/ThreadEnd/threadend002/threadend002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/ThreadEnd/threadend002/threadend002.cpp @@ -144,7 +144,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!setCallBacks()) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP04/ap04t003/ap04t003.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP04/ap04t003/ap04t003.cpp index 1444d017de8..a5d4d4df886 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP04/ap04t003/ap04t003.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/allocation/AP04/ap04t003/ap04t003.cpp @@ -339,17 +339,20 @@ static jthread newThreadObj(JNIEnv* jni) { jmethodID cid; jthread result = NULL; - if (!NSK_JNI_VERIFY(jni, (thrClass = jni->FindClass("java/lang/Thread")) != NULL)) { + thrClass = jni->FindClass("java/lang/Thread"); + if (!NSK_JNI_VERIFY(jni, thrClass != NULL)) { nsk_jvmti_setFailStatus(); return result; } - if (!NSK_JNI_VERIFY(jni, (cid = jni->GetMethodID(thrClass, "", "()V")) != NULL)) { + cid = jni->GetMethodID(thrClass, "", "()V"); + if (!NSK_JNI_VERIFY(jni, cid != NULL)) { nsk_jvmti_setFailStatus(); return result; } - if (!NSK_JNI_VERIFY(jni, (result = jni->NewObject(thrClass, cid)) != NULL)) { + result = jni->NewObject(thrClass, cid); + if (!NSK_JNI_VERIFY(jni, result != NULL)) { nsk_jvmti_setFailStatus(); return result; } @@ -366,7 +369,8 @@ static int prepareToIteration (JNIEnv* jni) { setCounter(&iterationCount, 0); setCounter(&objectCount, 0); - if (!NSK_VERIFY((threadObj = newThreadObj(jni)) != NULL)) { + threadObj = newThreadObj(jni); + if (!NSK_VERIFY(threadObj != NULL)) { nsk_jvmti_setFailStatus(); return NSK_FALSE; } @@ -511,8 +515,8 @@ Java_nsk_jvmti_scenarios_allocation_AP04_ap04t003_runIterateOverObjectsReachable int modified = 0; int found = 0; - if (!NSK_JNI_VERIFY(jni, (root = - jni->GetStaticObjectField(debugeeClass, rootFieldID)) != NULL)) { + root = jni->GetStaticObjectField(debugeeClass, rootFieldID); + if (!NSK_JNI_VERIFY(jni, root != NULL)) { NSK_COMPLAIN0("GetStaticObjectField returned NULL for 'root' field value\n\n"); nsk_jvmti_setFailStatus(); return; @@ -556,12 +560,13 @@ agentProc(jvmtiEnv* jvmti, JNIEnv* jni, void* arg) { return; } - if (!NSK_JNI_VERIFY(jni, (debugeeClass = (jclass)jni->NewGlobalRef(debugeeClass)) != NULL)) + debugeeClass = (jclass) jni->NewGlobalRef(debugeeClass); + if (!NSK_JNI_VERIFY(jni, debugeeClass != NULL)) return; NSK_DISPLAY1("Find ID of 'root' field: %s\n", ROOT_SIGNATURE); - if (!NSK_JNI_VERIFY(jni, (rootFieldID = - jni->GetStaticFieldID(debugeeClass, "root", ROOT_SIGNATURE)) != NULL)) { + rootFieldID = jni->GetStaticFieldID(debugeeClass, "root", ROOT_SIGNATURE); + if (!NSK_JNI_VERIFY(jni, rootFieldID != NULL)) { nsk_jvmti_setFailStatus(); return; } @@ -602,8 +607,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { return JNI_ERR; /* create JVMTI environment */ - if (!NSK_VERIFY((jvmti = - nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("counterMonitor", &counterMonitor_ptr))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t001/bi01t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t001/bi01t001.cpp index 5406d4d2569..8d3265474df 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t001/bi01t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t001/bi01t001.cpp @@ -52,14 +52,15 @@ Java_nsk_jvmti_scenarios_bcinstr_BI01_bi01t001_setNewByteCode(JNIEnv *jni_env, jbyte* elements; jboolean isCopy; - if (!NSK_JNI_VERIFY(jni_env, (newClassSize = jni_env->GetArrayLength(byteCode)) > 0)) { + newClassSize = jni_env->GetArrayLength(byteCode); + if (!NSK_JNI_VERIFY(jni_env, newClassSize > 0)) { nsk_jvmti_setFailStatus(); return NSK_FALSE; } NSK_DISPLAY1("\t... got array size: %d\n", newClassSize); - if (!NSK_JNI_VERIFY(jni_env, (elements = - jni_env->GetByteArrayElements(byteCode, &isCopy)) != NULL)) { + elements = jni_env->GetByteArrayElements(byteCode, &isCopy); + if (!NSK_JNI_VERIFY(jni_env, elements != NULL)) { nsk_jvmti_setFailStatus(); return NSK_FALSE; } @@ -94,8 +95,8 @@ JNIEXPORT void JNICALL Java_nsk_jvmti_scenarios_bcinstr_BI01_bi01t001_setClass(JNIEnv *jni_env, jobject o, jclass cls) { - if (!NSK_JNI_VERIFY(jni_env, (oldClassDef.klass = (jclass) - jni_env->NewGlobalRef(cls)) != NULL)) { + oldClassDef.klass = (jclass) jni_env->NewGlobalRef(cls); + if (!NSK_JNI_VERIFY(jni_env, oldClassDef.klass != NULL)) { nsk_jvmti_setFailStatus(); } } @@ -242,7 +243,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t002/bi01t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t002/bi01t002.cpp index e94859ee59d..e1b79a10386 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t002/bi01t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI01/bi01t002/bi01t002.cpp @@ -54,14 +54,15 @@ Java_nsk_jvmti_scenarios_bcinstr_BI01_bi01t002_setNewByteCode(JNIEnv *jni_env, jbyte* elements; jboolean isCopy; - if (!NSK_JNI_VERIFY(jni_env, (newClassSize[ind] = jni_env->GetArrayLength(byteCode)) > 0)) { + newClassSize[ind] = jni_env->GetArrayLength(byteCode); + if (!NSK_JNI_VERIFY(jni_env, newClassSize[ind] > 0)) { nsk_jvmti_setFailStatus(); return NSK_FALSE; } NSK_DISPLAY1("\t... got array size: %d\n", newClassSize[ind]); - if (!NSK_JNI_VERIFY(jni_env, (elements = - jni_env->GetByteArrayElements(byteCode, &isCopy)) != NULL)) { + elements = jni_env->GetByteArrayElements(byteCode, &isCopy); + if (!NSK_JNI_VERIFY(jni_env, elements != NULL)) { nsk_jvmti_setFailStatus(); return NSK_FALSE; } @@ -96,8 +97,8 @@ JNIEXPORT void JNICALL Java_nsk_jvmti_scenarios_bcinstr_BI01_bi01t002_setClass(JNIEnv *jni_env, jobject o, jint ind, jclass cls) { - if (!NSK_JNI_VERIFY(jni_env, (oldClassDef[ind].klass = (jclass) - jni_env->NewGlobalRef(cls)) != NULL)) { + oldClassDef[ind].klass = (jclass) jni_env->NewGlobalRef(cls); + if (!NSK_JNI_VERIFY(jni_env, oldClassDef[ind].klass != NULL)) { nsk_jvmti_setFailStatus(); } } @@ -255,7 +256,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI04/bi04t002/bi04t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI04/bi04t002/bi04t002.cpp index 497486c7c1e..c50b4a98cc1 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI04/bi04t002/bi04t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/bcinstr/BI04/bi04t002/bi04t002.cpp @@ -97,13 +97,14 @@ agentProc(jvmtiEnv* jvmti, JNIEnv* jni, void* arg) { return; NSK_DISPLAY1("Find class: %s\n", TESTED_CLASS_NAME); - if (!NSK_JNI_VERIFY(jni, (classDef.klass = jni->FindClass(TESTED_CLASS_NAME)) != NULL)) { + classDef.klass = jni->FindClass(TESTED_CLASS_NAME); + if (!NSK_JNI_VERIFY(jni, classDef.klass != NULL)) { nsk_jvmti_setFailStatus(); return; } - if (!NSK_JNI_VERIFY(jni, (classDef.klass = (jclass) - jni->NewGlobalRef(classDef.klass)) != NULL)) { + classDef.klass = (jclass) jni->NewGlobalRef(classDef.klass); + if (!NSK_JNI_VERIFY(jni, classDef.klass != NULL)) { nsk_jvmti_setFailStatus(); return; } @@ -150,7 +151,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM01/em01t001/em01t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM01/em01t001/em01t001.cpp index 207d22ff17f..42e23cfe919 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM01/em01t001/em01t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM01/em01t001/em01t001.cpp @@ -141,7 +141,8 @@ threadEventHandler(jvmtiEvent event, jvmtiEnv* jvmti_env, JNIEnv* jni_env, jvmtiPhase phase; - if (!NSK_JNI_VERIFY(jni_env, (classObject = jni_env->GetObjectClass(thread)) != NULL)) { + classObject = jni_env->GetObjectClass(thread); + if (!NSK_JNI_VERIFY(jni_env, classObject != NULL)) { nsk_jvmti_setFailStatus(); return; } @@ -428,7 +429,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; classLoaderCount = nsk_jvmti_findOptionIntValue(CLASS_LOADER_COUNT_PARAM, 10); - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("_syncLock", &syncLock))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM01/em01t002/em01t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM01/em01t002/em01t002.cpp index 209d361da94..d6bc0005518 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM01/em01t002/em01t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM01/em01t002/em01t002.cpp @@ -65,20 +65,21 @@ Java_nsk_jvmti_scenarios_events_EM01_em01t002_loadClass(JNIEnv *jni_env, jmethodID methodID; jclass loadedClass; - if (!NSK_JNI_VERIFY(jni_env, (klass = jni_env->GetObjectClass(loader)) != NULL)) { + klass = jni_env->GetObjectClass(loader); + if (!NSK_JNI_VERIFY(jni_env, klass != NULL)) { nsk_jvmti_setFailStatus(); return NULL; } - if (!NSK_JNI_VERIFY(jni_env, - (methodID = jni_env->GetMethodID( - klass, "loadClass", "(Ljava/lang/String;)Ljava/lang/Class;")) != NULL)) { + methodID = jni_env->GetMethodID( + klass, "loadClass", "(Ljava/lang/String;)Ljava/lang/Class;"); + if (!NSK_JNI_VERIFY(jni_env, methodID != NULL)) { nsk_jvmti_setFailStatus(); return NULL; } - if (!NSK_JNI_VERIFY(jni_env, (loadedClass = (jclass) - jni_env->CallObjectMethod(loader, methodID, className)) != NULL)) { + loadedClass = (jclass) jni_env->CallObjectMethod(loader, methodID, className); + if (!NSK_JNI_VERIFY(jni_env, loadedClass != NULL)) { nsk_jvmti_setFailStatus(); return NULL; } @@ -96,8 +97,8 @@ Java_nsk_jvmti_scenarios_events_EM01_em01t002_prepareClass(JNIEnv *jni_env, jobject o, jclass klass) { jfieldID fieldID; - if (!NSK_JNI_VERIFY(jni_env, (fieldID = - jni_env->GetStaticFieldID(klass, "toProvokePreparation", "I")) != NULL)) { + fieldID = jni_env->GetStaticFieldID(klass, "toProvokePreparation", "I"); + if (!NSK_JNI_VERIFY(jni_env, fieldID != NULL)) { nsk_jvmti_setFailStatus(); return NSK_FALSE; } @@ -116,13 +117,14 @@ Java_nsk_jvmti_scenarios_events_EM01_em01t002_startThread(JNIEnv *jni_env, jclass klass; jmethodID methodID; - if (!NSK_JNI_VERIFY(jni_env, (klass = jni_env->GetObjectClass(thread)) != NULL)) { + klass = jni_env->GetObjectClass(thread); + if (!NSK_JNI_VERIFY(jni_env, klass != NULL)) { nsk_jvmti_setFailStatus(); return NSK_FALSE; } - if (!NSK_JNI_VERIFY(jni_env, (methodID = - jni_env->GetMethodID(klass, "start", "()V")) != NULL)) { + methodID = jni_env->GetMethodID(klass, "start", "()V"); + if (!NSK_JNI_VERIFY(jni_env, methodID != NULL)) { nsk_jvmti_setFailStatus(); return NSK_FALSE; } @@ -228,7 +230,8 @@ threadEventHandler(jvmtiEvent event, jvmtiEnv* jvmti_env, JNIEnv* jni_env, jvmtiPhase phase; - if (!NSK_JNI_VERIFY(jni_env, (classObject = jni_env->GetObjectClass(thread)) != NULL)) { + classObject = jni_env->GetObjectClass(thread); + if (!NSK_JNI_VERIFY(jni_env, classObject != NULL)) { nsk_jvmti_setFailStatus(); return; } @@ -521,7 +524,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; classLoaderCount = nsk_jvmti_findOptionIntValue(CLASS_LOADER_COUNT_PARAM, 10); - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("_syncLock", &syncLock))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t001/em02t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t001/em02t001.cpp index fe6fbf6972e..a3a14c0d580 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t001/em02t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t001/em02t001.cpp @@ -105,11 +105,12 @@ getStaticObjField(const char* className, const char* objFieldName, jfieldID fieldID; jclass klass = NULL; - if (!NSK_JNI_VERIFY(jni, (klass = jni->FindClass(className)) != NULL)) + klass = jni->FindClass(className); + if (!NSK_JNI_VERIFY(jni, klass != NULL)) return NULL; - if (!NSK_JNI_VERIFY(jni, (fieldID = - jni->GetStaticFieldID(klass, objFieldName, signature)) != NULL)) + fieldID = jni->GetStaticFieldID(klass, objFieldName, signature); + if (!NSK_JNI_VERIFY(jni, fieldID != NULL)) return NULL; return jni->GetStaticObjectField(klass, fieldID); @@ -119,42 +120,46 @@ getStaticObjField(const char* className, const char* objFieldName, static int prepare() { - if (!NSK_VERIFY((mainThread = findThread(MAIN_THREAD_NAME))!= NULL)) { + mainThread = findThread(MAIN_THREAD_NAME); + if (!NSK_VERIFY(mainThread != NULL)) { NSK_COMPLAIN1("<%s> thread not found\n", MAIN_THREAD_NAME); return NSK_FALSE; } /* make thread accessable for a long time */ - if (!NSK_JNI_VERIFY(jni, (mainThread = jni->NewGlobalRef(mainThread)) != NULL)) + mainThread = jni->NewGlobalRef(mainThread); + if (!NSK_JNI_VERIFY(jni, mainThread != NULL)) return NSK_FALSE; - if (!NSK_VERIFY((startObject = - getStaticObjField(DEBUGEE_CLASS_NAME, START_FIELD_NAME, - OBJECT_FIELD_SIG)) != NULL)) + startObject = getStaticObjField(DEBUGEE_CLASS_NAME, START_FIELD_NAME, OBJECT_FIELD_SIG); + if (!NSK_VERIFY(startObject != NULL)) return NSK_FALSE; /*make object accessable for a long time*/ - if (!NSK_JNI_VERIFY(jni, (startObject = jni->NewGlobalRef(startObject)) != NULL)) + startObject = jni->NewGlobalRef(startObject); + if (!NSK_JNI_VERIFY(jni, startObject != NULL)) return NSK_FALSE; - if (!NSK_VERIFY((endObject = - getStaticObjField(DEBUGEE_CLASS_NAME, END_FIELD_NAME, - OBJECT_FIELD_SIG)) != NULL)) + endObject = getStaticObjField(DEBUGEE_CLASS_NAME, END_FIELD_NAME, OBJECT_FIELD_SIG); + if (!NSK_VERIFY(endObject != NULL)) return NSK_FALSE; /*make object accessable for a long time*/ - if (!NSK_JNI_VERIFY(jni, (endObject = jni->NewGlobalRef(endObject)) != NULL)) + endObject = jni->NewGlobalRef(endObject); + if (!NSK_JNI_VERIFY(jni, endObject != NULL)) return NSK_FALSE; - if (!NSK_VERIFY((debuggeeThread = - (jthread)getStaticObjField(DEBUGEE_CLASS_NAME, THREAD_FIELD_NAME, - THREAD_FIELD_SIG)) != NULL)) + debuggeeThread = (jthread) getStaticObjField(DEBUGEE_CLASS_NAME, + THREAD_FIELD_NAME, + THREAD_FIELD_SIG); + if (!NSK_VERIFY(debuggeeThread != NULL)) return NSK_FALSE; /* make thread accessable for a long time */ - if (!NSK_JNI_VERIFY(jni, (debuggeeThread = jni->NewGlobalRef(debuggeeThread)) != NULL)) + debuggeeThread = jni->NewGlobalRef(debuggeeThread); + if (!NSK_JNI_VERIFY(jni, debuggeeThread != NULL)) return NSK_FALSE; return NSK_TRUE; @@ -751,7 +756,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("_syncLock", &syncLock))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t002/em02t002.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t002/em02t002.cpp index 7b86f45cc34..467624e5947 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t002/em02t002.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t002/em02t002.cpp @@ -509,7 +509,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("_syncLock", &syncLock))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t003/em02t003.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t003/em02t003.cpp index b541f230913..fa29f485a62 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t003/em02t003.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t003/em02t003.cpp @@ -548,7 +548,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("_syncLock", &syncLock))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t004/em02t004.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t004/em02t004.cpp index 194bc6c9ef9..ae54d508d94 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t004/em02t004.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t004/em02t004.cpp @@ -554,7 +554,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("_syncLock", &syncLock))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t005/em02t005.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t005/em02t005.cpp index ee9a28eb1cb..1c52c529050 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t005/em02t005.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t005/em02t005.cpp @@ -534,7 +534,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t006/em02t006.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t006/em02t006.cpp index 40d3ecea4bd..38e5c715d95 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t006/em02t006.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t006/em02t006.cpp @@ -485,7 +485,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("_syncLock", &syncLock))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t007/em02t007.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t007/em02t007.cpp index 9afb751bd82..29f0a5b6e36 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t007/em02t007.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t007/em02t007.cpp @@ -521,7 +521,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("_syncLock", &syncLock))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t008/em02t008.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t008/em02t008.cpp index 51a29f81182..f6413d04377 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t008/em02t008.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t008/em02t008.cpp @@ -533,7 +533,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("_syncLock", &syncLock))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t009/em02t009.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t009/em02t009.cpp index 979386ee212..f401dcf06f9 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t009/em02t009.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t009/em02t009.cpp @@ -540,7 +540,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("_syncLock", &syncLock))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t010/em02t010.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t010/em02t010.cpp index baea21338d3..23a43ccb75e 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t010/em02t010.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t010/em02t010.cpp @@ -459,15 +459,16 @@ agentProc(jvmtiEnv* jvmti, JNIEnv* agentJNI, void* arg) { if (!nsk_jvmti_waitForSync(timeout)) return; - if (!NSK_JNI_VERIFY(agentJNI, (cls = agentJNI->FindClass(CLASS_NAME)) != NULL)) + cls = agentJNI->FindClass(CLASS_NAME); + if (!NSK_JNI_VERIFY(agentJNI, cls != NULL)) return; - if (!NSK_JNI_VERIFY(agentJNI, (field_accID = - agentJNI->GetStaticFieldID(cls, FIELD_ACC_NAME, "I")) != NULL)) + field_accID = agentJNI->GetStaticFieldID(cls, FIELD_ACC_NAME, "I"); + if (!NSK_JNI_VERIFY(agentJNI, field_accID != NULL)) return; - if (!NSK_JNI_VERIFY(agentJNI, (field_modID = - agentJNI->GetStaticFieldID(cls, FIELD_MOD_NAME, "I")) != NULL)) + field_modID = agentJNI->GetStaticFieldID(cls, FIELD_MOD_NAME, "I"); + if (!NSK_JNI_VERIFY(agentJNI, field_modID != NULL)) return; if (!NSK_JVMTI_VERIFY(jvmti->SetFieldModificationWatch(cls, field_modID))) @@ -521,7 +522,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("_syncLock", &syncLock))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t011/em02t011.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t011/em02t011.cpp index a145db72100..307126b636e 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t011/em02t011.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t011/em02t011.cpp @@ -444,11 +444,12 @@ agentProc(jvmtiEnv* jvmti, JNIEnv* agentJNI, void* arg) { if (!nsk_jvmti_waitForSync(timeout)) return; - if (!NSK_JNI_VERIFY(agentJNI, (cls = agentJNI->FindClass(CLASS_NAME)) != NULL)) + cls = agentJNI->FindClass(CLASS_NAME); + if (!NSK_JNI_VERIFY(agentJNI, cls != NULL)) return; - if (!NSK_JNI_VERIFY(agentJNI, (methodID = - agentJNI->GetStaticMethodID(cls, METHOD_NAME, "()I")) != NULL)) + methodID = agentJNI->GetStaticMethodID(cls, METHOD_NAME, "()I"); + if (!NSK_JNI_VERIFY(agentJNI, methodID != NULL)) return; if (!NSK_JVMTI_VERIFY(jvmti->SetBreakpoint(methodID, 0))) @@ -499,7 +500,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("_syncLock", &syncLock))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t012/em02t012.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t012/em02t012.cpp index 185ae70bf31..8fce2c7aedc 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t012/em02t012.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM02/em02t012/em02t012.cpp @@ -52,7 +52,8 @@ Java_nsk_jvmti_scenarios_events_EM02_em02t012_setThread(JNIEnv *jni_env, jobject o, jthread thrd) { /* make thread accessable for a long time */ - NSK_JNI_VERIFY(jni_env, (testedThread = jni_env->NewGlobalRef(thrd)) != NULL); + testedThread = jni_env->NewGlobalRef(thrd); + NSK_JNI_VERIFY(jni_env, testedThread != NULL); } static void @@ -502,7 +503,8 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; if (!NSK_JVMTI_VERIFY(jvmti->CreateRawMonitor("_syncLock", &syncLock))) { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM04/em04t001/em04t001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM04/em04t001/em04t001.cpp index 7c4318f9589..ae241b7582b 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM04/em04t001/em04t001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/scenarios/events/EM04/em04t001/em04t001.cpp @@ -199,10 +199,12 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { timeout = nsk_jvmti_getWaitTime() * 60 * 1000; - if (!NSK_VERIFY((jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved)) != NULL)) + jvmti = nsk_jvmti_createJVMTIEnv(jvm, reserved); + if (!NSK_VERIFY(jvmti != NULL)) return JNI_ERR; - if (!NSK_VERIFY((plist = (const void *)nsk_list_create()) != NULL)) + plist = (const void *)nsk_list_create(); + if (!NSK_VERIFY(plist != NULL)) return JNI_ERR; NSK_DISPLAY1("plist = 0x%p\n", plist); From 3837f1abc10bb0fc1662feea2251a84af2903970 Mon Sep 17 00:00:00 2001 From: David Holmes Date: Thu, 25 Oct 2018 19:12:39 -0400 Subject: [PATCH 24/84] 8210242: vmTestbase/nsk/stress/jni/jnistress001.java crashes with EXCEPTION_ACCESS_VIOLATION on windows-x86 Non-NUL-terminated string was passed to %s - use %.*s to specify the actual length. Reviewed-by: lfoltan, hseigel --- .../vmTestbase/nsk/stress/jni/jnihelper.h | 10 +++++ .../nsk/stress/jni/libjnistress001.cpp | 37 ++++++++++--------- 2 files changed, 30 insertions(+), 17 deletions(-) diff --git a/test/hotspot/jtreg/vmTestbase/nsk/stress/jni/jnihelper.h b/test/hotspot/jtreg/vmTestbase/nsk/stress/jni/jnihelper.h index 753e3048f4d..00c3e2a572b 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/stress/jni/jnihelper.h +++ b/test/hotspot/jtreg/vmTestbase/nsk/stress/jni/jnihelper.h @@ -21,6 +21,16 @@ * questions. */ +#include + +// checked malloc to trap OOM conditions +static void* c_malloc(JNIEnv* env, size_t size) { + void* ret = malloc(size); + if (ret == NULL) + env->FatalError("malloc failed"); + return ret; +} + // Asserts every exception as fatal one #define CE {\ if (env->ExceptionOccurred())\ diff --git a/test/hotspot/jtreg/vmTestbase/nsk/stress/jni/libjnistress001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/stress/jni/libjnistress001.cpp index e57cf28b3a1..2f70e8187ae 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/stress/jni/libjnistress001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/stress/jni/libjnistress001.cpp @@ -66,11 +66,11 @@ Java_nsk_stress_jni_JNIter001_jnistress (JNIEnv *env, jobject jobj, jstring jstr env->MonitorEnter(jobj); CE if (!allocs) { - element = (CHAR_ARRAY *)malloc(sizeof(CHAR_ARRAY)); - element->str = (const char **)malloc(nstr*sizeof(const char *)); - element->checkstr = (char **)malloc(nstr*sizeof(char *)); + element = (CHAR_ARRAY *)c_malloc(env, sizeof(CHAR_ARRAY)); + element->str = (const char **)c_malloc(env, nstr*sizeof(const char *)); + element->checkstr = (char **)c_malloc(env, nstr*sizeof(char *)); for (j=0;jcheckstr[j] = (char *)malloc(DIGESTLENGTH*sizeof(char)); + element->checkstr[j] = (char *)c_malloc(env, DIGESTLENGTH*sizeof(char)); } for(j=0;jMonitorEnter(jobj); CE if (!index) { - javachars = (JCHAR_ARRAY *)malloc(sizeof(JCHAR_ARRAY)); - javachars->str = (const jchar **)malloc(nstr*sizeof(const jchar *)); - javachars->checkstr = (char **)malloc(nstr*sizeof(char *)); - javachars->size = (int *)malloc(nstr*sizeof(int)); + javachars = (JCHAR_ARRAY *)c_malloc(env, sizeof(JCHAR_ARRAY)); + javachars->str = (const jchar **)c_malloc(env, nstr*sizeof(const jchar *)); + javachars->checkstr = (char **)c_malloc(env, nstr*sizeof(char *)); + javachars->size = (int *)c_malloc(env, nstr*sizeof(int)); for (j=0;jcheckstr[j] = (char *)malloc(DIGESTLENGTH*sizeof(char)); + javachars->checkstr[j] = (char *)c_malloc(env, DIGESTLENGTH*sizeof(char)); } for(j=0;jstr[index] = env->GetStringChars(jstr,0); CE javachars->size[index] = env->GetStringUTFLength(jstr); CE - len += javachars->size[index]; - elem = (char*) malloc(javachars->size[index]*sizeof(char)); - for (j=0; j < javachars->size[index]; j++) { + elem_len = javachars->size[index]; + len += elem_len; + elem = (char*) c_malloc(env, elem_len*sizeof(char)); + for (j=0; j < elem_len; j++) { elem[j] = (char) javachars->str[index][j]; } + //memcpy(digest, elem, javachars->size[index]); - for(j=0;jsize[index]; j++) { + for(j=0;jcheckstr[index++],digest,DIGESTLENGTH); if (index%printperiod==0) { - printf("Check string sum for thread %s is ",elem); + printf("Check string sum for thread %.*s is ", elem_len, elem); for (j=0;jNewString(javachars->str[index-1],javachars->size[index-1]); CE + tmpstr=env->NewString(javachars->str[index-1],elem_len); CE for (j=0; jsize[j]*sizeof(char)); + elem = (char*) c_malloc(env, javachars->size[j]*sizeof(char)); for (i=0; i < javachars->size[j]; i++) { elem[i] = (char) javachars->str[j][i]; } @@ -237,7 +240,7 @@ Java_nsk_stress_jni_JNIter001_jnistress1(JNIEnv *env, jobject jobj, jstring jstr return(tmpstr); } env->MonitorExit(jobj); CE - return(env->NewString(javachars->str[index-1],javachars->size[index-1])); + return(env->NewString(javachars->str[index-1],elem_len)); } } From 8b98cc3722931fa74fccb6543554e8ebbbf7a43b Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Thu, 25 Oct 2018 16:47:14 -0700 Subject: [PATCH 25/84] 8213005: Missing symbols in hs_err files on Windows after JDK-8212028 Reviewed-by: ctornqvi --- make/RunTests.gmk | 10 +++++++--- make/RunTestsPrebuiltSpec.gmk | 4 ++++ 2 files changed, 11 insertions(+), 3 deletions(-) diff --git a/make/RunTests.gmk b/make/RunTests.gmk index a252d2c0987..cffa93aae37 100644 --- a/make/RunTests.gmk +++ b/make/RunTests.gmk @@ -65,10 +65,14 @@ ifeq ($(OPENJDK_TARGET_OS), windows) ifndef _NT_SYMBOL_PATH # Can't use PathList here as it adds quotes around the value. _NT_SYMBOL_PATH := \ - $(subst $(SPACE),;, $(foreach p, $(sort $(dir $(wildcard \ - $(addprefix $(SYMBOLS_IMAGE_DIR)/bin/, *.pdb */*.pdb)))), $(call FixPath, $p))) + $(subst $(SPACE),;,$(strip \ + $(foreach p, $(sort $(dir $(wildcard \ + $(addprefix $(SYMBOLS_IMAGE_DIR)/bin/, *.pdb */*.pdb)))), \ + $(call FixPath, $p) \ + ) \ + )) export _NT_SYMBOL_PATH - $(info _NT_SYMBOL_PATH $(_NT_SYMBOL_PATH)) + $(info _NT_SYMBOL_PATH=$(_NT_SYMBOL_PATH)) endif endif diff --git a/make/RunTestsPrebuiltSpec.gmk b/make/RunTestsPrebuiltSpec.gmk index 200ab32c144..8564a1f7ddd 100644 --- a/make/RunTestsPrebuiltSpec.gmk +++ b/make/RunTestsPrebuiltSpec.gmk @@ -182,3 +182,7 @@ ifeq ($(OPENJDK_BUILD_OS), solaris) SED := gsed TAR := gtar endif + +ifeq ($(OPENJDK_BUILD_OS), windows) + CYGPATH := cygpath +endif From 7533f9f78a0612f10256aadb7392daa23ab52f4f Mon Sep 17 00:00:00 2001 From: Iris Clark Date: Thu, 25 Oct 2018 17:06:40 -0700 Subject: [PATCH 26/84] 8212994: Links to Oracle websites should use "https:" Reviewed-by: erikj, lancea --- make/Docs.gmk | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/make/Docs.gmk b/make/Docs.gmk index 65200f22512..fdaed245e76 100644 --- a/make/Docs.gmk +++ b/make/Docs.gmk @@ -61,11 +61,11 @@ MODULES_SOURCE_PATH := $(call PathList, $(call GetModuleSrcPath) \ $(SUPPORT_OUTPUTDIR)/rmic/* $(TOPDIR)/src/*/share/doc/stub) # URLs -JAVADOC_BASE_URL := http://www.oracle.com/pls/topic/lookup?ctx=javase$(VERSION_NUMBER)&id=homepage -BUG_SUBMIT_URL := http://bugreport.java.com/bugreport/ +JAVADOC_BASE_URL := https://www.oracle.com/pls/topic/lookup?ctx=javase$(VERSION_NUMBER)&id=homepage +BUG_SUBMIT_URL := https://bugreport.java.com/bugreport/ COPYRIGHT_URL := {@docroot}/../legal/copyright.html -LICENSE_URL := http://www.oracle.com/technetwork/java/javase/terms/license/java$(VERSION_NUMBER)speclicense.html -REDISTRIBUTION_URL := http://www.oracle.com/technetwork/java/redist-137594.html +LICENSE_URL := https://www.oracle.com/technetwork/java/javase/terms/license/java$(VERSION_NUMBER)speclicense.html +REDISTRIBUTION_URL := https://www.oracle.com/technetwork/java/redist-137594.html # In order to get a specific ordering it's necessary to specify the total # ordering of tags as the tags are otherwise ordered in order of definition. From c24f6506e7727d24ba2740c41532df0960aa2a3f Mon Sep 17 00:00:00 2001 From: Dean Long Date: Thu, 25 Oct 2018 18:41:26 -0700 Subject: [PATCH 27/84] 8021335: Missing synchronization when reading counters for live threads and peak thread count Reviewed-by: dholmes, mchung --- src/hotspot/share/runtime/thread.cpp | 12 ++- src/hotspot/share/services/threadService.cpp | 100 ++++++++++++++---- src/hotspot/share/services/threadService.hpp | 21 ++-- .../ThreadMXBean/ResetPeakThreadCount.java | 10 -- 4 files changed, 96 insertions(+), 47 deletions(-) diff --git a/src/hotspot/share/runtime/thread.cpp b/src/hotspot/share/runtime/thread.cpp index 3d4ba5171e8..1ad7accf25d 100644 --- a/src/hotspot/share/runtime/thread.cpp +++ b/src/hotspot/share/runtime/thread.cpp @@ -1819,6 +1819,9 @@ static void ensure_join(JavaThread* thread) { thread->clear_pending_exception(); } +static bool is_daemon(oop threadObj) { + return (threadObj != NULL && java_lang_Thread::is_daemon(threadObj)); +} // For any new cleanup additions, please check to see if they need to be applied to // cleanup_failed_attach_current_thread as well. @@ -1910,7 +1913,7 @@ void JavaThread::exit(bool destroy_vm, ExitType exit_type) { MutexLockerEx ml(SR_lock(), Mutex::_no_safepoint_check_flag); if (!is_external_suspend()) { set_terminated(_thread_exiting); - ThreadService::current_thread_exiting(this); + ThreadService::current_thread_exiting(this, is_daemon(threadObj())); break; } // Implied else: @@ -1930,6 +1933,7 @@ void JavaThread::exit(bool destroy_vm, ExitType exit_type) { } // no more external suspends are allowed at this point } else { + assert(!is_terminated() && !is_exiting(), "must not be exiting"); // before_exit() has already posted JVMTI THREAD_END events } @@ -4332,7 +4336,7 @@ jboolean Threads::is_supported_jni_version(jint version) { void Threads::add(JavaThread* p, bool force_daemon) { // The threads lock must be owned at this point - assert_locked_or_safepoint(Threads_lock); + assert(Threads_lock->owned_by_self(), "must have threads lock"); BarrierSet::barrier_set()->on_thread_attach(p); @@ -4348,7 +4352,7 @@ void Threads::add(JavaThread* p, bool force_daemon) { bool daemon = true; // Bootstrapping problem: threadObj can be null for initial // JavaThread (or for threads attached via JNI) - if ((!force_daemon) && (threadObj == NULL || !java_lang_Thread::is_daemon(threadObj))) { + if ((!force_daemon) && !is_daemon((threadObj))) { _number_of_non_daemon_threads++; daemon = false; } @@ -4393,7 +4397,7 @@ void Threads::remove(JavaThread* p) { _number_of_threads--; oop threadObj = p->threadObj(); bool daemon = true; - if (threadObj == NULL || !java_lang_Thread::is_daemon(threadObj)) { + if (!is_daemon(threadObj)) { _number_of_non_daemon_threads--; daemon = false; diff --git a/src/hotspot/share/services/threadService.cpp b/src/hotspot/share/services/threadService.cpp index 3be2e17f12c..89e88af2364 100644 --- a/src/hotspot/share/services/threadService.cpp +++ b/src/hotspot/share/services/threadService.cpp @@ -57,8 +57,8 @@ PerfCounter* ThreadService::_total_threads_count = NULL; PerfVariable* ThreadService::_live_threads_count = NULL; PerfVariable* ThreadService::_peak_threads_count = NULL; PerfVariable* ThreadService::_daemon_threads_count = NULL; -volatile int ThreadService::_exiting_threads_count = 0; -volatile int ThreadService::_exiting_daemon_threads_count = 0; +volatile int ThreadService::_atomic_threads_count = 0; +volatile int ThreadService::_atomic_daemon_threads_count = 0; ThreadDumpResult* ThreadService::_threaddump_list = NULL; @@ -101,50 +101,104 @@ void ThreadService::reset_peak_thread_count() { _peak_threads_count->set_value(get_live_thread_count()); } +static bool is_hidden_thread(JavaThread *thread) { + // hide VM internal or JVMTI agent threads + return thread->is_hidden_from_external_view() || thread->is_jvmti_agent_thread(); +} + void ThreadService::add_thread(JavaThread* thread, bool daemon) { - // Do not count VM internal or JVMTI agent threads - if (thread->is_hidden_from_external_view() || - thread->is_jvmti_agent_thread()) { + assert(Threads_lock->owned_by_self(), "must have threads lock"); + + // Do not count hidden threads + if (is_hidden_thread(thread)) { return; } _total_threads_count->inc(); _live_threads_count->inc(); + Atomic::inc(&_atomic_threads_count); + int count = _atomic_threads_count; - if (_live_threads_count->get_value() > _peak_threads_count->get_value()) { - _peak_threads_count->set_value(_live_threads_count->get_value()); + if (count > _peak_threads_count->get_value()) { + _peak_threads_count->set_value(count); } if (daemon) { _daemon_threads_count->inc(); + Atomic::inc(&_atomic_daemon_threads_count); + } +} + +void ThreadService::decrement_thread_counts(JavaThread* jt, bool daemon) { + Atomic::dec(&_atomic_threads_count); + + if (daemon) { + Atomic::dec(&_atomic_daemon_threads_count); } } void ThreadService::remove_thread(JavaThread* thread, bool daemon) { - Atomic::dec(&_exiting_threads_count); - if (daemon) { - Atomic::dec(&_exiting_daemon_threads_count); - } + assert(Threads_lock->owned_by_self(), "must have threads lock"); - if (thread->is_hidden_from_external_view() || - thread->is_jvmti_agent_thread()) { + // Do not count hidden threads + if (is_hidden_thread(thread)) { return; } - _live_threads_count->set_value(_live_threads_count->get_value() - 1); - if (daemon) { - _daemon_threads_count->set_value(_daemon_threads_count->get_value() - 1); + assert(!thread->is_terminated(), "must not be terminated"); + if (!thread->is_exiting()) { + // JavaThread::exit() skipped calling current_thread_exiting() + decrement_thread_counts(thread, daemon); } + + int daemon_count = _atomic_daemon_threads_count; + int count = _atomic_threads_count; + + // Counts are incremented at the same time, but atomic counts are + // decremented earlier than perf counts. + assert(_live_threads_count->get_value() > count, + "thread count mismatch %d : %d", + (int)_live_threads_count->get_value(), count); + + _live_threads_count->dec(1); + if (daemon) { + assert(_daemon_threads_count->get_value() > daemon_count, + "thread count mismatch %d : %d", + (int)_daemon_threads_count->get_value(), daemon_count); + + _daemon_threads_count->dec(1); + } + + // Counts are incremented at the same time, but atomic counts are + // decremented earlier than perf counts. + assert(_daemon_threads_count->get_value() >= daemon_count, + "thread count mismatch %d : %d", + (int)_daemon_threads_count->get_value(), daemon_count); + assert(_live_threads_count->get_value() >= count, + "thread count mismatch %d : %d", + (int)_live_threads_count->get_value(), count); + assert(_live_threads_count->get_value() > 0 || + (_live_threads_count->get_value() == 0 && count == 0 && + _daemon_threads_count->get_value() == 0 && daemon_count == 0), + "thread counts should reach 0 at the same time, live %d,%d daemon %d,%d", + (int)_live_threads_count->get_value(), count, + (int)_daemon_threads_count->get_value(), daemon_count); + assert(_daemon_threads_count->get_value() > 0 || + (_daemon_threads_count->get_value() == 0 && daemon_count == 0), + "thread counts should reach 0 at the same time, daemon %d,%d", + (int)_daemon_threads_count->get_value(), daemon_count); } -void ThreadService::current_thread_exiting(JavaThread* jt) { - assert(jt == JavaThread::current(), "Called by current thread"); - Atomic::inc(&_exiting_threads_count); - - oop threadObj = jt->threadObj(); - if (threadObj != NULL && java_lang_Thread::is_daemon(threadObj)) { - Atomic::inc(&_exiting_daemon_threads_count); +void ThreadService::current_thread_exiting(JavaThread* jt, bool daemon) { + // Do not count hidden threads + if (is_hidden_thread(jt)) { + return; } + + assert(jt == JavaThread::current(), "Called by current thread"); + assert(!jt->is_terminated() && jt->is_exiting(), "must be exiting"); + + decrement_thread_counts(jt, daemon); } // FIXME: JVMTI should call this function diff --git a/src/hotspot/share/services/threadService.hpp b/src/hotspot/share/services/threadService.hpp index 7967429cbc2..a09bd7d65b5 100644 --- a/src/hotspot/share/services/threadService.hpp +++ b/src/hotspot/share/services/threadService.hpp @@ -58,10 +58,12 @@ private: static PerfVariable* _peak_threads_count; static PerfVariable* _daemon_threads_count; - // These 2 counters are atomically incremented once the thread is exiting. - // They will be atomically decremented when ThreadService::remove_thread is called. - static volatile int _exiting_threads_count; - static volatile int _exiting_daemon_threads_count; + // These 2 counters are like the above thread counts, but are + // atomically decremented in ThreadService::current_thread_exiting instead of + // ThreadService::remove_thread, so that the thread count is updated before + // Thread.join() returns. + static volatile int _atomic_threads_count; + static volatile int _atomic_daemon_threads_count; static bool _thread_monitoring_contention_enabled; static bool _thread_cpu_time_enabled; @@ -72,11 +74,13 @@ private: // requested by multiple threads concurrently. static ThreadDumpResult* _threaddump_list; + static void decrement_thread_counts(JavaThread* jt, bool daemon); + public: static void init(); static void add_thread(JavaThread* thread, bool daemon); static void remove_thread(JavaThread* thread, bool daemon); - static void current_thread_exiting(JavaThread* jt); + static void current_thread_exiting(JavaThread* jt, bool daemon); static bool set_thread_monitoring_contention(bool flag); static bool is_thread_monitoring_contention() { return _thread_monitoring_contention_enabled; } @@ -89,11 +93,8 @@ public: static jlong get_total_thread_count() { return _total_threads_count->get_value(); } static jlong get_peak_thread_count() { return _peak_threads_count->get_value(); } - static jlong get_live_thread_count() { return _live_threads_count->get_value() - _exiting_threads_count; } - static jlong get_daemon_thread_count() { return _daemon_threads_count->get_value() - _exiting_daemon_threads_count; } - - static int exiting_threads_count() { return _exiting_threads_count; } - static int exiting_daemon_threads_count() { return _exiting_daemon_threads_count; } + static jlong get_live_thread_count() { return _atomic_threads_count; } + static jlong get_daemon_thread_count() { return _atomic_daemon_threads_count; } // Support for thread dump static void add_thread_dump(ThreadDumpResult* dump); diff --git a/test/jdk/java/lang/management/ThreadMXBean/ResetPeakThreadCount.java b/test/jdk/java/lang/management/ThreadMXBean/ResetPeakThreadCount.java index 414ee4b41d0..3cd0121eae0 100644 --- a/test/jdk/java/lang/management/ThreadMXBean/ResetPeakThreadCount.java +++ b/test/jdk/java/lang/management/ThreadMXBean/ResetPeakThreadCount.java @@ -158,10 +158,6 @@ public class ResetPeakThreadCount { " Expected to be == previous peak = " + peak1 + " + " + delta); } - // wait until the current thread count gets incremented - while (mbean.getThreadCount() < (current + count)) { - Thread.sleep(100); - } current = mbean.getThreadCount(); System.out.println(" Live thread count before returns " + current); return current; @@ -195,12 +191,6 @@ public class ResetPeakThreadCount { allThreads[i].join(); } - // there is a race in the counter update logic somewhere causing - // the thread counters go ff - // we need to give the terminated threads some extra time to really die - // JDK-8021335 - Thread.sleep(500); - long current = mbean.getThreadCount(); System.out.println(" Live thread count before returns " + current); return current; From ff4cf4f40b176e89366b81b9e9e679dc8345434a Mon Sep 17 00:00:00 2001 From: Tom Rodriguez Date: Thu, 25 Oct 2018 19:00:46 -0700 Subject: [PATCH 28/84] 8212956: [JVCMI] SpeculationReason should maintain identity Reviewed-by: kvn --- .../vm/ci/hotspot/HotSpotSpeculationLog.java | 23 +++++++-- .../src/jdk/vm/ci/meta/SpeculationLog.java | 14 ++++++ .../ci/runtime/test/TestSpeculationLog.java | 50 +++++++++++++++++++ 3 files changed, 82 insertions(+), 5 deletions(-) create mode 100644 test/hotspot/jtreg/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestSpeculationLog.java diff --git a/src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotSpeculationLog.java b/src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotSpeculationLog.java index 2d265c3f8df..0880a1f0e91 100644 --- a/src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotSpeculationLog.java +++ b/src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotSpeculationLog.java @@ -51,7 +51,7 @@ public class HotSpotSpeculationLog implements SpeculationLog { private Set failedSpeculations; /** Strong references to all reasons embedded in the current nmethod. */ - private Map speculations; + private HashMap speculations; private long currentSpeculationID; @@ -62,7 +62,7 @@ public class HotSpotSpeculationLog implements SpeculationLog { failedSpeculations = new HashSet<>(2); } if (speculations != null) { - SpeculationReason lastFailedSpeculation = speculations.get(lastFailed); + SpeculationReason lastFailedSpeculation = lookupSpeculation(this.lastFailed); if (lastFailedSpeculation != null) { failedSpeculations.add(lastFailedSpeculation); } @@ -72,6 +72,15 @@ public class HotSpotSpeculationLog implements SpeculationLog { } } + private SpeculationReason lookupSpeculation(long value) { + for (Map.Entry entry : speculations.entrySet()) { + if (value == entry.getValue().asLong()) { + return entry.getKey(); + } + } + return null; + } + @Override public synchronized boolean maySpeculate(SpeculationReason reason) { if (failedSpeculations != null && failedSpeculations.contains(reason)) { @@ -85,8 +94,12 @@ public class HotSpotSpeculationLog implements SpeculationLog { if (speculations == null) { speculations = new HashMap<>(); } - speculations.put(++currentSpeculationID, reason); - return new HotSpotSpeculation(reason, JavaConstant.forLong(currentSpeculationID)); + JavaConstant id = speculations.get(reason); + if (id == null) { + id = JavaConstant.forLong(++currentSpeculationID); + speculations.put(reason, id); + } + return new HotSpotSpeculation(reason, id); } @Override @@ -99,7 +112,7 @@ public class HotSpotSpeculationLog implements SpeculationLog { if (constant.isDefaultForKind()) { return NO_SPECULATION; } - SpeculationReason reason = speculations.get(constant.asLong()); + SpeculationReason reason = lookupSpeculation(constant.asLong()); assert reason != null : "Speculation should have been registered"; return new HotSpotSpeculation(reason, constant); } diff --git a/src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/SpeculationLog.java b/src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/SpeculationLog.java index 2a7a09b0c5e..612699ad925 100644 --- a/src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/SpeculationLog.java +++ b/src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.meta/src/jdk/vm/ci/meta/SpeculationLog.java @@ -58,6 +58,20 @@ public interface SpeculationLog { public String toString() { return reason.toString(); } + + @Override + public boolean equals(Object obj) { + if (obj instanceof Speculation) { + Speculation other = (Speculation) obj; + return reason.equals(other.reason); + } + return false; + } + + @Override + public int hashCode() { + return getReason().hashCode(); + } } Speculation NO_SPECULATION = new Speculation(new NoSpeculationReason()); diff --git a/test/hotspot/jtreg/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestSpeculationLog.java b/test/hotspot/jtreg/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestSpeculationLog.java new file mode 100644 index 00000000000..4ae2536bc33 --- /dev/null +++ b/test/hotspot/jtreg/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestSpeculationLog.java @@ -0,0 +1,50 @@ +/* + * Copyright (c) 2018, 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.vm.ci.runtime.test; + +import org.junit.Assert; +import org.junit.Test; + +import jdk.vm.ci.meta.JavaConstant; +import jdk.vm.ci.meta.SpeculationLog; + +public class TestSpeculationLog extends MethodUniverse { + + static class Dummy implements SpeculationLog.SpeculationReason { + + } + + @Test + public void testSpeculationIdentity() { + Dummy spec = new Dummy(); + SpeculationLog log = methods.entrySet().iterator().next().getValue().getSpeculationLog(); + SpeculationLog.Speculation s1 = log.speculate(spec); + SpeculationLog.Speculation s2 = log.speculate(spec); + Assert.assertTrue("Speculation should maintain identity", s1.equals(s2)); + JavaConstant e1 = metaAccess.encodeSpeculation(s1); + JavaConstant e2 = metaAccess.encodeSpeculation(s2); + Assert.assertTrue("speculation encoding should maintain identity", e1.equals(e2)); + } +} From 8dbea74827173c0db6d523891165f4ab3f48d0be Mon Sep 17 00:00:00 2001 From: Weijun Wang Date: Fri, 26 Oct 2018 11:11:13 +0800 Subject: [PATCH 29/84] 8212867: Link to DRBG test vectors is redirected to a broken link Reviewed-by: mullan --- .../share/classes/java/security/DrbgParameters.java | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/src/java.base/share/classes/java/security/DrbgParameters.java b/src/java.base/share/classes/java/security/DrbgParameters.java index 4dba498faf1..030836ba570 100644 --- a/src/java.base/share/classes/java/security/DrbgParameters.java +++ b/src/java.base/share/classes/java/security/DrbgParameters.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2018, 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 @@ -225,10 +225,6 @@ import java.util.Objects; *

* Calling {@link SecureRandom#generateSeed(int)} will directly read * from this system default entropy source. - *

- * This implementation has passed all tests included in the 20151104 version of - * - * The DRBG Test Vectors. * * @since 9 */ From 7c81535d46b9fb6bf8fb7d359beb9161aca5f950 Mon Sep 17 00:00:00 2001 From: Calvin Cheung Date: Thu, 25 Oct 2018 21:40:17 -0700 Subject: [PATCH 30/84] 8209598: Clean up how messages are printed when CDS aborts start-up Added a new function vm_exit_during_cds_dumping() to java.cpp so that it can be used when an error condition is encountered during CDS dumping. Reviewed-by: iklam, dholmes, jiangli --- src/hotspot/share/classfile/classLoader.cpp | 16 +++++++-------- .../share/classfile/classLoaderExt.cpp | 3 +-- src/hotspot/share/memory/metaspace.cpp | 7 +++---- src/hotspot/share/memory/metaspaceShared.cpp | 7 +++---- src/hotspot/share/runtime/java.cpp | 20 +++++++++++++++++++ src/hotspot/share/runtime/java.hpp | 2 ++ 6 files changed, 37 insertions(+), 18 deletions(-) diff --git a/src/hotspot/share/classfile/classLoader.cpp b/src/hotspot/share/classfile/classLoader.cpp index bd36f7bbc51..b033639b7b9 100644 --- a/src/hotspot/share/classfile/classLoader.cpp +++ b/src/hotspot/share/classfile/classLoader.cpp @@ -1471,16 +1471,16 @@ void ClassLoader::record_result(InstanceKlass* ik, const ClassFileStream* stream // if no protocol prefix is found, path is the same as stream->source() char* path = skip_uri_protocol(src); char* canonical_class_src_path = NEW_RESOURCE_ARRAY_IN_THREAD(THREAD, char, JVM_MAXPATHLEN); - if (!get_canonical_path(path, canonical_class_src_path, JVM_MAXPATHLEN)) { - tty->print_cr("Bad pathname %s. CDS dump aborted.", path); - vm_exit(1); - } + bool success = get_canonical_path(path, canonical_class_src_path, JVM_MAXPATHLEN); + // The path is from the ClassFileStream. Since a ClassFileStream has been created successfully in functions + // such as ClassLoader::load_class(), its source path must be valid. + assert(success, "must be valid path"); for (int i = 0; i < FileMapInfo::get_number_of_shared_paths(); i++) { SharedClassPathEntry* ent = FileMapInfo::shared_path(i); - if (!get_canonical_path(ent->name(), canonical_path_table_entry, JVM_MAXPATHLEN)) { - tty->print_cr("Bad pathname %s. CDS dump aborted.", ent->name()); - vm_exit(1); - } + success = get_canonical_path(ent->name(), canonical_path_table_entry, JVM_MAXPATHLEN); + // A shared path has been validated during its creation in ClassLoader::create_class_path_entry(), + // it must be valid here. + assert(success, "must be valid path"); // If the path (from the class stream source) is the same as the shared // class or module path, then we have a match. if (strcmp(canonical_path_table_entry, canonical_class_src_path) == 0) { diff --git a/src/hotspot/share/classfile/classLoaderExt.cpp b/src/hotspot/share/classfile/classLoaderExt.cpp index 887e8c009ee..0a7f07c9de9 100644 --- a/src/hotspot/share/classfile/classLoaderExt.cpp +++ b/src/hotspot/share/classfile/classLoaderExt.cpp @@ -175,8 +175,7 @@ void ClassLoaderExt::process_jar_manifest(ClassPathEntry* entry, } if (strstr(manifest, "Extension-List:") != NULL) { - tty->print_cr("-Xshare:dump does not support Extension-List in JAR manifest: %s", entry->name()); - vm_exit(1); + vm_exit_during_cds_dumping(err_msg("-Xshare:dump does not support Extension-List in JAR manifest: %s", entry->name())); } char* cp_attr = get_class_path_attr(entry->name(), manifest, manifest_size); diff --git a/src/hotspot/share/memory/metaspace.cpp b/src/hotspot/share/memory/metaspace.cpp index 79154b59f28..95cdadfeb66 100644 --- a/src/hotspot/share/memory/metaspace.cpp +++ b/src/hotspot/share/memory/metaspace.cpp @@ -1291,10 +1291,9 @@ MetaWord* Metaspace::allocate(ClassLoaderData* loader_data, size_t word_size, if (DumpSharedSpaces) { // CDS dumping keeps loading classes, so if we hit an OOM we probably will keep hitting OOM. // We should abort to avoid generating a potentially bad archive. - tty->print_cr("Failed allocating metaspace object type %s of size " SIZE_FORMAT ". CDS dump aborted.", - MetaspaceObj::type_name(type), word_size * BytesPerWord); - tty->print_cr("Please increase MaxMetaspaceSize (currently " SIZE_FORMAT " bytes).", MaxMetaspaceSize); - vm_exit(1); + vm_exit_during_cds_dumping(err_msg("Failed allocating metaspace object type %s of size " SIZE_FORMAT ". CDS dump aborted.", + MetaspaceObj::type_name(type), word_size * BytesPerWord), + err_msg("Please increase MaxMetaspaceSize (currently " SIZE_FORMAT " bytes).", MaxMetaspaceSize)); } report_metadata_oome(loader_data, word_size, type, mdtype, THREAD); assert(HAS_PENDING_EXCEPTION, "sanity"); diff --git a/src/hotspot/share/memory/metaspaceShared.cpp b/src/hotspot/share/memory/metaspaceShared.cpp index 53102b12dd5..00483505c87 100644 --- a/src/hotspot/share/memory/metaspaceShared.cpp +++ b/src/hotspot/share/memory/metaspaceShared.cpp @@ -1646,12 +1646,11 @@ void MetaspaceShared::link_and_cleanup_shared_classes(TRAPS) { } while (check_closure.made_progress()); if (IgnoreUnverifiableClassesDuringDump) { - // This is useful when running JCK or SQE tests. You should not - // enable this when running real apps. + // IgnoreUnverifiableClassesDuringDump is enabled by default. + // Unverifiable classes will not be included in the CDS archive. SystemDictionary::remove_classes_in_error_state(); } else { - tty->print_cr("Please remove the unverifiable classes from your class list and try again"); - exit(1); + vm_exit_during_cds_dumping("Please remove the unverifiable classes from your class list and try again"); } } } diff --git a/src/hotspot/share/runtime/java.cpp b/src/hotspot/share/runtime/java.cpp index a49b4ab7d16..55402df6e2e 100644 --- a/src/hotspot/share/runtime/java.cpp +++ b/src/hotspot/share/runtime/java.cpp @@ -609,6 +609,26 @@ void vm_abort(bool dump_core) { ShouldNotReachHere(); } +void vm_notify_during_cds_dumping(const char* error, const char* message) { + if (error != NULL) { + tty->print_cr("Error occurred during CDS dumping"); + tty->print("%s", error); + if (message != NULL) { + tty->print_cr(": %s", message); + } + else { + tty->cr(); + } + } +} + +void vm_exit_during_cds_dumping(const char* error, const char* message) { + vm_notify_during_cds_dumping(error, message); + + // Failure during CDS dumping, we don't want to dump core + vm_abort(false); +} + void vm_notify_during_shutdown(const char* error, const char* message) { if (error != NULL) { tty->print_cr("Error occurred during initialization of VM"); diff --git a/src/hotspot/share/runtime/java.hpp b/src/hotspot/share/runtime/java.hpp index 45919900fa1..a3e92c5cda2 100644 --- a/src/hotspot/share/runtime/java.hpp +++ b/src/hotspot/share/runtime/java.hpp @@ -51,6 +51,8 @@ extern void vm_exit_during_initialization(Symbol* exception_name, const char* me extern void vm_exit_during_initialization(const char* error, const char* message = NULL); extern void vm_shutdown_during_initialization(const char* error, const char* message = NULL); +extern void vm_exit_during_cds_dumping(const char* error, const char* message = NULL); + /** * With the integration of the changes to handle the version string * as defined by JEP-223, most of the code related to handle the version From 67d76fe937264361b180f286ce8be16cadace3d2 Mon Sep 17 00:00:00 2001 From: Harold Seigel Date: Fri, 26 Oct 2018 08:23:52 -0400 Subject: [PATCH 31/84] 8192864: defmeth tests can hide failures Add a call to addFailureCount() to record previously hidden failures. Reviewed-by: lfoltan, coleenp --- .../vmTestbase/vm/runtime/defmeth/shared/DefMethTest.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/shared/DefMethTest.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/shared/DefMethTest.java index 9acdffbe280..4f1a9d56add 100644 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/shared/DefMethTest.java +++ b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/shared/DefMethTest.java @@ -1,5 +1,5 @@ /* -1;2c * Copyright (c) 2013, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2018, 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 @@ -332,7 +332,7 @@ public abstract class DefMethTest extends TestBase { e.printStackTrace(); } } - + addFailureCount(1); if (failFast) { throw new TestFailure(e.getCause()); } From e4f51809e4e539b543e4a5f54b1d31ec373ad373 Mon Sep 17 00:00:00 2001 From: Thomas Stuefe Date: Fri, 19 Oct 2018 09:39:29 +0200 Subject: [PATCH 32/84] 8212173: Thread._stack_base/_stack_size initialized too late for new threads Reviewed-by: dholmes, simonis --- src/hotspot/os/aix/os_aix.cpp | 22 +-- src/hotspot/os/bsd/os_bsd.cpp | 18 ++- src/hotspot/os/linux/os_linux.cpp | 18 ++- src/hotspot/os/solaris/os_solaris.cpp | 130 +++++++++--------- src/hotspot/os/solaris/os_solaris.hpp | 6 +- src/hotspot/os/windows/os_windows.cpp | 17 +-- src/hotspot/os_cpu/aix_ppc/os_aix_ppc.cpp | 5 - src/hotspot/os_cpu/bsd_x86/os_bsd_x86.cpp | 4 - src/hotspot/os_cpu/bsd_zero/os_bsd_zero.cpp | 4 - .../os_cpu/linux_aarch64/os_linux_aarch64.cpp | 3 - src/hotspot/os_cpu/linux_arm/os_linux_arm.cpp | 4 - src/hotspot/os_cpu/linux_ppc/os_linux_ppc.cpp | 2 - .../os_cpu/linux_s390/os_linux_s390.cpp | 3 - .../os_cpu/linux_sparc/os_linux_sparc.cpp | 2 - src/hotspot/os_cpu/linux_x86/os_linux_x86.cpp | 4 - .../os_cpu/linux_zero/os_linux_zero.cpp | 4 - .../os_cpu/windows_x86/os_windows_x86.cpp | 4 - .../share/gc/parallel/gcTaskThread.cpp | 2 - .../share/gc/shared/concurrentGCThread.cpp | 1 - src/hotspot/share/gc/shared/workgroup.cpp | 1 - .../periodic/sampling/jfrThreadSampler.cpp | 2 - src/hotspot/share/prims/jni.cpp | 1 + src/hotspot/share/runtime/os.hpp | 1 - src/hotspot/share/runtime/thread.cpp | 59 +++++--- src/hotspot/share/runtime/thread.hpp | 11 +- src/hotspot/share/runtime/vmThread.cpp | 2 +- 26 files changed, 146 insertions(+), 184 deletions(-) diff --git a/src/hotspot/os/aix/os_aix.cpp b/src/hotspot/os/aix/os_aix.cpp index 0538841dceb..a4b7b7f17fe 100644 --- a/src/hotspot/os/aix/os_aix.cpp +++ b/src/hotspot/os/aix/os_aix.cpp @@ -776,12 +776,7 @@ bool os::Aix::get_meminfo(meminfo_t* pmi) { // Thread start routine for all newly created threads static void *thread_native_entry(Thread *thread) { - // find out my own stack dimensions - { - // actually, this should do exactly the same as thread->record_stack_base_and_size... - thread->set_stack_base(os::current_stack_base()); - thread->set_stack_size(os::current_stack_size()); - } + thread->record_stack_base_and_size(); const pthread_t pthread_id = ::pthread_self(); const tid_t kernel_thread_id = ::thread_self(); @@ -834,20 +829,15 @@ static void *thread_native_entry(Thread *thread) { assert(osthread->get_state() == RUNNABLE, "invalid os thread state"); // Call one more level start routine. - thread->run(); + thread->call_run(); + + // Note: at this point the thread object may already have deleted itself. + // Prevent dereferencing it from here on out. + thread = NULL; log_info(os, thread)("Thread finished (tid: " UINTX_FORMAT ", kernel thread id: " UINTX_FORMAT ").", os::current_thread_id(), (uintx) kernel_thread_id); - // If a thread has not deleted itself ("delete this") as part of its - // termination sequence, we have to ensure thread-local-storage is - // cleared before we actually terminate. No threads should ever be - // deleted asynchronously with respect to their termination. - if (Thread::current_or_null_safe() != NULL) { - assert(Thread::current_or_null_safe() == thread, "current thread is wrong"); - thread->clear_thread_current(); - } - return 0; } diff --git a/src/hotspot/os/bsd/os_bsd.cpp b/src/hotspot/os/bsd/os_bsd.cpp index be170883bb6..ea084a116fa 100644 --- a/src/hotspot/os/bsd/os_bsd.cpp +++ b/src/hotspot/os/bsd/os_bsd.cpp @@ -644,6 +644,9 @@ static uint64_t locate_unique_thread_id(mach_port_t mach_thread_port) { // Thread start routine for all newly created threads static void *thread_native_entry(Thread *thread) { + + thread->record_stack_base_and_size(); + // Try to randomize the cache line index of hot stack frames. // This helps when threads of the same stack traces evict each other's // cache lines. The threads can be either from the same JVM instance, or @@ -696,20 +699,15 @@ static void *thread_native_entry(Thread *thread) { } // call one more level start routine - thread->run(); + thread->call_run(); + + // Note: at this point the thread object may already have deleted itself. + // Prevent dereferencing it from here on out. + thread = NULL; log_info(os, thread)("Thread finished (tid: " UINTX_FORMAT ", pthread id: " UINTX_FORMAT ").", os::current_thread_id(), (uintx) pthread_self()); - // If a thread has not deleted itself ("delete this") as part of its - // termination sequence, we have to ensure thread-local-storage is - // cleared before we actually terminate. No threads should ever be - // deleted asynchronously with respect to their termination. - if (Thread::current_or_null_safe() != NULL) { - assert(Thread::current_or_null_safe() == thread, "current thread is wrong"); - thread->clear_thread_current(); - } - return 0; } diff --git a/src/hotspot/os/linux/os_linux.cpp b/src/hotspot/os/linux/os_linux.cpp index 51dea34407a..e5accf390c4 100644 --- a/src/hotspot/os/linux/os_linux.cpp +++ b/src/hotspot/os/linux/os_linux.cpp @@ -649,6 +649,9 @@ bool os::Linux::manually_expand_stack(JavaThread * t, address addr) { // Thread start routine for all newly created threads static void *thread_native_entry(Thread *thread) { + + thread->record_stack_base_and_size(); + // Try to randomize the cache line index of hot stack frames. // This helps when threads of the same stack traces evict each other's // cache lines. The threads can be either from the same JVM instance, or @@ -695,20 +698,15 @@ static void *thread_native_entry(Thread *thread) { } // call one more level start routine - thread->run(); + thread->call_run(); + + // Note: at this point the thread object may already have deleted itself. + // Prevent dereferencing it from here on out. + thread = NULL; log_info(os, thread)("Thread finished (tid: " UINTX_FORMAT ", pthread id: " UINTX_FORMAT ").", os::current_thread_id(), (uintx) pthread_self()); - // If a thread has not deleted itself ("delete this") as part of its - // termination sequence, we have to ensure thread-local-storage is - // cleared before we actually terminate. No threads should ever be - // deleted asynchronously with respect to their termination. - if (Thread::current_or_null_safe() != NULL) { - assert(Thread::current_or_null_safe() == thread, "current thread is wrong"); - thread->clear_thread_current(); - } - return 0; } diff --git a/src/hotspot/os/solaris/os_solaris.cpp b/src/hotspot/os/solaris/os_solaris.cpp index 785f6bf4f31..dbe5abc498b 100644 --- a/src/hotspot/os/solaris/os_solaris.cpp +++ b/src/hotspot/os/solaris/os_solaris.cpp @@ -199,6 +199,10 @@ static inline stack_t get_stack_info() { return st; } +static void _handle_uncaught_cxx_exception() { + VMError::report_and_die("An uncaught C++ exception"); +} + bool os::is_primordial_thread(void) { int r = thr_main(); guarantee(r == 0 || r == 1, "CR6501650 or CR6493689"); @@ -724,6 +728,11 @@ static thread_t main_thread; // Thread start routine for all newly created threads extern "C" void* thread_native_entry(void* thread_addr) { + + Thread* thread = (Thread*)thread_addr; + + thread->record_stack_base_and_size(); + // Try to randomize the cache line index of hot stack frames. // This helps when threads of the same stack traces evict each other's // cache lines. The threads can be either from the same JVM instance, or @@ -734,7 +743,6 @@ extern "C" void* thread_native_entry(void* thread_addr) { alloca(((pid ^ counter++) & 7) * 128); int prio; - Thread* thread = (Thread*)thread_addr; thread->initialize_thread_current(); @@ -775,7 +783,13 @@ extern "C" void* thread_native_entry(void* thread_addr) { // initialize signal mask for this thread os::Solaris::hotspot_sigmask(thread); - thread->run(); + os::Solaris::init_thread_fpu_state(); + std::set_terminate(_handle_uncaught_cxx_exception); + + thread->call_run(); + + // Note: at this point the thread object may already have deleted itself. + // Do not dereference it from here on out. // One less thread is executing // When the VMThread gets here, the main thread may have already exited @@ -786,15 +800,6 @@ extern "C" void* thread_native_entry(void* thread_addr) { log_info(os, thread)("Thread finished (tid: " UINTX_FORMAT ").", os::current_thread_id()); - // If a thread has not deleted itself ("delete this") as part of its - // termination sequence, we have to ensure thread-local-storage is - // cleared before we actually terminate. No threads should ever be - // deleted asynchronously with respect to their termination. - if (Thread::current_or_null_safe() != NULL) { - assert(Thread::current_or_null_safe() == thread, "current thread is wrong"); - thread->clear_thread_current(); - } - if (UseDetachedThreads) { thr_exit(NULL); ShouldNotReachHere(); @@ -1090,67 +1095,58 @@ sigset_t* os::Solaris::vm_signals() { return &vm_sigs; } -void _handle_uncaught_cxx_exception() { - VMError::report_and_die("An uncaught C++ exception"); -} +// CR 7190089: on Solaris, primordial thread's stack needs adjusting. +// Without the adjustment, stack size is incorrect if stack is set to unlimited (ulimit -s unlimited). +void os::Solaris::correct_stack_boundaries_for_primordial_thread(Thread* thr) { + assert(is_primordial_thread(), "Call only for primordial thread"); + JavaThread* jt = (JavaThread *)thr; + assert(jt != NULL, "Sanity check"); + size_t stack_size; + address base = jt->stack_base(); + if (Arguments::created_by_java_launcher()) { + // Use 2MB to allow for Solaris 7 64 bit mode. + stack_size = JavaThread::stack_size_at_create() == 0 + ? 2048*K : JavaThread::stack_size_at_create(); -// First crack at OS-specific initialization, from inside the new thread. -void os::initialize_thread(Thread* thr) { - if (is_primordial_thread()) { - JavaThread* jt = (JavaThread *)thr; - assert(jt != NULL, "Sanity check"); - size_t stack_size; - address base = jt->stack_base(); - if (Arguments::created_by_java_launcher()) { - // Use 2MB to allow for Solaris 7 64 bit mode. - stack_size = JavaThread::stack_size_at_create() == 0 - ? 2048*K : JavaThread::stack_size_at_create(); - - // There are rare cases when we may have already used more than - // the basic stack size allotment before this method is invoked. - // Attempt to allow for a normally sized java_stack. - size_t current_stack_offset = (size_t)(base - (address)&stack_size); - stack_size += ReservedSpace::page_align_size_down(current_stack_offset); - } else { - // 6269555: If we were not created by a Java launcher, i.e. if we are - // running embedded in a native application, treat the primordial thread - // as much like a native attached thread as possible. This means using - // the current stack size from thr_stksegment(), unless it is too large - // to reliably setup guard pages. A reasonable max size is 8MB. - size_t current_size = current_stack_size(); - // This should never happen, but just in case.... - if (current_size == 0) current_size = 2 * K * K; - stack_size = current_size > (8 * K * K) ? (8 * K * K) : current_size; - } - address bottom = align_up(base - stack_size, os::vm_page_size());; - stack_size = (size_t)(base - bottom); - - assert(stack_size > 0, "Stack size calculation problem"); - - if (stack_size > jt->stack_size()) { -#ifndef PRODUCT - struct rlimit limits; - getrlimit(RLIMIT_STACK, &limits); - size_t size = adjust_stack_size(base, (size_t)limits.rlim_cur); - assert(size >= jt->stack_size(), "Stack size problem in main thread"); -#endif - tty->print_cr("Stack size of %d Kb exceeds current limit of %d Kb.\n" - "(Stack sizes are rounded up to a multiple of the system page size.)\n" - "See limit(1) to increase the stack size limit.", - stack_size / K, jt->stack_size() / K); - vm_exit(1); - } - assert(jt->stack_size() >= stack_size, - "Attempt to map more stack than was allocated"); - jt->set_stack_size(stack_size); + // There are rare cases when we may have already used more than + // the basic stack size allotment before this method is invoked. + // Attempt to allow for a normally sized java_stack. + size_t current_stack_offset = (size_t)(base - (address)&stack_size); + stack_size += ReservedSpace::page_align_size_down(current_stack_offset); + } else { + // 6269555: If we were not created by a Java launcher, i.e. if we are + // running embedded in a native application, treat the primordial thread + // as much like a native attached thread as possible. This means using + // the current stack size from thr_stksegment(), unless it is too large + // to reliably setup guard pages. A reasonable max size is 8MB. + size_t current_size = os::current_stack_size(); + // This should never happen, but just in case.... + if (current_size == 0) current_size = 2 * K * K; + stack_size = current_size > (8 * K * K) ? (8 * K * K) : current_size; } + address bottom = align_up(base - stack_size, os::vm_page_size());; + stack_size = (size_t)(base - bottom); - // With the T2 libthread (T1 is no longer supported) threads are always bound - // and we use stackbanging in all cases. + assert(stack_size > 0, "Stack size calculation problem"); + + if (stack_size > jt->stack_size()) { +#ifndef PRODUCT + struct rlimit limits; + getrlimit(RLIMIT_STACK, &limits); + size_t size = adjust_stack_size(base, (size_t)limits.rlim_cur); + assert(size >= jt->stack_size(), "Stack size problem in main thread"); +#endif + tty->print_cr("Stack size of %d Kb exceeds current limit of %d Kb.\n" + "(Stack sizes are rounded up to a multiple of the system page size.)\n" + "See limit(1) to increase the stack size limit.", + stack_size / K, jt->stack_size() / K); + vm_exit(1); + } + assert(jt->stack_size() >= stack_size, + "Attempt to map more stack than was allocated"); + jt->set_stack_size(stack_size); - os::Solaris::init_thread_fpu_state(); - std::set_terminate(_handle_uncaught_cxx_exception); } diff --git a/src/hotspot/os/solaris/os_solaris.hpp b/src/hotspot/os/solaris/os_solaris.hpp index 9726e9becef..fa86bc9cd14 100644 --- a/src/hotspot/os/solaris/os_solaris.hpp +++ b/src/hotspot/os/solaris/os_solaris.hpp @@ -102,8 +102,6 @@ class Solaris { static size_t page_size_for_alignment(size_t alignment); static bool setup_large_pages(caddr_t start, size_t bytes, size_t align); - static void init_thread_fpu_state(void); - static void try_enable_extended_io(); static struct sigaction *(*get_signal_action)(int); @@ -148,6 +146,9 @@ class Solaris { // SR_handler static void SR_handler(Thread* thread, ucontext_t* uc); + + static void init_thread_fpu_state(void); + protected: // Solaris-specific interface goes here static julong available_memory(); @@ -268,6 +269,7 @@ class Solaris { static jint _os_thread_limit; static volatile jint _os_thread_count; + static void correct_stack_boundaries_for_primordial_thread(Thread* thr); // Stack overflow handling diff --git a/src/hotspot/os/windows/os_windows.cpp b/src/hotspot/os/windows/os_windows.cpp index bf8e6c0ceeb..1ec26f92814 100644 --- a/src/hotspot/os/windows/os_windows.cpp +++ b/src/hotspot/os/windows/os_windows.cpp @@ -420,6 +420,9 @@ LONG WINAPI topLevelExceptionFilter(struct _EXCEPTION_POINTERS* exceptionInfo); // Thread start routine for all newly created threads static unsigned __stdcall thread_native_entry(Thread* thread) { + + thread->record_stack_base_and_size(); + // Try to randomize the cache line index of hot stack frames. // This helps when threads of the same stack traces evict each other's // cache lines. The threads can be either from the same JVM instance, or @@ -453,12 +456,15 @@ static unsigned __stdcall thread_native_entry(Thread* thread) { // by VM, so VM can generate error dump when an exception occurred in non- // Java thread (e.g. VM thread). __try { - thread->run(); + thread->call_run(); } __except(topLevelExceptionFilter( (_EXCEPTION_POINTERS*)_exception_info())) { // Nothing to do. } + // Note: at this point the thread object may already have deleted itself. + // Do not dereference it from here on out. + log_info(os, thread)("Thread finished (tid: " UINTX_FORMAT ").", os::current_thread_id()); // One less thread is executing @@ -468,15 +474,6 @@ static unsigned __stdcall thread_native_entry(Thread* thread) { Atomic::dec(&os::win32::_os_thread_count); } - // If a thread has not deleted itself ("delete this") as part of its - // termination sequence, we have to ensure thread-local-storage is - // cleared before we actually terminate. No threads should ever be - // deleted asynchronously with respect to their termination. - if (Thread::current_or_null_safe() != NULL) { - assert(Thread::current_or_null_safe() == thread, "current thread is wrong"); - thread->clear_thread_current(); - } - // Thread must not return from exit_process_or_thread(), but if it does, // let it proceed to exit normally return (unsigned)os::win32::exit_process_or_thread(os::win32::EPT_THREAD, res); diff --git a/src/hotspot/os_cpu/aix_ppc/os_aix_ppc.cpp b/src/hotspot/os_cpu/aix_ppc/os_aix_ppc.cpp index 70d666ef7b0..8955d2fce97 100644 --- a/src/hotspot/os_cpu/aix_ppc/os_aix_ppc.cpp +++ b/src/hotspot/os_cpu/aix_ppc/os_aix_ppc.cpp @@ -85,11 +85,6 @@ char* os::non_memory_address_word() { return (char*) -1; } -// OS specific thread initialization -// -// Calculate and store the limits of the memory stack. -void os::initialize_thread(Thread *thread) { } - // Frame information (pc, sp, fp) retrieved via ucontext // always looks like a C-frame according to the frame // conventions in frame_ppc.hpp. diff --git a/src/hotspot/os_cpu/bsd_x86/os_bsd_x86.cpp b/src/hotspot/os_cpu/bsd_x86/os_bsd_x86.cpp index b2cb1331a91..56dadda030e 100644 --- a/src/hotspot/os_cpu/bsd_x86/os_bsd_x86.cpp +++ b/src/hotspot/os_cpu/bsd_x86/os_bsd_x86.cpp @@ -300,10 +300,6 @@ char* os::non_memory_address_word() { return (char*) -1; } -void os::initialize_thread(Thread* thr) { -// Nothing to do. -} - address os::Bsd::ucontext_get_pc(const ucontext_t * uc) { return (address)uc->context_pc; } diff --git a/src/hotspot/os_cpu/bsd_zero/os_bsd_zero.cpp b/src/hotspot/os_cpu/bsd_zero/os_bsd_zero.cpp index ab14f4b1990..cb992cbf760 100644 --- a/src/hotspot/os_cpu/bsd_zero/os_bsd_zero.cpp +++ b/src/hotspot/os_cpu/bsd_zero/os_bsd_zero.cpp @@ -100,10 +100,6 @@ char* os::non_memory_address_word() { #endif // SPARC } -void os::initialize_thread(Thread* thr) { - // Nothing to do. -} - address os::Bsd::ucontext_get_pc(const ucontext_t* uc) { ShouldNotCallThis(); return NULL; diff --git a/src/hotspot/os_cpu/linux_aarch64/os_linux_aarch64.cpp b/src/hotspot/os_cpu/linux_aarch64/os_linux_aarch64.cpp index 57b2f4e9493..13b7214af77 100644 --- a/src/hotspot/os_cpu/linux_aarch64/os_linux_aarch64.cpp +++ b/src/hotspot/os_cpu/linux_aarch64/os_linux_aarch64.cpp @@ -106,9 +106,6 @@ char* os::non_memory_address_word() { return (char*) 0xffffffffffff; } -void os::initialize_thread(Thread *thr) { -} - address os::Linux::ucontext_get_pc(const ucontext_t * uc) { #ifdef BUILTIN_SIM return (address)uc->uc_mcontext.gregs[REG_PC]; diff --git a/src/hotspot/os_cpu/linux_arm/os_linux_arm.cpp b/src/hotspot/os_cpu/linux_arm/os_linux_arm.cpp index ed4ab79ce45..f44c6570441 100644 --- a/src/hotspot/os_cpu/linux_arm/os_linux_arm.cpp +++ b/src/hotspot/os_cpu/linux_arm/os_linux_arm.cpp @@ -91,10 +91,6 @@ char* os::non_memory_address_word() { return (char*) -1; } -void os::initialize_thread(Thread* thr) { - // Nothing to do -} - #ifdef AARCH64 #define arm_pc pc diff --git a/src/hotspot/os_cpu/linux_ppc/os_linux_ppc.cpp b/src/hotspot/os_cpu/linux_ppc/os_linux_ppc.cpp index c171ad16933..63ca3089c0d 100644 --- a/src/hotspot/os_cpu/linux_ppc/os_linux_ppc.cpp +++ b/src/hotspot/os_cpu/linux_ppc/os_linux_ppc.cpp @@ -94,8 +94,6 @@ char* os::non_memory_address_word() { return (char*) -1; } -void os::initialize_thread(Thread *thread) { } - // Frame information (pc, sp, fp) retrieved via ucontext // always looks like a C-frame according to the frame // conventions in frame_ppc64.hpp. diff --git a/src/hotspot/os_cpu/linux_s390/os_linux_s390.cpp b/src/hotspot/os_cpu/linux_s390/os_linux_s390.cpp index 815a8f87d91..9d6e1d9b39e 100644 --- a/src/hotspot/os_cpu/linux_s390/os_linux_s390.cpp +++ b/src/hotspot/os_cpu/linux_s390/os_linux_s390.cpp @@ -95,9 +95,6 @@ char* os::non_memory_address_word() { return (char*) -1; } -// OS specific thread initialization. -void os::initialize_thread(Thread* thread) { } - // Frame information (pc, sp, fp) retrieved via ucontext // always looks like a C-frame according to the frame // conventions in frame_s390.hpp. diff --git a/src/hotspot/os_cpu/linux_sparc/os_linux_sparc.cpp b/src/hotspot/os_cpu/linux_sparc/os_linux_sparc.cpp index de46489594c..984aa7c8bee 100644 --- a/src/hotspot/os_cpu/linux_sparc/os_linux_sparc.cpp +++ b/src/hotspot/os_cpu/linux_sparc/os_linux_sparc.cpp @@ -159,8 +159,6 @@ char* os::non_memory_address_word() { return (char*) 0; } -void os::initialize_thread(Thread* thr) {} - void os::print_context(outputStream *st, const void *context) { if (context == NULL) return; diff --git a/src/hotspot/os_cpu/linux_x86/os_linux_x86.cpp b/src/hotspot/os_cpu/linux_x86/os_linux_x86.cpp index eab2ca57f2a..e0de85839ba 100644 --- a/src/hotspot/os_cpu/linux_x86/os_linux_x86.cpp +++ b/src/hotspot/os_cpu/linux_x86/os_linux_x86.cpp @@ -116,10 +116,6 @@ char* os::non_memory_address_word() { return (char*) -1; } -void os::initialize_thread(Thread* thr) { -// Nothing to do. -} - address os::Linux::ucontext_get_pc(const ucontext_t * uc) { return (address)uc->uc_mcontext.gregs[REG_PC]; } diff --git a/src/hotspot/os_cpu/linux_zero/os_linux_zero.cpp b/src/hotspot/os_cpu/linux_zero/os_linux_zero.cpp index 65909e04365..32f496459e1 100644 --- a/src/hotspot/os_cpu/linux_zero/os_linux_zero.cpp +++ b/src/hotspot/os_cpu/linux_zero/os_linux_zero.cpp @@ -96,10 +96,6 @@ char* os::non_memory_address_word() { #endif // SPARC } -void os::initialize_thread(Thread * thr){ - // Nothing to do. -} - address os::Linux::ucontext_get_pc(const ucontext_t* uc) { ShouldNotCallThis(); return NULL; // silence compile warnings diff --git a/src/hotspot/os_cpu/windows_x86/os_windows_x86.cpp b/src/hotspot/os_cpu/windows_x86/os_windows_x86.cpp index 71d82b3940a..8d4e5ba86f3 100644 --- a/src/hotspot/os_cpu/windows_x86/os_windows_x86.cpp +++ b/src/hotspot/os_cpu/windows_x86/os_windows_x86.cpp @@ -212,10 +212,6 @@ bool os::register_code_area(char *low, char *high) { return true; } -void os::initialize_thread(Thread* thr) { -// Nothing to do. -} - // Atomics and Stub Functions typedef int32_t xchg_func_t (int32_t, volatile int32_t*); diff --git a/src/hotspot/share/gc/parallel/gcTaskThread.cpp b/src/hotspot/share/gc/parallel/gcTaskThread.cpp index c7b953a4c07..dc2c348d3b2 100644 --- a/src/hotspot/share/gc/parallel/gcTaskThread.cpp +++ b/src/hotspot/share/gc/parallel/gcTaskThread.cpp @@ -114,8 +114,6 @@ void GCTaskThread::print_task_time_stamps() { // for tasks to be enqueued for execution. void GCTaskThread::run() { - // Set up the thread for stack overflow support - this->record_stack_base_and_size(); this->initialize_named_thread(); // Bind yourself to your processor. if (processor_id() != GCTaskManager::sentinel_worker()) { diff --git a/src/hotspot/share/gc/shared/concurrentGCThread.cpp b/src/hotspot/share/gc/shared/concurrentGCThread.cpp index 9038ee994cd..896fff8265d 100644 --- a/src/hotspot/share/gc/shared/concurrentGCThread.cpp +++ b/src/hotspot/share/gc/shared/concurrentGCThread.cpp @@ -49,7 +49,6 @@ void ConcurrentGCThread::create_and_start(ThreadPriority prio) { } void ConcurrentGCThread::initialize_in_thread() { - this->record_stack_base_and_size(); this->initialize_named_thread(); this->set_active_handles(JNIHandleBlock::allocate_block()); // From this time Thread::current() should be working. diff --git a/src/hotspot/share/gc/shared/workgroup.cpp b/src/hotspot/share/gc/shared/workgroup.cpp index c9d4e700bdb..a34c2fbd63a 100644 --- a/src/hotspot/share/gc/shared/workgroup.cpp +++ b/src/hotspot/share/gc/shared/workgroup.cpp @@ -297,7 +297,6 @@ void AbstractGangWorker::run() { } void AbstractGangWorker::initialize() { - this->record_stack_base_and_size(); this->initialize_named_thread(); assert(_gang != NULL, "No gang to run in"); os::set_priority(this, NearMaxPriority); diff --git a/src/hotspot/share/jfr/periodic/sampling/jfrThreadSampler.cpp b/src/hotspot/share/jfr/periodic/sampling/jfrThreadSampler.cpp index c3567702fa9..0beb4de9812 100644 --- a/src/hotspot/share/jfr/periodic/sampling/jfrThreadSampler.cpp +++ b/src/hotspot/share/jfr/periodic/sampling/jfrThreadSampler.cpp @@ -455,8 +455,6 @@ static jlong get_monotonic_ms() { void JfrThreadSampler::run() { assert(_sampler_thread == NULL, "invariant"); - record_stack_base_and_size(); - _sampler_thread = this; jlong last_java_ms = get_monotonic_ms(); diff --git a/src/hotspot/share/prims/jni.cpp b/src/hotspot/share/prims/jni.cpp index 97024dcc008..7bd3cc710eb 100644 --- a/src/hotspot/share/prims/jni.cpp +++ b/src/hotspot/share/prims/jni.cpp @@ -4132,6 +4132,7 @@ static jint attach_current_thread(JavaVM *vm, void **penv, void *_args, bool dae // be set in order for the Safepoint code to deal with it correctly. thread->set_thread_state(_thread_in_vm); thread->record_stack_base_and_size(); + thread->register_thread_stack_with_NMT(); thread->initialize_thread_current(); if (!os::create_attached_thread(thread)) { diff --git a/src/hotspot/share/runtime/os.hpp b/src/hotspot/share/runtime/os.hpp index 5a10a5745d2..b098c107f28 100644 --- a/src/hotspot/share/runtime/os.hpp +++ b/src/hotspot/share/runtime/os.hpp @@ -505,7 +505,6 @@ class os: AllStatic { static void pd_start_thread(Thread* thread); static void start_thread(Thread* thread); - static void initialize_thread(Thread* thr); static void free_thread(OSThread* osthread); // thread id on Linux/64bit is 64bit, on Windows and Solaris, it's 32bit diff --git a/src/hotspot/share/runtime/thread.cpp b/src/hotspot/share/runtime/thread.cpp index 1ad7accf25d..496607c3d17 100644 --- a/src/hotspot/share/runtime/thread.cpp +++ b/src/hotspot/share/runtime/thread.cpp @@ -338,31 +338,60 @@ void Thread::clear_thread_current() { } void Thread::record_stack_base_and_size() { + // Note: at this point, Thread object is not yet initialized. Do not rely on + // any members being initialized. Do not rely on Thread::current() being set. + // If possible, refrain from doing anything which may crash or assert since + // quite probably those crash dumps will be useless. set_stack_base(os::current_stack_base()); set_stack_size(os::current_stack_size()); - // CR 7190089: on Solaris, primordial thread's stack is adjusted - // in initialize_thread(). Without the adjustment, stack size is - // incorrect if stack is set to unlimited (ulimit -s unlimited). - // So far, only Solaris has real implementation of initialize_thread(). - // - // set up any platform-specific state. - os::initialize_thread(this); + +#ifdef SOLARIS + if (os::is_primordial_thread()) { + os::Solaris::correct_stack_boundaries_for_primordial_thread(this); + } +#endif // Set stack limits after thread is initialized. if (is_Java_thread()) { ((JavaThread*) this)->set_stack_overflow_limit(); ((JavaThread*) this)->set_reserved_stack_activation(stack_base()); } +} + #if INCLUDE_NMT - // record thread's native stack, stack grows downward +void Thread::register_thread_stack_with_NMT() { MemTracker::record_thread_stack(stack_end(), stack_size()); +} #endif // INCLUDE_NMT + +void Thread::call_run() { + // At this point, Thread object should be fully initialized and + // Thread::current() should be set. + + register_thread_stack_with_NMT(); + log_debug(os, thread)("Thread " UINTX_FORMAT " stack dimensions: " PTR_FORMAT "-" PTR_FORMAT " (" SIZE_FORMAT "k).", os::current_thread_id(), p2i(stack_base() - stack_size()), p2i(stack_base()), stack_size()/1024); -} + // Invoke ::run() + this->run(); + // Returned from ::run(). Thread finished. + + // Note: at this point the thread object may already have deleted itself. + // So from here on do not dereference *this*. + + // If a thread has not deleted itself ("delete this") as part of its + // termination sequence, we have to ensure thread-local-storage is + // cleared before we actually terminate. No threads should ever be + // deleted asynchronously with respect to their termination. + if (Thread::current_or_null_safe() != NULL) { + assert(Thread::current_or_null_safe() == this, "current thread is wrong"); + Thread::clear_thread_current(); + } + +} Thread::~Thread() { JFR_ONLY(Jfr::on_thread_destruct(this);) @@ -417,17 +446,12 @@ Thread::~Thread() { // clear Thread::current if thread is deleting itself. // Needed to ensure JNI correctly detects non-attached threads. if (this == Thread::current()) { - clear_thread_current(); + Thread::clear_thread_current(); } CHECK_UNHANDLED_OOPS_ONLY(if (CheckUnhandledOops) delete unhandled_oops();) } -// NOTE: dummy function for assertion purpose. -void Thread::run() { - ShouldNotReachHere(); -} - #ifdef ASSERT // A JavaThread is considered "dangling" if it is not the current // thread, has been added the Threads list, the system is not at a @@ -1374,7 +1398,6 @@ int WatcherThread::sleep() const { void WatcherThread::run() { assert(this == watcher_thread(), "just checking"); - this->record_stack_base_and_size(); this->set_native_thread_name(this->name()); this->set_active_handles(JNIHandleBlock::allocate_block()); while (true) { @@ -1740,9 +1763,6 @@ void JavaThread::run() { // used to test validity of stack trace backs this->record_base_of_stack_pointer(); - // Record real stack base and size. - this->record_stack_base_and_size(); - this->create_stack_guard_pages(); this->cache_global_variables(); @@ -3709,6 +3729,7 @@ jint Threads::create_vm(JavaVMInitArgs* args, bool* canTryAgain) { main_thread->initialize_thread_current(); // must do this before set_active_handles main_thread->record_stack_base_and_size(); + main_thread->register_thread_stack_with_NMT(); main_thread->set_active_handles(JNIHandleBlock::allocate_block()); if (!main_thread->set_as_starting_thread()) { diff --git a/src/hotspot/share/runtime/thread.hpp b/src/hotspot/share/runtime/thread.hpp index 3a212d85c26..ab7e01ccda8 100644 --- a/src/hotspot/share/runtime/thread.hpp +++ b/src/hotspot/share/runtime/thread.hpp @@ -397,11 +397,15 @@ class Thread: public ThreadShadow { // Manage Thread::current() void initialize_thread_current(); - void clear_thread_current(); // TLS cleanup needed before threads terminate + static void clear_thread_current(); // TLS cleanup needed before threads terminate + + protected: + // To be implemented by children. + virtual void run() = 0; public: - // thread entry point - virtual void run(); + // invokes ::run(), with common preparations and cleanups. + void call_run(); // Testers virtual bool is_VM_thread() const { return false; } @@ -643,6 +647,7 @@ protected: void set_stack_size(size_t size) { _stack_size = size; } address stack_end() const { return stack_base() - stack_size(); } void record_stack_base_and_size(); + void register_thread_stack_with_NMT() NOT_NMT_RETURN; bool on_local_stack(address adr) const { // QQQ this has knowledge of direction, ought to be a stack method diff --git a/src/hotspot/share/runtime/vmThread.cpp b/src/hotspot/share/runtime/vmThread.cpp index d3677b23894..7d509460da7 100644 --- a/src/hotspot/share/runtime/vmThread.cpp +++ b/src/hotspot/share/runtime/vmThread.cpp @@ -243,7 +243,7 @@ void VMThread::run() { assert(this == vm_thread(), "check"); this->initialize_named_thread(); - this->record_stack_base_and_size(); + // Notify_lock wait checks on active_handles() to rewait in // case of spurious wakeup, it should wait on the last // value set prior to the notify From ae77ef7d7a4633474f7d1a45b9246f13c0711d23 Mon Sep 17 00:00:00 2001 From: Weijun Wang Date: Fri, 26 Oct 2018 22:58:04 +0800 Subject: [PATCH 33/84] 8213007: Update the link in test/jdk/sun/security/provider/SecureRandom/DrbgCavp.java Reviewed-by: mullan --- test/jdk/sun/security/provider/SecureRandom/DrbgCavp.java | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/test/jdk/sun/security/provider/SecureRandom/DrbgCavp.java b/test/jdk/sun/security/provider/SecureRandom/DrbgCavp.java index 9e67848772b..594e27959df 100644 --- a/test/jdk/sun/security/provider/SecureRandom/DrbgCavp.java +++ b/test/jdk/sun/security/provider/SecureRandom/DrbgCavp.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2018, 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,8 +46,9 @@ import java.util.zip.ZipInputStream; import static java.security.DrbgParameters.Capability.*; /** - * The Known-output DRBG test. The test vector can be obtained from - * http://csrc.nist.gov/groups/STM/cavp/documents/drbg/drbgtestvectors.zip. + * The Known-output DRBG test. The test vector can be downloaded from + * https://csrc.nist.gov/CSRC/media/Projects/Cryptographic-Algorithm-Validation-Program/documents/drbg/drbgtestvectors.zip. + * The test is described on https://csrc.nist.gov/Projects/Cryptographic-Algorithm-Validation-Program/Random-Number-Generators. * * Manually run this test with * From 0108d754d794e7bfe1d5d9392d511f28c5b25e46 Mon Sep 17 00:00:00 2001 From: Gerard Ziemski Date: Fri, 26 Oct 2018 10:47:05 -0500 Subject: [PATCH 34/84] 8017061: os_bsd.cpp contains code for UseSHM and UseHugeTLBFS Removed the code using unused flags. Reviewed-by: dholmes, coleenp --- src/hotspot/os/bsd/globals_bsd.hpp | 8 +- src/hotspot/os/bsd/os_bsd.cpp | 134 +++++------------------- src/hotspot/share/runtime/arguments.cpp | 5 + 3 files changed, 32 insertions(+), 115 deletions(-) diff --git a/src/hotspot/os/bsd/globals_bsd.hpp b/src/hotspot/os/bsd/globals_bsd.hpp index 237a7e2c8e1..c00c3847d23 100644 --- a/src/hotspot/os/bsd/globals_bsd.hpp +++ b/src/hotspot/os/bsd/globals_bsd.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2018, 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,12 +46,6 @@ /* overridden in Arguments::parse_each_vm_init_arg. */ \ product(bool, UseBsdPosixThreadCPUClocks, true, \ "enable fast Bsd Posix clocks where available") \ - \ - product(bool, UseHugeTLBFS, false, \ - "Use MAP_HUGETLB for large pages") \ - \ - product(bool, UseSHM, false, \ - "Use SYSV shared memory for large pages") // // Defines Bsd-specific default values. The flags are available on all diff --git a/src/hotspot/os/bsd/os_bsd.cpp b/src/hotspot/os/bsd/os_bsd.cpp index ea084a116fa..2cfea80098d 100644 --- a/src/hotspot/os/bsd/os_bsd.cpp +++ b/src/hotspot/os/bsd/os_bsd.cpp @@ -70,50 +70,38 @@ #include "utilities/vmError.hpp" // put OS-includes here -# include -# include -# include -# include -# include -# include -# include # include -# include -# include -# include +# include +# include +# include +# include # include +# include +# include +# include +# include +# include +# include +# include +# include +# include +# include # include +# include +# include # include # include -# include -# include +# include # include # include -# include -# include -# include -# include -# include -# include -# include -# include -#ifndef __APPLE__ -# include -#endif -# include -# include -# include -# include +# include #if defined(__FreeBSD__) || defined(__NetBSD__) #include #endif #ifdef __APPLE__ - #include // semaphore_* API #include - #include - #include #endif #ifndef MAP_ANONYMOUS @@ -125,8 +113,6 @@ // for timer info max values which include all bits #define ALL_64_BITS CONST64(0xFFFFFFFFFFFFFFFF) -#define LARGEPAGES_BIT (1 << 6) - //////////////////////////////////////////////////////////////////////////////// // global variables julong os::Bsd::_physical_memory = 0; @@ -2116,95 +2102,27 @@ void os::large_page_init() { char* os::reserve_memory_special(size_t bytes, size_t alignment, char* req_addr, bool exec) { - fatal("This code is not used or maintained."); - - // "exec" is passed in but not used. Creating the shared image for - // the code cache doesn't have an SHM_X executable permission to check. - assert(UseLargePages && UseSHM, "only for SHM large pages"); - - key_t key = IPC_PRIVATE; - char *addr; - - bool warn_on_failure = UseLargePages && - (!FLAG_IS_DEFAULT(UseLargePages) || - !FLAG_IS_DEFAULT(LargePageSizeInBytes)); - - // Create a large shared memory region to attach to based on size. - // Currently, size is the total size of the heap - int shmid = shmget(key, bytes, IPC_CREAT|SHM_R|SHM_W); - if (shmid == -1) { - // Possible reasons for shmget failure: - // 1. shmmax is too small for Java heap. - // > check shmmax value: cat /proc/sys/kernel/shmmax - // > increase shmmax value: echo "0xffffffff" > /proc/sys/kernel/shmmax - // 2. not enough large page memory. - // > check available large pages: cat /proc/meminfo - // > increase amount of large pages: - // echo new_value > /proc/sys/vm/nr_hugepages - // Note 1: different Bsd may use different name for this property, - // e.g. on Redhat AS-3 it is "hugetlb_pool". - // Note 2: it's possible there's enough physical memory available but - // they are so fragmented after a long run that they can't - // coalesce into large pages. Try to reserve large pages when - // the system is still "fresh". - if (warn_on_failure) { - warning("Failed to reserve shared memory (errno = %d).", errno); - } - return NULL; - } - - // attach to the region - addr = (char*)shmat(shmid, req_addr, 0); - int err = errno; - - // Remove shmid. If shmat() is successful, the actual shared memory segment - // will be deleted when it's detached by shmdt() or when the process - // terminates. If shmat() is not successful this will remove the shared - // segment immediately. - shmctl(shmid, IPC_RMID, NULL); - - if ((intptr_t)addr == -1) { - if (warn_on_failure) { - warning("Failed to attach shared memory (errno = %d).", err); - } - return NULL; - } - - // The memory is committed - MemTracker::record_virtual_memory_reserve_and_commit((address)addr, bytes, CALLER_PC); - - return addr; + fatal("os::reserve_memory_special should not be called on BSD."); + return NULL; } bool os::release_memory_special(char* base, size_t bytes) { - if (MemTracker::tracking_level() > NMT_minimal) { - Tracker tkr(Tracker::release); - // detaching the SHM segment will also delete it, see reserve_memory_special() - int rslt = shmdt(base); - if (rslt == 0) { - tkr.record((address)base, bytes); - return true; - } else { - return false; - } - } else { - return shmdt(base) == 0; - } + fatal("os::release_memory_special should not be called on BSD."); + return false; } size_t os::large_page_size() { return _large_page_size; } -// HugeTLBFS allows application to commit large page memory on demand; -// with SysV SHM the entire memory region must be allocated as shared -// memory. bool os::can_commit_large_page_memory() { - return UseHugeTLBFS; + // Does not matter, we do not support huge pages. + return false; } bool os::can_execute_large_page_memory() { - return UseHugeTLBFS; + // Does not matter, we do not support huge pages. + return false; } char* os::pd_attempt_reserve_memory_at(size_t bytes, char* requested_addr, int file_desc) { diff --git a/src/hotspot/share/runtime/arguments.cpp b/src/hotspot/share/runtime/arguments.cpp index 2303e4aea0f..0909ce0725d 100644 --- a/src/hotspot/share/runtime/arguments.cpp +++ b/src/hotspot/share/runtime/arguments.cpp @@ -537,6 +537,11 @@ static SpecialFlag const special_jvm_flags[] = { { "CompilerThreadHintNoPreempt", JDK_Version::jdk(11), JDK_Version::jdk(12), JDK_Version::jdk(13) }, { "VMThreadHintNoPreempt", JDK_Version::jdk(11), JDK_Version::jdk(12), JDK_Version::jdk(13) }, +#if defined(_ALLBSD_SOURCE) + { "UseSHM", JDK_Version::undefined(), JDK_Version::jdk(12), JDK_Version::jdk(13) }, + { "UseHugeTLBFS", JDK_Version::undefined(), JDK_Version::jdk(12), JDK_Version::jdk(13) }, +#endif + // --- Deprecated alias flags (see also aliased_jvm_flags) - sorted by obsolete_in then expired_in: { "DefaultMaxRAMFraction", JDK_Version::jdk(8), JDK_Version::undefined(), JDK_Version::undefined() }, { "CreateMinidumpOnCrash", JDK_Version::jdk(9), JDK_Version::undefined(), JDK_Version::undefined() }, From a655e6b52b3819092c0e874d95e39c124d681381 Mon Sep 17 00:00:00 2001 From: Lance Andersen Date: Fri, 26 Oct 2018 14:02:31 -0400 Subject: [PATCH 35/84] 8212129: Remove finalize methods from java.util.zip.ZipFIle/Inflator/Deflator Reviewed-by: rriggs, sherman, alanb, clanger --- .../share/classes/java/util/zip/Deflater.java | 64 +---------- .../share/classes/java/util/zip/Inflater.java | 66 +---------- .../share/classes/java/util/zip/ZipFile.java | 67 +----------- .../util/zip/ZipFile/FinalizeZipFile.java | 103 ------------------ .../java/util/zip/ZipFile/TestCleaner.java | 100 ----------------- 5 files changed, 4 insertions(+), 396 deletions(-) delete mode 100644 test/jdk/java/util/zip/ZipFile/FinalizeZipFile.java diff --git a/src/java.base/share/classes/java/util/zip/Deflater.java b/src/java.base/share/classes/java/util/zip/Deflater.java index f173ad53f68..5239e8e33c3 100644 --- a/src/java.base/share/classes/java/util/zip/Deflater.java +++ b/src/java.base/share/classes/java/util/zip/Deflater.java @@ -89,13 +89,6 @@ import sun.nio.ch.DirectBuffer; * to perform cleanup should be modified to use alternative cleanup mechanisms such * as {@link java.lang.ref.Cleaner} and remove the overriding {@code finalize} method. * - * @implSpec - * If this {@code Deflater} has been subclassed and the {@code end} method has been - * overridden, the {@code end} method will be called by the finalization when the - * deflater is unreachable. But the subclasses should not depend on this specific - * implementation; the finalization is not reliable and the {@code finalize} method - * is deprecated to be removed. - * * @see Inflater * @author David Connelly * @since 1.1 @@ -204,8 +197,8 @@ public class Deflater { public Deflater(int level, boolean nowrap) { this.level = level; this.strategy = DEFAULT_STRATEGY; - this.zsRef = DeflaterZStreamRef.get(this, - init(level, DEFAULT_STRATEGY, nowrap)); + this.zsRef = new DeflaterZStreamRef(this, + init(level, DEFAULT_STRATEGY, nowrap)); } /** @@ -901,21 +894,6 @@ public class Deflater { } } - /** - * Closes the compressor when garbage is collected. - * - * @deprecated The {@code finalize} method has been deprecated and will be - * removed. It is implemented as a no-op. Subclasses that override - * {@code finalize} in order to perform cleanup should be modified to use - * alternative cleanup mechanisms and to remove the overriding {@code finalize} - * method. The recommended cleanup for compressor is to explicitly call - * {@code end} method when it is no longer in use. If the {@code end} is - * not invoked explicitly the resource of the compressor will be released - * when the instance becomes unreachable. - */ - @Deprecated(since="9", forRemoval=true) - protected void finalize() {} - private void ensureOpen() { assert Thread.holdsLock(zsRef); if (zsRef.address() == 0) @@ -977,43 +955,5 @@ public class Deflater { } } - /* - * If {@code Deflater} has been subclassed and the {@code end} method is - * overridden, uses {@code finalizer} mechanism for resource cleanup. So - * {@code end} method can be called when the {@code Deflater} is unreachable. - * This mechanism will be removed when the {@code finalize} method is - * removed from {@code Deflater}. - */ - static DeflaterZStreamRef get(Deflater owner, long addr) { - Class clz = owner.getClass(); - while (clz != Deflater.class) { - try { - clz.getDeclaredMethod("end"); - return new FinalizableZStreamRef(owner, addr); - } catch (NoSuchMethodException nsme) {} - clz = clz.getSuperclass(); - } - return new DeflaterZStreamRef(owner, addr); - } - - private static class FinalizableZStreamRef extends DeflaterZStreamRef { - final Deflater owner; - - FinalizableZStreamRef (Deflater owner, long addr) { - super(null, addr); - this.owner = owner; - } - - @Override - void clean() { - run(); - } - - @Override - @SuppressWarnings("deprecation") - protected void finalize() { - owner.end(); - } - } } } diff --git a/src/java.base/share/classes/java/util/zip/Inflater.java b/src/java.base/share/classes/java/util/zip/Inflater.java index 1b448a1b7e4..501d1ffa0b6 100644 --- a/src/java.base/share/classes/java/util/zip/Inflater.java +++ b/src/java.base/share/classes/java/util/zip/Inflater.java @@ -87,13 +87,6 @@ import sun.nio.ch.DirectBuffer; * to perform cleanup should be modified to use alternative cleanup mechanisms such * as {@link java.lang.ref.Cleaner} and remove the overriding {@code finalize} method. * - * @implSpec - * If this {@code Inflater} has been subclassed and the {@code end} method has been - * overridden, the {@code end} method will be called by the finalization when the - * inflater is unreachable. But the subclasses should not depend on this specific - * implementation; the finalization is not reliable and the {@code finalize} method - * is deprecated to be removed. - * * @see Deflater * @author David Connelly * @since 1.1 @@ -135,7 +128,7 @@ public class Inflater { * @param nowrap if true then support GZIP compatible compression */ public Inflater(boolean nowrap) { - this.zsRef = InflaterZStreamRef.get(this, init(nowrap)); + this.zsRef = new InflaterZStreamRef(this, init(nowrap)); } /** @@ -714,25 +707,6 @@ public class Inflater { } } - /** - * Closes the decompressor when garbage is collected. - * - * @implSpec - * If this {@code Inflater} has been subclassed and the {@code end} method - * has been overridden, the {@code end} method will be called when the - * inflater is unreachable. - * - * @deprecated The {@code finalize} method has been deprecated and will be - * removed. It is implemented as a no-op. Subclasses that override - * {@code finalize} in order to perform cleanup should be modified to use - * alternative cleanup mechanisms and remove the overriding {@code finalize} - * method. The recommended cleanup for compressor is to explicitly call - * {@code end} method when it is no longer in use. If the {@code end} is - * not invoked explicitly the resource of the compressor will be released - * when the instance becomes unreachable, - */ - @Deprecated(since="9", forRemoval=true) - protected void finalize() {} private void ensureOpen () { assert Thread.holdsLock(zsRef); @@ -792,43 +766,5 @@ public class Inflater { } } - /* - * If {@code Inflater} has been subclassed and the {@code end} method is - * overridden, uses {@code finalizer} mechanism for resource cleanup. So - * {@code end} method can be called when the {@code Inflater} is unreachable. - * This mechanism will be removed when the {@code finalize} method is - * removed from {@code Inflater}. - */ - static InflaterZStreamRef get(Inflater owner, long addr) { - Class clz = owner.getClass(); - while (clz != Inflater.class) { - try { - clz.getDeclaredMethod("end"); - return new FinalizableZStreamRef(owner, addr); - } catch (NoSuchMethodException nsme) {} - clz = clz.getSuperclass(); - } - return new InflaterZStreamRef(owner, addr); - } - - private static class FinalizableZStreamRef extends InflaterZStreamRef { - final Inflater owner; - - FinalizableZStreamRef(Inflater owner, long addr) { - super(null, addr); - this.owner = owner; - } - - @Override - void clean() { - run(); - } - - @Override - @SuppressWarnings("deprecation") - protected void finalize() { - owner.end(); - } - } } } diff --git a/src/java.base/share/classes/java/util/zip/ZipFile.java b/src/java.base/share/classes/java/util/zip/ZipFile.java index 601f8375e3f..1e07018cf38 100644 --- a/src/java.base/share/classes/java/util/zip/ZipFile.java +++ b/src/java.base/share/classes/java/util/zip/ZipFile.java @@ -56,7 +56,6 @@ import java.util.function.Consumer; import java.util.function.Function; import java.util.function.IntFunction; import java.util.jar.JarEntry; -import java.util.jar.JarFile; import java.util.stream.Stream; import java.util.stream.StreamSupport; import jdk.internal.misc.JavaLangAccess; @@ -85,13 +84,6 @@ import static java.util.zip.ZipUtils.*; * cleanup mechanisms such as {@link java.lang.ref.Cleaner} and remove the overriding * {@code finalize} method. * - * @implSpec - * If this {@code ZipFile} has been subclassed and the {@code close} method has - * been overridden, the {@code close} method will be called by the finalization - * when {@code ZipFile} is unreachable. But the subclasses should not depend on - * this specific implementation; the finalization is not reliable and the - * {@code finalize} method is deprecated to be removed. - * * @author David Connelly * @since 1.1 */ @@ -244,7 +236,7 @@ class ZipFile implements ZipConstants, Closeable { this.name = name; long t0 = System.nanoTime(); - this.res = CleanableResource.get(this, file, mode); + this.res = new CleanableResource(this, file, mode); PerfCounter.getZipFileOpenTime().addElapsedTimeFrom(t0); PerfCounter.getZipFileCount().increment(); @@ -825,44 +817,6 @@ class ZipFile implements ZipConstants, Closeable { this.zsrc = Source.get(file, (mode & OPEN_DELETE) != 0); } - /* - * If {@code ZipFile} has been subclassed and the {@code close} method is - * overridden, uses the {@code finalizer} mechanism for resource cleanup. - * So {@code close} method can be called when the the {@code ZipFile} is - * unreachable. This mechanism will be removed when {@code finalize} method - * is removed from {@code ZipFile}. - */ - static CleanableResource get(ZipFile zf, File file, int mode) - throws IOException { - Class clz = zf.getClass(); - while (clz != ZipFile.class && clz != JarFile.class) { - if (JLA.getDeclaredPublicMethods(clz, "close").size() != 0) { - return new FinalizableResource(zf, file, mode); - } - clz = clz.getSuperclass(); - } - return new CleanableResource(zf, file, mode); - } - - static class FinalizableResource extends CleanableResource { - ZipFile zf; - FinalizableResource(ZipFile zf, File file, int mode) - throws IOException { - super(file, mode); - this.zf = zf; - } - - @Override - void clean() { - run(); - } - - @Override - @SuppressWarnings("deprecation") - protected void finalize() throws IOException { - zf.close(); - } - } } /** @@ -891,25 +845,6 @@ class ZipFile implements ZipConstants, Closeable { } } - /** - * Ensures that the system resources held by this ZipFile object are - * released when there are no more references to it. - * - * @deprecated The {@code finalize} method has been deprecated and will be - * removed. It is implemented as a no-op. Subclasses that override - * {@code finalize} in order to perform cleanup should be modified to - * use alternative cleanup mechanisms and to remove the overriding - * {@code finalize} method. The recommended cleanup for ZipFile object - * is to explicitly invoke {@code close} method when it is no longer in - * use, or use try-with-resources. If the {@code close} is not invoked - * explicitly the resources held by this object will be released when - * the instance becomes unreachable. - * - * @throws IOException if an I/O error has occurred - */ - @Deprecated(since="9", forRemoval=true) - protected void finalize() throws IOException {} - private void ensureOpen() { if (closeRequested) { throw new IllegalStateException("zip file closed"); diff --git a/test/jdk/java/util/zip/ZipFile/FinalizeZipFile.java b/test/jdk/java/util/zip/ZipFile/FinalizeZipFile.java deleted file mode 100644 index 8641e183341..00000000000 --- a/test/jdk/java/util/zip/ZipFile/FinalizeZipFile.java +++ /dev/null @@ -1,103 +0,0 @@ -/* - * Copyright (c) 2010, 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 7007609 7009618 - * @summary Check that ZipFile objects are always collected - * @key randomness - */ - -import java.io.*; -import java.util.Random; -import java.util.zip.*; -import java.util.concurrent.CountDownLatch; -import java.util.concurrent.TimeUnit; - -public class FinalizeZipFile { - - private static final CountDownLatch finalizersDone = new CountDownLatch(3); - - private static class InstrumentedZipFile extends ZipFile { - - public InstrumentedZipFile(File f) throws Exception { - super(f); - System.out.printf("Using %s%n", f.getPath()); - } - @Override - protected void finalize() throws IOException { - System.out.printf("Killing %s%n", getName()); - super.finalize(); - finalizersDone.countDown(); - } - } - - private static void makeGarbage() throws Throwable { - final Random rnd = new Random(); - // Create some ZipFiles. - // Find some .jar files in test directory. - final File testdir = new File(System.getProperty("test.src", ".")); - check(testdir.isDirectory()); - final File[] jars = testdir.listFiles( - new FilenameFilter() { - public boolean accept(File dir, String name) { - return name.endsWith(".jar");}}); - check(jars.length > 1); - - new InstrumentedZipFile(jars[rnd.nextInt(jars.length)]).close(); - new InstrumentedZipFile(jars[rnd.nextInt(jars.length)]).close(); - - // Create a ZipFile and get an input stream from it - for (int i = 0; i < jars.length + 10; i++) { - ZipFile zf = new InstrumentedZipFile(jars[rnd.nextInt(jars.length)]); - ZipEntry ze = zf.getEntry("META-INF/MANIFEST.MF"); - if (ze != null) { - InputStream is = zf.getInputStream(ze); - break; - } - } - } - - public static void realMain(String[] args) throws Throwable { - makeGarbage(); - while (!finalizersDone.await(10, TimeUnit.MILLISECONDS)) { - System.gc(); - } - // Not all ZipFiles were collected? - equal(finalizersDone.getCount(), 0L); - } - - //--------------------- Infrastructure --------------------------- - static volatile int passed = 0, failed = 0; - static void pass() {passed++;} - static void fail() {failed++; Thread.dumpStack();} - static void fail(String msg) {System.out.println(msg); fail();} - static void unexpected(Throwable t) {failed++; t.printStackTrace();} - static void check(boolean cond) {if (cond) pass(); else fail();} - static void equal(Object x, Object y) { - if (x == null ? y == null : x.equals(y)) pass(); - else fail(x + " not equal to " + y);} - public static void main(String[] args) throws Throwable { - try {realMain(args);} catch (Throwable t) {unexpected(t);} - System.out.printf("%nPassed = %d, failed = %d%n%n", passed, failed); - if (failed > 0) throw new AssertionError("Some tests failed");} -} diff --git a/test/jdk/java/util/zip/ZipFile/TestCleaner.java b/test/jdk/java/util/zip/ZipFile/TestCleaner.java index 82c6209dccc..d24aa5045fd 100644 --- a/test/jdk/java/util/zip/ZipFile/TestCleaner.java +++ b/test/jdk/java/util/zip/ZipFile/TestCleaner.java @@ -31,8 +31,6 @@ import java.io.*; import java.lang.reflect.*; import java.util.*; -import java.util.concurrent.CountDownLatch; -import java.util.concurrent.TimeUnit; import java.util.zip.*; import jdk.internal.vm.annotation.DontInline; import static java.nio.charset.StandardCharsets.US_ASCII; @@ -56,34 +54,6 @@ public class TestCleaner { } } - private static class SubclassedInflater extends Inflater { - CountDownLatch endCountDown; - - SubclassedInflater(CountDownLatch endCountDown) { - this.endCountDown = endCountDown; - } - - @Override - public void end() { - super.end(); - endCountDown.countDown(); - } - } - - private static class SubclassedDeflater extends Deflater { - CountDownLatch endCountDown; - - SubclassedDeflater(CountDownLatch endCountDown) { - this.endCountDown = endCountDown; - } - - @Override - public void end() { - super.end(); - endCountDown.countDown(); - } - } - // verify the "native resource" of In/Deflater has been cleaned private static void testDeInflater() throws Throwable { Field zsRefDef = Deflater.class.getDeclaredField("zsRef"); @@ -124,44 +94,6 @@ public class TestCleaner { if (cnt != 0) throw new RuntimeException("cleaner failed to clean : " + cnt); - // test subclassed Deflater/Inflater, for behavioral compatibility. - // should be removed if the finalize() method is finally removed. - var endCountDown = new CountDownLatch(20); - for (int i = 0; i < 10; i++) { - var def = new SubclassedDeflater(endCountDown); - def.setInput("hello".getBytes()); - def.finish(); - n = def.deflate(buf1); - - var inf = new SubclassedInflater(endCountDown); - inf.setInput(buf1, 0, n); - n = inf.inflate(buf2); - if (!"hello".equals(new String(buf2, 0, n))) { - throw new RuntimeException("compression/decompression failed"); - } - } - while (!endCountDown.await(10, TimeUnit.MILLISECONDS)) { - System.gc(); - } - if (endCountDown.getCount() != 0) - throw new RuntimeException("finalizer failed to clean : " + - endCountDown.getCount()); - } - - private static class SubclassedZipFile extends ZipFile { - CountDownLatch closeCountDown; - - SubclassedZipFile(File f, CountDownLatch closeCountDown) - throws IOException { - super(f); - this.closeCountDown = closeCountDown; - } - - @Override - public void close() throws IOException { - closeCountDown.countDown(); - super.close(); - } } @DontInline @@ -198,27 +130,6 @@ public class TestCleaner { } } - @DontInline - private static void openAndCloseSubZipFile(File zip, CountDownLatch closeCountDown) - throws Throwable { - try { - try (var fos = new FileOutputStream(zip); - var zos = new ZipOutputStream(fos)) { - zos.putNextEntry(new ZipEntry("hello")); - zos.write("hello".getBytes(US_ASCII)); - zos.closeEntry(); - } - var zf = new SubclassedZipFile(zip, closeCountDown); - var es = zf.entries(); - while (es.hasMoreElements()) { - zf.getInputStream(es.nextElement()).read(); - } - es = null; - zf = null; - } finally { - zip.delete(); - } - } private static void testZipFile() throws Throwable { File dir = new File(System.getProperty("test.dir", ".")); @@ -241,16 +152,5 @@ public class TestCleaner { throw new RuntimeException("cleaner failed to clean zipfile."); } } - - // test subclassed ZipFile, for behavioral compatibility. - // should be removed if the finalize() method is finally removed. - var closeCountDown = new CountDownLatch(1); - openAndCloseSubZipFile(zip, closeCountDown); - while (!closeCountDown.await(10, TimeUnit.MILLISECONDS)) { - System.gc(); - } - if (closeCountDown.getCount() != 0) - throw new RuntimeException("finalizer failed to clean : " + - closeCountDown.getCount()); } } From 890a8b77055b9d62c27a057c8bbaccd8756b3e9b Mon Sep 17 00:00:00 2001 From: Mandy Chung Date: Fri, 26 Oct 2018 13:59:02 -0700 Subject: [PATCH 36/84] 8213043: Add internal Unsafe xxxObject methods as jsr166 is broken Reviewed-by: alanb --- .../classes/jdk/internal/misc/Unsafe.java | 88 +++++++++++++++++++ 1 file changed, 88 insertions(+) diff --git a/src/java.base/share/classes/jdk/internal/misc/Unsafe.java b/src/java.base/share/classes/jdk/internal/misc/Unsafe.java index 2868c3b66f4..09eac2026db 100644 --- a/src/java.base/share/classes/jdk/internal/misc/Unsafe.java +++ b/src/java.base/share/classes/jdk/internal/misc/Unsafe.java @@ -3716,4 +3716,92 @@ public final class Unsafe { private native int getLoadAverage0(double[] loadavg, int nelems); private native boolean unalignedAccess0(); private native boolean isBigEndian0(); + + + // The following deprecated methods are used by JSR 166. + + @Deprecated(since="12", forRemoval=true) + public final Object getObject(Object o, long offset) { + return getReference(o, offset); + } + @Deprecated(since="12", forRemoval=true) + public final Object getObjectVolatile(Object o, long offset) { + return getReferenceVolatile(o, offset); + } + @Deprecated(since="12", forRemoval=true) + public final Object getObjectAcquire(Object o, long offset) { + return getReferenceAcquire(o, offset); + } + @Deprecated(since="12", forRemoval=true) + public final Object getObjectOpaque(Object o, long offset) { + return getReferenceOpaque(o, offset); + } + + + @Deprecated(since="12", forRemoval=true) + public final void putObject(Object o, long offset, Object x) { + putReference(o, offset, x); + } + @Deprecated(since="12", forRemoval=true) + public final void putObjectVolatile(Object o, long offset, Object x) { + putReferenceVolatile(o, offset, x); + } + @Deprecated(since="12", forRemoval=true) + public final void putObjectOpaque(Object o, long offset, Object x) { + putReferenceOpaque(o, offset, x); + } + @Deprecated(since="12", forRemoval=true) + public final void putObjectRelease(Object o, long offset, Object x) { + putReferenceRelease(o, offset, x); + } + + + @Deprecated(since="12", forRemoval=true) + public final Object getAndSetObject(Object o, long offset, Object newValue) { + return getAndSetReference(o, offset, newValue); + } + @Deprecated(since="12", forRemoval=true) + public final Object getAndSetObjectAcquire(Object o, long offset, Object newValue) { + return getAndSetReferenceAcquire(o, offset, newValue); + } + @Deprecated(since="12", forRemoval=true) + public final Object getAndSetObjectRelease(Object o, long offset, Object newValue) { + return getAndSetReferenceRelease(o, offset, newValue); + } + + + @Deprecated(since="12", forRemoval=true) + public final boolean compareAndSetObject(Object o, long offset, Object expected, Object x) { + return compareAndSetReference(o, offset, expected, x); + } + @Deprecated(since="12", forRemoval=true) + public final Object compareAndExchangeObject(Object o, long offset, Object expected, Object x) { + return compareAndExchangeReference(o, offset, expected, x); + } + @Deprecated(since="12", forRemoval=true) + public final Object compareAndExchangeObjectAcquire(Object o, long offset, Object expected, Object x) { + return compareAndExchangeReferenceAcquire(o, offset, expected, x); + } + @Deprecated(since="12", forRemoval=true) + public final Object compareAndExchangeObjectRelease(Object o, long offset, Object expected, Object x) { + return compareAndExchangeReferenceRelease(o, offset, expected, x); + } + + + @Deprecated(since="12", forRemoval=true) + public final boolean weakCompareAndSetObject(Object o, long offset, Object expected, Object x) { + return weakCompareAndSetReference(o, offset, expected, x); + } + @Deprecated(since="12", forRemoval=true) + public final boolean weakCompareAndSetObjectAcquire(Object o, long offset, Object expected, Object x) { + return weakCompareAndSetReferenceAcquire(o, offset, expected, x); + } + @Deprecated(since="12", forRemoval=true) + public final boolean weakCompareAndSetObjectPlain(Object o, long offset, Object expected, Object x) { + return weakCompareAndSetReferencePlain(o, offset, expected, x); + } + @Deprecated(since="12", forRemoval=true) + public final boolean weakCompareAndSetObjectRelease(Object o, long offset, Object expected, Object x) { + return weakCompareAndSetReferenceRelease(o, offset, expected, x); + } } From d797264488134caa4d0d67030cdc29d7c3469ed2 Mon Sep 17 00:00:00 2001 From: Jonathan Gibbons Date: Fri, 26 Oct 2018 15:13:12 -0700 Subject: [PATCH 37/84] 8213056: Nested anchor tags in java.lang.module Reviewed-by: darcy --- src/java.base/share/classes/java/lang/String.java | 1 - src/java.base/share/classes/java/lang/module/package-info.java | 2 +- 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/src/java.base/share/classes/java/lang/String.java b/src/java.base/share/classes/java/lang/String.java index 6a87fab70df..77b633b67a4 100644 --- a/src/java.base/share/classes/java/lang/String.java +++ b/src/java.base/share/classes/java/lang/String.java @@ -2821,7 +2821,6 @@ public final class String *

* If {@code n == 0} then the line remains unchanged. However, line * terminators are still normalized. - *

* * @param n number of leading * {@link Character#isWhitespace(int) white space characters} diff --git a/src/java.base/share/classes/java/lang/module/package-info.java b/src/java.base/share/classes/java/lang/module/package-info.java index d1849bed936..f794e87bff3 100644 --- a/src/java.base/share/classes/java/lang/module/package-info.java +++ b/src/java.base/share/classes/java/lang/module/package-info.java @@ -34,7 +34,7 @@ * will cause a {@code NullPointerException}, unless otherwise specified.

* * - *

{@index "Module Resolution"}

+ *

{@index "Module Resolution"}

* *

Resolution is the process of computing how modules depend on each other. * The process occurs at compile time and run time.

From 931c9cf86d10d6b338e4036f927b8116352efa3a Mon Sep 17 00:00:00 2001 From: Thomas Schatzl Date: Mon, 29 Oct 2018 08:52:04 +0100 Subject: [PATCH 38/84] 8212974: Update RS Skipped cards uses wrong enum to register to phase Reviewed-by: kbarrett --- src/hotspot/share/gc/g1/g1GCPhaseTimes.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/hotspot/share/gc/g1/g1GCPhaseTimes.cpp b/src/hotspot/share/gc/g1/g1GCPhaseTimes.cpp index 6072c9a2169..1ebc8df86c4 100644 --- a/src/hotspot/share/gc/g1/g1GCPhaseTimes.cpp +++ b/src/hotspot/share/gc/g1/g1GCPhaseTimes.cpp @@ -95,7 +95,7 @@ G1GCPhaseTimes::G1GCPhaseTimes(STWGCTimer* gc_timer, uint max_gc_threads) : _update_rs_scanned_cards = new WorkerDataArray(max_gc_threads, "Scanned Cards:"); _gc_par_phases[UpdateRS]->link_thread_work_items(_update_rs_scanned_cards, UpdateRSScannedCards); _update_rs_skipped_cards = new WorkerDataArray(max_gc_threads, "Skipped Cards:"); - _gc_par_phases[UpdateRS]->link_thread_work_items(_update_rs_skipped_cards, ScanRSSkippedCards); + _gc_par_phases[UpdateRS]->link_thread_work_items(_update_rs_skipped_cards, UpdateRSSkippedCards); _termination_attempts = new WorkerDataArray(max_gc_threads, "Termination Attempts:"); _gc_par_phases[Termination]->link_thread_work_items(_termination_attempts); From f69c1407aed06c663078cc9eb98c96481e456eb4 Mon Sep 17 00:00:00 2001 From: Thomas Schatzl Date: Mon, 29 Oct 2018 08:55:03 +0100 Subject: [PATCH 39/84] 8212766: TestPromotionEventWithG1.java failed due to "RuntimeException: PLAB size is smaller than object size." Also send PLAB size in bytes, not in heap words. Reviewed-by: shade, sjohanss --- src/hotspot/share/gc/g1/g1ParScanThreadState.cpp | 2 +- .../jdk/jfr/event/gc/detailed/TestPromotionEventWithG1.java | 5 +++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/src/hotspot/share/gc/g1/g1ParScanThreadState.cpp b/src/hotspot/share/gc/g1/g1ParScanThreadState.cpp index b9c52345d80..fb1d8715fc8 100644 --- a/src/hotspot/share/gc/g1/g1ParScanThreadState.cpp +++ b/src/hotspot/share/gc/g1/g1ParScanThreadState.cpp @@ -203,7 +203,7 @@ void G1ParScanThreadState::report_promotion_event(InCSetState const dest_state, if (alloc_buf->contains(obj_ptr)) { _g1h->_gc_tracer_stw->report_promotion_in_new_plab_event(old->klass(), word_sz * HeapWordSize, age, dest_state.value() == InCSetState::Old, - alloc_buf->word_sz()); + alloc_buf->word_sz() * HeapWordSize); } else { _g1h->_gc_tracer_stw->report_promotion_outside_plab_event(old->klass(), word_sz * HeapWordSize, age, dest_state.value() == InCSetState::Old); diff --git a/test/jdk/jdk/jfr/event/gc/detailed/TestPromotionEventWithG1.java b/test/jdk/jdk/jfr/event/gc/detailed/TestPromotionEventWithG1.java index 31911afd47e..c1bcbe26031 100644 --- a/test/jdk/jdk/jfr/event/gc/detailed/TestPromotionEventWithG1.java +++ b/test/jdk/jdk/jfr/event/gc/detailed/TestPromotionEventWithG1.java @@ -26,6 +26,7 @@ package jdk.jfr.event.gc.detailed; /** * @test + * @bug 8212766 * @key jfr * @summary Test that events are created when an object is aged or promoted during a GC and the copying of the object requires a new PLAB or direct heap allocation * @requires vm.hasJFR @@ -33,8 +34,8 @@ package jdk.jfr.event.gc.detailed; * @requires (vm.gc == "G1" | vm.gc == null) * & vm.opt.ExplicitGCInvokesConcurrent != true * @library /test/lib /test/jdk - * @run main/othervm -Xmx32m -Xms32m -Xmn12m -XX:+UseG1GC -XX:-UseStringDeduplication -XX:MaxTenuringThreshold=5 -XX:InitialTenuringThreshold=5 - * jdk.jfr.event.gc.detailed.TestPromotionEventWithG1 + * @run main/othervm -Xmx32m -Xms32m -Xmn12m -XX:+UseG1GC -XX:-UseStringDeduplication -XX:MaxTenuringThreshold=5 -XX:InitialTenuringThreshold=5 jdk.jfr.event.gc.detailed.TestPromotionEventWithG1 + * @run main/othervm -Xmx32m -Xms32m -Xmn12m -XX:+UseG1GC -XX:-UseStringDeduplication -XX:MaxTenuringThreshold=5 -XX:InitialTenuringThreshold=5 -XX:MinTLABSize=576 -XX:TLABSize=576 jdk.jfr.event.gc.detailed.TestPromotionEventWithG1 */ public class TestPromotionEventWithG1 { From 71637b00c70e1ae9ecb9e5479dc6d9df2e0503af Mon Sep 17 00:00:00 2001 From: Harold Seigel Date: Mon, 29 Oct 2018 08:38:59 -0400 Subject: [PATCH 40/84] 8212997: [TESTBUG] Remove defmeth tests for class file versions 50 and 51 Remove the unneeded tests. Keep the tests for class file versions 49 and 52. Reviewed-by: acorn, coleenp --- .../vmTestbase/vm/runtime/defmeth/README | 2 +- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 46 ------------------ .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- .../TestDescription.java | 41 ---------------- .../TestDescription.java | 48 ------------------- 321 files changed, 1 insertion(+), 14321 deletions(-) delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_reflect_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_direct_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_direct_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_invoke_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_invoke_redefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_reflect_noredefine/TestDescription.java delete mode 100644 test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_reflect_redefine/TestDescription.java diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/README b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/README index 559060be958..cfdae4fecc3 100644 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/README +++ b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/README @@ -131,7 +131,7 @@ OVERVIEW where majorVer - major version of class files for generated concrete classes - values: ver49, ver50, ver51, ver52 + values: ver49, ver52 methodFlags - additional access flags for methods in generated classes values: diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_direct_noredefine/TestDescription.java deleted file mode 100644 index 245a2957395..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_none_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 0 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_direct_redefine/TestDescription.java deleted file mode 100644 index 44a2fe55a31..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_none_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_invoke_noredefine/TestDescription.java deleted file mode 100644 index 113e6e07c56..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_none_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 0 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_invoke_redefine/TestDescription.java deleted file mode 100644 index 67c2e2abf53..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_none_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_reflect_noredefine/TestDescription.java deleted file mode 100644 index dd2d07cbea1..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_none_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 0 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_reflect_redefine/TestDescription.java deleted file mode 100644 index a3f9709d037..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_none_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_none_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_direct_noredefine/TestDescription.java deleted file mode 100644 index 39fdd634bd6..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_strict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 2048 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_direct_redefine/TestDescription.java deleted file mode 100644 index 6422d05fdb4..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_strict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 30957aa5f47..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_strict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 2048 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_invoke_redefine/TestDescription.java deleted file mode 100644 index 9a3be1668e3..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_strict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 668d36e0fc1..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_strict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 2048 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_reflect_redefine/TestDescription.java deleted file mode 100644 index 09c25ce9cb9..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_strict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_strict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_direct_noredefine/TestDescription.java deleted file mode 100644 index c2512896a8b..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_sync_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 32 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_direct_redefine/TestDescription.java deleted file mode 100644 index 30c98d42f97..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_sync_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_invoke_noredefine/TestDescription.java deleted file mode 100644 index 29d5acaf43b..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_sync_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 32 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_invoke_redefine/TestDescription.java deleted file mode 100644 index e8bab57356a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_sync_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_reflect_noredefine/TestDescription.java deleted file mode 100644 index 313db0368f4..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_sync_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 32 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_reflect_redefine/TestDescription.java deleted file mode 100644 index d5c588b1d64..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_sync_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_sync_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_direct_noredefine/TestDescription.java deleted file mode 100644 index 3646220b9f4..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 2080 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_direct_redefine/TestDescription.java deleted file mode 100644 index f7a2c9f24dc..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_invoke_noredefine/TestDescription.java deleted file mode 100644 index c904036db1a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 2080 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_invoke_redefine/TestDescription.java deleted file mode 100644 index 92360c2cb21..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_reflect_noredefine/TestDescription.java deleted file mode 100644 index a634463b8d6..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 2080 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_reflect_redefine/TestDescription.java deleted file mode 100644 index 960d6afead8..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v50_syncstrict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_direct_noredefine/TestDescription.java deleted file mode 100644 index 1892b1123d4..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_none_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 0 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_direct_redefine/TestDescription.java deleted file mode 100644 index c3660c853c0..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_none_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_invoke_noredefine/TestDescription.java deleted file mode 100644 index 1508d5c9eed..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_none_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 0 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_invoke_redefine/TestDescription.java deleted file mode 100644 index 50257abbf23..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_none_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_reflect_noredefine/TestDescription.java deleted file mode 100644 index 44a084c4647..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_none_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 0 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_reflect_redefine/TestDescription.java deleted file mode 100644 index f5c26057d40..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_none_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_none_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_direct_noredefine/TestDescription.java deleted file mode 100644 index 4875bb59d3d..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_strict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 2048 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_direct_redefine/TestDescription.java deleted file mode 100644 index 08d12140be7..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_strict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 9b410c8305a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_strict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 2048 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_invoke_redefine/TestDescription.java deleted file mode 100644 index ac2b21ab072..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_strict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_reflect_noredefine/TestDescription.java deleted file mode 100644 index ecaba376e81..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_strict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 2048 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_reflect_redefine/TestDescription.java deleted file mode 100644 index 38f8e023570..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_strict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_strict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_direct_noredefine/TestDescription.java deleted file mode 100644 index 820e32d7751..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_sync_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 32 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_direct_redefine/TestDescription.java deleted file mode 100644 index 15ff850ba19..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_sync_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_invoke_noredefine/TestDescription.java deleted file mode 100644 index 9a9806749ed..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_sync_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 32 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_invoke_redefine/TestDescription.java deleted file mode 100644 index b4259a01b15..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_sync_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_reflect_noredefine/TestDescription.java deleted file mode 100644 index 45d0b756102..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_sync_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 32 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_reflect_redefine/TestDescription.java deleted file mode 100644 index 256bf4ce0f2..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_sync_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_sync_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_direct_noredefine/TestDescription.java deleted file mode 100644 index 000d356c78a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 2080 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_direct_redefine/TestDescription.java deleted file mode 100644 index 178cb0294d0..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 624e362a80f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 2080 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_invoke_redefine/TestDescription.java deleted file mode 100644 index 0c711cae846..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 395bdb052a3..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 2080 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_reflect_redefine/TestDescription.java deleted file mode 100644 index f6266cf53bc..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Basic_v51_syncstrict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.BasicTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_direct_noredefine/TestDescription.java deleted file mode 100644 index b68641489e2..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 0 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_direct_redefine/TestDescription.java deleted file mode 100644 index 3c3ae4ff135..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_invoke_noredefine/TestDescription.java deleted file mode 100644 index ae61db85258..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 0 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_invoke_redefine/TestDescription.java deleted file mode 100644 index 39594f1ed01..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_reflect_noredefine/TestDescription.java deleted file mode 100644 index da7be26ad63..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 0 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_reflect_redefine/TestDescription.java deleted file mode 100644 index 42608b5583f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_none_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_direct_noredefine/TestDescription.java deleted file mode 100644 index 7b60ba9b49e..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 2048 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_direct_redefine/TestDescription.java deleted file mode 100644 index e4a5ad23e15..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 7cf02798af6..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 2048 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_invoke_redefine/TestDescription.java deleted file mode 100644 index fefe086d61f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 3e8f8bfaf6a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 2048 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_reflect_redefine/TestDescription.java deleted file mode 100644 index 865037e67c8..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_strict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_direct_noredefine/TestDescription.java deleted file mode 100644 index 8355b961a5a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 32 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_direct_redefine/TestDescription.java deleted file mode 100644 index e1e2cb8a618..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_invoke_noredefine/TestDescription.java deleted file mode 100644 index 357154f2849..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 32 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_invoke_redefine/TestDescription.java deleted file mode 100644 index 6ebf736b60e..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_reflect_noredefine/TestDescription.java deleted file mode 100644 index b9584d57d98..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 32 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_reflect_redefine/TestDescription.java deleted file mode 100644 index cd05da32aaa..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_sync_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_direct_noredefine/TestDescription.java deleted file mode 100644 index 0c537186d19..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 2080 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_direct_redefine/TestDescription.java deleted file mode 100644 index d546066e080..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 21cb3f90390..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 2080 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_invoke_redefine/TestDescription.java deleted file mode 100644 index b47099b2ef2..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_reflect_noredefine/TestDescription.java deleted file mode 100644 index f3e7da6ce6e..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 2080 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_reflect_redefine/TestDescription.java deleted file mode 100644 index 385e1462f5b..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v50_syncstrict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_direct_noredefine/TestDescription.java deleted file mode 100644 index a4df2663faa..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 0 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_direct_redefine/TestDescription.java deleted file mode 100644 index b354bb897c2..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_invoke_noredefine/TestDescription.java deleted file mode 100644 index b544e7cb50e..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 0 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_invoke_redefine/TestDescription.java deleted file mode 100644 index 5ff9b1d94d7..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_reflect_noredefine/TestDescription.java deleted file mode 100644 index f03eb4fc9f9..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 0 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_reflect_redefine/TestDescription.java deleted file mode 100644 index 4ea61055a53..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_none_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_direct_noredefine/TestDescription.java deleted file mode 100644 index cb5c00e44ef..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 2048 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_direct_redefine/TestDescription.java deleted file mode 100644 index a5a1b117b73..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_invoke_noredefine/TestDescription.java deleted file mode 100644 index c46d2310b82..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 2048 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_invoke_redefine/TestDescription.java deleted file mode 100644 index d01bc792b93..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 899a2ad475b..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 2048 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_reflect_redefine/TestDescription.java deleted file mode 100644 index 779a84ec5b9..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_strict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_direct_noredefine/TestDescription.java deleted file mode 100644 index d4c16b38828..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 32 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_direct_redefine/TestDescription.java deleted file mode 100644 index 85287fe763e..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_invoke_noredefine/TestDescription.java deleted file mode 100644 index 85e8b916c43..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 32 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_invoke_redefine/TestDescription.java deleted file mode 100644 index d8e28817285..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_reflect_noredefine/TestDescription.java deleted file mode 100644 index 1f8ab4d3d28..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 32 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_reflect_redefine/TestDescription.java deleted file mode 100644 index 2ad29ccf940..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_sync_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_direct_noredefine/TestDescription.java deleted file mode 100644 index c9ca8e43d11..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 2080 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_direct_redefine/TestDescription.java deleted file mode 100644 index dd8101aff1d..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 10a211c6bae..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 2080 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_invoke_redefine/TestDescription.java deleted file mode 100644 index fe9bcb3584a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 4516e25138a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 2080 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_reflect_redefine/TestDescription.java deleted file mode 100644 index 643884c4c50..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/ConflictingDefaults_v51_syncstrict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.ConflictingDefaultsTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_direct_noredefine/TestDescription.java deleted file mode 100644 index 8ed4602572f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 0 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_direct_redefine/TestDescription.java deleted file mode 100644 index 651ee17b972..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_invoke_noredefine/TestDescription.java deleted file mode 100644 index 0bd21827dba..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 0 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_invoke_redefine/TestDescription.java deleted file mode 100644 index db8cff1f566..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_reflect_noredefine/TestDescription.java deleted file mode 100644 index 48e2f63d84f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 0 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_reflect_redefine/TestDescription.java deleted file mode 100644 index bc0ec147690..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_none_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_direct_noredefine/TestDescription.java deleted file mode 100644 index 9a1632e2e76..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 2048 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_direct_redefine/TestDescription.java deleted file mode 100644 index b12b485e3a9..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 40286a45529..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 2048 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_invoke_redefine/TestDescription.java deleted file mode 100644 index aca267a69ab..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 2963426bbbd..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 2048 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_reflect_redefine/TestDescription.java deleted file mode 100644 index 075b6ef1e4f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_strict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_direct_noredefine/TestDescription.java deleted file mode 100644 index f62ceb79140..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 32 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_direct_redefine/TestDescription.java deleted file mode 100644 index 1a2da8c86c3..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_invoke_noredefine/TestDescription.java deleted file mode 100644 index 0a4e39c497d..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 32 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_invoke_redefine/TestDescription.java deleted file mode 100644 index 5c49dfa1671..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_reflect_noredefine/TestDescription.java deleted file mode 100644 index 5c68310d3a3..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 32 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_reflect_redefine/TestDescription.java deleted file mode 100644 index 898f0d1bf5f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_sync_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_direct_noredefine/TestDescription.java deleted file mode 100644 index d359f8c94b9..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 2080 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_direct_redefine/TestDescription.java deleted file mode 100644 index 70d8954e94b..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 3ccfbd67b6e..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 2080 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_invoke_redefine/TestDescription.java deleted file mode 100644 index 4080870a6ab..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_reflect_noredefine/TestDescription.java deleted file mode 100644 index b2cd55710f6..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 2080 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_reflect_redefine/TestDescription.java deleted file mode 100644 index 8092984e208..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v50_syncstrict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_direct_noredefine/TestDescription.java deleted file mode 100644 index 9efa93abd0b..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 0 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_direct_redefine/TestDescription.java deleted file mode 100644 index d155128c749..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_invoke_noredefine/TestDescription.java deleted file mode 100644 index ad8f8d010ab..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 0 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_invoke_redefine/TestDescription.java deleted file mode 100644 index 8e518cd6df1..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_reflect_noredefine/TestDescription.java deleted file mode 100644 index 1bf298f564e..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 0 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_reflect_redefine/TestDescription.java deleted file mode 100644 index 1a57feba20c..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_none_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_direct_noredefine/TestDescription.java deleted file mode 100644 index 250933da6f0..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 2048 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_direct_redefine/TestDescription.java deleted file mode 100644 index 619c2404c63..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_invoke_noredefine/TestDescription.java deleted file mode 100644 index fa3c9404b9d..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 2048 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_invoke_redefine/TestDescription.java deleted file mode 100644 index 71829cdd116..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 12291080579..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 2048 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_reflect_redefine/TestDescription.java deleted file mode 100644 index 907e0daa54a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_strict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_direct_noredefine/TestDescription.java deleted file mode 100644 index 362d7804410..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 32 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_direct_redefine/TestDescription.java deleted file mode 100644 index 632bc136d85..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_invoke_noredefine/TestDescription.java deleted file mode 100644 index dd157ebac8f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 32 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_invoke_redefine/TestDescription.java deleted file mode 100644 index b338eb12c6f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_reflect_noredefine/TestDescription.java deleted file mode 100644 index 6300b18854b..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 32 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_reflect_redefine/TestDescription.java deleted file mode 100644 index d69f583c886..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_sync_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_direct_noredefine/TestDescription.java deleted file mode 100644 index 5f4a19dbdf1..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 2080 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_direct_redefine/TestDescription.java deleted file mode 100644 index 9361652ac24..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 8f8dd6fcaef..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 2080 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_invoke_redefine/TestDescription.java deleted file mode 100644 index d24d9099902..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 171c48c6c4b..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 2080 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_reflect_redefine/TestDescription.java deleted file mode 100644 index d98ce780274..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/DefaultVsAbstract_v51_syncstrict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.DefaultVsAbstractTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_direct_noredefine/TestDescription.java deleted file mode 100644 index efbff828da7..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_none_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 0 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_direct_redefine/TestDescription.java deleted file mode 100644 index 563caf777a7..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_none_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_invoke_noredefine/TestDescription.java deleted file mode 100644 index dd2ba24052a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_none_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 0 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_invoke_redefine/TestDescription.java deleted file mode 100644 index 09b03329928..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_none_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_reflect_noredefine/TestDescription.java deleted file mode 100644 index 56becae6544..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_none_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 0 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_reflect_redefine/TestDescription.java deleted file mode 100644 index 272a0a7b2dc..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_none_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_none_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_direct_noredefine/TestDescription.java deleted file mode 100644 index 17d48a59a00..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 2048 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_direct_redefine/TestDescription.java deleted file mode 100644 index 180c33d92d1..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_invoke_noredefine/TestDescription.java deleted file mode 100644 index b4bca083c89..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 2048 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_invoke_redefine/TestDescription.java deleted file mode 100644 index 890d17aa270..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 6a159667ef3..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 2048 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_reflect_redefine/TestDescription.java deleted file mode 100644 index b65abf7b45d..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_strict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_direct_noredefine/TestDescription.java deleted file mode 100644 index a3ac3db4143..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 32 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_direct_redefine/TestDescription.java deleted file mode 100644 index d27ce82129f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_invoke_noredefine/TestDescription.java deleted file mode 100644 index 8535344bd17..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 32 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_invoke_redefine/TestDescription.java deleted file mode 100644 index 81ef4b8a850..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_reflect_noredefine/TestDescription.java deleted file mode 100644 index ec48510b4e4..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 32 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_reflect_redefine/TestDescription.java deleted file mode 100644 index 265ac8c75f6..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_sync_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_direct_noredefine/TestDescription.java deleted file mode 100644 index 849cb7817da..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 2080 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_direct_redefine/TestDescription.java deleted file mode 100644 index 88922b8f3b3..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 8b7472dfe0d..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 2080 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_invoke_redefine/TestDescription.java deleted file mode 100644 index 1be36eb11c8..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 4be3b5f92ea..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 2080 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_reflect_redefine/TestDescription.java deleted file mode 100644 index 08955ffdc40..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v50_syncstrict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_direct_noredefine/TestDescription.java deleted file mode 100644 index d4417a55e17..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_none_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 0 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_direct_redefine/TestDescription.java deleted file mode 100644 index 7b49cc63aed..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_none_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_invoke_noredefine/TestDescription.java deleted file mode 100644 index 7912c0bbc5e..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_none_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 0 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_invoke_redefine/TestDescription.java deleted file mode 100644 index d04c36d8f8d..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_none_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_reflect_noredefine/TestDescription.java deleted file mode 100644 index 28c479ccd8a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_none_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 0 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_reflect_redefine/TestDescription.java deleted file mode 100644 index 90cf6c81242..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_none_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_none_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_direct_noredefine/TestDescription.java deleted file mode 100644 index 1b00e33c1d5..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 2048 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_direct_redefine/TestDescription.java deleted file mode 100644 index 40c249f9ecd..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_invoke_noredefine/TestDescription.java deleted file mode 100644 index dfb833e28fe..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 2048 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_invoke_redefine/TestDescription.java deleted file mode 100644 index 555428b45e3..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 4baa5eb67a0..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 2048 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_reflect_redefine/TestDescription.java deleted file mode 100644 index b3fbec01da4..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_strict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_direct_noredefine/TestDescription.java deleted file mode 100644 index 8d6e4d7a06e..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 32 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_direct_redefine/TestDescription.java deleted file mode 100644 index ca3539bbd44..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_invoke_noredefine/TestDescription.java deleted file mode 100644 index d7034dbc28c..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 32 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_invoke_redefine/TestDescription.java deleted file mode 100644 index fe1d7887cf7..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_reflect_noredefine/TestDescription.java deleted file mode 100644 index a88c976da4f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 32 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_reflect_redefine/TestDescription.java deleted file mode 100644 index fa14795b681..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_sync_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_direct_noredefine/TestDescription.java deleted file mode 100644 index 6f90ad4b640..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 2080 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_direct_redefine/TestDescription.java deleted file mode 100644 index 11cdd1c8f01..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_invoke_noredefine/TestDescription.java deleted file mode 100644 index cda26b82758..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 2080 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_invoke_redefine/TestDescription.java deleted file mode 100644 index a23e995717a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 4f0f7d884d2..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 2080 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_reflect_redefine/TestDescription.java deleted file mode 100644 index d080f8d565d..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/MethodResolution_v51_syncstrict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.MethodResolutionTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_direct_noredefine/TestDescription.java deleted file mode 100644 index 2b90ad72ca8..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 0 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_direct_redefine/TestDescription.java deleted file mode 100644 index 18e0456156f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_invoke_noredefine/TestDescription.java deleted file mode 100644 index 15add0b0b98..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 0 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_invoke_redefine/TestDescription.java deleted file mode 100644 index e5a26f76480..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_reflect_noredefine/TestDescription.java deleted file mode 100644 index 61336c1ff01..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 0 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_reflect_redefine/TestDescription.java deleted file mode 100644 index f631a3dd646..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_none_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_direct_noredefine/TestDescription.java deleted file mode 100644 index b2d63d6935a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 2048 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_direct_redefine/TestDescription.java deleted file mode 100644 index a74667b895b..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 93f40000b88..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 2048 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_invoke_redefine/TestDescription.java deleted file mode 100644 index ec5582f56c1..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 7dcd23f2d36..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 2048 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_reflect_redefine/TestDescription.java deleted file mode 100644 index 7635f88bc31..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_strict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_direct_noredefine/TestDescription.java deleted file mode 100644 index 79feaafc70c..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 32 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_direct_redefine/TestDescription.java deleted file mode 100644 index 9de3b2b9aaa..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_invoke_noredefine/TestDescription.java deleted file mode 100644 index 141c4e13abd..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 32 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_invoke_redefine/TestDescription.java deleted file mode 100644 index be7ec9abc85..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_reflect_noredefine/TestDescription.java deleted file mode 100644 index f94ca0ad792..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 32 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_reflect_redefine/TestDescription.java deleted file mode 100644 index 3bbd1277402..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_sync_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_direct_noredefine/TestDescription.java deleted file mode 100644 index 04b3bb4d6a9..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 2080 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_direct_redefine/TestDescription.java deleted file mode 100644 index 88716860f60..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 0b7695df99c..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 2080 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_invoke_redefine/TestDescription.java deleted file mode 100644 index b5aa7dc6b16..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 7b0353e64a9..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 2080 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_reflect_redefine/TestDescription.java deleted file mode 100644 index 069575f3a45..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v50_syncstrict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_direct_noredefine/TestDescription.java deleted file mode 100644 index c9b359cf781..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 0 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_direct_redefine/TestDescription.java deleted file mode 100644 index a021560a45f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_invoke_noredefine/TestDescription.java deleted file mode 100644 index e089e16d731..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 0 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_invoke_redefine/TestDescription.java deleted file mode 100644 index 1ee0193647f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_reflect_noredefine/TestDescription.java deleted file mode 100644 index 83c261a732b..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 0 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_reflect_redefine/TestDescription.java deleted file mode 100644 index 76083e9d13d..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_none_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_direct_noredefine/TestDescription.java deleted file mode 100644 index f64348fc931..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 2048 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_direct_redefine/TestDescription.java deleted file mode 100644 index 37029866d12..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_invoke_noredefine/TestDescription.java deleted file mode 100644 index fe3b7924161..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 2048 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_invoke_redefine/TestDescription.java deleted file mode 100644 index eeabbcc8863..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 1f45d8266d3..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 2048 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_reflect_redefine/TestDescription.java deleted file mode 100644 index d2849cbf641..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_strict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_direct_noredefine/TestDescription.java deleted file mode 100644 index 2f289d964c4..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 32 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_direct_redefine/TestDescription.java deleted file mode 100644 index 67eb080a4cb..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_invoke_noredefine/TestDescription.java deleted file mode 100644 index 47ae637d70f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 32 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_invoke_redefine/TestDescription.java deleted file mode 100644 index 2a0efe7c3d6..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_reflect_noredefine/TestDescription.java deleted file mode 100644 index 564abf41485..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 32 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_reflect_redefine/TestDescription.java deleted file mode 100644 index 25c655333bb..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_sync_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_direct_noredefine/TestDescription.java deleted file mode 100644 index ca12080f1a3..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 2080 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_direct_redefine/TestDescription.java deleted file mode 100644 index b9e4fe07f78..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 650cbaa15b9..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 2080 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_invoke_redefine/TestDescription.java deleted file mode 100644 index 22cf463df06..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 9f25cb9cae5..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 2080 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_reflect_redefine/TestDescription.java deleted file mode 100644 index aed5c28e8d6..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/PrivateMethods_v51_syncstrict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.PrivateMethodsTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_direct_noredefine/TestDescription.java deleted file mode 100644 index 63dd97e5b97..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_none_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 0 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_direct_redefine/TestDescription.java deleted file mode 100644 index 8149de182b3..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_none_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_invoke_noredefine/TestDescription.java deleted file mode 100644 index 0b04d8719e4..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_none_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 0 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_invoke_redefine/TestDescription.java deleted file mode 100644 index af9327bba34..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_none_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_none_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_direct_noredefine/TestDescription.java deleted file mode 100644 index ff2dd09efc4..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_strict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 2048 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_direct_redefine/TestDescription.java deleted file mode 100644 index 59d67086a8c..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_strict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 4cedaf2d07e..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_strict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 2048 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_invoke_redefine/TestDescription.java deleted file mode 100644 index b213c812c60..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_strict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_strict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_direct_noredefine/TestDescription.java deleted file mode 100644 index 1aa186339e8..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_sync_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 32 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_direct_redefine/TestDescription.java deleted file mode 100644 index 99495d51e22..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_sync_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_invoke_noredefine/TestDescription.java deleted file mode 100644 index 73315c8d599..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_sync_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 32 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_invoke_redefine/TestDescription.java deleted file mode 100644 index 74b06ef2bb6..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_sync_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_sync_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_direct_noredefine/TestDescription.java deleted file mode 100644 index 771c63c0e6c..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 2080 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_direct_redefine/TestDescription.java deleted file mode 100644 index 3dc6e1bc202..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 1b3affb1df3..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 2080 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_invoke_redefine/TestDescription.java deleted file mode 100644 index 310615a560c..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v50_syncstrict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_direct_noredefine/TestDescription.java deleted file mode 100644 index fb3de612ba7..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_none_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 0 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_direct_redefine/TestDescription.java deleted file mode 100644 index 6258387b3ed..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_none_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_invoke_noredefine/TestDescription.java deleted file mode 100644 index e1f54cba3c4..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_none_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 0 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_invoke_redefine/TestDescription.java deleted file mode 100644 index 5740cf7835b..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_none_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_none_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_direct_noredefine/TestDescription.java deleted file mode 100644 index 3c11b3bdb26..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_strict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 2048 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_direct_redefine/TestDescription.java deleted file mode 100644 index f822ca0f0c0..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_strict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 8bc24aad4c4..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_strict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 2048 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_invoke_redefine/TestDescription.java deleted file mode 100644 index c105515067f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_strict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_strict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_direct_noredefine/TestDescription.java deleted file mode 100644 index 2459c79d8fc..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_sync_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 32 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_direct_redefine/TestDescription.java deleted file mode 100644 index f96074b657f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_sync_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_invoke_noredefine/TestDescription.java deleted file mode 100644 index e6f24a5974a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_sync_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 32 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_invoke_redefine/TestDescription.java deleted file mode 100644 index bf15b52e750..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_sync_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_sync_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_direct_noredefine/TestDescription.java deleted file mode 100644 index c3d6793ad15..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 2080 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_direct_redefine/TestDescription.java deleted file mode 100644 index cd4b15a2ef0..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_invoke_noredefine/TestDescription.java deleted file mode 100644 index ecc16c8f189..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 2080 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_invoke_redefine/TestDescription.java deleted file mode 100644 index 4952b3b3496..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/Redefine_v51_syncstrict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.RedefineTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_direct_noredefine/TestDescription.java deleted file mode 100644 index e7ed979225f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_none_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 0 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_direct_redefine/TestDescription.java deleted file mode 100644 index c3717bd0859..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_none_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_invoke_noredefine/TestDescription.java deleted file mode 100644 index 1fdab35081d..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_none_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 0 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_invoke_redefine/TestDescription.java deleted file mode 100644 index 96ded93921c..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_none_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_reflect_noredefine/TestDescription.java deleted file mode 100644 index 5d16d677167..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_none_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 0 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_reflect_redefine/TestDescription.java deleted file mode 100644 index 155295a4a38..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_none_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_none_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 0 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_direct_noredefine/TestDescription.java deleted file mode 100644 index f776cb6aafb..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 2048 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_direct_redefine/TestDescription.java deleted file mode 100644 index 70d81939f7f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_invoke_noredefine/TestDescription.java deleted file mode 100644 index d77d3f14ded..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 2048 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_invoke_redefine/TestDescription.java deleted file mode 100644 index 38b5bba2fe3..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 658138835ab..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 2048 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_reflect_redefine/TestDescription.java deleted file mode 100644 index 2dd7fdb35fd..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_strict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 2048 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_direct_noredefine/TestDescription.java deleted file mode 100644 index a327777ca7a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 32 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_direct_redefine/TestDescription.java deleted file mode 100644 index 21c8f2a54f3..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_invoke_noredefine/TestDescription.java deleted file mode 100644 index 8ec02147014..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 32 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_invoke_redefine/TestDescription.java deleted file mode 100644 index d912f622a7f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_reflect_noredefine/TestDescription.java deleted file mode 100644 index 4b800e940ef..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 32 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_reflect_redefine/TestDescription.java deleted file mode 100644 index e90532fee6a..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_sync_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 32 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_direct_noredefine/TestDescription.java deleted file mode 100644 index dc7aa534450..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 2080 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_direct_redefine/TestDescription.java deleted file mode 100644 index 898576eb63d..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 1d170ea6392..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 2080 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_invoke_redefine/TestDescription.java deleted file mode 100644 index 6e5b6e6a44e..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_reflect_noredefine/TestDescription.java deleted file mode 100644 index bff24412612..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 2080 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_reflect_redefine/TestDescription.java deleted file mode 100644 index 401b72a93e8..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v50_syncstrict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 50 - * -flags 2080 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_direct_noredefine/TestDescription.java deleted file mode 100644 index 7de9c797884..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_none_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 0 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_direct_redefine/TestDescription.java deleted file mode 100644 index 480437fc41c..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_none_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_invoke_noredefine/TestDescription.java deleted file mode 100644 index 2b7f92b7bdc..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_none_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 0 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_invoke_redefine/TestDescription.java deleted file mode 100644 index 4e6ec6cf07b..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_none_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_reflect_noredefine/TestDescription.java deleted file mode 100644 index 6d0dbcf4b04..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_none_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 0 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_reflect_redefine/TestDescription.java deleted file mode 100644 index 0c12ef0aa64..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_none_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_none_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 0 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_direct_noredefine/TestDescription.java deleted file mode 100644 index 93536501c8b..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 2048 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_direct_redefine/TestDescription.java deleted file mode 100644 index 3e7e61c1ee2..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_invoke_noredefine/TestDescription.java deleted file mode 100644 index 6d001e4172e..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 2048 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_invoke_redefine/TestDescription.java deleted file mode 100644 index f3e092a96de..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_reflect_noredefine/TestDescription.java deleted file mode 100644 index 0d6db393c80..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 2048 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_reflect_redefine/TestDescription.java deleted file mode 100644 index ae55956c41f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_strict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 2048 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_direct_noredefine/TestDescription.java deleted file mode 100644 index 537b7611247..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 32 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_direct_redefine/TestDescription.java deleted file mode 100644 index 81b8799c99c..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_invoke_noredefine/TestDescription.java deleted file mode 100644 index d65e7b62ecc..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 32 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_invoke_redefine/TestDescription.java deleted file mode 100644 index 70e71a3f377..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_reflect_noredefine/TestDescription.java deleted file mode 100644 index eb7f4617107..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 32 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_reflect_redefine/TestDescription.java deleted file mode 100644 index 2c341b9530b..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_sync_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 32 - * -redefine - * -retransform - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_direct_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_direct_noredefine/TestDescription.java deleted file mode 100644 index 9cf18552946..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_direct_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_direct_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 2080 - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_direct_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_direct_redefine/TestDescription.java deleted file mode 100644 index f9fad630578..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_direct_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_direct_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode direct - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_invoke_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_invoke_noredefine/TestDescription.java deleted file mode 100644 index be168fa7e55..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_invoke_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_invoke_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 2080 - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_invoke_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_invoke_redefine/TestDescription.java deleted file mode 100644 index 2113642a69f..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_invoke_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_invoke_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode invoke - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_reflect_noredefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_reflect_noredefine/TestDescription.java deleted file mode 100644 index f86ae43e585..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_reflect_noredefine/TestDescription.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_reflect_noredefine. - * VM Testbase keywords: [defmeth, jdk8, quick] - * - * @library /vmTestbase /test/lib - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm - * -XX:+IgnoreUnrecognizedVMOptions - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 2080 - * -mode reflect - */ - diff --git a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_reflect_redefine/TestDescription.java b/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_reflect_redefine/TestDescription.java deleted file mode 100644 index 611640fada7..00000000000 --- a/test/hotspot/jtreg/vmTestbase/vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_reflect_redefine/TestDescription.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2017, 2018, 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 - * @modules java.base/jdk.internal.org.objectweb.asm:+open java.base/jdk.internal.org.objectweb.asm.util:+open - * - * @summary converted from VM Testbase vm/runtime/defmeth/scenarios/StaticMethods_v51_syncstrict_reflect_redefine. - * VM Testbase keywords: [defmeth, jdk8, jdk_instrument, quick] - * - * @library /vmTestbase /test/lib - * - * @comment build retransform.jar in current dir - * @run driver vm.runtime.defmeth.shared.BuildJar - * - * @run driver jdk.test.lib.FileInstaller . . - * @run main/othervm/native - * -agentlib:redefineClasses - * -javaagent:retransform.jar - * vm.runtime.defmeth.StaticMethodsTest - * -ver 51 - * -flags 2080 - * -redefine - * -retransform - * -mode reflect - */ - From 6a045adbed74710b10e68d8b2ee14bf2f92aad16 Mon Sep 17 00:00:00 2001 From: Coleen Phillimore Date: Mon, 29 Oct 2018 10:21:34 -0400 Subject: [PATCH 41/84] 8212958: Allow Klass::_subklass and _next_sibling to have unloaded classes Don't return unloaded klasses. Make sure access is protected by Compile_lock. Reviewed-by: eosterlund, dlong --- src/hotspot/share/ci/ciInstanceKlass.cpp | 11 +- src/hotspot/share/ci/ciInstanceKlass.hpp | 9 +- .../share/jfr/jni/jfrGetAllEventClasses.cpp | 18 +-- src/hotspot/share/jvmci/jvmciCompilerToVM.cpp | 1 + src/hotspot/share/memory/universe.cpp | 18 +-- src/hotspot/share/memory/universe.hpp | 1 + src/hotspot/share/oops/instanceKlass.cpp | 110 ++++++++++-------- src/hotspot/share/oops/instanceKlass.hpp | 2 +- src/hotspot/share/oops/klass.cpp | 63 +++++++--- src/hotspot/share/oops/klass.hpp | 5 +- src/hotspot/share/runtime/mutex.cpp | 2 +- src/hotspot/share/utilities/vmError.cpp | 2 + .../ClassUnload/UnloadInterfaceTest.java | 95 +++++++++++++++ .../ClassUnload/test/ImplementorClass.java | 29 +++++ .../runtime/ClassUnload/test/Interface.java | 29 +++++ .../testlibrary/ClassUnloadCommon.java | 21 ++++ 16 files changed, 322 insertions(+), 94 deletions(-) create mode 100644 test/hotspot/jtreg/runtime/ClassUnload/UnloadInterfaceTest.java create mode 100644 test/hotspot/jtreg/runtime/ClassUnload/test/ImplementorClass.java create mode 100644 test/hotspot/jtreg/runtime/ClassUnload/test/Interface.java diff --git a/src/hotspot/share/ci/ciInstanceKlass.cpp b/src/hotspot/share/ci/ciInstanceKlass.cpp index b04e7b1c29d..e72cebc1b14 100644 --- a/src/hotspot/share/ci/ciInstanceKlass.cpp +++ b/src/hotspot/share/ci/ciInstanceKlass.cpp @@ -57,7 +57,7 @@ ciInstanceKlass::ciInstanceKlass(Klass* k) : AccessFlags access_flags = ik->access_flags(); _flags = ciFlags(access_flags); _has_finalizer = access_flags.has_finalizer(); - _has_subklass = ik->subklass() != NULL; + _has_subklass = flags().is_final() ? subklass_false : subklass_unknown; _init_state = ik->init_state(); _nonstatic_field_size = ik->nonstatic_field_size(); _has_nonstatic_fields = ik->has_nonstatic_fields(); @@ -146,9 +146,10 @@ void ciInstanceKlass::compute_shared_init_state() { // ciInstanceKlass::compute_shared_has_subklass bool ciInstanceKlass::compute_shared_has_subklass() { GUARDED_VM_ENTRY( + MutexLocker ml(Compile_lock); InstanceKlass* ik = get_instanceKlass(); - _has_subklass = ik->subklass() != NULL; - return _has_subklass; + _has_subklass = ik->subklass() != NULL ? subklass_true : subklass_false; + return _has_subklass == subklass_true; ) } @@ -374,6 +375,7 @@ ciInstanceKlass* ciInstanceKlass::unique_concrete_subklass() { if (!is_abstract()) return NULL; // Only applies to abstract classes. if (!has_subklass()) return NULL; // Must have at least one subklass. VM_ENTRY_MARK; + MutexLocker ml(Compile_lock); InstanceKlass* ik = get_instanceKlass(); Klass* up = ik->up_cast_abstract(); assert(up->is_instance_klass(), "must be InstanceKlass"); @@ -388,6 +390,7 @@ ciInstanceKlass* ciInstanceKlass::unique_concrete_subklass() { bool ciInstanceKlass::has_finalizable_subclass() { if (!is_loaded()) return true; VM_ENTRY_MARK; + MutexLocker ml(Compile_lock); return Dependencies::find_finalizable_subclass(get_instanceKlass()) != NULL; } @@ -577,7 +580,7 @@ bool ciInstanceKlass::is_leaf_type() { if (is_shared()) { return is_final(); // approximately correct } else { - return !_has_subklass && (nof_implementors() == 0); + return !has_subklass() && (nof_implementors() == 0); } } diff --git a/src/hotspot/share/ci/ciInstanceKlass.hpp b/src/hotspot/share/ci/ciInstanceKlass.hpp index c5b7d78f4b9..303ee04ff9f 100644 --- a/src/hotspot/share/ci/ciInstanceKlass.hpp +++ b/src/hotspot/share/ci/ciInstanceKlass.hpp @@ -44,13 +44,15 @@ class ciInstanceKlass : public ciKlass { friend class ciField; private: + enum SubklassValue { subklass_unknown, subklass_false, subklass_true }; + jobject _loader; jobject _protection_domain; InstanceKlass::ClassState _init_state; // state of class bool _is_shared; bool _has_finalizer; - bool _has_subklass; + SubklassValue _has_subklass; bool _has_nonstatic_fields; bool _has_nonstatic_concrete_methods; bool _is_unsafe_anonymous; @@ -139,14 +141,15 @@ public: return _has_finalizer; } bool has_subklass() { assert(is_loaded(), "must be loaded"); - if (_is_shared && !_has_subklass) { + if (_has_subklass == subklass_unknown || + (_is_shared && _has_subklass == subklass_false)) { if (flags().is_final()) { return false; } else { return compute_shared_has_subklass(); } } - return _has_subklass; + return _has_subklass == subklass_true; } jint size_helper() { return (Klass::layout_helper_size_in_bytes(layout_helper()) diff --git a/src/hotspot/share/jfr/jni/jfrGetAllEventClasses.cpp b/src/hotspot/share/jfr/jni/jfrGetAllEventClasses.cpp index 2854c2c30c1..d4978c46be7 100644 --- a/src/hotspot/share/jfr/jni/jfrGetAllEventClasses.cpp +++ b/src/hotspot/share/jfr/jni/jfrGetAllEventClasses.cpp @@ -90,7 +90,6 @@ static void fill_klasses(GrowableArray& event_subklasses, const Kla DEBUG_ONLY(JfrJavaSupport::check_java_thread_in_vm(thread)); Stack mark_stack; - MutexLocker ml(Compile_lock, thread); mark_stack.push(event_klass->subklass()); while (!mark_stack.is_empty()) { @@ -146,16 +145,19 @@ jobject JfrEventClasses::get_all_event_classes(TRAPS) { assert(klass != NULL, "invariant"); assert(JdkJfrEvent::is(klass), "invariant"); - if (klass->subklass() == NULL) { - return empty_java_util_arraylist; - } - ResourceMark rm(THREAD); GrowableArray event_subklasses(THREAD, initial_size_growable_array); - fill_klasses(event_subklasses, klass, THREAD); + { + MutexLocker cl(Compile_lock); + if (klass->subklass() == NULL) { + return empty_java_util_arraylist; + } - if (event_subklasses.is_empty()) { - return empty_java_util_arraylist; + fill_klasses(event_subklasses, klass, THREAD); + + if (event_subklasses.is_empty()) { + return empty_java_util_arraylist; + } } transform_klasses_to_local_jni_handles(event_subklasses, THREAD); diff --git a/src/hotspot/share/jvmci/jvmciCompilerToVM.cpp b/src/hotspot/share/jvmci/jvmciCompilerToVM.cpp index 670b351dd13..8eba7677c5d 100644 --- a/src/hotspot/share/jvmci/jvmciCompilerToVM.cpp +++ b/src/hotspot/share/jvmci/jvmciCompilerToVM.cpp @@ -627,6 +627,7 @@ C2V_END C2V_VMENTRY(jboolean, hasFinalizableSubclass,(JNIEnv *, jobject, jobject jvmci_type)) Klass* klass = CompilerToVM::asKlass(jvmci_type); assert(klass != NULL, "method must not be called for primitive types"); + MutexLocker ml(Compile_lock); return Dependencies::find_finalizable_subclass(klass) != NULL; C2V_END diff --git a/src/hotspot/share/memory/universe.cpp b/src/hotspot/share/memory/universe.cpp index b62f6281a25..f016ce934d3 100644 --- a/src/hotspot/share/memory/universe.cpp +++ b/src/hotspot/share/memory/universe.cpp @@ -531,10 +531,6 @@ oop Universe::swap_reference_pending_list(oop list) { #undef assert_pll_locked #undef assert_pll_ownership -// initialize_vtable could cause gc if -// 1) we specified true to initialize_vtable and -// 2) this ran after gc was enabled -// In case those ever change we use handles for oops void Universe::reinitialize_vtable_of(Klass* ko, TRAPS) { // init vtable of k and all subclasses ko->vtable().initialize_vtable(false, CHECK); @@ -547,6 +543,16 @@ void Universe::reinitialize_vtable_of(Klass* ko, TRAPS) { } } +void Universe::reinitialize_vtables(TRAPS) { + // The vtables are initialized by starting at java.lang.Object and + // initializing through the subclass links, so that the super + // classes are always initialized first. The subclass links + // require the Compile_lock. + MutexLocker cl(Compile_lock); + Klass* ok = SystemDictionary::Object_klass(); + Universe::reinitialize_vtable_of(ok, THREAD); +} + void initialize_itable_for_klass(InstanceKlass* k, TRAPS) { k->itable().initialize_itable(false, CHECK); @@ -964,9 +970,7 @@ bool universe_post_init() { { ResourceMark rm; Interpreter::initialize(); // needed for interpreter entry points if (!UseSharedSpaces) { - HandleMark hm(THREAD); - Klass* ok = SystemDictionary::Object_klass(); - Universe::reinitialize_vtable_of(ok, CHECK_false); + Universe::reinitialize_vtables(CHECK_false); Universe::reinitialize_itables(CHECK_false); } } diff --git a/src/hotspot/share/memory/universe.hpp b/src/hotspot/share/memory/universe.hpp index 0acc16a7917..9a37d79809f 100644 --- a/src/hotspot/share/memory/universe.hpp +++ b/src/hotspot/share/memory/universe.hpp @@ -219,6 +219,7 @@ class Universe: AllStatic { static void fixup_mirrors(TRAPS); static void reinitialize_vtable_of(Klass* k, TRAPS); + static void reinitialize_vtables(TRAPS); static void reinitialize_itables(TRAPS); static void compute_base_vtable_size(); // compute vtable size of class Object diff --git a/src/hotspot/share/oops/instanceKlass.cpp b/src/hotspot/share/oops/instanceKlass.cpp index d6f5b368403..6471b11833b 100644 --- a/src/hotspot/share/oops/instanceKlass.cpp +++ b/src/hotspot/share/oops/instanceKlass.cpp @@ -1054,16 +1054,28 @@ void InstanceKlass::set_initialization_state_and_notify(ClassState state, TRAPS) } } -Klass* InstanceKlass::implementor() const { +Klass* InstanceKlass::implementor(bool log) const { assert_locked_or_safepoint(Compile_lock); Klass** k = adr_implementor(); if (k == NULL) { return NULL; } else { - return *k; + Klass* kls = *k; + if (kls != NULL && !kls->is_loader_alive()) { + if (log) { + if (log_is_enabled(Trace, class, unload)) { + ResourceMark rm; + log_trace(class, unload)("unlinking class (implementor): %s", kls->external_name()); + } + } + return NULL; // don't return unloaded class + } else { + return kls; + } } } + void InstanceKlass::set_implementor(Klass* k) { assert_lock_strong(Compile_lock); assert(is_interface(), "not interface"); @@ -2139,20 +2151,15 @@ void InstanceKlass::clean_weak_instanceklass_links() { } void InstanceKlass::clean_implementors_list() { + assert_locked_or_safepoint(Compile_lock); assert(is_loader_alive(), "this klass should be live"); if (is_interface()) { - if (ClassUnloading) { - Klass* impl = implementor(); - if (impl != NULL) { - if (!impl->is_loader_alive()) { - // remove this guy - Klass** klass = adr_implementor(); - assert(klass != NULL, "null klass"); - if (klass != NULL) { - *klass = NULL; - } - } - } + assert (ClassUnloading, "only called for ClassUnloading"); + Klass* impl = implementor(true); + if (impl == NULL) { + // NULL this field, might be an unloaded klass or NULL + Klass** klass = adr_implementor(); + *klass = NULL; } } } @@ -3080,28 +3087,29 @@ void InstanceKlass::print_on(outputStream* st) const { st->print(BULLET"name: "); name()->print_value_on(st); st->cr(); st->print(BULLET"super: "); Metadata::print_value_on_maybe_null(st, super()); st->cr(); st->print(BULLET"sub: "); - Klass* sub = subklass(); - int n; - for (n = 0; sub != NULL; n++, sub = sub->next_sibling()) { - if (n < MaxSubklassPrintSize) { - sub->print_value_on(st); - st->print(" "); - } - } - if (n >= MaxSubklassPrintSize) st->print("(" INTX_FORMAT " more klasses...)", n - MaxSubklassPrintSize); - st->cr(); - - if (is_interface()) { + { MutexLocker ml(Compile_lock); - st->print_cr(BULLET"nof implementors: %d", nof_implementors()); - if (nof_implementors() == 1) { - st->print_cr(BULLET"implementor: "); - st->print(" "); - implementor()->print_value_on(st); - st->cr(); + Klass* sub = subklass(); + int n; + for (n = 0; sub != NULL; n++, sub = sub->next_sibling()) { + if (n < MaxSubklassPrintSize) { + sub->print_value_on(st); + st->print(" "); + } + } + if (n >= MaxSubklassPrintSize) st->print("(" INTX_FORMAT " more klasses...)", n - MaxSubklassPrintSize); + st->cr(); + + if (is_interface()) { + st->print_cr(BULLET"nof implementors: %d", nof_implementors()); + if (nof_implementors() == 1) { + st->print_cr(BULLET"implementor: "); + st->print(" "); + implementor()->print_value_on(st); + st->cr(); + } } } - st->print(BULLET"arrays: "); Metadata::print_value_on_maybe_null(st, array_klasses()); st->cr(); st->print(BULLET"methods: "); methods()->print_value_on(st); st->cr(); if (Verbose || WizardMode) { @@ -3483,25 +3491,29 @@ void InstanceKlass::verify_on(outputStream* st) { vtable().verify(st); } - // Verify first subklass - if (subklass() != NULL) { - guarantee(subklass()->is_klass(), "should be klass"); - } - - // Verify siblings - Klass* super = this->super(); - Klass* sib = next_sibling(); - if (sib != NULL) { - if (sib == this) { - fatal("subclass points to itself " PTR_FORMAT, p2i(sib)); + // This is called from add_to_hierarchy when the Compile_lock is owned. + { + MutexLockerEx ml(Compile_lock->owned_by_self() ? NULL : Compile_lock); + // Verify first subklass + if (subklass() != NULL) { + guarantee(subklass()->is_klass(), "should be klass"); } - guarantee(sib->is_klass(), "should be klass"); - guarantee(sib->super() == super, "siblings should have same superklass"); - } + // Verify siblings + Klass* super = this->super(); + Klass* sib = next_sibling(); + if (sib != NULL) { + if (sib == this) { + fatal("subclass points to itself " PTR_FORMAT, p2i(sib)); + } - // Verify implementor fields requires the Compile_lock, but this is sometimes - // called inside a safepoint, so don't verify. + guarantee(sib->is_klass(), "should be klass"); + guarantee(sib->super() == super, "siblings should have same superklass"); + } + + // Verify implementor fields requires the Compile_lock, + // but this is sometimes called inside a safepoint, so don't verify. + } // Verify local interfaces if (local_interfaces()) { diff --git a/src/hotspot/share/oops/instanceKlass.hpp b/src/hotspot/share/oops/instanceKlass.hpp index aac519f3576..3d3a9d49909 100644 --- a/src/hotspot/share/oops/instanceKlass.hpp +++ b/src/hotspot/share/oops/instanceKlass.hpp @@ -1007,7 +1007,7 @@ public: #endif // Access to the implementor of an interface. - Klass* implementor() const; + Klass* implementor(bool log = false) const; void set_implementor(Klass* k); int nof_implementors() const; void add_implementor(Klass* k); // k is a new class that implements this interface diff --git a/src/hotspot/share/oops/klass.cpp b/src/hotspot/share/oops/klass.cpp index a9da8f9269c..ecc51719b8e 100644 --- a/src/hotspot/share/oops/klass.cpp +++ b/src/hotspot/share/oops/klass.cpp @@ -117,7 +117,7 @@ Klass *Klass::up_cast_abstract() { Klass *r = this; while( r->is_abstract() ) { // Receiver is abstract? Klass *s = r->subklass(); // Check for exactly 1 subklass - if( !s || s->next_sibling() ) // Oops; wrong count; give up + if (s == NULL || s->next_sibling() != NULL) // Oops; wrong count; give up return this; // Return 'this' as a no-progress flag r = s; // Loop till find concrete class } @@ -358,11 +358,49 @@ GrowableArray* Klass::compute_secondary_supers(int num_extra_slots, } +// superklass links InstanceKlass* Klass::superklass() const { assert(super() == NULL || super()->is_instance_klass(), "must be instance klass"); return _super == NULL ? NULL : InstanceKlass::cast(_super); } +// subklass links. Used by the compiler (and vtable initialization) +// May be cleaned concurrently, so must use the Compile_lock. +// The log parameter is for clean_weak_klass_links to report unlinked classes. +Klass* Klass::subklass(bool log) const { + assert_locked_or_safepoint(Compile_lock); + for (Klass* chain = _subklass; chain != NULL; + chain = chain->_next_sibling) { + if (chain->is_loader_alive()) { + return chain; + } else if (log) { + if (log_is_enabled(Trace, class, unload)) { + ResourceMark rm; + log_trace(class, unload)("unlinking class (subclass): %s", chain->external_name()); + } + } + } + return NULL; +} + +Klass* Klass::next_sibling(bool log) const { + assert_locked_or_safepoint(Compile_lock); + for (Klass* chain = _next_sibling; chain != NULL; + chain = chain->_next_sibling) { + // Only return alive klass, there may be stale klass + // in this chain if cleaned concurrently. + if (chain->is_loader_alive()) { + return chain; + } else if (log) { + if (log_is_enabled(Trace, class, unload)) { + ResourceMark rm; + log_trace(class, unload)("unlinking class (sibling): %s", chain->external_name()); + } + } + } + return NULL; +} + void Klass::set_subklass(Klass* s) { assert(s != this, "sanity check"); _subklass = s; @@ -374,6 +412,7 @@ void Klass::set_next_sibling(Klass* s) { } void Klass::append_to_sibling_list() { + assert_locked_or_safepoint(Compile_lock); debug_only(verify();) // add ourselves to superklass' subklass list InstanceKlass* super = superklass(); @@ -381,6 +420,7 @@ void Klass::append_to_sibling_list() { assert((!super->is_interface() // interfaces cannot be supers && (super->superklass() == NULL || !is_interface())), "an interface can only be a subklass of Object"); + Klass* prev_first_subklass = super->subklass(); if (prev_first_subklass != NULL) { // set our sibling to be the superklass' previous first subklass @@ -396,6 +436,7 @@ oop Klass::holder_phantom() const { } void Klass::clean_weak_klass_links(bool unloading_occurred, bool clean_alive_klasses) { + assert_locked_or_safepoint(Compile_lock); if (!ClassUnloading || !unloading_occurred) { return; } @@ -410,30 +451,14 @@ void Klass::clean_weak_klass_links(bool unloading_occurred, bool clean_alive_kla assert(current->is_loader_alive(), "just checking, this should be live"); // Find and set the first alive subklass - Klass* sub = current->subklass(); - while (sub != NULL && !sub->is_loader_alive()) { -#ifndef PRODUCT - if (log_is_enabled(Trace, class, unload)) { - ResourceMark rm; - log_trace(class, unload)("unlinking class (subclass): %s", sub->external_name()); - } -#endif - sub = sub->next_sibling(); - } + Klass* sub = current->subklass(true); current->set_subklass(sub); if (sub != NULL) { stack.push(sub); } // Find and set the first alive sibling - Klass* sibling = current->next_sibling(); - while (sibling != NULL && !sibling->is_loader_alive()) { - if (log_is_enabled(Trace, class, unload)) { - ResourceMark rm; - log_trace(class, unload)("[Unlinking class (sibling) %s]", sibling->external_name()); - } - sibling = sibling->next_sibling(); - } + Klass* sibling = current->next_sibling(true); current->set_next_sibling(sibling); if (sibling != NULL) { stack.push(sibling); diff --git a/src/hotspot/share/oops/klass.hpp b/src/hotspot/share/oops/klass.hpp index 35ea1367832..b6c2782d2a9 100644 --- a/src/hotspot/share/oops/klass.hpp +++ b/src/hotspot/share/oops/klass.hpp @@ -284,8 +284,9 @@ protected: // Use InstanceKlass::contains_field_offset to classify field offsets. // sub/superklass links - Klass* subklass() const { return _subklass; } - Klass* next_sibling() const { return _next_sibling; } + Klass* subklass(bool log = false) const; + Klass* next_sibling(bool log = false) const; + InstanceKlass* superklass() const; void append_to_sibling_list(); // add newly created receiver to superklass' subklass list diff --git a/src/hotspot/share/runtime/mutex.cpp b/src/hotspot/share/runtime/mutex.cpp index 308c07c37e9..9243262d218 100644 --- a/src/hotspot/share/runtime/mutex.cpp +++ b/src/hotspot/share/runtime/mutex.cpp @@ -876,7 +876,7 @@ void Monitor::lock(Thread * Self) { #endif // CHECK_UNHANDLED_OOPS debug_only(check_prelock_state(Self, StrictSafepointChecks)); - assert(_owner != Self, "invariant"); + assert(_owner != Self, "this lock %s is already held by this thread", name()); assert(_OnDeck != Self->_MutexEvent, "invariant"); if (TryFast()) { diff --git a/src/hotspot/share/utilities/vmError.cpp b/src/hotspot/share/utilities/vmError.cpp index 061ebef5ea5..6184adbd7f8 100644 --- a/src/hotspot/share/utilities/vmError.cpp +++ b/src/hotspot/share/utilities/vmError.cpp @@ -1467,6 +1467,8 @@ void VMError::report_and_die(int id, const char* message, const char* detail_fmt log.set_fd(-1); } + // Error handling generates replay data without the compile lock. + NOT_PRODUCT(FlagSetting fs(IgnoreLockingAssertions, true)); static bool skip_replay = ReplayCompiles; // Do not overwrite file during replay if (DumpReplayDataOnError && _thread && _thread->is_Compiler_thread() && !skip_replay) { skip_replay = true; diff --git a/test/hotspot/jtreg/runtime/ClassUnload/UnloadInterfaceTest.java b/test/hotspot/jtreg/runtime/ClassUnload/UnloadInterfaceTest.java new file mode 100644 index 00000000000..e1991954079 --- /dev/null +++ b/test/hotspot/jtreg/runtime/ClassUnload/UnloadInterfaceTest.java @@ -0,0 +1,95 @@ +/* + * Copyright (c) 2018, 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 UnloadInterfaceTest + * @requires vm.opt.final.ClassUnloading + * @modules java.base/jdk.internal.misc + * @library /runtime/testlibrary /test/lib + * @compile test/Interface.java + * @compile test/ImplementorClass.java + * @build sun.hotspot.WhiteBox + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * sun.hotspot.WhiteBox$WhiteBoxPermission + * @run main/othervm -Xbootclasspath/a:. -Xmn8m -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xlog:class+unload=trace UnloadInterfaceTest + */ +import sun.hotspot.WhiteBox; +import test.Interface; +import java.lang.ClassLoader; + +/** + * Test that verifies that class unloaded removes the implementor from its the interface that it implements + * via logging. + * [1.364s][info][class,unload] unloading class test.ImplementorClass 0x00000008000a2840 + * [1.366s][trace][class,unload] unlinking class (subclass): test.ImplementorClass + * [1.366s][trace][class,unload] unlinking class (implementor): test.ImplementorClass + */ +public class UnloadInterfaceTest { + private static String className = "test.ImplementorClass"; + private static String interfaceName = "test.Interface"; + + static class LoaderToUnload extends ClassLoader { + ClassLoader myParent; + public Class loadClass(String name) throws ClassNotFoundException { + if (name.contains(className)) { + System.out.println("className found " + className); + byte[] data = ClassUnloadCommon.getClassData(name); + return defineClass(name, data, 0, data.length); + } else { + return myParent.loadClass(name); + } + } + public LoaderToUnload(ClassLoader parent) { + super(); + myParent = parent; + } + } + + public static void main(String... args) throws Exception { + run(); + } + + private static void run() throws Exception { + final WhiteBox wb = WhiteBox.getWhiteBox(); + + ClassUnloadCommon.failIf(wb.isClassAlive(className), "is not expected to be alive yet"); + + // Load interface Class with one class loader. + ClassLoader icl = ClassUnloadCommon.newClassLoader(); + Class ic = icl.loadClass(interfaceName); + + ClassLoader cl = new LoaderToUnload(icl); + Class c = cl.loadClass(className); + Object o = c.newInstance(); + + ClassUnloadCommon.failIf(!wb.isClassAlive(className), "should be live here"); + ClassUnloadCommon.failIf(!wb.isClassAlive(interfaceName), "should be live here"); + + cl = null; c = null; o = null; + ClassUnloadCommon.triggerUnloading(); + ClassUnloadCommon.failIf(wb.isClassAlive(className), "should have been unloaded"); + ClassUnloadCommon.failIf(!wb.isClassAlive(interfaceName), "should be live here"); + System.out.println("We still have Interface referenced" + ic); + } +} + diff --git a/test/hotspot/jtreg/runtime/ClassUnload/test/ImplementorClass.java b/test/hotspot/jtreg/runtime/ClassUnload/test/ImplementorClass.java new file mode 100644 index 00000000000..ae8c17bf4c1 --- /dev/null +++ b/test/hotspot/jtreg/runtime/ClassUnload/test/ImplementorClass.java @@ -0,0 +1,29 @@ +/* + * Copyright (c) 2018, 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 test; + +public class ImplementorClass implements Interface { + public void foo() { System.out.println("foo implemented!"); } +} diff --git a/test/hotspot/jtreg/runtime/ClassUnload/test/Interface.java b/test/hotspot/jtreg/runtime/ClassUnload/test/Interface.java new file mode 100644 index 00000000000..97a0eebdf93 --- /dev/null +++ b/test/hotspot/jtreg/runtime/ClassUnload/test/Interface.java @@ -0,0 +1,29 @@ +/* + * Copyright (c) 2018, 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 test; + +public interface Interface { + public void foo(); +} diff --git a/test/hotspot/jtreg/runtime/testlibrary/ClassUnloadCommon.java b/test/hotspot/jtreg/runtime/testlibrary/ClassUnloadCommon.java index 254411efeeb..d5bf0fe0742 100644 --- a/test/hotspot/jtreg/runtime/testlibrary/ClassUnloadCommon.java +++ b/test/hotspot/jtreg/runtime/testlibrary/ClassUnloadCommon.java @@ -27,7 +27,10 @@ * for an example. */ + import java.io.File; +import java.io.FileInputStream; +import java.io.IOException; import java.net.MalformedURLException; import java.net.URL; import java.net.URLClassLoader; @@ -104,4 +107,22 @@ public class ClassUnloadCommon { throw new RuntimeException(e); } } + + // Get data for pre-compiled class file to load. + public static byte[] getClassData(String name) { + try { + String TempName = name.replaceAll("\\.", "/"); + String currentDir = System.getProperty("test.classes"); + String filename = currentDir + File.separator + TempName + ".class"; + System.out.println("filename is " + filename); + FileInputStream fis = new FileInputStream(filename); + byte[] b = new byte[5000]; + int cnt = fis.read(b, 0, 5000); + byte[] c = new byte[cnt]; + for (int i=0; i Date: Mon, 29 Oct 2018 12:31:49 -0300 Subject: [PATCH 42/84] 8212694: Using Raw String Literals with align() and Integer.MIN_VALUE causes out of memory error Reviewed-by: smarks, sherman --- src/java.base/share/classes/java/lang/String.java | 4 +++- test/jdk/java/lang/String/AlignIndent.java | 13 +++++++++++++ 2 files changed, 16 insertions(+), 1 deletion(-) diff --git a/src/java.base/share/classes/java/lang/String.java b/src/java.base/share/classes/java/lang/String.java index 77b633b67a4..d366e676602 100644 --- a/src/java.base/share/classes/java/lang/String.java +++ b/src/java.base/share/classes/java/lang/String.java @@ -2967,7 +2967,9 @@ public final class String .mapToInt(String::indexOfNonWhitespace) .min() .orElse(0); - return indent(n - outdent, true); + // overflow-conscious code + int indent = n - outdent; + return indent(indent > n ? Integer.MIN_VALUE : indent, true); } /** diff --git a/test/jdk/java/lang/String/AlignIndent.java b/test/jdk/java/lang/String/AlignIndent.java index 5afd145fba1..1438a977555 100644 --- a/test/jdk/java/lang/String/AlignIndent.java +++ b/test/jdk/java/lang/String/AlignIndent.java @@ -53,6 +53,7 @@ public class AlignIndent { test1(); test2(); test3(); + test4(); } /* @@ -154,6 +155,18 @@ public class AlignIndent { } } + /* + * JDK-8212694: Using Raw String Literals with align() and Integer.MIN_VALUE causes out of memory error + */ + static void test4() { + try { + String str = "\n A\n".align(Integer.MIN_VALUE); + } catch (OutOfMemoryError ex) { + System.err.println("align(Integer.MIN_VALUE) not clipping indentation"); + throw new RuntimeException(); + } + } + public static int indexOfNonWhitespace(String s) { int left = 0; while (left < s.length()) { From 37ef084d732fa1b4cc3fc15c515df74229782a38 Mon Sep 17 00:00:00 2001 From: Robert Field Date: Mon, 29 Oct 2018 08:34:33 -0700 Subject: [PATCH 43/84] 8210808: jshell tool: only considers the first snippet of the external editor Reviewed-by: jlahoda, sundar --- .../jdk/internal/jshell/tool/JShellTool.java | 2 +- test/langtools/jdk/jshell/EditorTestBase.java | 18 ++++++++++++++++++ .../jdk/jshell/ExternalEditorTest.java | 2 +- 3 files changed, 20 insertions(+), 2 deletions(-) diff --git a/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/JShellTool.java b/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/JShellTool.java index 2243aa614e3..dd09d6c90b5 100644 --- a/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/JShellTool.java +++ b/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/JShellTool.java @@ -2936,7 +2936,7 @@ public class JShellTool implements MessageHandler { } String tsrc = trimNewlines(an.source()); if (!failed && !currSrcs.contains(tsrc)) { - failed = processSource(tsrc); + failed = !processSource(tsrc); } nextSrcs.add(tsrc); if (an.remaining().isEmpty()) { diff --git a/test/langtools/jdk/jshell/EditorTestBase.java b/test/langtools/jdk/jshell/EditorTestBase.java index 14e20d6339f..422d07ba1c8 100644 --- a/test/langtools/jdk/jshell/EditorTestBase.java +++ b/test/langtools/jdk/jshell/EditorTestBase.java @@ -125,6 +125,24 @@ public abstract class EditorTestBase extends ReplToolTesting { ); } + @Test + public void testWriteVariables() { + testEditor( + a -> assertEditOutput(a, "/edit", + "x ==> 1\n" + + "y ==> 2\n" + + "z ==> 3", + () -> { + writeSource( + "var x = 1;\n" + + "var y = 2;\n" + + "var z = 3;\n"); + exit(); + }), + a -> assertCommand(a, "z", "z ==> 3") + ); + } + public void testEditClass1() { testEditor( a -> assertClass(a, "class A {}", "class", "A"), diff --git a/test/langtools/jdk/jshell/ExternalEditorTest.java b/test/langtools/jdk/jshell/ExternalEditorTest.java index 7cae81ae618..607637e207c 100644 --- a/test/langtools/jdk/jshell/ExternalEditorTest.java +++ b/test/langtools/jdk/jshell/ExternalEditorTest.java @@ -24,7 +24,7 @@ /* * @test * @summary Testing external editor. - * @bug 8143955 8080843 8163816 8143006 8169828 8171130 8162989 + * @bug 8143955 8080843 8163816 8143006 8169828 8171130 8162989 8210808 * @modules jdk.jshell/jdk.internal.jshell.tool * @build ReplToolTesting CustomEditor EditorTestBase * @run testng ExternalEditorTest From 9a06fc3ea75f586473742c4b593fcdac870a4e5c Mon Sep 17 00:00:00 2001 From: Ioi Lam Date: Thu, 25 Oct 2018 11:23:43 -0700 Subject: [PATCH 44/84] 8212205: VM asserts after CDS archive has been unmapped Reviewed-by: dholmes, jiangli, hseigel, stuefe --- src/hotspot/share/memory/allocation.hpp | 8 +++++++- src/hotspot/share/memory/filemap.cpp | 2 ++ src/hotspot/share/memory/metaspaceShared.cpp | 3 +-- src/hotspot/share/memory/metaspaceShared.hpp | 2 +- 4 files changed, 11 insertions(+), 4 deletions(-) diff --git a/src/hotspot/share/memory/allocation.hpp b/src/hotspot/share/memory/allocation.hpp index 18796d8d486..5978ab01a52 100644 --- a/src/hotspot/share/memory/allocation.hpp +++ b/src/hotspot/share/memory/allocation.hpp @@ -244,7 +244,6 @@ class ClassLoaderData; class MetaspaceClosure; class MetaspaceObj { - friend class MetaspaceShared; // When CDS is enabled, all shared metaspace objects are mapped // into a single contiguous memory block, so we can use these // two pointers to quickly determine if something is in the @@ -263,6 +262,13 @@ class MetaspaceObj { } void print_address_on(outputStream* st) const; // nonvirtual address printing + static void set_shared_metaspace_range(void* base, void* top) { + _shared_metaspace_base = base; + _shared_metaspace_top = top; + } + static void* shared_metaspace_base() { return _shared_metaspace_base; } + static void* shared_metaspace_top() { return _shared_metaspace_top; } + #define METASPACE_OBJ_TYPES_DO(f) \ f(Class) \ f(Symbol) \ diff --git a/src/hotspot/share/memory/filemap.cpp b/src/hotspot/share/memory/filemap.cpp index 0381756af19..63778deb8f1 100644 --- a/src/hotspot/share/memory/filemap.cpp +++ b/src/hotspot/share/memory/filemap.cpp @@ -1355,6 +1355,8 @@ bool FileMapInfo::is_in_shared_region(const void* p, int idx) { // Unmap mapped regions of shared space. void FileMapInfo::stop_sharing_and_unmap(const char* msg) { + MetaspaceObj::set_shared_metaspace_range(NULL, NULL); + FileMapInfo *map_info = FileMapInfo::current_info(); if (map_info) { map_info->fail_continue("%s", msg); diff --git a/src/hotspot/share/memory/metaspaceShared.cpp b/src/hotspot/share/memory/metaspaceShared.cpp index 00483505c87..712b5e80004 100644 --- a/src/hotspot/share/memory/metaspaceShared.cpp +++ b/src/hotspot/share/memory/metaspaceShared.cpp @@ -1957,8 +1957,7 @@ bool MetaspaceShared::map_shared_spaces(FileMapInfo* mapinfo) { assert(ro_top == md_base, "must be"); assert(md_top == od_base, "must be"); - MetaspaceObj::_shared_metaspace_base = (void*)mc_base; - MetaspaceObj::_shared_metaspace_top = (void*)od_top; + MetaspaceObj::set_shared_metaspace_range((void*)mc_base, (void*)od_top); return true; } else { // If there was a failure in mapping any of the spaces, unmap the ones diff --git a/src/hotspot/share/memory/metaspaceShared.hpp b/src/hotspot/share/memory/metaspaceShared.hpp index eeb5b455d65..f461833adc3 100644 --- a/src/hotspot/share/memory/metaspaceShared.hpp +++ b/src/hotspot/share/memory/metaspaceShared.hpp @@ -125,7 +125,7 @@ class MetaspaceShared : AllStatic { static bool is_in_shared_metaspace(const void* p) { // If no shared metaspace regions are mapped, MetaspceObj::_shared_metaspace_{base,top} will // both be NULL and all values of p will be rejected quickly. - return (p < MetaspaceObj::_shared_metaspace_top && p >= MetaspaceObj::_shared_metaspace_base); + return (p < MetaspaceObj::shared_metaspace_top() && p >= MetaspaceObj::shared_metaspace_base()); } // Return true if given address is in the shared region corresponding to the idx From efce2c039709f3f1292f4e120fcb7528585c188c Mon Sep 17 00:00:00 2001 From: Calvin Cheung Date: Mon, 29 Oct 2018 13:58:29 -0700 Subject: [PATCH 45/84] 8212154: [TESTBUG] CheckArchivedModuleApp fails with NPE when JVMCI is absent Added a null check on wb.getBooleanVMFlag("EnableJVMCI"). Reviewed-by: hseigel, jiangli --- .../runtime/appcds/cacheObject/CheckArchivedModuleApp.java | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/test/hotspot/jtreg/runtime/appcds/cacheObject/CheckArchivedModuleApp.java b/test/hotspot/jtreg/runtime/appcds/cacheObject/CheckArchivedModuleApp.java index 5568e1cd6bb..d7774187c3f 100644 --- a/test/hotspot/jtreg/runtime/appcds/cacheObject/CheckArchivedModuleApp.java +++ b/test/hotspot/jtreg/runtime/appcds/cacheObject/CheckArchivedModuleApp.java @@ -52,7 +52,8 @@ public class CheckArchivedModuleApp { boolean expectArchivedConfiguration = "yes".equals(args[1]); // -XX:+EnableJVMCI adds extra system modules, in which case the system // module objects are not archived. - if (wb.getBooleanVMFlag("EnableJVMCI")) { + Boolean enableJVMCI = wb.getBooleanVMFlag("EnableJVMCI"); + if (enableJVMCI != null && enableJVMCI) { expectArchivedDescriptors = false; expectArchivedConfiguration = false; } From 810ba0eb12484d18f614e72cd0008af063eda1f6 Mon Sep 17 00:00:00 2001 From: Kirill Zhaldybin Date: Mon, 29 Oct 2018 14:04:42 -0700 Subject: [PATCH 46/84] 8157728: Convert GCTimer_test to GTest Reviewed-by: tschatzl, jcbeyler, iignatyev --- src/hotspot/share/gc/shared/gcTimer.cpp | 211 ---------------- src/hotspot/share/gc/shared/gcTimer.hpp | 1 - .../share/utilities/internalVMTests.cpp | 1 - src/hotspot/share/utilities/ticks.hpp | 2 +- test/hotspot/gtest/gc/shared/test_gcTimer.cpp | 238 ++++++++++++++++++ 5 files changed, 239 insertions(+), 214 deletions(-) create mode 100644 test/hotspot/gtest/gc/shared/test_gcTimer.cpp diff --git a/src/hotspot/share/gc/shared/gcTimer.cpp b/src/hotspot/share/gc/shared/gcTimer.cpp index 229812a0a63..871a3e48bbc 100644 --- a/src/hotspot/share/gc/shared/gcTimer.cpp +++ b/src/hotspot/share/gc/shared/gcTimer.cpp @@ -182,214 +182,3 @@ GCPhase* TimePartitionPhasesIterator::next() { assert(has_next(), "Must have phases left"); return _time_partitions->phase_at(_next++); } - - -/////////////// Unit tests /////////////// - -#ifndef PRODUCT - -class TimePartitionPhasesIteratorTest { - public: - static void all() { - one_pause(); - two_pauses(); - one_sub_pause_phase(); - many_sub_pause_phases(); - many_sub_pause_phases2(); - max_nested_pause_phases(); - one_concurrent(); - } - - static void validate_gc_phase(GCPhase* phase, int level, const char* name, const Ticks& start, const Ticks& end) { - assert(phase->level() == level, "Incorrect level"); - assert(strcmp(phase->name(), name) == 0, "Incorrect name"); - assert(phase->start() == start, "Incorrect start"); - assert(phase->end() == end, "Incorrect end"); - } - - static void one_pause() { - TimePartitions time_partitions; - time_partitions.report_gc_phase_start("PausePhase", 2); - time_partitions.report_gc_phase_end(8); - - TimePartitionPhasesIterator iter(&time_partitions); - - validate_gc_phase(iter.next(), 0, "PausePhase", 2, 8); - assert(time_partitions.sum_of_pauses() == Ticks(8) - Ticks(2), "Incorrect"); - assert(time_partitions.longest_pause() == Ticks(8) - Ticks(2), "Incorrect"); - - assert(!iter.has_next(), "Too many elements"); - } - - static void two_pauses() { - TimePartitions time_partitions; - time_partitions.report_gc_phase_start("PausePhase1", 2); - time_partitions.report_gc_phase_end(3); - time_partitions.report_gc_phase_start("PausePhase2", 4); - time_partitions.report_gc_phase_end(6); - - TimePartitionPhasesIterator iter(&time_partitions); - - validate_gc_phase(iter.next(), 0, "PausePhase1", 2, 3); - validate_gc_phase(iter.next(), 0, "PausePhase2", 4, 6); - - assert(time_partitions.sum_of_pauses() == Ticks(3) - Ticks(0), "Incorrect"); - assert(time_partitions.longest_pause() == Ticks(2) - Ticks(0), "Incorrect"); - - assert(!iter.has_next(), "Too many elements"); - } - - static void one_sub_pause_phase() { - TimePartitions time_partitions; - time_partitions.report_gc_phase_start("PausePhase", 2); - time_partitions.report_gc_phase_start("SubPhase", 3); - time_partitions.report_gc_phase_end(4); - time_partitions.report_gc_phase_end(5); - - TimePartitionPhasesIterator iter(&time_partitions); - - validate_gc_phase(iter.next(), 0, "PausePhase", 2, 5); - validate_gc_phase(iter.next(), 1, "SubPhase", 3, 4); - - assert(time_partitions.sum_of_pauses() == Ticks(3) - Ticks(0), "Incorrect"); - assert(time_partitions.longest_pause() == Ticks(3) - Ticks(0), "Incorrect"); - - assert(!iter.has_next(), "Too many elements"); - } - - static void max_nested_pause_phases() { - TimePartitions time_partitions; - time_partitions.report_gc_phase_start("PausePhase", 2); - time_partitions.report_gc_phase_start("SubPhase1", 3); - time_partitions.report_gc_phase_start("SubPhase2", 4); - time_partitions.report_gc_phase_start("SubPhase3", 5); - time_partitions.report_gc_phase_end(6); - time_partitions.report_gc_phase_end(7); - time_partitions.report_gc_phase_end(8); - time_partitions.report_gc_phase_end(9); - - TimePartitionPhasesIterator iter(&time_partitions); - - validate_gc_phase(iter.next(), 0, "PausePhase", 2, 9); - validate_gc_phase(iter.next(), 1, "SubPhase1", 3, 8); - validate_gc_phase(iter.next(), 2, "SubPhase2", 4, 7); - validate_gc_phase(iter.next(), 3, "SubPhase3", 5, 6); - - assert(time_partitions.sum_of_pauses() == Ticks(7) - Ticks(0), "Incorrect"); - assert(time_partitions.longest_pause() == Ticks(7) - Ticks(0), "Incorrect"); - - assert(!iter.has_next(), "Too many elements"); - } - - static void many_sub_pause_phases() { - TimePartitions time_partitions; - time_partitions.report_gc_phase_start("PausePhase", 2); - - time_partitions.report_gc_phase_start("SubPhase1", 3); - time_partitions.report_gc_phase_end(4); - time_partitions.report_gc_phase_start("SubPhase2", 5); - time_partitions.report_gc_phase_end(6); - time_partitions.report_gc_phase_start("SubPhase3", 7); - time_partitions.report_gc_phase_end(8); - time_partitions.report_gc_phase_start("SubPhase4", 9); - time_partitions.report_gc_phase_end(10); - - time_partitions.report_gc_phase_end(11); - - TimePartitionPhasesIterator iter(&time_partitions); - - validate_gc_phase(iter.next(), 0, "PausePhase", 2, 11); - validate_gc_phase(iter.next(), 1, "SubPhase1", 3, 4); - validate_gc_phase(iter.next(), 1, "SubPhase2", 5, 6); - validate_gc_phase(iter.next(), 1, "SubPhase3", 7, 8); - validate_gc_phase(iter.next(), 1, "SubPhase4", 9, 10); - - assert(time_partitions.sum_of_pauses() == Ticks(9) - Ticks(0), "Incorrect"); - assert(time_partitions.longest_pause() == Ticks(9) - Ticks(0), "Incorrect"); - - assert(!iter.has_next(), "Too many elements"); - } - - static void many_sub_pause_phases2() { - TimePartitions time_partitions; - time_partitions.report_gc_phase_start("PausePhase", 2); - - time_partitions.report_gc_phase_start("SubPhase1", 3); - time_partitions.report_gc_phase_start("SubPhase11", 4); - time_partitions.report_gc_phase_end(5); - time_partitions.report_gc_phase_start("SubPhase12", 6); - time_partitions.report_gc_phase_end(7); - time_partitions.report_gc_phase_end(8); - time_partitions.report_gc_phase_start("SubPhase2", 9); - time_partitions.report_gc_phase_start("SubPhase21", 10); - time_partitions.report_gc_phase_end(11); - time_partitions.report_gc_phase_start("SubPhase22", 12); - time_partitions.report_gc_phase_end(13); - time_partitions.report_gc_phase_end(14); - time_partitions.report_gc_phase_start("SubPhase3", 15); - time_partitions.report_gc_phase_end(16); - - time_partitions.report_gc_phase_end(17); - - TimePartitionPhasesIterator iter(&time_partitions); - - validate_gc_phase(iter.next(), 0, "PausePhase", 2, 17); - validate_gc_phase(iter.next(), 1, "SubPhase1", 3, 8); - validate_gc_phase(iter.next(), 2, "SubPhase11", 4, 5); - validate_gc_phase(iter.next(), 2, "SubPhase12", 6, 7); - validate_gc_phase(iter.next(), 1, "SubPhase2", 9, 14); - validate_gc_phase(iter.next(), 2, "SubPhase21", 10, 11); - validate_gc_phase(iter.next(), 2, "SubPhase22", 12, 13); - validate_gc_phase(iter.next(), 1, "SubPhase3", 15, 16); - - assert(time_partitions.sum_of_pauses() == Ticks(15) - Ticks(0), "Incorrect"); - assert(time_partitions.longest_pause() == Ticks(15) - Ticks(0), "Incorrect"); - - assert(!iter.has_next(), "Too many elements"); - } - - static void one_concurrent() { - TimePartitions time_partitions; - time_partitions.report_gc_phase_start("ConcurrentPhase", 2, GCPhase::ConcurrentPhaseType); - time_partitions.report_gc_phase_end(8, GCPhase::ConcurrentPhaseType); - - TimePartitionPhasesIterator iter(&time_partitions); - - validate_gc_phase(iter.next(), 0, "ConcurrentPhase", 2, 8); - // ConcurrentPhaseType should not affect to both 'sum_of_pauses()' and 'longest_pause()'. - assert(time_partitions.sum_of_pauses() == Tickspan(), "Incorrect"); - assert(time_partitions.longest_pause() == Tickspan(), "Incorrect"); - - assert(!iter.has_next(), "Too many elements"); - } -}; - -class GCTimerTest { -public: - static void all() { - gc_start(); - gc_end(); - } - - static void gc_start() { - GCTimer gc_timer; - gc_timer.register_gc_start(1); - - assert(gc_timer.gc_start() == Ticks(1), "Incorrect"); - } - - static void gc_end() { - GCTimer gc_timer; - gc_timer.register_gc_start(1); - gc_timer.register_gc_end(2); - - assert(gc_timer.gc_end() == Ticks(2), "Incorrect"); - } -}; - -void GCTimer_test() { - GCTimerTest::all(); - TimePartitionPhasesIteratorTest::all(); -} - -#endif diff --git a/src/hotspot/share/gc/shared/gcTimer.hpp b/src/hotspot/share/gc/shared/gcTimer.hpp index d8834cfee63..30507edfe34 100644 --- a/src/hotspot/share/gc/shared/gcTimer.hpp +++ b/src/hotspot/share/gc/shared/gcTimer.hpp @@ -129,7 +129,6 @@ class PhasesIterator { }; class GCTimer : public ResourceObj { - NOT_PRODUCT(friend class GCTimerTest;) protected: Ticks _gc_start; Ticks _gc_end; diff --git a/src/hotspot/share/utilities/internalVMTests.cpp b/src/hotspot/share/utilities/internalVMTests.cpp index b324ed1aacd..b10f3a24f4b 100644 --- a/src/hotspot/share/utilities/internalVMTests.cpp +++ b/src/hotspot/share/utilities/internalVMTests.cpp @@ -44,7 +44,6 @@ void InternalVMTests::run() { tty->print_cr("Running internal VM tests"); run_unit_test(TestReserveMemorySpecial_test); run_unit_test(TestMetaspaceUtils_test); - run_unit_test(GCTimer_test); tty->print_cr("All internal VM tests passed"); } diff --git a/src/hotspot/share/utilities/ticks.hpp b/src/hotspot/share/utilities/ticks.hpp index 81deb7094f5..6e03d6887a8 100644 --- a/src/hotspot/share/utilities/ticks.hpp +++ b/src/hotspot/share/utilities/ticks.hpp @@ -233,7 +233,7 @@ class TimeInstant : public Rep { TimeInstant(jlong ticks) : Rep(ticks) {} friend class GranularTimer; friend class ObjectSample; - // GC VM tests + // GC unit tests friend class TimePartitionPhasesIteratorTest; friend class GCTimerTest; }; diff --git a/test/hotspot/gtest/gc/shared/test_gcTimer.cpp b/test/hotspot/gtest/gc/shared/test_gcTimer.cpp new file mode 100644 index 00000000000..c3282ffd1a1 --- /dev/null +++ b/test/hotspot/gtest/gc/shared/test_gcTimer.cpp @@ -0,0 +1,238 @@ +/* + * Copyright (c) 2001, 2018, 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 "gc/shared/gcTimer.hpp" +#include "utilities/ticks.hpp" +#include "unittest.hpp" + +class GCTimerTest { + public: + static void register_gc_start(GCTimer* const timer, jlong ticks) { + timer->register_gc_start(Ticks(ticks)); + } + static void register_gc_end(GCTimer* const timer, jlong ticks) { + timer->register_gc_end(Ticks(ticks)); + } +}; + +TEST(GCTimer, start) { + GCTimer gc_timer; + GCTimerTest::register_gc_start(&gc_timer, 1); + + EXPECT_EQ(1, gc_timer.gc_start().value()); +} + +TEST(GCTimer, end) { + GCTimer gc_timer; + + GCTimerTest::register_gc_start(&gc_timer, 1); + GCTimerTest::register_gc_end(&gc_timer, 2); + + EXPECT_EQ(2, gc_timer.gc_end().value()); +} + +class TimePartitionPhasesIteratorTest { + public: + + static void validate_gc_phase(GCPhase* phase, int level, const char* name, const jlong& start, const jlong& end) { + EXPECT_EQ(level, phase->level()); + EXPECT_STREQ(name, phase->name()); + EXPECT_EQ(start, phase->start().value()); + EXPECT_EQ(end, phase->end().value()); + } + + static void validate_pauses(const TimePartitions& time_partitions, const Tickspan& expected_sum_of_pauses, const Tickspan& expected_longest_pause) { + EXPECT_EQ(expected_sum_of_pauses, time_partitions.sum_of_pauses()); + EXPECT_EQ(expected_longest_pause, time_partitions.longest_pause()); + } + static void validate_pauses(const TimePartitions& time_partitions, const Tickspan& expected_pause) { + TimePartitionPhasesIteratorTest::validate_pauses(time_partitions, expected_pause, expected_pause); + } + static void validate_pauses(const TimePartitions& time_partitions, jlong end, jlong start) { + TimePartitionPhasesIteratorTest::validate_pauses(time_partitions, Ticks(end) - Ticks(start)); + } + static void validate_pauses(const TimePartitions& time_partitions, jlong all_end, jlong all_start, jlong longest_end, jlong longest_start) { + TimePartitionPhasesIteratorTest::validate_pauses(time_partitions, Ticks(all_end) - Ticks(all_start), Ticks(longest_end) - Ticks(longest_start)); + } + + static void report_gc_phase_start(TimePartitions* const partitions, const char* name, jlong ticks, GCPhase::PhaseType type=GCPhase::PausePhaseType) { + partitions->report_gc_phase_start(name, Ticks(ticks), type); + } + + static void report_gc_phase_end(TimePartitions* const partitions, jlong ticks, GCPhase::PhaseType type=GCPhase::PausePhaseType) { + partitions->report_gc_phase_end(Ticks(ticks), type); + } +}; + +TEST(TimePartitionPhasesIterator, one_pause) { + TimePartitions time_partitions; + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "PausePhase", 2); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 8); + + TimePartitionPhasesIterator iter(&time_partitions); + + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 0, "PausePhase", 2, 8)); + + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_pauses(time_partitions, 8, 2)); + + EXPECT_FALSE(iter.has_next()) << "Too many elements"; +} + +TEST(TimePartitionPhasesIterator, two_pauses) { + TimePartitions time_partitions; + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "PausePhase1", 2); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 3); + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "PausePhase2", 4); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 6); + + TimePartitionPhasesIterator iter(&time_partitions); + + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 0, "PausePhase1", 2, 3)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 0, "PausePhase2", 4, 6)); + + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_pauses(time_partitions, 3, 0, 2, 0)); + + EXPECT_FALSE(iter.has_next()) << "Too many elements"; +} + +TEST(TimePartitionPhasesIterator, one_sub_pause_phase) { + TimePartitions time_partitions; + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "PausePhase", 2); + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase", 3); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 4); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 5); + + TimePartitionPhasesIterator iter(&time_partitions); + + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 0, "PausePhase", 2, 5)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 1, "SubPhase", 3, 4)); + + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_pauses(time_partitions, 3, 0)); + + EXPECT_FALSE(iter.has_next()) << "Too many elements"; +} + +TEST(TimePartitionPhasesIterator, max_nested_pause_phases) { + TimePartitions time_partitions; + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "PausePhase", 2); + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase1", 3); + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase2", 4); + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase3", 5); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 6); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 7); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 8); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 9); + + TimePartitionPhasesIterator iter(&time_partitions); + + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 0, "PausePhase", 2, 9)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 1, "SubPhase1", 3, 8)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 2, "SubPhase2", 4, 7)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 3, "SubPhase3", 5, 6)); + + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_pauses(time_partitions, 7, 0)); + + EXPECT_FALSE(iter.has_next()) << "Too many elements"; +} + +TEST(TimePartitionPhasesIterator, many_sub_pause_phases) { + TimePartitions time_partitions; + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "PausePhase", 2); + + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase1", 3); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 4); + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase2", 5); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 6); + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase3", 7); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 8); + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase4", 9); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 10); + + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 11); + + TimePartitionPhasesIterator iter(&time_partitions); + + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 0, "PausePhase", 2, 11)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 1, "SubPhase1", 3, 4)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 1, "SubPhase2", 5, 6)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 1, "SubPhase3", 7, 8)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 1, "SubPhase4", 9, 10)); + + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_pauses(time_partitions, 9, 0)); + + EXPECT_FALSE(iter.has_next()) << "Too many elements"; +} + +TEST(TimePartitionPhasesIterator, many_sub_pause_phases2) { + TimePartitions time_partitions; + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "PausePhase", 2); + + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase1", 3); + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase11", 4); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 5); + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase12", 6); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 7); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 8); + + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase2", 9); + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase21", 10); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 11); + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase22", 12); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 13); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 14); + + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "SubPhase3", 15); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 16); + + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 17); + + TimePartitionPhasesIterator iter(&time_partitions); + + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 0, "PausePhase", 2, 17)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 1, "SubPhase1", 3, 8)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 2, "SubPhase11", 4, 5)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 2, "SubPhase12", 6, 7)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 1, "SubPhase2", 9, 14)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 2, "SubPhase21", 10, 11)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 2, "SubPhase22", 12, 13)); + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 1, "SubPhase3", 15, 16)); + + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_pauses(time_partitions, 15, 0)); + + EXPECT_FALSE(iter.has_next()) << "Too many elements"; +} + +TEST(TimePartitionPhasesIterator, one_concurrent) { + TimePartitions time_partitions; + TimePartitionPhasesIteratorTest::report_gc_phase_start(&time_partitions, "ConcurrentPhase", 2, GCPhase::ConcurrentPhaseType); + TimePartitionPhasesIteratorTest::report_gc_phase_end(&time_partitions, 8, GCPhase::ConcurrentPhaseType); + + TimePartitionPhasesIterator iter(&time_partitions); + + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_gc_phase(iter.next(), 0, "ConcurrentPhase", 2, 8)); + // ConcurrentPhaseType should not affect to both 'sum_of_pauses()' and 'longest_pause()'. + EXPECT_NO_FATAL_FAILURE(TimePartitionPhasesIteratorTest::validate_pauses(time_partitions, Tickspan())); + + EXPECT_FALSE(iter.has_next()) << "Too many elements"; +} From 93c891c51bec37d06fe91d9e968b2eb1ac946929 Mon Sep 17 00:00:00 2001 From: Igor Ignatyev Date: Mon, 29 Oct 2018 14:04:44 -0700 Subject: [PATCH 47/84] 8177710: Convert TestMetaspaceUtils_test to GTest Reviewed-by: tschatzl --- .../share/utilities/internalVMTests.cpp | 1 - test/hotspot/gtest/memory/test_metaspace.cpp | 84 +++++++++++++++++++ 2 files changed, 84 insertions(+), 1 deletion(-) create mode 100644 test/hotspot/gtest/memory/test_metaspace.cpp diff --git a/src/hotspot/share/utilities/internalVMTests.cpp b/src/hotspot/share/utilities/internalVMTests.cpp index b10f3a24f4b..854e94ada55 100644 --- a/src/hotspot/share/utilities/internalVMTests.cpp +++ b/src/hotspot/share/utilities/internalVMTests.cpp @@ -43,7 +43,6 @@ void InternalVMTests::run_test(const char* name, void (*test)()) { void InternalVMTests::run() { tty->print_cr("Running internal VM tests"); run_unit_test(TestReserveMemorySpecial_test); - run_unit_test(TestMetaspaceUtils_test); tty->print_cr("All internal VM tests passed"); } diff --git a/test/hotspot/gtest/memory/test_metaspace.cpp b/test/hotspot/gtest/memory/test_metaspace.cpp new file mode 100644 index 00000000000..c0adcc1e420 --- /dev/null +++ b/test/hotspot/gtest/memory/test_metaspace.cpp @@ -0,0 +1,84 @@ +/* + * Copyright (c) 2018, 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 "memory/metaspace.hpp" +#include "memory/metaspace/virtualSpaceList.hpp" +#include "unittest.hpp" + +using namespace metaspace; + +TEST_VM(MetaspaceUtils, reserved) { + size_t reserved = MetaspaceUtils::reserved_bytes(); + EXPECT_GT(reserved, 0UL); + + size_t reserved_metadata = MetaspaceUtils::reserved_bytes(Metaspace::NonClassType); + EXPECT_GT(reserved_metadata, 0UL); + EXPECT_LE(reserved_metadata, reserved); +} + +TEST_VM(MetaspaceUtils, reserved_compressed_class_pointers) { + if (!UseCompressedClassPointers) { + return; + } + size_t reserved = MetaspaceUtils::reserved_bytes(); + EXPECT_GT(reserved, 0UL); + + size_t reserved_class = MetaspaceUtils::reserved_bytes(Metaspace::ClassType); + EXPECT_GT(reserved_class, 0UL); + EXPECT_LE(reserved_class, reserved); +} + +TEST_VM(MetaspaceUtils, committed) { + size_t committed = MetaspaceUtils::committed_bytes(); + EXPECT_GT(committed, 0UL); + + size_t reserved = MetaspaceUtils::reserved_bytes(); + EXPECT_LE(committed, reserved); + + size_t committed_metadata = MetaspaceUtils::committed_bytes(Metaspace::NonClassType); + EXPECT_GT(committed_metadata, 0UL); + EXPECT_LE(committed_metadata, committed); +} + +TEST_VM(MetaspaceUtils, committed_compressed_class_pointers) { + if (!UseCompressedClassPointers) { + return; + } + size_t committed = MetaspaceUtils::committed_bytes(); + EXPECT_GT(committed, 0UL); + + size_t committed_class = MetaspaceUtils::committed_bytes(Metaspace::ClassType); + EXPECT_GT(committed_class, 0UL); + EXPECT_LE(committed_class, committed); +} + +TEST_VM(MetaspaceUtils, virtual_space_list_large_chunk) { + VirtualSpaceList* vs_list = new VirtualSpaceList(os::vm_allocation_granularity()); + MutexLockerEx cl(MetaspaceExpand_lock, Mutex::_no_safepoint_check_flag); + // A size larger than VirtualSpaceSize (256k) and add one page to make it _not_ be + // vm_allocation_granularity aligned on Windows. + size_t large_size = (size_t)(2*256*K + (os::vm_page_size() / BytesPerWord)); + large_size += (os::vm_page_size() / BytesPerWord); + vs_list->get_new_chunk(large_size, 0); +} From d0696b538a45126a550945ce9c118c1ce94d7047 Mon Sep 17 00:00:00 2001 From: Vicente Romero Date: Mon, 29 Oct 2018 17:09:44 -0400 Subject: [PATCH 48/84] 8213100: fix test OptionSmokeTest before removing it from the problem list Reviewed-by: jlahoda --- .../javac/options/smokeTests/OptionSmokeTest.java | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/test/langtools/tools/javac/options/smokeTests/OptionSmokeTest.java b/test/langtools/tools/javac/options/smokeTests/OptionSmokeTest.java index 3b480200274..faf3bb01eb8 100644 --- a/test/langtools/tools/javac/options/smokeTests/OptionSmokeTest.java +++ b/test/langtools/tools/javac/options/smokeTests/OptionSmokeTest.java @@ -32,9 +32,11 @@ * jdk.compiler/com.sun.tools.javac.util * jdk.jdeps/com.sun.tools.javap * @build toolbox.ToolBox toolbox.JavacTask toolbox.TestRunner - * @run main OptionSmokeTest + * @run main/othervm OptionSmokeTest */ +import java.util.Locale; + import java.nio.file.Path; import java.nio.file.Paths; @@ -51,6 +53,7 @@ public class OptionSmokeTest extends TestRunner { public OptionSmokeTest() { super(System.err); + Locale.setDefault(Locale.US); } protected void runTests() throws Exception { @@ -117,7 +120,7 @@ public class OptionSmokeTest extends TestRunner { @Test public void requiresArg(Path base) throws Exception { - doTestNoSource(base, "error: -target requires an argument", "-target"); + doTestNoSource(base, "error: --target requires an argument", "-target"); } @Test @@ -209,7 +212,7 @@ public class OptionSmokeTest extends TestRunner { @Test public void optionCantBeUsedWithRelease(Path base) throws Exception { - doTestNoSource(base, "error: option -source cannot be used together with --release", + doTestNoSource(base, "error: option --source cannot be used together with --release", String.format("--release %s -source %s", Source.DEFAULT.name, Source.DEFAULT.name)); } @@ -232,9 +235,9 @@ public class OptionSmokeTest extends TestRunner { String.format("--release %s -endorseddirs any", Source.DEFAULT.name)); doTestNoSource(base, "error: option -extdirs cannot be used together with --release", String.format("--release %s -extdirs any", Source.DEFAULT.name)); - doTestNoSource(base, "error: option -source cannot be used together with --release", + doTestNoSource(base, "error: option --source cannot be used together with --release", String.format("--release %s -source %s", Source.MIN.name, Source.DEFAULT.name)); - doTestNoSource(base, "error: option -target cannot be used together with --release", + doTestNoSource(base, "error: option --target cannot be used together with --release", String.format("--release %s -target %s", Source.MIN.name, Source.DEFAULT.name)); doTestNoSource(base, "error: option --system cannot be used together with --release", String.format("--release %s --system none", Source.DEFAULT.name)); From d9d067369b885a25999067e1fb83452fc8b9ad57 Mon Sep 17 00:00:00 2001 From: Vicente Romero Date: Mon, 29 Oct 2018 17:11:46 -0400 Subject: [PATCH 49/84] 8212624: remove outdated entries from langtools problem list Reviewed-by: darcy --- test/langtools/ProblemList.txt | 5 ----- 1 file changed, 5 deletions(-) diff --git a/test/langtools/ProblemList.txt b/test/langtools/ProblemList.txt index 72c7572b34f..d8e9fad98ce 100644 --- a/test/langtools/ProblemList.txt +++ b/test/langtools/ProblemList.txt @@ -56,11 +56,6 @@ tools/javac/warnings/suppress/TypeAnnotations.java tools/javac/modules/SourceInSymlinkTest.java 8180263 windows-all fails when run on a subst drive tools/javac/importscope/T8193717.java 8203925 generic-all the test requires too much memory - -tools/javac/options/smokeTests/OptionSmokeTest.java 8205493 generic-all hard-coded release values in strings - -tools/javac/file/zip/8003512/LoadClassFromJava6CreatedJarTest.java 8206874 generic-all test requires a JDK 6 environment to be useful - ########################################################################### # # javap From 4b27547977e99639f694d65c2f29a5b2944e25ac Mon Sep 17 00:00:00 2001 From: Tobias Hartmann Date: Tue, 30 Oct 2018 09:06:08 +0100 Subject: [PATCH 50/84] 8177899: Tests fail due to code cache exhaustion on machines with many cores Implemented upper limit on CICompilerCount based on code cache size. Reviewed-by: kvn, mdoerr --- src/hotspot/share/c1/c1_Compiler.cpp | 6 +----- src/hotspot/share/code/codeCache.cpp | 4 ++-- src/hotspot/share/opto/c2compiler.cpp | 8 +++++--- src/hotspot/share/opto/c2compiler.hpp | 3 ++- src/hotspot/share/opto/compile.cpp | 4 +--- .../share/runtime/compilationPolicy.cpp | 20 +++++++++++++++++++ .../share/runtime/tieredThresholdPolicy.cpp | 15 +++++++++++++- 7 files changed, 45 insertions(+), 15 deletions(-) diff --git a/src/hotspot/share/c1/c1_Compiler.cpp b/src/hotspot/share/c1/c1_Compiler.cpp index c3b1547900f..76836e75858 100644 --- a/src/hotspot/share/c1/c1_Compiler.cpp +++ b/src/hotspot/share/c1/c1_Compiler.cpp @@ -79,7 +79,6 @@ void Compiler::initialize() { } int Compiler::code_buffer_size() { - assert(SegmentedCodeCache, "Should be only used with a segmented code cache"); return Compilation::desired_max_code_buffer_size() + Compilation::desired_max_constant_size(); } @@ -90,10 +89,7 @@ BufferBlob* Compiler::init_buffer_blob() { // setup CodeBuffer. Preallocate a BufferBlob of size // NMethodSizeLimit plus some extra space for constants. - int code_buffer_size = Compilation::desired_max_code_buffer_size() + - Compilation::desired_max_constant_size(); - - BufferBlob* buffer_blob = BufferBlob::create("C1 temporary CodeBuffer", code_buffer_size); + BufferBlob* buffer_blob = BufferBlob::create("C1 temporary CodeBuffer", code_buffer_size()); if (buffer_blob != NULL) { CompilerThread::current()->set_buffer_blob(buffer_blob); } diff --git a/src/hotspot/share/code/codeCache.cpp b/src/hotspot/share/code/codeCache.cpp index d4c2b1e1ac9..c853d2e5b47 100644 --- a/src/hotspot/share/code/codeCache.cpp +++ b/src/hotspot/share/code/codeCache.cpp @@ -274,10 +274,10 @@ void CodeCache::initialize_heaps() { } // Make sure we have enough space for VM internal code uint min_code_cache_size = CodeCacheMinimumUseSpace DEBUG_ONLY(* 3); - if (non_nmethod_size < (min_code_cache_size + code_buffers_size)) { + if (non_nmethod_size < min_code_cache_size) { vm_exit_during_initialization(err_msg( "Not enough space in non-nmethod code heap to run VM: " SIZE_FORMAT "K < " SIZE_FORMAT "K", - non_nmethod_size/K, (min_code_cache_size + code_buffers_size)/K)); + non_nmethod_size/K, min_code_cache_size/K)); } // Verify sizes and update flag values diff --git a/src/hotspot/share/opto/c2compiler.cpp b/src/hotspot/share/opto/c2compiler.cpp index ab6c54d832f..7f4243d993f 100644 --- a/src/hotspot/share/opto/c2compiler.cpp +++ b/src/hotspot/share/opto/c2compiler.cpp @@ -604,7 +604,9 @@ bool C2Compiler::is_intrinsic_supported(const methodHandle& method, bool is_virt return true; } -int C2Compiler::initial_code_buffer_size() { - assert(SegmentedCodeCache, "Should be only used with a segmented code cache"); - return Compile::MAX_inst_size + Compile::MAX_locs_size + initial_const_capacity; +int C2Compiler::initial_code_buffer_size(int const_size) { + // See Compile::init_scratch_buffer_blob + int locs_size = sizeof(relocInfo) * Compile::MAX_locs_size; + int slop = 2 * CodeSection::end_slop(); // space between sections + return Compile::MAX_inst_size + Compile::MAX_stubs_size + const_size + slop + locs_size; } diff --git a/src/hotspot/share/opto/c2compiler.hpp b/src/hotspot/share/opto/c2compiler.hpp index d7eb0225841..33193bde3e5 100644 --- a/src/hotspot/share/opto/c2compiler.hpp +++ b/src/hotspot/share/opto/c2compiler.hpp @@ -26,6 +26,7 @@ #define SHARE_VM_OPTO_C2COMPILER_HPP #include "compiler/abstractCompiler.hpp" +#include "opto/output.hpp" class C2Compiler : public AbstractCompiler { private: @@ -66,7 +67,7 @@ public: virtual bool is_intrinsic_supported(const methodHandle& method, bool is_virtual); // Initial size of the code buffer (may be increased at runtime) - static int initial_code_buffer_size(); + static int initial_code_buffer_size(int const_size = initial_const_capacity); }; #endif // SHARE_VM_OPTO_C2COMPILER_HPP diff --git a/src/hotspot/share/opto/compile.cpp b/src/hotspot/share/opto/compile.cpp index 30c56b1f4a5..759f193a3be 100644 --- a/src/hotspot/share/opto/compile.cpp +++ b/src/hotspot/share/opto/compile.cpp @@ -544,9 +544,7 @@ void Compile::init_scratch_buffer_blob(int const_size) { ResourceMark rm; _scratch_const_size = const_size; - int locs_size = sizeof(relocInfo) * MAX_locs_size; - int slop = 2 * CodeSection::end_slop(); // space between sections - int size = (MAX_inst_size + MAX_stubs_size + _scratch_const_size + slop + locs_size); + int size = C2Compiler::initial_code_buffer_size(const_size); blob = BufferBlob::create("Compile::scratch_buffer", size); // Record the buffer blob for next time. set_scratch_buffer_blob(blob); diff --git a/src/hotspot/share/runtime/compilationPolicy.cpp b/src/hotspot/share/runtime/compilationPolicy.cpp index f235d4f093d..3fc9689c524 100644 --- a/src/hotspot/share/runtime/compilationPolicy.cpp +++ b/src/hotspot/share/runtime/compilationPolicy.cpp @@ -46,6 +46,13 @@ #include "utilities/events.hpp" #include "utilities/globalDefinitions.hpp" +#ifdef COMPILER1 +#include "c1/c1_Compiler.hpp" +#endif +#ifdef COMPILER2 +#include "opto/c2compiler.hpp" +#endif + CompilationPolicy* CompilationPolicy::_policy; elapsedTimer CompilationPolicy::_accumulated_time; bool CompilationPolicy::_in_vm_startup; @@ -222,6 +229,19 @@ void NonTieredCompPolicy::initialize() { // max(log2(8)-1,1) = 2 compiler threads on an 8-way machine. // May help big-app startup time. _compiler_count = MAX2(log2_intptr(os::active_processor_count())-1,1); + // Make sure there is enough space in the code cache to hold all the compiler buffers + size_t buffer_size = 1; +#ifdef COMPILER1 + buffer_size = is_client_compilation_mode_vm() ? Compiler::code_buffer_size() : buffer_size; +#endif +#ifdef COMPILER2 + buffer_size = is_server_compilation_mode_vm() ? C2Compiler::initial_code_buffer_size() : buffer_size; +#endif + int max_count = (ReservedCodeCacheSize - (CodeCacheMinimumUseSpace DEBUG_ONLY(* 3))) / (int)buffer_size; + if (_compiler_count > max_count) { + // Lower the compiler count such that all buffers fit into the code cache + _compiler_count = MAX2(max_count, 1); + } FLAG_SET_ERGO(intx, CICompilerCount, _compiler_count); } else { _compiler_count = CICompilerCount; diff --git a/src/hotspot/share/runtime/tieredThresholdPolicy.cpp b/src/hotspot/share/runtime/tieredThresholdPolicy.cpp index 0e6a2acbe31..4d8b351730b 100644 --- a/src/hotspot/share/runtime/tieredThresholdPolicy.cpp +++ b/src/hotspot/share/runtime/tieredThresholdPolicy.cpp @@ -38,6 +38,9 @@ #ifdef TIERED +#include "c1/c1_Compiler.hpp" +#include "opto/c2compiler.hpp" + template bool TieredThresholdPolicy::call_predicate_helper(int i, int b, double scale, Method* method) { double threshold_scaling; @@ -215,6 +218,7 @@ void TieredThresholdPolicy::print_event(EventType type, const methodHandle& mh, void TieredThresholdPolicy::initialize() { int count = CICompilerCount; + bool c1_only = TieredStopAtLevel < CompLevel_full_optimization; #ifdef _LP64 // Turn on ergonomic compiler count selection if (FLAG_IS_DEFAULT(CICompilerCountPerCPU) && FLAG_IS_DEFAULT(CICompilerCount)) { @@ -225,6 +229,15 @@ void TieredThresholdPolicy::initialize() { int log_cpu = log2_intptr(os::active_processor_count()); int loglog_cpu = log2_intptr(MAX2(log_cpu, 1)); count = MAX2(log_cpu * loglog_cpu * 3 / 2, 2); + // Make sure there is enough space in the code cache to hold all the compiler buffers + size_t c1_size = Compiler::code_buffer_size(); + size_t c2_size = C2Compiler::initial_code_buffer_size(); + size_t buffer_size = c1_only ? c1_size : (c1_size/3 + 2*c2_size/3); + int max_count = (ReservedCodeCacheSize - (CodeCacheMinimumUseSpace DEBUG_ONLY(* 3))) / (int)buffer_size; + if (count > max_count) { + // Lower the compiler count such that all buffers fit into the code cache + count = MAX2(max_count, c1_only ? 1 : 2); + } FLAG_SET_ERGO(intx, CICompilerCount, count); } #else @@ -241,7 +254,7 @@ void TieredThresholdPolicy::initialize() { } #endif - if (TieredStopAtLevel < CompLevel_full_optimization) { + if (c1_only) { // No C2 compiler thread required set_c1_count(count); } else { From 91a2c2e3401f564ccf4cc6dfdc573f0369b00d02 Mon Sep 17 00:00:00 2001 From: Claes Redestad Date: Tue, 30 Oct 2018 09:34:50 +0100 Subject: [PATCH 51/84] 8213035: Pack MethodHandleInlineStrategy coder and length into a long Reviewed-by: vlivanov, mchung --- .../classes/java/lang/StringConcatHelper.java | 240 +++++++++--------- .../java/lang/invoke/StringConcatFactory.java | 128 ++++------ 2 files changed, 174 insertions(+), 194 deletions(-) diff --git a/src/java.base/share/classes/java/lang/StringConcatHelper.java b/src/java.base/share/classes/java/lang/StringConcatHelper.java index cae184701e1..242d54af4ce 100644 --- a/src/java.base/share/classes/java/lang/StringConcatHelper.java +++ b/src/java.base/share/classes/java/lang/StringConcatHelper.java @@ -37,119 +37,104 @@ final class StringConcatHelper { } /** - * Check for overflow, throw the exception on overflow. - * @param len String length - * @return length + * Check for overflow, throw exception on overflow. + * @param lengthCoder String length and coder + * @return lengthCoder */ - private static int checkOverflow(int len) { - if (len < 0) { - throw new OutOfMemoryError("Overflow: String length out of range"); + private static long checkOverflow(long lengthCoder) { + if ((int)lengthCoder >= 0) { + return lengthCoder; } - return len; + throw new OutOfMemoryError("Overflow: String length out of range"); } /** - * Mix value length into current length + * Mix value length and coder into current length and coder. * @param current current length * @param value value to mix in - * @return new length + * @return new length and coder */ - static int mixLen(int current, boolean value) { + static long mix(long current, boolean value) { return checkOverflow(current + (value ? 4 : 5)); } /** - * Mix value length into current length + * Mix value length and coder into current length and coder. * @param current current length * @param value value to mix in - * @return new length + * @return new length and coder */ - static int mixLen(int current, byte value) { - return mixLen(current, (int)value); + static long mix(long current, byte value) { + return mix(current, (int)value); } /** - * Mix value length into current length + * Mix value length and coder into current length and coder. * @param current current length * @param value value to mix in - * @return new length + * @return new length and coder */ - static int mixLen(int current, char value) { - return checkOverflow(current + 1); + static long mix(long current, char value) { + return checkOverflow(current + 1) | (StringLatin1.canEncode(value) ? 0 : UTF16); } /** - * Mix value length into current length + * Mix value length and coder into current length and coder. * @param current current length * @param value value to mix in - * @return new length + * @return new length and coder */ - static int mixLen(int current, short value) { - return mixLen(current, (int)value); + static long mix(long current, short value) { + return mix(current, (int)value); } /** - * Mix value length into current length + * Mix value length and coder into current length and coder. * @param current current length * @param value value to mix in - * @return new length + * @return new length and coder */ - static int mixLen(int current, int value) { + static long mix(long current, int value) { return checkOverflow(current + Integer.stringSize(value)); } /** - * Mix value length into current length + * Mix value length and coder into current length and coder. * @param current current length * @param value value to mix in - * @return new length + * @return new length and coder */ - static int mixLen(int current, long value) { + static long mix(long current, long value) { return checkOverflow(current + Long.stringSize(value)); } /** - * Mix value length into current length + * Mix value length and coder into current length and coder. * @param current current length * @param value value to mix in - * @return new length + * @return new length and coder */ - static int mixLen(int current, String value) { - return checkOverflow(current + value.length()); - } - - /** - * Mix coder into current coder - * @param current current coder - * @param value value to mix in - * @return new coder - */ - static byte mixCoder(byte current, char value) { - return (byte)(current | (StringLatin1.canEncode(value) ? 0 : 1)); - } - - /** - * Mix coder into current coder - * @param current current coder - * @param value value to mix in - * @return new coder - */ - static byte mixCoder(byte current, String value) { - return (byte)(current | value.coder()); + static long mix(long current, String value) { + current += value.length(); + if (value.coder() == String.UTF16) { + current |= UTF16; + } + return checkOverflow(current); } /** * Prepends the stringly representation of boolean value into buffer, * given the coder and final index. Index is measured in chars, not in bytes! * - * @param index final char index in the buffer - * @param buf buffer to append to - * @param coder coder to add with - * @param value boolean value to encode - * @return new index + * @param indexCoder final char index in the buffer, along with coder packed + * into higher bits. + * @param buf buffer to append to + * @param value boolean value to encode + * @return updated index (coder value retained) */ - static int prepend(int index, byte[] buf, byte coder, boolean value) { - if (coder == String.LATIN1) { + static long prepend(long indexCoder, byte[] buf, boolean value) { + int index = (int)indexCoder; + if (indexCoder < UTF16) { if (value) { buf[--index] = 'e'; buf[--index] = 'u'; @@ -162,6 +147,7 @@ final class StringConcatHelper { buf[--index] = 'a'; buf[--index] = 'f'; } + return index; } else { if (value) { StringUTF16.putChar(buf, --index, 'e'); @@ -175,72 +161,72 @@ final class StringConcatHelper { StringUTF16.putChar(buf, --index, 'a'); StringUTF16.putChar(buf, --index, 'f'); } + return index | UTF16; } - return index; } /** * Prepends the stringly representation of byte value into buffer, * given the coder and final index. Index is measured in chars, not in bytes! * - * @param index final char index in the buffer - * @param buf buffer to append to - * @param coder coder to add with - * @param value byte value to encode - * @return new index + * @param indexCoder final char index in the buffer, along with coder packed + * into higher bits. + * @param buf buffer to append to + * @param value byte value to encode + * @return updated index (coder value retained) */ - static int prepend(int index, byte[] buf, byte coder, byte value) { - return prepend(index, buf, coder, (int)value); + static long prepend(long indexCoder, byte[] buf, byte value) { + return prepend(indexCoder, buf, (int)value); } /** * Prepends the stringly representation of char value into buffer, * given the coder and final index. Index is measured in chars, not in bytes! * - * @param index final char index in the buffer - * @param buf buffer to append to - * @param coder coder to add with - * @param value char value to encode - * @return new index + * @param indexCoder final char index in the buffer, along with coder packed + * into higher bits. + * @param buf buffer to append to + * @param value char value to encode + * @return updated index (coder value retained) */ - static int prepend(int index, byte[] buf, byte coder, char value) { - if (coder == String.LATIN1) { - buf[--index] = (byte) (value & 0xFF); + static long prepend(long indexCoder, byte[] buf, char value) { + if (indexCoder < UTF16) { + buf[(int)(--indexCoder)] = (byte) (value & 0xFF); } else { - StringUTF16.putChar(buf, --index, value); + StringUTF16.putChar(buf, (int)(--indexCoder), value); } - return index; + return indexCoder; } /** * Prepends the stringly representation of short value into buffer, * given the coder and final index. Index is measured in chars, not in bytes! * - * @param index final char index in the buffer - * @param buf buffer to append to - * @param coder coder to add with - * @param value short value to encode - * @return new index + * @param indexCoder final char index in the buffer, along with coder packed + * into higher bits. + * @param buf buffer to append to + * @param value short value to encode + * @return updated index (coder value retained) */ - static int prepend(int index, byte[] buf, byte coder, short value) { - return prepend(index, buf, coder, (int)value); + static long prepend(long indexCoder, byte[] buf, short value) { + return prepend(indexCoder, buf, (int)value); } /** * Prepends the stringly representation of integer value into buffer, * given the coder and final index. Index is measured in chars, not in bytes! * - * @param index final char index in the buffer - * @param buf buffer to append to - * @param coder coder to add with - * @param value integer value to encode - * @return new index + * @param indexCoder final char index in the buffer, along with coder packed + * into higher bits. + * @param buf buffer to append to + * @param value integer value to encode + * @return updated index (coder value retained) */ - static int prepend(int index, byte[] buf, byte coder, int value) { - if (coder == String.LATIN1) { - return Integer.getChars(value, index, buf); + static long prepend(long indexCoder, byte[] buf, int value) { + if (indexCoder < UTF16) { + return Integer.getChars(value, (int)indexCoder, buf); } else { - return StringUTF16.getChars(value, index, buf); + return StringUTF16.getChars(value, (int)indexCoder, buf) | UTF16; } } @@ -248,17 +234,17 @@ final class StringConcatHelper { * Prepends the stringly representation of long value into buffer, * given the coder and final index. Index is measured in chars, not in bytes! * - * @param index final char index in the buffer - * @param buf buffer to append to - * @param coder coder to add with - * @param value long value to encode - * @return new index + * @param indexCoder final char index in the buffer, along with coder packed + * into higher bits. + * @param buf buffer to append to + * @param value long value to encode + * @return updated index (coder value retained) */ - static int prepend(int index, byte[] buf, byte coder, long value) { - if (coder == String.LATIN1) { - return Long.getChars(value, index, buf); + static long prepend(long indexCoder, byte[] buf, long value) { + if (indexCoder < UTF16) { + return Long.getChars(value, (int)indexCoder, buf); } else { - return StringUTF16.getChars(value, index, buf); + return StringUTF16.getChars(value, (int)indexCoder, buf) | UTF16; } } @@ -266,39 +252,49 @@ final class StringConcatHelper { * Prepends the stringly representation of String value into buffer, * given the coder and final index. Index is measured in chars, not in bytes! * - * @param index final char index in the buffer - * @param buf buffer to append to - * @param coder coder to add with - * @param value String value to encode - * @return new index + * @param indexCoder final char index in the buffer, along with coder packed + * into higher bits. + * @param buf buffer to append to + * @param value String value to encode + * @return updated index (coder value retained) */ - static int prepend(int index, byte[] buf, byte coder, String value) { - index -= value.length(); - value.getBytes(buf, index, coder); - return index; + static long prepend(long indexCoder, byte[] buf, String value) { + indexCoder -= value.length(); + if (indexCoder < UTF16) { + value.getBytes(buf, (int)indexCoder, String.LATIN1); + } else { + value.getBytes(buf, (int)indexCoder, String.UTF16); + } + return indexCoder; } /** * Instantiates the String with given buffer and coder - * @param buf buffer to use - * @param index remaining index - * @param coder coder to use - * @return String resulting string + * @param buf buffer to use + * @param indexCoder remaining index (should be zero) and coder + * @return String resulting string */ - static String newString(byte[] buf, int index, byte coder) { + static String newString(byte[] buf, long indexCoder) { // Use the private, non-copying constructor (unsafe!) - if (index != 0) { - throw new InternalError("Storage is not completely initialized, " + index + " bytes left"); + if (indexCoder == LATIN1) { + return new String(buf, String.LATIN1); + } else if (indexCoder == UTF16) { + return new String(buf, String.UTF16); + } else { + throw new InternalError("Storage is not completely initialized, " + (int)indexCoder + " bytes left"); } - return new String(buf, coder); } + private static final long LATIN1 = (long)String.LATIN1 << 32; + + private static final long UTF16 = (long)String.UTF16 << 32; + /** * Provides the initial coder for the String. - * @return initial coder + * @return initial coder, adjusted into the upper half */ - static byte initialCoder() { - return String.COMPACT_STRINGS ? String.LATIN1 : String.UTF16; + static long initialCoder() { + return String.COMPACT_STRINGS ? LATIN1 : UTF16; } } diff --git a/src/java.base/share/classes/java/lang/invoke/StringConcatFactory.java b/src/java.base/share/classes/java/lang/invoke/StringConcatFactory.java index ddf3de7c00b..7eb90b77140 100644 --- a/src/java.base/share/classes/java/lang/invoke/StringConcatFactory.java +++ b/src/java.base/share/classes/java/lang/invoke/StringConcatFactory.java @@ -317,6 +317,13 @@ public final class StringConcatFactory { return elements.equals(recipe.elements); } + @Override + public String toString() { + return "Recipe{" + + "elements=" + elements + + '}'; + } + @Override public int hashCode() { return elements.hashCode(); @@ -367,6 +374,15 @@ public final class StringConcatFactory { return true; } + @Override + public String toString() { + return "RecipeElement{" + + "value='" + value + '\'' + + ", argPos=" + argPos + + ", tag=" + tag + + '}'; + } + @Override public int hashCode() { return (int)tag; @@ -1520,24 +1536,24 @@ public final class StringConcatFactory { } // Start building the combinator tree. The tree "starts" with ()String, and "finishes" - // with the (int, byte[], byte)String in String helper. The combinators are assembled bottom-up, - // which makes the code arguably hard to read. + // with the (byte[], long)String shape to invoke newString in StringConcatHelper. The combinators are + // assembled bottom-up, which makes the code arguably hard to read. // Drop all remaining parameter types, leave only helper arguments: MethodHandle mh; - mh = MethodHandles.dropArguments(NEW_STRING, 3, ptypes); + mh = MethodHandles.dropArguments(NEW_STRING, 2, ptypes); - // Mix in prependers. This happens when (byte[], int, byte) = (storage, index, coder) is already - // known from the combinators below. We are assembling the string backwards, so "index" is the - // *ending* index. + // Mix in prependers. This happens when (byte[], long) = (storage, indexCoder) is already + // known from the combinators below. We are assembling the string backwards, so the index coded + // into indexCoder is the *ending* index. for (RecipeElement el : recipe.getElements()) { // Do the prepend, and put "new" index at index 1 switch (el.getTag()) { case TAG_CONST: { - MethodHandle prepender = MethodHandles.insertArguments(prepender(String.class), 3, el.getValue()); + MethodHandle prepender = MethodHandles.insertArguments(prepender(String.class), 2, el.getValue()); mh = MethodHandles.filterArgumentsWithCombiner(mh, 1, prepender, - 1, 0, 2 // index, storage, coder + 1, 0 // indexCoder, storage ); break; } @@ -1545,8 +1561,8 @@ public final class StringConcatFactory { int pos = el.getArgPos(); MethodHandle prepender = prepender(ptypes[pos]); mh = MethodHandles.filterArgumentsWithCombiner(mh, 1, prepender, - 1, 0, 2, // index, storage, coder - 3 + pos // selected argument + 1, 0, // indexCoder, storage + 2 + pos // selected argument ); break; } @@ -1557,7 +1573,7 @@ public final class StringConcatFactory { // Fold in byte[] instantiation at argument 0 mh = MethodHandles.foldArgumentsWithCombiner(mh, 0, NEW_ARRAY, - 1, 2 // index, coder + 1 // index ); // Start combining length and coder mixers. @@ -1569,47 +1585,28 @@ public final class StringConcatFactory { // Coders are more interesting. Only Object, String and char arguments (and constants) // can have non-Latin1 encoding. It is easier to blindly convert constants to String, // and deduce the coder from there. Arguments would be either converted to Strings - // during the initial filtering, or handled by primitive specializations in CODER_MIXERS. + // during the initial filtering, or handled by specializations in MIXERS. // - // The method handle shape before and after all length and coder mixers is: - // (int, byte, )String = ("index", "coder", ) - byte initialCoder = INITIAL_CODER; - int initialLen = 0; // initial length, in characters + // The method handle shape before and after all mixers are combined in is: + // (long, )String = ("indexCoder", ) + long initialLengthCoder = INITIAL_CODER; for (RecipeElement el : recipe.getElements()) { switch (el.getTag()) { case TAG_CONST: String constant = el.getValue(); - initialCoder = (byte) coderMixer(String.class).invoke(initialCoder, constant); - initialLen += constant.length(); + initialLengthCoder = (long)mixer(String.class).invoke(initialLengthCoder, constant); break; case TAG_ARG: int ac = el.getArgPos(); Class argClass = ptypes[ac]; - MethodHandle lm = lengthMixer(argClass); + MethodHandle mix = mixer(argClass); - if (argClass.isPrimitive() && argClass != char.class) { - // Compute new "index" in-place using old value plus the appropriate argument. - mh = MethodHandles.filterArgumentsWithCombiner(mh, 0, lm, - 0, // old-index - 2 + ac // selected argument - ); - - } else { - MethodHandle cm = coderMixer(argClass); - - // Compute new "index" in-place using old value plus the appropriate argument. - mh = MethodHandles.filterArgumentsWithCombiner(mh, 0, lm, - 0, // old-index - 2 + ac // selected argument - ); - - // Compute new "coder" in-place using old value plus the appropriate argument. - mh = MethodHandles.filterArgumentsWithCombiner(mh, 1, cm, - 1, // old-coder - 2 + ac // selected argument - ); - } + // Compute new "index" in-place using old value plus the appropriate argument. + mh = MethodHandles.filterArgumentsWithCombiner(mh, 0, mix, + 0, // old-index + 1 + ac // selected argument + ); break; default: @@ -1617,9 +1614,9 @@ public final class StringConcatFactory { } } - // Insert initial lengths and coders here. + // Insert initial length and coder value here. // The method handle shape here is (). - mh = MethodHandles.insertArguments(mh, 0, initialLen, initialCoder); + mh = MethodHandles.insertArguments(mh, 0, initialLengthCoder); // Apply filters, converting the arguments: if (filters != null) { @@ -1630,45 +1627,34 @@ public final class StringConcatFactory { } @ForceInline - private static byte[] newArray(int length, byte coder) { - return (byte[]) UNSAFE.allocateUninitializedArray(byte.class, length << coder); + private static byte[] newArray(long indexCoder) { + byte coder = (byte)(indexCoder >> 32); + int index = ((int)indexCoder & 0x7FFFFFFF); + return (byte[]) UNSAFE.allocateUninitializedArray(byte.class, index << coder); } private static MethodHandle prepender(Class cl) { return PREPENDERS.computeIfAbsent(cl, PREPEND); } - private static MethodHandle coderMixer(Class cl) { - return CODER_MIXERS.computeIfAbsent(cl, CODER_MIX); - } - - private static MethodHandle lengthMixer(Class cl) { - return LENGTH_MIXERS.computeIfAbsent(cl, LENGTH_MIX); + private static MethodHandle mixer(Class cl) { + return MIXERS.computeIfAbsent(cl, MIX); } // This one is deliberately non-lambdified to optimize startup time: private static final Function, MethodHandle> PREPEND = new Function, MethodHandle>() { @Override public MethodHandle apply(Class c) { - return lookupStatic(Lookup.IMPL_LOOKUP, STRING_HELPER, "prepend", int.class, int.class, byte[].class, byte.class, + return lookupStatic(Lookup.IMPL_LOOKUP, STRING_HELPER, "prepend", long.class, long.class, byte[].class, Wrapper.asPrimitiveType(c)); } }; // This one is deliberately non-lambdified to optimize startup time: - private static final Function, MethodHandle> CODER_MIX = new Function, MethodHandle>() { + private static final Function, MethodHandle> MIX = new Function, MethodHandle>() { @Override public MethodHandle apply(Class c) { - return lookupStatic(Lookup.IMPL_LOOKUP, STRING_HELPER, "mixCoder", byte.class, byte.class, - Wrapper.asPrimitiveType(c)); - } - }; - - // This one is deliberately non-lambdified to optimize startup time: - private static final Function, MethodHandle> LENGTH_MIX = new Function, MethodHandle>() { - @Override - public MethodHandle apply(Class c) { - return lookupStatic(Lookup.IMPL_LOOKUP, STRING_HELPER, "mixLen", int.class, int.class, + return lookupStatic(Lookup.IMPL_LOOKUP, STRING_HELPER, "mix", long.class, long.class, Wrapper.asPrimitiveType(c)); } }; @@ -1676,26 +1662,24 @@ public final class StringConcatFactory { private static final MethodHandle NEW_STRING; private static final MethodHandle NEW_ARRAY; private static final ConcurrentMap, MethodHandle> PREPENDERS; - private static final ConcurrentMap, MethodHandle> LENGTH_MIXERS; - private static final ConcurrentMap, MethodHandle> CODER_MIXERS; - private static final byte INITIAL_CODER; + private static final ConcurrentMap, MethodHandle> MIXERS; + private static final long INITIAL_CODER; static final Class STRING_HELPER; static { try { STRING_HELPER = Class.forName("java.lang.StringConcatHelper"); - MethodHandle initCoder = lookupStatic(Lookup.IMPL_LOOKUP, STRING_HELPER, "initialCoder", byte.class); - INITIAL_CODER = (byte) initCoder.invoke(); + MethodHandle initCoder = lookupStatic(Lookup.IMPL_LOOKUP, STRING_HELPER, "initialCoder", long.class); + INITIAL_CODER = (long) initCoder.invoke(); } catch (Throwable e) { throw new AssertionError(e); } PREPENDERS = new ConcurrentHashMap<>(); - LENGTH_MIXERS = new ConcurrentHashMap<>(); - CODER_MIXERS = new ConcurrentHashMap<>(); + MIXERS = new ConcurrentHashMap<>(); - NEW_STRING = lookupStatic(Lookup.IMPL_LOOKUP, STRING_HELPER, "newString", String.class, byte[].class, int.class, byte.class); - NEW_ARRAY = lookupStatic(Lookup.IMPL_LOOKUP, MethodHandleInlineCopyStrategy.class, "newArray", byte[].class, int.class, byte.class); + NEW_STRING = lookupStatic(Lookup.IMPL_LOOKUP, STRING_HELPER, "newString", String.class, byte[].class, long.class); + NEW_ARRAY = lookupStatic(Lookup.IMPL_LOOKUP, MethodHandleInlineCopyStrategy.class, "newArray", byte[].class, long.class); } } From d153c9c259e5618008355899413f13b0308fa1cd Mon Sep 17 00:00:00 2001 From: Thomas Stuefe Date: Fri, 26 Oct 2018 16:49:18 +0200 Subject: [PATCH 52/84] 8213017: jspawnhelper: need to handle pipe write failure when sending return code Reviewed-by: alanb --- src/java.base/unix/native/jspawnhelper/jspawnhelper.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/java.base/unix/native/jspawnhelper/jspawnhelper.c b/src/java.base/unix/native/jspawnhelper/jspawnhelper.c index e522b0cf73a..13882017163 100644 --- a/src/java.base/unix/native/jspawnhelper/jspawnhelper.c +++ b/src/java.base/unix/native/jspawnhelper/jspawnhelper.c @@ -49,7 +49,10 @@ extern int errno; #define ERR_ARGS 3 void error (int fd, int err) { - write (fd, &err, sizeof(err)); + if (write (fd, &err, sizeof(err)) != sizeof(err)) { + /* Not sure what to do here. I have no one to speak to. */ + exit(0x80 + err); + } exit (1); } From 0c554411b04e17e4ba43b465cf857ef6d1c487c6 Mon Sep 17 00:00:00 2001 From: Jiangli Zhou Date: Mon, 29 Oct 2018 14:00:48 -0400 Subject: [PATCH 53/84] 8205327: Clean up #if INCLUDE_CDS in classLoaderExt.cpp and classLoaderExt.hpp Clean up #if INCLUDE_CDS in classLoaderExt.* files. Reviewed-by: dholmes --- .../share/classfile/classLoaderExt.cpp | 2 -- .../share/classfile/classLoaderExt.hpp | 33 +++++++++---------- 2 files changed, 15 insertions(+), 20 deletions(-) diff --git a/src/hotspot/share/classfile/classLoaderExt.cpp b/src/hotspot/share/classfile/classLoaderExt.cpp index 0a7f07c9de9..44a62267527 100644 --- a/src/hotspot/share/classfile/classLoaderExt.cpp +++ b/src/hotspot/share/classfile/classLoaderExt.cpp @@ -55,12 +55,10 @@ bool ClassLoaderExt::_has_app_classes = false; bool ClassLoaderExt::_has_platform_classes = false; void ClassLoaderExt::append_boot_classpath(ClassPathEntry* new_entry) { -#if INCLUDE_CDS if (UseSharedSpaces) { warning("Sharing is only supported for boot loader classes because bootstrap classpath has been appended"); FileMapInfo::current_info()->header()->set_has_platform_or_app_classes(false); } -#endif ClassLoader::add_to_boot_append_entries(new_entry); } diff --git a/src/hotspot/share/classfile/classLoaderExt.hpp b/src/hotspot/share/classfile/classLoaderExt.hpp index 85b39a097ae..869008da3c7 100644 --- a/src/hotspot/share/classfile/classLoaderExt.hpp +++ b/src/hotspot/share/classfile/classLoaderExt.hpp @@ -33,12 +33,17 @@ class ClassListParser; class ClassLoaderExt: public ClassLoader { // AllStatic public: + static bool should_verify(int classpath_index) { + CDS_ONLY(return (classpath_index >= _app_class_paths_start_index);) + NOT_CDS(return false;) + } + +#if INCLUDE_CDS +private: enum SomeConstants { max_classpath_index = 0x7fff }; -private: -#if INCLUDE_CDS static char* get_class_path_attr(const char* jar_path, char* manifest, jint manifest_size); static void setup_app_search_path(); // Only when -Xshare:dump static void process_module_table(ModuleEntryTable* met, TRAPS); @@ -54,27 +59,19 @@ private: static bool _has_app_classes; static bool _has_platform_classes; -#endif -public: - CDS_ONLY(static void process_jar_manifest(ClassPathEntry* entry, bool check_for_duplicates);) - - static bool should_verify(int classpath_index) { - CDS_ONLY(return (classpath_index >= _app_class_paths_start_index);) - NOT_CDS(return false;) - } - // Called by JVMTI code to add boot classpath - static void append_boot_classpath(ClassPathEntry* new_entry); - - static void setup_search_paths() NOT_CDS_RETURN; - static void setup_module_paths(TRAPS) NOT_CDS_RETURN; - -#if INCLUDE_CDS -private: static char* read_manifest(ClassPathEntry* entry, jint *manifest_size, bool clean_text, TRAPS); static ClassPathEntry* find_classpath_entry_from_cache(const char* path, TRAPS); public: + static void process_jar_manifest(ClassPathEntry* entry, bool check_for_duplicates); + + // Called by JVMTI code to add boot classpath + static void append_boot_classpath(ClassPathEntry* new_entry); + + static void setup_search_paths(); + static void setup_module_paths(TRAPS); + static char* read_manifest(ClassPathEntry* entry, jint *manifest_size, TRAPS) { // Remove all the new-line continuations (which wrap long lines at 72 characters, see // http://docs.oracle.com/javase/6/docs/technotes/guides/jar/jar.html#JAR%20Manifest), so From e0911eacd64b4f38af7e15f123e3489d0a67d357 Mon Sep 17 00:00:00 2001 From: Calvin Cheung Date: Mon, 29 Oct 2018 11:05:45 -0700 Subject: [PATCH 54/84] 8209566: [TESTBUG] runtime/appcds/jigsaw/modulepath/JvmtiAddPath.java timeout on tier6 on sparc Increased the timeout from 120s (default) to 240s Reviewed-by: dcubed, mseledtsov --- .../jtreg/runtime/appcds/jigsaw/modulepath/JvmtiAddPath.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/hotspot/jtreg/runtime/appcds/jigsaw/modulepath/JvmtiAddPath.java b/test/hotspot/jtreg/runtime/appcds/jigsaw/modulepath/JvmtiAddPath.java index a024a0e1996..c68e36b905f 100644 --- a/test/hotspot/jtreg/runtime/appcds/jigsaw/modulepath/JvmtiAddPath.java +++ b/test/hotspot/jtreg/runtime/appcds/jigsaw/modulepath/JvmtiAddPath.java @@ -33,7 +33,7 @@ * @build sun.hotspot.WhiteBox * @run driver ClassFileInstaller sun.hotspot.WhiteBox * @compile ../../test-classes/JvmtiApp.java - * @run driver JvmtiAddPath + * @run driver/timeout=240 JvmtiAddPath */ import java.io.File; From 7e19a09742b99ffd99c2772014b2f343b2698a67 Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Mon, 29 Oct 2018 11:31:25 -0700 Subject: [PATCH 55/84] 8212081: AnnotatedType.toString implementation don't print annotations on embedded types Reviewed-by: jfranck, wmdietl --- .../annotation/AnnotatedTypeFactory.java | 95 +++++++- .../typeAnnotations/TestObjectMethods.java | 226 ++++++++++++++++-- 2 files changed, 282 insertions(+), 39 deletions(-) diff --git a/src/java.base/share/classes/sun/reflect/annotation/AnnotatedTypeFactory.java b/src/java.base/share/classes/sun/reflect/annotation/AnnotatedTypeFactory.java index b33bf079b8d..47f7b94132b 100644 --- a/src/java.base/share/classes/sun/reflect/annotation/AnnotatedTypeFactory.java +++ b/src/java.base/share/classes/sun/reflect/annotation/AnnotatedTypeFactory.java @@ -33,6 +33,8 @@ import java.util.List; import java.util.Map; import java.util.Objects; import java.util.StringJoiner; +import java.util.stream.Stream; +import java.util.stream.Collectors; import static sun.reflect.annotation.TypeAnnotation.*; @@ -125,6 +127,12 @@ public final class AnnotatedTypeFactory { EMPTY_TYPE_ANNOTATION_ARRAY, EMPTY_TYPE_ANNOTATION_ARRAY, null); static final AnnotatedType[] EMPTY_ANNOTATED_TYPE_ARRAY = new AnnotatedType[0]; + /* + * Note that if additional subclasses of AnnotatedTypeBaseImpl are + * added, the equals methods of AnnotatedTypeBaseImpl will need to + * be updated to properly implement the equals contract. + */ + private static class AnnotatedTypeBaseImpl implements AnnotatedType { private final Type type; private final AnnotatedElement decl; @@ -207,25 +215,26 @@ public final class AnnotatedTypeFactory { @Override // java.lang.Object public String toString() { // Reusable toString implementation, but needs to be - // specialized for quirks of arrays. - return annotationsToString(getAnnotations(), false) + type.toString(); + // specialized for quirks of arrays and interior types of + // wildcards, etc. + return annotationsToString(getAnnotations(), false) + + ((type instanceof Class) ? type.getTypeName(): type.toString()); } protected String annotationsToString(Annotation[] annotations, boolean leadingSpace) { if (annotations != null && annotations.length > 0) { - StringJoiner sj = new StringJoiner(" "); - if (leadingSpace) { - sj.add(""); // Add a space - } + StringBuffer sb = new StringBuffer(); - for (Annotation annotation : annotations) { - sj.add(annotation.toString()); - } + sb.append(Stream.of(annotations). + map(Annotation::toString). + collect(Collectors.joining(" "))); - if (!leadingSpace) { - sj.add(""); - } - return sj.toString(); + if (leadingSpace) + sb.insert(0, " "); + else + sb.append(" "); + + return sb.toString(); } else { return ""; } @@ -377,6 +386,13 @@ public final class AnnotatedTypeFactory { return (TypeVariable)getType(); } + // For toString, the declaration of a type variable should + // including information about its bounds, etc. However, the + // use of a type variable should not. For that reason, it is + // acceptable for the toString implementation of + // AnnotatedTypeVariableImpl to use the inherited + // implementation from AnnotatedTypeBaseImpl. + @Override public boolean equals(Object o) { if (o instanceof AnnotatedTypeVariable) { @@ -444,6 +460,23 @@ public final class AnnotatedTypeFactory { return (ParameterizedType)getType(); } + @Override + public String toString() { + StringBuilder sb = new StringBuilder(); + sb.append(annotationsToString(getAnnotations(), false)); + + Type t = getParameterizedType().getRawType(); + sb.append(t.getTypeName()); + + AnnotatedType[] typeArgs = getAnnotatedActualTypeArguments(); + if (typeArgs.length > 0) { + sb.append(Stream.of(typeArgs).map(AnnotatedType::toString). + collect(Collectors.joining(", ", "<", ">"))); + } + + return sb.toString(); + } + @Override public boolean equals(Object o) { if (o instanceof AnnotatedParameterizedType) { @@ -523,6 +556,42 @@ public final class AnnotatedTypeFactory { return hasUpperBounds; } + @Override + public String toString() { + StringBuilder sb = new StringBuilder(); + sb.append(annotationsToString(getAnnotations(), false)); + sb.append("?"); + + // Note that the wildcard API is written to accommodate + // multiple bounds for wildcards, but at the time of + // writing only a single bound is allowed in the + // language. + AnnotatedType[] bounds = getAnnotatedLowerBounds(); + if (bounds.length > 0) { + sb.append(" super "); + } else { + bounds = getAnnotatedUpperBounds(); + if (bounds.length > 0) { + if (bounds.length == 1) { + // Check for and elide " extends java.lang.Object" if a lone + // Object bound is not annotated. + AnnotatedType bound = bounds[0]; + if (bound.getType().equals(Object.class) && + bound.getAnnotations().length == 0) { + return sb.toString(); + } + } + sb.append(" extends "); + } + } + + sb.append(Stream.of(bounds).map(AnnotatedType::toString). + collect(Collectors.joining(" & "))); + + return sb.toString(); + } + + @Override public boolean equals(Object o) { if (o instanceof AnnotatedWildcardType) { diff --git a/test/jdk/java/lang/annotation/typeAnnotations/TestObjectMethods.java b/test/jdk/java/lang/annotation/typeAnnotations/TestObjectMethods.java index fc818bb36e1..ae8d8f2a265 100644 --- a/test/jdk/java/lang/annotation/typeAnnotations/TestObjectMethods.java +++ b/test/jdk/java/lang/annotation/typeAnnotations/TestObjectMethods.java @@ -23,17 +23,19 @@ /* * @test - * @bug 8058202 + * @bug 8058202 8212081 * @summary Test java.lang.Object methods on AnnotatedType objects. */ import java.lang.annotation.*; import java.lang.reflect.*; import java.util.*; +import java.util.regex.*; /** * Test toString, equals, and hashCode on various AnnotatedType objects. */ + public class TestObjectMethods { private static int errors = 0; @@ -61,8 +63,8 @@ public class TestObjectMethods { testEquals(clazz); } - testToString(TypeHost.class, false); - testToString(AnnotatedTypeHost.class, true); + testToString(TypeHost.class); + testToString(AnnotatedTypeHost.class); testAnnotationsMatterForEquals(TypeHost.class, AnnotatedTypeHost.class); @@ -80,29 +82,45 @@ public class TestObjectMethods { * For non-array types, verify toString version of the annotated * type ends with the same string as the generic type. */ - static void testToString(Class clazz, boolean leadingAnnotations) { + static void testToString(Class clazz) { System.err.println("Testing toString on methods of class " + clazz.getName()); Method[] methods = clazz.getDeclaredMethods(); for (Method m : methods) { + // Expected information about the type annotations stored + // in a *declaration* annotation. + AnnotTypeInfo annotTypeInfo = m.getAnnotation(AnnotTypeInfo.class); + int expectedAnnotCount = annotTypeInfo.count(); + Relation relation = annotTypeInfo.relation(); + AnnotatedType annotType = m.getAnnotatedReturnType(); String annotTypeString = annotType.toString(); Type type = m.getGenericReturnType(); - String typeString = type.toString(); + String typeString = (type instanceof Class) ? + type.getTypeName() : + type.toString(); boolean isArray = annotType instanceof AnnotatedArrayType; boolean isVoid = "void".equals(typeString); boolean valid; - if (!isArray) { - if (leadingAnnotations && !isVoid) { - valid = - annotTypeString.endsWith(typeString) && - !annotTypeString.startsWith(typeString); - } else { - valid = annotTypeString.equals(typeString); - } - } else { + + switch(relation) { + case EQUAL: + valid = annotTypeString.equals(typeString); + break; + + case POSTFIX: + valid = annotTypeString.endsWith(typeString) && + !annotTypeString.startsWith(typeString); + break; + + case STRIPPED: + String stripped = annotationRegex.matcher(annotTypeString).replaceAll(""); + valid = typeString.replace(" ", "").equals(stripped.replace(" ", "")); + break; + + case ARRAY: // Find final non-array component type and gets its name. typeString = null; @@ -114,6 +132,38 @@ public class TestObjectMethods { String componentName = componentType.getType().getTypeName(); valid = annotTypeString.contains(componentName); + break; + + case OTHER: + // No additional checks + valid = true; + break; + + default: + throw new AssertionError("Shouldn't be reached"); + } + + // Verify number of type annotations matches expected value + Matcher matcher = annotationRegex.matcher(annotTypeString); + if (expectedAnnotCount > 0) { + int i = expectedAnnotCount; + int annotCount = 0; + while (i > 0) { + boolean found = matcher.find(); + if (found) { + i--; + annotCount++; + } else { + errors++; + System.err.println("\tExpected annotation not found: " + annotTypeString); + } + } + } + + boolean found = matcher.find(); + if (found) { + errors++; + System.err.println("\tAnnotation found unexpectedly: " + annotTypeString); } if (!valid) { @@ -125,6 +175,8 @@ public class TestObjectMethods { } } + private static final Pattern annotationRegex = Pattern.compile("@TestObjectMethods\\$AnnotType\\(value=(\\p{Digit})+\\)"); + static void testGetAnnotations(Class clazz, boolean annotationsExpectedOnMethods) { System.err.println("Testing getAnnotations on methods of class " + clazz.getName()); Method[] methods = clazz.getDeclaredMethods(); @@ -230,7 +282,6 @@ public class TestObjectMethods { } } - static void testWildcards() { System.err.println("Testing wildcards"); // public @AnnotType(10) Set fooNumberSet() {return null;} @@ -269,22 +320,53 @@ public class TestObjectMethods { // possible. static class TypeHost { + @AnnotTypeInfo public void fooVoid() {return;} + @AnnotTypeInfo public int foo() {return 0;} + + @AnnotTypeInfo public String fooString() {return null;} + @AnnotTypeInfo public int[] fooIntArray() {return null;} + + @AnnotTypeInfo public String[] fooStringArray() {return null;} + + @AnnotTypeInfo public String [][] fooStringArrayArray() {return null;} + @AnnotTypeInfo public Set fooSetString() {return null;} + + @AnnotTypeInfo + public Set fooSetNumber() {return null;} + + @AnnotTypeInfo public E fooE() {return null;} + + @AnnotTypeInfo public F fooF() {return null;} + + @AnnotTypeInfo public G fooG() {return null;} + @AnnotTypeInfo public Set fooNumberSet() {return null;} + + @AnnotTypeInfo public Set fooNumberSet2() {return null;} + + @AnnotTypeInfo + public Set fooNumberSet3() {return null;} + + @AnnotTypeInfo + public Set fooObjectSet() {return null;} + + @AnnotTypeInfo + public List fooObjectList() {return null;} } @Retention(RetentionPolicy.RUNTIME) @@ -293,22 +375,114 @@ public class TestObjectMethods { int value() default 0; } + @Retention(RetentionPolicy.RUNTIME) + @Target(ElementType.METHOD) + static @interface AnnotTypeInfo { + /** + * Expected number of @AnnotType + */ + int count() default 0; + + /** + * Relation to genericString output. + */ + Relation relation() default Relation.EQUAL; + } + + /** + * Expected relationship of toString output of AnnotatedType to + * toGenericString output of underlying type. + */ + static private enum Relation { + EQUAL, + + /** + * The toGenericString output is a postfix of the + * AnnotatedType output; a leading annotation is expected. + */ + POSTFIX, + + /** + * If the annotations are stripped from the AnnotatedType + * output and whitespace adjusted accordingly, it should equal + * the toGenericString output. + */ + STRIPPED, + + /** + * The output of AnnotatedType for arrays would require more + * extensive transformation to map to toGenericString output. + */ + ARRAY, + + /** + * Some other, harder to characterize, relationship. Currently + * used for a wildcard where Object in "extends Object" is + * annotated; the "extends Object" is elided in toGenericString. + */ + OTHER; + } + static class AnnotatedTypeHost { + @AnnotTypeInfo public /*@AnnotType(0)*/ void fooVoid() {return;} // Illegal to annotate void - public @AnnotType(1) int foo() {return 0;} - public @AnnotType(2) String fooString() {return null;} + @AnnotTypeInfo(count =1, relation = Relation.POSTFIX) + @AnnotType(1) + public int foo() {return 0;} - public int @AnnotType(3) [] fooIntArray() {return null;} - public String @AnnotType(4) [] fooStringArray() {return null;} - public @AnnotType(5) String @AnnotType(0) [] @AnnotType(1) [] fooStringArrayArray() {return null;} + @AnnotTypeInfo(count = 1, relation = Relation.POSTFIX) + @AnnotType(2) + public String fooString() {return null;} - public @AnnotType(6) Set fooSetString() {return null;} - public @AnnotType(7) E fooE() {return null;} - public @AnnotType(8) F fooF() {return null;} - public @AnnotType(9) G fooG() {return null;} + @AnnotTypeInfo(count = 1, relation = Relation.ARRAY) + public int @AnnotType(3) [] fooIntArray() {return null;} - public @AnnotType(10) Set fooNumberSet() {return null;} - public @AnnotType(11) Set<@AnnotType(13) ? extends Number> fooNumberSet2() {return null;} + @AnnotTypeInfo(count = 1, relation = Relation.ARRAY) + public String @AnnotType(4) [] fooStringArray() {return null;} + + @AnnotTypeInfo(count = 3, relation = Relation.ARRAY) + @AnnotType(5) + public String @AnnotType(0) [] @AnnotType(1) [] fooStringArrayArray() {return null;} + + @AnnotTypeInfo(count = 1, relation = Relation.POSTFIX) + @AnnotType(6) + public Set fooSetString() {return null;} + + @AnnotTypeInfo(count = 2, relation = Relation.STRIPPED) + @AnnotType(7) + public Set<@AnnotType(8) Number> fooSetNumber() {return null;} + + @AnnotTypeInfo(count = 1, relation = Relation.POSTFIX) + @AnnotType(9) + public E fooE() {return null;} + + @AnnotTypeInfo(count = 1, relation = Relation.POSTFIX) + @AnnotType(10) + public F fooF() {return null;} + + @AnnotTypeInfo(count = 1, relation = Relation.POSTFIX) + @AnnotType(11) + public G fooG() {return null;} + + @AnnotTypeInfo(count = 1, relation = Relation.POSTFIX) + @AnnotType(12) + public Set fooNumberSet() {return null;} + + @AnnotTypeInfo(count = 2, relation = Relation.STRIPPED) + @AnnotType(13) + public Set<@AnnotType(14) ? extends Number> fooNumberSet2() {return null;} + + @AnnotTypeInfo(count = 2, relation = Relation.STRIPPED) + @AnnotType(15) + public Set< ? extends @AnnotType(16) Long> fooNumberSet3() {return null;} + + @AnnotTypeInfo(count = 2, relation = Relation.STRIPPED) + @AnnotType(16) + public Set<@AnnotType(17) ?> fooObjectSet() {return null;} + + @AnnotTypeInfo(count = 2, relation = Relation.OTHER) + @AnnotType(18) + public List fooObjectList() {return null;} } } From 0399760d7fd2165d24f933123d671c251ac45368 Mon Sep 17 00:00:00 2001 From: Harold Seigel Date: Tue, 30 Oct 2018 09:13:00 -0400 Subject: [PATCH 56/84] 8213148: JDK build fails because of missing #includes Add missing #includes Reviewed-by: dcubed --- test/hotspot/gtest/memory/test_metaspace.cpp | 2 ++ 1 file changed, 2 insertions(+) diff --git a/test/hotspot/gtest/memory/test_metaspace.cpp b/test/hotspot/gtest/memory/test_metaspace.cpp index c0adcc1e420..edc3bccbf5a 100644 --- a/test/hotspot/gtest/memory/test_metaspace.cpp +++ b/test/hotspot/gtest/memory/test_metaspace.cpp @@ -24,6 +24,8 @@ #include "precompiled.hpp" #include "memory/metaspace.hpp" #include "memory/metaspace/virtualSpaceList.hpp" +#include "runtime/mutexLocker.hpp" +#include "runtime/os.hpp" #include "unittest.hpp" using namespace metaspace; From 05027c124c62e23f010a3e8edb233ac50906d34f Mon Sep 17 00:00:00 2001 From: Bob Vandette Date: Tue, 30 Oct 2018 10:39:19 -0400 Subject: [PATCH 57/84] 8209093: JEP 340: One AArch64 Port, Not Two Reviewed-by: dholmes, erikj, mikael, shade, avoitylov, bulasevich --- doc/building.html | 1 - doc/building.md | 8 - make/autoconf/flags-cflags.m4 | 4 - make/autoconf/flags-ldflags.m4 | 4 - make/autoconf/flags.m4 | 6 +- make/autoconf/hotspot.m4 | 33 +- make/conf/jib-profiles.js | 62 +- make/hotspot/lib/CompileJvm.gmk | 6 - .../cpu/arm/abstractInterpreter_arm.cpp | 105 +- src/hotspot/cpu/arm/arm.ad | 3375 ----------------- src/hotspot/cpu/arm/arm_64.ad | 998 ----- src/hotspot/cpu/arm/assembler_arm.hpp | 75 - src/hotspot/cpu/arm/assembler_arm_64.cpp | 186 - src/hotspot/cpu/arm/assembler_arm_64.hpp | 1718 --------- src/hotspot/cpu/arm/c1_CodeStubs_arm.cpp | 28 +- src/hotspot/cpu/arm/c1_Defs_arm.hpp | 12 +- src/hotspot/cpu/arm/c1_FrameMap_arm.cpp | 33 +- src/hotspot/cpu/arm/c1_FrameMap_arm.hpp | 17 - src/hotspot/cpu/arm/c1_LIRAssembler_arm.cpp | 744 +--- src/hotspot/cpu/arm/c1_LIRAssembler_arm.hpp | 9 +- src/hotspot/cpu/arm/c1_LIRGenerator_arm.cpp | 260 +- src/hotspot/cpu/arm/c1_LIRGenerator_arm.hpp | 4 - src/hotspot/cpu/arm/c1_LIR_arm.cpp | 22 - src/hotspot/cpu/arm/c1_LinearScan_arm.hpp | 7 - src/hotspot/cpu/arm/c1_MacroAssembler_arm.cpp | 93 - src/hotspot/cpu/arm/c1_Runtime1_arm.cpp | 156 +- src/hotspot/cpu/arm/c2_globals_arm.hpp | 12 - src/hotspot/cpu/arm/frame_arm.cpp | 40 - src/hotspot/cpu/arm/frame_arm.hpp | 21 +- src/hotspot/cpu/arm/frame_arm.inline.hpp | 11 - .../arm/gc/g1/g1BarrierSetAssembler_arm.cpp | 74 +- .../arm/gc/shared/barrierSetAssembler_arm.cpp | 42 +- .../cardTableBarrierSetAssembler_arm.cpp | 10 - src/hotspot/cpu/arm/globalDefinitions_arm.hpp | 23 +- src/hotspot/cpu/arm/globals_arm.hpp | 10 +- src/hotspot/cpu/arm/icBuffer_arm.cpp | 2 +- src/hotspot/cpu/arm/icache_arm.cpp | 37 - src/hotspot/cpu/arm/interp_masm_arm.cpp | 214 +- src/hotspot/cpu/arm/interp_masm_arm.hpp | 57 - src/hotspot/cpu/arm/interpreterRT_arm.cpp | 89 +- src/hotspot/cpu/arm/interpreterRT_arm.hpp | 6 - src/hotspot/cpu/arm/jniFastGetField_arm.cpp | 48 +- src/hotspot/cpu/arm/jniTypes_arm.hpp | 16 - src/hotspot/cpu/arm/macroAssembler_arm.cpp | 982 +---- src/hotspot/cpu/arm/macroAssembler_arm.hpp | 478 +-- .../cpu/arm/macroAssembler_arm.inline.hpp | 40 +- src/hotspot/cpu/arm/methodHandles_arm.cpp | 39 +- src/hotspot/cpu/arm/nativeInst_arm.hpp | 4 - src/hotspot/cpu/arm/nativeInst_arm_64.cpp | 243 -- src/hotspot/cpu/arm/nativeInst_arm_64.hpp | 771 ---- src/hotspot/cpu/arm/register_arm.cpp | 14 - src/hotspot/cpu/arm/register_arm.hpp | 156 +- .../cpu/arm/register_definitions_arm.cpp | 37 - src/hotspot/cpu/arm/relocInfo_arm.cpp | 51 +- src/hotspot/cpu/arm/runtime_arm.cpp | 7 - src/hotspot/cpu/arm/sharedRuntime_arm.cpp | 638 +--- src/hotspot/cpu/arm/stubGenerator_arm.cpp | 1370 +------ src/hotspot/cpu/arm/stubRoutines_arm.cpp | 4 - src/hotspot/cpu/arm/stubRoutines_arm.hpp | 6 - .../arm/templateInterpreterGenerator_arm.cpp | 365 +- src/hotspot/cpu/arm/templateTable_arm.cpp | 583 +-- src/hotspot/cpu/arm/vm_version_arm.hpp | 18 - src/hotspot/cpu/arm/vm_version_arm_64.cpp | 261 -- src/hotspot/cpu/arm/vm_version_ext_arm.cpp | 4 - src/hotspot/cpu/arm/vtableStubs_arm.cpp | 18 +- .../os_cpu/linux_arm/atomic_linux_arm.hpp | 124 +- .../linux_arm/copy_linux_arm.inline.hpp | 19 - .../os_cpu/linux_arm/globals_linux_arm.hpp | 6 - src/hotspot/os_cpu/linux_arm/linux_arm_32.s | 8 +- src/hotspot/os_cpu/linux_arm/linux_arm_64.s | 542 --- .../linux_arm/orderAccess_linux_arm.hpp | 134 +- src/hotspot/os_cpu/linux_arm/os_linux_arm.cpp | 35 +- src/hotspot/os_cpu/linux_arm/os_linux_arm.hpp | 6 - .../linux_arm/prefetch_linux_arm.inline.hpp | 8 - .../os_cpu/linux_arm/thread_linux_arm.cpp | 7 +- src/hotspot/share/utilities/macros.hpp | 7 +- .../jvm/hotspot/utilities/PlatformInfo.java | 11 - .../ReservedStack/ReservedStackTest.java | 26 +- 78 files changed, 260 insertions(+), 15440 deletions(-) delete mode 100644 src/hotspot/cpu/arm/arm_64.ad delete mode 100644 src/hotspot/cpu/arm/assembler_arm_64.cpp delete mode 100644 src/hotspot/cpu/arm/assembler_arm_64.hpp delete mode 100644 src/hotspot/cpu/arm/nativeInst_arm_64.cpp delete mode 100644 src/hotspot/cpu/arm/nativeInst_arm_64.hpp delete mode 100644 src/hotspot/cpu/arm/vm_version_arm_64.cpp delete mode 100644 src/hotspot/os_cpu/linux_arm/linux_arm_64.s diff --git a/doc/building.html b/doc/building.html index 363a45058be..fbb13f9626c 100644 --- a/doc/building.html +++ b/doc/building.html @@ -707,7 +707,6 @@ ls build/linux-aarch64-normal-server-release/

Additional architectures might be supported by Debian/Ubuntu Ports.

Building for ARM/aarch64

A common cross-compilation target is the ARM CPU. When building for ARM, it is useful to set the ABI profile. A number of pre-defined ABI profiles are available using --with-abi-profile: arm-vfp-sflt, arm-vfp-hflt, arm-sflt, armv5-vfp-sflt, armv6-vfp-hflt. Note that soft-float ABIs are no longer properly supported by the JDK.

-

The JDK contains two different ports for the aarch64 platform, one is the original aarch64 port from the AArch64 Port Project and one is a 64-bit version of the Oracle contributed ARM port. When targeting aarch64, by the default the original aarch64 port is used. To select the Oracle ARM 64 port, use --with-cpu-port=arm64. Also set the corresponding value (aarch64 or arm64) to --with-abi-profile, to ensure a consistent build.

Verifying the Build

The build will end up in a directory named like build/linux-arm-normal-server-release.

Inside this build output directory, the images/jdk will contain the newly built JDK, for your target system.

diff --git a/doc/building.md b/doc/building.md index 5ac227b7f6b..f9448a4b38c 100644 --- a/doc/building.md +++ b/doc/building.md @@ -1080,14 +1080,6 @@ available using `--with-abi-profile`: arm-vfp-sflt, arm-vfp-hflt, arm-sflt, armv5-vfp-sflt, armv6-vfp-hflt. Note that soft-float ABIs are no longer properly supported by the JDK. -The JDK contains two different ports for the aarch64 platform, one is the -original aarch64 port from the [AArch64 Port Project]( -http://openjdk.java.net/projects/aarch64-port) and one is a 64-bit version of -the Oracle contributed ARM port. When targeting aarch64, by the default the -original aarch64 port is used. To select the Oracle ARM 64 port, use -`--with-cpu-port=arm64`. Also set the corresponding value (`aarch64` or -`arm64`) to --with-abi-profile, to ensure a consistent build. - ### Verifying the Build The build will end up in a directory named like diff --git a/make/autoconf/flags-cflags.m4 b/make/autoconf/flags-cflags.m4 index b5180fef55b..76101ccbe53 100644 --- a/make/autoconf/flags-cflags.m4 +++ b/make/autoconf/flags-cflags.m4 @@ -747,10 +747,6 @@ AC_DEFUN([FLAGS_SETUP_CFLAGS_CPU_DEP], # -Wno-psabi to get rid of annoying "note: the mangling of 'va_list' has changed in GCC 4.4" $1_CFLAGS_CPU="-fsigned-char -Wno-psabi $ARM_ARCH_TYPE_FLAGS $ARM_FLOAT_TYPE_FLAGS -DJDK_ARCH_ABI_PROP_NAME='\"\$(JDK_ARCH_ABI_PROP_NAME)\"'" $1_CFLAGS_CPU_JVM="-DARM" - elif test "x$FLAGS_CPU" = xaarch64; then - if test "x$HOTSPOT_TARGET_CPU_PORT" = xarm64; then - $1_CFLAGS_CPU_JVM="-fsigned-char -DARM" - fi elif test "x$FLAGS_CPU_ARCH" = xppc; then $1_CFLAGS_CPU_JVM="-minsert-sched-nops=regroup_exact -mno-multiple -mno-string" if test "x$FLAGS_CPU" = xppc64; then diff --git a/make/autoconf/flags-ldflags.m4 b/make/autoconf/flags-ldflags.m4 index 7284aad5e8d..ee68164fdbf 100644 --- a/make/autoconf/flags-ldflags.m4 +++ b/make/autoconf/flags-ldflags.m4 @@ -173,10 +173,6 @@ AC_DEFUN([FLAGS_SETUP_LDFLAGS_CPU_DEP], elif test "x$OPENJDK_$1_CPU" = xarm; then $1_CPU_LDFLAGS_JVM_ONLY="${$1_CPU_LDFLAGS_JVM_ONLY} -fsigned-char" $1_CPU_LDFLAGS="$ARM_ARCH_TYPE_FLAGS $ARM_FLOAT_TYPE_FLAGS" - elif test "x$FLAGS_CPU" = xaarch64; then - if test "x$HOTSPOT_TARGET_CPU_PORT" = xarm64; then - $1_CPU_LDFLAGS_JVM_ONLY="${$1_CPU_LDFLAGS_JVM_ONLY} -fsigned-char" - fi fi elif test "x$TOOLCHAIN_TYPE" = xsolstudio; then diff --git a/make/autoconf/flags.m4 b/make/autoconf/flags.m4 index 208f6f48d18..8ef9550f774 100644 --- a/make/autoconf/flags.m4 +++ b/make/autoconf/flags.m4 @@ -34,7 +34,7 @@ m4_include([flags-other.m4]) AC_DEFUN([FLAGS_SETUP_ABI_PROFILE], [ AC_ARG_WITH(abi-profile, [AS_HELP_STRING([--with-abi-profile], - [specify ABI profile for ARM builds (arm-vfp-sflt,arm-vfp-hflt,arm-sflt, armv5-vfp-sflt,armv6-vfp-hflt,arm64,aarch64) @<:@toolchain dependent@:>@ ])]) + [specify ABI profile for ARM builds (arm-vfp-sflt,arm-vfp-hflt,arm-sflt, armv5-vfp-sflt,armv6-vfp-hflt,aarch64) @<:@toolchain dependent@:>@ ])]) if test "x$with_abi_profile" != x; then if test "x$OPENJDK_TARGET_CPU" != xarm && \ @@ -61,10 +61,6 @@ AC_DEFUN([FLAGS_SETUP_ABI_PROFILE], elif test "x$OPENJDK_TARGET_ABI_PROFILE" = xarmv6-vfp-hflt; then ARM_FLOAT_TYPE=vfp-hflt ARM_ARCH_TYPE_FLAGS='-march=armv6 -marm' - elif test "x$OPENJDK_TARGET_ABI_PROFILE" = xarm64; then - # No special flags, just need to trigger setting JDK_ARCH_ABI_PROP_NAME - ARM_FLOAT_TYPE= - ARM_ARCH_TYPE_FLAGS= elif test "x$OPENJDK_TARGET_ABI_PROFILE" = xaarch64; then # No special flags, just need to trigger setting JDK_ARCH_ABI_PROP_NAME ARM_FLOAT_TYPE= diff --git a/make/autoconf/hotspot.m4 b/make/autoconf/hotspot.m4 index 39b681085fd..b822a691e43 100644 --- a/make/autoconf/hotspot.m4 +++ b/make/autoconf/hotspot.m4 @@ -72,8 +72,6 @@ AC_DEFUN_ONCE([HOTSPOT_SETUP_JVM_VARIANTS], AC_ARG_WITH([jvm-variants], [AS_HELP_STRING([--with-jvm-variants], [JVM variants (separated by commas) to build (server,client,minimal,core,zero,custom) @<:@server@:>@])]) - SETUP_HOTSPOT_TARGET_CPU_PORT - if test "x$with_jvm_variants" = x; then with_jvm_variants="server" fi @@ -299,9 +297,6 @@ AC_DEFUN_ONCE([HOTSPOT_SETUP_JVM_FEATURES], if test "x$OPENJDK_TARGET_CPU" = xarm; then HOTSPOT_TARGET_CPU=arm_32 HOTSPOT_TARGET_CPU_DEFINE="ARM32" - elif test "x$OPENJDK_TARGET_CPU" = xaarch64 && test "x$HOTSPOT_TARGET_CPU_PORT" = xarm64; then - HOTSPOT_TARGET_CPU=arm_64 - HOTSPOT_TARGET_CPU_ARCH=arm fi # Verify that dependencies are met for explicitly set features. @@ -542,6 +537,9 @@ AC_DEFUN_ONCE([HOTSPOT_SETUP_JVM_FEATURES], # Used for verification of Makefiles by check-jvm-feature AC_SUBST(VALID_JVM_FEATURES) + + # --with-cpu-port is no longer supported + BASIC_DEPRECATED_ARG_WITH(with-cpu-port) ]) ############################################################################### @@ -578,31 +576,6 @@ AC_DEFUN_ONCE([HOTSPOT_FINALIZE_JVM_FEATURES], done ]) -################################################################################ -# -# Specify which sources will be used to build the 64-bit ARM port -# -# --with-cpu-port=arm64 will use hotspot/src/cpu/arm -# --with-cpu-port=aarch64 will use hotspot/src/cpu/aarch64 -# -AC_DEFUN([SETUP_HOTSPOT_TARGET_CPU_PORT], -[ - AC_ARG_WITH(cpu-port, [AS_HELP_STRING([--with-cpu-port], - [specify sources to use for Hotspot 64-bit ARM port (arm64,aarch64) @<:@aarch64@:>@ ])]) - - if test "x$with_cpu_port" != x; then - if test "x$OPENJDK_TARGET_CPU" != xaarch64; then - AC_MSG_ERROR([--with-cpu-port only available on aarch64]) - fi - if test "x$with_cpu_port" != xarm64 && \ - test "x$with_cpu_port" != xaarch64; then - AC_MSG_ERROR([--with-cpu-port must specify arm64 or aarch64]) - fi - HOTSPOT_TARGET_CPU_PORT="$with_cpu_port" - fi -]) - - ################################################################################ # Check if gtest should be built # diff --git a/make/conf/jib-profiles.js b/make/conf/jib-profiles.js index 6147b41838e..08156f067ad 100644 --- a/make/conf/jib-profiles.js +++ b/make/conf/jib-profiles.js @@ -233,8 +233,7 @@ var getJibProfilesCommon = function (input, data) { common.main_profile_names = [ "linux-x64", "linux-x86", "macosx-x64", "solaris-x64", "solaris-sparcv9", "windows-x64", "windows-x86", - "linux-aarch64", "linux-arm32", "linux-arm64", "linux-arm-vfp-hflt", - "linux-arm-vfp-hflt-dyn" + "linux-aarch64", "linux-arm32" ]; // These are the base setttings for all the main build profiles. @@ -440,20 +439,7 @@ var getJibProfilesProfiles = function (input, common, data) { dependencies: ["devkit", "build_devkit", "cups"], configure_args: [ "--openjdk-target=aarch64-linux-gnu", "--with-freetype=bundled", - "--disable-warnings-as-errors", "--with-cpu-port=aarch64", - ], - }, - - "linux-arm64": { - target_os: "linux", - target_cpu: "aarch64", - build_cpu: "x64", - dependencies: ["devkit", "build_devkit", "cups", "headless_stubs"], - configure_args: [ - "--with-cpu-port=arm64", - "--with-jvm-variants=server", - "--openjdk-target=aarch64-linux-gnu", - "--enable-headless-only" + "--disable-warnings-as-errors" ], }, @@ -467,30 +453,7 @@ var getJibProfilesProfiles = function (input, common, data) { "--with-abi-profile=arm-vfp-hflt", "--disable-warnings-as-errors" ], }, - - "linux-arm-vfp-hflt": { - target_os: "linux", - target_cpu: "arm", - build_cpu: "x64", - dependencies: ["devkit", "build_devkit", "cups"], - configure_args: [ - "--with-jvm-variants=minimal1,client", - "--with-x=" + input.get("devkit", "install_path") + "/arm-linux-gnueabihf/libc/usr/X11R6-PI", - "--with-fontconfig=" + input.get("devkit", "install_path") + "/arm-linux-gnueabihf/libc/usr/X11R6-PI", - "--openjdk-target=arm-linux-gnueabihf", - "--with-abi-profile=arm-vfp-hflt", - "--with-freetype=bundled" - ], - }, - - // Special version of the SE profile adjusted to be testable on arm64 hardware. - "linux-arm-vfp-hflt-dyn": { - configure_args: "--with-stdc++lib=dynamic" - } }; - // Let linux-arm-vfp-hflt-dyn inherit everything from linux-arm-vfp-hflt - profiles["linux-arm-vfp-hflt-dyn"] = concatObjects( - profiles["linux-arm-vfp-hflt-dyn"], profiles["linux-arm-vfp-hflt"]); // Add the base settings to all the main profiles common.main_profile_names.forEach(function (name) { @@ -617,15 +580,6 @@ var getJibProfilesProfiles = function (input, common, data) { }, "linux-arm32": { platform: "linux-arm32", - }, - "linux-arm64": { - platform: "linux-arm64-vfp-hflt", - }, - "linux-arm-vfp-hflt": { - platform: "linux-arm32-vfp-hflt", - }, - "linux-arm-vfp-hflt-dyn": { - platform: "linux-arm32-vfp-hflt-dyn", } } // Generate common artifacts for all main profiles @@ -850,16 +804,8 @@ var getJibProfilesDependencies = function (input, common) { solaris_x64: "SS12u4-Solaris11u1+1.0", solaris_sparcv9: "SS12u6-Solaris11u3+1.0", windows_x64: "VS2017-15.5.5+1.0", - linux_aarch64: (input.profile != null && input.profile.indexOf("arm64") >= 0 - ? "gcc-linaro-aarch64-linux-gnu-4.8-2013.11_linux+1.0" - : "gcc7.3.0-Fedora27+1.0"), - linux_arm: (input.profile != null && input.profile.indexOf("hflt") >= 0 - ? "gcc-linaro-arm-linux-gnueabihf-raspbian-2012.09-20120921_linux+1.0" - : (input.profile != null && input.profile.indexOf("arm32") >= 0 - ? "gcc7.3.0-Fedora27+1.0" - : "arm-linaro-4.7+1.0" - ) - ) + linux_aarch64: "gcc7.3.0-Fedora27+1.0", + linux_arm: "gcc7.3.0-Fedora27+1.0" }; var devkit_platform = (input.target_cpu == "x86" diff --git a/make/hotspot/lib/CompileJvm.gmk b/make/hotspot/lib/CompileJvm.gmk index a520621f3c2..01f4e6219c9 100644 --- a/make/hotspot/lib/CompileJvm.gmk +++ b/make/hotspot/lib/CompileJvm.gmk @@ -60,12 +60,6 @@ ifeq ($(OPENJDK_TARGET_CPU), x86_64) OPENJDK_TARGET_CPU_VM_VERSION := amd64 else ifeq ($(OPENJDK_TARGET_CPU), sparcv9) OPENJDK_TARGET_CPU_VM_VERSION := sparc -else ifeq ($(HOTSPOT_TARGET_CPU_ARCH), arm) - ifeq ($(OPENJDK_TARGET_CPU), aarch64) - # This sets the Oracle Aarch64 port to use arm64 - # while the original Aarch64 port uses aarch64 - OPENJDK_TARGET_CPU_VM_VERSION := arm64 - endif else OPENJDK_TARGET_CPU_VM_VERSION := $(OPENJDK_TARGET_CPU) endif diff --git a/src/hotspot/cpu/arm/abstractInterpreter_arm.cpp b/src/hotspot/cpu/arm/abstractInterpreter_arm.cpp index efc233a562e..8ff35363d78 100644 --- a/src/hotspot/cpu/arm/abstractInterpreter_arm.cpp +++ b/src/hotspot/cpu/arm/abstractInterpreter_arm.cpp @@ -38,19 +38,6 @@ int AbstractInterpreter::BasicType_as_index(BasicType type) { int i = 0; switch (type) { -#ifdef AARCH64 - case T_BOOLEAN: i = 0; break; - case T_CHAR : i = 1; break; - case T_BYTE : i = 2; break; - case T_SHORT : i = 3; break; - case T_INT : // fall through - case T_LONG : // fall through - case T_VOID : // fall through - case T_FLOAT : // fall through - case T_DOUBLE : i = 4; break; - case T_OBJECT : // fall through - case T_ARRAY : i = 5; break; -#else case T_VOID : i = 0; break; case T_BOOLEAN: i = 1; break; case T_CHAR : i = 2; break; @@ -62,7 +49,6 @@ int AbstractInterpreter::BasicType_as_index(BasicType type) { case T_LONG : i = 7; break; case T_FLOAT : i = 8; break; case T_DOUBLE : i = 9; break; -#endif // AARCH64 default : ShouldNotReachHere(); } assert(0 <= i && i < AbstractInterpreter::number_of_result_handlers, "index out of bounds"); @@ -71,7 +57,7 @@ int AbstractInterpreter::BasicType_as_index(BasicType type) { // How much stack a method activation needs in words. int AbstractInterpreter::size_top_interpreter_activation(Method* method) { - const int stub_code = AARCH64_ONLY(24) NOT_AARCH64(12); // see generate_call_stub + const int stub_code = 12; // see generate_call_stub // Save space for one monitor to get into the interpreted method in case // the method is synchronized int monitor_size = method->is_synchronized() ? @@ -108,9 +94,6 @@ int AbstractInterpreter::size_activation(int max_stack, (moncount*frame::interpreter_frame_monitor_size()) + tempcount*Interpreter::stackElementWords + extra_args; -#ifdef AARCH64 - size = align_up(size, StackAlignmentInBytes/BytesPerWord); -#endif // AARCH64 return size; } @@ -146,65 +129,7 @@ void AbstractInterpreter::layout_activation(Method* method, // interpreter_frame_sender_sp is the original sp of the caller (the unextended_sp) // and sender_sp is (fp + sender_sp_offset*wordSize) -#ifdef AARCH64 - intptr_t* locals; - if (caller->is_interpreted_frame()) { - // attach locals to the expression stack of caller interpreter frame - locals = caller->interpreter_frame_tos_address() + caller_actual_parameters*Interpreter::stackElementWords - 1; - } else { - assert (is_bottom_frame, "should be"); - locals = interpreter_frame->fp() + frame::sender_sp_offset + method->max_locals() - 1; - } - - if (TraceDeoptimization) { - tty->print_cr("layout_activation:"); - - if (caller->is_entry_frame()) { - tty->print("entry "); - } - if (caller->is_compiled_frame()) { - tty->print("compiled "); - } - if (caller->is_interpreted_frame()) { - tty->print("interpreted "); - } - tty->print_cr("caller: sp=%p, unextended_sp=%p, fp=%p, pc=%p", caller->sp(), caller->unextended_sp(), caller->fp(), caller->pc()); - tty->print_cr("interpreter_frame: sp=%p, unextended_sp=%p, fp=%p, pc=%p", interpreter_frame->sp(), interpreter_frame->unextended_sp(), interpreter_frame->fp(), interpreter_frame->pc()); - tty->print_cr("method: max_locals = %d, size_of_parameters = %d", method->max_locals(), method->size_of_parameters()); - tty->print_cr("caller_actual_parameters = %d", caller_actual_parameters); - tty->print_cr("locals = %p", locals); - } - -#ifdef ASSERT - if (caller_actual_parameters != method->size_of_parameters()) { - assert(caller->is_interpreted_frame(), "adjusted caller_actual_parameters, but caller is not interpreter frame"); - Bytecode_invoke inv(caller->interpreter_frame_method(), caller->interpreter_frame_bci()); - - if (is_bottom_frame) { - assert(caller_actual_parameters == 0, "invalid adjusted caller_actual_parameters value for bottom frame"); - assert(inv.is_invokedynamic() || inv.is_invokehandle(), "adjusted caller_actual_parameters for bottom frame, but not invokedynamic/invokehandle"); - } else { - assert(caller_actual_parameters == method->size_of_parameters()+1, "invalid adjusted caller_actual_parameters value"); - assert(!inv.is_invokedynamic() && MethodHandles::has_member_arg(inv.klass(), inv.name()), "adjusted caller_actual_parameters, but no member arg"); - } - } - if (caller->is_interpreted_frame()) { - intptr_t* locals_base = (locals - method->max_locals()*Interpreter::stackElementWords + 1); - locals_base = align_down(locals_base, StackAlignmentInBytes); - assert(interpreter_frame->sender_sp() <= locals_base, "interpreter-to-interpreter frame chaining"); - - } else if (caller->is_compiled_frame()) { - assert(locals + 1 <= caller->unextended_sp(), "compiled-to-interpreter frame chaining"); - - } else { - assert(caller->is_entry_frame(), "should be"); - assert(locals + 1 <= caller->fp(), "entry-to-interpreter frame chaining"); - } -#endif // ASSERT - -#else intptr_t* locals = interpreter_frame->sender_sp() + max_locals - 1; -#endif // AARCH64 interpreter_frame->interpreter_frame_set_locals(locals); BasicObjectLock* montop = interpreter_frame->interpreter_frame_monitor_begin(); @@ -215,44 +140,16 @@ void AbstractInterpreter::layout_activation(Method* method, intptr_t* stack_top = (intptr_t*) monbot - tempcount*Interpreter::stackElementWords - popframe_extra_args; -#ifdef AARCH64 - interpreter_frame->interpreter_frame_set_stack_top(stack_top); - - // We have to add extra reserved slots to max_stack. There are 3 users of the extra slots, - // none of which are at the same time, so we just need to make sure there is enough room - // for the biggest user: - // -reserved slot for exception handler - // -reserved slots for JSR292. Method::extra_stack_entries() is the size. - // -3 reserved slots so get_method_counters() can save some registers before call_VM(). - int max_stack = method->constMethod()->max_stack() + MAX2(3, Method::extra_stack_entries()); - intptr_t* extended_sp = (intptr_t*) monbot - - (max_stack * Interpreter::stackElementWords) - - popframe_extra_args; - extended_sp = align_down(extended_sp, StackAlignmentInBytes); - interpreter_frame->interpreter_frame_set_extended_sp(extended_sp); -#else interpreter_frame->interpreter_frame_set_last_sp(stack_top); -#endif // AARCH64 // All frames but the initial (oldest) interpreter frame we fill in have a // value for sender_sp that allows walking the stack but isn't // truly correct. Correct the value here. -#ifdef AARCH64 - if (caller->is_interpreted_frame()) { - intptr_t* sender_sp = align_down(caller->interpreter_frame_tos_address(), StackAlignmentInBytes); - interpreter_frame->set_interpreter_frame_sender_sp(sender_sp); - - } else { - // in case of non-interpreter caller sender_sp of the oldest frame is already - // set to valid value - } -#else if (extra_locals != 0 && interpreter_frame->sender_sp() == interpreter_frame->interpreter_frame_sender_sp() ) { interpreter_frame->set_interpreter_frame_sender_sp(caller->sp() + extra_locals); } -#endif // AARCH64 *interpreter_frame->interpreter_frame_cache_addr() = method->constants()->cache(); diff --git a/src/hotspot/cpu/arm/arm.ad b/src/hotspot/cpu/arm/arm.ad index c20e514999b..43d771ea050 100644 --- a/src/hotspot/cpu/arm/arm.ad +++ b/src/hotspot/cpu/arm/arm.ad @@ -67,15 +67,10 @@ static inline bool cache_reachable() { return MacroAssembler::_cache_fully_reachable(); } -#ifdef AARCH64 -#define ldr_32 ldr_w -#define str_32 str_w -#else #define ldr_32 ldr #define str_32 str #define tst_32 tst #define teq_32 teq -#endif #if 1 extern bool PrintOptoAssembly; #endif @@ -111,12 +106,7 @@ class HandlerImpl { static int emit_deopt_handler(CodeBuffer& cbuf); static uint size_exception_handler() { -#ifdef AARCH64 - // ldr_literal; br; (pad); - return 3 * Assembler::InstructionSize + wordSize; -#else return ( 3 * 4 ); -#endif } @@ -205,9 +195,6 @@ void emit_hi(CodeBuffer &cbuf, int val) { } const RegMask& MachConstantBaseNode::_out_RegMask = PTR_REG_mask(); int Compile::ConstantTable::calculate_table_base_offset() const { -#ifdef AARCH64 - return 0; -#else int offset = -(size() / 2); // flds, fldd: 8-bit offset multiplied by 4: +/- 1024 // ldr, ldrb : 12-bit offset: +/- 4096 @@ -215,7 +202,6 @@ int Compile::ConstantTable::calculate_table_base_offset() const { offset = Assembler::min_simm10(); } return offset; -#endif } bool MachConstantBaseNode::requires_postalloc_expand() const { return false; } @@ -240,11 +226,7 @@ void MachConstantBaseNode::emit(CodeBuffer& cbuf, PhaseRegAlloc* ra_) const { } uint MachConstantBaseNode::size(PhaseRegAlloc*) const { -#ifdef AARCH64 - return 5 * Assembler::InstructionSize; -#else return 8; -#endif } #ifndef PRODUCT @@ -262,12 +244,6 @@ void MachPrologNode::format( PhaseRegAlloc *ra_, outputStream *st ) const { for (int i = 0; i < OptoPrologueNops; i++) { st->print_cr("NOP"); st->print("\t"); } -#ifdef AARCH64 - if (OptoPrologueNops <= 0) { - st->print_cr("NOP\t! required for safe patching"); - st->print("\t"); - } -#endif size_t framesize = C->frame_size_in_bytes(); assert((framesize & (StackAlignmentInBytes-1)) == 0, "frame size not aligned"); @@ -298,11 +274,6 @@ void MachPrologNode::emit(CodeBuffer &cbuf, PhaseRegAlloc *ra_) const { for (int i = 0; i < OptoPrologueNops; i++) { __ nop(); } -#ifdef AARCH64 - if (OptoPrologueNops <= 0) { - __ nop(); // required for safe patching by patch_verified_entry() - } -#endif size_t framesize = C->frame_size_in_bytes(); assert((framesize & (StackAlignmentInBytes-1)) == 0, "frame size not aligned"); @@ -361,18 +332,8 @@ void MachEpilogNode::format( PhaseRegAlloc *ra_, outputStream *st ) const { if (do_polling() && ra_->C->is_method_compilation()) { st->print("\n\t"); -#ifdef AARCH64 - if (MacroAssembler::page_reachable_from_cache(os::get_polling_page())) { - st->print("ADRP Rtemp, #PollAddr\t! Load Polling address\n\t"); - st->print("LDR ZR,[Rtemp + #PollAddr & 0xfff]\t!Poll for Safepointing"); - } else { - st->print("mov_slow Rtemp, #PollAddr\t! Load Polling address\n\t"); - st->print("LDR ZR,[Rtemp]\t!Poll for Safepointing"); - } -#else st->print("MOV Rtemp, #PollAddr\t! Load Polling address\n\t"); st->print("LDR Rtemp,[Rtemp]\t!Poll for Safepointing"); -#endif } } #endif @@ -390,36 +351,15 @@ void MachEpilogNode::emit(CodeBuffer &cbuf, PhaseRegAlloc *ra_) const { // If this does safepoint polling, then do it here if (do_polling() && ra_->C->is_method_compilation()) { -#ifdef AARCH64 - if (false && MacroAssembler::page_reachable_from_cache(os::get_polling_page())) { -/* FIXME: TODO - __ relocate(relocInfo::xxx); - __ adrp(Rtemp, (intptr_t)os::get_polling_page()); - __ relocate(relocInfo::poll_return_type); - int offset = os::get_polling_page() & 0xfff; - __ ldr(ZR, Address(Rtemp + offset)); -*/ - } else { - __ mov_address(Rtemp, (address)os::get_polling_page(), symbolic_Relocation::polling_page_reference); - __ relocate(relocInfo::poll_return_type); - __ ldr(ZR, Address(Rtemp)); - } -#else // mov_slow here is usually one or two instruction __ mov_address(Rtemp, (address)os::get_polling_page(), symbolic_Relocation::polling_page_reference); __ relocate(relocInfo::poll_return_type); __ ldr(Rtemp, Address(Rtemp)); -#endif } } uint MachEpilogNode::size(PhaseRegAlloc *ra_) const { -#ifdef AARCH64 - // allow for added alignment nop from mov_address bind_literal - return MachNode::size(ra_) + 1 * Assembler::InstructionSize; -#else return MachNode::size(ra_); -#endif } int MachEpilogNode::reloc() const { @@ -451,16 +391,12 @@ static enum RC rc_class( OptoReg::Name reg ) { } static inline bool is_iRegLd_memhd(OptoReg::Name src_first, OptoReg::Name src_second, int offset) { -#ifdef AARCH64 - return is_memoryHD(offset); -#else int rlo = Matcher::_regEncode[src_first]; int rhi = Matcher::_regEncode[src_second]; if (!((rlo&1)==0 && (rlo+1 == rhi))) { tty->print_cr("CAUGHT BAD LDRD/STRD"); } return (rlo&1)==0 && (rlo+1 == rhi) && is_memoryHD(offset); -#endif } uint MachSpillCopyNode::implementation( CodeBuffer *cbuf, @@ -549,11 +485,6 @@ uint MachSpillCopyNode::implementation( CodeBuffer *cbuf, Matcher::regName[src_first]); #endif } -#ifdef AARCH64 - if (src_first+1 == src_second && dst_first+1 == dst_second) { - return size + 4; - } -#endif size += 4; } @@ -722,19 +653,11 @@ uint MachSpillCopyNode::implementation( CodeBuffer *cbuf, assert((src_first&1)==0 && src_first+1 == src_second, "pairs of registers must be aligned/contiguous"); assert(src_second_rc == rc_int && dst_second_rc == rc_float, "unsupported"); if (cbuf) { -#ifdef AARCH64 - __ fmov_dx(reg_to_FloatRegister_object(Matcher::_regEncode[dst_first]), reg_to_register_object(Matcher::_regEncode[src_first])); -#else __ fmdrr(reg_to_FloatRegister_object(Matcher::_regEncode[dst_first]), reg_to_register_object(Matcher::_regEncode[src_first]), reg_to_register_object(Matcher::_regEncode[src_second])); -#endif #ifndef PRODUCT } else if (!do_size) { if (size != 0) st->print("\n\t"); -#ifdef AARCH64 - st->print("FMOV_DX R_%s, R_%s\t! spill",OptoReg::regname(dst_first), OptoReg::regname(src_first)); -#else st->print("FMDRR R_%s, R_%s, R_%s\t! spill",OptoReg::regname(dst_first), OptoReg::regname(src_first), OptoReg::regname(src_second)); -#endif #endif } return size + 4; @@ -759,19 +682,11 @@ uint MachSpillCopyNode::implementation( CodeBuffer *cbuf, assert((dst_first&1)==0 && dst_first+1 == dst_second, "pairs of registers must be aligned/contiguous"); assert(src_second_rc == rc_float && dst_second_rc == rc_int, "unsupported"); if (cbuf) { -#ifdef AARCH64 - __ fmov_xd(reg_to_register_object(Matcher::_regEncode[dst_first]), reg_to_FloatRegister_object(Matcher::_regEncode[src_first])); -#else __ fmrrd(reg_to_register_object(Matcher::_regEncode[dst_first]), reg_to_register_object(Matcher::_regEncode[dst_second]), reg_to_FloatRegister_object(Matcher::_regEncode[src_first])); -#endif #ifndef PRODUCT } else if (!do_size) { if (size != 0) st->print("\n\t"); -#ifdef AARCH64 - st->print("FMOV_XD R_%s, R_%s\t! spill",OptoReg::regname(dst_first), OptoReg::regname(src_first)); -#else st->print("FMRRD R_%s, R_%s, R_%s\t! spill",OptoReg::regname(dst_first), OptoReg::regname(dst_second), OptoReg::regname(src_first)); -#endif #endif } return size + 4; @@ -795,7 +710,6 @@ uint MachSpillCopyNode::implementation( CodeBuffer *cbuf, return size; // Self copy; no move assert( src_second_rc != rc_bad && dst_second_rc != rc_bad, "src_second & dst_second cannot be Bad" ); -#ifndef AARCH64 // Check for integer reg-reg copy. Hi bits are stuck up in the top // 32-bits of a 64-bit register, but are needed in low bits of another // register (else it's a hi-bits-to-hi-bits copy which should have @@ -852,7 +766,6 @@ uint MachSpillCopyNode::implementation( CodeBuffer *cbuf, } return size + 4; } -#endif Unimplemented(); return 0; // Mute compiler @@ -910,11 +823,7 @@ void BoxLockNode::emit(CodeBuffer &cbuf, PhaseRegAlloc *ra_) const { __ add(dst, SP, offset); } else { __ mov_slow(dst, offset); -#ifdef AARCH64 - __ add(dst, SP, dst, ex_lsl); -#else __ add(dst, SP, dst); -#endif } } @@ -926,11 +835,7 @@ uint BoxLockNode::size(PhaseRegAlloc *ra_) const { //============================================================================= #ifndef PRODUCT -#ifdef AARCH64 -#define R_RTEMP "R_R16" -#else #define R_RTEMP "R_R12" -#endif void MachUEPNode::format( PhaseRegAlloc *ra_, outputStream *st ) const { st->print_cr("\nUEP:"); if (UseCompressedClassPointers) { @@ -952,14 +857,7 @@ void MachUEPNode::emit(CodeBuffer &cbuf, PhaseRegAlloc *ra_) const { __ load_klass(Rtemp, receiver); __ cmp(Rtemp, iCache); -#ifdef AARCH64 - Label match; - __ b(match, eq); - __ jump(SharedRuntime::get_ic_miss_stub(), relocInfo::runtime_call_type, Rtemp); - __ bind(match); -#else __ jump(SharedRuntime::get_ic_miss_stub(), relocInfo::runtime_call_type, noreg, ne); -#endif } uint MachUEPNode::size(PhaseRegAlloc *ra_) const { @@ -1005,24 +903,12 @@ int HandlerImpl::emit_deopt_handler(CodeBuffer& cbuf) { int offset = __ offset(); address deopt_pc = __ pc(); -#ifdef AARCH64 - // See LR saved by caller in sharedRuntime_arm.cpp - // see also hse1 ws - // see also LIR_Assembler::emit_deopt_handler - - __ raw_push(LR, LR); // preserve LR in both slots - __ mov_relative_address(LR, deopt_pc); - __ str(LR, Address(SP, 1 * wordSize)); // save deopt PC - // OK to kill LR, because deopt blob will restore it from SP[0] - __ jump(SharedRuntime::deopt_blob()->unpack(), relocInfo::runtime_call_type, LR_tmp); -#else __ sub(SP, SP, wordSize); // make room for saved PC __ push(LR); // save LR that may be live when we get here __ mov_relative_address(LR, deopt_pc); __ str(LR, Address(SP, wordSize)); // save deopt PC __ pop(LR); // restore LR __ jump(SharedRuntime::deopt_blob()->unpack(), relocInfo::runtime_call_type, noreg); -#endif assert(__ offset() - offset <= (int) size_deopt_handler(), "overflow"); @@ -1073,21 +959,13 @@ const bool Matcher::match_rule_supported(int opcode) { case Op_AddVF: case Op_SubVF: case Op_MulVF: -#ifdef AARCH64 - return VM_Version::has_simd(); -#else return VM_Version::has_vfp() || VM_Version::has_simd(); -#endif case Op_AddVD: case Op_SubVD: case Op_MulVD: case Op_DivVF: case Op_DivVD: -#ifdef AARCH64 - return VM_Version::has_simd(); -#else return VM_Version::has_vfp(); -#endif } return true; // Per default match rules are supported. @@ -1158,11 +1036,7 @@ const bool Matcher::pass_original_key_for_aes() { } const bool Matcher::convL2FSupported(void) { -#ifdef AARCH64 - return true; -#else return false; -#endif } // Is this branch offset short enough that a short branch can be used? @@ -1181,29 +1055,17 @@ bool Matcher::is_short_branch_offset(int rule, int br_size, int offset) { const bool Matcher::isSimpleConstant64(jlong value) { // Will one (StoreL ConL) be cheaper than two (StoreI ConI)?. -#ifdef AARCH64 - return (value == 0); -#else return false; -#endif } // No scaling for the parameter the ClearArray node. const bool Matcher::init_array_count_is_in_bytes = true; -#ifdef AARCH64 -const int Matcher::long_cmove_cost() { return 1; } -#else // Needs 2 CMOV's for longs. const int Matcher::long_cmove_cost() { return 2; } -#endif -#ifdef AARCH64 -const int Matcher::float_cmove_cost() { return 1; } -#else // CMOVF/CMOVD are expensive on ARM. const int Matcher::float_cmove_cost() { return ConditionalMoveLimit; } -#endif // Does the CPU require late expand (see block.cpp for description of late expand)? const bool Matcher::require_postalloc_expand = false; @@ -1211,11 +1073,7 @@ const bool Matcher::require_postalloc_expand = false; // Do we need to mask the count passed to shift instructions or does // the cpu only look at the lower 5/6 bits anyway? // FIXME: does this handle vector shifts as well? -#ifdef AARCH64 -const bool Matcher::need_masked_shift_count = false; -#else const bool Matcher::need_masked_shift_count = true; -#endif const bool Matcher::convi2l_type_required = true; @@ -1261,14 +1119,7 @@ const bool Matcher::rematerialize_float_constants = false; // needed. Else we split the double into 2 integer pieces and move it // piece-by-piece. Only happens when passing doubles into C code as the // Java calling convention forces doubles to be aligned. -#ifdef AARCH64 -// On stack replacement support: -// We don't need Load[DL]_unaligned support, because interpreter stack -// has correct alignment -const bool Matcher::misaligned_doubles_ok = true; -#else const bool Matcher::misaligned_doubles_ok = false; -#endif // No-op on ARM. void Matcher::pd_implicit_null_fixup(MachNode *node, uint idx) { @@ -1300,10 +1151,6 @@ const bool Matcher::int_in_long = false; // Registers not mentioned will be killed by the VM call in the trampoline, and // arguments in those registers not be available to the callee. bool Matcher::can_be_java_arg( int reg ) { -#ifdef AARCH64 - if (reg >= R_R0_num && reg < R_R8_num) return true; - if (reg >= R_V0_num && reg <= R_V7b_num && ((reg & 3) < 2)) return true; -#else if (reg == R_R0_num || reg == R_R1_num || reg == R_R2_num || @@ -1311,7 +1158,6 @@ bool Matcher::can_be_java_arg( int reg ) { if (reg >= R_S0_num && reg <= R_S13_num) return true; -#endif return false; } @@ -1454,44 +1300,14 @@ encode %{ Register R8_ic_reg = reg_to_register_object(Matcher::inline_cache_reg_encode()); assert(R8_ic_reg == Ricklass, "should be"); __ set_inst_mark(); -#ifdef AARCH64 -// TODO: see C1 LIR_Assembler::ic_call() - InlinedAddress oop_literal((address)Universe::non_oop_word()); - int offset = __ offset(); - int fixed_size = mov_oop_size * 4; - if (VM_Version::prefer_moves_over_load_literal()) { - uintptr_t val = (uintptr_t)Universe::non_oop_word(); - __ movz(R8_ic_reg, (val >> 0) & 0xffff, 0); - __ movk(R8_ic_reg, (val >> 16) & 0xffff, 16); - __ movk(R8_ic_reg, (val >> 32) & 0xffff, 32); - __ movk(R8_ic_reg, (val >> 48) & 0xffff, 48); - } else { - __ ldr_literal(R8_ic_reg, oop_literal); - } - assert(__ offset() - offset == fixed_size, "bad mov_oop size"); -#else __ movw(R8_ic_reg, ((unsigned int)Universe::non_oop_word()) & 0xffff); __ movt(R8_ic_reg, ((unsigned int)Universe::non_oop_word()) >> 16); -#endif address virtual_call_oop_addr = __ inst_mark(); // CALL to fixup routine. Fixup routine uses ScopeDesc info to determine // who we intended to call. int method_index = resolved_method_index(cbuf); __ relocate(virtual_call_Relocation::spec(virtual_call_oop_addr, method_index)); emit_call_reloc(cbuf, as_MachCall(), $meth, RelocationHolder::none); -#ifdef AARCH64 - if (!VM_Version::prefer_moves_over_load_literal()) { - Label skip_literal; - __ b(skip_literal); - int off2 = __ offset(); - __ bind_literal(oop_literal); - if (__ offset() - off2 == wordSize) { - // no padding, so insert nop for worst-case sizing - __ nop(); - } - __ bind(skip_literal); - } -#endif %} enc_class LdReplImmI(immI src, regD dst, iRegI tmp, int cnt, int wth) %{ @@ -1558,16 +1374,8 @@ encode %{ // See if the lengths are different, and calculate min in str1_reg. // Stash diff in tmp2 in case we need it for a tie-breaker. __ subs_32(tmp2_reg, cnt1_reg, cnt2_reg); -#ifdef AARCH64 - Label Lskip; - __ _lsl_w(cnt1_reg, cnt1_reg, exact_log2(sizeof(jchar))); // scale the limit - __ b(Lskip, mi); - __ _lsl_w(cnt1_reg, cnt2_reg, exact_log2(sizeof(jchar))); // scale the limit - __ bind(Lskip); -#else __ mov(cnt1_reg, AsmOperand(cnt1_reg, lsl, exact_log2(sizeof(jchar)))); // scale the limit __ mov(cnt1_reg, AsmOperand(cnt2_reg, lsl, exact_log2(sizeof(jchar))), pl); // scale the limit -#endif // reallocate cnt1_reg, cnt2_reg, result_reg // Note: limit_reg holds the string length pre-scaled by 2 @@ -1717,16 +1525,6 @@ encode %{ int base_offset = arrayOopDesc::base_offset_in_bytes(T_CHAR); // return true if the same array -#ifdef AARCH64 - __ cmp(ary1_reg, ary2_reg); - __ b(Lequal, eq); - - __ mov(result_reg, 0); - - __ cbz(ary1_reg, Ldone); // not equal - - __ cbz(ary2_reg, Ldone); // not equal -#else __ teq(ary1_reg, ary2_reg); __ mov(result_reg, 1, eq); __ b(Ldone, eq); // equal @@ -1738,19 +1536,12 @@ encode %{ __ tst(ary2_reg, ary2_reg); __ mov(result_reg, 0, eq); __ b(Ldone, eq); // not equal -#endif //load the lengths of arrays __ ldr_s32(tmp1_reg, Address(ary1_reg, length_offset)); // int __ ldr_s32(tmp2_reg, Address(ary2_reg, length_offset)); // int // return false if the two arrays are not equal length -#ifdef AARCH64 - __ cmp_w(tmp1_reg, tmp2_reg); - __ b(Ldone, ne); // not equal - - __ cbz_w(tmp1_reg, Lequal); // zero-length arrays are equal -#else __ teq_32(tmp1_reg, tmp2_reg); __ mov(result_reg, 0, ne); __ b(Ldone, ne); // not equal @@ -1758,7 +1549,6 @@ encode %{ __ tst(tmp1_reg, tmp1_reg); __ mov(result_reg, 1, eq); __ b(Ldone, eq); // zero-length arrays are equal -#endif // load array addresses __ add(ary1_reg, ary1_reg, base_offset); @@ -1852,11 +1642,7 @@ frame %{ sync_stack_slots(1 * VMRegImpl::slots_per_word); // Compiled code's Frame Pointer -#ifdef AARCH64 - frame_pointer(R_SP); -#else frame_pointer(R_R13); -#endif // Stack alignment requirement stack_alignment(StackAlignmentInBytes); @@ -1953,7 +1739,6 @@ operand immI16() %{ interface(CONST_INTER); %} -#ifndef AARCH64 // Integer Immediate: offset for half and double word loads and stores operand immIHD() %{ predicate(is_memoryHD(n->get_int())); @@ -1972,7 +1757,6 @@ operand immIFP() %{ format %{ %} interface(CONST_INTER); %} -#endif // Valid scale values for addressing modes and shifts operand immU5() %{ @@ -2183,45 +1967,6 @@ operand limmIn() %{ interface(CONST_INTER); %} -#ifdef AARCH64 -// Long Immediate: for logical instruction -operand limmL() %{ - predicate(is_limmL(n->get_long())); - match(ConL); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -operand limmLn() %{ - predicate(is_limmL(~n->get_long())); - match(ConL); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -// Long Immediate: for arithmetic instruction -operand aimmL() %{ - predicate(is_aimm(n->get_long())); - match(ConL); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -operand aimmLneg() %{ - predicate(is_aimm(-n->get_long())); - match(ConL); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} -#endif // AARCH64 // Long Immediate: the value FF operand immL_FF() %{ @@ -2404,11 +2149,7 @@ operand iRegI() %{ match(R1RegI); match(R2RegI); match(R3RegI); -#ifdef AARCH64 - match(ZRRegI); -#else match(R12RegI); -#endif format %{ %} interface(REG_INTER); @@ -2446,49 +2187,6 @@ operand sp_ptr_RegP() %{ interface(REG_INTER); %} -#ifdef AARCH64 -// Like sp_ptr_reg, but exclude regs (Aarch64 SP) that can't be -// stored directly. Includes ZR, so can't be used as a destination. -operand store_ptr_RegP() %{ - constraint(ALLOC_IN_RC(store_ptr_reg)); - match(RegP); - match(iRegP); - match(ZRRegP); - - format %{ %} - interface(REG_INTER); -%} - -operand store_RegI() %{ - constraint(ALLOC_IN_RC(store_reg)); - match(RegI); - match(iRegI); - match(ZRRegI); - - format %{ %} - interface(REG_INTER); -%} - -operand store_RegL() %{ - constraint(ALLOC_IN_RC(store_ptr_reg)); - match(RegL); - match(iRegL); - match(ZRRegL); - - format %{ %} - interface(REG_INTER); -%} - -operand store_RegN() %{ - constraint(ALLOC_IN_RC(store_reg)); - match(RegN); - match(iRegN); - match(ZRRegN); - - format %{ %} - interface(REG_INTER); -%} -#endif operand R0RegP() %{ constraint(ALLOC_IN_RC(R0_regP)); @@ -2578,7 +2276,6 @@ operand R3RegI() %{ interface(REG_INTER); %} -#ifndef AARCH64 operand R12RegI() %{ constraint(ALLOC_IN_RC(R12_regI)); match(iRegI); @@ -2586,18 +2283,13 @@ operand R12RegI() %{ format %{ %} interface(REG_INTER); %} -#endif // Long Register operand iRegL() %{ constraint(ALLOC_IN_RC(long_reg)); match(RegL); -#ifdef AARCH64 - match(iRegLd); -#else match(R0R1RegL); match(R2R3RegL); -#endif //match(iRegLex); format %{ %} @@ -2612,7 +2304,6 @@ operand iRegLd() %{ interface(REG_INTER); %} -#ifndef AARCH64 // first long arg, or return value operand R0R1RegL() %{ constraint(ALLOC_IN_RC(R0R1_regL)); @@ -2629,7 +2320,6 @@ operand R2R3RegL() %{ format %{ %} interface(REG_INTER); %} -#endif // Condition Code Flag Register operand flagsReg() %{ @@ -2671,7 +2361,6 @@ operand flagsRegP() %{ %} // Condition Code Register, long comparisons. -#ifndef AARCH64 operand flagsRegL_LTGE() %{ constraint(ALLOC_IN_RC(int_flags)); match(RegFlags); @@ -2719,7 +2408,6 @@ operand flagsRegUL_LEGT() %{ format %{ "apsr_UL_LEGT" %} interface(REG_INTER); %} -#endif // Condition Code Register, floating comparisons, unordered same as "less". operand flagsRegF() %{ @@ -2800,113 +2488,12 @@ operand indirect(sp_ptr_RegP reg) %{ format %{ "[$reg]" %} interface(MEMORY_INTER) %{ base($reg); -#ifdef AARCH64 - index(0xff); // 0xff => no index -#else index(0xf); // PC => no index -#endif scale(0x0); disp(0x0); %} %} -#ifdef AARCH64 -// Indirect with scaled*1 uimm12 offset -operand indOffsetU12ScaleB(sp_ptr_RegP reg, immUL12 offset) %{ - constraint(ALLOC_IN_RC(sp_ptr_reg)); - match(AddP reg offset); - - op_cost(100); - format %{ "[$reg + $offset]" %} - interface(MEMORY_INTER) %{ - base($reg); -#ifdef AARCH64 - index(0xff); // 0xff => no index -#else - index(0xf); // PC => no index -#endif - scale(0x0); - disp($offset); - %} -%} - -// Indirect with scaled*2 uimm12 offset -operand indOffsetU12ScaleS(sp_ptr_RegP reg, immUL12x2 offset) %{ - constraint(ALLOC_IN_RC(sp_ptr_reg)); - match(AddP reg offset); - - op_cost(100); - format %{ "[$reg + $offset]" %} - interface(MEMORY_INTER) %{ - base($reg); -#ifdef AARCH64 - index(0xff); // 0xff => no index -#else - index(0xf); // PC => no index -#endif - scale(0x0); - disp($offset); - %} -%} - -// Indirect with scaled*4 uimm12 offset -operand indOffsetU12ScaleI(sp_ptr_RegP reg, immUL12x4 offset) %{ - constraint(ALLOC_IN_RC(sp_ptr_reg)); - match(AddP reg offset); - - op_cost(100); - format %{ "[$reg + $offset]" %} - interface(MEMORY_INTER) %{ - base($reg); -#ifdef AARCH64 - index(0xff); // 0xff => no index -#else - index(0xf); // PC => no index -#endif - scale(0x0); - disp($offset); - %} -%} - -// Indirect with scaled*8 uimm12 offset -operand indOffsetU12ScaleL(sp_ptr_RegP reg, immUL12x8 offset) %{ - constraint(ALLOC_IN_RC(sp_ptr_reg)); - match(AddP reg offset); - - op_cost(100); - format %{ "[$reg + $offset]" %} - interface(MEMORY_INTER) %{ - base($reg); -#ifdef AARCH64 - index(0xff); // 0xff => no index -#else - index(0xf); // PC => no index -#endif - scale(0x0); - disp($offset); - %} -%} - -// Indirect with scaled*16 uimm12 offset -operand indOffsetU12ScaleQ(sp_ptr_RegP reg, immUL12x16 offset) %{ - constraint(ALLOC_IN_RC(sp_ptr_reg)); - match(AddP reg offset); - - op_cost(100); - format %{ "[$reg + $offset]" %} - interface(MEMORY_INTER) %{ - base($reg); -#ifdef AARCH64 - index(0xff); // 0xff => no index -#else - index(0xf); // PC => no index -#endif - scale(0x0); - disp($offset); - %} -%} - -#else // ! AARCH64 // Indirect with Offset in ]-4096, 4096[ operand indOffset12(sp_ptr_RegP reg, immI12 offset) %{ @@ -2917,11 +2504,7 @@ operand indOffset12(sp_ptr_RegP reg, immI12 offset) %{ format %{ "[$reg + $offset]" %} interface(MEMORY_INTER) %{ base($reg); -#ifdef AARCH64 - index(0xff); // 0xff => no index -#else index(0xf); // PC => no index -#endif scale(0x0); disp($offset); %} @@ -2936,11 +2519,7 @@ operand indOffsetFP(sp_ptr_RegP reg, immIFP offset) %{ format %{ "[$reg + $offset]" %} interface(MEMORY_INTER) %{ base($reg); -#ifdef AARCH64 - index(0xff); // 0xff => no index -#else index(0xf); // PC => no index -#endif scale(0x0); disp($offset); %} @@ -2955,11 +2534,7 @@ operand indOffsetHD(sp_ptr_RegP reg, immIHD offset) %{ format %{ "[$reg + $offset]" %} interface(MEMORY_INTER) %{ base($reg); -#ifdef AARCH64 - index(0xff); // 0xff => no index -#else index(0xf); // PC => no index -#endif scale(0x0); disp($offset); %} @@ -2974,11 +2549,7 @@ operand indOffsetFPx2(sp_ptr_RegP reg, immX10x2 offset) %{ format %{ "[$reg + $offset]" %} interface(MEMORY_INTER) %{ base($reg); -#ifdef AARCH64 - index(0xff); // 0xff => no index -#else index(0xf); // PC => no index -#endif scale(0x0); disp($offset); %} @@ -2993,16 +2564,11 @@ operand indOffset12x2(sp_ptr_RegP reg, immI12x2 offset) %{ format %{ "[$reg + $offset]" %} interface(MEMORY_INTER) %{ base($reg); -#ifdef AARCH64 - index(0xff); // 0xff => no index -#else index(0xf); // PC => no index -#endif scale(0x0); disp($offset); %} %} -#endif // !AARCH64 // Indirect with Register Index operand indIndex(iRegP addr, iRegX index) %{ @@ -3019,127 +2585,6 @@ operand indIndex(iRegP addr, iRegX index) %{ %} %} -#ifdef AARCH64 -// Indirect Memory Times Scale Plus Index Register -operand indIndexScaleS(iRegP addr, iRegX index, immI_1 scale) %{ - constraint(ALLOC_IN_RC(ptr_reg)); - match(AddP addr (LShiftX index scale)); - - op_cost(100); - format %{"[$addr + $index << $scale]" %} - interface(MEMORY_INTER) %{ - base($addr); - index($index); - scale($scale); - disp(0x0); - %} -%} - -// Indirect Memory Times Scale Plus 32-bit Index Register -operand indIndexIScaleS(iRegP addr, iRegI index, immI_1 scale) %{ - constraint(ALLOC_IN_RC(ptr_reg)); - match(AddP addr (LShiftX (ConvI2L index) scale)); - - op_cost(100); - format %{"[$addr + $index.w << $scale]" %} - interface(MEMORY_INTER) %{ - base($addr); - index($index); - scale($scale); - disp(0x7fffffff); // sxtw - %} -%} - -// Indirect Memory Times Scale Plus Index Register -operand indIndexScaleI(iRegP addr, iRegX index, immI_2 scale) %{ - constraint(ALLOC_IN_RC(ptr_reg)); - match(AddP addr (LShiftX index scale)); - - op_cost(100); - format %{"[$addr + $index << $scale]" %} - interface(MEMORY_INTER) %{ - base($addr); - index($index); - scale($scale); - disp(0x0); - %} -%} - -// Indirect Memory Times Scale Plus 32-bit Index Register -operand indIndexIScaleI(iRegP addr, iRegI index, immI_2 scale) %{ - constraint(ALLOC_IN_RC(ptr_reg)); - match(AddP addr (LShiftX (ConvI2L index) scale)); - - op_cost(100); - format %{"[$addr + $index.w << $scale]" %} - interface(MEMORY_INTER) %{ - base($addr); - index($index); - scale($scale); - disp(0x7fffffff); // sxtw - %} -%} - -// Indirect Memory Times Scale Plus Index Register -operand indIndexScaleL(iRegP addr, iRegX index, immI_3 scale) %{ - constraint(ALLOC_IN_RC(ptr_reg)); - match(AddP addr (LShiftX index scale)); - - op_cost(100); - format %{"[$addr + $index << $scale]" %} - interface(MEMORY_INTER) %{ - base($addr); - index($index); - scale($scale); - disp(0x0); - %} -%} - -// Indirect Memory Times Scale Plus 32-bit Index Register -operand indIndexIScaleL(iRegP addr, iRegI index, immI_3 scale) %{ - constraint(ALLOC_IN_RC(ptr_reg)); - match(AddP addr (LShiftX (ConvI2L index) scale)); - - op_cost(100); - format %{"[$addr + $index.w << $scale]" %} - interface(MEMORY_INTER) %{ - base($addr); - index($index); - scale($scale); - disp(0x7fffffff); // sxtw - %} -%} - -// Indirect Memory Times Scale Plus Index Register -operand indIndexScaleQ(iRegP addr, iRegX index, immI_4 scale) %{ - constraint(ALLOC_IN_RC(ptr_reg)); - match(AddP addr (LShiftX index scale)); - - op_cost(100); - format %{"[$addr + $index << $scale]" %} - interface(MEMORY_INTER) %{ - base($addr); - index($index); - scale($scale); - disp(0x0); - %} -%} - -// Indirect Memory Times Scale Plus 32-bit Index Register -operand indIndexIScaleQ(iRegP addr, iRegI index, immI_4 scale) %{ - constraint(ALLOC_IN_RC(ptr_reg)); - match(AddP addr (LShiftX (ConvI2L index) scale)); - - op_cost(100); - format %{"[$addr + $index.w << $scale]" %} - interface(MEMORY_INTER) %{ - base($addr); - index($index); - scale($scale); - disp(0x7fffffff); // sxtw - %} -%} -#else // Indirect Memory Times Scale Plus Index Register operand indIndexScale(iRegP addr, iRegX index, immU5 scale) %{ constraint(ALLOC_IN_RC(ptr_reg)); @@ -3154,7 +2599,6 @@ operand indIndexScale(iRegP addr, iRegX index, immU5 scale) %{ disp(0x0); %} %} -#endif // Operands for expressing Control Flow // NOTE: Label is a predefined operand which should not be redefined in @@ -3312,29 +2756,6 @@ operand cmpOpUL_commute() %{ // instructions for every form of operand when the instruction accepts // multiple operand types with the same basic encoding and format. The classic // case of this is memory operands. -#ifdef AARCH64 -opclass memoryB(indirect, indIndex, indOffsetU12ScaleB); -opclass memoryS(indirect, indIndex, indIndexScaleS, indIndexIScaleS, indOffsetU12ScaleS); -opclass memoryI(indirect, indIndex, indIndexScaleI, indIndexIScaleI, indOffsetU12ScaleI); -opclass memoryL(indirect, indIndex, indIndexScaleL, indIndexIScaleL, indOffsetU12ScaleL); -opclass memoryP(indirect, indIndex, indIndexScaleL, indIndexIScaleL, indOffsetU12ScaleL); -opclass memoryQ(indirect, indIndex, indIndexScaleQ, indIndexIScaleQ, indOffsetU12ScaleQ); -opclass memoryF(indirect, indIndex, indIndexScaleI, indIndexIScaleI, indOffsetU12ScaleI); -opclass memoryD(indirect, indIndex, indIndexScaleL, indIndexIScaleL, indOffsetU12ScaleL); - -opclass memoryScaledS(indIndexScaleS, indIndexIScaleS); -opclass memoryScaledI(indIndexScaleI, indIndexIScaleI); -opclass memoryScaledL(indIndexScaleL, indIndexIScaleL); -opclass memoryScaledP(indIndexScaleL, indIndexIScaleL); -opclass memoryScaledQ(indIndexScaleQ, indIndexIScaleQ); -opclass memoryScaledF(indIndexScaleI, indIndexIScaleI); -opclass memoryScaledD(indIndexScaleL, indIndexIScaleL); -// when ldrex/strex is used: -opclass memoryex ( indirect ); -opclass indIndexMemory( indIndex ); -opclass memoryvld ( indirect /* , write back mode not implemented */ ); - -#else opclass memoryI ( indirect, indOffset12, indIndex, indIndexScale ); opclass memoryP ( indirect, indOffset12, indIndex, indIndexScale ); @@ -3354,7 +2775,6 @@ opclass memoryex ( indirect ); opclass indIndexMemory( indIndex ); opclass memorylong ( indirect, indOffset12x2 ); opclass memoryvld ( indirect /* , write back mode not implemented */ ); -#endif //----------PIPELINE----------------------------------------------------------- pipeline %{ @@ -4163,7 +3583,6 @@ instruct loadB(iRegI dst, memoryB mem) %{ size(4); format %{ "LDRSB $dst,$mem\t! byte -> int" %} ins_encode %{ - // High 32 bits are harmlessly set on Aarch64 __ ldrsb($dst$$Register, $mem$$Address); %} ins_pipe(iload_mask_mem); @@ -4174,13 +3593,6 @@ instruct loadB2L(iRegL dst, memoryB mem) %{ match(Set dst (ConvI2L (LoadB mem))); ins_cost(MEMORY_REF_COST); -#ifdef AARCH64 - size(4); - format %{ "LDRSB $dst,$mem\t! byte -> long" %} - ins_encode %{ - __ ldrsb($dst$$Register, $mem$$Address); - %} -#else size(8); format %{ "LDRSB $dst.lo,$mem\t! byte -> long\n\t" "ASR $dst.hi,$dst.lo,31" %} @@ -4188,7 +3600,6 @@ instruct loadB2L(iRegL dst, memoryB mem) %{ __ ldrsb($dst$$Register, $mem$$Address); __ mov($dst$$Register->successor(), AsmOperand($dst$$Register, asr, 31)); %} -#endif ins_pipe(iload_mask_mem); %} @@ -4210,13 +3621,6 @@ instruct loadUB2L(iRegL dst, memoryB mem) %{ match(Set dst (ConvI2L (LoadUB mem))); ins_cost(MEMORY_REF_COST); -#ifdef AARCH64 - size(4); - format %{ "LDRB $dst,$mem\t! ubyte -> long" %} - ins_encode %{ - __ ldrb($dst$$Register, $mem$$Address); - %} -#else size(8); format %{ "LDRB $dst.lo,$mem\t! ubyte -> long\n\t" "MOV $dst.hi,0" %} @@ -4224,7 +3628,6 @@ instruct loadUB2L(iRegL dst, memoryB mem) %{ __ ldrb($dst$$Register, $mem$$Address); __ mov($dst$$Register->successor(), 0); %} -#endif ins_pipe(iload_mem); %} @@ -4232,16 +3635,6 @@ instruct loadUB2L(iRegL dst, memoryB mem) %{ instruct loadUB2L_limmI(iRegL dst, memoryB mem, limmIlow8 mask) %{ match(Set dst (ConvI2L (AndI (LoadUB mem) mask))); -#ifdef AARCH64 - ins_cost(MEMORY_REF_COST + DEFAULT_COST); - size(8); - format %{ "LDRB $dst,$mem\t! ubyte -> long\n\t" - "AND $dst,$dst,$mask" %} - ins_encode %{ - __ ldrb($dst$$Register, $mem$$Address); - __ andr($dst$$Register, $dst$$Register, limmI_low($mask$$constant, 8)); - %} -#else ins_cost(MEMORY_REF_COST + 2*DEFAULT_COST); size(12); format %{ "LDRB $dst.lo,$mem\t! ubyte -> long\n\t" @@ -4252,29 +3645,10 @@ instruct loadUB2L_limmI(iRegL dst, memoryB mem, limmIlow8 mask) %{ __ mov($dst$$Register->successor(), 0); __ andr($dst$$Register, $dst$$Register, limmI_low($mask$$constant, 8)); %} -#endif ins_pipe(iload_mem); %} // Load Short (16bit signed) -#ifdef AARCH64 -// XXX This variant shouldn't be necessary if 6217251 is implemented -instruct loadSoff(iRegI dst, memoryScaledS mem, aimmX off, iRegP tmp) %{ - match(Set dst (LoadS (AddP mem off))); - ins_cost(MEMORY_REF_COST + DEFAULT_COST); // assume shift/sign-extend is free - effect(TEMP tmp); - size(4 * 2); - - format %{ "LDRSH $dst,$mem+$off\t! short temp=$tmp" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - __ add($tmp$$Register, base, $off$$constant); - Address nmem = Address::make_raw($tmp$$reg, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none); - __ ldrsh($dst$$Register, nmem); - %} - ins_pipe(iload_mask_mem); -%} -#endif instruct loadS(iRegI dst, memoryS mem) %{ match(Set dst (LoadS mem)); @@ -4297,7 +3671,6 @@ instruct loadS2B(iRegI dst, memoryS mem, immI_24 twentyfour) %{ format %{ "LDRSB $dst,$mem\t! short -> byte" %} ins_encode %{ - // High 32 bits are harmlessly set on Aarch64 __ ldrsb($dst$$Register, $mem$$Address); %} ins_pipe(iload_mask_mem); @@ -4308,13 +3681,6 @@ instruct loadS2L(iRegL dst, memoryS mem) %{ match(Set dst (ConvI2L (LoadS mem))); ins_cost(MEMORY_REF_COST); -#ifdef AARCH64 - size(4); - format %{ "LDRSH $dst,$mem\t! short -> long" %} - ins_encode %{ - __ ldrsh($dst$$Register, $mem$$Address); - %} -#else size(8); format %{ "LDRSH $dst.lo,$mem\t! short -> long\n\t" "ASR $dst.hi,$dst.lo,31" %} @@ -4322,30 +3688,11 @@ instruct loadS2L(iRegL dst, memoryS mem) %{ __ ldrsh($dst$$Register, $mem$$Address); __ mov($dst$$Register->successor(), AsmOperand($dst$$Register, asr, 31)); %} -#endif ins_pipe(iload_mask_mem); %} // Load Unsigned Short/Char (16bit UNsigned) -#ifdef AARCH64 -// XXX This variant shouldn't be necessary if 6217251 is implemented -instruct loadUSoff(iRegI dst, memoryScaledS mem, aimmX off, iRegP tmp) %{ - match(Set dst (LoadUS (AddP mem off))); - ins_cost(MEMORY_REF_COST + DEFAULT_COST); // assume shift/sign-extend is free - effect(TEMP tmp); - size(4 * 2); - - format %{ "LDRH $dst,$mem+$off\t! ushort/char temp=$tmp" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - __ add($tmp$$Register, base, $off$$constant); - Address nmem = Address::make_raw($tmp$$reg, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none); - __ ldrh($dst$$Register, nmem); - %} - ins_pipe(iload_mem); -%} -#endif instruct loadUS(iRegI dst, memoryS mem) %{ match(Set dst (LoadUS mem)); @@ -4377,13 +3724,6 @@ instruct loadUS2L(iRegL dst, memoryS mem) %{ match(Set dst (ConvI2L (LoadUS mem))); ins_cost(MEMORY_REF_COST); -#ifdef AARCH64 - size(4); - format %{ "LDRH $dst,$mem\t! short -> long" %} - ins_encode %{ - __ ldrh($dst$$Register, $mem$$Address); - %} -#else size(8); format %{ "LDRH $dst.lo,$mem\t! short -> long\n\t" "MOV $dst.hi, 0" %} @@ -4391,7 +3731,6 @@ instruct loadUS2L(iRegL dst, memoryS mem) %{ __ ldrh($dst$$Register, $mem$$Address); __ mov($dst$$Register->successor(), 0); %} -#endif ins_pipe(iload_mem); %} @@ -4400,13 +3739,6 @@ instruct loadUS2L_immI_255(iRegL dst, memoryB mem, immI_255 mask) %{ match(Set dst (ConvI2L (AndI (LoadUS mem) mask))); ins_cost(MEMORY_REF_COST); -#ifdef AARCH64 - size(4); - format %{ "LDRB $dst,$mem" %} - ins_encode %{ - __ ldrb($dst$$Register, $mem$$Address); - %} -#else size(8); format %{ "LDRB $dst.lo,$mem\t! \n\t" "MOV $dst.hi, 0" %} @@ -4414,24 +3746,12 @@ instruct loadUS2L_immI_255(iRegL dst, memoryB mem, immI_255 mask) %{ __ ldrb($dst$$Register, $mem$$Address); __ mov($dst$$Register->successor(), 0); %} -#endif ins_pipe(iload_mem); %} // Load Unsigned Short/Char (16bit UNsigned) with a immediate mask into a Long Register instruct loadUS2L_limmI(iRegL dst, memoryS mem, limmI mask) %{ match(Set dst (ConvI2L (AndI (LoadUS mem) mask))); -#ifdef AARCH64 - ins_cost(MEMORY_REF_COST + 1*DEFAULT_COST); - - size(8); - format %{ "LDRH $dst,$mem\t! ushort/char & mask -> long\n\t" - "AND $dst,$dst,$mask" %} - ins_encode %{ - __ ldrh($dst$$Register, $mem$$Address); - __ andr($dst$$Register, $dst$$Register, (uintx)$mask$$constant); - %} -#else ins_cost(MEMORY_REF_COST + 2*DEFAULT_COST); size(12); @@ -4443,30 +3763,11 @@ instruct loadUS2L_limmI(iRegL dst, memoryS mem, limmI mask) %{ __ mov($dst$$Register->successor(), 0); __ andr($dst$$Register, $dst$$Register, $mask$$constant); %} -#endif ins_pipe(iload_mem); %} // Load Integer -#ifdef AARCH64 -// XXX This variant shouldn't be necessary if 6217251 is implemented -instruct loadIoff(iRegI dst, memoryScaledI mem, aimmX off, iRegP tmp) %{ - match(Set dst (LoadI (AddP mem off))); - ins_cost(MEMORY_REF_COST + DEFAULT_COST); // assume shift/sign-extend is free - effect(TEMP tmp); - size(4 * 2); - - format %{ "ldr_s32 $dst,$mem+$off\t! int temp=$tmp" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - __ add($tmp$$Register, base, $off$$constant); - Address nmem = Address::make_raw($tmp$$reg, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none); - __ ldr_s32($dst$$Register, nmem); - %} - ins_pipe(iload_mem); -%} -#endif instruct loadI(iRegI dst, memoryI mem) %{ match(Set dst (LoadI mem)); @@ -4537,15 +3838,6 @@ instruct loadI2US(iRegI dst, memoryS mem, immI_65535 mask) %{ // Load Integer into a Long Register instruct loadI2L(iRegL dst, memoryI mem) %{ match(Set dst (ConvI2L (LoadI mem))); -#ifdef AARCH64 - ins_cost(MEMORY_REF_COST); - - size(4); - format %{ "LDRSW $dst.lo,$mem\t! int -> long" %} - ins_encode %{ - __ ldr_s32($dst$$Register, $mem$$Address); - %} -#else ins_cost(MEMORY_REF_COST); size(8); @@ -4555,22 +3847,12 @@ instruct loadI2L(iRegL dst, memoryI mem) %{ __ ldr($dst$$Register, $mem$$Address); __ mov($dst$$Register->successor(), AsmOperand($dst$$Register, asr, 31)); %} -#endif ins_pipe(iload_mask_mem); %} // Load Integer with mask 0xFF into a Long Register instruct loadI2L_immI_255(iRegL dst, memoryB mem, immI_255 mask) %{ match(Set dst (ConvI2L (AndI (LoadI mem) mask))); -#ifdef AARCH64 - ins_cost(MEMORY_REF_COST); - - size(4); - format %{ "LDRB $dst.lo,$mem\t! int & 0xFF -> long" %} - ins_encode %{ - __ ldrb($dst$$Register, $mem$$Address); - %} -#else ins_cost(MEMORY_REF_COST); size(8); @@ -4580,7 +3862,6 @@ instruct loadI2L_immI_255(iRegL dst, memoryB mem, immI_255 mask) %{ __ ldrb($dst$$Register, $mem$$Address); __ mov($dst$$Register->successor(), 0); %} -#endif ins_pipe(iload_mem); %} @@ -4589,13 +3870,6 @@ instruct loadI2L_immI_65535(iRegL dst, memoryS mem, immI_65535 mask) %{ match(Set dst (ConvI2L (AndI (LoadI mem) mask))); ins_cost(MEMORY_REF_COST); -#ifdef AARCH64 - size(4); - format %{ "LDRH $dst,$mem\t! int & 0xFFFF -> long" %} - ins_encode %{ - __ ldrh($dst$$Register, $mem$$Address); - %} -#else size(8); format %{ "LDRH $dst,$mem\t! int & 0xFFFF -> long\n\t" "MOV $dst.hi, 0" %} @@ -4603,27 +3877,9 @@ instruct loadI2L_immI_65535(iRegL dst, memoryS mem, immI_65535 mask) %{ __ ldrh($dst$$Register, $mem$$Address); __ mov($dst$$Register->successor(), 0); %} -#endif ins_pipe(iload_mask_mem); %} -#ifdef AARCH64 -// Load Integer with an immediate mask into a Long Register -instruct loadI2L_limmI(iRegL dst, memoryI mem, limmI mask) %{ - match(Set dst (ConvI2L (AndI (LoadI mem) mask))); - ins_cost(MEMORY_REF_COST + 1*DEFAULT_COST); - - size(8); - format %{ "LDRSW $dst,$mem\t! int -> long\n\t" - "AND $dst,$dst,$mask" %} - - ins_encode %{ - __ ldr_s32($dst$$Register, $mem$$Address); - __ andr($dst$$Register, $dst$$Register, (uintx)$mask$$constant); - %} - ins_pipe(iload_mem); -%} -#else // Load Integer with a 31-bit immediate mask into a Long Register instruct loadI2L_limmU31(iRegL dst, memoryI mem, limmU31 mask) %{ match(Set dst (ConvI2L (AndI (LoadI mem) mask))); @@ -4641,27 +3897,7 @@ instruct loadI2L_limmU31(iRegL dst, memoryI mem, limmU31 mask) %{ %} ins_pipe(iload_mem); %} -#endif -#ifdef AARCH64 -// Load Integer with mask into a Long Register -// FIXME: use signedRegI mask, remove tmp? -instruct loadI2L_immI(iRegL dst, memoryI mem, immI mask, iRegI tmp) %{ - match(Set dst (ConvI2L (AndI (LoadI mem) mask))); - effect(TEMP dst, TEMP tmp); - - ins_cost(MEMORY_REF_COST + 3*DEFAULT_COST); - format %{ "LDRSW $mem,$dst\t! int & 31-bit mask -> long\n\t" - "MOV_SLOW $tmp,$mask\n\t" - "AND $dst,$tmp,$dst" %} - ins_encode %{ - __ ldrsw($dst$$Register, $mem$$Address); - __ mov_slow($tmp$$Register, $mask$$constant); - __ andr($dst$$Register, $dst$$Register, $tmp$$Register); - %} - ins_pipe(iload_mem); -%} -#else // Load Integer with a 31-bit mask into a Long Register // FIXME: use iRegI mask, remove tmp? instruct loadI2L_immU31(iRegL dst, memoryI mem, immU31 mask, iRegI tmp) %{ @@ -4682,20 +3918,12 @@ instruct loadI2L_immU31(iRegL dst, memoryI mem, immU31 mask, iRegI tmp) %{ %} ins_pipe(iload_mem); %} -#endif // Load Unsigned Integer into a Long Register instruct loadUI2L(iRegL dst, memoryI mem, immL_32bits mask) %{ match(Set dst (AndL (ConvI2L (LoadI mem)) mask)); ins_cost(MEMORY_REF_COST); -#ifdef AARCH64 -//size(4); - format %{ "LDR_w $dst,$mem\t! uint -> long" %} - ins_encode %{ - __ ldr_w($dst$$Register, $mem$$Address); - %} -#else size(8); format %{ "LDR $dst.lo,$mem\t! uint -> long\n\t" "MOV $dst.hi,0" %} @@ -4703,37 +3931,14 @@ instruct loadUI2L(iRegL dst, memoryI mem, immL_32bits mask) %{ __ ldr($dst$$Register, $mem$$Address); __ mov($dst$$Register->successor(), 0); %} -#endif ins_pipe(iload_mem); %} // Load Long -#ifdef AARCH64 -// XXX This variant shouldn't be necessary if 6217251 is implemented -instruct loadLoff(iRegLd dst, memoryScaledL mem, aimmX off, iRegP tmp) %{ - match(Set dst (LoadL (AddP mem off))); - ins_cost(MEMORY_REF_COST + DEFAULT_COST); // assume shift/sign-extend is free - effect(TEMP tmp); - size(4 * 2); - - format %{ "LDR $dst,$mem+$off\t! long temp=$tmp" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - __ add($tmp$$Register, base, $off$$constant); - Address nmem = Address::make_raw($tmp$$reg, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none); - __ ldr($dst$$Register, nmem); - %} - ins_pipe(iload_mem); -%} -#endif instruct loadL(iRegLd dst, memoryL mem ) %{ -#ifdef AARCH64 - // already atomic for Aarch64 -#else predicate(!((LoadLNode*)n)->require_atomic_access()); -#endif match(Set dst (LoadL mem)); effect(TEMP dst); ins_cost(MEMORY_REF_COST); @@ -4746,7 +3951,6 @@ instruct loadL(iRegLd dst, memoryL mem ) %{ ins_pipe(iload_mem); %} -#ifndef AARCH64 instruct loadL_2instr(iRegL dst, memorylong mem ) %{ predicate(!((LoadLNode*)n)->require_atomic_access()); match(Set dst (LoadL mem)); @@ -4822,7 +4026,6 @@ instruct loadL_unaligned(iRegL dst, memorylong mem ) %{ %} ins_pipe(iload_mem); %} -#endif // !AARCH64 // Load Range instruct loadRange(iRegI dst, memoryI mem) %{ @@ -4839,24 +4042,6 @@ instruct loadRange(iRegI dst, memoryI mem) %{ // Load Pointer -#ifdef AARCH64 -// XXX This variant shouldn't be necessary if 6217251 is implemented -instruct loadPoff(iRegP dst, memoryScaledP mem, aimmX off, iRegP tmp) %{ - match(Set dst (LoadP (AddP mem off))); - ins_cost(MEMORY_REF_COST + DEFAULT_COST); // assume shift/sign-extend is free - effect(TEMP tmp); - size(4 * 2); - - format %{ "LDR $dst,$mem+$off\t! ptr temp=$tmp" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - __ add($tmp$$Register, base, $off$$constant); - Address nmem = Address::make_raw($tmp$$reg, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none); - __ ldr($dst$$Register, nmem); - %} - ins_pipe(iload_mem); -%} -#endif instruct loadP(iRegP dst, memoryP mem) %{ match(Set dst (LoadP mem)); @@ -4950,24 +4135,6 @@ instruct loadNKlass(iRegN dst, memoryI mem) %{ %} #endif -#ifdef AARCH64 -// XXX This variant shouldn't be necessary if 6217251 is implemented -instruct loadDoff(regD dst, memoryScaledD mem, aimmX off, iRegP tmp) %{ - match(Set dst (LoadD (AddP mem off))); - ins_cost(MEMORY_REF_COST + DEFAULT_COST); // assume shift/sign-extend is free - effect(TEMP tmp); - size(4 * 2); - - format %{ "ldr $dst,$mem+$off\t! double temp=$tmp" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - __ add($tmp$$Register, base, $off$$constant); - Address nmem = Address::make_raw($tmp$$reg, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none); - __ ldr_d($dst$$FloatRegister, nmem); - %} - ins_pipe(floadD_mem); -%} -#endif instruct loadD(regD dst, memoryD mem) %{ match(Set dst (LoadD mem)); @@ -4983,7 +4150,6 @@ instruct loadD(regD dst, memoryD mem) %{ ins_pipe(floadD_mem); %} -#ifndef AARCH64 // Load Double - UNaligned instruct loadD_unaligned(regD_low dst, memoryF2 mem ) %{ match(Set dst (LoadD_unaligned mem)); @@ -4999,26 +4165,7 @@ instruct loadD_unaligned(regD_low dst, memoryF2 mem ) %{ %} ins_pipe(iload_mem); %} -#endif -#ifdef AARCH64 -// XXX This variant shouldn't be necessary if 6217251 is implemented -instruct loadFoff(regF dst, memoryScaledF mem, aimmX off, iRegP tmp) %{ - match(Set dst (LoadF (AddP mem off))); - ins_cost(MEMORY_REF_COST + DEFAULT_COST); // assume shift/sign-extend is free - effect(TEMP tmp); - size(4 * 2); - - format %{ "ldr $dst,$mem+$off\t! float temp=$tmp" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - __ add($tmp$$Register, base, $off$$constant); - Address nmem = Address::make_raw($tmp$$reg, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none); - __ ldr_s($dst$$FloatRegister, nmem); - %} - ins_pipe(floadF_mem); -%} -#endif instruct loadF(regF dst, memoryF mem) %{ match(Set dst (LoadF mem)); @@ -5032,17 +4179,6 @@ instruct loadF(regF dst, memoryF mem) %{ ins_pipe(floadF_mem); %} -#ifdef AARCH64 -instruct load_limmI(iRegI dst, limmI src) %{ - match(Set dst src); - ins_cost(DEFAULT_COST + 1); // + 1 because MOV is preferred - format %{ "ORR_w $dst, ZR, $src\t! int" %} - ins_encode %{ - __ orr_w($dst$$Register, ZR, (uintx)$src$$constant); - %} - ins_pipe(ialu_imm); -%} -#endif // // Load Constant instruct loadConI( iRegI dst, immI src ) %{ @@ -5065,7 +4201,6 @@ instruct loadConIMov( iRegI dst, immIMov src ) %{ ins_pipe(ialu_imm); %} -#ifndef AARCH64 instruct loadConIMovn( iRegI dst, immIRotn src ) %{ match(Set dst src); size(4); @@ -5075,22 +4210,13 @@ instruct loadConIMovn( iRegI dst, immIRotn src ) %{ %} ins_pipe(ialu_imm_n); %} -#endif instruct loadConI16( iRegI dst, immI16 src ) %{ match(Set dst src); size(4); -#ifdef AARCH64 - format %{ "MOVZ_w $dst, $src" %} -#else format %{ "MOVW $dst, $src" %} -#endif ins_encode %{ -#ifdef AARCH64 - __ mov_w($dst$$Register, $src$$constant); -#else __ movw($dst$$Register, $src$$constant); -#endif %} ins_pipe(ialu_imm_n); %} @@ -5124,80 +4250,6 @@ instruct loadConP_poll(iRegP dst, immP_poll src) %{ ins_pipe(loadConP_poll); %} -#ifdef AARCH64 -instruct loadConP0(iRegP dst, immP0 src) %{ - match(Set dst src); - ins_cost(DEFAULT_COST); - format %{ "MOV $dst,ZR\t!ptr" %} - ins_encode %{ - __ mov($dst$$Register, ZR); - %} - ins_pipe(ialu_none); -%} - -instruct loadConN(iRegN dst, immN src) %{ - match(Set dst src); - ins_cost(DEFAULT_COST * 3/2); - format %{ "SET $dst,$src\t! compressed ptr" %} - ins_encode %{ - Register dst = $dst$$Register; - // FIXME: use $constanttablebase? - __ set_narrow_oop(dst, (jobject)$src$$constant); - %} - ins_pipe(ialu_hi_lo_reg); -%} - -instruct loadConN0(iRegN dst, immN0 src) %{ - match(Set dst src); - ins_cost(DEFAULT_COST); - format %{ "MOV $dst,ZR\t! compressed ptr" %} - ins_encode %{ - __ mov($dst$$Register, ZR); - %} - ins_pipe(ialu_none); -%} - -instruct loadConNKlass(iRegN dst, immNKlass src) %{ - match(Set dst src); - ins_cost(DEFAULT_COST * 3/2); - format %{ "SET $dst,$src\t! compressed klass ptr" %} - ins_encode %{ - Register dst = $dst$$Register; - // FIXME: use $constanttablebase? - __ set_narrow_klass(dst, (Klass*)$src$$constant); - %} - ins_pipe(ialu_hi_lo_reg); -%} - -instruct load_limmL(iRegL dst, limmL src) %{ - match(Set dst src); - ins_cost(DEFAULT_COST); - format %{ "ORR $dst, ZR, $src\t! long" %} - ins_encode %{ - __ orr($dst$$Register, ZR, (uintx)$src$$constant); - %} - ins_pipe(loadConL); -%} -instruct load_immLMov(iRegL dst, immLMov src) %{ - match(Set dst src); - ins_cost(DEFAULT_COST); - format %{ "MOV $dst, $src\t! long" %} - ins_encode %{ - __ mov($dst$$Register, $src$$constant); - %} - ins_pipe(loadConL); -%} -instruct loadConL(iRegL dst, immL src) %{ - match(Set dst src); - ins_cost(DEFAULT_COST * 4); // worst case - format %{ "mov_slow $dst, $src\t! long" %} - ins_encode %{ - // FIXME: use $constanttablebase? - __ mov_slow($dst$$Register, $src$$constant); - %} - ins_pipe(loadConL); -%} -#else instruct loadConL(iRegL dst, immL src) %{ match(Set dst src); ins_cost(DEFAULT_COST * 4); @@ -5223,7 +4275,6 @@ instruct loadConL16( iRegL dst, immL16 src ) %{ %} ins_pipe(ialu_imm); %} -#endif instruct loadConF_imm8(regF dst, imm8F src) %{ match(Set dst src); @@ -5238,25 +4289,6 @@ instruct loadConF_imm8(regF dst, imm8F src) %{ ins_pipe(loadConFD); // FIXME %} -#ifdef AARCH64 -instruct loadIConF(iRegI dst, immF src) %{ - match(Set dst src); - ins_cost(DEFAULT_COST * 2); - - format %{ "MOV_SLOW $dst, $src\t! loadIConF" %} - - ins_encode %{ - // FIXME revisit once 6961697 is in - union { - jfloat f; - int i; - } v; - v.f = $src$$constant; - __ mov_slow($dst$$Register, v.i); - %} - ins_pipe(ialu_imm); -%} -#endif instruct loadConF(regF dst, immF src, iRegI tmp) %{ match(Set dst src); @@ -5323,11 +4355,7 @@ instruct prefetchAlloc( memoryP mem ) %{ format %{ "PLDW $mem\t! Prefetch allocation" %} ins_encode %{ -#ifdef AARCH64 - __ prfm(pstl1keep, $mem$$Address); -#else __ pldw($mem$$Address); -#endif %} ins_pipe(iload_mem); %} @@ -5360,24 +4388,6 @@ instruct storeCM(memoryB mem, store_RegI src) %{ // Store Char/Short -#ifdef AARCH64 -// XXX This variant shouldn't be necessary if 6217251 is implemented -instruct storeCoff(store_RegI src, memoryScaledS mem, aimmX off, iRegP tmp) %{ - match(Set mem (StoreC (AddP mem off) src)); - ins_cost(MEMORY_REF_COST + DEFAULT_COST); // assume shift/sign-extend is free - effect(TEMP tmp); - size(4 * 2); - - format %{ "STRH $src,$mem+$off\t! short temp=$tmp" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - __ add($tmp$$Register, base, $off$$constant); - Address nmem = Address::make_raw($tmp$$reg, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none); - __ strh($src$$Register, nmem); - %} - ins_pipe(istore_mem_reg); -%} -#endif instruct storeC(memoryS mem, store_RegI src) %{ match(Set mem (StoreC mem src)); @@ -5393,24 +4403,6 @@ instruct storeC(memoryS mem, store_RegI src) %{ // Store Integer -#ifdef AARCH64 -// XXX This variant shouldn't be necessary if 6217251 is implemented -instruct storeIoff(store_RegI src, memoryScaledI mem, aimmX off, iRegP tmp) %{ - match(Set mem (StoreI (AddP mem off) src)); - ins_cost(MEMORY_REF_COST + DEFAULT_COST); // assume shift/sign-extend is free - effect(TEMP tmp); - size(4 * 2); - - format %{ "str_32 $src,$mem+$off\t! int temp=$tmp" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - __ add($tmp$$Register, base, $off$$constant); - Address nmem = Address::make_raw($tmp$$reg, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none); - __ str_32($src$$Register, nmem); - %} - ins_pipe(istore_mem_reg); -%} -#endif instruct storeI(memoryI mem, store_RegI src) %{ match(Set mem (StoreI mem src)); @@ -5426,31 +4418,9 @@ instruct storeI(memoryI mem, store_RegI src) %{ // Store Long -#ifdef AARCH64 -// XXX This variant shouldn't be necessary if 6217251 is implemented -instruct storeLoff(store_RegLd src, memoryScaledL mem, aimmX off, iRegP tmp) %{ - match(Set mem (StoreL (AddP mem off) src)); - ins_cost(MEMORY_REF_COST + DEFAULT_COST); // assume shift/sign-extend is free - effect(TEMP tmp); - size(4 * 2); - - format %{ "str_64 $src,$mem+$off\t! long temp=$tmp" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - __ add($tmp$$Register, base, $off$$constant); - Address nmem = Address::make_raw($tmp$$reg, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none); - __ str_64($src$$Register, nmem); - %} - ins_pipe(istore_mem_reg); -%} -#endif instruct storeL(memoryL mem, store_RegLd src) %{ -#ifdef AARCH64 - // already atomic for Aarch64 -#else predicate(!((StoreLNode*)n)->require_atomic_access()); -#endif match(Set mem (StoreL mem src)); ins_cost(MEMORY_REF_COST); @@ -5463,7 +4433,6 @@ instruct storeL(memoryL mem, store_RegLd src) %{ ins_pipe(istore_mem_reg); %} -#ifndef AARCH64 instruct storeL_2instr(memorylong mem, iRegL src) %{ predicate(!((StoreLNode*)n)->require_atomic_access()); match(Set mem (StoreL mem src)); @@ -5496,9 +4465,7 @@ instruct storeL_volatile(indirect mem, iRegL src) %{ %} ins_pipe(istore_mem_reg); %} -#endif // !AARCH64 -#ifndef AARCH64 instruct storeL_volatile_fp(memoryD mem, iRegL src) %{ predicate(((StoreLNode*)n)->require_atomic_access()); match(Set mem (StoreL mem src)); @@ -5512,7 +4479,6 @@ instruct storeL_volatile_fp(memoryD mem, iRegL src) %{ %} ins_pipe(istore_mem_reg); %} -#endif #ifdef XXX // Move SP Pointer @@ -5534,60 +4500,12 @@ instruct movSP(store_ptr_RegP dst, SPRegP src) %{ %} #endif -#ifdef AARCH64 -// FIXME -// Store SP Pointer -instruct storeSP(memoryP mem, SPRegP src, iRegP tmp) %{ - match(Set mem (StoreP mem src)); - predicate(_kids[1]->_leaf->is_Proj() && _kids[1]->_leaf->as_Proj()->_con == TypeFunc::FramePtr); - // Multiple StoreP rules, different only in register mask. - // Matcher makes the last always valid. The others will - // only be valid if they cost less than the last valid - // rule. So cost(rule1) < cost(rule2) < cost(last) - // Unlike immediates, register constraints are not checked - // at match time. - ins_cost(MEMORY_REF_COST+DEFAULT_COST+4); - effect(TEMP tmp); - size(8); - - format %{ "MOV $tmp,$src\t! SP ptr\n\t" - "STR $tmp,$mem\t! SP ptr" %} - ins_encode %{ - assert($src$$Register == SP, "SP expected"); - __ mov($tmp$$Register, $src$$Register); - __ str($tmp$$Register, $mem$$Address); - %} - ins_pipe(istore_mem_spORreg); // FIXME -%} -#endif // AARCH64 // Store Pointer -#ifdef AARCH64 -// XXX This variant shouldn't be necessary if 6217251 is implemented -instruct storePoff(store_ptr_RegP src, memoryScaledP mem, aimmX off, iRegP tmp) %{ - predicate(!_kids[1]->_leaf->is_Proj() || _kids[1]->_leaf->as_Proj()->_con != TypeFunc::FramePtr); - match(Set mem (StoreP (AddP mem off) src)); - ins_cost(MEMORY_REF_COST + DEFAULT_COST); // assume shift/sign-extend is free - effect(TEMP tmp); - size(4 * 2); - - format %{ "STR $src,$mem+$off\t! ptr temp=$tmp" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - __ add($tmp$$Register, base, $off$$constant); - Address nmem = Address::make_raw($tmp$$reg, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none); - __ str($src$$Register, nmem); - %} - ins_pipe(istore_mem_reg); -%} -#endif instruct storeP(memoryP mem, store_ptr_RegP src) %{ match(Set mem (StoreP mem src)); -#ifdef AARCH64 - predicate(!_kids[1]->_leaf->is_Proj() || _kids[1]->_leaf->as_Proj()->_con != TypeFunc::FramePtr); -#endif ins_cost(MEMORY_REF_COST); size(4); @@ -5598,42 +4516,10 @@ instruct storeP(memoryP mem, store_ptr_RegP src) %{ ins_pipe(istore_mem_spORreg); %} -#ifdef AARCH64 -// Store NULL Pointer -instruct storeP0(memoryP mem, immP0 src) %{ - match(Set mem (StoreP mem src)); - ins_cost(MEMORY_REF_COST); - size(4); - - format %{ "STR ZR,$mem\t! ptr" %} - ins_encode %{ - __ str(ZR, $mem$$Address); - %} - ins_pipe(istore_mem_spORreg); -%} -#endif // AARCH64 #ifdef _LP64 // Store Compressed Pointer -#ifdef AARCH64 -// XXX This variant shouldn't be necessary if 6217251 is implemented -instruct storeNoff(store_RegN src, memoryScaledI mem, aimmX off, iRegP tmp) %{ - match(Set mem (StoreN (AddP mem off) src)); - ins_cost(MEMORY_REF_COST + DEFAULT_COST); // assume shift/sign-extend is free - effect(TEMP tmp); - size(4 * 2); - - format %{ "str_32 $src,$mem+$off\t! compressed ptr temp=$tmp" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - __ add($tmp$$Register, base, $off$$constant); - Address nmem = Address::make_raw($tmp$$reg, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none); - __ str_32($src$$Register, nmem); - %} - ins_pipe(istore_mem_reg); -%} -#endif instruct storeN(memoryI mem, store_RegN src) %{ match(Set mem (StoreN mem src)); @@ -5647,20 +4533,6 @@ instruct storeN(memoryI mem, store_RegN src) %{ ins_pipe(istore_mem_reg); %} -#ifdef AARCH64 -// Store NULL Pointer -instruct storeN0(memoryI mem, immN0 src) %{ - match(Set mem (StoreN mem src)); - ins_cost(MEMORY_REF_COST); - size(4); - - format %{ "str_32 ZR,$mem\t! compressed ptr" %} - ins_encode %{ - __ str_32(ZR, $mem$$Address); - %} - ins_pipe(istore_mem_reg); -%} -#endif // Store Compressed Klass Pointer instruct storeNKlass(memoryI mem, store_RegN src) %{ @@ -5678,24 +4550,6 @@ instruct storeNKlass(memoryI mem, store_RegN src) %{ // Store Double -#ifdef AARCH64 -// XXX This variant shouldn't be necessary if 6217251 is implemented -instruct storeDoff(regD src, memoryScaledD mem, aimmX off, iRegP tmp) %{ - match(Set mem (StoreD (AddP mem off) src)); - ins_cost(MEMORY_REF_COST + DEFAULT_COST); // assume shift/sign-extend is free - effect(TEMP tmp); - size(4 * 2); - - format %{ "STR $src,$mem+$off\t! double temp=$tmp" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - __ add($tmp$$Register, base, $off$$constant); - Address nmem = Address::make_raw($tmp$$reg, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none); - __ str_d($src$$FloatRegister, nmem); - %} - ins_pipe(fstoreD_mem_reg); -%} -#endif instruct storeD(memoryD mem, regD src) %{ match(Set mem (StoreD mem src)); @@ -5711,50 +4565,9 @@ instruct storeD(memoryD mem, regD src) %{ ins_pipe(fstoreD_mem_reg); %} -#ifdef AARCH64 -instruct movI2F(regF dst, iRegI src) %{ - match(Set dst src); - size(4); - - format %{ "FMOV_sw $dst,$src\t! movI2F" %} - ins_encode %{ - __ fmov_sw($dst$$FloatRegister, $src$$Register); - %} - ins_pipe(ialu_reg); // FIXME -%} - -instruct movF2I(iRegI dst, regF src) %{ - match(Set dst src); - size(4); - - format %{ "FMOV_ws $dst,$src\t! movF2I" %} - ins_encode %{ - __ fmov_ws($dst$$Register, $src$$FloatRegister); - %} - ins_pipe(ialu_reg); // FIXME -%} -#endif // Store Float -#ifdef AARCH64 -// XXX This variant shouldn't be necessary if 6217251 is implemented -instruct storeFoff(regF src, memoryScaledF mem, aimmX off, iRegP tmp) %{ - match(Set mem (StoreF (AddP mem off) src)); - ins_cost(MEMORY_REF_COST + DEFAULT_COST); // assume shift/sign-extend is free - effect(TEMP tmp); - size(4 * 2); - - format %{ "str_s $src,$mem+$off\t! float temp=$tmp" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - __ add($tmp$$Register, base, $off$$constant); - Address nmem = Address::make_raw($tmp$$reg, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none); - __ str_s($src$$FloatRegister, nmem); - %} - ins_pipe(fstoreF_mem_reg); -%} -#endif instruct storeF( memoryF mem, regF src) %{ match(Set mem (StoreF mem src)); @@ -5768,75 +4581,10 @@ instruct storeF( memoryF mem, regF src) %{ ins_pipe(fstoreF_mem_reg); %} -#ifdef AARCH64 -// Convert oop pointer into compressed form -instruct encodeHeapOop(iRegN dst, iRegP src, flagsReg ccr) %{ - predicate(n->bottom_type()->make_ptr()->ptr() != TypePtr::NotNull); - match(Set dst (EncodeP src)); - effect(KILL ccr); - format %{ "encode_heap_oop $dst, $src" %} - ins_encode %{ - __ encode_heap_oop($dst$$Register, $src$$Register); - %} - ins_pipe(ialu_reg); -%} - -instruct encodeHeapOop_not_null(iRegN dst, iRegP src) %{ - predicate(n->bottom_type()->make_ptr()->ptr() == TypePtr::NotNull); - match(Set dst (EncodeP src)); - format %{ "encode_heap_oop_not_null $dst, $src" %} - ins_encode %{ - __ encode_heap_oop_not_null($dst$$Register, $src$$Register); - %} - ins_pipe(ialu_reg); -%} - -instruct decodeHeapOop(iRegP dst, iRegN src, flagsReg ccr) %{ - predicate(n->bottom_type()->is_oopptr()->ptr() != TypePtr::NotNull && - n->bottom_type()->is_oopptr()->ptr() != TypePtr::Constant); - match(Set dst (DecodeN src)); - effect(KILL ccr); - format %{ "decode_heap_oop $dst, $src" %} - ins_encode %{ - __ decode_heap_oop($dst$$Register, $src$$Register); - %} - ins_pipe(ialu_reg); -%} - -instruct decodeHeapOop_not_null(iRegP dst, iRegN src) %{ - predicate(n->bottom_type()->is_oopptr()->ptr() == TypePtr::NotNull || - n->bottom_type()->is_oopptr()->ptr() == TypePtr::Constant); - match(Set dst (DecodeN src)); - format %{ "decode_heap_oop_not_null $dst, $src" %} - ins_encode %{ - __ decode_heap_oop_not_null($dst$$Register, $src$$Register); - %} - ins_pipe(ialu_reg); -%} - -instruct encodeKlass_not_null(iRegN dst, iRegP src) %{ - match(Set dst (EncodePKlass src)); - format %{ "encode_klass_not_null $dst, $src" %} - ins_encode %{ - __ encode_klass_not_null($dst$$Register, $src$$Register); - %} - ins_pipe(ialu_reg); -%} - -instruct decodeKlass_not_null(iRegP dst, iRegN src) %{ - match(Set dst (DecodeNKlass src)); - format %{ "decode_klass_not_null $dst, $src" %} - ins_encode %{ - __ decode_klass_not_null($dst$$Register, $src$$Register); - %} - ins_pipe(ialu_reg); -%} -#endif // AARCH64 //----------MemBar Instructions----------------------------------------------- // Memory barrier flavors -// TODO: take advantage of Aarch64 load-acquire, store-release, etc // pattern-match out unnecessary membars instruct membar_storestore() %{ match(MemBarStoreStore); @@ -5932,53 +4680,6 @@ instruct unnecessary_membar_volatile() %{ // %} -#ifdef AARCH64 -// 0 constant in register -instruct zrImmI0(ZRRegI dst, immI0 imm) %{ - match(Set dst imm); - size(0); - ins_cost(0); - - format %{ "! ZR (int 0)" %} - ins_encode( /*empty encoding*/ ); - ins_pipe(ialu_none); -%} - -// 0 constant in register -instruct zrImmL0(ZRRegL dst, immL0 imm) %{ - match(Set dst imm); - size(0); - ins_cost(0); - - format %{ "! ZR (long 0)" %} - ins_encode( /*empty encoding*/ ); - ins_pipe(ialu_none); -%} - -#ifdef XXX -// 0 constant in register -instruct zrImmN0(ZRRegN dst, immN0 imm) %{ - match(Set dst imm); - size(0); - ins_cost(0); - - format %{ "! ZR (compressed pointer NULL)" %} - ins_encode( /*empty encoding*/ ); - ins_pipe(ialu_none); -%} - -// 0 constant in register -instruct zrImmP0(ZRRegP dst, immP0 imm) %{ - match(Set dst imm); - size(0); - ins_cost(0); - - format %{ "! ZR (NULL)" %} - ins_encode( /*empty encoding*/ ); - ins_pipe(ialu_none); -%} -#endif -#endif // AARCH64 // Cast Index to Pointer for unsafe natives instruct castX2P(iRegX src, iRegP dst) %{ @@ -6006,7 +4707,6 @@ instruct castP2X(iRegP src, iRegX dst) %{ ins_pipe(ialu_reg); %} -#ifndef AARCH64 //----------Conditional Move--------------------------------------------------- // Conditional move instruct cmovIP_reg(cmpOpP cmp, flagsRegP pcc, iRegI dst, iRegI src) %{ @@ -6019,187 +4719,8 @@ instruct cmovIP_reg(cmpOpP cmp, flagsRegP pcc, iRegI dst, iRegI src) %{ %} ins_pipe(ialu_reg); %} -#endif -#ifdef AARCH64 -instruct cmovI_reg3(cmpOp cmp, flagsReg icc, iRegI dst, iRegI src1, iRegI src2) %{ - match(Set dst (CMoveI (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! int" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} -instruct cmovL_reg3(cmpOp cmp, flagsReg icc, iRegL dst, iRegL src1, iRegL src2) %{ - match(Set dst (CMoveL (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! long" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} - -instruct cmovP_reg3(cmpOp cmp, flagsReg icc, iRegP dst, iRegP src1, iRegP src2) %{ - match(Set dst (CMoveP (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! ptr" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} - -instruct cmovN_reg3(cmpOp cmp, flagsReg icc, iRegN dst, iRegN src1, iRegN src2) %{ - match(Set dst (CMoveN (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! compressed ptr" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} - -instruct cmovIP_reg3(cmpOpP cmp, flagsRegP icc, iRegI dst, iRegI src1, iRegI src2) %{ - match(Set dst (CMoveI (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! int" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} - -instruct cmovLP_reg3(cmpOpP cmp, flagsRegP icc, iRegL dst, iRegL src1, iRegL src2) %{ - match(Set dst (CMoveL (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! long" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} - -instruct cmovPP_reg3(cmpOpP cmp, flagsRegP icc, iRegP dst, iRegP src1, iRegP src2) %{ - match(Set dst (CMoveP (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! ptr" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} - -instruct cmovNP_reg3(cmpOpP cmp, flagsRegP icc, iRegN dst, iRegN src1, iRegN src2) %{ - match(Set dst (CMoveN (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! compressed ptr" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} - -instruct cmovIU_reg3(cmpOpU cmp, flagsRegU icc, iRegI dst, iRegI src1, iRegI src2) %{ - match(Set dst (CMoveI (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! int" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} - -instruct cmovLU_reg3(cmpOpU cmp, flagsRegU icc, iRegL dst, iRegL src1, iRegL src2) %{ - match(Set dst (CMoveL (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! long" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} - -instruct cmovPU_reg3(cmpOpU cmp, flagsRegU icc, iRegP dst, iRegP src1, iRegP src2) %{ - match(Set dst (CMoveP (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! ptr" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} - -instruct cmovNU_reg3(cmpOpU cmp, flagsRegU icc, iRegN dst, iRegN src1, iRegN src2) %{ - match(Set dst (CMoveN (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! compressed ptr" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} - -instruct cmovIZ_reg3(cmpOp0 cmp, flagsReg_EQNELTGE icc, iRegI dst, iRegI src1, iRegI src2) %{ - match(Set dst (CMoveI (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! int" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} - -instruct cmovLZ_reg3(cmpOp0 cmp, flagsReg_EQNELTGE icc, iRegL dst, iRegL src1, iRegL src2) %{ - match(Set dst (CMoveL (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! long" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} - -instruct cmovPZ_reg3(cmpOp0 cmp, flagsReg_EQNELTGE icc, iRegP dst, iRegP src1, iRegP src2) %{ - match(Set dst (CMoveP (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! ptr" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} - -instruct cmovNZ_reg3(cmpOp0 cmp, flagsReg_EQNELTGE icc, iRegN dst, iRegN src1, iRegN src2) %{ - match(Set dst (CMoveN (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "CSEL $dst,$src1,$src2,$cmp\t! compressed ptr" %} - ins_encode %{ - __ csel($dst$$Register, $src1$$Register, $src2$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} -#endif // AARCH64 - -#ifndef AARCH64 instruct cmovIP_immMov(cmpOpP cmp, flagsRegP pcc, iRegI dst, immIMov src) %{ match(Set dst (CMoveI (Binary cmp pcc) (Binary dst src))); ins_cost(140); @@ -6221,7 +4742,6 @@ instruct cmovIP_imm16(cmpOpP cmp, flagsRegP pcc, iRegI dst, immI16 src) %{ %} ins_pipe(ialu_imm); %} -#endif instruct cmovI_reg(cmpOp cmp, flagsReg icc, iRegI dst, iRegI src) %{ match(Set dst (CMoveI (Binary cmp icc) (Binary dst src))); @@ -6234,20 +4754,7 @@ instruct cmovI_reg(cmpOp cmp, flagsReg icc, iRegI dst, iRegI src) %{ ins_pipe(ialu_reg); %} -#ifdef AARCH64 -instruct cmovL_reg(cmpOp cmp, flagsReg icc, iRegL dst, iRegL src) %{ - match(Set dst (CMoveL (Binary cmp icc) (Binary dst src))); - ins_cost(150); - size(4); - format %{ "MOV$cmp $dst,$src\t! long" %} - ins_encode %{ - __ mov($dst$$Register, $src$$Register, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(ialu_reg); -%} -#endif -#ifndef AARCH64 instruct cmovI_immMov(cmpOp cmp, flagsReg icc, iRegI dst, immIMov src) %{ match(Set dst (CMoveI (Binary cmp icc) (Binary dst src))); ins_cost(140); @@ -6269,7 +4776,6 @@ instruct cmovII_imm16(cmpOp cmp, flagsReg icc, iRegI dst, immI16 src) %{ %} ins_pipe(ialu_imm); %} -#endif instruct cmovII_reg_EQNELTGE(cmpOp0 cmp, flagsReg_EQNELTGE icc, iRegI dst, iRegI src) %{ match(Set dst (CMoveI (Binary cmp icc) (Binary dst src))); @@ -6286,7 +4792,6 @@ instruct cmovII_reg_EQNELTGE(cmpOp0 cmp, flagsReg_EQNELTGE icc, iRegI dst, iRegI ins_pipe(ialu_reg); %} -#ifndef AARCH64 instruct cmovII_immMov_EQNELTGE(cmpOp0 cmp, flagsReg_EQNELTGE icc, iRegI dst, immIMov src) %{ match(Set dst (CMoveI (Binary cmp icc) (Binary dst src))); predicate(_kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::eq || @@ -6316,7 +4821,6 @@ instruct cmovII_imm16_EQNELTGE(cmpOp0 cmp, flagsReg_EQNELTGE icc, iRegI dst, imm %} ins_pipe(ialu_imm); %} -#endif instruct cmovIIu_reg(cmpOpU cmp, flagsRegU icc, iRegI dst, iRegI src) %{ match(Set dst (CMoveI (Binary cmp icc) (Binary dst src))); @@ -6329,7 +4833,6 @@ instruct cmovIIu_reg(cmpOpU cmp, flagsRegU icc, iRegI dst, iRegI src) %{ ins_pipe(ialu_reg); %} -#ifndef AARCH64 instruct cmovIIu_immMov(cmpOpU cmp, flagsRegU icc, iRegI dst, immIMov src) %{ match(Set dst (CMoveI (Binary cmp icc) (Binary dst src))); ins_cost(140); @@ -6351,7 +4854,6 @@ instruct cmovIIu_imm16(cmpOpU cmp, flagsRegU icc, iRegI dst, immI16 src) %{ %} ins_pipe(ialu_imm); %} -#endif // Conditional move instruct cmovPP_reg(cmpOpP cmp, flagsRegP pcc, iRegP dst, iRegP src) %{ @@ -6369,17 +4871,9 @@ instruct cmovPP_imm(cmpOpP cmp, flagsRegP pcc, iRegP dst, immP0 src) %{ match(Set dst (CMoveP (Binary cmp pcc) (Binary dst src))); ins_cost(140); size(4); -#ifdef AARCH64 - format %{ "MOV$cmp $dst,ZR" %} -#else format %{ "MOV$cmp $dst,$src" %} -#endif ins_encode %{ -#ifdef AARCH64 - __ mov($dst$$Register, ZR, (AsmCondition)($cmp$$cmpcode)); -#else __ mov($dst$$Register, $src$$constant, (AsmCondition)($cmp$$cmpcode)); -#endif %} ins_pipe(ialu_imm); %} @@ -6430,17 +4924,9 @@ instruct cmovPI_imm(cmpOp cmp, flagsReg icc, iRegP dst, immP0 src) %{ ins_cost(140); size(4); -#ifdef AARCH64 - format %{ "MOV$cmp $dst,ZR\t! ptr" %} -#else format %{ "MOV$cmp $dst,$src\t! ptr" %} -#endif ins_encode %{ -#ifdef AARCH64 - __ mov($dst$$Register, ZR, (AsmCondition)($cmp$$cmpcode)); -#else __ mov($dst$$Register, $src$$constant, (AsmCondition)($cmp$$cmpcode)); -#endif %} ins_pipe(ialu_imm); %} @@ -6454,17 +4940,9 @@ instruct cmovPI_imm_EQNELTGE(cmpOp0 cmp, flagsReg_EQNELTGE icc, iRegP dst, immP0 ins_cost(140); size(4); -#ifdef AARCH64 - format %{ "MOV$cmp $dst,ZR\t! ptr" %} -#else format %{ "MOV$cmp $dst,$src\t! ptr" %} -#endif ins_encode %{ -#ifdef AARCH64 - __ mov($dst$$Register, ZR, (AsmCondition)($cmp$$cmpcode)); -#else __ mov($dst$$Register, $src$$constant, (AsmCondition)($cmp$$cmpcode)); -#endif %} ins_pipe(ialu_imm); %} @@ -6474,112 +4952,13 @@ instruct cmovPIu_imm(cmpOpU cmp, flagsRegU icc, iRegP dst, immP0 src) %{ ins_cost(140); size(4); -#ifdef AARCH64 - format %{ "MOV$cmp $dst,ZR\t! ptr" %} -#else format %{ "MOV$cmp $dst,$src\t! ptr" %} -#endif ins_encode %{ -#ifdef AARCH64 - __ mov($dst$$Register, ZR, (AsmCondition)($cmp$$cmpcode)); -#else __ mov($dst$$Register, $src$$constant, (AsmCondition)($cmp$$cmpcode)); -#endif %} ins_pipe(ialu_imm); %} -#ifdef AARCH64 -// Conditional move -instruct cmovF_reg(cmpOp cmp, flagsReg icc, regF dst, regF src1, regF src2) %{ - match(Set dst (CMoveF (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "FCSEL_s $dst,$src1,$src2,$cmp" %} - ins_encode %{ - __ fcsel_s($dst$$FloatRegister, $src1$$FloatRegister, $src2$$FloatRegister, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(int_conditional_float_move); -%} - -instruct cmovD_reg(cmpOp cmp, flagsReg icc, regD dst, regD src1, regD src2) %{ - match(Set dst (CMoveD (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "FCSEL_d $dst,$src1,$src2,$cmp" %} - ins_encode %{ - __ fcsel_d($dst$$FloatRegister, $src1$$FloatRegister, $src2$$FloatRegister, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(int_conditional_float_move); -%} - -instruct cmovFP_reg(cmpOpP cmp, flagsRegP icc, regF dst, regF src1, regF src2) %{ - match(Set dst (CMoveF (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "FCSEL_s $dst,$src1,$src2,$cmp" %} - ins_encode %{ - __ fcsel_s($dst$$FloatRegister, $src1$$FloatRegister, $src2$$FloatRegister, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(int_conditional_float_move); -%} - -instruct cmovDP_reg(cmpOpP cmp, flagsRegP icc, regD dst, regD src1, regD src2) %{ - match(Set dst (CMoveD (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "FCSEL_d $dst,$src1,$src2,$cmp" %} - ins_encode %{ - __ fcsel_d($dst$$FloatRegister, $src1$$FloatRegister, $src2$$FloatRegister, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(int_conditional_float_move); -%} - -instruct cmovFU_reg(cmpOpU cmp, flagsRegU icc, regF dst, regF src1, regF src2) %{ - match(Set dst (CMoveF (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "FCSEL_s $dst,$src1,$src2,$cmp" %} - ins_encode %{ - __ fcsel_s($dst$$FloatRegister, $src1$$FloatRegister, $src2$$FloatRegister, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(int_conditional_float_move); -%} - -instruct cmovDU_reg(cmpOpU cmp, flagsRegU icc, regD dst, regD src1, regD src2) %{ - match(Set dst (CMoveD (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "FCSEL_d $dst,$src1,$src2,$cmp" %} - ins_encode %{ - __ fcsel_d($dst$$FloatRegister, $src1$$FloatRegister, $src2$$FloatRegister, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(int_conditional_float_move); -%} - -instruct cmovFZ_reg(cmpOp0 cmp, flagsReg_EQNELTGE icc, regF dst, regF src1, regF src2) %{ - match(Set dst (CMoveF (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "FCSEL_s $dst,$src1,$src2,$cmp" %} - ins_encode %{ - __ fcsel_s($dst$$FloatRegister, $src1$$FloatRegister, $src2$$FloatRegister, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(int_conditional_float_move); -%} - -instruct cmovDZ_reg(cmpOp0 cmp, flagsReg_EQNELTGE icc, regD dst, regD src1, regD src2) %{ - match(Set dst (CMoveD (Binary cmp icc) (Binary src2 src1))); - ins_cost(150); - size(4); - format %{ "FCSEL_d $dst,$src1,$src2,$cmp" %} - ins_encode %{ - __ fcsel_d($dst$$FloatRegister, $src1$$FloatRegister, $src2$$FloatRegister, (AsmCondition)($cmp$$cmpcode)); - %} - ins_pipe(int_conditional_float_move); -%} - -#else // !AARCH64 // Conditional move instruct cmovFP_reg(cmpOpP cmp, flagsRegP pcc, regF dst, regF src) %{ @@ -6840,7 +5219,6 @@ instruct cmovLIu_reg(cmpOpU cmp, flagsRegU icc, iRegL dst, iRegL src) %{ %} ins_pipe(ialu_reg); %} -#endif // !AARCH64 //----------OS and Locking Instructions---------------------------------------- @@ -6897,7 +5275,6 @@ instruct addI_reg_reg(iRegI dst, iRegI src1, iRegI src2) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct addshlI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (AddI (LShiftI src1 src2) src3)); @@ -6908,22 +5285,7 @@ instruct addshlI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif -#ifdef AARCH64 -#ifdef TODO -instruct addshlL_reg_imm_reg(iRegL dst, iRegL src1, immU6 src2, iRegL src3) %{ - match(Set dst (AddL (LShiftL src1 src2) src3)); - - size(4); - format %{ "ADD $dst,$src3,$src1<<$src2\t! long" %} - ins_encode %{ - __ add($dst$$Register, $src3$$Register, AsmOperand($src1$$Register, lsl, $src2$$constant)); - %} - ins_pipe(ialu_reg_reg); -%} -#endif -#endif instruct addshlI_reg_imm_reg(iRegI dst, iRegI src1, immU5 src2, iRegI src3) %{ match(Set dst (AddI (LShiftI src1 src2) src3)); @@ -6936,7 +5298,6 @@ instruct addshlI_reg_imm_reg(iRegI dst, iRegI src1, immU5 src2, iRegI src3) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct addsarI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (AddI (RShiftI src1 src2) src3)); @@ -6947,7 +5308,6 @@ instruct addsarI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif instruct addsarI_reg_imm_reg(iRegI dst, iRegI src1, immU5 src2, iRegI src3) %{ match(Set dst (AddI (RShiftI src1 src2) src3)); @@ -6960,7 +5320,6 @@ instruct addsarI_reg_imm_reg(iRegI dst, iRegI src1, immU5 src2, iRegI src3) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct addshrI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (AddI (URShiftI src1 src2) src3)); @@ -6971,7 +5330,6 @@ instruct addshrI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif instruct addshrI_reg_imm_reg(iRegI dst, iRegI src1, immU5 src2, iRegI src3) %{ match(Set dst (AddI (URShiftI src1 src2) src3)); @@ -7008,69 +5366,6 @@ instruct addP_reg_reg(iRegP dst, iRegP src1, iRegX src2) %{ ins_pipe(ialu_reg_reg); %} -#ifdef AARCH64 -// unshifted I2L operand -operand unshiftedI2L(iRegI src2) %{ -//constraint(ALLOC_IN_RC(sp_ptr_reg)); - match(ConvI2L src2); - - op_cost(1); - format %{ "$src2.w" %} - interface(MEMORY_INTER) %{ - base($src2); - index(0xff); - scale(0x0); - disp(0x0); - %} -%} - -// shifted I2L operand -operand shiftedI2L(iRegI src2, immI_0_4 src3) %{ -//constraint(ALLOC_IN_RC(sp_ptr_reg)); - match(LShiftX (ConvI2L src2) src3); - - op_cost(1); - format %{ "$src2.w << $src3" %} - interface(MEMORY_INTER) %{ - base($src2); - index(0xff); - scale($src3); - disp(0x0); - %} -%} - -opclass shiftedRegI(shiftedI2L, unshiftedI2L); - -instruct shlL_reg_regI(iRegL dst, iRegI src1, immU6 src2) %{ - match(Set dst (LShiftL (ConvI2L src1) src2)); - - size(4); - format %{ "LSL $dst,$src1.w,$src2\t! ptr" %} - ins_encode %{ - int c = $src2$$constant; - int r = 64 - c; - int s = 31; - if (s >= r) { - s = r - 1; - } - __ sbfm($dst$$Register, $src1$$Register, r, s); - %} - ins_pipe(ialu_reg_reg); -%} - -instruct addP_reg_regI(iRegP dst, iRegP src1, shiftedRegI src2) %{ - match(Set dst (AddP src1 src2)); - - ins_cost(DEFAULT_COST * 3/2); - size(4); - format %{ "ADD $dst,$src1,$src2, sxtw\t! ptr" %} - ins_encode %{ - Register base = reg_to_register_object($src2$$base); - __ add($dst$$Register, $src1$$Register, base, ex_sxtw, $src2$$scale); - %} - ins_pipe(ialu_reg_reg); -%} -#endif // shifted iRegX operand operand shiftedX(iRegX src2, shimmX src3) %{ @@ -7113,30 +5408,6 @@ instruct addP_reg_aimmX(iRegP dst, iRegP src1, aimmX src2) %{ %} // Long Addition -#ifdef AARCH64 -instruct addL_reg_reg(iRegL dst, iRegL src1, iRegL src2) %{ - match(Set dst (AddL src1 src2)); - size(4); - format %{ "ADD $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ add($dst$$Register, $src1$$Register, $src2$$Register); - %} - ins_pipe(ialu_reg_reg); -%} - -instruct addL_reg_regI(iRegL dst, iRegL src1, shiftedRegI src2) %{ - match(Set dst (AddL src1 src2)); - - ins_cost(DEFAULT_COST * 3/2); - size(4); - format %{ "ADD $dst,$src1,$src2, sxtw\t! long" %} - ins_encode %{ - Register base = reg_to_register_object($src2$$base); - __ add($dst$$Register, $src1$$Register, base, ex_sxtw, $src2$$scale); - %} - ins_pipe(ialu_reg_reg); -%} -#else instruct addL_reg_reg(iRegL dst, iRegL src1, iRegL src2, flagsReg ccr) %{ match(Set dst (AddL src1 src2)); effect(KILL ccr); @@ -7149,36 +5420,9 @@ instruct addL_reg_reg(iRegL dst, iRegL src1, iRegL src2, flagsReg ccr) %{ %} ins_pipe(ialu_reg_reg); %} -#endif -#ifdef AARCH64 -// Immediate Addition -instruct addL_reg_aimm(iRegL dst, iRegL src1, aimmL src2) %{ - match(Set dst (AddL src1 src2)); - - size(4); - format %{ "ADD $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ add($dst$$Register, $src1$$Register, $src2$$constant); - %} - ins_pipe(ialu_reg_imm); -%} - -instruct addL_reg_immLneg(iRegL dst, iRegL src1, aimmLneg src2) %{ - match(Set dst (SubL src1 src2)); - - size(4); - format %{ "ADD $dst,$src1,-($src2)\t! long" %} - ins_encode %{ - __ add($dst$$Register, $src1$$Register, -$src2$$constant); - %} - ins_pipe(ialu_reg_imm); -%} -#else // TODO -#endif -#ifndef AARCH64 // TODO: try immLRot2 instead, (0, $con$$constant) becomes // (hi($con$$constant), lo($con$$constant)) becomes instruct addL_reg_immRot(iRegL dst, iRegL src1, immLlowRot con, flagsReg ccr) %{ @@ -7193,26 +5437,19 @@ instruct addL_reg_immRot(iRegL dst, iRegL src1, immLlowRot con, flagsReg ccr) %{ %} ins_pipe(ialu_reg_imm); %} -#endif //----------Conditional_store-------------------------------------------------- // Conditional-store of the updated heap-top. // Used during allocation of the shared heap. // Sets flags (EQ) on success. -// TODO: optimize out barriers with AArch64 load-acquire/store-release // LoadP-locked. instruct loadPLocked(iRegP dst, memoryex mem) %{ match(Set dst (LoadPLocked mem)); size(4); format %{ "LDREX $dst,$mem" %} ins_encode %{ -#ifdef AARCH64 - Register base = reg_to_register_object($mem$$base); - __ ldxr($dst$$Register, base); -#else __ ldrex($dst$$Register,$mem$$Address); -#endif %} ins_pipe(iload_mem); %} @@ -7225,12 +5462,7 @@ instruct storePConditional( memoryex heap_top_ptr, iRegP oldval, iRegP newval, i format %{ "STREX $tmp,$newval,$heap_top_ptr\n\t" "CMP $tmp, 0" %} ins_encode %{ -#ifdef AARCH64 - Register base = reg_to_register_object($heap_top_ptr$$base); - __ stxr($tmp$$Register, $newval$$Register, base); -#else __ strex($tmp$$Register, $newval$$Register, $heap_top_ptr$$Address); -#endif __ cmp($tmp$$Register, 0); %} ins_pipe( long_memory_op ); @@ -7238,20 +5470,6 @@ instruct storePConditional( memoryex heap_top_ptr, iRegP oldval, iRegP newval, i // Conditional-store of an intx value. instruct storeXConditional( memoryex mem, iRegX oldval, iRegX newval, iRegX tmp, flagsReg icc ) %{ -#ifdef AARCH64 - match(Set icc (StoreLConditional mem (Binary oldval newval))); - effect( TEMP tmp ); - size(28); - format %{ "loop:\n\t" - "LDXR $tmp, $mem\t! If $oldval==[$mem] Then store $newval into [$mem], DOESN'T set $newval=[$mem] in any case\n\t" - "SUBS $tmp, $tmp, $oldval\n\t" - "B.ne done\n\t" - "STXR $tmp, $newval, $mem\n\t" - "CBNZ_w $tmp, loop\n\t" - "CMP $tmp, 0\n\t" - "done:\n\t" - "membar LoadStore|LoadLoad" %} -#else match(Set icc (StoreIConditional mem (Binary oldval newval))); effect( TEMP tmp ); size(28); @@ -7263,29 +5481,15 @@ instruct storeXConditional( memoryex mem, iRegX oldval, iRegX newval, iRegX tmp, "B.eq loop \n\t" "TEQ $tmp, 0\n\t" "membar LoadStore|LoadLoad" %} -#endif ins_encode %{ Label loop; __ bind(loop); -#ifdef AARCH64 -// FIXME: use load-acquire/store-release, remove membar? - Label done; - Register base = reg_to_register_object($mem$$base); - __ ldxr($tmp$$Register, base); - __ subs($tmp$$Register, $tmp$$Register, $oldval$$Register); - __ b(done, ne); - __ stxr($tmp$$Register, $newval$$Register, base); - __ cbnz_w($tmp$$Register, loop); - __ cmp($tmp$$Register, 0); - __ bind(done); -#else __ ldrex($tmp$$Register, $mem$$Address); __ eors($tmp$$Register, $tmp$$Register, $oldval$$Register); __ strex($tmp$$Register, $newval$$Register, $mem$$Address, eq); __ cmp($tmp$$Register, 1, eq); __ b(loop, eq); __ teq($tmp$$Register, 0); -#endif // used by biased locking only. Requires a membar. __ membar(MacroAssembler::Membar_mask_bits(MacroAssembler::LoadStore | MacroAssembler::LoadLoad), noreg); %} @@ -7294,118 +5498,6 @@ instruct storeXConditional( memoryex mem, iRegX oldval, iRegX newval, iRegX tmp, // No flag versions for CompareAndSwap{P,I,L} because matcher can't match them -#ifdef AARCH64 -// TODO: if combined with membar, elide membar and use -// load-acquire/store-release if appropriate -instruct compareAndSwapL_bool(memoryex mem, iRegL oldval, iRegL newval, iRegI res, iRegI tmp, flagsReg ccr) %{ - match(Set res (CompareAndSwapL mem (Binary oldval newval))); - effect( KILL ccr, TEMP tmp); - size(24); - format %{ "loop:\n\t" - "LDXR $tmp, $mem\t! If $oldval==[$mem] Then store $newval into [$mem]\n\t" - "CMP $tmp, $oldval\n\t" - "B.ne done\n\t" - "STXR $tmp, $newval, $mem\n\t" - "CBNZ_w $tmp, loop\n\t" - "done:\n\t" - "CSET_w $res, eq" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - Label loop, done; - __ bind(loop); - __ ldxr($tmp$$Register, base); - __ cmp($tmp$$Register, $oldval$$Register); - __ b(done, ne); - __ stxr($tmp$$Register, $newval$$Register, base); - __ cbnz_w($tmp$$Register, loop); - __ bind(done); - __ cset_w($res$$Register, eq); - %} - ins_pipe( long_memory_op ); -%} - -instruct compareAndSwapI_bool(memoryex mem, iRegI oldval, iRegI newval, iRegI res, iRegI tmp, flagsReg ccr) %{ - match(Set res (CompareAndSwapI mem (Binary oldval newval))); - effect( KILL ccr, TEMP tmp); - size(24); - format %{ "loop:\n\t" - "LDXR_w $tmp, $mem\t! If $oldval==[$mem] Then store $newval into [$mem]\n\t" - "CMP_w $tmp, $oldval\n\t" - "B.ne done\n\t" - "STXR_w $tmp, $newval, $mem\n\t" - "CBNZ_w $tmp, loop\n\t" - "done:\n\t" - "CSET_w $res, eq" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - Label loop, done; - __ bind(loop); - __ ldxr_w($tmp$$Register, base); - __ cmp_w($tmp$$Register, $oldval$$Register); - __ b(done, ne); - __ stxr_w($tmp$$Register, $newval$$Register, base); - __ cbnz_w($tmp$$Register, loop); - __ bind(done); - __ cset_w($res$$Register, eq); - %} - ins_pipe( long_memory_op ); -%} - -// tmp must use iRegI instead of iRegN until 8051805 is fixed. -instruct compareAndSwapN_bool(memoryex mem, iRegN oldval, iRegN newval, iRegI res, iRegI tmp, flagsReg ccr) %{ - match(Set res (CompareAndSwapN mem (Binary oldval newval))); - effect( KILL ccr, TEMP tmp); - size(24); - format %{ "loop:\n\t" - "LDXR_w $tmp, $mem\t! If $oldval==[$mem] Then store $newval into [$mem]\n\t" - "CMP_w $tmp, $oldval\n\t" - "B.ne done\n\t" - "STXR_w $tmp, $newval, $mem\n\t" - "CBNZ_w $tmp, loop\n\t" - "done:\n\t" - "CSET_w $res, eq" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - Label loop, done; - __ bind(loop); - __ ldxr_w($tmp$$Register, base); - __ cmp_w($tmp$$Register, $oldval$$Register); - __ b(done, ne); - __ stxr_w($tmp$$Register, $newval$$Register, base); - __ cbnz_w($tmp$$Register, loop); - __ bind(done); - __ cset_w($res$$Register, eq); - %} - ins_pipe( long_memory_op ); -%} - -instruct compareAndSwapP_bool(memoryex mem, iRegP oldval, iRegP newval, iRegI res, iRegI tmp, flagsReg ccr) %{ - match(Set res (CompareAndSwapP mem (Binary oldval newval))); - effect( KILL ccr, TEMP tmp); - size(24); - format %{ "loop:\n\t" - "LDXR $tmp, $mem\t! If $oldval==[$mem] Then store $newval into [$mem]\n\t" - "CMP $tmp, $oldval\n\t" - "B.ne done\n\t" - "STXR $tmp, $newval, $mem\n\t" - "CBNZ_w $tmp, loop\n\t" - "done:\n\t" - "CSET_w $res, eq" %} - ins_encode %{ - Register base = reg_to_register_object($mem$$base); - Label loop, done; - __ bind(loop); - __ ldxr($tmp$$Register, base); - __ cmp($tmp$$Register, $oldval$$Register); - __ b(done, ne); - __ stxr($tmp$$Register, $newval$$Register, base); - __ cbnz_w($tmp$$Register, loop); - __ bind(done); - __ cset_w($res$$Register, eq); - %} - ins_pipe( long_memory_op ); -%} -#else // !AARCH64 instruct compareAndSwapL_bool(memoryex mem, iRegL oldval, iRegLd newval, iRegI res, iRegLd tmp, flagsReg ccr ) %{ match(Set res (CompareAndSwapL mem (Binary oldval newval))); effect( KILL ccr, TEMP tmp); @@ -7488,32 +5580,7 @@ instruct compareAndSwapP_bool(memoryex mem, iRegP oldval, iRegP newval, iRegI re %} ins_pipe( long_memory_op ); %} -#endif // !AARCH64 -#ifdef AARCH64 -instruct xaddI_aimmI_no_res(memoryex mem, aimmI add, Universe dummy, iRegI tmp1, iRegI tmp2) %{ - predicate(n->as_LoadStore()->result_not_used()); - match(Set dummy (GetAndAddI mem add)); - effect(TEMP tmp1, TEMP tmp2); - size(16); - format %{ "loop:\n\t" - "LDXR_w $tmp1, $mem\n\t" - "ADD_w $tmp1, $tmp1, $add\n\t" - "STXR_w $tmp2, $tmp1, $mem\n\t" - "CBNZ_w $tmp2, loop" %} - - ins_encode %{ - Label loop; - Register base = reg_to_register_object($mem$$base); - __ bind(loop); - __ ldxr_w($tmp1$$Register, base); - __ add_w($tmp1$$Register, $tmp1$$Register, $add$$constant); - __ stxr_w($tmp2$$Register, $tmp1$$Register, base); - __ cbnz_w($tmp2$$Register, loop); - %} - ins_pipe( long_memory_op ); -%} -#else instruct xaddI_aimmI_no_res(memoryex mem, aimmI add, Universe dummy, iRegI tmp1, iRegI tmp2, flagsReg ccr) %{ predicate(n->as_LoadStore()->result_not_used()); match(Set dummy (GetAndAddI mem add)); @@ -7537,32 +5604,7 @@ instruct xaddI_aimmI_no_res(memoryex mem, aimmI add, Universe dummy, iRegI tmp1, %} ins_pipe( long_memory_op ); %} -#endif -#ifdef AARCH64 -instruct xaddI_reg_no_res(memoryex mem, iRegI add, Universe dummy, iRegI tmp1, iRegI tmp2) %{ - predicate(n->as_LoadStore()->result_not_used()); - match(Set dummy (GetAndAddI mem add)); - effect(TEMP tmp1, TEMP tmp2); - size(16); - format %{ "loop:\n\t" - "LDXR_w $tmp1, $mem\n\t" - "ADD_w $tmp1, $tmp1, $add\n\t" - "STXR_w $tmp2, $tmp1, $mem\n\t" - "CBNZ_w $tmp2, loop" %} - - ins_encode %{ - Label loop; - Register base = reg_to_register_object($mem$$base); - __ bind(loop); - __ ldxr_w($tmp1$$Register, base); - __ add_w($tmp1$$Register, $tmp1$$Register, $add$$Register); - __ stxr_w($tmp2$$Register, $tmp1$$Register, base); - __ cbnz_w($tmp2$$Register, loop); - %} - ins_pipe( long_memory_op ); -%} -#else instruct xaddI_reg_no_res(memoryex mem, iRegI add, Universe dummy, iRegI tmp1, iRegI tmp2, flagsReg ccr) %{ predicate(n->as_LoadStore()->result_not_used()); match(Set dummy (GetAndAddI mem add)); @@ -7586,31 +5628,7 @@ instruct xaddI_reg_no_res(memoryex mem, iRegI add, Universe dummy, iRegI tmp1, i %} ins_pipe( long_memory_op ); %} -#endif -#ifdef AARCH64 -instruct xaddI_aimmI(memoryex mem, aimmI add, iRegI res, iRegI tmp1, iRegI tmp2) %{ - match(Set res (GetAndAddI mem add)); - effect(TEMP tmp1, TEMP tmp2, TEMP res); - size(16); - format %{ "loop:\n\t" - "LDXR_w $res, $mem\n\t" - "ADD_w $tmp1, $res, $add\n\t" - "STXR_w $tmp2, $tmp1, $mem\n\t" - "CBNZ_w $tmp2, loop" %} - - ins_encode %{ - Label loop; - Register base = reg_to_register_object($mem$$base); - __ bind(loop); - __ ldxr_w($res$$Register, base); - __ add_w($tmp1$$Register, $res$$Register, $add$$constant); - __ stxr_w($tmp2$$Register, $tmp1$$Register, base); - __ cbnz_w($tmp2$$Register, loop); - %} - ins_pipe( long_memory_op ); -%} -#else instruct xaddI_aimmI(memoryex mem, aimmI add, iRegI res, iRegI tmp1, iRegI tmp2, flagsReg ccr) %{ match(Set res (GetAndAddI mem add)); effect(KILL ccr, TEMP tmp1, TEMP tmp2, TEMP res); @@ -7633,31 +5651,7 @@ instruct xaddI_aimmI(memoryex mem, aimmI add, iRegI res, iRegI tmp1, iRegI tmp2, %} ins_pipe( long_memory_op ); %} -#endif -#ifdef AARCH64 -instruct xaddI_reg(memoryex mem, iRegI add, iRegI res, iRegI tmp1, iRegI tmp2) %{ - match(Set res (GetAndAddI mem add)); - effect(TEMP tmp1, TEMP tmp2, TEMP res); - size(16); - format %{ "loop:\n\t" - "LDXR_w $res, $mem\n\t" - "ADD_w $tmp1, $res, $add\n\t" - "STXR_w $tmp2, $tmp1, $mem\n\t" - "CBNZ_w $tmp2, loop" %} - - ins_encode %{ - Label loop; - Register base = reg_to_register_object($mem$$base); - __ bind(loop); - __ ldxr_w($res$$Register, base); - __ add_w($tmp1$$Register, $res$$Register, $add$$Register); - __ stxr_w($tmp2$$Register, $tmp1$$Register, base); - __ cbnz_w($tmp2$$Register, loop); - %} - ins_pipe( long_memory_op ); -%} -#else instruct xaddI_reg(memoryex mem, iRegI add, iRegI res, iRegI tmp1, iRegI tmp2, flagsReg ccr) %{ match(Set res (GetAndAddI mem add)); effect(KILL ccr, TEMP tmp1, TEMP tmp2, TEMP res); @@ -7680,32 +5674,7 @@ instruct xaddI_reg(memoryex mem, iRegI add, iRegI res, iRegI tmp1, iRegI tmp2, f %} ins_pipe( long_memory_op ); %} -#endif -#ifdef AARCH64 -instruct xaddL_reg_no_res(memoryex mem, iRegL add, Universe dummy, iRegL tmp1, iRegI tmp2) %{ - predicate(n->as_LoadStore()->result_not_used()); - match(Set dummy (GetAndAddL mem add)); - effect(TEMP tmp1, TEMP tmp2); - size(16); - format %{ "loop:\n\t" - "LDXR $tmp1, $mem\n\t" - "ADD $tmp1, $tmp1, $add\n\t" - "STXR $tmp2, $tmp1, $mem\n\t" - "CBNZ_w $tmp2, loop" %} - - ins_encode %{ - Label loop; - Register base = reg_to_register_object($mem$$base); - __ bind(loop); - __ ldxr($tmp1$$Register, base); - __ add($tmp1$$Register, $tmp1$$Register, $add$$Register); - __ stxr($tmp2$$Register, $tmp1$$Register, base); - __ cbnz_w($tmp2$$Register, loop); - %} - ins_pipe( long_memory_op ); -%} -#else instruct xaddL_reg_no_res(memoryex mem, iRegL add, Universe dummy, iRegLd tmp1, iRegI tmp2, flagsReg ccr) %{ predicate(n->as_LoadStore()->result_not_used()); match(Set dummy (GetAndAddL mem add)); @@ -7731,32 +5700,7 @@ instruct xaddL_reg_no_res(memoryex mem, iRegL add, Universe dummy, iRegLd tmp1, %} ins_pipe( long_memory_op ); %} -#endif -#ifdef AARCH64 -instruct xaddL_imm_no_res(memoryex mem, aimmL add, Universe dummy, iRegL tmp1, iRegI tmp2) %{ - predicate(n->as_LoadStore()->result_not_used()); - match(Set dummy (GetAndAddL mem add)); - effect(TEMP tmp1, TEMP tmp2); - size(16); - format %{ "loop:\n\t" - "LDXR $tmp1, $mem\n\t" - "ADD $tmp1, $tmp1, $add\n\t" - "STXR $tmp2, $tmp1, $mem\n\t" - "CBNZ_w $tmp2, loop" %} - - ins_encode %{ - Label loop; - Register base = reg_to_register_object($mem$$base); - __ bind(loop); - __ ldxr($tmp1$$Register, base); - __ add($tmp1$$Register, $tmp1$$Register, $add$$constant); - __ stxr($tmp2$$Register, $tmp1$$Register, base); - __ cbnz_w($tmp2$$Register, loop); - %} - ins_pipe( long_memory_op ); -%} -#else // TODO: try immLRot2 instead, (0, $con$$constant) becomes // (hi($con$$constant), lo($con$$constant)) becomes instruct xaddL_immRot_no_res(memoryex mem, immLlowRot add, Universe dummy, iRegLd tmp1, iRegI tmp2, flagsReg ccr) %{ @@ -7784,31 +5728,7 @@ instruct xaddL_immRot_no_res(memoryex mem, immLlowRot add, Universe dummy, iRegL %} ins_pipe( long_memory_op ); %} -#endif -#ifdef AARCH64 -instruct xaddL_reg(memoryex mem, iRegL add, iRegL res, iRegL tmp1, iRegI tmp2) %{ - match(Set res (GetAndAddL mem add)); - effect(TEMP tmp1, TEMP tmp2, TEMP res); - size(16); - format %{ "loop:\n\t" - "LDXR $res, $mem\n\t" - "ADD $tmp1, $res, $add\n\t" - "STXR $tmp2, $tmp1, $mem\n\t" - "CBNZ_w $tmp2, loop" %} - - ins_encode %{ - Label loop; - Register base = reg_to_register_object($mem$$base); - __ bind(loop); - __ ldxr($res$$Register, base); - __ add($tmp1$$Register, $res$$Register, $add$$Register); - __ stxr($tmp2$$Register, $tmp1$$Register, base); - __ cbnz_w($tmp2$$Register, loop); - %} - ins_pipe( long_memory_op ); -%} -#else instruct xaddL_reg(memoryex mem, iRegL add, iRegLd res, iRegLd tmp1, iRegI tmp2, flagsReg ccr) %{ match(Set res (GetAndAddL mem add)); effect( KILL ccr, TEMP tmp1, TEMP tmp2, TEMP res); @@ -7833,31 +5753,7 @@ instruct xaddL_reg(memoryex mem, iRegL add, iRegLd res, iRegLd tmp1, iRegI tmp2, %} ins_pipe( long_memory_op ); %} -#endif -#ifdef AARCH64 -instruct xaddL_imm(memoryex mem, aimmL add, iRegL res, iRegL tmp1, iRegI tmp2) %{ - match(Set res (GetAndAddL mem add)); - effect(TEMP tmp1, TEMP tmp2, TEMP res); - size(16); - format %{ "loop:\n\t" - "LDXR $res, $mem\n\t" - "ADD $tmp1, $res, $add\n\t" - "STXR $tmp2, $tmp1, $mem\n\t" - "CBNZ_w $tmp2, loop" %} - - ins_encode %{ - Label loop; - Register base = reg_to_register_object($mem$$base); - __ bind(loop); - __ ldxr($res$$Register, base); - __ add($tmp1$$Register, $res$$Register, $add$$constant); - __ stxr($tmp2$$Register, $tmp1$$Register, base); - __ cbnz_w($tmp2$$Register, loop); - %} - ins_pipe( long_memory_op ); -%} -#else // TODO: try immLRot2 instead, (0, $con$$constant) becomes // (hi($con$$constant), lo($con$$constant)) becomes instruct xaddL_immRot(memoryex mem, immLlowRot add, iRegLd res, iRegLd tmp1, iRegI tmp2, flagsReg ccr) %{ @@ -7884,52 +5780,7 @@ instruct xaddL_immRot(memoryex mem, immLlowRot add, iRegLd res, iRegLd tmp1, iRe %} ins_pipe( long_memory_op ); %} -#endif -#ifdef AARCH64 -instruct xchgI(memoryex mem, iRegI newval, iRegI res, iRegI tmp) %{ - match(Set res (GetAndSetI mem newval)); - effect(TEMP tmp, TEMP res); - size(12); - format %{ "loop:\n\t" - "LDXR_w $res, $mem\n\t" - "STXR_w $tmp, $newval, $mem\n\t" - "CBNZ_w $tmp, loop" %} - - ins_encode %{ - Label loop; - Register base = reg_to_register_object($mem$$base); - __ bind(loop); - __ ldxr_w($res$$Register, base); - __ stxr_w($tmp$$Register, $newval$$Register, base); - __ cbnz_w($tmp$$Register, loop); - %} - ins_pipe( long_memory_op ); -%} - -#ifdef XXX -// Disabled until 8051805 is fixed. -instruct xchgN(memoryex mem, iRegN newval, iRegN res, iRegN tmp) %{ - match(Set res (GetAndSetN mem newval)); - effect(TEMP tmp, TEMP res); - size(12); - format %{ "loop:\n\t" - "LDXR_w $res, $mem\n\t" - "STXR_w $tmp, $newval, $mem\n\t" - "CBNZ_w $tmp, loop" %} - - ins_encode %{ - Label loop; - Register base = reg_to_register_object($mem$$base); - __ bind(loop); - __ ldxr_w($res$$Register, base); - __ stxr_w($tmp$$Register, $newval$$Register, base); - __ cbnz_w($tmp$$Register, loop); - %} - ins_pipe( long_memory_op ); -%} -#endif -#else instruct xchgI(memoryex mem, iRegI newval, iRegI res, iRegI tmp, flagsReg ccr) %{ match(Set res (GetAndSetI mem newval)); effect(KILL ccr, TEMP tmp, TEMP res); @@ -7950,29 +5801,7 @@ instruct xchgI(memoryex mem, iRegI newval, iRegI res, iRegI tmp, flagsReg ccr) % %} ins_pipe( long_memory_op ); %} -#endif -#ifdef AARCH64 -instruct xchgL(memoryex mem, iRegL newval, iRegL res, iRegI tmp) %{ - match(Set res (GetAndSetL mem newval)); - effect(TEMP tmp, TEMP res); - size(12); - format %{ "loop:\n\t" - "LDXR $res, $mem\n\t" - "STXR $tmp, $newval, $mem\n\t" - "CBNZ_w $tmp, loop" %} - - ins_encode %{ - Label loop; - Register base = reg_to_register_object($mem$$base); - __ bind(loop); - __ ldxr($res$$Register, base); - __ stxr($tmp$$Register, $newval$$Register, base); - __ cbnz_w($tmp$$Register, loop); - %} - ins_pipe( long_memory_op ); -%} -#else instruct xchgL(memoryex mem, iRegLd newval, iRegLd res, iRegI tmp, flagsReg ccr) %{ match(Set res (GetAndSetL mem newval)); effect( KILL ccr, TEMP tmp, TEMP res); @@ -7993,29 +5822,7 @@ instruct xchgL(memoryex mem, iRegLd newval, iRegLd res, iRegI tmp, flagsReg ccr) %} ins_pipe( long_memory_op ); %} -#endif // !AARCH64 -#ifdef AARCH64 -instruct xchgP(memoryex mem, iRegP newval, iRegP res, iRegI tmp) %{ - match(Set res (GetAndSetP mem newval)); - effect(TEMP tmp, TEMP res); - size(12); - format %{ "loop:\n\t" - "LDREX $res, $mem\n\t" - "STREX $tmp, $newval, $mem\n\t" - "CBNZ_w $tmp, loop" %} - - ins_encode %{ - Label loop; - Register base = reg_to_register_object($mem$$base); - __ bind(loop); - __ ldrex($res$$Register, base); - __ strex($tmp$$Register, $newval$$Register, base); - __ cbnz_w($tmp$$Register, loop); - %} - ins_pipe( long_memory_op ); -%} -#else instruct xchgP(memoryex mem, iRegP newval, iRegP res, iRegI tmp, flagsReg ccr) %{ match(Set res (GetAndSetP mem newval)); effect(KILL ccr, TEMP tmp, TEMP res); @@ -8036,7 +5843,6 @@ instruct xchgP(memoryex mem, iRegP newval, iRegP res, iRegI tmp, flagsReg ccr) % %} ins_pipe( long_memory_op ); %} -#endif // !AARCH64 //--------------------- // Subtraction Instructions @@ -8052,7 +5858,6 @@ instruct subI_reg_reg(iRegI dst, iRegI src1, iRegI src2) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct subshlI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (SubI src1 (LShiftI src2 src3))); @@ -8063,7 +5868,6 @@ instruct subshlI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif instruct subshlI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ match(Set dst (SubI src1 (LShiftI src2 src3))); @@ -8076,7 +5880,6 @@ instruct subshlI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct subsarI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (SubI src1 (RShiftI src2 src3))); @@ -8087,7 +5890,6 @@ instruct subsarI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif instruct subsarI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ match(Set dst (SubI src1 (RShiftI src2 src3))); @@ -8100,7 +5902,6 @@ instruct subsarI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct subshrI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (SubI src1 (URShiftI src2 src3))); @@ -8111,7 +5912,6 @@ instruct subshrI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif instruct subshrI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ match(Set dst (SubI src1 (URShiftI src2 src3))); @@ -8124,7 +5924,6 @@ instruct subshrI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct rsbshlI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (SubI (LShiftI src1 src2) src3)); @@ -8190,7 +5989,6 @@ instruct rsbshrI_reg_imm_reg(iRegI dst, iRegI src1, immU5 src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif // Immediate Subtraction instruct subI_reg_aimmI(iRegI dst, iRegI src1, aimmI src2) %{ @@ -8215,7 +6013,6 @@ instruct subI_reg_immRotneg(iRegI dst, iRegI src1, aimmIneg src2) %{ ins_pipe(ialu_reg_imm); %} -#ifndef AARCH64 instruct subI_immRot_reg(iRegI dst, immIRot src1, iRegI src2) %{ match(Set dst (SubI src1 src2)); @@ -8226,21 +6023,8 @@ instruct subI_immRot_reg(iRegI dst, immIRot src1, iRegI src2) %{ %} ins_pipe(ialu_zero_reg); %} -#endif // Register Subtraction -#ifdef AARCH64 -instruct subL_reg_reg(iRegL dst, iRegL src1, iRegL src2) %{ - match(Set dst (SubL src1 src2)); - - size(4); - format %{ "SUB $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ sub($dst$$Register, $src1$$Register, $src2$$Register); - %} - ins_pipe(ialu_reg_reg); -%} -#else instruct subL_reg_reg(iRegL dst, iRegL src1, iRegL src2, flagsReg icc ) %{ match(Set dst (SubL src1 src2)); effect (KILL icc); @@ -8254,36 +6038,9 @@ instruct subL_reg_reg(iRegL dst, iRegL src1, iRegL src2, flagsReg icc ) %{ %} ins_pipe(ialu_reg_reg); %} -#endif -#ifdef AARCH64 -// Immediate Subtraction -instruct subL_reg_aimm(iRegL dst, iRegL src1, aimmL src2) %{ - match(Set dst (SubL src1 src2)); - - size(4); - format %{ "SUB $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ sub($dst$$Register, $src1$$Register, $src2$$constant); - %} - ins_pipe(ialu_reg_imm); -%} - -instruct subL_reg_immLneg(iRegL dst, iRegL src1, aimmLneg src2) %{ - match(Set dst (AddL src1 src2)); - - size(4); - format %{ "SUB $dst,$src1,-($src2)\t! long" %} - ins_encode %{ - __ sub($dst$$Register, $src1$$Register, -$src2$$constant); - %} - ins_pipe(ialu_reg_imm); -%} -#else // TODO -#endif -#ifndef AARCH64 // Immediate Subtraction // TODO: try immLRot2 instead, (0, $con$$constant) becomes // (hi($con$$constant), lo($con$$constant)) becomes @@ -8315,7 +6072,6 @@ instruct negL_reg_reg(iRegL dst, immL0 zero, iRegL src2, flagsReg icc) %{ %} ins_pipe(ialu_zero_reg); %} -#endif // !AARCH64 // Multiplication Instructions // Integer Multiplication @@ -8331,17 +6087,6 @@ instruct mulI_reg_reg(iRegI dst, iRegI src1, iRegI src2) %{ ins_pipe(imul_reg_reg); %} -#ifdef AARCH64 -instruct mulL_reg_reg(iRegL dst, iRegL src1, iRegL src2) %{ - match(Set dst (MulL src1 src2)); - size(4); - format %{ "MUL $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ mul($dst$$Register, $src1$$Register, $src2$$Register); - %} - ins_pipe(imul_reg_reg); -%} -#else instruct mulL_lo1_hi2(iRegL dst, iRegL src1, iRegL src2) %{ effect(DEF dst, USE src1, USE src2); size(4); @@ -8383,22 +6128,9 @@ instruct mulL_reg_reg(iRegL dst, iRegL src1, iRegL src2) %{ mulL_lo1_lo2(dst, src1, src2); %} %} -#endif // !AARCH64 // Integer Division // Register Division -#ifdef AARCH64 -instruct divI_reg_reg(iRegI dst, iRegI src1, iRegI src2) %{ - match(Set dst (DivI src1 src2)); - - size(4); - format %{ "SDIV $dst,$src1,$src2\t! 32-bit" %} - ins_encode %{ - __ sdiv_w($dst$$Register, $src1$$Register, $src2$$Register); - %} - ins_pipe(ialu_reg_reg); // FIXME -%} -#else instruct divI_reg_reg(R1RegI dst, R0RegI src1, R2RegI src2, LRRegP lr, flagsReg ccr) %{ match(Set dst (DivI src1 src2)); effect( KILL ccr, KILL src1, KILL src2, KILL lr); @@ -8410,21 +6142,8 @@ instruct divI_reg_reg(R1RegI dst, R0RegI src1, R2RegI src2, LRRegP lr, flagsReg %} ins_pipe(sdiv_reg_reg); %} -#endif // Register Long Division -#ifdef AARCH64 -instruct divL_reg_reg(iRegL dst, iRegL src1, iRegL src2) %{ - match(Set dst (DivL src1 src2)); - - size(4); - format %{ "SDIV $dst,$src1,$src2" %} - ins_encode %{ - __ sdiv($dst$$Register, $src1$$Register, $src2$$Register); - %} - ins_pipe(ialu_reg_reg); // FIXME -%} -#else instruct divL_reg_reg(R0R1RegL dst, R2R3RegL src1, R0R1RegL src2) %{ match(Set dst (DivL src1 src2)); effect(CALL); @@ -8436,38 +6155,9 @@ instruct divL_reg_reg(R0R1RegL dst, R2R3RegL src1, R0R1RegL src2) %{ %} ins_pipe(divL_reg_reg); %} -#endif // Integer Remainder // Register Remainder -#ifdef AARCH64 -#ifdef TODO -instruct msubI_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ - match(Set dst (SubI src1 (MulI src2 src3))); - - size(4); - format %{ "MSUB $dst,$src2,$src3,$src1\t! 32-bit\n\t" %} - ins_encode %{ - __ msub_w($dst$$Register, $src2$$Register, $src3$$Register, $src1$$Register); - %} - ins_pipe(ialu_reg_reg); // FIXME -%} -#endif - -instruct modI_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI temp) %{ - match(Set dst (ModI src1 src2)); - effect(TEMP temp); - - size(8); - format %{ "SDIV $temp,$src1,$src2\t! 32-bit\n\t" - "MSUB $dst,$src2,$temp,$src1\t! 32-bit\n\t" %} - ins_encode %{ - __ sdiv_w($temp$$Register, $src1$$Register, $src2$$Register); - __ msub_w($dst$$Register, $src2$$Register, $temp$$Register, $src1$$Register); - %} - ins_pipe(ialu_reg_reg); // FIXME -%} -#else instruct modI_reg_reg(R0RegI dst, R0RegI src1, R2RegI src2, R1RegI temp, LRRegP lr, flagsReg ccr ) %{ match(Set dst (ModI src1 src2)); effect( KILL ccr, KILL temp, KILL src2, KILL lr); @@ -8478,24 +6168,8 @@ instruct modI_reg_reg(R0RegI dst, R0RegI src1, R2RegI src2, R1RegI temp, LRRegP %} ins_pipe(sdiv_reg_reg); %} -#endif // Register Long Remainder -#ifdef AARCH64 -instruct modL_reg_reg(iRegL dst, iRegL src1, iRegL src2, iRegL temp) %{ - match(Set dst (ModL src1 src2)); - effect(TEMP temp); - - size(8); - format %{ "SDIV $temp,$src1,$src2\n\t" - "MSUB $dst,$src2,$temp,$src1" %} - ins_encode %{ - __ sdiv($temp$$Register, $src1$$Register, $src2$$Register); - __ msub($dst$$Register, $src2$$Register, $temp$$Register, $src1$$Register); - %} - ins_pipe(ialu_reg_reg); // FIXME -%} -#else instruct modL_reg_reg(R0R1RegL dst, R2R3RegL src1, R0R1RegL src2) %{ match(Set dst (ModL src1 src2)); effect(CALL); @@ -8507,7 +6181,6 @@ instruct modL_reg_reg(R0R1RegL dst, R2R3RegL src1, R0R1RegL src2) %{ %} ins_pipe(divL_reg_reg); %} -#endif // Integer Shift Instructions @@ -8516,17 +6189,10 @@ instruct shlI_reg_reg(iRegI dst, iRegI src1, iRegI src2) %{ match(Set dst (LShiftI src1 src2)); size(4); -#ifdef AARCH64 - format %{ "LSLV $dst,$src1,$src2\t! int" %} - ins_encode %{ - __ lslv_w($dst$$Register, $src1$$Register, $src2$$Register); - %} -#else format %{ "LSL $dst,$src1,$src2 \n\t" %} ins_encode %{ __ mov($dst$$Register, AsmOperand($src1$$Register, lsl, $src2$$Register)); %} -#endif ins_pipe(ialu_reg_reg); %} @@ -8535,21 +6201,13 @@ instruct shlI_reg_imm5(iRegI dst, iRegI src1, immU5 src2) %{ match(Set dst (LShiftI src1 src2)); size(4); -#ifdef AARCH64 - format %{ "LSL_w $dst,$src1,$src2\t! int" %} - ins_encode %{ - __ _lsl($dst$$Register, $src1$$Register, $src2$$constant); - %} -#else format %{ "LSL $dst,$src1,$src2\t! int" %} ins_encode %{ __ logical_shift_left($dst$$Register, $src1$$Register, $src2$$constant); %} -#endif ins_pipe(ialu_reg_imm); %} -#ifndef AARCH64 instruct shlL_reg_reg_merge_hi(iRegL dst, iRegL src1, iRegI src2) %{ effect(USE_DEF dst, USE src1, USE src2); size(4); @@ -8587,40 +6245,18 @@ instruct shlL_reg_reg_overlap(iRegL dst, iRegL src1, iRegI src2, flagsReg ccr) % %} ins_pipe(ialu_reg_reg); %} -#endif // !AARCH64 instruct shlL_reg_reg(iRegL dst, iRegL src1, iRegI src2) %{ match(Set dst (LShiftL src1 src2)); -#ifdef AARCH64 - size(4); - format %{ "LSLV $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ lslv($dst$$Register, $src1$$Register, $src2$$Register); - %} - ins_pipe(ialu_reg_reg); -#else expand %{ flagsReg ccr; shlL_reg_reg_overlap(dst, src1, src2, ccr); shlL_reg_reg_merge_hi(dst, src1, src2); shlL_reg_reg_merge_lo(dst, src1, src2); %} -#endif %} -#ifdef AARCH64 -instruct shlL_reg_imm6(iRegL dst, iRegL src1, immU6 src2) %{ - match(Set dst (LShiftL src1 src2)); - - size(4); - format %{ "LSL $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ logical_shift_left($dst$$Register, $src1$$Register, $src2$$constant); - %} - ins_pipe(ialu_reg_imm); -%} -#else // Register Shift Left Immediate instruct shlL_reg_imm6(iRegL dst, iRegL src1, immU6Big src2) %{ match(Set dst (LShiftL src1 src2)); @@ -8655,23 +6291,15 @@ instruct shlL_reg_imm5(iRegL dst, iRegL src1, immU5 src2) %{ %} ins_pipe(ialu_reg_imm); %} -#endif // !AARCH64 // Register Arithmetic Shift Right instruct sarI_reg_reg(iRegI dst, iRegI src1, iRegI src2) %{ match(Set dst (RShiftI src1 src2)); size(4); -#ifdef AARCH64 - format %{ "ASRV $dst,$src1,$src2\t! int" %} - ins_encode %{ - __ asrv_w($dst$$Register, $src1$$Register, $src2$$Register); - %} -#else format %{ "ASR $dst,$src1,$src2\t! int" %} ins_encode %{ __ mov($dst$$Register, AsmOperand($src1$$Register, asr, $src2$$Register)); %} -#endif ins_pipe(ialu_reg_reg); %} @@ -8680,21 +6308,13 @@ instruct sarI_reg_imm5(iRegI dst, iRegI src1, immU5 src2) %{ match(Set dst (RShiftI src1 src2)); size(4); -#ifdef AARCH64 - format %{ "ASR_w $dst,$src1,$src2" %} - ins_encode %{ - __ _asr_w($dst$$Register, $src1$$Register, $src2$$constant); - %} -#else format %{ "ASR $dst,$src1,$src2" %} ins_encode %{ __ mov($dst$$Register, AsmOperand($src1$$Register, asr, $src2$$constant)); %} -#endif ins_pipe(ialu_reg_imm); %} -#ifndef AARCH64 // Register Shift Right Arithmetic Long instruct sarL_reg_reg_merge_lo(iRegL dst, iRegL src1, iRegI src2) %{ effect(USE_DEF dst, USE src1, USE src2); @@ -8733,41 +6353,19 @@ instruct sarL_reg_reg_overlap(iRegL dst, iRegL src1, iRegI src2, flagsReg ccr) % %} ins_pipe(ialu_reg_reg); %} -#endif // !AARCH64 instruct sarL_reg_reg(iRegL dst, iRegL src1, iRegI src2) %{ match(Set dst (RShiftL src1 src2)); -#ifdef AARCH64 - size(4); - format %{ "ASRV $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ asrv($dst$$Register, $src1$$Register, $src2$$Register); - %} - ins_pipe(ialu_reg_reg); -#else expand %{ flagsReg ccr; sarL_reg_reg_overlap(dst, src1, src2, ccr); sarL_reg_reg_merge_lo(dst, src1, src2); sarL_reg_reg_merge_hi(dst, src1, src2); %} -#endif %} // Register Shift Left Immediate -#ifdef AARCH64 -instruct sarL_reg_imm6(iRegL dst, iRegL src1, immU6 src2) %{ - match(Set dst (RShiftL src1 src2)); - - size(4); - format %{ "ASR $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ _asr($dst$$Register, $src1$$Register, $src2$$constant); - %} - ins_pipe(ialu_reg_imm); -%} -#else instruct sarL_reg_imm6(iRegL dst, iRegL src1, immU6Big src2) %{ match(Set dst (RShiftL src1 src2)); @@ -8801,23 +6399,15 @@ instruct sarL_reg_imm5(iRegL dst, iRegL src1, immU5 src2) %{ %} ins_pipe(ialu_reg_imm); %} -#endif // Register Shift Right instruct shrI_reg_reg(iRegI dst, iRegI src1, iRegI src2) %{ match(Set dst (URShiftI src1 src2)); size(4); -#ifdef AARCH64 - format %{ "LSRV $dst,$src1,$src2\t! int" %} - ins_encode %{ - __ lsrv_w($dst$$Register, $src1$$Register, $src2$$Register); - %} -#else format %{ "LSR $dst,$src1,$src2\t! int" %} ins_encode %{ __ mov($dst$$Register, AsmOperand($src1$$Register, lsr, $src2$$Register)); %} -#endif ins_pipe(ialu_reg_reg); %} @@ -8826,21 +6416,13 @@ instruct shrI_reg_imm5(iRegI dst, iRegI src1, immU5 src2) %{ match(Set dst (URShiftI src1 src2)); size(4); -#ifdef AARCH64 - format %{ "LSR_w $dst,$src1,$src2" %} - ins_encode %{ - __ _lsr_w($dst$$Register, $src1$$Register, $src2$$constant); - %} -#else format %{ "LSR $dst,$src1,$src2" %} ins_encode %{ __ mov($dst$$Register, AsmOperand($src1$$Register, lsr, $src2$$constant)); %} -#endif ins_pipe(ialu_reg_imm); %} -#ifndef AARCH64 // Register Shift Right instruct shrL_reg_reg_merge_lo(iRegL dst, iRegL src1, iRegI src2) %{ effect(USE_DEF dst, USE src1, USE src2); @@ -8879,41 +6461,19 @@ instruct shrL_reg_reg_overlap(iRegL dst, iRegL src1, iRegI src2, flagsReg ccr) % %} ins_pipe(ialu_reg_reg); %} -#endif // !AARCH64 instruct shrL_reg_reg(iRegL dst, iRegL src1, iRegI src2) %{ match(Set dst (URShiftL src1 src2)); -#ifdef AARCH64 - size(4); - format %{ "LSRV $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ lsrv($dst$$Register, $src1$$Register, $src2$$Register); - %} - ins_pipe(ialu_reg_reg); -#else expand %{ flagsReg ccr; shrL_reg_reg_overlap(dst, src1, src2, ccr); shrL_reg_reg_merge_lo(dst, src1, src2); shrL_reg_reg_merge_hi(dst, src1, src2); %} -#endif %} // Register Shift Right Immediate -#ifdef AARCH64 -instruct shrL_reg_imm6(iRegL dst, iRegL src1, immU6 src2) %{ - match(Set dst (URShiftL src1 src2)); - - size(4); - format %{ "LSR $dst,$src1,$src2" %} - ins_encode %{ - __ _lsr($dst$$Register, $src1$$Register, $src2$$constant); - %} - ins_pipe(ialu_reg_imm); -%} -#else instruct shrL_reg_imm6(iRegL dst, iRegL src1, immU6Big src2) %{ match(Set dst (URShiftL src1 src2)); @@ -8948,7 +6508,6 @@ instruct shrL_reg_imm5(iRegL dst, iRegL src1, immU5 src2) %{ %} ins_pipe(ialu_reg_imm); %} -#endif // !AARCH64 instruct shrP_reg_imm5(iRegX dst, iRegP src1, immU5 src2) %{ @@ -9146,7 +6705,6 @@ instruct andI_reg_reg(iRegI dst, iRegI src1, iRegI src2) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct andshlI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (AndI src1 (LShiftI src2 src3))); @@ -9157,7 +6715,6 @@ instruct andshlI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif instruct andshlI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ match(Set dst (AndI src1 (LShiftI src2 src3))); @@ -9170,7 +6727,6 @@ instruct andshlI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct andsarI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (AndI src1 (RShiftI src2 src3))); @@ -9181,7 +6737,6 @@ instruct andsarI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif instruct andsarI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ match(Set dst (AndI src1 (RShiftI src2 src3))); @@ -9194,7 +6749,6 @@ instruct andsarI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct andshrI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (AndI src1 (URShiftI src2 src3))); @@ -9205,7 +6759,6 @@ instruct andshrI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif instruct andshrI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ match(Set dst (AndI src1 (URShiftI src2 src3))); @@ -9230,7 +6783,6 @@ instruct andI_reg_limm(iRegI dst, iRegI src1, limmI src2) %{ ins_pipe(ialu_reg_imm); %} -#ifndef AARCH64 instruct andI_reg_limmn(iRegI dst, iRegI src1, limmIn src2) %{ match(Set dst (AndI src1 src2)); @@ -9241,43 +6793,21 @@ instruct andI_reg_limmn(iRegI dst, iRegI src1, limmIn src2) %{ %} ins_pipe(ialu_reg_imm); %} -#endif // Register And Long instruct andL_reg_reg(iRegL dst, iRegL src1, iRegL src2) %{ match(Set dst (AndL src1 src2)); ins_cost(DEFAULT_COST); -#ifdef AARCH64 - size(4); - format %{ "AND $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ andr($dst$$Register, $src1$$Register, $src2$$Register); - %} -#else size(8); format %{ "AND $dst,$src1,$src2\t! long" %} ins_encode %{ __ andr($dst$$Register, $src1$$Register, $src2$$Register); __ andr($dst$$Register->successor(), $src1$$Register->successor(), $src2$$Register->successor()); %} -#endif ins_pipe(ialu_reg_reg); %} -#ifdef AARCH64 -// Immediate And -instruct andL_reg_limm(iRegL dst, iRegL src1, limmL src2) %{ - match(Set dst (AndL src1 src2)); - - size(4); - format %{ "AND $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ andr($dst$$Register, $src1$$Register, (uintx)$src2$$constant); - %} - ins_pipe(ialu_reg_imm); -%} -#else // TODO: try immLRot2 instead, (0, $con$$constant) becomes // (hi($con$$constant), lo($con$$constant)) becomes instruct andL_reg_immRot(iRegL dst, iRegL src1, immLlowRot con) %{ @@ -9291,7 +6821,6 @@ instruct andL_reg_immRot(iRegL dst, iRegL src1, immLlowRot con) %{ %} ins_pipe(ialu_reg_imm); %} -#endif // Or Instructions // Register Or @@ -9306,7 +6835,6 @@ instruct orI_reg_reg(iRegI dst, iRegI src1, iRegI src2) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct orshlI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (OrI src1 (LShiftI src2 src3))); @@ -9317,7 +6845,6 @@ instruct orshlI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif instruct orshlI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ match(Set dst (OrI src1 (LShiftI src2 src3))); @@ -9330,7 +6857,6 @@ instruct orshlI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct orsarI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (OrI src1 (RShiftI src2 src3))); @@ -9341,7 +6867,6 @@ instruct orsarI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif instruct orsarI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ match(Set dst (OrI src1 (RShiftI src2 src3))); @@ -9354,7 +6879,6 @@ instruct orsarI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct orshrI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (OrI src1 (URShiftI src2 src3))); @@ -9365,7 +6889,6 @@ instruct orshrI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif instruct orshrI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ match(Set dst (OrI src1 (URShiftI src2 src3))); @@ -9396,13 +6919,6 @@ instruct orL_reg_reg(iRegL dst, iRegL src1, iRegL src2) %{ match(Set dst (OrL src1 src2)); ins_cost(DEFAULT_COST); -#ifdef AARCH64 - size(4); - format %{ "OR $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ orr($dst$$Register, $src1$$Register, $src2$$Register); - %} -#else size(8); format %{ "OR $dst.lo,$src1.lo,$src2.lo\t! long\n\t" "OR $dst.hi,$src1.hi,$src2.hi" %} @@ -9410,22 +6926,9 @@ instruct orL_reg_reg(iRegL dst, iRegL src1, iRegL src2) %{ __ orr($dst$$Register, $src1$$Register, $src2$$Register); __ orr($dst$$Register->successor(), $src1$$Register->successor(), $src2$$Register->successor()); %} -#endif ins_pipe(ialu_reg_reg); %} -#ifdef AARCH64 -instruct orL_reg_limm(iRegL dst, iRegL src1, limmL src2) %{ - match(Set dst (OrL src1 src2)); - - size(4); - format %{ "ORR $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ orr($dst$$Register, $src1$$Register, (uintx)$src2$$constant); - %} - ins_pipe(ialu_reg_imm); -%} -#else // TODO: try immLRot2 instead, (0, $con$$constant) becomes // (hi($con$$constant), lo($con$$constant)) becomes instruct orL_reg_immRot(iRegL dst, iRegL src1, immLlowRot con) %{ @@ -9440,7 +6943,6 @@ instruct orL_reg_immRot(iRegL dst, iRegL src1, immLlowRot con) %{ %} ins_pipe(ialu_reg_imm); %} -#endif #ifdef TODO // Use SPRegP to match Rthread (TLS register) without spilling. @@ -9470,7 +6972,6 @@ instruct xorI_reg_reg(iRegI dst, iRegI src1, iRegI src2) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct xorshlI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (XorI src1 (LShiftI src2 src3))); @@ -9481,7 +6982,6 @@ instruct xorshlI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif instruct xorshlI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ match(Set dst (XorI src1 (LShiftI src2 src3))); @@ -9494,7 +6994,6 @@ instruct xorshlI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct xorsarI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (XorI src1 (RShiftI src2 src3))); @@ -9505,7 +7004,6 @@ instruct xorsarI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif instruct xorsarI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ match(Set dst (XorI src1 (RShiftI src2 src3))); @@ -9518,7 +7016,6 @@ instruct xorsarI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ ins_pipe(ialu_reg_reg); %} -#ifndef AARCH64 instruct xorshrI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ match(Set dst (XorI src1 (URShiftI src2 src3))); @@ -9529,7 +7026,6 @@ instruct xorshrI_reg_reg_reg(iRegI dst, iRegI src1, iRegI src2, iRegI src3) %{ %} ins_pipe(ialu_reg_reg); %} -#endif instruct xorshrI_reg_reg_imm(iRegI dst, iRegI src1, iRegI src2, immU5 src3) %{ match(Set dst (XorI src1 (URShiftI src2 src3))); @@ -9558,13 +7054,6 @@ instruct xorI_reg_imm(iRegI dst, iRegI src1, limmI src2) %{ instruct xorL_reg_reg(iRegL dst, iRegL src1, iRegL src2) %{ match(Set dst (XorL src1 src2)); ins_cost(DEFAULT_COST); -#ifdef AARCH64 - size(4); - format %{ "XOR $dst,$src1,$src2\t! long" %} - ins_encode %{ - __ eor($dst$$Register, $src1$$Register, $src2$$Register); - %} -#else size(8); format %{ "XOR $dst.hi,$src1.hi,$src2.hi\t! long\n\t" "XOR $dst.lo,$src1.lo,$src2.lo\t! long" %} @@ -9572,22 +7061,9 @@ instruct xorL_reg_reg(iRegL dst, iRegL src1, iRegL src2) %{ __ eor($dst$$Register, $src1$$Register, $src2$$Register); __ eor($dst$$Register->successor(), $src1$$Register->successor(), $src2$$Register->successor()); %} -#endif ins_pipe(ialu_reg_reg); %} -#ifdef AARCH64 -instruct xorL_reg_limmL(iRegL dst, iRegL src1, limmL con) %{ - match(Set dst (XorL src1 con)); - ins_cost(DEFAULT_COST); - size(4); - format %{ "EOR $dst,$src1,$con\t! long" %} - ins_encode %{ - __ eor($dst$$Register, $src1$$Register, (uintx)$con$$constant); - %} - ins_pipe(ialu_reg_imm); -%} -#else // TODO: try immLRot2 instead, (0, $con$$constant) becomes // (hi($con$$constant), lo($con$$constant)) becomes instruct xorL_reg_immRot(iRegL dst, iRegL src1, immLlowRot con) %{ @@ -9602,22 +7078,11 @@ instruct xorL_reg_immRot(iRegL dst, iRegL src1, immLlowRot con) %{ %} ins_pipe(ialu_reg_imm); %} -#endif // AARCH64 //----------Convert to Boolean------------------------------------------------- instruct convI2B( iRegI dst, iRegI src, flagsReg ccr ) %{ match(Set dst (Conv2B src)); effect(KILL ccr); -#ifdef AARCH64 - size(8); - ins_cost(DEFAULT_COST*2); - format %{ "cmp_32 $src,ZR\n\t" - "cset_w $dst, ne" %} - ins_encode %{ - __ cmp_32($src$$Register, ZR); - __ cset_w($dst$$Register, ne); - %} -#else size(12); ins_cost(DEFAULT_COST*2); format %{ "TST $src,$src \n\t" @@ -9628,23 +7093,12 @@ instruct convI2B( iRegI dst, iRegI src, flagsReg ccr ) %{ __ mov($dst$$Register, 0); __ mov($dst$$Register, 1, ne); %} -#endif ins_pipe(ialu_reg_ialu); %} instruct convP2B( iRegI dst, iRegP src, flagsReg ccr ) %{ match(Set dst (Conv2B src)); effect(KILL ccr); -#ifdef AARCH64 - size(8); - ins_cost(DEFAULT_COST*2); - format %{ "CMP $src,ZR\n\t" - "cset $dst, ne" %} - ins_encode %{ - __ cmp($src$$Register, ZR); - __ cset($dst$$Register, ne); - %} -#else size(12); ins_cost(DEFAULT_COST*2); format %{ "TST $src,$src \n\t" @@ -9655,23 +7109,12 @@ instruct convP2B( iRegI dst, iRegP src, flagsReg ccr ) %{ __ mov($dst$$Register, 0); __ mov($dst$$Register, 1, ne); %} -#endif ins_pipe(ialu_reg_ialu); %} instruct cmpLTMask_reg_reg( iRegI dst, iRegI p, iRegI q, flagsReg ccr ) %{ match(Set dst (CmpLTMask p q)); effect( KILL ccr ); -#ifdef AARCH64 - size(8); - ins_cost(DEFAULT_COST*2); - format %{ "CMP_w $p,$q\n\t" - "CSETM_w $dst, lt" %} - ins_encode %{ - __ cmp_w($p$$Register, $q$$Register); - __ csetm_w($dst$$Register, lt); - %} -#else ins_cost(DEFAULT_COST*3); format %{ "CMP $p,$q\n\t" "MOV $dst, #0\n\t" @@ -9681,23 +7124,12 @@ instruct cmpLTMask_reg_reg( iRegI dst, iRegI p, iRegI q, flagsReg ccr ) %{ __ mov($dst$$Register, 0); __ mvn($dst$$Register, 0, lt); %} -#endif ins_pipe(ialu_reg_reg_ialu); %} instruct cmpLTMask_reg_imm( iRegI dst, iRegI p, aimmI q, flagsReg ccr ) %{ match(Set dst (CmpLTMask p q)); effect( KILL ccr ); -#ifdef AARCH64 - size(8); - ins_cost(DEFAULT_COST*2); - format %{ "CMP_w $p,$q\n\t" - "CSETM_w $dst, lt" %} - ins_encode %{ - __ cmp_w($p$$Register, $q$$constant); - __ csetm_w($dst$$Register, lt); - %} -#else ins_cost(DEFAULT_COST*3); format %{ "CMP $p,$q\n\t" "MOV $dst, #0\n\t" @@ -9707,27 +7139,9 @@ instruct cmpLTMask_reg_imm( iRegI dst, iRegI p, aimmI q, flagsReg ccr ) %{ __ mov($dst$$Register, 0); __ mvn($dst$$Register, 0, lt); %} -#endif ins_pipe(ialu_reg_reg_ialu); %} -#ifdef AARCH64 -instruct cadd_cmpLTMask3( iRegI dst, iRegI p, iRegI q, iRegI y, iRegI x, flagsReg ccr ) %{ - match(Set dst (AddI (AndI (CmpLTMask p q) y) x)); - effect( TEMP dst, KILL ccr ); - size(12); - ins_cost(DEFAULT_COST*3); - format %{ "CMP_w $p,$q\n\t" - "ADD_w $dst,$y,$x\n\t" - "CSEL_w $dst,$dst,$x,lt" %} - ins_encode %{ - __ cmp_w($p$$Register, $q$$Register); - __ add_w($dst$$Register, $y$$Register, $x$$Register); - __ csel_w($dst$$Register, $dst$$Register, $x$$Register, lt); - %} - ins_pipe( cadd_cmpltmask ); -%} -#else instruct cadd_cmpLTMask3( iRegI p, iRegI q, iRegI y, iRegI z, flagsReg ccr ) %{ match(Set z (AddI (AndI (CmpLTMask p q) y) z)); effect( KILL ccr ); @@ -9740,25 +7154,7 @@ instruct cadd_cmpLTMask3( iRegI p, iRegI q, iRegI y, iRegI z, flagsReg ccr ) %{ %} ins_pipe( cadd_cmpltmask ); %} -#endif -#ifdef AARCH64 -instruct cadd_cmpLTMask4( iRegI dst, iRegI p, aimmI q, iRegI y, iRegI x, flagsReg ccr ) %{ - match(Set dst (AddI (AndI (CmpLTMask p q) y) x)); - effect( TEMP dst, KILL ccr ); - size(12); - ins_cost(DEFAULT_COST*3); - format %{ "CMP_w $p,$q\n\t" - "ADD_w $dst,$y,$x\n\t" - "CSEL_w $dst,$dst,$x,lt" %} - ins_encode %{ - __ cmp_w($p$$Register, $q$$constant); - __ add_w($dst$$Register, $y$$Register, $x$$Register); - __ csel_w($dst$$Register, $dst$$Register, $x$$Register, lt); - %} - ins_pipe( cadd_cmpltmask ); -%} -#else // FIXME: remove unused "dst" instruct cadd_cmpLTMask4( iRegI dst, iRegI p, aimmI q, iRegI y, iRegI z, flagsReg ccr ) %{ match(Set z (AddI (AndI (CmpLTMask p q) y) z)); @@ -9772,25 +7168,7 @@ instruct cadd_cmpLTMask4( iRegI dst, iRegI p, aimmI q, iRegI y, iRegI z, flagsRe %} ins_pipe( cadd_cmpltmask ); %} -#endif // !AARCH64 -#ifdef AARCH64 -instruct cadd_cmpLTMask( iRegI dst, iRegI p, iRegI q, iRegI y, flagsReg ccr ) %{ - match(Set dst (AddI (AndI (CmpLTMask p q) y) (SubI p q))); - effect( TEMP dst, KILL ccr ); - size(12); - ins_cost(DEFAULT_COST*3); - format %{ "SUBS_w $p,$p,$q\n\t" - "ADD_w $dst,$y,$p\n\t" - "CSEL_w $dst,$dst,$p,lt" %} - ins_encode %{ - __ subs_w($p$$Register, $p$$Register, $q$$Register); - __ add_w($dst$$Register, $y$$Register, $p$$Register); - __ csel_w($dst$$Register, $dst$$Register, $p$$Register, lt); - %} - ins_pipe( cadd_cmpltmask ); // FIXME -%} -#else instruct cadd_cmpLTMask( iRegI p, iRegI q, iRegI y, flagsReg ccr ) %{ match(Set p (AddI (AndI (CmpLTMask p q) y) (SubI p q))); effect( KILL ccr ); @@ -9803,7 +7181,6 @@ instruct cadd_cmpLTMask( iRegI p, iRegI q, iRegI y, flagsReg ccr ) %{ %} ins_pipe( cadd_cmpltmask ); %} -#endif //----------Arithmetic Conversion Instructions--------------------------------- // The conversions operations are all Alpha sorted. Please keep it that way! @@ -9821,27 +7198,6 @@ instruct convD2F_reg(regF dst, regD src) %{ // Convert a double to an int in a float register. // If the double is a NAN, stuff a zero in instead. -#ifdef AARCH64 -instruct convD2I_reg_reg(iRegI dst, regD src) %{ - match(Set dst (ConvD2I src)); - ins_cost(DEFAULT_COST*2 + MEMORY_REF_COST*2 + BRANCH_COST); // FIXME - format %{ "FCVTZS_wd $dst, $src" %} - ins_encode %{ - __ fcvtzs_wd($dst$$Register, $src$$FloatRegister); - %} - ins_pipe(fcvtD2I); -%} - -instruct convD2L_reg_reg(iRegL dst, regD src) %{ - match(Set dst (ConvD2L src)); - ins_cost(DEFAULT_COST*2 + MEMORY_REF_COST*2 + BRANCH_COST); // FIXME - format %{ "FCVTZS_xd $dst, $src" %} - ins_encode %{ - __ fcvtzs_xd($dst$$Register, $src$$FloatRegister); - %} - ins_pipe(fcvtD2L); -%} -#else instruct convD2I_reg_reg(iRegI dst, regD src, regF tmp) %{ match(Set dst (ConvD2I src)); effect( TEMP tmp ); @@ -9854,12 +7210,10 @@ instruct convD2I_reg_reg(iRegI dst, regD src, regF tmp) %{ %} ins_pipe(fcvtD2I); %} -#endif // Convert a double to a long in a double register. // If the double is a NAN, stuff a zero in instead. -#ifndef AARCH64 // Double to Long conversion instruct convD2L_reg(R0R1RegL dst, regD src) %{ match(Set dst (ConvD2L src)); @@ -9879,7 +7233,6 @@ instruct convD2L_reg(R0R1RegL dst, regD src) %{ %} ins_pipe(fcvtD2L); %} -#endif instruct convF2D_reg(regD dst, regF src) %{ match(Set dst (ConvF2D src)); @@ -9891,29 +7244,6 @@ instruct convF2D_reg(regD dst, regF src) %{ ins_pipe(fcvtF2D); %} -#ifdef AARCH64 -instruct convF2I_reg_reg(iRegI dst, regF src) %{ - match(Set dst (ConvF2I src)); - ins_cost(DEFAULT_COST*2 + MEMORY_REF_COST*2 + BRANCH_COST); // FIXME - size(4); - format %{ "FCVTZS_ws $dst, $src" %} - ins_encode %{ - __ fcvtzs_ws($dst$$Register, $src$$FloatRegister); - %} - ins_pipe(fcvtF2I); -%} - -instruct convF2L_reg_reg(iRegL dst, regF src) %{ - match(Set dst (ConvF2L src)); - ins_cost(DEFAULT_COST*2 + MEMORY_REF_COST*2 + BRANCH_COST); // FIXME - size(4); - format %{ "FCVTZS_xs $dst, $src" %} - ins_encode %{ - __ fcvtzs_xs($dst$$Register, $src$$FloatRegister); - %} - ins_pipe(fcvtF2L); -%} -#else instruct convF2I_reg_reg(iRegI dst, regF src, regF tmp) %{ match(Set dst (ConvF2I src)); effect( TEMP tmp ); @@ -9947,20 +7277,7 @@ instruct convF2L_reg(R0R1RegL dst, regF src, R0RegI arg1) %{ %} ins_pipe(fcvtF2L); %} -#endif -#ifdef AARCH64 -instruct convI2D_reg_reg(iRegI src, regD dst) %{ - match(Set dst (ConvI2D src)); - ins_cost(DEFAULT_COST + MEMORY_REF_COST); // FIXME - size(4); - format %{ "SCVTF_dw $dst,$src" %} - ins_encode %{ - __ scvtf_dw($dst$$FloatRegister, $src$$Register); - %} - ins_pipe(fcvtI2D); -%} -#else instruct convI2D_reg_reg(iRegI src, regD_low dst) %{ match(Set dst (ConvI2D src)); ins_cost(DEFAULT_COST + MEMORY_REF_COST); // FIXME @@ -9973,18 +7290,10 @@ instruct convI2D_reg_reg(iRegI src, regD_low dst) %{ %} ins_pipe(fcvtI2D); %} -#endif instruct convI2F_reg_reg( regF dst, iRegI src ) %{ match(Set dst (ConvI2F src)); ins_cost(DEFAULT_COST + MEMORY_REF_COST); // FIXME -#ifdef AARCH64 - size(4); - format %{ "SCVTF_sw $dst,$src" %} - ins_encode %{ - __ scvtf_sw($dst$$FloatRegister, $src$$Register); - %} -#else size(8); format %{ "FMSR $dst,$src \n\t" "FSITOS $dst, $dst"%} @@ -9992,19 +7301,11 @@ instruct convI2F_reg_reg( regF dst, iRegI src ) %{ __ fmsr($dst$$FloatRegister, $src$$Register); __ fsitos($dst$$FloatRegister, $dst$$FloatRegister); %} -#endif ins_pipe(fcvtI2F); %} instruct convI2L_reg(iRegL dst, iRegI src) %{ match(Set dst (ConvI2L src)); -#ifdef AARCH64 - size(4); - format %{ "SXTW $dst,$src\t! int->long" %} - ins_encode %{ - __ sxtw($dst$$Register, $src$$Register); - %} -#else size(8); format %{ "MOV $dst.lo, $src \n\t" "ASR $dst.hi,$src,31\t! int->long" %} @@ -10012,20 +7313,12 @@ instruct convI2L_reg(iRegL dst, iRegI src) %{ __ mov($dst$$Register, $src$$Register); __ mov($dst$$Register->successor(), AsmOperand($src$$Register, asr, 31)); %} -#endif ins_pipe(ialu_reg_reg); %} // Zero-extend convert int to long instruct convI2L_reg_zex(iRegL dst, iRegI src, immL_32bits mask ) %{ match(Set dst (AndL (ConvI2L src) mask) ); -#ifdef AARCH64 - size(4); - format %{ "mov_w $dst,$src\t! zero-extend int to long" %} - ins_encode %{ - __ mov_w($dst$$Register, $src$$Register); - %} -#else size(8); format %{ "MOV $dst.lo,$src.lo\t! zero-extend int to long\n\t" "MOV $dst.hi, 0"%} @@ -10033,20 +7326,12 @@ instruct convI2L_reg_zex(iRegL dst, iRegI src, immL_32bits mask ) %{ __ mov($dst$$Register, $src$$Register); __ mov($dst$$Register->successor(), 0); %} -#endif ins_pipe(ialu_reg_reg); %} // Zero-extend long instruct zerox_long(iRegL dst, iRegL src, immL_32bits mask ) %{ match(Set dst (AndL src mask) ); -#ifdef AARCH64 - size(4); - format %{ "mov_w $dst,$src\t! zero-extend long" %} - ins_encode %{ - __ mov_w($dst$$Register, $src$$Register); - %} -#else size(8); format %{ "MOV $dst.lo,$src.lo\t! zero-extend long\n\t" "MOV $dst.hi, 0"%} @@ -10054,7 +7339,6 @@ instruct zerox_long(iRegL dst, iRegL src, immL_32bits mask ) %{ __ mov($dst$$Register, $src$$Register); __ mov($dst$$Register->successor(), 0); %} -#endif ins_pipe(ialu_reg_reg); %} @@ -10089,17 +7373,10 @@ instruct MoveD2L_reg_reg(iRegL dst, regD src) %{ ins_cost(MEMORY_REF_COST); // FIXME size(4); -#ifdef AARCH64 - format %{ "FMOV_xd $dst,$src\t! MoveD2L" %} - ins_encode %{ - __ fmov_xd($dst$$Register, $src$$FloatRegister); - %} -#else format %{ "FMRRD $dst,$src\t! MoveD2L" %} ins_encode %{ __ fmrrd($dst$$Register, $dst$$Register->successor(), $src$$FloatRegister); %} -#endif ins_pipe(iload_mem); // FIXME %} @@ -10109,46 +7386,16 @@ instruct MoveL2D_reg_reg(regD dst, iRegL src) %{ ins_cost(MEMORY_REF_COST); // FIXME size(4); -#ifdef AARCH64 - format %{ "FMOV_dx $dst,$src\t! MoveL2D" %} - ins_encode %{ - __ fmov_dx($dst$$FloatRegister, $src$$Register); - %} -#else format %{ "FMDRR $dst,$src\t! MoveL2D" %} ins_encode %{ __ fmdrr($dst$$FloatRegister, $src$$Register, $src$$Register->successor()); %} -#endif ins_pipe(ialu_reg_reg); // FIXME %} //----------- // Long to Double conversion -#ifdef AARCH64 -instruct convL2D(regD dst, iRegL src) %{ - match(Set dst (ConvL2D src)); - ins_cost(DEFAULT_COST*2 + MEMORY_REF_COST*2 + BRANCH_COST); // FIXME - size(4); - format %{ "SCVTF_dx $dst, $src" %} - ins_encode %{ - __ scvtf_dx($dst$$FloatRegister, $src$$Register); - %} - ins_pipe(fcvtL2D); -%} - -instruct convL2F(regF dst, iRegL src) %{ - match(Set dst (ConvL2F src)); - ins_cost(DEFAULT_COST*2 + MEMORY_REF_COST*2 + BRANCH_COST); // FIXME - size(4); - format %{ "SCVTF_sx $dst, $src" %} - ins_encode %{ - __ scvtf_sx($dst$$FloatRegister, $src$$Register); - %} - ins_pipe(fcvtL2F); -%} -#else // Magic constant, 0x43300000 instruct loadConI_x43300000(iRegI dst) %{ effect(DEF dst); @@ -10194,7 +7441,6 @@ instruct regDHi_regDLo_to_regD(regD_low dst, regD_low src1, regD_low src2) %{ ins_pipe(faddD_reg_reg); %} -#ifndef AARCH64 // Convert integer in high half of a double register (in the lower half of // the double register file) to double instruct convI2D_regDHi_regD(regD dst, regD_low src) %{ @@ -10206,7 +7452,6 @@ instruct convI2D_regDHi_regD(regD dst, regD_low src) %{ %} ins_pipe(fcvtLHi2D); %} -#endif // Add float double precision instruct addD_regD_regD(regD dst, regD src1, regD src2) %{ @@ -10297,26 +7542,17 @@ instruct convL2D_reg_slow_fxtof(regD dst, iRegL src) %{ addD_regD_regD(dst, tmp3, tmp4); %} %} -#endif // !AARCH64 instruct convL2I_reg(iRegI dst, iRegL src) %{ match(Set dst (ConvL2I src)); size(4); -#ifdef AARCH64 - format %{ "MOV_w $dst,$src\t! long->int" %} - ins_encode %{ - __ mov_w($dst$$Register, $src$$Register); - %} -#else format %{ "MOV $dst,$src.lo\t! long->int" %} ins_encode %{ __ mov($dst$$Register, $src$$Register); %} -#endif ins_pipe(ialu_move_reg_I_to_L); %} -#ifndef AARCH64 // Register Shift Right Immediate instruct shrL_reg_imm6_L2I(iRegI dst, iRegL src, immI_32_63 cnt) %{ match(Set dst (ConvL2I (RShiftL src cnt))); @@ -10331,7 +7567,6 @@ instruct shrL_reg_imm6_L2I(iRegI dst, iRegL src, immI_32_63 cnt) %{ %} ins_pipe(ialu_reg_imm); %} -#endif //----------Control Flow Instructions------------------------------------------ @@ -10410,7 +7645,6 @@ instruct testI_reg_reg( flagsReg_EQNELTGE icc, iRegI op1, iRegI op2, immI0 zero ins_pipe(ialu_cconly_reg_reg_zero); %} -#ifndef AARCH64 instruct testshlI_reg_reg_reg( flagsReg_EQNELTGE icc, iRegI op1, iRegI op2, iRegI op3, immI0 zero ) %{ match(Set icc (CmpI (AndI op1 (LShiftI op2 op3)) zero)); size(4); @@ -10421,7 +7655,6 @@ instruct testshlI_reg_reg_reg( flagsReg_EQNELTGE icc, iRegI op1, iRegI op2, iReg %} ins_pipe(ialu_cconly_reg_reg_zero); %} -#endif instruct testshlI_reg_reg_imm( flagsReg_EQNELTGE icc, iRegI op1, iRegI op2, immU5 op3, immI0 zero ) %{ match(Set icc (CmpI (AndI op1 (LShiftI op2 op3)) zero)); @@ -10434,7 +7667,6 @@ instruct testshlI_reg_reg_imm( flagsReg_EQNELTGE icc, iRegI op1, iRegI op2, immU ins_pipe(ialu_cconly_reg_reg_zero); %} -#ifndef AARCH64 instruct testsarI_reg_reg_reg( flagsReg_EQNELTGE icc, iRegI op1, iRegI op2, iRegI op3, immI0 zero ) %{ match(Set icc (CmpI (AndI op1 (RShiftI op2 op3)) zero)); size(4); @@ -10445,7 +7677,6 @@ instruct testsarI_reg_reg_reg( flagsReg_EQNELTGE icc, iRegI op1, iRegI op2, iReg %} ins_pipe(ialu_cconly_reg_reg_zero); %} -#endif instruct testsarI_reg_reg_imm( flagsReg_EQNELTGE icc, iRegI op1, iRegI op2, immU5 op3, immI0 zero ) %{ match(Set icc (CmpI (AndI op1 (RShiftI op2 op3)) zero)); @@ -10458,7 +7689,6 @@ instruct testsarI_reg_reg_imm( flagsReg_EQNELTGE icc, iRegI op1, iRegI op2, immU ins_pipe(ialu_cconly_reg_reg_zero); %} -#ifndef AARCH64 instruct testshrI_reg_reg_reg( flagsReg_EQNELTGE icc, iRegI op1, iRegI op2, iRegI op3, immI0 zero ) %{ match(Set icc (CmpI (AndI op1 (URShiftI op2 op3)) zero)); size(4); @@ -10469,7 +7699,6 @@ instruct testshrI_reg_reg_reg( flagsReg_EQNELTGE icc, iRegI op1, iRegI op2, iReg %} ins_pipe(ialu_cconly_reg_reg_zero); %} -#endif instruct testshrI_reg_reg_imm( flagsReg_EQNELTGE icc, iRegI op1, iRegI op2, immU5 op3, immI0 zero ) %{ match(Set icc (CmpI (AndI op1 (URShiftI op2 op3)) zero)); @@ -10493,31 +7722,6 @@ instruct testI_reg_imm( flagsReg_EQNELTGE icc, iRegI op1, limmI op2, immI0 zero ins_pipe(ialu_cconly_reg_imm_zero); %} -#ifdef AARCH64 -instruct compL_reg_reg(flagsReg xcc, iRegL op1, iRegL op2) -%{ - match(Set xcc (CmpL op1 op2)); - effect( DEF xcc, USE op1, USE op2 ); - - size(4); - format %{ "CMP $op1,$op2\t! long" %} - ins_encode %{ - __ cmp($op1$$Register, $op2$$Register); - %} - ins_pipe(ialu_cconly_reg_reg); -%} - -instruct compUL_iReg(flagsRegU xcc, iRegL op1, iRegL op2) %{ - match(Set xcc (CmpUL op1 op2)); - - size(4); - format %{ "CMP $op1,$op2\t! unsigned long" %} - ins_encode %{ - __ cmp($op1$$Register, $op2$$Register); - %} - ins_pipe(ialu_cconly_reg_reg); -%} -#else instruct compL_reg_reg_LTGE(flagsRegL_LTGE xcc, iRegL op1, iRegL op2, iRegL tmp) %{ match(Set xcc (CmpL op1 op2)); effect( DEF xcc, USE op1, USE op2, TEMP tmp ); @@ -10545,35 +7749,7 @@ instruct compUL_reg_reg_LTGE(flagsRegUL_LTGE xcc, iRegL op1, iRegL op2, iRegL tm %} ins_pipe(ialu_cconly_reg_reg); %} -#endif -#ifdef AARCH64 -instruct compL_reg_con(flagsReg xcc, iRegL op1, aimmL con) %{ - match(Set xcc (CmpL op1 con)); - effect( DEF xcc, USE op1, USE con ); - - size(8); - format %{ "CMP $op1,$con\t\t! long" %} - ins_encode %{ - __ cmp($op1$$Register, $con$$constant); - %} - - ins_pipe(ialu_cconly_reg_imm); -%} - -instruct compUL_reg_con(flagsRegU xcc, iRegL op1, aimmL con) %{ - match(Set xcc (CmpUL op1 con)); - effect(DEF xcc, USE op1, USE con); - - size(8); - format %{ "CMP $op1,$con\t\t! unsigned long" %} - ins_encode %{ - __ cmp($op1$$Register, $con$$constant); - %} - - ins_pipe(ialu_cconly_reg_imm); -%} -#else instruct compL_reg_reg_EQNE(flagsRegL_EQNE xcc, iRegL op1, iRegL op2) %{ match(Set xcc (CmpL op1 op2)); effect( DEF xcc, USE op1, USE op2 ); @@ -10731,7 +7907,6 @@ instruct compUL_reg_con_LEGT(flagsRegUL_LEGT xcc, iRegL op1, immLlowRot con, iRe ins_pipe(ialu_cconly_reg_reg); %} -#endif /* instruct testL_reg_reg(flagsRegL xcc, iRegL op1, iRegL op2, immL0 zero) %{ */ /* match(Set xcc (CmpL (AndL op1 op2) zero)); */ @@ -10839,13 +8014,6 @@ instruct cmpF_cc(flagsRegF fcc, flagsReg icc, regF src1, regF src2) %{ match(Set icc (CmpF src1 src2)); effect(KILL fcc); -#ifdef AARCH64 - size(4); - format %{ "FCMP_s $src1,$src2" %} - ins_encode %{ - __ fcmp_s($src1$$FloatRegister, $src2$$FloatRegister); - %} -#else size(8); format %{ "FCMPs $src1,$src2\n\t" "FMSTAT" %} @@ -10853,7 +8021,6 @@ instruct cmpF_cc(flagsRegF fcc, flagsReg icc, regF src1, regF src2) %{ __ fcmps($src1$$FloatRegister, $src2$$FloatRegister); __ fmstat(); %} -#endif ins_pipe(faddF_fcc_reg_reg_zero); %} @@ -10861,13 +8028,6 @@ instruct cmpF0_cc(flagsRegF fcc, flagsReg icc, regF src1, immF0 src2) %{ match(Set icc (CmpF src1 src2)); effect(KILL fcc); -#ifdef AARCH64 - size(4); - format %{ "FCMP0_s $src1" %} - ins_encode %{ - __ fcmp0_s($src1$$FloatRegister); - %} -#else size(8); format %{ "FCMPs $src1,$src2\n\t" "FMSTAT" %} @@ -10875,7 +8035,6 @@ instruct cmpF0_cc(flagsRegF fcc, flagsReg icc, regF src1, immF0 src2) %{ __ fcmpzs($src1$$FloatRegister); __ fmstat(); %} -#endif ins_pipe(faddF_fcc_reg_reg_zero); %} @@ -10883,13 +8042,6 @@ instruct cmpD_cc(flagsRegF fcc, flagsReg icc, regD src1, regD src2) %{ match(Set icc (CmpD src1 src2)); effect(KILL fcc); -#ifdef AARCH64 - size(4); - format %{ "FCMP_d $src1,$src2" %} - ins_encode %{ - __ fcmp_d($src1$$FloatRegister, $src2$$FloatRegister); - %} -#else size(8); format %{ "FCMPd $src1,$src2 \n\t" "FMSTAT" %} @@ -10897,7 +8049,6 @@ instruct cmpD_cc(flagsRegF fcc, flagsReg icc, regD src1, regD src2) %{ __ fcmpd($src1$$FloatRegister, $src2$$FloatRegister); __ fmstat(); %} -#endif ins_pipe(faddD_fcc_reg_reg_zero); %} @@ -10905,13 +8056,6 @@ instruct cmpD0_cc(flagsRegF fcc, flagsReg icc, regD src1, immD0 src2) %{ match(Set icc (CmpD src1 src2)); effect(KILL fcc); -#ifdef AARCH64 - size(8); - format %{ "FCMP0_d $src1" %} - ins_encode %{ - __ fcmp0_d($src1$$FloatRegister); - %} -#else size(8); format %{ "FCMPZd $src1,$src2 \n\t" "FMSTAT" %} @@ -10919,87 +8063,9 @@ instruct cmpD0_cc(flagsRegF fcc, flagsReg icc, regD src1, immD0 src2) %{ __ fcmpzd($src1$$FloatRegister); __ fmstat(); %} -#endif ins_pipe(faddD_fcc_reg_reg_zero); %} -#ifdef AARCH64 -// Compare floating, generate -1,0,1 -instruct cmpF_reg(iRegI dst, regF src1, regF src2, flagsReg icc) %{ - match(Set dst (CmpF3 src1 src2)); - // effect(KILL fcc); // nobody cares if flagsRegF is killed - effect(KILL icc); - ins_cost(DEFAULT_COST*3); // FIXME - size(12); - format %{ "FCMP_s $src1,$src2\n\t" - "CSET $dst, gt\n\t" - "CSINV $dst, $dst, ZR, ge" %} - ins_encode %{ - Register dst = $dst$$Register; - __ fcmp_s($src1$$FloatRegister, $src2$$FloatRegister); - __ cset(dst, gt); // 1 if '>', else 0 - __ csinv(dst, dst, ZR, ge); // previous value if '>=', else -1 - %} - ins_pipe( floating_cmp ); // FIXME -%} - -// Compare floating, generate -1,0,1 -instruct cmpD_reg(iRegI dst, regD src1, regD src2, flagsReg icc) %{ - match(Set dst (CmpD3 src1 src2)); - // effect(KILL fcc); // nobody cares if flagsRegF is killed - effect(KILL icc); - ins_cost(DEFAULT_COST*3); // FIXME - size(12); - format %{ "FCMP_d $src1,$src2\n\t" - "CSET $dst, gt\n\t" - "CSINV $dst, $dst, ZR, ge" %} - ins_encode %{ - Register dst = $dst$$Register; - __ fcmp_d($src1$$FloatRegister, $src2$$FloatRegister); - __ cset(dst, gt); // 1 if '>', else 0 - __ csinv(dst, dst, ZR, ge); // previous value if '>=', else -1 - %} - ins_pipe( floating_cmp ); // FIXME -%} - -// Compare floating, generate -1,0,1 -instruct cmpF0_reg(iRegI dst, regF src1, immF0 src2, flagsReg icc) %{ - match(Set dst (CmpF3 src1 src2)); - // effect(KILL fcc); // nobody cares if flagsRegF is killed - effect(KILL icc); - ins_cost(DEFAULT_COST*3); // FIXME - size(12); - format %{ "FCMP0_s $src1\n\t" - "CSET $dst, gt\n\t" - "CSINV $dst, $dst, ZR, ge" %} - ins_encode %{ - Register dst = $dst$$Register; - __ fcmp0_s($src1$$FloatRegister); - __ cset(dst, gt); // 1 if '>', else 0 - __ csinv(dst, dst, ZR, ge); // previous value if '>=', else -1 - %} - ins_pipe( floating_cmp ); // FIXME -%} - -// Compare floating, generate -1,0,1 -instruct cmpD0_reg(iRegI dst, regD src1, immD0 src2, flagsReg icc) %{ - match(Set dst (CmpD3 src1 src2)); - // effect(KILL fcc); // nobody cares if flagsRegF is killed - effect(KILL icc); - ins_cost(DEFAULT_COST*3); // FIXME - size(12); - format %{ "FCMP0_d $src1\n\t" - "CSET $dst, gt\n\t" - "CSINV $dst, $dst, ZR, ge" %} - ins_encode %{ - Register dst = $dst$$Register; - __ fcmp0_d($src1$$FloatRegister); - __ cset(dst, gt); // 1 if '>', else 0 - __ csinv(dst, dst, ZR, ge); // previous value if '>=', else -1 - %} - ins_pipe( floating_cmp ); // FIXME -%} -#else // Compare floating, generate -1,0,1 instruct cmpF_reg(iRegI dst, regF src1, regF src2, flagsRegF fcc) %{ match(Set dst (CmpF3 src1 src2)); @@ -11076,7 +8142,6 @@ instruct cmpD0_reg(iRegI dst, regD src1, immD0 src2, flagsRegF fcc) %{ %} ins_pipe( floating_cmp ); %} -#endif // !AARCH64 //----------Branches--------------------------------------------------------- // Jump @@ -11158,61 +8223,6 @@ instruct branchCon_EQNELTGE(cmpOp0 cmp, flagsReg_EQNELTGE icc, label labl) %{ %} #endif -#ifdef AARCH64 -instruct cbzI(cmpOp cmp, iRegI op1, immI0 op2, label labl) %{ - match(If cmp (CmpI op1 op2)); - effect(USE labl); - predicate(_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::eq || - _kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ne); - size(4); - ins_cost(BRANCH_COST); - format %{ "CB{N}Z $op1, $labl\t! int $cmp" %} - ins_encode %{ - if ($cmp$$cmpcode == eq) { - __ cbz_w($op1$$Register, *($labl$$label)); - } else { - __ cbnz_w($op1$$Register, *($labl$$label)); - } - %} - ins_pipe(br_cc); // FIXME -%} - -instruct cbzP(cmpOpP cmp, iRegP op1, immP0 op2, label labl) %{ - match(If cmp (CmpP op1 op2)); - effect(USE labl); - predicate(_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::eq || - _kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ne); - size(4); - ins_cost(BRANCH_COST); - format %{ "CB{N}Z $op1, $labl\t! ptr $cmp" %} - ins_encode %{ - if ($cmp$$cmpcode == eq) { - __ cbz($op1$$Register, *($labl$$label)); - } else { - __ cbnz($op1$$Register, *($labl$$label)); - } - %} - ins_pipe(br_cc); // FIXME -%} - -instruct cbzL(cmpOpL cmp, iRegL op1, immL0 op2, label labl) %{ - match(If cmp (CmpL op1 op2)); - effect(USE labl); - predicate(_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::eq || - _kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ne); - size(4); - ins_cost(BRANCH_COST); - format %{ "CB{N}Z $op1, $labl\t! long $cmp" %} - ins_encode %{ - if ($cmp$$cmpcode == eq) { - __ cbz($op1$$Register, *($labl$$label)); - } else { - __ cbnz($op1$$Register, *($labl$$label)); - } - %} - ins_pipe(br_cc); // FIXME -%} -#endif instruct branchConU(cmpOpU cmp, flagsRegU icc, label labl) %{ match(If cmp icc); @@ -11240,7 +8250,6 @@ instruct branchConP(cmpOpP cmp, flagsRegP pcc, label labl) %{ ins_pipe(br_cc); %} -#ifndef AARCH64 instruct branchConL_LTGE(cmpOpL cmp, flagsRegL_LTGE xcc, label labl) %{ match(If cmp xcc); effect(USE labl); @@ -11324,7 +8333,6 @@ instruct branchConUL_LEGT(cmpOpUL_commute cmp, flagsRegUL_LEGT xcc, label labl) %} ins_pipe(br_cc); %} -#endif instruct branchLoopEnd(cmpOp cmp, flagsReg icc, label labl) %{ match(CountedLoopEnd cmp icc); @@ -11372,26 +8380,6 @@ instruct branchLoopEnd(cmpOp cmp, flagsReg icc, label labl) %{ // Manifest a CmpL3 result in an integer register. Very painful. // This is the test to avoid. -#ifdef AARCH64 -instruct cmpL3_reg_reg(iRegI dst, iRegL src1, iRegL src2, flagsReg ccr) %{ - match(Set dst (CmpL3 src1 src2)); - // effect(KILL fcc); // nobody cares if flagsRegF is killed - effect(KILL ccr); - ins_cost(DEFAULT_COST*3); // FIXME - size(12); - format %{ "CMP $src1,$src2\n\t" - "CSET $dst, gt\n\t" - "CSINV $dst, $dst, ZR, ge" %} - ins_encode %{ - Register dst = $dst$$Register; - __ cmp($src1$$Register, $src2$$Register); - __ cset(dst, gt); // 1 if '>', else 0 - __ csinv(dst, dst, ZR, ge); // previous value if '>=', else -1 - %} - ins_pipe( ialu_cconly_reg_reg ); // FIXME -%} -// TODO cmpL3_reg_imm -#else instruct cmpL3_reg_reg(iRegI dst, iRegL src1, iRegL src2, flagsReg ccr ) %{ match(Set dst (CmpL3 src1 src2) ); effect( KILL ccr ); @@ -11419,9 +8407,7 @@ instruct cmpL3_reg_reg(iRegI dst, iRegL src1, iRegL src2, flagsReg ccr ) %{ %} ins_pipe(cmpL_reg); %} -#endif -#ifndef AARCH64 // Conditional move instruct cmovLL_reg_LTGE(cmpOpL cmp, flagsRegL_LTGE xcc, iRegL dst, iRegL src) %{ match(Set dst (CMoveL (Binary cmp xcc) (Binary dst src))); @@ -11509,9 +8495,7 @@ instruct cmovLL_imm_LEGT(cmpOpL_commute cmp, flagsRegL_LEGT xcc, iRegL dst, immL %} ins_pipe(ialu_imm); %} -#endif // !AARCH64 -#ifndef AARCH64 instruct cmovIL_reg_LTGE(cmpOpL cmp, flagsRegL_LTGE xcc, iRegI dst, iRegI src) %{ match(Set dst (CMoveI (Binary cmp xcc) (Binary dst src))); predicate(_kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::lt || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ge ); @@ -11550,9 +8534,7 @@ instruct cmovIL_reg_LEGT(cmpOpL_commute cmp, flagsRegL_LEGT xcc, iRegI dst, iReg %} ins_pipe(ialu_reg); %} -#endif // !AARCH64 -#ifndef AARCH64 instruct cmovIL_imm_LTGE(cmpOpL cmp, flagsRegL_LTGE xcc, iRegI dst, immI16 src) %{ match(Set dst (CMoveI (Binary cmp xcc) (Binary dst src))); predicate(_kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::lt || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ge ); @@ -11738,25 +8720,9 @@ instruct cmovDL_reg_LEGT(cmpOpL_commute cmp, flagsRegL_LEGT xcc, regD dst, regD %} ins_pipe(int_conditional_float_move); %} -#endif // !AARCH64 // ============================================================================ // Safepoint Instruction -#ifdef AARCH64 -instruct safePoint_poll(iRegP poll, flagsReg icc, RtempRegP tmp) %{ - match(SafePoint poll); - // The handler stub kills Rtemp - effect(USE poll, KILL tmp, KILL icc); - - size(4); - format %{ "LDR ZR,[$poll]\t! Safepoint: poll for GC" %} - ins_encode %{ - __ relocate(relocInfo::poll_type); - __ ldr(ZR, Address($poll$$Register)); - %} - ins_pipe(loadPollP); -%} -#else // rather than KILL R12, it would be better to use any reg as // TEMP. Can't do that at this point because it crashes the compiler instruct safePoint_poll(iRegP poll, R12RegI tmp, flagsReg icc) %{ @@ -11771,7 +8737,6 @@ instruct safePoint_poll(iRegP poll, R12RegI tmp, flagsReg icc) %{ %} ins_pipe(loadPollP); %} -#endif // ============================================================================ @@ -11820,13 +8785,8 @@ instruct CallRuntimeDirect(method meth) %{ effect(USE meth); ins_cost(CALL_COST); format %{ "CALL,runtime" %} -#ifdef AARCH64 - ins_encode( save_last_PC, Java_To_Runtime( meth ), - call_epilog ); -#else ins_encode( Java_To_Runtime( meth ), call_epilog ); -#endif ins_pipe(simple_call); %} @@ -11952,11 +8912,7 @@ instruct ShouldNotReachHere( ) // Use the following format syntax format %{ "ShouldNotReachHere" %} ins_encode %{ -#ifdef AARCH64 - __ dpcs1(0xdead); -#else __ udf(0xdead); -#endif %} ins_pipe(tail_call); %} @@ -11986,49 +8942,21 @@ instruct partialSubtypeCheck( R0RegP index, R1RegP sub, R2RegP super, flagsRegP // ============================================================================ // inlined locking and unlocking -#ifdef AARCH64 -instruct cmpFastLock(flagsRegP pcc, iRegP object, iRegP box, iRegP scratch2, iRegP scratch, iRegP scratch3 ) -#else instruct cmpFastLock(flagsRegP pcc, iRegP object, iRegP box, iRegP scratch2, iRegP scratch ) -#endif %{ match(Set pcc (FastLock object box)); -#ifdef AARCH64 - effect(TEMP scratch, TEMP scratch2, TEMP scratch3); -#else effect(TEMP scratch, TEMP scratch2); -#endif ins_cost(100); -#ifdef AARCH64 - format %{ "FASTLOCK $object, $box; KILL $scratch, $scratch2, $scratch3" %} - ins_encode %{ - __ fast_lock($object$$Register, $box$$Register, $scratch$$Register, $scratch2$$Register, $scratch3$$Register); - %} -#else format %{ "FASTLOCK $object, $box; KILL $scratch, $scratch2" %} ins_encode %{ __ fast_lock($object$$Register, $box$$Register, $scratch$$Register, $scratch2$$Register); %} -#endif ins_pipe(long_memory_op); %} -#ifdef AARCH64 -instruct cmpFastUnlock(flagsRegP pcc, iRegP object, iRegP box, iRegP scratch2, iRegP scratch, iRegP scratch3 ) %{ - match(Set pcc (FastUnlock object box)); - effect(TEMP scratch, TEMP scratch2, TEMP scratch3); - ins_cost(100); - - format %{ "FASTUNLOCK $object, $box; KILL $scratch, $scratch2, $scratch3" %} - ins_encode %{ - __ fast_unlock($object$$Register, $box$$Register, $scratch$$Register, $scratch2$$Register, $scratch3$$Register); - %} - ins_pipe(long_memory_op); -%} -#else instruct cmpFastUnlock(flagsRegP pcc, iRegP object, iRegP box, iRegP scratch2, iRegP scratch ) %{ match(Set pcc (FastUnlock object box)); effect(TEMP scratch, TEMP scratch2); @@ -12040,48 +8968,7 @@ instruct cmpFastUnlock(flagsRegP pcc, iRegP object, iRegP box, iRegP scratch2, i %} ins_pipe(long_memory_op); %} -#endif -#ifdef AARCH64 -// TODO: add version that takes immI cnt? -instruct clear_array(iRegX cnt, iRegP base, iRegP ptr, iRegX temp, Universe dummy, flagsReg cpsr) %{ - match(Set dummy (ClearArray cnt base)); - effect(TEMP temp, TEMP ptr, KILL cpsr); - ins_cost(300); - format %{ - " MOV $temp,$cnt\n" - " ADD $ptr,$base,$cnt\n" - " SUBS $temp,$temp,16\t! Count down dword pair in bytes\n" - " B.lt done16\n" - "loop: STP ZR,ZR,[$ptr,-16]!\n" - " SUBS $temp,$temp,16\t! Count down dword pair in bytes\n" - " B.ge loop\t! Clearing loop\n" - "done16: ADDS $temp,$temp,8\t! Room for 1 more long?\n" - " B.lt done\n" - " STR ZR,[$base+$temp]\n" - "done:" - %} - ins_encode %{ - // TODO: preload? - __ mov($temp$$Register, $cnt$$Register); - __ add($ptr$$Register, $base$$Register, $cnt$$Register); - Label loop, done, done16; - __ subs($temp$$Register, $temp$$Register, 16); - __ b(done16, lt); - __ bind(loop); - __ stp(ZR, ZR, Address($ptr$$Register, -16, pre_indexed)); - __ subs($temp$$Register, $temp$$Register, 16); - __ b(loop, ge); - __ bind(done16); - __ adds($temp$$Register, $temp$$Register, 8); - __ b(done, lt); - // $temp should be 0 here - __ str(ZR, Address($base$$Register, $temp$$Register)); - __ bind(done); - %} - ins_pipe(long_memory_op); -%} -#else // Count and Base registers are fixed because the allocator cannot // kill unknown registers. The encodings are generic. instruct clear_array(iRegX cnt, iRegP base, iRegI temp, iRegX zero, Universe dummy, flagsReg cpsr) %{ @@ -12104,7 +8991,6 @@ instruct clear_array(iRegX cnt, iRegP base, iRegI temp, iRegX zero, Universe dum %} ins_pipe(long_memory_op); %} -#endif #ifdef XXX // FIXME: Why R0/R1/R2/R3? @@ -12159,17 +9045,6 @@ instruct countLeadingZerosI(iRegI dst, iRegI src) %{ ins_pipe(ialu_reg); %} -#ifdef AARCH64 -instruct countLeadingZerosL(iRegI dst, iRegL src) %{ - match(Set dst (CountLeadingZerosL src)); - size(4); - format %{ "CLZ $dst,$src" %} - ins_encode %{ - __ clz($dst$$Register, $src$$Register); - %} - ins_pipe(ialu_reg); -%} -#else instruct countLeadingZerosL(iRegI dst, iRegL src, iRegI tmp, flagsReg ccr) %{ match(Set dst (CountLeadingZerosL src)); effect(TEMP tmp, TEMP dst, KILL ccr); @@ -12186,7 +9061,6 @@ instruct countLeadingZerosL(iRegI dst, iRegL src, iRegI tmp, flagsReg ccr) %{ %} ins_pipe(ialu_reg); %} -#endif instruct countTrailingZerosI(iRegI dst, iRegI src, iRegI tmp) %{ match(Set dst (CountTrailingZerosI src)); @@ -12201,20 +9075,6 @@ instruct countTrailingZerosI(iRegI dst, iRegI src, iRegI tmp) %{ ins_pipe(ialu_reg); %} -#ifdef AARCH64 -instruct countTrailingZerosL(iRegI dst, iRegL src, iRegL tmp) %{ - match(Set dst (CountTrailingZerosL src)); - effect(TEMP tmp); - size(8); - format %{ "RBIT $tmp, $src\n\t" - "CLZ $dst,$tmp" %} - ins_encode %{ - __ rbit($tmp$$Register, $src$$Register); - __ clz($dst$$Register, $tmp$$Register); - %} - ins_pipe(ialu_reg); -%} -#else instruct countTrailingZerosL(iRegI dst, iRegL src, iRegI tmp, flagsReg ccr) %{ match(Set dst (CountTrailingZerosL src)); effect(TEMP tmp, TEMP dst, KILL ccr); @@ -12235,37 +9095,10 @@ instruct countTrailingZerosL(iRegI dst, iRegL src, iRegI tmp, flagsReg ccr) %{ %} ins_pipe(ialu_reg); %} -#endif //---------- Population Count Instructions ------------------------------------- -#ifdef AARCH64 -instruct popCountI(iRegI dst, iRegI src, regD_low tmp) %{ - predicate(UsePopCountInstruction); - match(Set dst (PopCountI src)); - effect(TEMP tmp); - size(20); - - format %{ "MOV_W $dst,$src\n\t" - "FMOV_dx $tmp,$dst\n\t" - "VCNT $tmp.8B,$tmp.8B\n\t" - "ADDV $tmp.B,$tmp.8B\n\t" - "FMRS $dst,$tmp" %} - - ins_encode %{ - __ mov_w($dst$$Register, $src$$Register); - __ fmov_dx($tmp$$FloatRegister, $dst$$Register); - int quad = 0; - int cnt_size = 0; // VELEM_SIZE_8 - __ vcnt($tmp$$FloatRegister, $tmp$$FloatRegister, quad, cnt_size); - int add_size = 0; // VELEM_SIZE_8 - __ addv($tmp$$FloatRegister, $tmp$$FloatRegister, quad, add_size); - __ fmrs($dst$$Register, $tmp$$FloatRegister); - %} - ins_pipe(ialu_reg); // FIXME -%} -#else instruct popCountI(iRegI dst, iRegI src, regD_low tmp) %{ predicate(UsePopCountInstruction); match(Set dst (PopCountI src)); @@ -12287,32 +9120,7 @@ instruct popCountI(iRegI dst, iRegI src, regD_low tmp) %{ %} ins_pipe(ialu_reg); // FIXME %} -#endif -#ifdef AARCH64 -instruct popCountL(iRegI dst, iRegL src, regD tmp) %{ - predicate(UsePopCountInstruction); - match(Set dst (PopCountL src)); - effect(TEMP tmp); - size(16); - - format %{ "FMOV_dx $tmp,$src\n\t" - "VCNT $tmp.8B,$tmp.8B\n\t" - "ADDV $tmp.B,$tmp.8B\n\t" - "FMOV_ws $dst,$tmp" %} - - ins_encode %{ - __ fmov_dx($tmp$$FloatRegister, $src$$Register); - int quad = 0; - int cnt_size = 0; - __ vcnt($tmp$$FloatRegister, $tmp$$FloatRegister, quad, cnt_size); - int add_size = 0; - __ addv($tmp$$FloatRegister, $tmp$$FloatRegister, quad, add_size); - __ fmov_ws($dst$$Register, $tmp$$FloatRegister); - %} - ins_pipe(ialu_reg); // FIXME -%} -#else // Note: Long.bitCount(long) returns an int. instruct popCountL(iRegI dst, iRegL src, regD_low tmp) %{ predicate(UsePopCountInstruction); @@ -12338,7 +9146,6 @@ instruct popCountL(iRegI dst, iRegL src, regD_low tmp) %{ %} ins_pipe(ialu_reg); %} -#endif // ============================================================================ @@ -12350,26 +9157,13 @@ instruct bytes_reverse_int(iRegI dst, iRegI src) %{ size(4); format %{ "REV32 $dst,$src" %} ins_encode %{ -#ifdef AARCH64 - __ rev_w($dst$$Register, $src$$Register); - // high 32 bits zeroed, not sign extended -#else __ rev($dst$$Register, $src$$Register); -#endif %} ins_pipe( iload_mem ); // FIXME %} instruct bytes_reverse_long(iRegL dst, iRegL src) %{ match(Set dst (ReverseBytesL src)); -#ifdef AARCH64 -//size(4); - format %{ "REV $dst,$src" %} - ins_encode %{ - __ rev($dst$$Register, $src$$Register); - %} - ins_pipe(ialu_reg_reg); // FIXME -#else effect(TEMP dst); size(8); format %{ "REV $dst.lo,$src.lo\n\t" @@ -12379,45 +9173,25 @@ instruct bytes_reverse_long(iRegL dst, iRegL src) %{ __ rev($dst$$Register->successor(), $src$$Register); %} ins_pipe( iload_mem ); // FIXME -#endif %} instruct bytes_reverse_unsigned_short(iRegI dst, iRegI src) %{ match(Set dst (ReverseBytesUS src)); -#ifdef AARCH64 - size(4); - format %{ "REV16_W $dst,$src" %} - ins_encode %{ - __ rev16_w($dst$$Register, $src$$Register); - // high 32 bits zeroed - %} -#else size(4); format %{ "REV16 $dst,$src" %} ins_encode %{ __ rev16($dst$$Register, $src$$Register); %} -#endif ins_pipe( iload_mem ); // FIXME %} instruct bytes_reverse_short(iRegI dst, iRegI src) %{ match(Set dst (ReverseBytesS src)); -#ifdef AARCH64 - size(8); - format %{ "REV16_W $dst,$src\n\t" - "SIGN_EXT16 $dst" %} - ins_encode %{ - __ rev16_w($dst$$Register, $src$$Register); - __ sign_extend($dst$$Register, $dst$$Register, 16); - %} -#else size(4); format %{ "REVSH $dst,$src" %} ins_encode %{ __ revsh($dst$$Register, $src$$Register); %} -#endif ins_pipe( iload_mem ); // FIXME %} @@ -12476,7 +9250,6 @@ instruct storeV16(memoryvld mem, vecX src) %{ ins_pipe(fstoreD_mem_reg); // FIXME %} -#ifndef AARCH64 // Replicate scalar to packed byte values in Double register instruct Repl8B_reg(vecD dst, iRegI src, iRegI tmp) %{ predicate(n->as_Vector()->length() == 8); @@ -12498,7 +9271,6 @@ instruct Repl8B_reg(vecD dst, iRegI src, iRegI tmp) %{ %} ins_pipe(ialu_reg); // FIXME %} -#endif /* !AARCH64 */ // Replicate scalar to packed byte values in Double register instruct Repl8B_reg_simd(vecD dst, iRegI src) %{ @@ -12530,7 +9302,6 @@ instruct Repl16B_reg(vecX dst, iRegI src) %{ ins_pipe(ialu_reg); // FIXME %} -#ifndef AARCH64 // Replicate scalar constant to packed byte values in Double register instruct Repl8B_immI(vecD dst, immI src, iRegI tmp) %{ predicate(n->as_Vector()->length() == 8); @@ -12544,7 +9315,6 @@ instruct Repl8B_immI(vecD dst, immI src, iRegI tmp) %{ ins_encode( LdReplImmI(src, dst, tmp, (4), (1)) ); ins_pipe(loadConFD); // FIXME %} -#endif /* !AARCH64 */ // Replicate scalar constant to packed byte values in Double register // TODO: support negative constants with MVNI? @@ -12577,7 +9347,6 @@ instruct Repl16B_immU8(vecX dst, immU8 src) %{ ins_pipe(loadConFD); // FIXME %} -#ifndef AARCH64 // Replicate scalar to packed short/char values into Double register instruct Repl4S_reg(vecD dst, iRegI src, iRegI tmp) %{ predicate(n->as_Vector()->length() == 4); @@ -12597,7 +9366,6 @@ instruct Repl4S_reg(vecD dst, iRegI src, iRegI tmp) %{ %} ins_pipe(ialu_reg); // FIXME %} -#endif /* !AARCH64 */ // Replicate scalar to packed byte values in Double register instruct Repl4S_reg_simd(vecD dst, iRegI src) %{ @@ -12630,7 +9398,6 @@ instruct Repl8S_reg(vecX dst, iRegI src) %{ %} -#ifndef AARCH64 // Replicate scalar constant to packed short/char values in Double register instruct Repl4S_immI(vecD dst, immI src, iRegP tmp) %{ predicate(n->as_Vector()->length() == 4); @@ -12644,7 +9411,6 @@ instruct Repl4S_immI(vecD dst, immI src, iRegP tmp) %{ ins_encode( LdReplImmI(src, dst, tmp, (2), (2)) ); ins_pipe(loadConFD); // FIXME %} -#endif /* !AARCH64 */ // Replicate scalar constant to packed byte values in Double register instruct Repl4S_immU8(vecD dst, immU8 src) %{ @@ -12676,7 +9442,6 @@ instruct Repl8S_immU8(vecX dst, immU8 src) %{ ins_pipe(loadConFD); // FIXME %} -#ifndef AARCH64 // Replicate scalar to packed int values in Double register instruct Repl2I_reg(vecD dst, iRegI src) %{ predicate(n->as_Vector()->length() == 2); @@ -12707,7 +9472,6 @@ instruct Repl4I_reg(vecX dst, iRegI src) %{ %} ins_pipe(ialu_reg); // FIXME %} -#endif /* !AARCH64 */ // Replicate scalar to packed int values in Double register instruct Repl2I_reg_simd(vecD dst, iRegI src) %{ @@ -12740,7 +9504,6 @@ instruct Repl4I_reg_simd(vecX dst, iRegI src) %{ %} -#ifndef AARCH64 // Replicate scalar zero constant to packed int values in Double register instruct Repl2I_immI(vecD dst, immI src, iRegI tmp) %{ predicate(n->as_Vector()->length() == 2); @@ -12754,7 +9517,6 @@ instruct Repl2I_immI(vecD dst, immI src, iRegI tmp) %{ ins_encode( LdReplImmI(src, dst, tmp, (1), (4)) ); ins_pipe(loadConFD); // FIXME %} -#endif /* !AARCH64 */ // Replicate scalar constant to packed byte values in Double register instruct Repl2I_immU8(vecD dst, immU8 src) %{ @@ -12786,23 +9548,6 @@ instruct Repl4I_immU8(vecX dst, immU8 src) %{ ins_pipe(loadConFD); // FIXME %} -#ifdef AARCH64 -// Replicate scalar to packed byte values in Double register pair -instruct Repl2L_reg(vecX dst, iRegL src) %{ - predicate(n->as_Vector()->length() == 2); - match(Set dst (ReplicateL src)); - size(4*1); - ins_cost(DEFAULT_COST*1); // FIXME - - format %{ "VDUP.2D $dst.Q,$src\t" %} - ins_encode %{ - bool quad = true; - __ vdupI($dst$$FloatRegister, $src$$Register, - MacroAssembler::VELEM_SIZE_64, quad); - %} - ins_pipe(ialu_reg); // FIXME -%} -#else /* !AARCH64 */ // Replicate scalar to packed byte values in Double register pair instruct Repl2L_reg(vecX dst, iRegL src) %{ predicate(n->as_Vector()->length() == 2); @@ -12847,7 +9592,6 @@ instruct Repl2F_reg_vfp(vecD dst, regF src) %{ Repl2F_regI(dst,tmp); %} %} -#endif /* !AARCH64 */ // Replicate scalar to packed float values in Double register instruct Repl2F_reg_simd(vecD dst, regF src) %{ @@ -12864,7 +9608,6 @@ instruct Repl2F_reg_simd(vecD dst, regF src) %{ ins_pipe(ialu_reg); // FIXME %} -#ifndef AARCH64 // Replicate scalar to packed float values in Double register pair instruct Repl4F_reg(vecX dst, regF src, iRegI tmp) %{ predicate(n->as_Vector()->length() == 4); @@ -12884,7 +9627,6 @@ instruct Repl4F_reg(vecX dst, regF src, iRegI tmp) %{ %} ins_pipe(ialu_reg); // FIXME %} -#endif /* !AARCH64 */ // Replicate scalar to packed float values in Double register pair instruct Repl4F_reg_simd(vecX dst, regF src) %{ @@ -12901,7 +9643,6 @@ instruct Repl4F_reg_simd(vecX dst, regF src) %{ ins_pipe(ialu_reg); // FIXME %} -#ifndef AARCH64 // Replicate scalar zero constant to packed float values in Double register instruct Repl2F_immI(vecD dst, immF src, iRegI tmp) %{ predicate(n->as_Vector()->length() == 2); @@ -12915,22 +9656,9 @@ instruct Repl2F_immI(vecD dst, immF src, iRegI tmp) %{ ins_encode( LdReplImmF(src, dst, tmp) ); ins_pipe(loadConFD); // FIXME %} -#endif /* !AAARCH64 */ // Replicate scalar to packed double float values in Double register pair instruct Repl2D_reg(vecX dst, regD src) %{ -#ifdef AARCH64 - predicate(n->as_Vector()->length() == 2 && VM_Version::has_simd()); - match(Set dst (ReplicateD src)); - size(4*1); - ins_cost(DEFAULT_COST*1); // FIXME - - format %{ "VDUP $dst.2D,$src\t" %} - ins_encode %{ - bool quad = true; - __ vdupD($dst$$FloatRegister, $src$$FloatRegister, quad); - %} -#else predicate(n->as_Vector()->length() == 2); match(Set dst (ReplicateD src)); size(4*2); @@ -12945,7 +9673,6 @@ instruct Repl2D_reg(vecX dst, regD src) %{ FloatRegister dstb = dsta->successor()->successor(); __ fcpyd(dstb, src); %} -#endif ins_pipe(ialu_reg); // FIXME %} @@ -13062,7 +9789,6 @@ instruct vadd2F_reg(vecD dst, vecD src1, vecD src2) %{ ins_pipe( faddD_reg_reg ); // FIXME %} -#ifndef AARCH64 instruct vadd2F_reg_vfp(vecD dst, vecD src1, vecD src2) %{ predicate(n->as_Vector()->length() == 2 && !VM_Version::simd_math_is_compliant()); match(Set dst (AddVF src1 src2)); @@ -13080,7 +9806,6 @@ instruct vadd2F_reg_vfp(vecD dst, vecD src1, vecD src2) %{ ins_pipe(faddF_reg_reg); // FIXME %} -#endif instruct vadd4F_reg_simd(vecX dst, vecX src1, vecX src2) %{ predicate(n->as_Vector()->length() == 4 && VM_Version::simd_math_is_compliant()); @@ -13095,20 +9820,6 @@ instruct vadd4F_reg_simd(vecX dst, vecX src1, vecX src2) %{ ins_pipe( faddD_reg_reg ); // FIXME %} -#ifdef AARCH64 -instruct vadd2D_reg_simd(vecX dst, vecX src1, vecX src2) %{ - predicate(n->as_Vector()->length() == 2 && VM_Version::simd_math_is_compliant()); - match(Set dst (AddVD src1 src2)); - size(4); - format %{ "VADD.F64 $dst.Q,$src1.Q,$src2.Q\t! add packed2D" %} - ins_encode %{ - bool quad = true; - __ vaddF($dst$$FloatRegister, $src1$$FloatRegister, $src2$$FloatRegister, - MacroAssembler::VFA_SIZE_F64, quad); - %} - ins_pipe( faddD_reg_reg ); // FIXME -%} -#else instruct vadd4F_reg_vfp(vecX dst, vecX src1, vecX src2) %{ predicate(n->as_Vector()->length() == 4 && !VM_Version::simd_math_is_compliant()); match(Set dst (AddVF src1 src2)); @@ -13164,7 +9875,6 @@ instruct vadd2D_reg_vfp(vecX dst, vecX src1, vecX src2) %{ ins_pipe(faddF_reg_reg); // FIXME %} -#endif // Bytes vector sub @@ -13276,7 +9986,6 @@ instruct vsub2F_reg(vecD dst, vecD src1, vecD src2) %{ ins_pipe( faddF_reg_reg ); // FIXME %} -#ifndef AARCH64 instruct vsub2F_reg_vfp(vecD dst, vecD src1, vecD src2) %{ predicate(n->as_Vector()->length() == 2 && !VM_Version::simd_math_is_compliant()); match(Set dst (SubVF src1 src2)); @@ -13299,7 +10008,6 @@ instruct vsub2F_reg_vfp(vecD dst, vecD src1, vecD src2) %{ ins_pipe(faddF_reg_reg); // FIXME %} -#endif instruct vsub4F_reg(vecX dst, vecX src1, vecX src2) %{ @@ -13315,20 +10023,6 @@ instruct vsub4F_reg(vecX dst, vecX src1, vecX src2) %{ ins_pipe( faddF_reg_reg ); // FIXME %} -#ifdef AARCH64 -instruct vsub2D_reg_simd(vecX dst, vecX src1, vecX src2) %{ - predicate(n->as_Vector()->length() == 2 && VM_Version::simd_math_is_compliant()); - match(Set dst (SubVD src1 src2)); - size(4); - format %{ "VSUB.F64 $dst.Q,$src1.Q,$src2.Q\t! add packed2D" %} - ins_encode %{ - bool quad = true; - __ vsubF($dst$$FloatRegister, $src1$$FloatRegister, $src2$$FloatRegister, - MacroAssembler::VFA_SIZE_F64, quad); - %} - ins_pipe( faddD_reg_reg ); // FIXME -%} -#else instruct vsub4F_reg_vfp(vecX dst, vecX src1, vecX src2) %{ predicate(n->as_Vector()->length() == 4 && !VM_Version::simd_math_is_compliant()); match(Set dst (SubVF src1 src2)); @@ -13384,7 +10078,6 @@ instruct vsub2D_reg_vfp(vecX dst, vecX src1, vecX src2) %{ ins_pipe(faddF_reg_reg); // FIXME %} -#endif // Shorts/Chars vector mul instruct vmul4S_reg(vecD dst, vecD src1, vecD src2) %{ @@ -13449,7 +10142,6 @@ instruct vmul2F_reg(vecD dst, vecD src1, vecD src2) %{ ins_pipe( fmulF_reg_reg ); // FIXME %} -#ifndef AARCH64 instruct vmul2F_reg_vfp(vecD dst, vecD src1, vecD src2) %{ predicate(n->as_Vector()->length() == 2 && !VM_Version::simd_math_is_compliant()); match(Set dst (MulVF src1 src2)); @@ -13467,7 +10159,6 @@ instruct vmul2F_reg_vfp(vecD dst, vecD src1, vecD src2) %{ ins_pipe(fmulF_reg_reg); // FIXME %} -#endif instruct vmul4F_reg(vecX dst, vecX src1, vecX src2) %{ predicate(n->as_Vector()->length() == 4 && VM_Version::simd_math_is_compliant()); @@ -13481,7 +10172,6 @@ instruct vmul4F_reg(vecX dst, vecX src1, vecX src2) %{ ins_pipe( fmulF_reg_reg ); // FIXME %} -#ifndef AARCH64 instruct vmul4F_reg_vfp(vecX dst, vecX src1, vecX src2) %{ predicate(n->as_Vector()->length() == 4 && !VM_Version::simd_math_is_compliant()); match(Set dst (MulVF src1 src2)); @@ -13514,25 +10204,7 @@ instruct vmul4F_reg_vfp(vecX dst, vecX src1, vecX src2) %{ ins_pipe(fmulF_reg_reg); // FIXME %} -#endif -#ifdef AARCH64 -instruct vmul2D_reg(vecX dst, vecX src1, vecX src2) %{ - predicate(n->as_Vector()->length() == 2 && VM_Version::has_simd()); - match(Set dst (MulVD src1 src2)); - size(4*1); - ins_cost(DEFAULT_COST*1); // FIXME - - format %{ "FMUL.2D $dst,$src1,$src2\t! double[2]" %} - ins_encode %{ - int quad = 1; - __ vmulF($dst$$FloatRegister, $src1$$FloatRegister, $src2$$FloatRegister, - MacroAssembler::VFA_SIZE_F64, quad); - %} - - ins_pipe(fdivF_reg_reg); // FIXME -%} -#else instruct vmul2D_reg_vfp(vecX dst, vecX src1, vecX src2) %{ predicate(n->as_Vector()->length() == 2); match(Set dst (MulVD src1 src2)); @@ -13554,26 +10226,12 @@ instruct vmul2D_reg_vfp(vecX dst, vecX src1, vecX src2) %{ ins_pipe(fmulD_reg_reg); // FIXME %} -#endif // Floats vector div instruct vdiv2F_reg_vfp(vecD dst, vecD src1, vecD src2) %{ predicate(n->as_Vector()->length() == 2); match(Set dst (DivVF src1 src2)); -#ifdef AARCH64 - size(4*1); - ins_cost(DEFAULT_COST*1); // FIXME - - format %{ "FDIV.2S $dst,$src1,$src2\t! float[2]" %} - ins_encode %{ - int quad = 0; - __ vdivF($dst$$FloatRegister, $src1$$FloatRegister, $src2$$FloatRegister, - MacroAssembler::VFA_SIZE_F32, quad); - %} - - ins_pipe(fdivF_reg_reg); // FIXME -#else size(4*2); ins_cost(DEFAULT_COST*2); // FIXME @@ -13587,25 +10245,11 @@ instruct vdiv2F_reg_vfp(vecD dst, vecD src1, vecD src2) %{ %} ins_pipe(fdivF_reg_reg); // FIXME -#endif %} instruct vdiv4F_reg_vfp(vecX dst, vecX src1, vecX src2) %{ predicate(n->as_Vector()->length() == 4); match(Set dst (DivVF src1 src2)); -#ifdef AARCH64 - size(4*1); - ins_cost(DEFAULT_COST*1); // FIXME - - format %{ "FDIV.4S $dst,$src1,$src2\t! float[4]" %} - ins_encode %{ - int quad = 1; - __ vdivF($dst$$FloatRegister, $src1$$FloatRegister, $src2$$FloatRegister, - MacroAssembler::VFA_SIZE_F32, quad); - %} - - ins_pipe(fdivF_reg_reg); // FIXME -#else size(4*4); ins_cost(DEFAULT_COST*4); // FIXME @@ -13634,26 +10278,8 @@ instruct vdiv4F_reg_vfp(vecX dst, vecX src1, vecX src2) %{ %} ins_pipe(fdivF_reg_reg); // FIXME -#endif %} -#ifdef AARCH64 -instruct vdiv2D_reg(vecX dst, vecX src1, vecX src2) %{ - predicate(n->as_Vector()->length() == 2 && VM_Version::has_simd()); - match(Set dst (DivVD src1 src2)); - size(4*1); - ins_cost(DEFAULT_COST*1); // FIXME - - format %{ "FDIV.2D $dst,$src1,$src2\t! double[2]" %} - ins_encode %{ - int quad = 1; - __ vdivF($dst$$FloatRegister, $src1$$FloatRegister, $src2$$FloatRegister, - MacroAssembler::VFA_SIZE_F64, quad); - %} - - ins_pipe(fdivF_reg_reg); // FIXME -%} -#else instruct vdiv2D_reg_vfp(vecX dst, vecX src1, vecX src2) %{ predicate(n->as_Vector()->length() == 2); match(Set dst (DivVD src1 src2)); @@ -13675,7 +10301,6 @@ instruct vdiv2D_reg_vfp(vecX dst, vecX src1, vecX src2) %{ ins_pipe(fdivD_reg_reg); // FIXME %} -#endif // --------------------------------- NEG -------------------------------------- diff --git a/src/hotspot/cpu/arm/arm_64.ad b/src/hotspot/cpu/arm/arm_64.ad deleted file mode 100644 index 5d5a6c871b3..00000000000 --- a/src/hotspot/cpu/arm/arm_64.ad +++ /dev/null @@ -1,998 +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. -// - -// ARM Architecture Description File - -//----------REGISTER DEFINITION BLOCK------------------------------------------ -// This information is used by the matcher and the register allocator to -// describe individual registers and classes of registers within the target -// archtecture. -register %{ -//----------Architecture Description Register Definitions---------------------- -// General Registers -// "reg_def" name ( register save type, C convention save type, -// ideal register type, encoding, vm name ); -// Register Save Types: -// -// NS = No-Save: The register allocator assumes that these registers -// can be used without saving upon entry to the method, & -// that they do not need to be saved at call sites. -// -// SOC = Save-On-Call: The register allocator assumes that these registers -// can be used without saving upon entry to the method, -// but that they must be saved at call sites. -// -// SOE = Save-On-Entry: The register allocator assumes that these registers -// must be saved before using them upon entry to the -// method, but they do not need to be saved at call -// sites. -// -// AS = Always-Save: The register allocator assumes that these registers -// must be saved before using them upon entry to the -// method, & that they must be saved at call sites. -// -// Ideal Register Type is used to determine how to save & restore a -// register. Op_RegI will get spilled with LoadI/StoreI, Op_RegP will get -// spilled with LoadP/StoreP. If the register supports both, use Op_RegI. -// FIXME: above comment seems wrong. Spill done through MachSpillCopyNode -// -// The encoding number is the actual bit-pattern placed into the opcodes. - - -// ---------------------------- -// Integer/Long Registers -// ---------------------------- - -// TODO: would be nice to keep track of high-word state: -// zeroRegI --> RegL -// signedRegI --> RegL -// junkRegI --> RegL -// how to tell C2 to treak RegI as RegL, or RegL as RegI? -reg_def R_R0 (SOC, SOC, Op_RegI, 0, R0->as_VMReg()); -reg_def R_R0x (SOC, SOC, Op_RegI, 255, R0->as_VMReg()->next()); -reg_def R_R1 (SOC, SOC, Op_RegI, 1, R1->as_VMReg()); -reg_def R_R1x (SOC, SOC, Op_RegI, 255, R1->as_VMReg()->next()); -reg_def R_R2 (SOC, SOC, Op_RegI, 2, R2->as_VMReg()); -reg_def R_R2x (SOC, SOC, Op_RegI, 255, R2->as_VMReg()->next()); -reg_def R_R3 (SOC, SOC, Op_RegI, 3, R3->as_VMReg()); -reg_def R_R3x (SOC, SOC, Op_RegI, 255, R3->as_VMReg()->next()); -reg_def R_R4 (SOC, SOC, Op_RegI, 4, R4->as_VMReg()); -reg_def R_R4x (SOC, SOC, Op_RegI, 255, R4->as_VMReg()->next()); -reg_def R_R5 (SOC, SOC, Op_RegI, 5, R5->as_VMReg()); -reg_def R_R5x (SOC, SOC, Op_RegI, 255, R5->as_VMReg()->next()); -reg_def R_R6 (SOC, SOC, Op_RegI, 6, R6->as_VMReg()); -reg_def R_R6x (SOC, SOC, Op_RegI, 255, R6->as_VMReg()->next()); -reg_def R_R7 (SOC, SOC, Op_RegI, 7, R7->as_VMReg()); -reg_def R_R7x (SOC, SOC, Op_RegI, 255, R7->as_VMReg()->next()); - -reg_def R_R8 (SOC, SOC, Op_RegI, 8, R8->as_VMReg()); -reg_def R_R8x (SOC, SOC, Op_RegI, 255, R8->as_VMReg()->next()); -reg_def R_R9 (SOC, SOC, Op_RegI, 9, R9->as_VMReg()); -reg_def R_R9x (SOC, SOC, Op_RegI, 255, R9->as_VMReg()->next()); -reg_def R_R10 (SOC, SOC, Op_RegI, 10, R10->as_VMReg()); -reg_def R_R10x(SOC, SOC, Op_RegI, 255, R10->as_VMReg()->next()); -reg_def R_R11 (SOC, SOC, Op_RegI, 11, R11->as_VMReg()); -reg_def R_R11x(SOC, SOC, Op_RegI, 255, R11->as_VMReg()->next()); -reg_def R_R12 (SOC, SOC, Op_RegI, 12, R12->as_VMReg()); -reg_def R_R12x(SOC, SOC, Op_RegI, 255, R12->as_VMReg()->next()); -reg_def R_R13 (SOC, SOC, Op_RegI, 13, R13->as_VMReg()); -reg_def R_R13x(SOC, SOC, Op_RegI, 255, R13->as_VMReg()->next()); -reg_def R_R14 (SOC, SOC, Op_RegI, 14, R14->as_VMReg()); -reg_def R_R14x(SOC, SOC, Op_RegI, 255, R14->as_VMReg()->next()); -reg_def R_R15 (SOC, SOC, Op_RegI, 15, R15->as_VMReg()); -reg_def R_R15x(SOC, SOC, Op_RegI, 255, R15->as_VMReg()->next()); - -reg_def R_R16 (SOC, SOC, Op_RegI, 16, R16->as_VMReg()); // IP0 -reg_def R_R16x(SOC, SOC, Op_RegI, 255, R16->as_VMReg()->next()); -reg_def R_R17 (SOC, SOC, Op_RegI, 17, R17->as_VMReg()); // IP1 -reg_def R_R17x(SOC, SOC, Op_RegI, 255, R17->as_VMReg()->next()); -reg_def R_R18 (SOC, SOC, Op_RegI, 18, R18->as_VMReg()); // Platform Register -reg_def R_R18x(SOC, SOC, Op_RegI, 255, R18->as_VMReg()->next()); - -reg_def R_R19 (SOC, SOE, Op_RegI, 19, R19->as_VMReg()); -reg_def R_R19x(SOC, SOE, Op_RegI, 255, R19->as_VMReg()->next()); -reg_def R_R20 (SOC, SOE, Op_RegI, 20, R20->as_VMReg()); -reg_def R_R20x(SOC, SOE, Op_RegI, 255, R20->as_VMReg()->next()); -reg_def R_R21 (SOC, SOE, Op_RegI, 21, R21->as_VMReg()); -reg_def R_R21x(SOC, SOE, Op_RegI, 255, R21->as_VMReg()->next()); -reg_def R_R22 (SOC, SOE, Op_RegI, 22, R22->as_VMReg()); -reg_def R_R22x(SOC, SOE, Op_RegI, 255, R22->as_VMReg()->next()); -reg_def R_R23 (SOC, SOE, Op_RegI, 23, R23->as_VMReg()); -reg_def R_R23x(SOC, SOE, Op_RegI, 255, R23->as_VMReg()->next()); -reg_def R_R24 (SOC, SOE, Op_RegI, 24, R24->as_VMReg()); -reg_def R_R24x(SOC, SOE, Op_RegI, 255, R24->as_VMReg()->next()); -reg_def R_R25 (SOC, SOE, Op_RegI, 25, R25->as_VMReg()); -reg_def R_R25x(SOC, SOE, Op_RegI, 255, R25->as_VMReg()->next()); -reg_def R_R26 (SOC, SOE, Op_RegI, 26, R26->as_VMReg()); -reg_def R_R26x(SOC, SOE, Op_RegI, 255, R26->as_VMReg()->next()); -reg_def R_R27 (SOC, SOE, Op_RegI, 27, R27->as_VMReg()); // Rheap_base -reg_def R_R27x(SOC, SOE, Op_RegI, 255, R27->as_VMReg()->next()); // Rheap_base -reg_def R_R28 ( NS, SOE, Op_RegI, 28, R28->as_VMReg()); // TLS -reg_def R_R28x( NS, SOE, Op_RegI, 255, R28->as_VMReg()->next()); // TLS - -reg_def R_R29 ( NS, SOE, Op_RegI, 29, R29->as_VMReg()); // FP -reg_def R_R29x( NS, SOE, Op_RegI, 255, R29->as_VMReg()->next()); // FP -reg_def R_R30 (SOC, SOC, Op_RegI, 30, R30->as_VMReg()); // LR -reg_def R_R30x(SOC, SOC, Op_RegI, 255, R30->as_VMReg()->next()); // LR - -reg_def R_ZR ( NS, NS, Op_RegI, 31, ZR->as_VMReg()); // ZR -reg_def R_ZRx( NS, NS, Op_RegI, 255, ZR->as_VMReg()->next()); // ZR - -// FIXME -//reg_def R_SP ( NS, NS, Op_RegP, 32, SP->as_VMReg()); -reg_def R_SP ( NS, NS, Op_RegI, 32, SP->as_VMReg()); -//reg_def R_SPx( NS, NS, Op_RegP, 255, SP->as_VMReg()->next()); -reg_def R_SPx( NS, NS, Op_RegI, 255, SP->as_VMReg()->next()); - -// ---------------------------- -// Float/Double/Vector Registers -// ---------------------------- - -reg_def R_V0(SOC, SOC, Op_RegF, 0, V0->as_VMReg()); -reg_def R_V1(SOC, SOC, Op_RegF, 1, V1->as_VMReg()); -reg_def R_V2(SOC, SOC, Op_RegF, 2, V2->as_VMReg()); -reg_def R_V3(SOC, SOC, Op_RegF, 3, V3->as_VMReg()); -reg_def R_V4(SOC, SOC, Op_RegF, 4, V4->as_VMReg()); -reg_def R_V5(SOC, SOC, Op_RegF, 5, V5->as_VMReg()); -reg_def R_V6(SOC, SOC, Op_RegF, 6, V6->as_VMReg()); -reg_def R_V7(SOC, SOC, Op_RegF, 7, V7->as_VMReg()); -reg_def R_V8(SOC, SOC, Op_RegF, 8, V8->as_VMReg()); -reg_def R_V9(SOC, SOC, Op_RegF, 9, V9->as_VMReg()); -reg_def R_V10(SOC, SOC, Op_RegF, 10, V10->as_VMReg()); -reg_def R_V11(SOC, SOC, Op_RegF, 11, V11->as_VMReg()); -reg_def R_V12(SOC, SOC, Op_RegF, 12, V12->as_VMReg()); -reg_def R_V13(SOC, SOC, Op_RegF, 13, V13->as_VMReg()); -reg_def R_V14(SOC, SOC, Op_RegF, 14, V14->as_VMReg()); -reg_def R_V15(SOC, SOC, Op_RegF, 15, V15->as_VMReg()); -reg_def R_V16(SOC, SOC, Op_RegF, 16, V16->as_VMReg()); -reg_def R_V17(SOC, SOC, Op_RegF, 17, V17->as_VMReg()); -reg_def R_V18(SOC, SOC, Op_RegF, 18, V18->as_VMReg()); -reg_def R_V19(SOC, SOC, Op_RegF, 19, V19->as_VMReg()); -reg_def R_V20(SOC, SOC, Op_RegF, 20, V20->as_VMReg()); -reg_def R_V21(SOC, SOC, Op_RegF, 21, V21->as_VMReg()); -reg_def R_V22(SOC, SOC, Op_RegF, 22, V22->as_VMReg()); -reg_def R_V23(SOC, SOC, Op_RegF, 23, V23->as_VMReg()); -reg_def R_V24(SOC, SOC, Op_RegF, 24, V24->as_VMReg()); -reg_def R_V25(SOC, SOC, Op_RegF, 25, V25->as_VMReg()); -reg_def R_V26(SOC, SOC, Op_RegF, 26, V26->as_VMReg()); -reg_def R_V27(SOC, SOC, Op_RegF, 27, V27->as_VMReg()); -reg_def R_V28(SOC, SOC, Op_RegF, 28, V28->as_VMReg()); -reg_def R_V29(SOC, SOC, Op_RegF, 29, V29->as_VMReg()); -reg_def R_V30(SOC, SOC, Op_RegF, 30, V30->as_VMReg()); -reg_def R_V31(SOC, SOC, Op_RegF, 31, V31->as_VMReg()); - -reg_def R_V0b(SOC, SOC, Op_RegF, 255, V0->as_VMReg()->next(1)); -reg_def R_V1b(SOC, SOC, Op_RegF, 255, V1->as_VMReg()->next(1)); -reg_def R_V2b(SOC, SOC, Op_RegF, 255, V2->as_VMReg()->next(1)); -reg_def R_V3b(SOC, SOC, Op_RegF, 3, V3->as_VMReg()->next(1)); -reg_def R_V4b(SOC, SOC, Op_RegF, 4, V4->as_VMReg()->next(1)); -reg_def R_V5b(SOC, SOC, Op_RegF, 5, V5->as_VMReg()->next(1)); -reg_def R_V6b(SOC, SOC, Op_RegF, 6, V6->as_VMReg()->next(1)); -reg_def R_V7b(SOC, SOC, Op_RegF, 7, V7->as_VMReg()->next(1)); -reg_def R_V8b(SOC, SOC, Op_RegF, 255, V8->as_VMReg()->next(1)); -reg_def R_V9b(SOC, SOC, Op_RegF, 9, V9->as_VMReg()->next(1)); -reg_def R_V10b(SOC, SOC, Op_RegF, 10, V10->as_VMReg()->next(1)); -reg_def R_V11b(SOC, SOC, Op_RegF, 11, V11->as_VMReg()->next(1)); -reg_def R_V12b(SOC, SOC, Op_RegF, 12, V12->as_VMReg()->next(1)); -reg_def R_V13b(SOC, SOC, Op_RegF, 13, V13->as_VMReg()->next(1)); -reg_def R_V14b(SOC, SOC, Op_RegF, 14, V14->as_VMReg()->next(1)); -reg_def R_V15b(SOC, SOC, Op_RegF, 15, V15->as_VMReg()->next(1)); -reg_def R_V16b(SOC, SOC, Op_RegF, 16, V16->as_VMReg()->next(1)); -reg_def R_V17b(SOC, SOC, Op_RegF, 17, V17->as_VMReg()->next(1)); -reg_def R_V18b(SOC, SOC, Op_RegF, 18, V18->as_VMReg()->next(1)); -reg_def R_V19b(SOC, SOC, Op_RegF, 19, V19->as_VMReg()->next(1)); -reg_def R_V20b(SOC, SOC, Op_RegF, 20, V20->as_VMReg()->next(1)); -reg_def R_V21b(SOC, SOC, Op_RegF, 21, V21->as_VMReg()->next(1)); -reg_def R_V22b(SOC, SOC, Op_RegF, 22, V22->as_VMReg()->next(1)); -reg_def R_V23b(SOC, SOC, Op_RegF, 23, V23->as_VMReg()->next(1)); -reg_def R_V24b(SOC, SOC, Op_RegF, 24, V24->as_VMReg()->next(1)); -reg_def R_V25b(SOC, SOC, Op_RegF, 25, V25->as_VMReg()->next(1)); -reg_def R_V26b(SOC, SOC, Op_RegF, 26, V26->as_VMReg()->next(1)); -reg_def R_V27b(SOC, SOC, Op_RegF, 27, V27->as_VMReg()->next(1)); -reg_def R_V28b(SOC, SOC, Op_RegF, 28, V28->as_VMReg()->next(1)); -reg_def R_V29b(SOC, SOC, Op_RegF, 29, V29->as_VMReg()->next(1)); -reg_def R_V30b(SOC, SOC, Op_RegD, 30, V30->as_VMReg()->next(1)); -reg_def R_V31b(SOC, SOC, Op_RegF, 31, V31->as_VMReg()->next(1)); - -reg_def R_V0c(SOC, SOC, Op_RegF, 0, V0->as_VMReg()->next(2)); -reg_def R_V1c(SOC, SOC, Op_RegF, 1, V1->as_VMReg()->next(2)); -reg_def R_V2c(SOC, SOC, Op_RegF, 2, V2->as_VMReg()->next(2)); -reg_def R_V3c(SOC, SOC, Op_RegF, 3, V3->as_VMReg()->next(2)); -reg_def R_V4c(SOC, SOC, Op_RegF, 4, V4->as_VMReg()->next(2)); -reg_def R_V5c(SOC, SOC, Op_RegF, 5, V5->as_VMReg()->next(2)); -reg_def R_V6c(SOC, SOC, Op_RegF, 6, V6->as_VMReg()->next(2)); -reg_def R_V7c(SOC, SOC, Op_RegF, 7, V7->as_VMReg()->next(2)); -reg_def R_V8c(SOC, SOC, Op_RegF, 8, V8->as_VMReg()->next(2)); -reg_def R_V9c(SOC, SOC, Op_RegF, 9, V9->as_VMReg()->next(2)); -reg_def R_V10c(SOC, SOC, Op_RegF, 10, V10->as_VMReg()->next(2)); -reg_def R_V11c(SOC, SOC, Op_RegF, 11, V11->as_VMReg()->next(2)); -reg_def R_V12c(SOC, SOC, Op_RegF, 12, V12->as_VMReg()->next(2)); -reg_def R_V13c(SOC, SOC, Op_RegF, 13, V13->as_VMReg()->next(2)); -reg_def R_V14c(SOC, SOC, Op_RegF, 14, V14->as_VMReg()->next(2)); -reg_def R_V15c(SOC, SOC, Op_RegF, 15, V15->as_VMReg()->next(2)); -reg_def R_V16c(SOC, SOC, Op_RegF, 16, V16->as_VMReg()->next(2)); -reg_def R_V17c(SOC, SOC, Op_RegF, 17, V17->as_VMReg()->next(2)); -reg_def R_V18c(SOC, SOC, Op_RegF, 18, V18->as_VMReg()->next(2)); -reg_def R_V19c(SOC, SOC, Op_RegF, 19, V19->as_VMReg()->next(2)); -reg_def R_V20c(SOC, SOC, Op_RegF, 20, V20->as_VMReg()->next(2)); -reg_def R_V21c(SOC, SOC, Op_RegF, 21, V21->as_VMReg()->next(2)); -reg_def R_V22c(SOC, SOC, Op_RegF, 22, V22->as_VMReg()->next(2)); -reg_def R_V23c(SOC, SOC, Op_RegF, 23, V23->as_VMReg()->next(2)); -reg_def R_V24c(SOC, SOC, Op_RegF, 24, V24->as_VMReg()->next(2)); -reg_def R_V25c(SOC, SOC, Op_RegF, 25, V25->as_VMReg()->next(2)); -reg_def R_V26c(SOC, SOC, Op_RegF, 26, V26->as_VMReg()->next(2)); -reg_def R_V27c(SOC, SOC, Op_RegF, 27, V27->as_VMReg()->next(2)); -reg_def R_V28c(SOC, SOC, Op_RegF, 28, V28->as_VMReg()->next(2)); -reg_def R_V29c(SOC, SOC, Op_RegF, 29, V29->as_VMReg()->next(2)); -reg_def R_V30c(SOC, SOC, Op_RegF, 30, V30->as_VMReg()->next(2)); -reg_def R_V31c(SOC, SOC, Op_RegF, 31, V31->as_VMReg()->next(2)); - -reg_def R_V0d(SOC, SOC, Op_RegF, 0, V0->as_VMReg()->next(3)); -reg_def R_V1d(SOC, SOC, Op_RegF, 1, V1->as_VMReg()->next(3)); -reg_def R_V2d(SOC, SOC, Op_RegF, 2, V2->as_VMReg()->next(3)); -reg_def R_V3d(SOC, SOC, Op_RegF, 3, V3->as_VMReg()->next(3)); -reg_def R_V4d(SOC, SOC, Op_RegF, 4, V4->as_VMReg()->next(3)); -reg_def R_V5d(SOC, SOC, Op_RegF, 5, V5->as_VMReg()->next(3)); -reg_def R_V6d(SOC, SOC, Op_RegF, 6, V6->as_VMReg()->next(3)); -reg_def R_V7d(SOC, SOC, Op_RegF, 7, V7->as_VMReg()->next(3)); -reg_def R_V8d(SOC, SOC, Op_RegF, 8, V8->as_VMReg()->next(3)); -reg_def R_V9d(SOC, SOC, Op_RegF, 9, V9->as_VMReg()->next(3)); -reg_def R_V10d(SOC, SOC, Op_RegF, 10, V10->as_VMReg()->next(3)); -reg_def R_V11d(SOC, SOC, Op_RegF, 11, V11->as_VMReg()->next(3)); -reg_def R_V12d(SOC, SOC, Op_RegF, 12, V12->as_VMReg()->next(3)); -reg_def R_V13d(SOC, SOC, Op_RegF, 13, V13->as_VMReg()->next(3)); -reg_def R_V14d(SOC, SOC, Op_RegF, 14, V14->as_VMReg()->next(3)); -reg_def R_V15d(SOC, SOC, Op_RegF, 15, V15->as_VMReg()->next(3)); -reg_def R_V16d(SOC, SOC, Op_RegF, 16, V16->as_VMReg()->next(3)); -reg_def R_V17d(SOC, SOC, Op_RegF, 17, V17->as_VMReg()->next(3)); -reg_def R_V18d(SOC, SOC, Op_RegF, 18, V18->as_VMReg()->next(3)); -reg_def R_V19d(SOC, SOC, Op_RegF, 19, V19->as_VMReg()->next(3)); -reg_def R_V20d(SOC, SOC, Op_RegF, 20, V20->as_VMReg()->next(3)); -reg_def R_V21d(SOC, SOC, Op_RegF, 21, V21->as_VMReg()->next(3)); -reg_def R_V22d(SOC, SOC, Op_RegF, 22, V22->as_VMReg()->next(3)); -reg_def R_V23d(SOC, SOC, Op_RegF, 23, V23->as_VMReg()->next(3)); -reg_def R_V24d(SOC, SOC, Op_RegF, 24, V24->as_VMReg()->next(3)); -reg_def R_V25d(SOC, SOC, Op_RegF, 25, V25->as_VMReg()->next(3)); -reg_def R_V26d(SOC, SOC, Op_RegF, 26, V26->as_VMReg()->next(3)); -reg_def R_V27d(SOC, SOC, Op_RegF, 27, V27->as_VMReg()->next(3)); -reg_def R_V28d(SOC, SOC, Op_RegF, 28, V28->as_VMReg()->next(3)); -reg_def R_V29d(SOC, SOC, Op_RegF, 29, V29->as_VMReg()->next(3)); -reg_def R_V30d(SOC, SOC, Op_RegF, 30, V30->as_VMReg()->next(3)); -reg_def R_V31d(SOC, SOC, Op_RegF, 31, V31->as_VMReg()->next(3)); - -// ---------------------------- -// Special Registers -// Condition Codes Flag Registers -reg_def APSR (SOC, SOC, Op_RegFlags, 255, VMRegImpl::Bad()); -reg_def FPSCR(SOC, SOC, Op_RegFlags, 255, VMRegImpl::Bad()); - -// ---------------------------- -// Specify the enum values for the registers. These enums are only used by the -// OptoReg "class". We can convert these enum values at will to VMReg when needed -// for visibility to the rest of the vm. The order of this enum influences the -// register allocator so having the freedom to set this order and not be stuck -// with the order that is natural for the rest of the vm is worth it. - -// Quad vector must be aligned here, so list them first. -alloc_class fprs( - R_V8, R_V8b, R_V8c, R_V8d, R_V9, R_V9b, R_V9c, R_V9d, - R_V10, R_V10b, R_V10c, R_V10d, R_V11, R_V11b, R_V11c, R_V11d, - R_V12, R_V12b, R_V12c, R_V12d, R_V13, R_V13b, R_V13c, R_V13d, - R_V14, R_V14b, R_V14c, R_V14d, R_V15, R_V15b, R_V15c, R_V15d, - R_V16, R_V16b, R_V16c, R_V16d, R_V17, R_V17b, R_V17c, R_V17d, - R_V18, R_V18b, R_V18c, R_V18d, R_V19, R_V19b, R_V19c, R_V19d, - R_V20, R_V20b, R_V20c, R_V20d, R_V21, R_V21b, R_V21c, R_V21d, - R_V22, R_V22b, R_V22c, R_V22d, R_V23, R_V23b, R_V23c, R_V23d, - R_V24, R_V24b, R_V24c, R_V24d, R_V25, R_V25b, R_V25c, R_V25d, - R_V26, R_V26b, R_V26c, R_V26d, R_V27, R_V27b, R_V27c, R_V27d, - R_V28, R_V28b, R_V28c, R_V28d, R_V29, R_V29b, R_V29c, R_V29d, - R_V30, R_V30b, R_V30c, R_V30d, R_V31, R_V31b, R_V31c, R_V31d, - R_V0, R_V0b, R_V0c, R_V0d, R_V1, R_V1b, R_V1c, R_V1d, - R_V2, R_V2b, R_V2c, R_V2d, R_V3, R_V3b, R_V3c, R_V3d, - R_V4, R_V4b, R_V4c, R_V4d, R_V5, R_V5b, R_V5c, R_V5d, - R_V6, R_V6b, R_V6c, R_V6d, R_V7, R_V7b, R_V7c, R_V7d -); - -// Need double-register alignment here. -// We are already quad-register aligned because of vectors above. -alloc_class gprs( - R_R0, R_R0x, R_R1, R_R1x, R_R2, R_R2x, R_R3, R_R3x, - R_R4, R_R4x, R_R5, R_R5x, R_R6, R_R6x, R_R7, R_R7x, - R_R8, R_R8x, R_R9, R_R9x, R_R10, R_R10x, R_R11, R_R11x, - R_R12, R_R12x, R_R13, R_R13x, R_R14, R_R14x, R_R15, R_R15x, - R_R16, R_R16x, R_R17, R_R17x, R_R18, R_R18x, R_R19, R_R19x, - R_R20, R_R20x, R_R21, R_R21x, R_R22, R_R22x, R_R23, R_R23x, - R_R24, R_R24x, R_R25, R_R25x, R_R26, R_R26x, R_R27, R_R27x, - R_R28, R_R28x, R_R29, R_R29x, R_R30, R_R30x -); -// Continuing with double-reigister alignment... -alloc_class chunk2(APSR, FPSCR); -alloc_class chunk3(R_SP, R_SPx); -alloc_class chunk4(R_ZR, R_ZRx); - -//----------Architecture Description Register Classes-------------------------- -// Several register classes are automatically defined based upon information in -// this architecture description. -// 1) reg_class inline_cache_reg ( as defined in frame section ) -// 2) reg_class interpreter_method_oop_reg ( as defined in frame section ) -// 3) reg_class stack_slots( /* one chunk of stack-based "registers" */ ) -// - -// ---------------------------- -// Integer Register Classes -// ---------------------------- -reg_class int_reg_all(R_R0, R_R1, R_R2, R_R3, R_R4, R_R5, R_R6, R_R7, - R_R8, R_R9, R_R10, R_R11, R_R12, R_R13, R_R14, R_R15, - R_R16, R_R17, R_R18, R_R19, R_R20, R_R21, R_R22, R_R23, - R_R24, R_R25, R_R26, R_R27, R_R28, R_R29, R_R30 -); - -// Exclusions from i_reg: -// SP (R31) -// Rthread/R28: reserved by HotSpot to the TLS register (invariant within Java) -reg_class int_reg %{ - return _INT_REG_mask; -%} -reg_class ptr_reg %{ - return _PTR_REG_mask; -%} -reg_class vectorx_reg %{ - return _VECTORX_REG_mask; -%} - -reg_class R0_regI(R_R0); -reg_class R1_regI(R_R1); -reg_class R2_regI(R_R2); -reg_class R3_regI(R_R3); -//reg_class R12_regI(R_R12); - -// ---------------------------- -// Pointer Register Classes -// ---------------------------- - -// Special class for storeP instructions, which can store SP or RPC to TLS. -// It is also used for memory addressing, allowing direct TLS addressing. - -reg_class sp_ptr_reg %{ - return _SP_PTR_REG_mask; -%} - -reg_class store_reg %{ - return _STR_REG_mask; -%} - -reg_class store_ptr_reg %{ - return _STR_PTR_REG_mask; -%} - -reg_class spillP_reg %{ - return _SPILLP_REG_mask; -%} - -// Other special pointer regs -reg_class R0_regP(R_R0, R_R0x); -reg_class R1_regP(R_R1, R_R1x); -reg_class R2_regP(R_R2, R_R2x); -reg_class Rexception_regP(R_R19, R_R19x); -reg_class Ricklass_regP(R_R8, R_R8x); -reg_class Rmethod_regP(R_R27, R_R27x); - -reg_class Rthread_regP(R_R28, R_R28x); -reg_class IP_regP(R_R16, R_R16x); -#define RtempRegP IPRegP -reg_class LR_regP(R_R30, R_R30x); - -reg_class SP_regP(R_SP, R_SPx); -reg_class FP_regP(R_R29, R_R29x); - -reg_class ZR_regP(R_ZR, R_ZRx); -reg_class ZR_regI(R_ZR); - -// ---------------------------- -// Long Register Classes -// ---------------------------- -reg_class long_reg %{ return _PTR_REG_mask; %} -// for ldrexd, strexd: first reg of pair must be even -reg_class long_reg_align %{ return LONG_REG_mask(); %} - -reg_class R0_regL(R_R0,R_R0x); // arg 1 or return value - -// ---------------------------- -// Special Class for Condition Code Flags Register -reg_class int_flags(APSR); -reg_class float_flags(FPSCR); - - -// ---------------------------- -// Float Point Register Classes -// ---------------------------- -reg_class sflt_reg_0( - R_V0, R_V1, R_V2, R_V3, R_V4, R_V5, R_V6, R_V7, - R_V8, R_V9, R_V10, R_V11, R_V12, R_V13, R_V14, R_V15, - R_V16, R_V17, R_V18, R_V19, R_V20, R_V21, R_V22, R_V23, - R_V24, R_V25, R_V26, R_V27, R_V28, R_V29, R_V30, R_V31); - -reg_class sflt_reg %{ - return _SFLT_REG_mask; -%} - -reg_class dflt_low_reg %{ - return _DFLT_REG_mask; -%} - -reg_class actual_dflt_reg %{ - return _DFLT_REG_mask; -%} - -reg_class vectorx_reg_0( - R_V0, R_V1, R_V2, R_V3, R_V4, R_V5, R_V6, R_V7, - R_V8, R_V9, R_V10, R_V11, R_V12, R_V13, R_V14, R_V15, - R_V16, R_V17, R_V18, R_V19, R_V20, R_V21, R_V22, R_V23, - R_V24, R_V25, R_V26, R_V27, R_V28, R_V29, R_V30, /*R_V31,*/ - R_V0b, R_V1b, R_V2b, R_V3b, R_V4b, R_V5b, R_V6b, R_V7b, - R_V8b, R_V9b, R_V10b, R_V11b, R_V12b, R_V13b, R_V14b, R_V15b, - R_V16b, R_V17b, R_V18b, R_V19b, R_V20b, R_V21b, R_V22b, R_V23b, - R_V24b, R_V25b, R_V26b, R_V27b, R_V28b, R_V29b, R_V30b, /*R_V31b,*/ - R_V0c, R_V1c, R_V2c, R_V3c, R_V4c, R_V5c, R_V6c, R_V7c, - R_V8c, R_V9c, R_V10c, R_V11c, R_V12c, R_V13c, R_V14c, R_V15c, - R_V16c, R_V17c, R_V18c, R_V19c, R_V20c, R_V21c, R_V22c, R_V23c, - R_V24c, R_V25c, R_V26c, R_V27c, R_V28c, R_V29c, R_V30c, /*R_V31c,*/ - R_V0d, R_V1d, R_V2d, R_V3d, R_V4d, R_V5d, R_V6d, R_V7d, - R_V8d, R_V9d, R_V10d, R_V11d, R_V12d, R_V13d, R_V14d, R_V15d, - R_V16d, R_V17d, R_V18d, R_V19d, R_V20d, R_V21d, R_V22d, R_V23d, - R_V24d, R_V25d, R_V26d, R_V27d, R_V28d, R_V29d, R_V30d, /*R_V31d*/); - -reg_class Rmemcopy_reg %{ - return _RMEMCOPY_REG_mask; -%} - -%} - -source_hpp %{ - -const MachRegisterNumbers R_mem_copy_lo_num = R_V31_num; -const MachRegisterNumbers R_mem_copy_hi_num = R_V31b_num; -const FloatRegister Rmemcopy = V31; - -const MachRegisterNumbers R_hf_ret_lo_num = R_V0_num; -const MachRegisterNumbers R_hf_ret_hi_num = R_V0b_num; -const FloatRegister Rhfret = V0; - -extern OptoReg::Name R_Ricklass_num; -extern OptoReg::Name R_Rmethod_num; -extern OptoReg::Name R_tls_num; -extern OptoReg::Name R_Rheap_base_num; - -extern RegMask _INT_REG_mask; -extern RegMask _PTR_REG_mask; -extern RegMask _SFLT_REG_mask; -extern RegMask _DFLT_REG_mask; -extern RegMask _VECTORX_REG_mask; -extern RegMask _RMEMCOPY_REG_mask; -extern RegMask _SP_PTR_REG_mask; -extern RegMask _SPILLP_REG_mask; -extern RegMask _STR_REG_mask; -extern RegMask _STR_PTR_REG_mask; - -#define LDR_DOUBLE "LDR_D" -#define LDR_FLOAT "LDR_S" -#define STR_DOUBLE "STR_D" -#define STR_FLOAT "STR_S" -#define STR_64 "STR" -#define LDR_64 "LDR" -#define STR_32 "STR_W" -#define LDR_32 "LDR_W" -#define MOV_DOUBLE "FMOV_D" -#define MOV_FLOAT "FMOV_S" -#define FMSR "FMOV_SW" -#define FMRS "FMOV_WS" -#define LDREX "ldxr " -#define STREX "stxr " - -#define str_64 str -#define ldr_64 ldr -#define ldr_32 ldr_w -#define ldrex ldxr -#define strex stxr - -#define fmsr fmov_sw -#define fmrs fmov_ws -#define fconsts fmov_s -#define fconstd fmov_d - -static inline bool is_uimm12(jlong imm, int shift) { - return Assembler::is_unsigned_imm_in_range(imm, 12, shift); -} - -static inline bool is_memoryD(int offset) { - int scale = 3; // LogBytesPerDouble - return is_uimm12(offset, scale); -} - -static inline bool is_memoryfp(int offset) { - int scale = LogBytesPerInt; // include 32-bit word accesses - return is_uimm12(offset, scale); -} - -static inline bool is_memoryI(int offset) { - int scale = LogBytesPerInt; - return is_uimm12(offset, scale); -} - -static inline bool is_memoryP(int offset) { - int scale = LogBytesPerWord; - return is_uimm12(offset, scale); -} - -static inline bool is_memoryHD(int offset) { - int scale = LogBytesPerInt; // include 32-bit word accesses - return is_uimm12(offset, scale); -} - -uintx limmL_low(uintx imm, int n); - -static inline bool Xis_aimm(int imm) { - return Assembler::ArithmeticImmediate(imm).is_encoded(); -} - -static inline bool is_aimm(intptr_t imm) { - return Assembler::ArithmeticImmediate(imm).is_encoded(); -} - -static inline bool is_limmL(uintptr_t imm) { - return Assembler::LogicalImmediate(imm).is_encoded(); -} - -static inline bool is_limmL_low(intptr_t imm, int n) { - return is_limmL(limmL_low(imm, n)); -} - -static inline bool is_limmI(jint imm) { - return Assembler::LogicalImmediate(imm, true).is_encoded(); -} - -static inline uintx limmI_low(jint imm, int n) { - return limmL_low(imm, n); -} - -static inline bool is_limmI_low(jint imm, int n) { - return is_limmL_low(imm, n); -} - -%} - -source %{ - -// Given a register encoding, produce a Integer Register object -static Register reg_to_register_object(int register_encoding) { - assert(R0->encoding() == R_R0_enc && R30->encoding() == R_R30_enc, "right coding"); - assert(Rthread->encoding() == R_R28_enc, "right coding"); - assert(SP->encoding() == R_SP_enc, "right coding"); - return as_Register(register_encoding); -} - -// Given a register encoding, produce a single-precision Float Register object -static FloatRegister reg_to_FloatRegister_object(int register_encoding) { - assert(V0->encoding() == R_V0_enc && V31->encoding() == R_V31_enc, "right coding"); - return as_FloatRegister(register_encoding); -} - -RegMask _INT_REG_mask; -RegMask _PTR_REG_mask; -RegMask _SFLT_REG_mask; -RegMask _DFLT_REG_mask; -RegMask _VECTORX_REG_mask; -RegMask _RMEMCOPY_REG_mask; -RegMask _SP_PTR_REG_mask; -RegMask _SPILLP_REG_mask; -RegMask _STR_REG_mask; -RegMask _STR_PTR_REG_mask; - -OptoReg::Name R_Ricklass_num = -1; -OptoReg::Name R_Rmethod_num = -1; -OptoReg::Name R_tls_num = -1; -OptoReg::Name R_Rtemp_num = -1; -OptoReg::Name R_Rheap_base_num = -1; - -static int mov_oop_size = -1; - -#ifdef ASSERT -static bool same_mask(const RegMask &a, const RegMask &b) { - RegMask a_sub_b = a; a_sub_b.SUBTRACT(b); - RegMask b_sub_a = b; b_sub_a.SUBTRACT(a); - return a_sub_b.Size() == 0 && b_sub_a.Size() == 0; -} -#endif - -void Compile::pd_compiler2_init() { - - R_Ricklass_num = OptoReg::as_OptoReg(Ricklass->as_VMReg()); - R_Rmethod_num = OptoReg::as_OptoReg(Rmethod->as_VMReg()); - R_tls_num = OptoReg::as_OptoReg(Rthread->as_VMReg()); - R_Rtemp_num = OptoReg::as_OptoReg(Rtemp->as_VMReg()); - R_Rheap_base_num = OptoReg::as_OptoReg(Rheap_base->as_VMReg()); - - _INT_REG_mask = _INT_REG_ALL_mask; - _INT_REG_mask.Remove(R_tls_num); - _INT_REG_mask.Remove(R_SP_num); - if (UseCompressedOops) { - _INT_REG_mask.Remove(R_Rheap_base_num); - } - // Remove Rtemp because safepoint poll can trash it - // (see SharedRuntime::generate_handler_blob) - _INT_REG_mask.Remove(R_Rtemp_num); - - _PTR_REG_mask = _INT_REG_mask; - _PTR_REG_mask.smear_to_sets(2); - - // STR_REG = INT_REG+ZR - // SPILLP_REG = INT_REG+SP - // SP_PTR_REG = INT_REG+SP+TLS - _STR_REG_mask = _INT_REG_mask; - _SP_PTR_REG_mask = _STR_REG_mask; - _STR_REG_mask.Insert(R_ZR_num); - _SP_PTR_REG_mask.Insert(R_SP_num); - _SPILLP_REG_mask = _SP_PTR_REG_mask; - _SP_PTR_REG_mask.Insert(R_tls_num); - _STR_PTR_REG_mask = _STR_REG_mask; - _STR_PTR_REG_mask.smear_to_sets(2); - _SP_PTR_REG_mask.smear_to_sets(2); - _SPILLP_REG_mask.smear_to_sets(2); - - _RMEMCOPY_REG_mask = RegMask(R_mem_copy_lo_num); -assert(OptoReg::as_OptoReg(Rmemcopy->as_VMReg()) == R_mem_copy_lo_num, "!"); - - _SFLT_REG_mask = _SFLT_REG_0_mask; - _SFLT_REG_mask.SUBTRACT(_RMEMCOPY_REG_mask); - _DFLT_REG_mask = _SFLT_REG_mask; - _DFLT_REG_mask.smear_to_sets(2); - _VECTORX_REG_mask = _SFLT_REG_mask; - _VECTORX_REG_mask.smear_to_sets(4); - assert(same_mask(_VECTORX_REG_mask, _VECTORX_REG_0_mask), "!"); - -#ifdef ASSERT - RegMask r((RegMask *)&SFLT_REG_mask()); - r.smear_to_sets(2); - assert(same_mask(r, _DFLT_REG_mask), "!"); -#endif - - if (VM_Version::prefer_moves_over_load_literal()) { - mov_oop_size = 4; - } else { - mov_oop_size = 1; - } - - assert(Matcher::interpreter_method_oop_reg_encode() == Rmethod->encoding(), "should be"); -} - -uintx limmL_low(uintx imm, int n) { - // 1: try as is - if (is_limmL(imm)) { - return imm; - } - // 2: try low bits + all 0's - uintx imm0 = imm & right_n_bits(n); - if (is_limmL(imm0)) { - return imm0; - } - // 3: try low bits + all 1's - uintx imm1 = imm0 | left_n_bits(BitsPerWord - n); - if (is_limmL(imm1)) { - return imm1; - } -#if 0 - // 4: try low bits replicated - int field = 1 << log2_intptr(n + n - 1); - assert(field >= n, "!"); - assert(field / n == 1, "!"); - intptr_t immr = immx; - while (field < BitsPerWord) { - intrptr_t bits = immr & right_n_bits(field); - immr = bits | (bits << field); - field = field << 1; - } - // replicate at power-of-2 boundary - if (is_limmL(immr)) { - return immr; - } -#endif - return imm; -} - -// Convert the raw encoding form into the form expected by the -// constructor for Address. -Address Address::make_raw(int base, int index, int scale, int disp, relocInfo::relocType disp_reloc) { - RelocationHolder rspec; - if (disp_reloc != relocInfo::none) { - rspec = Relocation::spec_simple(disp_reloc); - } - - Register rbase = (base == 0xff) ? SP : as_Register(base); - if (index != 0xff) { - Register rindex = as_Register(index); - if (disp == 0x7fffffff) { // special value to indicate sign-extend - Address madr(rbase, rindex, ex_sxtw, scale); - madr._rspec = rspec; - return madr; - } else { - assert(disp == 0, "unsupported"); - Address madr(rbase, rindex, ex_lsl, scale); - madr._rspec = rspec; - return madr; - } - } else { - assert(scale == 0, "not supported"); - Address madr(rbase, disp); - madr._rspec = rspec; - return madr; - } -} - -// Location of compiled Java return values. Same as C -OptoRegPair c2::return_value(int ideal_reg) { - assert( ideal_reg >= Op_RegI && ideal_reg <= Op_RegL, "only return normal values" ); - static int lo[Op_RegL+1] = { 0, 0, OptoReg::Bad, R_R0_num, R_R0_num, R_hf_ret_lo_num, R_hf_ret_lo_num, R_R0_num }; - static int hi[Op_RegL+1] = { 0, 0, OptoReg::Bad, OptoReg::Bad, R_R0x_num, OptoReg::Bad, R_hf_ret_hi_num, R_R0x_num }; - return OptoRegPair( hi[ideal_reg], lo[ideal_reg]); -} - -// !!!!! Special hack to get all type of calls to specify the byte offset -// from the start of the call to the point where the return address -// will point. - -int MachCallStaticJavaNode::ret_addr_offset() { - bool far = (_method == NULL) ? maybe_far_call(this) : !cache_reachable(); - bool patchable = _method != NULL; - int call_size = MacroAssembler::call_size(entry_point(), far, patchable); - return (call_size + (_method_handle_invoke ? 1 : 0)) * NativeInstruction::instruction_size; -} - -int MachCallDynamicJavaNode::ret_addr_offset() { - bool far = !cache_reachable(); - int call_size = MacroAssembler::call_size(entry_point(), far, true); - return (mov_oop_size + call_size) * NativeInstruction::instruction_size; -} - -int MachCallRuntimeNode::ret_addr_offset() { - int call_size = 0; - // TODO: check if Leaf nodes also need this - if (!is_MachCallLeaf()) { - // adr $temp, ret_addr - // str $temp, [SP + last_java_pc] - call_size += 2; - } - // bl or mov_slow; blr - bool far = maybe_far_call(this); - call_size += MacroAssembler::call_size(entry_point(), far, false); - return call_size * NativeInstruction::instruction_size; -} - -%} - -// The intptr_t operand types, defined by textual substitution. -// (Cf. opto/type.hpp. This lets us avoid many, many other ifdefs.) -#define immX immL -#define iRegX iRegL -#define aimmX aimmL -#define limmX limmL -#define immX9 immL9 -#define LShiftX LShiftL -#define shimmX immU6 - -#define store_RegLd store_RegL - -//----------ATTRIBUTES--------------------------------------------------------- -//----------Operand Attributes------------------------------------------------- -op_attrib op_cost(1); // Required cost attribute - -//----------OPERANDS----------------------------------------------------------- -// Operand definitions must precede instruction definitions for correct parsing -// in the ADLC because operands constitute user defined types which are used in -// instruction definitions. - -//----------Simple Operands---------------------------------------------------- -// Immediate Operands - -// Integer Immediate: 9-bit (including sign bit), so same as immI8? -// FIXME: simm9 allows -256, but immI8 doesn't... -operand simm9() %{ - predicate(Assembler::is_imm_in_range(n->get_int(), 9, 0)); - match(ConI); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - - -operand uimm12() %{ - predicate(Assembler::is_unsigned_imm_in_range(n->get_int(), 12, 0)); - match(ConI); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -operand aimmP() %{ - predicate(n->get_ptr() == 0 || (is_aimm(n->get_ptr()) && ((ConPNode*)n)->type()->reloc() == relocInfo::none)); - match(ConP); - - op_cost(0); - // formats are generated automatically for constants and base registers - format %{ %} - interface(CONST_INTER); -%} - -// Long Immediate: 12-bit - for addressing mode -operand immL12() %{ - predicate((-4096 < n->get_long()) && (n->get_long() < 4096)); - match(ConL); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -// Long Immediate: 9-bit - for addressing mode -operand immL9() %{ - predicate((-256 <= n->get_long()) && (n->get_long() < 256)); - match(ConL); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -operand immIMov() %{ - predicate(n->get_int() >> 16 == 0); - match(ConI); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -operand immLMov() %{ - predicate(n->get_long() >> 16 == 0); - match(ConL); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -operand immUL12() %{ - predicate(is_uimm12(n->get_long(), 0)); - match(ConL); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -operand immUL12x2() %{ - predicate(is_uimm12(n->get_long(), 1)); - match(ConL); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -operand immUL12x4() %{ - predicate(is_uimm12(n->get_long(), 2)); - match(ConL); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -operand immUL12x8() %{ - predicate(is_uimm12(n->get_long(), 3)); - match(ConL); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -operand immUL12x16() %{ - predicate(is_uimm12(n->get_long(), 4)); - match(ConL); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -// Used for long shift -operand immU6() %{ - predicate(0 <= n->get_int() && (n->get_int() <= 63)); - match(ConI); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -// Used for register extended shift -operand immI_0_4() %{ - predicate(0 <= n->get_int() && (n->get_int() <= 4)); - match(ConI); - op_cost(0); - - format %{ %} - interface(CONST_INTER); -%} - -// Compressed Pointer Register -operand iRegN() %{ - constraint(ALLOC_IN_RC(int_reg)); - match(RegN); - match(ZRRegN); - - format %{ %} - interface(REG_INTER); -%} - -operand SPRegP() %{ - constraint(ALLOC_IN_RC(SP_regP)); - match(RegP); - - format %{ %} - interface(REG_INTER); -%} - -operand ZRRegP() %{ - constraint(ALLOC_IN_RC(ZR_regP)); - match(RegP); - - format %{ %} - interface(REG_INTER); -%} - -operand ZRRegL() %{ - constraint(ALLOC_IN_RC(ZR_regP)); - match(RegL); - - format %{ %} - interface(REG_INTER); -%} - -operand ZRRegI() %{ - constraint(ALLOC_IN_RC(ZR_regI)); - match(RegI); - - format %{ %} - interface(REG_INTER); -%} - -operand ZRRegN() %{ - constraint(ALLOC_IN_RC(ZR_regI)); - match(RegN); - - format %{ %} - interface(REG_INTER); -%} diff --git a/src/hotspot/cpu/arm/assembler_arm.hpp b/src/hotspot/cpu/arm/assembler_arm.hpp index 694660f431d..4e0bd822e74 100644 --- a/src/hotspot/cpu/arm/assembler_arm.hpp +++ b/src/hotspot/cpu/arm/assembler_arm.hpp @@ -40,29 +40,14 @@ enum AsmShift { lsl, lsr, asr, ror }; -#ifdef AARCH64 -enum AsmExtendOp { - ex_uxtb, ex_uxth, ex_uxtw, ex_uxtx, - ex_sxtb, ex_sxth, ex_sxtw, ex_sxtx, - - ex_lsl = ex_uxtx -}; -#endif enum AsmOffset { -#ifdef AARCH64 - basic_offset = 0b00, - pre_indexed = 0b11, - post_indexed = 0b01 -#else basic_offset = 1 << 24, pre_indexed = 1 << 24 | 1 << 21, post_indexed = 0 -#endif }; -#ifndef AARCH64 enum AsmWriteback { no_writeback, writeback @@ -72,7 +57,6 @@ enum AsmOffsetOp { sub_offset = 0, add_offset = 1 }; -#endif // ARM Addressing Modes 2 and 3 - Load and store @@ -84,21 +68,13 @@ class Address { AsmOffset _mode; RelocationHolder _rspec; int _shift_imm; -#ifdef AARCH64 - AsmExtendOp _extend; -#else AsmShift _shift; AsmOffsetOp _offset_op; static inline int abs(int x) { return x < 0 ? -x : x; } static inline int up (int x) { return x < 0 ? 0 : 1; } -#endif -#ifdef AARCH64 - static const AsmExtendOp LSL = ex_lsl; -#else static const AsmShift LSL = lsl; -#endif public: Address() : _base(noreg) {} @@ -109,12 +85,8 @@ class Address { _disp = offset; _mode = mode; _shift_imm = 0; -#ifdef AARCH64 - _extend = ex_lsl; -#else _shift = lsl; _offset_op = add_offset; -#endif } #ifdef ASSERT @@ -124,27 +96,11 @@ class Address { _disp = in_bytes(offset); _mode = mode; _shift_imm = 0; -#ifdef AARCH64 - _extend = ex_lsl; -#else _shift = lsl; _offset_op = add_offset; -#endif } #endif -#ifdef AARCH64 - Address(Register rn, Register rm, AsmExtendOp extend = ex_lsl, int shift_imm = 0) { - assert ((extend == ex_uxtw) || (extend == ex_lsl) || (extend == ex_sxtw) || (extend == ex_sxtx), "invalid extend for address mode"); - assert ((0 <= shift_imm) && (shift_imm <= 4), "shift amount is out of range"); - _base = rn; - _index = rm; - _disp = 0; - _mode = basic_offset; - _extend = extend; - _shift_imm = shift_imm; - } -#else Address(Register rn, Register rm, AsmShift shift = lsl, int shift_imm = 0, AsmOffset mode = basic_offset, AsmOffsetOp offset_op = add_offset) { @@ -181,7 +137,6 @@ class Address { _mode = basic_offset; _offset_op = add_offset; } -#endif // AARCH64 // [base + index * wordSize] static Address indexed_ptr(Register base, Register index) { @@ -211,25 +166,6 @@ class Address { return a; } -#ifdef AARCH64 - int encoding_simd() const { - assert(_index != SP, "encoding constraint"); - assert(_disp == 0 || _mode == post_indexed, "encoding constraint"); - assert(_index == noreg || _mode == basic_offset, "encoding constraint"); - assert(_mode == basic_offset || _mode == post_indexed, "encoding constraint"); - assert(_extend == ex_lsl, "encoding constraint"); - int index; - if (_index == noreg) { - if (_mode == post_indexed) - index = 0b100 << 5 | 31; - else - index = 0; - } else { - index = 0b100 << 5 | _index->encoding(); - } - return index << 16 | _base->encoding_with_sp() << 5; - } -#else /* !AARCH64 */ int encoding2() const { assert(_mode == basic_offset || _base != PC, "unpredictable instruction"); if (_index == noreg) { @@ -287,7 +223,6 @@ class Address { return _base->encoding() << 16 | index; } -#endif // !AARCH64 Register base() const { return _base; @@ -309,11 +244,6 @@ class Address { return _shift_imm; } -#ifdef AARCH64 - AsmExtendOp extend() const { - return _extend; - } -#else AsmShift shift() const { return _shift; } @@ -321,7 +251,6 @@ class Address { AsmOffsetOp offset_op() const { return _offset_op; } -#endif bool uses(Register reg) const { return _base == reg || _index == reg; } @@ -394,11 +323,7 @@ class VFP { }; #endif -#ifdef AARCH64 -#include "assembler_arm_64.hpp" -#else #include "assembler_arm_32.hpp" -#endif #endif // CPU_ARM_VM_ASSEMBLER_ARM_HPP diff --git a/src/hotspot/cpu/arm/assembler_arm_64.cpp b/src/hotspot/cpu/arm/assembler_arm_64.cpp deleted file mode 100644 index 1e06cca452d..00000000000 --- a/src/hotspot/cpu/arm/assembler_arm_64.cpp +++ /dev/null @@ -1,186 +0,0 @@ -/* - * Copyright (c) 2008, 2018, 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 "asm/assembler.hpp" -#include "asm/assembler.inline.hpp" -#include "ci/ciEnv.hpp" -#include "gc/shared/cardTableBarrierSet.hpp" -#include "gc/shared/collectedHeap.inline.hpp" -#include "interpreter/interpreter.hpp" -#include "interpreter/interpreterRuntime.hpp" -#include "interpreter/templateInterpreterGenerator.hpp" -#include "memory/resourceArea.hpp" -#include "prims/jvm_misc.hpp" -#include "prims/methodHandles.hpp" -#include "runtime/biasedLocking.hpp" -#include "runtime/interfaceSupport.inline.hpp" -#include "runtime/objectMonitor.hpp" -#include "runtime/os.hpp" -#include "runtime/sharedRuntime.hpp" -#include "runtime/stubRoutines.hpp" -#include "utilities/hashtable.hpp" -#include "utilities/macros.hpp" - -// Returns whether given imm has equal bit fields <0:size-1> and . -inline bool Assembler::LogicalImmediate::has_equal_subpatterns(uintx imm, int size) { - uintx mask = right_n_bits(size); - uintx subpattern1 = mask_bits(imm, mask); - uintx subpattern2 = mask_bits(imm >> size, mask); - return subpattern1 == subpattern2; -} - -// Returns least size that is a power of two from 2 to 64 with the proviso that given -// imm is composed of repeating patterns of this size. -inline int Assembler::LogicalImmediate::least_pattern_size(uintx imm) { - int size = BitsPerWord; - while (size > 2 && has_equal_subpatterns(imm, size >> 1)) { - size >>= 1; - } - return size; -} - -// Returns count of set bits in given imm. Based on variable-precision SWAR algorithm. -inline int Assembler::LogicalImmediate::population_count(uintx x) { - x -= ((x >> 1) & 0x5555555555555555L); - x = (((x >> 2) & 0x3333333333333333L) + (x & 0x3333333333333333L)); - x = (((x >> 4) + x) & 0x0f0f0f0f0f0f0f0fL); - x += (x >> 8); - x += (x >> 16); - x += (x >> 32); - return(x & 0x7f); -} - -// Let given x be where B = 0 and least bit of A = 1. Returns , where C is B-size set bits. -inline uintx Assembler::LogicalImmediate::set_least_zeroes(uintx x) { - return x | (x - 1); -} - - -#ifdef ASSERT - -// Restores immediate by encoded bit masks. -uintx Assembler::LogicalImmediate::decode() { - assert (_encoded, "should be"); - - int len_code = (_immN << 6) | ((~_imms) & 0x3f); - assert (len_code != 0, "should be"); - - int len = 6; - while (!is_set_nth_bit(len_code, len)) len--; - int esize = 1 << len; - assert (len > 0, "should be"); - assert ((_is32bit ? 32 : 64) >= esize, "should be"); - - int levels = right_n_bits(len); - int S = _imms & levels; - int R = _immr & levels; - - assert (S != levels, "should be"); - - uintx welem = right_n_bits(S + 1); - uintx wmask = (R == 0) ? welem : ((welem >> R) | (welem << (esize - R))); - - for (int size = esize; size < 64; size <<= 1) { - wmask |= (wmask << size); - } - - return wmask; -} - -#endif - - -// Constructs LogicalImmediate by given imm. Figures out if given imm can be used in AArch64 logical -// instructions (AND, ANDS, EOR, ORR) and saves its encoding. -void Assembler::LogicalImmediate::construct(uintx imm, bool is32) { - _is32bit = is32; - - if (is32) { - assert(((imm >> 32) == 0) || (((intx)imm >> 31) == -1), "32-bit immediate is out of range"); - - // Replicate low 32 bits. - imm &= 0xffffffff; - imm |= imm << 32; - } - - // All-zeroes and all-ones can not be encoded. - if (imm != 0 && (~imm != 0)) { - - // Let LPS (least pattern size) be the least size (power of two from 2 to 64) of repeating - // patterns in the immediate. If immediate value can be encoded, it is encoded by pattern - // of exactly LPS size (due to structure of valid patterns). In order to verify - // that immediate value can be encoded, LPS is calculated and bits of immediate - // are verified to be valid pattern. - int lps = least_pattern_size(imm); - uintx lps_mask = right_n_bits(lps); - - // A valid pattern has one of the following forms: - // | 0 x A | 1 x B | 0 x C |, where B > 0 and C > 0, or - // | 1 x A | 0 x B | 1 x C |, where B > 0 and C > 0. - // For simplicity, the second form of the pattern is inverted into the first form. - bool inverted = imm & 0x1; - uintx pattern = (inverted ? ~imm : imm) & lps_mask; - - // | 0 x A | 1 x (B + C) | - uintx without_least_zeroes = set_least_zeroes(pattern); - - // Pattern is valid iff without least zeroes it is a power of two - 1. - if ((without_least_zeroes & (without_least_zeroes + 1)) == 0) { - - // Count B as population count of pattern. - int bits_count = population_count(pattern); - - // Count B+C as population count of pattern without least zeroes - int left_range = population_count(without_least_zeroes); - - // S-prefix is a part of imms field which encodes LPS. - // LPS | S prefix - // 64 | not defined - // 32 | 0b0 - // 16 | 0b10 - // 8 | 0b110 - // 4 | 0b1110 - // 2 | 0b11110 - int s_prefix = (lps == 64) ? 0 : ~set_least_zeroes(lps) & 0x3f; - - // immN bit is set iff LPS == 64. - _immN = (lps == 64) ? 1 : 0; - assert (!is32 || (_immN == 0), "32-bit immediate should be encoded with zero N-bit"); - - // immr is the rotation size. - _immr = lps + (inverted ? 0 : bits_count) - left_range; - - // imms is the field that encodes bits count and S-prefix. - _imms = ((inverted ? (lps - bits_count) : bits_count) - 1) | s_prefix; - - _encoded = true; - assert (decode() == imm, "illegal encoding"); - - return; - } - } - - _encoded = false; -} diff --git a/src/hotspot/cpu/arm/assembler_arm_64.hpp b/src/hotspot/cpu/arm/assembler_arm_64.hpp deleted file mode 100644 index 51ca96248a3..00000000000 --- a/src/hotspot/cpu/arm/assembler_arm_64.hpp +++ /dev/null @@ -1,1718 +0,0 @@ -/* - * Copyright (c) 2008, 2018, 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. - * - */ - -#ifndef CPU_ARM_VM_ASSEMBLER_ARM_64_HPP -#define CPU_ARM_VM_ASSEMBLER_ARM_64_HPP - -enum AsmShift12 { - lsl0, lsl12 -}; - -enum AsmPrefetchOp { - pldl1keep = 0b00000, - pldl1strm, - pldl2keep, - pldl2strm, - pldl3keep, - pldl3strm, - - plil1keep = 0b01000, - plil1strm, - plil2keep, - plil2strm, - plil3keep, - plil3strm, - - pstl1keep = 0b10000, - pstl1strm, - pstl2keep, - pstl2strm, - pstl3keep, - pstl3strm, -}; - -// Shifted register operand for data processing instructions. -class AsmOperand { - private: - Register _reg; - AsmShift _shift; - int _shift_imm; - - public: - AsmOperand(Register reg) { - assert(reg != SP, "SP is not allowed in shifted register operand"); - _reg = reg; - _shift = lsl; - _shift_imm = 0; - } - - AsmOperand(Register reg, AsmShift shift, int shift_imm) { - assert(reg != SP, "SP is not allowed in shifted register operand"); - assert(shift_imm >= 0, "shift amount should be non-negative"); - _reg = reg; - _shift = shift; - _shift_imm = shift_imm; - } - - Register reg() const { - return _reg; - } - - AsmShift shift() const { - return _shift; - } - - int shift_imm() const { - return _shift_imm; - } -}; - - -class Assembler : public AbstractAssembler { - - public: - - static const int LogInstructionSize = 2; - static const int InstructionSize = 1 << LogInstructionSize; - - Assembler(CodeBuffer* code) : AbstractAssembler(code) {} - - static inline AsmCondition inverse(AsmCondition cond) { - assert ((cond != al) && (cond != nv), "AL and NV conditions cannot be inversed"); - return (AsmCondition)((int)cond ^ 1); - } - - // Returns value of nzcv flags conforming to the given condition. - static inline int flags_for_condition(AsmCondition cond) { - switch(cond) { // NZCV - case mi: case lt: return 0b1000; - case eq: case le: return 0b0100; - case hs: case hi: return 0b0010; - case vs: return 0b0001; - default: return 0b0000; - } - } - - // Immediate, encoded into logical instructions. - class LogicalImmediate { - private: - bool _encoded; - bool _is32bit; - int _immN; - int _immr; - int _imms; - - static inline bool has_equal_subpatterns(uintx imm, int size); - static inline int least_pattern_size(uintx imm); - static inline int population_count(uintx x); - static inline uintx set_least_zeroes(uintx x); - -#ifdef ASSERT - uintx decode(); -#endif - - void construct(uintx imm, bool is32); - - public: - LogicalImmediate(uintx imm, bool is32 = false) { construct(imm, is32); } - - // Returns true if given immediate can be used in AArch64 logical instruction. - bool is_encoded() const { return _encoded; } - - bool is32bit() const { return _is32bit; } - int immN() const { assert(_encoded, "should be"); return _immN; } - int immr() const { assert(_encoded, "should be"); return _immr; } - int imms() const { assert(_encoded, "should be"); return _imms; } - }; - - // Immediate, encoded into arithmetic add/sub instructions. - class ArithmeticImmediate { - private: - bool _encoded; - int _imm; - AsmShift12 _shift; - - public: - ArithmeticImmediate(intx x) { - if (is_unsigned_imm_in_range(x, 12, 0)) { - _encoded = true; - _imm = x; - _shift = lsl0; - } else if (is_unsigned_imm_in_range(x, 12, 12)) { - _encoded = true; - _imm = x >> 12; - _shift = lsl12; - } else { - _encoded = false; - } - } - - ArithmeticImmediate(intx x, AsmShift12 sh) { - if (is_unsigned_imm_in_range(x, 12, 0)) { - _encoded = true; - _imm = x; - _shift = sh; - } else { - _encoded = false; - } - } - - // Returns true if this immediate can be used in AArch64 arithmetic (add/sub/cmp/cmn) instructions. - bool is_encoded() const { return _encoded; } - - int imm() const { assert(_encoded, "should be"); return _imm; } - AsmShift12 shift() const { assert(_encoded, "should be"); return _shift; } - }; - - static inline bool is_imm_in_range(intx value, int bits, int align_bits) { - intx sign_bits = (value >> (bits + align_bits - 1)); - return ((value & right_n_bits(align_bits)) == 0) && ((sign_bits == 0) || (sign_bits == -1)); - } - - static inline int encode_imm(intx value, int bits, int align_bits, int low_bit_in_encoding) { - assert (is_imm_in_range(value, bits, align_bits), "immediate value is out of range"); - return ((value >> align_bits) & right_n_bits(bits)) << low_bit_in_encoding; - } - - static inline bool is_unsigned_imm_in_range(intx value, int bits, int align_bits) { - return (value >= 0) && ((value & right_n_bits(align_bits)) == 0) && ((value >> (align_bits + bits)) == 0); - } - - static inline int encode_unsigned_imm(intx value, int bits, int align_bits, int low_bit_in_encoding) { - assert (is_unsigned_imm_in_range(value, bits, align_bits), "immediate value is out of range"); - return (value >> align_bits) << low_bit_in_encoding; - } - - static inline bool is_offset_in_range(intx offset, int bits) { - assert (bits == 14 || bits == 19 || bits == 26, "wrong bits number"); - return is_imm_in_range(offset, bits, 2); - } - - static inline int encode_offset(intx offset, int bits, int low_bit_in_encoding) { - return encode_imm(offset, bits, 2, low_bit_in_encoding); - } - - // Returns true if given value can be used as immediate in arithmetic (add/sub/cmp/cmn) instructions. - static inline bool is_arith_imm_in_range(intx value) { - return ArithmeticImmediate(value).is_encoded(); - } - - - // Load/store instructions - -#define F(mnemonic, opc) \ - void mnemonic(Register rd, address literal_addr) { \ - intx offset = literal_addr - pc(); \ - assert (opc != 0b01 || offset == 0 || ((uintx)literal_addr & 7) == 0, "ldr target should be aligned"); \ - assert (is_offset_in_range(offset, 19), "offset is out of range"); \ - emit_int32(opc << 30 | 0b011 << 27 | encode_offset(offset, 19, 5) | rd->encoding_with_zr()); \ - } - - F(ldr_w, 0b00) - F(ldr, 0b01) - F(ldrsw, 0b10) -#undef F - -#define F(mnemonic, opc) \ - void mnemonic(FloatRegister rt, address literal_addr) { \ - intx offset = literal_addr - pc(); \ - assert (offset == 0 || ((uintx)literal_addr & right_n_bits(2 + opc)) == 0, "ldr target should be aligned"); \ - assert (is_offset_in_range(offset, 19), "offset is out of range"); \ - emit_int32(opc << 30 | 0b011100 << 24 | encode_offset(offset, 19, 5) | rt->encoding()); \ - } - - F(ldr_s, 0b00) - F(ldr_d, 0b01) - F(ldr_q, 0b10) -#undef F - -#define F(mnemonic, size, o2, L, o1, o0) \ - void mnemonic(Register rt, Register rn) { \ - emit_int32(size << 30 | 0b001000 << 24 | o2 << 23 | L << 22 | o1 << 21 | 0b11111 << 16 | \ - o0 << 15 | 0b11111 << 10 | rn->encoding_with_sp() << 5 | rt->encoding_with_zr()); \ - } - - F(ldxrb, 0b00, 0, 1, 0, 0) - F(ldaxrb, 0b00, 0, 1, 0, 1) - F(ldarb, 0b00, 1, 1, 0, 1) - F(ldxrh, 0b01, 0, 1, 0, 0) - F(ldaxrh, 0b01, 0, 1, 0, 1) - F(ldarh, 0b01, 1, 1, 0, 1) - F(ldxr_w, 0b10, 0, 1, 0, 0) - F(ldaxr_w, 0b10, 0, 1, 0, 1) - F(ldar_w, 0b10, 1, 1, 0, 1) - F(ldxr, 0b11, 0, 1, 0, 0) - F(ldaxr, 0b11, 0, 1, 0, 1) - F(ldar, 0b11, 1, 1, 0, 1) - - F(stlrb, 0b00, 1, 0, 0, 1) - F(stlrh, 0b01, 1, 0, 0, 1) - F(stlr_w, 0b10, 1, 0, 0, 1) - F(stlr, 0b11, 1, 0, 0, 1) -#undef F - -#define F(mnemonic, size, o2, L, o1, o0) \ - void mnemonic(Register rs, Register rt, Register rn) { \ - assert (rs != rt, "should be different"); \ - assert (rs != rn, "should be different"); \ - emit_int32(size << 30 | 0b001000 << 24 | o2 << 23 | L << 22 | o1 << 21 | rs->encoding_with_zr() << 16 | \ - o0 << 15 | 0b11111 << 10 | rn->encoding_with_sp() << 5 | rt->encoding_with_zr()); \ - } - - F(stxrb, 0b00, 0, 0, 0, 0) - F(stlxrb, 0b00, 0, 0, 0, 1) - F(stxrh, 0b01, 0, 0, 0, 0) - F(stlxrh, 0b01, 0, 0, 0, 1) - F(stxr_w, 0b10, 0, 0, 0, 0) - F(stlxr_w, 0b10, 0, 0, 0, 1) - F(stxr, 0b11, 0, 0, 0, 0) - F(stlxr, 0b11, 0, 0, 0, 1) -#undef F - -#define F(mnemonic, size, o2, L, o1, o0) \ - void mnemonic(Register rt, Register rt2, Register rn) { \ - assert (rt != rt2, "should be different"); \ - emit_int32(size << 30 | 0b001000 << 24 | o2 << 23 | L << 22 | o1 << 21 | 0b11111 << 16 | \ - o0 << 15 | rt2->encoding_with_zr() << 10 | rn->encoding_with_sp() << 5 | rt->encoding_with_zr()); \ - } - - F(ldxp_w, 0b10, 0, 1, 1, 0) - F(ldaxp_w, 0b10, 0, 1, 1, 1) - F(ldxp, 0b11, 0, 1, 1, 0) - F(ldaxp, 0b11, 0, 1, 1, 1) -#undef F - -#define F(mnemonic, size, o2, L, o1, o0) \ - void mnemonic(Register rs, Register rt, Register rt2, Register rn) { \ - assert (rs != rt, "should be different"); \ - assert (rs != rt2, "should be different"); \ - assert (rs != rn, "should be different"); \ - emit_int32(size << 30 | 0b001000 << 24 | o2 << 23 | L << 22 | o1 << 21 | rs->encoding_with_zr() << 16 | \ - o0 << 15 | rt2->encoding_with_zr() << 10 | rn->encoding_with_sp() << 5 | rt->encoding_with_zr()); \ - } - - F(stxp_w, 0b10, 0, 0, 1, 0) - F(stlxp_w, 0b10, 0, 0, 1, 1) - F(stxp, 0b11, 0, 0, 1, 0) - F(stlxp, 0b11, 0, 0, 1, 1) -#undef F - -#define F(mnemonic, opc, V, L) \ - void mnemonic(Register rt, Register rt2, Register rn, int offset = 0) { \ - assert (!L || rt != rt2, "should be different"); \ - int align_bits = 2 + (opc >> 1); \ - assert (is_imm_in_range(offset, 7, align_bits), "offset is out of range"); \ - emit_int32(opc << 30 | 0b101 << 27 | V << 26 | L << 22 | encode_imm(offset, 7, align_bits, 15) | \ - rt2->encoding_with_zr() << 10 | rn->encoding_with_sp() << 5 | rt->encoding_with_zr()); \ - } - - F(stnp_w, 0b00, 0, 0) - F(ldnp_w, 0b00, 0, 1) - F(stnp, 0b10, 0, 0) - F(ldnp, 0b10, 0, 1) -#undef F - -#define F(mnemonic, opc, V, L) \ - void mnemonic(FloatRegister rt, FloatRegister rt2, Register rn, int offset = 0) { \ - assert (!L || (rt != rt2), "should be different"); \ - int align_bits = 2 + opc; \ - assert (is_imm_in_range(offset, 7, align_bits), "offset is out of range"); \ - emit_int32(opc << 30 | 0b101 << 27 | V << 26 | L << 22 | encode_imm(offset, 7, align_bits, 15) | \ - rt2->encoding() << 10 | rn->encoding_with_sp() << 5 | rt->encoding()); \ - } - - F(stnp_s, 0b00, 1, 0) - F(stnp_d, 0b01, 1, 0) - F(stnp_q, 0b10, 1, 0) - F(ldnp_s, 0b00, 1, 1) - F(ldnp_d, 0b01, 1, 1) - F(ldnp_q, 0b10, 1, 1) -#undef F - -#define F(mnemonic, size, V, opc) \ - void mnemonic(Register rt, Address addr) { \ - assert((addr.mode() == basic_offset) || (rt != addr.base()), "should be different"); \ - if (addr.index() == noreg) { \ - if ((addr.mode() == basic_offset) && is_unsigned_imm_in_range(addr.disp(), 12, size)) { \ - emit_int32(size << 30 | 0b111 << 27 | V << 26 | 0b01 << 24 | opc << 22 | \ - encode_unsigned_imm(addr.disp(), 12, size, 10) | \ - addr.base()->encoding_with_sp() << 5 | rt->encoding_with_zr()); \ - } else { \ - assert(is_imm_in_range(addr.disp(), 9, 0), "offset is out of range"); \ - emit_int32(size << 30 | 0b111 << 27 | V << 26 | opc << 22 | encode_imm(addr.disp(), 9, 0, 12) | \ - addr.mode() << 10 | addr.base()->encoding_with_sp() << 5 | rt->encoding_with_zr()); \ - } \ - } else { \ - assert (addr.disp() == 0, "non-zero displacement for [reg + reg] address mode"); \ - assert ((addr.shift_imm() == 0) || (addr.shift_imm() == size), "invalid shift amount"); \ - emit_int32(size << 30 | 0b111 << 27 | V << 26 | opc << 22 | 1 << 21 | \ - addr.index()->encoding_with_zr() << 16 | addr.extend() << 13 | (addr.shift_imm() != 0) << 12 | \ - 0b10 << 10 | addr.base()->encoding_with_sp() << 5 | rt->encoding_with_zr()); \ - } \ - } - - F(strb, 0b00, 0, 0b00) - F(ldrb, 0b00, 0, 0b01) - F(ldrsb, 0b00, 0, 0b10) - F(ldrsb_w, 0b00, 0, 0b11) - - F(strh, 0b01, 0, 0b00) - F(ldrh, 0b01, 0, 0b01) - F(ldrsh, 0b01, 0, 0b10) - F(ldrsh_w, 0b01, 0, 0b11) - - F(str_w, 0b10, 0, 0b00) - F(ldr_w, 0b10, 0, 0b01) - F(ldrsw, 0b10, 0, 0b10) - - F(str, 0b11, 0, 0b00) - F(ldr, 0b11, 0, 0b01) -#undef F - -#define F(mnemonic, size, V, opc) \ - void mnemonic(AsmPrefetchOp prfop, Address addr) { \ - assert (addr.mode() == basic_offset, #mnemonic " supports only basic_offset address mode"); \ - if (addr.index() == noreg) { \ - if (is_unsigned_imm_in_range(addr.disp(), 12, size)) { \ - emit_int32(size << 30 | 0b111 << 27 | V << 26 | 0b01 << 24 | opc << 22 | \ - encode_unsigned_imm(addr.disp(), 12, size, 10) | \ - addr.base()->encoding_with_sp() << 5 | prfop); \ - } else { \ - assert(is_imm_in_range(addr.disp(), 9, 0), "offset is out of range"); \ - emit_int32(size << 30 | 0b111 << 27 | V << 26 | opc << 22 | encode_imm(addr.disp(), 9, 0, 12) | \ - addr.base()->encoding_with_sp() << 5 | prfop); \ - } \ - } else { \ - assert (addr.disp() == 0, "non-zero displacement for [reg + reg] address mode"); \ - assert ((addr.shift_imm() == 0) || (addr.shift_imm() == size), "invalid shift amount"); \ - emit_int32(size << 30 | 0b111 << 27 | V << 26 | opc << 22 | 1 << 21 | \ - addr.index()->encoding_with_zr() << 16 | addr.extend() << 13 | (addr.shift_imm() != 0) << 12 | \ - 0b10 << 10 | addr.base()->encoding_with_sp() << 5 | prfop); \ - } \ - } - - F(prfm, 0b11, 0, 0b10) -#undef F - -#define F(mnemonic, size, V, opc) \ - void mnemonic(FloatRegister rt, Address addr) { \ - int align_bits = (((opc & 0b10) >> 1) << 2) | size; \ - if (addr.index() == noreg) { \ - if ((addr.mode() == basic_offset) && is_unsigned_imm_in_range(addr.disp(), 12, align_bits)) { \ - emit_int32(size << 30 | 0b111 << 27 | V << 26 | 0b01 << 24 | opc << 22 | \ - encode_unsigned_imm(addr.disp(), 12, align_bits, 10) | \ - addr.base()->encoding_with_sp() << 5 | rt->encoding()); \ - } else { \ - assert(is_imm_in_range(addr.disp(), 9, 0), "offset is out of range"); \ - emit_int32(size << 30 | 0b111 << 27 | V << 26 | opc << 22 | encode_imm(addr.disp(), 9, 0, 12) | \ - addr.mode() << 10 | addr.base()->encoding_with_sp() << 5 | rt->encoding()); \ - } \ - } else { \ - assert (addr.disp() == 0, "non-zero displacement for [reg + reg] address mode"); \ - assert ((addr.shift_imm() == 0) || (addr.shift_imm() == align_bits), "invalid shift amount"); \ - emit_int32(size << 30 | 0b111 << 27 | V << 26 | opc << 22 | 1 << 21 | \ - addr.index()->encoding_with_zr() << 16 | addr.extend() << 13 | (addr.shift_imm() != 0) << 12 | \ - 0b10 << 10 | addr.base()->encoding_with_sp() << 5 | rt->encoding()); \ - } \ - } - - F(str_b, 0b00, 1, 0b00) - F(ldr_b, 0b00, 1, 0b01) - F(str_h, 0b01, 1, 0b00) - F(ldr_h, 0b01, 1, 0b01) - F(str_s, 0b10, 1, 0b00) - F(ldr_s, 0b10, 1, 0b01) - F(str_d, 0b11, 1, 0b00) - F(ldr_d, 0b11, 1, 0b01) - F(str_q, 0b00, 1, 0b10) - F(ldr_q, 0b00, 1, 0b11) -#undef F - -#define F(mnemonic, opc, V, L) \ - void mnemonic(Register rt, Register rt2, Address addr) { \ - assert((addr.mode() == basic_offset) || ((rt != addr.base()) && (rt2 != addr.base())), "should be different"); \ - assert(!L || (rt != rt2), "should be different"); \ - assert(addr.index() == noreg, "[reg + reg] address mode is not available for load/store pair"); \ - int align_bits = 2 + (opc >> 1); \ - int mode_encoding = (addr.mode() == basic_offset) ? 0b10 : addr.mode(); \ - assert(is_imm_in_range(addr.disp(), 7, align_bits), "offset is out of range"); \ - emit_int32(opc << 30 | 0b101 << 27 | V << 26 | mode_encoding << 23 | L << 22 | \ - encode_imm(addr.disp(), 7, align_bits, 15) | rt2->encoding_with_zr() << 10 | \ - addr.base()->encoding_with_sp() << 5 | rt->encoding_with_zr()); \ - } - - F(stp_w, 0b00, 0, 0) - F(ldp_w, 0b00, 0, 1) - F(ldpsw, 0b01, 0, 1) - F(stp, 0b10, 0, 0) - F(ldp, 0b10, 0, 1) -#undef F - -#define F(mnemonic, opc, V, L) \ - void mnemonic(FloatRegister rt, FloatRegister rt2, Address addr) { \ - assert(!L || (rt != rt2), "should be different"); \ - assert(addr.index() == noreg, "[reg + reg] address mode is not available for load/store pair"); \ - int align_bits = 2 + opc; \ - int mode_encoding = (addr.mode() == basic_offset) ? 0b10 : addr.mode(); \ - assert(is_imm_in_range(addr.disp(), 7, align_bits), "offset is out of range"); \ - emit_int32(opc << 30 | 0b101 << 27 | V << 26 | mode_encoding << 23 | L << 22 | \ - encode_imm(addr.disp(), 7, align_bits, 15) | rt2->encoding() << 10 | \ - addr.base()->encoding_with_sp() << 5 | rt->encoding()); \ - } - - F(stp_s, 0b00, 1, 0) - F(ldp_s, 0b00, 1, 1) - F(stp_d, 0b01, 1, 0) - F(ldp_d, 0b01, 1, 1) - F(stp_q, 0b10, 1, 0) - F(ldp_q, 0b10, 1, 1) -#undef F - - // Data processing instructions - -#define F(mnemonic, sf, opc) \ - void mnemonic(Register rd, Register rn, const LogicalImmediate& imm) { \ - assert (imm.is_encoded(), "illegal immediate for logical instruction"); \ - assert (imm.is32bit() == (sf == 0), "immediate size does not match instruction size"); \ - emit_int32(sf << 31 | opc << 29 | 0b100100 << 23 | imm.immN() << 22 | imm.immr() << 16 | \ - imm.imms() << 10 | rn->encoding_with_zr() << 5 | \ - ((opc == 0b11) ? rd->encoding_with_zr() : rd->encoding_with_sp())); \ - } \ - void mnemonic(Register rd, Register rn, uintx imm) { \ - LogicalImmediate limm(imm, (sf == 0)); \ - mnemonic(rd, rn, limm); \ - } \ - void mnemonic(Register rd, Register rn, unsigned int imm) { \ - mnemonic(rd, rn, (uintx)imm); \ - } - - F(andr_w, 0, 0b00) - F(orr_w, 0, 0b01) - F(eor_w, 0, 0b10) - F(ands_w, 0, 0b11) - - F(andr, 1, 0b00) - F(orr, 1, 0b01) - F(eor, 1, 0b10) - F(ands, 1, 0b11) -#undef F - - void tst(Register rn, unsigned int imm) { - ands(ZR, rn, imm); - } - - void tst_w(Register rn, unsigned int imm) { - ands_w(ZR, rn, imm); - } - -#define F(mnemonic, sf, opc, N) \ - void mnemonic(Register rd, Register rn, AsmOperand operand) { \ - assert (operand.shift_imm() >> (5 + sf) == 0, "shift amount is too large"); \ - emit_int32(sf << 31 | opc << 29 | 0b01010 << 24 | operand.shift() << 22 | N << 21 | \ - operand.reg()->encoding_with_zr() << 16 | operand.shift_imm() << 10 | \ - rn->encoding_with_zr() << 5 | rd->encoding_with_zr()); \ - } - - F(andr_w, 0, 0b00, 0) - F(bic_w, 0, 0b00, 1) - F(orr_w, 0, 0b01, 0) - F(orn_w, 0, 0b01, 1) - F(eor_w, 0, 0b10, 0) - F(eon_w, 0, 0b10, 1) - F(ands_w, 0, 0b11, 0) - F(bics_w, 0, 0b11, 1) - - F(andr, 1, 0b00, 0) - F(bic, 1, 0b00, 1) - F(orr, 1, 0b01, 0) - F(orn, 1, 0b01, 1) - F(eor, 1, 0b10, 0) - F(eon, 1, 0b10, 1) - F(ands, 1, 0b11, 0) - F(bics, 1, 0b11, 1) -#undef F - - void tst(Register rn, AsmOperand operand) { - ands(ZR, rn, operand); - } - - void tst_w(Register rn, AsmOperand operand) { - ands_w(ZR, rn, operand); - } - - void mvn(Register rd, AsmOperand operand) { - orn(rd, ZR, operand); - } - - void mvn_w(Register rd, AsmOperand operand) { - orn_w(rd, ZR, operand); - } - -#define F(mnemonic, sf, op, S) \ - void mnemonic(Register rd, Register rn, const ArithmeticImmediate& imm) { \ - assert(imm.is_encoded(), "immediate is out of range"); \ - emit_int32(sf << 31 | op << 30 | S << 29 | 0b10001 << 24 | imm.shift() << 22 | \ - imm.imm() << 10 | rn->encoding_with_sp() << 5 | \ - (S == 1 ? rd->encoding_with_zr() : rd->encoding_with_sp())); \ - } \ - void mnemonic(Register rd, Register rn, int imm) { \ - mnemonic(rd, rn, ArithmeticImmediate(imm)); \ - } \ - void mnemonic(Register rd, Register rn, int imm, AsmShift12 shift) { \ - mnemonic(rd, rn, ArithmeticImmediate(imm, shift)); \ - } \ - void mnemonic(Register rd, Register rn, Register rm, AsmExtendOp extend, int shift_imm = 0) { \ - assert ((0 <= shift_imm) && (shift_imm <= 4), "shift amount is out of range"); \ - emit_int32(sf << 31 | op << 30 | S << 29 | 0b01011001 << 21 | rm->encoding_with_zr() << 16 | \ - extend << 13 | shift_imm << 10 | rn->encoding_with_sp() << 5 | \ - (S == 1 ? rd->encoding_with_zr() : rd->encoding_with_sp())); \ - } \ - void mnemonic(Register rd, Register rn, AsmOperand operand) { \ - assert (operand.shift() != ror, "illegal shift type"); \ - assert (operand.shift_imm() >> (5 + sf) == 0, "shift amount is too large"); \ - emit_int32(sf << 31 | op << 30 | S << 29 | 0b01011 << 24 | operand.shift() << 22 | \ - operand.reg()->encoding_with_zr() << 16 | operand.shift_imm() << 10 | \ - rn->encoding_with_zr() << 5 | rd->encoding_with_zr()); \ - } - - F(add_w, 0, 0, 0) - F(adds_w, 0, 0, 1) - F(sub_w, 0, 1, 0) - F(subs_w, 0, 1, 1) - - F(add, 1, 0, 0) - F(adds, 1, 0, 1) - F(sub, 1, 1, 0) - F(subs, 1, 1, 1) -#undef F - - void mov(Register rd, Register rm) { - if ((rd == SP) || (rm == SP)) { - add(rd, rm, 0); - } else { - orr(rd, ZR, rm); - } - } - - void mov_w(Register rd, Register rm) { - if ((rd == SP) || (rm == SP)) { - add_w(rd, rm, 0); - } else { - orr_w(rd, ZR, rm); - } - } - - void cmp(Register rn, int imm) { - subs(ZR, rn, imm); - } - - void cmp_w(Register rn, int imm) { - subs_w(ZR, rn, imm); - } - - void cmp(Register rn, Register rm) { - assert (rm != SP, "SP should not be used as the 2nd operand of cmp"); - if (rn == SP) { - subs(ZR, rn, rm, ex_uxtx); - } else { - subs(ZR, rn, rm); - } - } - - void cmp_w(Register rn, Register rm) { - assert ((rn != SP) && (rm != SP), "SP should not be used in 32-bit cmp"); - subs_w(ZR, rn, rm); - } - - void cmp(Register rn, AsmOperand operand) { - assert (rn != SP, "SP is not allowed in cmp with shifted register (AsmOperand)"); - subs(ZR, rn, operand); - } - - void cmn(Register rn, int imm) { - adds(ZR, rn, imm); - } - - void cmn_w(Register rn, int imm) { - adds_w(ZR, rn, imm); - } - - void cmn(Register rn, Register rm) { - assert (rm != SP, "SP should not be used as the 2nd operand of cmp"); - if (rn == SP) { - adds(ZR, rn, rm, ex_uxtx); - } else { - adds(ZR, rn, rm); - } - } - - void cmn_w(Register rn, Register rm) { - assert ((rn != SP) && (rm != SP), "SP should not be used in 32-bit cmp"); - adds_w(ZR, rn, rm); - } - - void neg(Register rd, Register rm) { - sub(rd, ZR, rm); - } - - void neg_w(Register rd, Register rm) { - sub_w(rd, ZR, rm); - } - -#define F(mnemonic, sf, op, S) \ - void mnemonic(Register rd, Register rn, Register rm) { \ - emit_int32(sf << 31 | op << 30 | S << 29 | 0b11010000 << 21 | rm->encoding_with_zr() << 16 | \ - rn->encoding_with_zr() << 5 | rd->encoding_with_zr()); \ - } - - F(adc_w, 0, 0, 0) - F(adcs_w, 0, 0, 1) - F(sbc_w, 0, 1, 0) - F(sbcs_w, 0, 1, 1) - - F(adc, 1, 0, 0) - F(adcs, 1, 0, 1) - F(sbc, 1, 1, 0) - F(sbcs, 1, 1, 1) -#undef F - -#define F(mnemonic, sf, N) \ - void mnemonic(Register rd, Register rn, Register rm, int lsb) { \ - assert ((lsb >> (5 + sf)) == 0, "illegal least significant bit position"); \ - emit_int32(sf << 31 | 0b100111 << 23 | N << 22 | rm->encoding_with_zr() << 16 | \ - lsb << 10 | rn->encoding_with_zr() << 5 | rd->encoding_with_zr()); \ - } - - F(extr_w, 0, 0) - F(extr, 1, 1) -#undef F - -#define F(mnemonic, sf, opc) \ - void mnemonic(Register rd, int imm, int shift) { \ - assert ((imm >> 16) == 0, "immediate is out of range"); \ - assert (((shift & 0xf) == 0) && ((shift >> (5 + sf)) == 0), "invalid shift"); \ - emit_int32(sf << 31 | opc << 29 | 0b100101 << 23 | (shift >> 4) << 21 | \ - imm << 5 | rd->encoding_with_zr()); \ - } - - F(movn_w, 0, 0b00) - F(movz_w, 0, 0b10) - F(movk_w, 0, 0b11) - F(movn, 1, 0b00) - F(movz, 1, 0b10) - F(movk, 1, 0b11) -#undef F - - void mov(Register rd, int imm) { - assert ((imm >> 16) == 0, "immediate is out of range"); - movz(rd, imm, 0); - } - - void mov_w(Register rd, int imm) { - assert ((imm >> 16) == 0, "immediate is out of range"); - movz_w(rd, imm, 0); - } - -#define F(mnemonic, sf, op, S) \ - void mnemonic(Register rn, int imm, int nzcv, AsmCondition cond) { \ - assert ((imm >> 5) == 0, "immediate is out of range"); \ - assert ((nzcv >> 4) == 0, "illegal nzcv"); \ - emit_int32(sf << 31 | op << 30 | S << 29 | 0b11010010 << 21 | imm << 16 | \ - cond << 12 | 1 << 11 | rn->encoding_with_zr() << 5 | nzcv); \ - } - - F(ccmn_w, 0, 0, 1) - F(ccmp_w, 0, 1, 1) - F(ccmn, 1, 0, 1) - F(ccmp, 1, 1, 1) -#undef F - -#define F(mnemonic, sf, op, S) \ - void mnemonic(Register rn, Register rm, int nzcv, AsmCondition cond) { \ - assert ((nzcv >> 4) == 0, "illegal nzcv"); \ - emit_int32(sf << 31 | op << 30 | S << 29 | 0b11010010 << 21 | rm->encoding_with_zr() << 16 | \ - cond << 12 | rn->encoding_with_zr() << 5 | nzcv); \ - } - - F(ccmn_w, 0, 0, 1) - F(ccmp_w, 0, 1, 1) - F(ccmn, 1, 0, 1) - F(ccmp, 1, 1, 1) -#undef F - -#define F(mnemonic, sf, op, S, op2) \ - void mnemonic(Register rd, Register rn, Register rm, AsmCondition cond) { \ - emit_int32(sf << 31 | op << 30 | S << 29 | 0b11010100 << 21 | rm->encoding_with_zr() << 16 | \ - cond << 12 | op2 << 10 | rn->encoding_with_zr() << 5 | rd->encoding_with_zr()); \ - } - - F(csel_w, 0, 0, 0, 0b00) - F(csinc_w, 0, 0, 0, 0b01) - F(csinv_w, 0, 1, 0, 0b00) - F(csneg_w, 0, 1, 0, 0b01) - - F(csel, 1, 0, 0, 0b00) - F(csinc, 1, 0, 0, 0b01) - F(csinv, 1, 1, 0, 0b00) - F(csneg, 1, 1, 0, 0b01) -#undef F - - void cset(Register rd, AsmCondition cond) { - csinc(rd, ZR, ZR, inverse(cond)); - } - - void cset_w(Register rd, AsmCondition cond) { - csinc_w(rd, ZR, ZR, inverse(cond)); - } - - void csetm(Register rd, AsmCondition cond) { - csinv(rd, ZR, ZR, inverse(cond)); - } - - void csetm_w(Register rd, AsmCondition cond) { - csinv_w(rd, ZR, ZR, inverse(cond)); - } - - void cinc(Register rd, Register rn, AsmCondition cond) { - csinc(rd, rn, rn, inverse(cond)); - } - - void cinc_w(Register rd, Register rn, AsmCondition cond) { - csinc_w(rd, rn, rn, inverse(cond)); - } - - void cinv(Register rd, Register rn, AsmCondition cond) { - csinv(rd, rn, rn, inverse(cond)); - } - - void cinv_w(Register rd, Register rn, AsmCondition cond) { - csinv_w(rd, rn, rn, inverse(cond)); - } - -#define F(mnemonic, sf, S, opcode) \ - void mnemonic(Register rd, Register rn) { \ - emit_int32(sf << 31 | 1 << 30 | S << 29 | 0b11010110 << 21 | opcode << 10 | \ - rn->encoding_with_zr() << 5 | rd->encoding_with_zr()); \ - } - - F(rbit_w, 0, 0, 0b000000) - F(rev16_w, 0, 0, 0b000001) - F(rev_w, 0, 0, 0b000010) - F(clz_w, 0, 0, 0b000100) - F(cls_w, 0, 0, 0b000101) - - F(rbit, 1, 0, 0b000000) - F(rev16, 1, 0, 0b000001) - F(rev32, 1, 0, 0b000010) - F(rev, 1, 0, 0b000011) - F(clz, 1, 0, 0b000100) - F(cls, 1, 0, 0b000101) -#undef F - -#define F(mnemonic, sf, S, opcode) \ - void mnemonic(Register rd, Register rn, Register rm) { \ - emit_int32(sf << 31 | S << 29 | 0b11010110 << 21 | rm->encoding_with_zr() << 16 | \ - opcode << 10 | rn->encoding_with_zr() << 5 | rd->encoding_with_zr()); \ - } - - F(udiv_w, 0, 0, 0b000010) - F(sdiv_w, 0, 0, 0b000011) - F(lslv_w, 0, 0, 0b001000) - F(lsrv_w, 0, 0, 0b001001) - F(asrv_w, 0, 0, 0b001010) - F(rorv_w, 0, 0, 0b001011) - - F(udiv, 1, 0, 0b000010) - F(sdiv, 1, 0, 0b000011) - F(lslv, 1, 0, 0b001000) - F(lsrv, 1, 0, 0b001001) - F(asrv, 1, 0, 0b001010) - F(rorv, 1, 0, 0b001011) -#undef F - -#define F(mnemonic, sf, op31, o0) \ - void mnemonic(Register rd, Register rn, Register rm, Register ra) { \ - emit_int32(sf << 31 | 0b11011 << 24 | op31 << 21 | rm->encoding_with_zr() << 16 | \ - o0 << 15 | ra->encoding_with_zr() << 10 | rn->encoding_with_zr() << 5 | rd->encoding_with_zr()); \ - } - - F(madd_w, 0, 0b000, 0) - F(msub_w, 0, 0b000, 1) - F(madd, 1, 0b000, 0) - F(msub, 1, 0b000, 1) - - F(smaddl, 1, 0b001, 0) - F(smsubl, 1, 0b001, 1) - F(umaddl, 1, 0b101, 0) - F(umsubl, 1, 0b101, 1) -#undef F - - void mul(Register rd, Register rn, Register rm) { - madd(rd, rn, rm, ZR); - } - - void mul_w(Register rd, Register rn, Register rm) { - madd_w(rd, rn, rm, ZR); - } - -#define F(mnemonic, sf, op31, o0) \ - void mnemonic(Register rd, Register rn, Register rm) { \ - emit_int32(sf << 31 | 0b11011 << 24 | op31 << 21 | rm->encoding_with_zr() << 16 | \ - o0 << 15 | 0b11111 << 10 | rn->encoding_with_zr() << 5 | rd->encoding_with_zr()); \ - } - - F(smulh, 1, 0b010, 0) - F(umulh, 1, 0b110, 0) -#undef F - -#define F(mnemonic, op) \ - void mnemonic(Register rd, address addr) { \ - intx offset; \ - if (op == 0) { \ - offset = addr - pc(); \ - } else { \ - offset = (((intx)addr) - (((intx)pc()) & ~0xfff)) >> 12; \ - } \ - assert (is_imm_in_range(offset, 21, 0), "offset is out of range"); \ - emit_int32(op << 31 | (offset & 3) << 29 | 0b10000 << 24 | \ - encode_imm(offset >> 2, 19, 0, 5) | rd->encoding_with_zr()); \ - } \ - - F(adr, 0) - F(adrp, 1) -#undef F - - void adr(Register rd, Label& L) { - adr(rd, target(L)); - } - -#define F(mnemonic, sf, opc, N) \ - void mnemonic(Register rd, Register rn, int immr, int imms) { \ - assert ((immr >> (5 + sf)) == 0, "immr is out of range"); \ - assert ((imms >> (5 + sf)) == 0, "imms is out of range"); \ - emit_int32(sf << 31 | opc << 29 | 0b100110 << 23 | N << 22 | immr << 16 | \ - imms << 10 | rn->encoding_with_zr() << 5 | rd->encoding_with_zr()); \ - } - - F(sbfm_w, 0, 0b00, 0) - F(bfm_w, 0, 0b01, 0) - F(ubfm_w, 0, 0b10, 0) - - F(sbfm, 1, 0b00, 1) - F(bfm, 1, 0b01, 1) - F(ubfm, 1, 0b10, 1) -#undef F - -#define F(alias, mnemonic, sf, immr, imms) \ - void alias(Register rd, Register rn, int lsb, int width) { \ - assert ((lsb >> (5 + sf)) == 0, "lsb is out of range"); \ - assert ((1 <= width) && (width <= (32 << sf) - lsb), "width is out of range"); \ - mnemonic(rd, rn, immr, imms); \ - } - - F(bfi_w, bfm_w, 0, (-lsb) & 0x1f, width - 1) - F(bfi, bfm, 1, (-lsb) & 0x3f, width - 1) - F(bfxil_w, bfm_w, 0, lsb, lsb + width - 1) - F(bfxil, bfm, 1, lsb, lsb + width - 1) - F(sbfiz_w, sbfm_w, 0, (-lsb) & 0x1f, width - 1) - F(sbfiz, sbfm, 1, (-lsb) & 0x3f, width - 1) - F(sbfx_w, sbfm_w, 0, lsb, lsb + width - 1) - F(sbfx, sbfm, 1, lsb, lsb + width - 1) - F(ubfiz_w, ubfm_w, 0, (-lsb) & 0x1f, width - 1) - F(ubfiz, ubfm, 1, (-lsb) & 0x3f, width - 1) - F(ubfx_w, ubfm_w, 0, lsb, lsb + width - 1) - F(ubfx, ubfm, 1, lsb, lsb + width - 1) -#undef F - -#define F(alias, mnemonic, sf, immr, imms) \ - void alias(Register rd, Register rn, int shift) { \ - assert ((shift >> (5 + sf)) == 0, "shift is out of range"); \ - mnemonic(rd, rn, immr, imms); \ - } - - F(_asr_w, sbfm_w, 0, shift, 31) - F(_asr, sbfm, 1, shift, 63) - F(_lsl_w, ubfm_w, 0, (-shift) & 0x1f, 31 - shift) - F(_lsl, ubfm, 1, (-shift) & 0x3f, 63 - shift) - F(_lsr_w, ubfm_w, 0, shift, 31) - F(_lsr, ubfm, 1, shift, 63) -#undef F - -#define F(alias, mnemonic, immr, imms) \ - void alias(Register rd, Register rn) { \ - mnemonic(rd, rn, immr, imms); \ - } - - F(sxtb_w, sbfm_w, 0, 7) - F(sxtb, sbfm, 0, 7) - F(sxth_w, sbfm_w, 0, 15) - F(sxth, sbfm, 0, 15) - F(sxtw, sbfm, 0, 31) - F(uxtb_w, ubfm_w, 0, 7) - F(uxtb, ubfm, 0, 7) - F(uxth_w, ubfm_w, 0, 15) - F(uxth, ubfm, 0, 15) -#undef F - - // Branch instructions - -#define F(mnemonic, op) \ - void mnemonic(Register rn) { \ - emit_int32(0b1101011 << 25 | op << 21 | 0b11111 << 16 | rn->encoding_with_zr() << 5); \ - } - - F(br, 0b00) - F(blr, 0b01) - F(ret, 0b10) -#undef F - - void ret() { - ret(LR); - } - -#define F(mnemonic, op) \ - void mnemonic(address target) { \ - intx offset = target - pc(); \ - assert (is_offset_in_range(offset, 26), "offset is out of range"); \ - emit_int32(op << 31 | 0b00101 << 26 | encode_offset(offset, 26, 0)); \ - } - - F(b, 0) - F(bl, 1) -#undef F - - void b(address target, AsmCondition cond) { - if (cond == al) { - b(target); - } else { - intx offset = target - pc(); - assert (is_offset_in_range(offset, 19), "offset is out of range"); - emit_int32(0b0101010 << 25 | encode_offset(offset, 19, 5) | cond); - } - } - - -#define F(mnemonic, sf, op) \ - void mnemonic(Register rt, address target) { \ - intx offset = target - pc(); \ - assert (is_offset_in_range(offset, 19), "offset is out of range"); \ - emit_int32(sf << 31 | 0b011010 << 25 | op << 24 | encode_offset(offset, 19, 5) | rt->encoding_with_zr()); \ - } \ - - F(cbz_w, 0, 0) - F(cbnz_w, 0, 1) - F(cbz, 1, 0) - F(cbnz, 1, 1) -#undef F - -#define F(mnemonic, op) \ - void mnemonic(Register rt, int bit, address target) { \ - intx offset = target - pc(); \ - assert (is_offset_in_range(offset, 14), "offset is out of range"); \ - assert (0 <= bit && bit < 64, "bit number is out of range"); \ - emit_int32((bit >> 5) << 31 | 0b011011 << 25 | op << 24 | (bit & 0x1f) << 19 | \ - encode_offset(offset, 14, 5) | rt->encoding_with_zr()); \ - } \ - - F(tbz, 0) - F(tbnz, 1) -#undef F - - // System instructions - - enum DMB_Opt { - DMB_ld = 0b1101, - DMB_st = 0b1110, - DMB_all = 0b1111 - }; - -#define F(mnemonic, L, op0, op1, CRn, op2, Rt) \ - void mnemonic(DMB_Opt option) { \ - emit_int32(0b1101010100 << 22 | L << 21 | op0 << 19 | op1 << 16 | \ - CRn << 12 | option << 8 | op2 << 5 | Rt); \ - } - - F(dsb, 0, 0b00, 0b011, 0b0011, 0b100, 0b11111) - F(dmb, 0, 0b00, 0b011, 0b0011, 0b101, 0b11111) -#undef F - -#define F(mnemonic, L, op0, op1, CRn, Rt) \ - void mnemonic(int imm) { \ - assert ((imm >> 7) == 0, "immediate is out of range"); \ - emit_int32(0b1101010100 << 22 | L << 21 | op0 << 19 | op1 << 16 | \ - CRn << 12 | imm << 5 | Rt); \ - } - - F(hint, 0, 0b00, 0b011, 0b0010, 0b11111) -#undef F - - void nop() { - hint(0); - } - - void yield() { - hint(1); - } - -#define F(mnemonic, opc, op2, LL) \ - void mnemonic(int imm = 0) { \ - assert ((imm >> 16) == 0, "immediate is out of range"); \ - emit_int32(0b11010100 << 24 | opc << 21 | imm << 5 | op2 << 2 | LL); \ - } - - F(brk, 0b001, 0b000, 0b00) - F(hlt, 0b010, 0b000, 0b00) - F(dpcs1, 0b101, 0b000, 0b01) -#undef F - - enum SystemRegister { // o0<1> op1<3> CRn<4> CRm<4> op2<3> - SysReg_NZCV = 0b101101000010000, - SysReg_FPCR = 0b101101000100000, - }; - - void mrs(Register rt, SystemRegister systemReg) { - assert ((systemReg >> 15) == 0, "systemReg is out of range"); - emit_int32(0b110101010011 << 20 | systemReg << 5 | rt->encoding_with_zr()); - } - - void msr(SystemRegister systemReg, Register rt) { - assert ((systemReg >> 15) == 0, "systemReg is out of range"); - emit_int32(0b110101010001 << 20 | systemReg << 5 | rt->encoding_with_zr()); - } - - // Floating-point instructions - -#define F(mnemonic, M, S, type, opcode2) \ - void mnemonic(FloatRegister rn, FloatRegister rm) { \ - emit_int32(M << 31 | S << 29 | 0b11110 << 24 | type << 22 | 1 << 21 | \ - rm->encoding() << 16 | 0b1000 << 10 | rn->encoding() << 5 | opcode2); \ - } - - F(fcmp_s, 0, 0, 0b00, 0b00000) - F(fcmpe_s, 0, 0, 0b00, 0b01000) - F(fcmp_d, 0, 0, 0b01, 0b00000) - F(fcmpe_d, 0, 0, 0b01, 0b10000) -#undef F - -#define F(mnemonic, M, S, type, opcode2) \ - void mnemonic(FloatRegister rn) { \ - emit_int32(M << 31 | S << 29 | 0b11110 << 24 | type << 22 | 1 << 21 | \ - 0b1000 << 10 | rn->encoding() << 5 | opcode2); \ - } - - F(fcmp0_s, 0, 0, 0b00, 0b01000) - F(fcmpe0_s, 0, 0, 0b00, 0b11000) - F(fcmp0_d, 0, 0, 0b01, 0b01000) - F(fcmpe0_d, 0, 0, 0b01, 0b11000) -#undef F - -#define F(mnemonic, M, S, type, op) \ - void mnemonic(FloatRegister rn, FloatRegister rm, int nzcv, AsmCondition cond) { \ - assert ((nzcv >> 4) == 0, "illegal nzcv"); \ - emit_int32(M << 31 | S << 29 | 0b11110 << 24 | type << 22 | 1 << 21 | \ - rm->encoding() << 16 | cond << 12 | 0b01 << 10 | rn->encoding() << 5 | op << 4 | nzcv); \ - } - - F(fccmp_s, 0, 0, 0b00, 0) - F(fccmpe_s, 0, 0, 0b00, 1) - F(fccmp_d, 0, 0, 0b01, 0) - F(fccmpe_d, 0, 0, 0b01, 1) -#undef F - -#define F(mnemonic, M, S, type) \ - void mnemonic(FloatRegister rd, FloatRegister rn, FloatRegister rm, AsmCondition cond) { \ - emit_int32(M << 31 | S << 29 | 0b11110 << 24 | type << 22 | 1 << 21 | \ - rm->encoding() << 16 | cond << 12 | 0b11 << 10 | rn->encoding() << 5 | rd->encoding()); \ - } - - F(fcsel_s, 0, 0, 0b00) - F(fcsel_d, 0, 0, 0b01) -#undef F - -#define F(mnemonic, M, S, type, opcode) \ - void mnemonic(FloatRegister rd, FloatRegister rn) { \ - emit_int32(M << 31 | S << 29 | 0b11110 << 24 | type << 22 | 1 << 21 | \ - opcode << 15 | 0b10000 << 10 | rn->encoding() << 5 | rd->encoding()); \ - } - - F(fmov_s, 0, 0, 0b00, 0b000000) - F(fabs_s, 0, 0, 0b00, 0b000001) - F(fneg_s, 0, 0, 0b00, 0b000010) - F(fsqrt_s, 0, 0, 0b00, 0b000011) - F(fcvt_ds, 0, 0, 0b00, 0b000101) - F(fcvt_hs, 0, 0, 0b00, 0b000111) - F(frintn_s, 0, 0, 0b00, 0b001000) - F(frintp_s, 0, 0, 0b00, 0b001001) - F(frintm_s, 0, 0, 0b00, 0b001010) - F(frintz_s, 0, 0, 0b00, 0b001011) - F(frinta_s, 0, 0, 0b00, 0b001100) - F(frintx_s, 0, 0, 0b00, 0b001110) - F(frinti_s, 0, 0, 0b00, 0b001111) - - F(fmov_d, 0, 0, 0b01, 0b000000) - F(fabs_d, 0, 0, 0b01, 0b000001) - F(fneg_d, 0, 0, 0b01, 0b000010) - F(fsqrt_d, 0, 0, 0b01, 0b000011) - F(fcvt_sd, 0, 0, 0b01, 0b000100) - F(fcvt_hd, 0, 0, 0b01, 0b000111) - F(frintn_d, 0, 0, 0b01, 0b001000) - F(frintp_d, 0, 0, 0b01, 0b001001) - F(frintm_d, 0, 0, 0b01, 0b001010) - F(frintz_d, 0, 0, 0b01, 0b001011) - F(frinta_d, 0, 0, 0b01, 0b001100) - F(frintx_d, 0, 0, 0b01, 0b001110) - F(frinti_d, 0, 0, 0b01, 0b001111) - - F(fcvt_sh, 0, 0, 0b11, 0b000100) - F(fcvt_dh, 0, 0, 0b11, 0b000101) -#undef F - -#define F(mnemonic, M, S, type, opcode) \ - void mnemonic(FloatRegister rd, FloatRegister rn, FloatRegister rm) { \ - emit_int32(M << 31 | S << 29 | 0b11110 << 24 | type << 22 | 1 << 21 | \ - rm->encoding() << 16 | opcode << 12 | 0b10 << 10 | rn->encoding() << 5 | rd->encoding()); \ - } - - F(fmul_s, 0, 0, 0b00, 0b0000) - F(fdiv_s, 0, 0, 0b00, 0b0001) - F(fadd_s, 0, 0, 0b00, 0b0010) - F(fsub_s, 0, 0, 0b00, 0b0011) - F(fmax_s, 0, 0, 0b00, 0b0100) - F(fmin_s, 0, 0, 0b00, 0b0101) - F(fmaxnm_s, 0, 0, 0b00, 0b0110) - F(fminnm_s, 0, 0, 0b00, 0b0111) - F(fnmul_s, 0, 0, 0b00, 0b1000) - - F(fmul_d, 0, 0, 0b01, 0b0000) - F(fdiv_d, 0, 0, 0b01, 0b0001) - F(fadd_d, 0, 0, 0b01, 0b0010) - F(fsub_d, 0, 0, 0b01, 0b0011) - F(fmax_d, 0, 0, 0b01, 0b0100) - F(fmin_d, 0, 0, 0b01, 0b0101) - F(fmaxnm_d, 0, 0, 0b01, 0b0110) - F(fminnm_d, 0, 0, 0b01, 0b0111) - F(fnmul_d, 0, 0, 0b01, 0b1000) -#undef F - -#define F(mnemonic, M, S, type, o1, o0) \ - void mnemonic(FloatRegister rd, FloatRegister rn, FloatRegister rm, FloatRegister ra) { \ - emit_int32(M << 31 | S << 29 | 0b11111 << 24 | type << 22 | o1 << 21 | rm->encoding() << 16 | \ - o0 << 15 | ra->encoding() << 10 | rn->encoding() << 5 | rd->encoding()); \ - } - - F(fmadd_s, 0, 0, 0b00, 0, 0) - F(fmsub_s, 0, 0, 0b00, 0, 1) - F(fnmadd_s, 0, 0, 0b00, 1, 0) - F(fnmsub_s, 0, 0, 0b00, 1, 1) - - F(fmadd_d, 0, 0, 0b01, 0, 0) - F(fmsub_d, 0, 0, 0b01, 0, 1) - F(fnmadd_d, 0, 0, 0b01, 1, 0) - F(fnmsub_d, 0, 0, 0b01, 1, 1) -#undef F - -#define F(mnemonic, M, S, type) \ - void mnemonic(FloatRegister rd, int imm8) { \ - assert ((imm8 >> 8) == 0, "immediate is out of range"); \ - emit_int32(M << 31 | S << 29 | 0b11110 << 24 | type << 22 | 1 << 21 | \ - imm8 << 13 | 0b100 << 10 | rd->encoding()); \ - } - - F(fmov_s, 0, 0, 0b00) - F(fmov_d, 0, 0, 0b01) -#undef F - -#define F(mnemonic, sf, S, type, rmode, opcode) \ - void mnemonic(Register rd, FloatRegister rn) { \ - emit_int32(sf << 31 | S << 29 | 0b11110 << 24 | type << 22 | 1 << 21 | \ - rmode << 19 | opcode << 16 | rn->encoding() << 5 | rd->encoding_with_zr()); \ - } - - F(fcvtns_ws, 0, 0, 0b00, 0b00, 0b000) - F(fcvtnu_ws, 0, 0, 0b00, 0b00, 0b001) - F(fcvtas_ws, 0, 0, 0b00, 0b00, 0b100) - F(fcvtau_ws, 0, 0, 0b00, 0b00, 0b101) - F(fmov_ws, 0, 0, 0b00, 0b00, 0b110) - F(fcvtps_ws, 0, 0, 0b00, 0b01, 0b000) - F(fcvtpu_ws, 0, 0, 0b00, 0b01, 0b001) - F(fcvtms_ws, 0, 0, 0b00, 0b10, 0b000) - F(fcvtmu_ws, 0, 0, 0b00, 0b10, 0b001) - F(fcvtzs_ws, 0, 0, 0b00, 0b11, 0b000) - F(fcvtzu_ws, 0, 0, 0b00, 0b11, 0b001) - - F(fcvtns_wd, 0, 0, 0b01, 0b00, 0b000) - F(fcvtnu_wd, 0, 0, 0b01, 0b00, 0b001) - F(fcvtas_wd, 0, 0, 0b01, 0b00, 0b100) - F(fcvtau_wd, 0, 0, 0b01, 0b00, 0b101) - F(fcvtps_wd, 0, 0, 0b01, 0b01, 0b000) - F(fcvtpu_wd, 0, 0, 0b01, 0b01, 0b001) - F(fcvtms_wd, 0, 0, 0b01, 0b10, 0b000) - F(fcvtmu_wd, 0, 0, 0b01, 0b10, 0b001) - F(fcvtzs_wd, 0, 0, 0b01, 0b11, 0b000) - F(fcvtzu_wd, 0, 0, 0b01, 0b11, 0b001) - - F(fcvtns_xs, 1, 0, 0b00, 0b00, 0b000) - F(fcvtnu_xs, 1, 0, 0b00, 0b00, 0b001) - F(fcvtas_xs, 1, 0, 0b00, 0b00, 0b100) - F(fcvtau_xs, 1, 0, 0b00, 0b00, 0b101) - F(fcvtps_xs, 1, 0, 0b00, 0b01, 0b000) - F(fcvtpu_xs, 1, 0, 0b00, 0b01, 0b001) - F(fcvtms_xs, 1, 0, 0b00, 0b10, 0b000) - F(fcvtmu_xs, 1, 0, 0b00, 0b10, 0b001) - F(fcvtzs_xs, 1, 0, 0b00, 0b11, 0b000) - F(fcvtzu_xs, 1, 0, 0b00, 0b11, 0b001) - - F(fcvtns_xd, 1, 0, 0b01, 0b00, 0b000) - F(fcvtnu_xd, 1, 0, 0b01, 0b00, 0b001) - F(fcvtas_xd, 1, 0, 0b01, 0b00, 0b100) - F(fcvtau_xd, 1, 0, 0b01, 0b00, 0b101) - F(fmov_xd, 1, 0, 0b01, 0b00, 0b110) - F(fcvtps_xd, 1, 0, 0b01, 0b01, 0b000) - F(fcvtpu_xd, 1, 0, 0b01, 0b01, 0b001) - F(fcvtms_xd, 1, 0, 0b01, 0b10, 0b000) - F(fcvtmu_xd, 1, 0, 0b01, 0b10, 0b001) - F(fcvtzs_xd, 1, 0, 0b01, 0b11, 0b000) - F(fcvtzu_xd, 1, 0, 0b01, 0b11, 0b001) - - F(fmov_xq, 1, 0, 0b10, 0b01, 0b110) -#undef F - -#define F(mnemonic, sf, S, type, rmode, opcode) \ - void mnemonic(FloatRegister rd, Register rn) { \ - emit_int32(sf << 31 | S << 29 | 0b11110 << 24 | type << 22 | 1 << 21 | \ - rmode << 19 | opcode << 16 | rn->encoding_with_zr() << 5 | rd->encoding()); \ - } - - F(scvtf_sw, 0, 0, 0b00, 0b00, 0b010) - F(ucvtf_sw, 0, 0, 0b00, 0b00, 0b011) - F(fmov_sw, 0, 0, 0b00, 0b00, 0b111) - F(scvtf_dw, 0, 0, 0b01, 0b00, 0b010) - F(ucvtf_dw, 0, 0, 0b01, 0b00, 0b011) - - F(scvtf_sx, 1, 0, 0b00, 0b00, 0b010) - F(ucvtf_sx, 1, 0, 0b00, 0b00, 0b011) - F(scvtf_dx, 1, 0, 0b01, 0b00, 0b010) - F(ucvtf_dx, 1, 0, 0b01, 0b00, 0b011) - F(fmov_dx, 1, 0, 0b01, 0b00, 0b111) - - F(fmov_qx, 1, 0, 0b10, 0b01, 0b111) -#undef F - -#define F(mnemonic, opcode) \ - void mnemonic(FloatRegister Vd, FloatRegister Vn) { \ - emit_int32( opcode << 10 | Vn->encoding() << 5 | Vd->encoding()); \ - } - - F(aese, 0b0100111000101000010010); - F(aesd, 0b0100111000101000010110); - F(aesmc, 0b0100111000101000011010); - F(aesimc, 0b0100111000101000011110); -#undef F - -#ifdef COMPILER2 - typedef VFP::double_num double_num; - typedef VFP::float_num float_num; -#endif - - void vcnt(FloatRegister Dd, FloatRegister Dn, int quad = 0, int size = 0) { - // emitted at VM startup to detect whether the instruction is available - assert(!VM_Version::is_initialized() || VM_Version::has_simd(), "simd instruction"); - assert(size == 0, "illegal size value"); - emit_int32(0x0e205800 | quad << 30 | size << 22 | Dn->encoding() << 5 | Dd->encoding()); - } - -#ifdef COMPILER2 - void addv(FloatRegister Dd, FloatRegister Dm, int quad, int size) { - // emitted at VM startup to detect whether the instruction is available - assert(VM_Version::has_simd(), "simd instruction"); - assert((quad & ~1) == 0, "illegal value"); - assert(size >= 0 && size < 3, "illegal value"); - assert(((size << 1) | quad) != 4, "illegal values (size 2, quad 0)"); - emit_int32(0x0e31b800 | quad << 30 | size << 22 | Dm->encoding() << 5 | Dd->encoding()); - } - - enum VElem_Size { - VELEM_SIZE_8 = 0x00, - VELEM_SIZE_16 = 0x01, - VELEM_SIZE_32 = 0x02, - VELEM_SIZE_64 = 0x03 - }; - - enum VLD_Type { - VLD1_TYPE_1_REG = 0b0111, - VLD1_TYPE_2_REGS = 0b1010, - VLD1_TYPE_3_REGS = 0b0110, - VLD1_TYPE_4_REGS = 0b0010 - }; - - enum VFloat_Arith_Size { - VFA_SIZE_F32 = 0b0, - VFA_SIZE_F64 = 0b1 - }; - -#define F(mnemonic, U, S, P) \ - void mnemonic(FloatRegister fd, FloatRegister fn, FloatRegister fm, \ - int size, int quad) { \ - assert(VM_Version::has_simd(), "simd instruction"); \ - assert(!(size == VFA_SIZE_F64 && !quad), "reserved"); \ - assert((size & 1) == size, "overflow"); \ - emit_int32(quad << 30 | U << 29 | 0b01110 << 24 | \ - S << 23 | size << 22 | 1 << 21 | P << 11 | 1 << 10 | \ - fm->encoding() << 16 | \ - fn->encoding() << 5 | \ - fd->encoding()); \ - } - - F(vaddF, 0, 0, 0b11010) // Vd = Vn + Vm (float) - F(vsubF, 0, 1, 0b11010) // Vd = Vn - Vm (float) - F(vmulF, 1, 0, 0b11011) // Vd = Vn - Vm (float) - F(vdivF, 1, 0, 0b11111) // Vd = Vn / Vm (float) -#undef F - -#define F(mnemonic, U) \ - void mnemonic(FloatRegister fd, FloatRegister fm, FloatRegister fn, \ - int size, int quad) { \ - assert(VM_Version::has_simd(), "simd instruction"); \ - assert(!(size == VELEM_SIZE_64 && !quad), "reserved"); \ - assert((size & 0b11) == size, "overflow"); \ - int R = 0; /* rounding */ \ - int S = 0; /* saturating */ \ - emit_int32(quad << 30 | U << 29 | 0b01110 << 24 | size << 22 | \ - 1 << 21 | R << 12 | S << 11 | 0b10001 << 10 | \ - fm->encoding() << 16 | \ - fn->encoding() << 5 | \ - fd->encoding()); \ - } - - F(vshlSI, 0) // Vd = ashift(Vn,Vm) (int) - F(vshlUI, 1) // Vd = lshift(Vn,Vm) (int) -#undef F - -#define F(mnemonic, U, P, M) \ - void mnemonic(FloatRegister fd, FloatRegister fn, FloatRegister fm, \ - int size, int quad) { \ - assert(VM_Version::has_simd(), "simd instruction"); \ - assert(!(size == VELEM_SIZE_64 && !quad), "reserved"); \ - assert(!(size == VELEM_SIZE_64 && M), "reserved"); \ - assert((size & 0b11) == size, "overflow"); \ - emit_int32(quad << 30 | U << 29 | 0b01110 << 24 | size << 22 | \ - 1 << 21 | P << 11 | 1 << 10 | \ - fm->encoding() << 16 | \ - fn->encoding() << 5 | \ - fd->encoding()); \ - } - - F(vmulI, 0, 0b10011, true) // Vd = Vn * Vm (int) - F(vaddI, 0, 0b10000, false) // Vd = Vn + Vm (int) - F(vsubI, 1, 0b10000, false) // Vd = Vn - Vm (int) -#undef F - -#define F(mnemonic, U, O) \ - void mnemonic(FloatRegister fd, FloatRegister fn, FloatRegister fm, \ - int quad) { \ - assert(VM_Version::has_simd(), "simd instruction"); \ - emit_int32(quad << 30 | U << 29 | 0b01110 << 24 | O << 22 | \ - 1 << 21 | 0b00011 << 11 | 1 << 10 | \ - fm->encoding() << 16 | \ - fn->encoding() << 5 | \ - fd->encoding()); \ - } - - F(vandI, 0, 0b00) // Vd = Vn & Vm (int) - F(vorI, 0, 0b10) // Vd = Vn | Vm (int) - F(vxorI, 1, 0b00) // Vd = Vn ^ Vm (int) -#undef F - - void vnegI(FloatRegister fd, FloatRegister fn, int size, int quad) { - int U = 1; - assert(VM_Version::has_simd(), "simd instruction"); - assert(quad || size != VELEM_SIZE_64, "reserved"); - emit_int32(quad << 30 | U << 29 | 0b01110 << 24 | - size << 22 | 0b100000101110 << 10 | - fn->encoding() << 5 | - fd->encoding() << 0); - } - - void vshli(FloatRegister fd, FloatRegister fn, int esize, int imm, int quad) { - assert(VM_Version::has_simd(), "simd instruction"); - - if (imm >= esize) { - // maximum shift gives all zeroes, direction doesn't matter, - // but only available for shift right - vshri(fd, fn, esize, esize, true /* unsigned */, quad); - return; - } - assert(imm >= 0 && imm < esize, "out of range"); - - int imm7 = esize + imm; - int immh = imm7 >> 3; - assert(immh != 0, "encoding constraint"); - assert((uint)immh < 16, "sanity"); - assert(((immh >> 2) | quad) != 0b10, "reserved"); - emit_int32(quad << 30 | 0b011110 << 23 | imm7 << 16 | - 0b010101 << 10 | fn->encoding() << 5 | fd->encoding() << 0); - } - - void vshri(FloatRegister fd, FloatRegister fn, int esize, int imm, - bool U /* unsigned */, int quad) { - assert(VM_Version::has_simd(), "simd instruction"); - assert(imm > 0, "out of range"); - if (imm >= esize) { - // maximum shift (all zeroes) - imm = esize; - } - int imm7 = 2 * esize - imm ; - int immh = imm7 >> 3; - assert(immh != 0, "encoding constraint"); - assert((uint)immh < 16, "sanity"); - assert(((immh >> 2) | quad) != 0b10, "reserved"); - emit_int32(quad << 30 | U << 29 | 0b011110 << 23 | imm7 << 16 | - 0b000001 << 10 | fn->encoding() << 5 | fd->encoding() << 0); - } - void vshrUI(FloatRegister fd, FloatRegister fm, int size, int imm, int quad) { - vshri(fd, fm, size, imm, true /* unsigned */, quad); - } - void vshrSI(FloatRegister fd, FloatRegister fm, int size, int imm, int quad) { - vshri(fd, fm, size, imm, false /* signed */, quad); - } - - void vld1(FloatRegister Vt, Address addr, VElem_Size size, int bits) { - assert(VM_Version::has_simd(), "simd instruction"); - assert(bits == 128, "unsupported"); - assert(addr.disp() == 0 || addr.disp() == 16, "must be"); - int type = 0b11; // 2D - int quad = 1; - int L = 1; - int opcode = VLD1_TYPE_1_REG; - emit_int32(quad << 30 | 0b11 << 26 | L << 22 | opcode << 12 | size << 10 | - Vt->encoding() << 0 | addr.encoding_simd()); - } - - void vst1(FloatRegister Vt, Address addr, VElem_Size size, int bits) { - assert(VM_Version::has_simd(), "simd instruction"); - assert(bits == 128, "unsupported"); - assert(addr.disp() == 0 || addr.disp() == 16, "must be"); - int type = 0b11; // 2D - int quad = 1; - int L = 0; - int opcode = VLD1_TYPE_1_REG; - emit_int32(quad << 30 | 0b11 << 26 | L << 22 | opcode << 12 | size << 10 | - Vt->encoding() << 0 | addr.encoding_simd()); - } - - void vld1(FloatRegister Vt, FloatRegister Vt2, Address addr, VElem_Size size, int bits) { - assert(VM_Version::has_simd(), "simd instruction"); - assert(bits == 128, "unsupported"); - assert(Vt->successor() == Vt2, "Registers must be ordered"); - assert(addr.disp() == 0 || addr.disp() == 32, "must be"); - int type = 0b11; // 2D - int quad = 1; - int L = 1; - int opcode = VLD1_TYPE_2_REGS; - emit_int32(quad << 30 | 0b11 << 26 | L << 22 | opcode << 12 | size << 10 | - Vt->encoding() << 0 | addr.encoding_simd()); - } - - void vst1(FloatRegister Vt, FloatRegister Vt2, Address addr, VElem_Size size, int bits) { - assert(VM_Version::has_simd(), "simd instruction"); - assert(Vt->successor() == Vt2, "Registers must be ordered"); - assert(bits == 128, "unsupported"); - assert(addr.disp() == 0 || addr.disp() == 32, "must be"); - int type = 0b11; // 2D - int quad = 1; - int L = 0; - int opcode = VLD1_TYPE_2_REGS; - emit_int32(quad << 30 | 0b11 << 26 | L << 22 | opcode << 12 | size << 10 | - Vt->encoding() << 0 | addr.encoding_simd()); - } - - void vld1(FloatRegister Vt, FloatRegister Vt2, FloatRegister Vt3, - Address addr, VElem_Size size, int bits) { - assert(VM_Version::has_simd(), "simd instruction"); - assert(bits == 128, "unsupported"); - assert(Vt->successor() == Vt2 && Vt2->successor() == Vt3, - "Registers must be ordered"); - assert(addr.disp() == 0 || addr.disp() == 48, "must be"); - int type = 0b11; // 2D - int quad = 1; - int L = 1; - int opcode = VLD1_TYPE_3_REGS; - emit_int32(quad << 30 | 0b11 << 26 | L << 22 | opcode << 12 | size << 10 | - Vt->encoding() << 0 | addr.encoding_simd()); - } - - void vst1(FloatRegister Vt, FloatRegister Vt2, FloatRegister Vt3, - Address addr, VElem_Size size, int bits) { - assert(VM_Version::has_simd(), "simd instruction"); - assert(bits == 128, "unsupported"); - assert(Vt->successor() == Vt2 && Vt2->successor() == Vt3, - "Registers must be ordered"); - assert(addr.disp() == 0 || addr.disp() == 48, "must be"); - int type = 0b11; // 2D - int quad = 1; - int L = 0; - int opcode = VLD1_TYPE_3_REGS; - emit_int32(quad << 30 | 0b11 << 26 | L << 22 | opcode << 12 | size << 10 | - Vt->encoding() << 0 | addr.encoding_simd()); - } - - void vld1(FloatRegister Vt, FloatRegister Vt2, FloatRegister Vt3, - FloatRegister Vt4, Address addr, VElem_Size size, int bits) { - assert(VM_Version::has_simd(), "simd instruction"); - assert(bits == 128, "unsupported"); - assert(Vt->successor() == Vt2 && Vt2->successor() == Vt3 && - Vt3->successor() == Vt4, "Registers must be ordered"); - assert(addr.disp() == 0 || addr.disp() == 64, "must be"); - int type = 0b11; // 2D - int quad = 1; - int L = 1; - int opcode = VLD1_TYPE_4_REGS; - emit_int32(quad << 30 | 0b11 << 26 | L << 22 | opcode << 12 | size << 10 | - Vt->encoding() << 0 | addr.encoding_simd()); - } - - void vst1(FloatRegister Vt, FloatRegister Vt2, FloatRegister Vt3, - FloatRegister Vt4, Address addr, VElem_Size size, int bits) { - assert(VM_Version::has_simd(), "simd instruction"); - assert(bits == 128, "unsupported"); - assert(Vt->successor() == Vt2 && Vt2->successor() == Vt3 && - Vt3->successor() == Vt4, "Registers must be ordered"); - assert(addr.disp() == 0 || addr.disp() == 64, "must be"); - int type = 0b11; // 2D - int quad = 1; - int L = 0; - int opcode = VLD1_TYPE_4_REGS; - emit_int32(quad << 30 | 0b11 << 26 | L << 22 | opcode << 12 | size << 10 | - Vt->encoding() << 0 | addr.encoding_simd()); - } - - void rev32(FloatRegister Vd, FloatRegister Vn, VElem_Size size, int quad) { - assert(VM_Version::has_simd(), "simd instruction"); - assert(size == VELEM_SIZE_8 || size == VELEM_SIZE_16, "must be"); - emit_int32(quad << 30 | 0b101110 << 24 | size << 22 | - 0b100000000010 << 10 | Vn->encoding() << 5 | Vd->encoding()); - } - - void eor(FloatRegister Vd, FloatRegister Vn, FloatRegister Vm, VElem_Size size, int quad) { - assert(VM_Version::has_simd(), "simd instruction"); - assert(size == VELEM_SIZE_8, "must be"); - emit_int32(quad << 30 | 0b101110001 << 21 | Vm->encoding() << 16 | - 0b000111 << 10 | Vn->encoding() << 5 | Vd->encoding()); - } - - void orr(FloatRegister Vd, FloatRegister Vn, FloatRegister Vm, VElem_Size size, int quad) { - assert(VM_Version::has_simd(), "simd instruction"); - assert(size == VELEM_SIZE_8, "must be"); - emit_int32(quad << 30 | 0b001110101 << 21 | Vm->encoding() << 16 | - 0b000111 << 10 | Vn->encoding() << 5 | Vd->encoding()); - } - - void vmovI(FloatRegister Dd, int imm8, VElem_Size size, int quad) { - assert(VM_Version::has_simd(), "simd instruction"); - assert(imm8 >= 0 && imm8 < 256, "out of range"); - int op; - int cmode; - switch (size) { - case VELEM_SIZE_8: - op = 0; - cmode = 0b1110; - break; - case VELEM_SIZE_16: - op = 0; - cmode = 0b1000; - break; - case VELEM_SIZE_32: - op = 0; - cmode = 0b0000; - break; - default: - cmode = 0; - ShouldNotReachHere(); - } - int abc = imm8 >> 5; - int defgh = imm8 & 0b11111; - emit_int32(quad << 30 | op << 29 | 0b1111 << 24 | - abc << 16 | cmode << 12 | 0b01 << 10 | - defgh << 5 | Dd->encoding() << 0); - } - - void vdupI(FloatRegister Dd, Register Rn, VElem_Size size, int quad) { - assert(VM_Version::has_simd(), "simd instruction"); - assert(size <= 3, "unallocated encoding"); - assert(size != 3 || quad == 1, "reserved"); - int imm5 = 1 << size; -#ifdef ASSERT - switch (size) { - case VELEM_SIZE_8: - assert(imm5 == 0b00001, "sanity"); - break; - case VELEM_SIZE_16: - assert(imm5 == 0b00010, "sanity"); - break; - case VELEM_SIZE_32: - assert(imm5 == 0b00100, "sanity"); - break; - case VELEM_SIZE_64: - assert(imm5 == 0b01000, "sanity"); - break; - default: - ShouldNotReachHere(); - } -#endif - emit_int32(quad << 30 | 0b111 << 25 | 0b11 << 10 | - imm5 << 16 | Rn->encoding() << 5 | - Dd->encoding() << 0); - } - - void vdup(FloatRegister Vd, FloatRegister Vn, VElem_Size size, int quad) { - assert(VM_Version::has_simd(), "simd instruction"); - int index = 0; - int bytes = 1 << size; - int range = 16 / bytes; - assert(index < range, "overflow"); - - assert(size != VELEM_SIZE_64 || quad, "reserved"); - assert(8 << VELEM_SIZE_8 == 8, "sanity"); - assert(8 << VELEM_SIZE_16 == 16, "sanity"); - assert(8 << VELEM_SIZE_32 == 32, "sanity"); - assert(8 << VELEM_SIZE_64 == 64, "sanity"); - - int imm5 = (index << (size + 1)) | bytes; - - emit_int32(quad << 30 | 0b001110000 << 21 | imm5 << 16 | 0b000001 << 10 | - Vn->encoding() << 5 | Vd->encoding() << 0); - } - - void vdupF(FloatRegister Vd, FloatRegister Vn, int quad) { - vdup(Vd, Vn, VELEM_SIZE_32, quad); - } - - void vdupD(FloatRegister Vd, FloatRegister Vn, int quad) { - vdup(Vd, Vn, VELEM_SIZE_64, quad); - } -#endif -}; - - -#endif // CPU_ARM_VM_ASSEMBLER_ARM_64_HPP diff --git a/src/hotspot/cpu/arm/c1_CodeStubs_arm.cpp b/src/hotspot/cpu/arm/c1_CodeStubs_arm.cpp index b28403544db..c06357b48b7 100644 --- a/src/hotspot/cpu/arm/c1_CodeStubs_arm.cpp +++ b/src/hotspot/cpu/arm/c1_CodeStubs_arm.cpp @@ -67,9 +67,6 @@ void RangeCheckStub::emit_code(LIR_Assembler* ce) { __ bind(_entry); if (_info->deoptimize_on_exception()) { -#ifdef AARCH64 - __ NOT_TESTED(); -#endif __ call(Runtime1::entry_for(Runtime1::predicate_failed_trap_id), relocInfo::runtime_call_type); ce->add_call_info_here(_info); ce->verify_oop_map(_info); @@ -86,9 +83,6 @@ void RangeCheckStub::emit_code(LIR_Assembler* ce) { } if (_throw_index_out_of_bounds_exception) { -#ifdef AARCH64 - __ NOT_TESTED(); -#endif __ call(Runtime1::entry_for(Runtime1::throw_index_exception_id), relocInfo::runtime_call_type); } else { __ str(_array->as_pointer_register(), Address(SP, BytesPerWord)); // ??? Correct offset? Correct instruction? @@ -208,16 +202,12 @@ void MonitorEnterStub::emit_code(LIR_Assembler* ce) { const Register lock_reg = _lock_reg->as_pointer_register(); ce->verify_reserved_argument_area_size(2); -#ifdef AARCH64 - __ stp(obj_reg, lock_reg, Address(SP)); -#else if (obj_reg < lock_reg) { __ stmia(SP, RegisterSet(obj_reg) | RegisterSet(lock_reg)); } else { __ str(obj_reg, Address(SP)); __ str(lock_reg, Address(SP, BytesPerWord)); } -#endif // AARCH64 Runtime1::StubID enter_id = ce->compilation()->has_fpu_code() ? Runtime1::monitorenter_id : @@ -259,7 +249,7 @@ void PatchingStub::align_patch_site(MacroAssembler* masm) { } void PatchingStub::emit_code(LIR_Assembler* ce) { - const int patchable_instruction_offset = AARCH64_ONLY(NativeInstruction::instruction_size) NOT_AARCH64(0); + const int patchable_instruction_offset = 0; assert(NativeCall::instruction_size <= _bytes_to_copy && _bytes_to_copy <= 0xFF, "not enough room for call"); @@ -267,31 +257,17 @@ void PatchingStub::emit_code(LIR_Assembler* ce) { Label call_patch; bool is_load = (_id == load_klass_id) || (_id == load_mirror_id) || (_id == load_appendix_id); -#ifdef AARCH64 - assert(nativeInstruction_at(_pc_start)->is_nop(), "required for MT safe patching"); - // Same alignment of reg2mem code and PatchingStub code. Required to make copied bind_literal() code properly aligned. - __ align(wordSize); -#endif // AARCH64 - - if (is_load NOT_AARCH64(&& !VM_Version::supports_movw())) { + if (is_load && !VM_Version::supports_movw()) { address start = __ pc(); // The following sequence duplicates code provided in MacroAssembler::patchable_mov_oop() // without creating relocation info entry. -#ifdef AARCH64 - // Extra nop for MT safe patching - __ nop(); -#endif // AARCH64 assert((__ pc() - start) == patchable_instruction_offset, "should be"); -#ifdef AARCH64 - __ ldr(_obj, __ pc()); -#else __ ldr(_obj, Address(PC)); // Extra nop to handle case of large offset of oop placeholder (see NativeMovConstReg::set_data). __ nop(); -#endif // AARCH64 #ifdef ASSERT for (int i = 0; i < _bytes_to_copy; i++) { diff --git a/src/hotspot/cpu/arm/c1_Defs_arm.hpp b/src/hotspot/cpu/arm/c1_Defs_arm.hpp index 665d5682e56..f2baedf8593 100644 --- a/src/hotspot/cpu/arm/c1_Defs_arm.hpp +++ b/src/hotspot/cpu/arm/c1_Defs_arm.hpp @@ -47,9 +47,9 @@ enum { // registers enum { - pd_nof_cpu_regs_frame_map = AARCH64_ONLY(33) NOT_AARCH64(16), // number of registers used during code emission - pd_nof_caller_save_cpu_regs_frame_map = AARCH64_ONLY(27) NOT_AARCH64(10), // number of registers killed by calls - pd_nof_cpu_regs_reg_alloc = AARCH64_ONLY(27) NOT_AARCH64(10), // number of registers that are visible to register allocator (including Rheap_base which is visible only if compressed pointers are not enabled) + pd_nof_cpu_regs_frame_map = 16, // number of registers used during code emission + pd_nof_caller_save_cpu_regs_frame_map = 10, // number of registers killed by calls + pd_nof_cpu_regs_reg_alloc = 10, // number of registers that are visible to register allocator (including Rheap_base which is visible only if compressed pointers are not enabled) pd_nof_cpu_regs_linearscan = pd_nof_cpu_regs_frame_map, // number of registers visible to linear scan pd_nof_cpu_regs_processed_in_linearscan = pd_nof_cpu_regs_reg_alloc + 1, // number of registers processed in linear scan; includes LR as it is used as temporary register in c1_LIRGenerator_arm pd_first_cpu_reg = 0, @@ -57,7 +57,7 @@ enum { pd_nof_fpu_regs_frame_map = VFP(32) SOFT(0), // number of float registers used during code emission pd_nof_caller_save_fpu_regs_frame_map = VFP(32) SOFT(0), // number of float registers killed by calls - pd_nof_fpu_regs_reg_alloc = AARCH64_ONLY(32) NOT_AARCH64(VFP(30) SOFT(0)), // number of float registers that are visible to register allocator + pd_nof_fpu_regs_reg_alloc = VFP(30) SOFT(0), // number of float registers that are visible to register allocator pd_nof_fpu_regs_linearscan = pd_nof_fpu_regs_frame_map, // number of float registers visible to linear scan pd_first_fpu_reg = pd_nof_cpu_regs_frame_map, pd_last_fpu_reg = pd_first_fpu_reg + pd_nof_fpu_regs_frame_map - 1, @@ -74,11 +74,7 @@ enum { pd_float_saved_as_double = false }; -#ifdef AARCH64 -#define PATCHED_ADDR 0xff8 -#else #define PATCHED_ADDR (204) -#endif #define CARDTABLEBARRIERSET_POST_BARRIER_HELPER #define GENERATE_ADDRESS_IS_PREFERRED diff --git a/src/hotspot/cpu/arm/c1_FrameMap_arm.cpp b/src/hotspot/cpu/arm/c1_FrameMap_arm.cpp index 55b5fcc137a..cb234675241 100644 --- a/src/hotspot/cpu/arm/c1_FrameMap_arm.cpp +++ b/src/hotspot/cpu/arm/c1_FrameMap_arm.cpp @@ -49,9 +49,6 @@ LIR_Opr FrameMap::R3_metadata_opr; LIR_Opr FrameMap::R4_metadata_opr; LIR_Opr FrameMap::R5_metadata_opr; -#ifdef AARCH64 -LIR_Opr FrameMap::ZR_opr; -#endif // AARCH64 LIR_Opr FrameMap::LR_opr; LIR_Opr FrameMap::LR_oop_opr; @@ -82,12 +79,7 @@ LIR_Opr FrameMap::map_to_opr(BasicType type, VMRegPair* reg, bool) { } else if (r_1->is_Register()) { Register reg = r_1->as_Register(); if (r_2->is_Register() && (type == T_LONG || type == T_DOUBLE)) { -#ifdef AARCH64 - assert(r_1->next() == r_2, "should be the same"); - opr = as_long_opr(reg); -#else opr = as_long_opr(reg, r_2->as_Register()); -#endif } else if (type == T_OBJECT || type == T_ARRAY) { opr = as_oop_opr(reg); } else if (type == T_METADATA) { @@ -115,20 +107,10 @@ void FrameMap::initialize() { int rnum = 0; // Registers used for allocation -#ifdef AARCH64 - assert(Rthread == R28 && Rheap_base == R27 && Rtemp == R16, "change the code here"); - for (i = 0; i < 16; i++) { - map_register(rnum++, as_Register(i)); - } - for (i = 17; i < 28; i++) { - map_register(rnum++, as_Register(i)); - } -#else assert(Rthread == R10 && Rtemp == R12, "change the code here"); for (i = 0; i < 10; i++) { map_register(rnum++, as_Register(i)); } -#endif // AARCH64 assert(rnum == pd_nof_cpu_regs_reg_alloc, "should be"); // Registers not used for allocation @@ -139,11 +121,7 @@ void FrameMap::initialize() { map_register(rnum++, Rthread); map_register(rnum++, FP); // ARM32: R7 or R11 map_register(rnum++, SP); -#ifdef AARCH64 - map_register(rnum++, ZR); -#else map_register(rnum++, PC); -#endif assert(rnum == pd_nof_cpu_regs_frame_map, "should be"); _init_done = true; @@ -155,9 +133,6 @@ void FrameMap::initialize() { R4_opr = as_opr(R4); R4_oop_opr = as_oop_opr(R4); R4_metadata_opr = as_metadata_opr(R4); R5_opr = as_opr(R5); R5_oop_opr = as_oop_opr(R5); R5_metadata_opr = as_metadata_opr(R5); -#ifdef AARCH64 - ZR_opr = as_opr(ZR); -#endif // AARCH64 LR_opr = as_opr(LR); LR_oop_opr = as_oop_opr(LR); @@ -169,11 +144,6 @@ void FrameMap::initialize() { // LIR operands for result Int_result_opr = R0_opr; Object_result_opr = R0_oop_opr; -#ifdef AARCH64 - Long_result_opr = as_long_opr(R0); - Float_result_opr = as_float_opr(S0); - Double_result_opr = as_double_opr(D0); -#else Long_result_opr = as_long_opr(R0, R1); #ifdef __ABI_HARD__ Float_result_opr = as_float_opr(S0); @@ -182,7 +152,6 @@ void FrameMap::initialize() { Float_result_opr = LIR_OprFact::single_softfp(0); Double_result_opr = LIR_OprFact::double_softfp(0, 1); #endif // __ABI_HARD__ -#endif // AARCH64 Exception_oop_opr = as_oop_opr(Rexception_obj); Exception_pc_opr = as_opr(Rexception_pc); @@ -222,7 +191,7 @@ bool FrameMap::validate_frame() { } java_index += type2size[opr->type()]; } - return max_offset < AARCH64_ONLY(16384) NOT_AARCH64(4096); // TODO-AARCH64 check that LIRAssembler does not generate load/store of byte and half-word with SP as address base + return max_offset < 4096; } VMReg FrameMap::fpu_regname(int n) { diff --git a/src/hotspot/cpu/arm/c1_FrameMap_arm.hpp b/src/hotspot/cpu/arm/c1_FrameMap_arm.hpp index efb2acfb837..2309224f148 100644 --- a/src/hotspot/cpu/arm/c1_FrameMap_arm.hpp +++ b/src/hotspot/cpu/arm/c1_FrameMap_arm.hpp @@ -54,9 +54,6 @@ static LIR_Opr R4_metadata_opr; static LIR_Opr R5_metadata_opr; -#ifdef AARCH64 - static LIR_Opr ZR_opr; -#endif // AARCH64 static LIR_Opr LR_opr; static LIR_Opr LR_oop_opr; @@ -75,19 +72,6 @@ static LIR_Opr Exception_oop_opr; static LIR_Opr Exception_pc_opr; -#ifdef AARCH64 - static LIR_Opr as_long_opr(Register r) { - return LIR_OprFact::double_cpu(cpu_reg2rnr(r), cpu_reg2rnr(r)); - } - - static LIR_Opr as_pointer_opr(Register r) { - return LIR_OprFact::double_cpu(cpu_reg2rnr(r), cpu_reg2rnr(r)); - } - - static LIR_Opr as_double_opr(FloatRegister r) { - return LIR_OprFact::double_fpu(r->encoding()); - } -#else static LIR_Opr as_long_opr(Register r, Register r2) { return LIR_OprFact::double_cpu(cpu_reg2rnr(r), cpu_reg2rnr(r2)); } @@ -99,7 +83,6 @@ static LIR_Opr as_double_opr(FloatRegister r) { return LIR_OprFact::double_fpu(r->encoding(), r->successor()->encoding()); } -#endif static LIR_Opr as_float_opr(FloatRegister r) { return LIR_OprFact::single_fpu(r->encoding()); diff --git a/src/hotspot/cpu/arm/c1_LIRAssembler_arm.cpp b/src/hotspot/cpu/arm/c1_LIRAssembler_arm.cpp index 2247c092d19..43573d69531 100644 --- a/src/hotspot/cpu/arm/c1_LIRAssembler_arm.cpp +++ b/src/hotspot/cpu/arm/c1_LIRAssembler_arm.cpp @@ -127,9 +127,6 @@ void LIR_Assembler::pop(LIR_Opr opr) { Address LIR_Assembler::as_Address(LIR_Address* addr) { Register base = addr->base()->as_pointer_register(); -#ifdef AARCH64 - int align = exact_log2(type2aelembytes(addr->type(), true)); -#endif if (addr->index()->is_illegal() || addr->index()->is_constant()) { int offset = addr->disp(); @@ -137,16 +134,9 @@ Address LIR_Assembler::as_Address(LIR_Address* addr) { offset += addr->index()->as_constant_ptr()->as_jint() << addr->scale(); } -#ifdef AARCH64 - if (!Assembler::is_unsigned_imm_in_range(offset, 12, align) && !Assembler::is_imm_in_range(offset, 9, 0)) { - BAILOUT_("offset not in range", Address(base)); - } - assert(UseUnalignedAccesses || (offset & right_n_bits(align)) == 0, "offset should be aligned"); -#else if ((offset <= -4096) || (offset >= 4096)) { BAILOUT_("offset not in range", Address(base)); } -#endif // AARCH64 return Address(base, offset); @@ -154,44 +144,21 @@ Address LIR_Assembler::as_Address(LIR_Address* addr) { assert(addr->disp() == 0, "can't have both"); int scale = addr->scale(); -#ifdef AARCH64 - assert((scale == 0) || (scale == align), "scale should be zero or equal to embedded shift"); - - bool is_index_extended = (addr->index()->type() == T_INT); - if (is_index_extended) { - assert(addr->index()->is_single_cpu(), "should be"); - return Address(base, addr->index()->as_register(), ex_sxtw, scale); - } else { - assert(addr->index()->is_double_cpu(), "should be"); - return Address(base, addr->index()->as_register_lo(), ex_lsl, scale); - } -#else assert(addr->index()->is_single_cpu(), "should be"); return scale >= 0 ? Address(base, addr->index()->as_register(), lsl, scale) : Address(base, addr->index()->as_register(), lsr, -scale); -#endif // AARCH64 } } Address LIR_Assembler::as_Address_hi(LIR_Address* addr) { -#ifdef AARCH64 - ShouldNotCallThis(); // Not used on AArch64 - return Address(); -#else Address base = as_Address(addr); assert(base.index() == noreg, "must be"); if (base.disp() + BytesPerWord >= 4096) { BAILOUT_("offset not in range", Address(base.base(),0)); } return Address(base.base(), base.disp() + BytesPerWord); -#endif // AARCH64 } Address LIR_Assembler::as_Address_lo(LIR_Address* addr) { -#ifdef AARCH64 - ShouldNotCallThis(); // Not used on AArch64 - return Address(); -#else return as_Address(addr); -#endif // AARCH64 } @@ -327,13 +294,8 @@ int LIR_Assembler::emit_deopt_handler() { int offset = code_offset(); __ mov_relative_address(LR, __ pc()); -#ifdef AARCH64 - __ raw_push(LR, LR); - __ jump(SharedRuntime::deopt_blob()->unpack(), relocInfo::runtime_call_type, Rtemp); -#else __ push(LR); // stub expects LR to be saved __ jump(SharedRuntime::deopt_blob()->unpack(), relocInfo::runtime_call_type, noreg); -#endif // AARCH64 assert(code_offset() - offset <= deopt_handler_size(), "overflow"); __ end_a_stub(); @@ -347,7 +309,6 @@ void LIR_Assembler::return_op(LIR_Opr result) { __ remove_frame(initial_frame_size_in_bytes()); // mov_slow here is usually one or two instruction - // TODO-AARCH64 3 instructions on AArch64, so try to load polling page by ldr_literal __ mov_address(Rtemp, os::get_polling_page(), symbolic_Relocation::polling_page_reference); __ relocate(relocInfo::poll_return_type); __ ldr(Rtemp, Address(Rtemp)); @@ -386,12 +347,8 @@ void LIR_Assembler::const2reg(LIR_Opr src, LIR_Opr dest, LIR_PatchCode patch_cod case T_LONG: assert(patch_code == lir_patch_none, "no patching handled here"); -#ifdef AARCH64 - __ mov_slow(dest->as_pointer_register(), (intptr_t)c->as_jlong()); -#else __ mov_slow(dest->as_register_lo(), c->as_jint_lo()); __ mov_slow(dest->as_register_hi(), c->as_jint_hi()); -#endif // AARCH64 break; case T_OBJECT: @@ -414,12 +371,8 @@ void LIR_Assembler::const2reg(LIR_Opr src, LIR_Opr dest, LIR_PatchCode patch_cod if (dest->is_single_fpu()) { __ mov_float(dest->as_float_reg(), c->as_jfloat()); } else { -#ifdef AARCH64 - ShouldNotReachHere(); -#else // Simple getters can return float constant directly into r0 __ mov_slow(dest->as_register(), c->as_jint_bits()); -#endif // AARCH64 } break; @@ -427,13 +380,9 @@ void LIR_Assembler::const2reg(LIR_Opr src, LIR_Opr dest, LIR_PatchCode patch_cod if (dest->is_double_fpu()) { __ mov_double(dest->as_double_reg(), c->as_jdouble()); } else { -#ifdef AARCH64 - ShouldNotReachHere(); -#else // Simple getters can return double constant directly into r1r0 __ mov_slow(dest->as_register_lo(), c->as_jint_lo_bits()); __ mov_slow(dest->as_register_hi(), c->as_jint_hi_bits()); -#endif // AARCH64 } break; @@ -466,17 +415,12 @@ void LIR_Assembler::const2stack(LIR_Opr src, LIR_Opr dest) { case T_LONG: // fall through case T_DOUBLE: -#ifdef AARCH64 - __ mov_slow(Rtemp, c->as_jlong_bits()); - __ str(Rtemp, frame_map()->address_for_slot(dest->double_stack_ix())); -#else __ mov_slow(Rtemp, c->as_jint_lo_bits()); __ str(Rtemp, frame_map()->address_for_slot(dest->double_stack_ix(), lo_word_offset_in_bytes)); if (c->as_jint_hi_bits() != c->as_jint_lo_bits()) { __ mov_slow(Rtemp, c->as_jint_hi_bits()); } __ str(Rtemp, frame_map()->address_for_slot(dest->double_stack_ix(), hi_word_offset_in_bytes)); -#endif // AARCH64 break; default: @@ -486,49 +430,14 @@ void LIR_Assembler::const2stack(LIR_Opr src, LIR_Opr dest) { void LIR_Assembler::const2mem(LIR_Opr src, LIR_Opr dest, BasicType type, CodeEmitInfo* info, bool wide) { -#ifdef AARCH64 - assert((src->as_constant_ptr()->type() == T_OBJECT && src->as_constant_ptr()->as_jobject() == NULL) || - (src->as_constant_ptr()->type() == T_INT && src->as_constant_ptr()->as_jint() == 0) || - (src->as_constant_ptr()->type() == T_LONG && src->as_constant_ptr()->as_jlong() == 0) || - (src->as_constant_ptr()->type() == T_FLOAT && src->as_constant_ptr()->as_jint_bits() == 0) || - (src->as_constant_ptr()->type() == T_DOUBLE && src->as_constant_ptr()->as_jlong_bits() == 0), - "cannot handle otherwise"); - assert(dest->as_address_ptr()->type() == type, "should be"); - - Address addr = as_Address(dest->as_address_ptr()); - int null_check_offset = code_offset(); - switch (type) { - case T_OBJECT: // fall through - case T_ARRAY: - if (UseCompressedOops && !wide) { - __ str_w(ZR, addr); - } else { - __ str(ZR, addr); - } - break; - case T_ADDRESS: // fall through - case T_DOUBLE: // fall through - case T_LONG: __ str(ZR, addr); break; - case T_FLOAT: // fall through - case T_INT: __ str_w(ZR, addr); break; - case T_BOOLEAN: // fall through - case T_BYTE: __ strb(ZR, addr); break; - case T_CHAR: // fall through - case T_SHORT: __ strh(ZR, addr); break; - default: ShouldNotReachHere(); - } -#else assert((src->as_constant_ptr()->type() == T_OBJECT && src->as_constant_ptr()->as_jobject() == NULL),"cannot handle otherwise"); __ mov(Rtemp, 0); int null_check_offset = code_offset(); __ str(Rtemp, as_Address(dest->as_address_ptr())); -#endif // AARCH64 if (info != NULL) { -#ifndef AARCH64 assert(false, "arm32 didn't support this before, investigate if bug"); -#endif add_debug_info_for_null_check(null_check_offset, info); } } @@ -539,27 +448,17 @@ void LIR_Assembler::reg2reg(LIR_Opr src, LIR_Opr dest) { if (src->is_single_cpu()) { if (dest->is_single_cpu()) { move_regs(src->as_register(), dest->as_register()); -#ifdef AARCH64 - } else if (dest->is_double_cpu()) { - assert ((src->type() == T_OBJECT) || (src->type() == T_ARRAY) || (src->type() == T_ADDRESS), "invalid src type"); - move_regs(src->as_register(), dest->as_register_lo()); -#else } else if (dest->is_single_fpu()) { __ fmsr(dest->as_float_reg(), src->as_register()); -#endif // AARCH64 } else { ShouldNotReachHere(); } } else if (src->is_double_cpu()) { -#ifdef AARCH64 - move_regs(src->as_register_lo(), dest->as_register_lo()); -#else if (dest->is_double_cpu()) { __ long_move(dest->as_register_lo(), dest->as_register_hi(), src->as_register_lo(), src->as_register_hi()); } else { __ fmdrr(dest->as_double_reg(), src->as_register_lo(), src->as_register_hi()); } -#endif // AARCH64 } else if (src->is_single_fpu()) { if (dest->is_single_fpu()) { __ mov_float(dest->as_float_reg(), src->as_float_reg()); @@ -572,11 +471,7 @@ void LIR_Assembler::reg2reg(LIR_Opr src, LIR_Opr dest) { if (dest->is_double_fpu()) { __ mov_double(dest->as_double_reg(), src->as_double_reg()); } else if (dest->is_double_cpu()) { -#ifdef AARCH64 - __ fmov_xd(dest->as_register_lo(), src->as_double_reg()); -#else __ fmrrd(dest->as_register_lo(), dest->as_register_hi(), src->as_double_reg()); -#endif // AARCH64 } else { ShouldNotReachHere(); } @@ -593,12 +488,10 @@ void LIR_Assembler::reg2stack(LIR_Opr src, LIR_Opr dest, BasicType type, bool po frame_map()->address_for_slot(dest->single_stack_ix()) : frame_map()->address_for_slot(dest->double_stack_ix()); -#ifndef AARCH64 assert(lo_word_offset_in_bytes == 0 && hi_word_offset_in_bytes == 4, "little ending"); if (src->is_single_fpu() || src->is_double_fpu()) { if (addr.disp() >= 1024) { BAILOUT("Too exotic case to handle here"); } } -#endif // !AARCH64 if (src->is_single_cpu()) { switch (type) { @@ -613,9 +506,7 @@ void LIR_Assembler::reg2stack(LIR_Opr src, LIR_Opr dest, BasicType type, bool po } } else if (src->is_double_cpu()) { __ str(src->as_register_lo(), addr); -#ifndef AARCH64 __ str(src->as_register_hi(), frame_map()->address_for_slot(dest->double_stack_ix(), hi_word_offset_in_bytes)); -#endif // !AARCH64 } else if (src->is_single_fpu()) { __ str_float(src->as_float_reg(), addr); } else if (src->is_double_fpu()) { @@ -636,15 +527,7 @@ void LIR_Assembler::reg2mem(LIR_Opr src, LIR_Opr dest, BasicType type, PatchingStub* patch = NULL; if (needs_patching) { -#ifdef AARCH64 - // Same alignment of reg2mem code and PatchingStub code. Required to make copied bind_literal() code properly aligned. - __ align(wordSize); -#endif patch = new PatchingStub(_masm, PatchingStub::access_field_id); -#ifdef AARCH64 - // Extra nop for MT safe patching - __ nop(); -#endif // AARCH64 } int null_check_offset = code_offset(); @@ -653,24 +536,13 @@ void LIR_Assembler::reg2mem(LIR_Opr src, LIR_Opr dest, BasicType type, case T_ARRAY: case T_OBJECT: if (UseCompressedOops && !wide) { -#ifdef AARCH64 - const Register temp_src = Rtemp; - assert_different_registers(temp_src, src->as_register()); - __ encode_heap_oop(temp_src, src->as_register()); - null_check_offset = code_offset(); - __ str_32(temp_src, as_Address(to_addr)); -#else ShouldNotReachHere(); -#endif // AARCH64 } else { __ str(src->as_register(), as_Address(to_addr)); } break; case T_ADDRESS: -#ifdef AARCH64 - case T_LONG: -#endif // AARCH64 __ str(src->as_pointer_register(), as_Address(to_addr)); break; @@ -691,17 +563,6 @@ void LIR_Assembler::reg2mem(LIR_Opr src, LIR_Opr dest, BasicType type, __ str_32(src->as_register(), as_Address(to_addr)); break; -#ifdef AARCH64 - - case T_FLOAT: - __ str_s(src->as_float_reg(), as_Address(to_addr)); - break; - - case T_DOUBLE: - __ str_d(src->as_double_reg(), as_Address(to_addr)); - break; - -#else // AARCH64 #ifdef __SOFTFP__ case T_DOUBLE: @@ -765,7 +626,6 @@ void LIR_Assembler::reg2mem(LIR_Opr src, LIR_Opr dest, BasicType type, break; #endif // __SOFTFP__ -#endif // AARCH64 default: ShouldNotReachHere(); @@ -793,12 +653,10 @@ void LIR_Assembler::stack2reg(LIR_Opr src, LIR_Opr dest, BasicType type) { frame_map()->address_for_slot(src->single_stack_ix()) : frame_map()->address_for_slot(src->double_stack_ix()); -#ifndef AARCH64 assert(lo_word_offset_in_bytes == 0 && hi_word_offset_in_bytes == 4, "little ending"); if (dest->is_single_fpu() || dest->is_double_fpu()) { if (addr.disp() >= 1024) { BAILOUT("Too exotic case to handle here"); } } -#endif // !AARCH64 if (dest->is_single_cpu()) { switch (type) { @@ -816,9 +674,7 @@ void LIR_Assembler::stack2reg(LIR_Opr src, LIR_Opr dest, BasicType type) { } } else if (dest->is_double_cpu()) { __ ldr(dest->as_register_lo(), addr); -#ifndef AARCH64 __ ldr(dest->as_register_hi(), frame_map()->address_for_slot(src->double_stack_ix(), hi_word_offset_in_bytes)); -#endif // !AARCH64 } else if (dest->is_single_fpu()) { __ ldr_float(dest->as_float_reg(), addr); } else if (dest->is_double_fpu()) { @@ -853,12 +709,8 @@ void LIR_Assembler::stack2stack(LIR_Opr src, LIR_Opr dest, BasicType type) { assert(src->is_double_stack(), "must be"); __ ldr(Rtemp, frame_map()->address_for_slot(src->double_stack_ix(), lo_word_offset_in_bytes)); __ str(Rtemp, frame_map()->address_for_slot(dest->double_stack_ix(), lo_word_offset_in_bytes)); -#ifdef AARCH64 - assert(lo_word_offset_in_bytes == 0, "adjust this code"); -#else __ ldr(Rtemp, frame_map()->address_for_slot(src->double_stack_ix(), hi_word_offset_in_bytes)); __ str(Rtemp, frame_map()->address_for_slot(dest->double_stack_ix(), hi_word_offset_in_bytes)); -#endif // AARCH64 } } @@ -875,10 +727,6 @@ void LIR_Assembler::mem2reg(LIR_Opr src, LIR_Opr dest, BasicType type, PatchingStub* patch = NULL; if (patch_code != lir_patch_none) { patch = new PatchingStub(_masm, PatchingStub::access_field_id); -#ifdef AARCH64 - // Extra nop for MT safe patching - __ nop(); -#endif // AARCH64 } if (info != NULL) { add_debug_info_for_null_check_here(info); @@ -902,14 +750,10 @@ void LIR_Assembler::mem2reg(LIR_Opr src, LIR_Opr dest, BasicType type, } break; -#ifdef AARCH64 - case T_LONG: -#else case T_INT: #ifdef __SOFTFP__ case T_FLOAT: #endif // __SOFTFP__ -#endif // AARCH64 __ ldr(dest->as_pointer_register(), as_Address(addr)); break; @@ -929,21 +773,6 @@ void LIR_Assembler::mem2reg(LIR_Opr src, LIR_Opr dest, BasicType type, __ ldrsh(dest->as_register(), as_Address(addr)); break; -#ifdef AARCH64 - - case T_INT: - __ ldr_w(dest->as_register(), as_Address(addr)); - break; - - case T_FLOAT: - __ ldr_s(dest->as_float_reg(), as_Address(addr)); - break; - - case T_DOUBLE: - __ ldr_d(dest->as_double_reg(), as_Address(addr)); - break; - -#else // AARCH64 #ifdef __SOFTFP__ case T_DOUBLE: @@ -1007,7 +836,6 @@ void LIR_Assembler::mem2reg(LIR_Opr src, LIR_Opr dest, BasicType type, break; #endif // __SOFTFP__ -#endif // AARCH64 default: ShouldNotReachHere(); @@ -1021,23 +849,6 @@ void LIR_Assembler::mem2reg(LIR_Opr src, LIR_Opr dest, BasicType type, patching_epilog(patch, patch_code, base_reg, info); } -#ifdef AARCH64 - switch (type) { - case T_ARRAY: - case T_OBJECT: - if (UseCompressedOops && !wide) { - __ decode_heap_oop(dest->as_register()); - } - __ verify_oop(dest->as_register()); - break; - - case T_ADDRESS: - if (UseCompressedClassPointers && addr->disp() == oopDesc::klass_offset_in_bytes()) { - __ decode_klass_not_null(dest->as_register()); - } - break; - } -#endif // AARCH64 } @@ -1064,48 +875,13 @@ void LIR_Assembler::emit_op3(LIR_Op3* op) { // x/0x80000000 is a special case, since dividend is a power of two, but is negative. // The only possible result values are 0 and 1, with 1 only for dividend == divisor == 0x80000000. __ cmp_32(left, c); -#ifdef AARCH64 - __ cset(dest, eq); -#else __ mov(dest, 0, ne); __ mov(dest, 1, eq); -#endif // AARCH64 } } else { -#ifdef AARCH64 - Register left = op->in_opr1()->as_pointer_register(); - Register right = op->in_opr2()->as_pointer_register(); - Register dest = op->result_opr()->as_pointer_register(); - - switch (op->code()) { - case lir_idiv: - if (is_32) { - __ sdiv_w(dest, left, right); - } else { - __ sdiv(dest, left, right); - } - break; - case lir_irem: { - Register tmp = op->in_opr3()->as_pointer_register(); - assert_different_registers(left, tmp); - assert_different_registers(right, tmp); - if (is_32) { - __ sdiv_w(tmp, left, right); - __ msub_w(dest, right, tmp, left); - } else { - __ sdiv(tmp, left, right); - __ msub(dest, right, tmp, left); - } - break; - } - default: - ShouldNotReachHere(); - } -#else assert(op->code() == lir_idiv || op->code() == lir_irem, "unexpected op3"); __ call(StubRoutines::Arm::idiv_irem_entry(), relocInfo::runtime_call_type); add_debug_info_for_div0_here(op->info()); -#endif // AARCH64 } } @@ -1122,9 +898,7 @@ void LIR_Assembler::emit_opBranch(LIR_OpBranch* op) { assert (op->code() != lir_cond_float_branch, "this should be impossible"); #else if (op->code() == lir_cond_float_branch) { -#ifndef AARCH64 __ fmstat(); -#endif // !AARCH64 __ b(*(op->ublock()->label()), vs); } #endif // __SOFTFP__ @@ -1151,12 +925,8 @@ void LIR_Assembler::emit_opConvert(LIR_OpConvert* op) { switch (op->bytecode()) { case Bytecodes::_i2l: -#ifdef AARCH64 - __ sign_extend(dest->as_register_lo(), src->as_register(), 32); -#else move_regs(src->as_register(), dest->as_register_lo()); __ mov(dest->as_register_hi(), AsmOperand(src->as_register(), asr, 31)); -#endif // AARCH64 break; case Bytecodes::_l2i: move_regs(src->as_register_lo(), dest->as_register()); @@ -1177,51 +947,21 @@ void LIR_Assembler::emit_opConvert(LIR_OpConvert* op) { __ convert_d2f(dest->as_float_reg(), src->as_double_reg()); break; case Bytecodes::_i2f: -#ifdef AARCH64 - __ scvtf_sw(dest->as_float_reg(), src->as_register()); -#else __ fmsr(Stemp, src->as_register()); __ fsitos(dest->as_float_reg(), Stemp); -#endif // AARCH64 break; case Bytecodes::_i2d: -#ifdef AARCH64 - __ scvtf_dw(dest->as_double_reg(), src->as_register()); -#else __ fmsr(Stemp, src->as_register()); __ fsitod(dest->as_double_reg(), Stemp); -#endif // AARCH64 break; case Bytecodes::_f2i: -#ifdef AARCH64 - __ fcvtzs_ws(dest->as_register(), src->as_float_reg()); -#else __ ftosizs(Stemp, src->as_float_reg()); __ fmrs(dest->as_register(), Stemp); -#endif // AARCH64 break; case Bytecodes::_d2i: -#ifdef AARCH64 - __ fcvtzs_wd(dest->as_register(), src->as_double_reg()); -#else __ ftosizd(Stemp, src->as_double_reg()); __ fmrs(dest->as_register(), Stemp); -#endif // AARCH64 break; -#ifdef AARCH64 - case Bytecodes::_l2f: - __ scvtf_sx(dest->as_float_reg(), src->as_register_lo()); - break; - case Bytecodes::_l2d: - __ scvtf_dx(dest->as_double_reg(), src->as_register_lo()); - break; - case Bytecodes::_f2l: - __ fcvtzs_xs(dest->as_register_lo(), src->as_float_reg()); - break; - case Bytecodes::_d2l: - __ fcvtzs_xd(dest->as_register_lo(), src->as_double_reg()); - break; -#endif // AARCH64 default: ShouldNotReachHere(); } @@ -1327,11 +1067,7 @@ void LIR_Assembler::typecheck_profile_helper1(ciMethod* method, int bci, assert_different_registers(obj, mdo, data_val); setup_md_access(method, bci, md, data, mdo_offset_bias); Label not_null; -#ifdef AARCH64 - __ cbnz(obj, not_null); -#else __ b(not_null, ne); -#endif // AARCH64 __ mov_metadata(mdo, md->constant_encoding()); if (mdo_offset_bias > 0) { __ mov_slow(data_val, mdo_offset_bias); @@ -1373,13 +1109,9 @@ void LIR_Assembler::typecheck_profile_helper2(ciMethodData* md, ciProfileData* d __ b(*failure); } -// Sets `res` to true, if `cond` holds. On AArch64 also sets `res` to false if `cond` does not hold. +// Sets `res` to true, if `cond` holds. static void set_instanceof_result(MacroAssembler* _masm, Register res, AsmCondition cond) { -#ifdef AARCH64 - __ cset(res, cond); -#else __ mov(res, 1, cond); -#endif // AARCH64 } @@ -1406,9 +1138,7 @@ void LIR_Assembler::emit_opTypeCheck(LIR_OpTypeCheck* op) { Label *failure_target = op->should_profile() ? &profile_cast_failure : stub->entry(); if (op->should_profile()) { -#ifndef AARCH64 __ cmp(value, 0); -#endif // !AARCH64 typecheck_profile_helper1(op->profiled_method(), op->profiled_bci(), md, data, mdo_offset_bias, value, k_RInfo, Rtemp, &done); } else { __ cbz(value, done); @@ -1470,57 +1200,6 @@ void LIR_Assembler::emit_opTypeCheck(LIR_OpTypeCheck* op) { Label *failure_target = op->should_profile() ? &profile_cast_failure : op->stub()->entry(); Label *success_target = op->should_profile() ? &profile_cast_success : &done; -#ifdef AARCH64 - move_regs(obj, res); - if (op->should_profile()) { - typecheck_profile_helper1(op->profiled_method(), op->profiled_bci(), md, data, mdo_offset_bias, res, klass_RInfo, Rtemp, &done); - } else { - __ cbz(obj, done); - } - if (k->is_loaded()) { - __ mov_metadata(k_RInfo, k->constant_encoding()); - } else { - if (res != obj) { - op->info_for_patch()->add_register_oop(FrameMap::as_oop_opr(res)); - } - klass2reg_with_patching(k_RInfo, op->info_for_patch()); - } - __ load_klass(klass_RInfo, res); - - if (op->fast_check()) { - __ cmp(klass_RInfo, k_RInfo); - __ b(*failure_target, ne); - } else if (k->is_loaded()) { - __ ldr(Rtemp, Address(klass_RInfo, k->super_check_offset())); - if (in_bytes(Klass::secondary_super_cache_offset()) != (int) k->super_check_offset()) { - __ cmp(Rtemp, k_RInfo); - __ b(*failure_target, ne); - } else { - __ cmp(klass_RInfo, k_RInfo); - __ cond_cmp(Rtemp, k_RInfo, ne); - __ b(*success_target, eq); - assert(klass_RInfo == R0 && k_RInfo == R1, "runtime call setup"); - __ call(Runtime1::entry_for(Runtime1::slow_subtype_check_id), relocInfo::runtime_call_type); - __ cbz(R0, *failure_target); - } - } else { - __ ldr_u32(Rtemp, Address(k_RInfo, Klass::super_check_offset_offset())); - // check for immediate positive hit - __ ldr(Rtemp, Address(klass_RInfo, Rtemp)); - __ cmp(klass_RInfo, k_RInfo); - __ cond_cmp(Rtemp, k_RInfo, ne); - __ b(*success_target, eq); - // check for immediate negative hit - __ ldr_u32(Rtemp, Address(k_RInfo, Klass::super_check_offset_offset())); - __ cmp(Rtemp, in_bytes(Klass::secondary_super_cache_offset())); - __ b(*failure_target, ne); - // slow case - assert(klass_RInfo == R0 && k_RInfo == R1, "runtime call setup"); - __ call(Runtime1::entry_for(Runtime1::slow_subtype_check_id), relocInfo::runtime_call_type); - __ cbz(R0, *failure_target); - } - -#else // AARCH64 __ movs(res, obj); if (op->should_profile()) { @@ -1575,7 +1254,6 @@ void LIR_Assembler::emit_opTypeCheck(LIR_OpTypeCheck* op) { __ call(Runtime1::entry_for(Runtime1::slow_subtype_check_id), relocInfo::runtime_call_type); __ cbz(R0, *failure_target); } -#endif // AARCH64 if (op->should_profile()) { Register mdo = klass_RInfo, recv = k_RInfo, tmp1 = Rtemp; @@ -1605,20 +1283,12 @@ void LIR_Assembler::emit_opTypeCheck(LIR_OpTypeCheck* op) { Label *failure_target = op->should_profile() ? &profile_cast_failure : &done; Label *success_target = op->should_profile() ? &profile_cast_success : &done; -#ifdef AARCH64 - move_regs(obj, res); -#else __ movs(res, obj); -#endif // AARCH64 if (op->should_profile()) { typecheck_profile_helper1(op->profiled_method(), op->profiled_bci(), md, data, mdo_offset_bias, res, klass_RInfo, Rtemp, &done); } else { -#ifdef AARCH64 - __ cbz(obj, done); // If obj == NULL, res is false -#else __ b(done, eq); -#endif // AARCH64 } if (k->is_loaded()) { @@ -1629,11 +1299,9 @@ void LIR_Assembler::emit_opTypeCheck(LIR_OpTypeCheck* op) { } __ load_klass(klass_RInfo, res); -#ifndef AARCH64 if (!op->should_profile()) { __ mov(res, 0); } -#endif // !AARCH64 if (op->fast_check()) { __ cmp(klass_RInfo, k_RInfo); @@ -1671,21 +1339,11 @@ void LIR_Assembler::emit_opTypeCheck(LIR_OpTypeCheck* op) { // check for immediate positive hit __ cmp(klass_RInfo, k_RInfo); if (!op->should_profile()) { -#ifdef AARCH64 - // TODO-AARCH64 check if separate conditional branch is more efficient than ldr+cond_cmp - __ ldr(res, Address(klass_RInfo, Rtemp)); -#else __ ldr(res, Address(klass_RInfo, Rtemp), ne); -#endif // AARCH64 __ cond_cmp(res, k_RInfo, ne); set_instanceof_result(_masm, res, eq); } else { -#ifdef AARCH64 - // TODO-AARCH64 check if separate conditional branch is more efficient than ldr+cond_cmp - __ ldr(Rtemp, Address(klass_RInfo, Rtemp)); -#else __ ldr(Rtemp, Address(klass_RInfo, Rtemp), ne); -#endif // AARCH64 __ cond_cmp(Rtemp, k_RInfo, ne); } __ b(*success_target, eq); @@ -1695,11 +1353,7 @@ void LIR_Assembler::emit_opTypeCheck(LIR_OpTypeCheck* op) { } __ cmp(Rtemp, in_bytes(Klass::secondary_super_cache_offset())); if (!op->should_profile()) { -#ifdef AARCH64 - __ mov(res, 0); -#else __ mov(res, 0, ne); -#endif // AARCH64 } __ b(*failure_target, ne); // slow case @@ -1741,41 +1395,6 @@ void LIR_Assembler::emit_compare_and_swap(LIR_OpCompareAndSwap* op) { // } else { // dest = 0; // } -#ifdef AARCH64 - Label retry, done; - Register addr = op->addr()->as_pointer_register(); - Register cmpval = op->cmp_value()->as_pointer_register(); - Register newval = op->new_value()->as_pointer_register(); - Register dest = op->result_opr()->as_pointer_register(); - assert_different_registers(dest, addr, cmpval, newval, Rtemp); - - if (UseCompressedOops && op->code() == lir_cas_obj) { - Register tmp1 = op->tmp1()->as_pointer_register(); - Register tmp2 = op->tmp2()->as_pointer_register(); - assert_different_registers(dest, addr, cmpval, newval, tmp1, tmp2, Rtemp); - __ encode_heap_oop(tmp1, cmpval); cmpval = tmp1; - __ encode_heap_oop(tmp2, newval); newval = tmp2; - } - - __ mov(dest, ZR); - __ bind(retry); - if (((op->code() == lir_cas_obj) && !UseCompressedOops) || op->code() == lir_cas_long) { - __ ldaxr(Rtemp, addr); - __ cmp(Rtemp, cmpval); - __ b(done, ne); - __ stlxr(Rtemp, newval, addr); - } else if (((op->code() == lir_cas_obj) && UseCompressedOops) || op->code() == lir_cas_int) { - __ ldaxr_w(Rtemp, addr); - __ cmp_w(Rtemp, cmpval); - __ b(done, ne); - __ stlxr_w(Rtemp, newval, addr); - } else { - ShouldNotReachHere(); - } - __ cbnz_w(Rtemp, retry); - __ mov(dest, 1); - __ bind(done); -#else // FIXME: membar_release __ membar(MacroAssembler::Membar_mask_bits(MacroAssembler::StoreStore | MacroAssembler::LoadStore), Rtemp); Register addr = op->addr()->is_register() ? @@ -1812,7 +1431,6 @@ void LIR_Assembler::emit_compare_and_swap(LIR_OpCompareAndSwap* op) { } else { Unimplemented(); } -#endif // AARCH64 // FIXME: is full membar really needed instead of just membar_acquire? __ membar(MacroAssembler::Membar_mask_bits(MacroAssembler::StoreLoad | MacroAssembler::StoreStore), Rtemp); } @@ -1835,36 +1453,6 @@ void LIR_Assembler::cmove(LIR_Condition condition, LIR_Opr opr1, LIR_Opr opr2, L } } -#ifdef AARCH64 - - // TODO-AARCH64 implement it more efficiently - - if (opr1->is_register()) { - reg2reg(opr1, result); - } else if (opr1->is_stack()) { - stack2reg(opr1, result, result->type()); - } else if (opr1->is_constant()) { - const2reg(opr1, result, lir_patch_none, NULL); - } else { - ShouldNotReachHere(); - } - - Label skip; - __ b(skip, acond); - - if (opr2->is_register()) { - reg2reg(opr2, result); - } else if (opr2->is_stack()) { - stack2reg(opr2, result, result->type()); - } else if (opr2->is_constant()) { - const2reg(opr2, result, lir_patch_none, NULL); - } else { - ShouldNotReachHere(); - } - - __ bind(skip); - -#else for (;;) { // two iterations only if (opr1 == result) { // do nothing @@ -1924,10 +1512,9 @@ void LIR_Assembler::cmove(LIR_Condition condition, LIR_Opr opr1, LIR_Opr opr2, L opr1 = opr2; acond = ncond; } -#endif // AARCH64 } -#if defined(AARCH64) || defined(ASSERT) +#ifdef ASSERT static int reg_size(LIR_Opr op) { switch (op->type()) { case T_FLOAT: @@ -1959,37 +1546,6 @@ void LIR_Assembler::arith_op(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Opr int scale = addr->scale(); AsmShift shift = lsl; -#ifdef AARCH64 - bool is_index_extended = reg_size(addr->base()) > reg_size(addr->index()); - if (scale < 0) { - scale = -scale; - shift = lsr; - } - assert(shift == lsl || !is_index_extended, "could not have extend and right shift in one operand"); - assert(0 <= scale && scale <= 63, "scale is too large"); - - if (is_index_extended) { - assert(scale <= 4, "scale is too large for add with extended register"); - assert(addr->index()->is_single_cpu(), "should be"); - assert(addr->index()->type() == T_INT, "should be"); - assert(dest->is_double_cpu(), "should be"); - assert(code == lir_add, "special case of add with extended register"); - - __ add(res, lreg, addr->index()->as_register(), ex_sxtw, scale); - return; - } else if (reg_size(dest) == BytesPerInt) { - assert(reg_size(addr->base()) == reg_size(addr->index()), "should be"); - assert(reg_size(addr->base()) == reg_size(dest), "should be"); - - AsmOperand operand(addr->index()->as_pointer_register(), shift, scale); - switch (code) { - case lir_add: __ add_32(res, lreg, operand); break; - case lir_sub: __ sub_32(res, lreg, operand); break; - default: ShouldNotReachHere(); - } - return; - } -#endif // AARCH64 assert(reg_size(addr->base()) == reg_size(addr->index()), "should be"); assert(reg_size(addr->base()) == reg_size(dest), "should be"); @@ -2002,7 +1558,6 @@ void LIR_Assembler::arith_op(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Opr default: ShouldNotReachHere(); } -#ifndef AARCH64 } else if (left->is_address()) { assert(code == lir_sub && right->is_single_cpu(), "special case used by strength_reduce_multiply()"); const LIR_Address* addr = left->as_address_ptr(); @@ -2010,15 +1565,9 @@ void LIR_Assembler::arith_op(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Opr const Register rreg = right->as_register(); assert(addr->base()->as_register() == rreg && addr->index()->is_register() && addr->disp() == 0, "must be"); __ rsb(res, rreg, AsmOperand(addr->index()->as_register(), lsl, addr->scale())); -#endif // !AARCH64 } else if (dest->is_single_cpu()) { assert(left->is_single_cpu(), "unexpected left operand"); -#ifdef AARCH64 - assert(dest->type() == T_INT, "unexpected dest type"); - assert(left->type() == T_INT, "unexpected left type"); - assert(right->type() == T_INT, "unexpected right type"); -#endif // AARCH64 const Register res = dest->as_register(); const Register lreg = left->as_register(); @@ -2045,36 +1594,6 @@ void LIR_Assembler::arith_op(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Opr } } else if (dest->is_double_cpu()) { -#ifdef AARCH64 - assert(left->is_double_cpu() || - (left->is_single_cpu() && ((left->type() == T_OBJECT) || (left->type() == T_ARRAY) || (left->type() == T_ADDRESS))), - "unexpected left operand"); - - const Register res = dest->as_register_lo(); - const Register lreg = left->as_pointer_register(); - - if (right->is_constant()) { - assert(right->type() == T_LONG, "unexpected right type"); - assert((right->as_constant_ptr()->as_jlong() >> 24) == 0, "out of range"); - jint imm = (jint)right->as_constant_ptr()->as_jlong(); - switch (code) { - case lir_add: __ add(res, lreg, imm); break; - case lir_sub: __ sub(res, lreg, imm); break; - default: ShouldNotReachHere(); - } - } else { - assert(right->is_double_cpu() || - (right->is_single_cpu() && ((right->type() == T_OBJECT) || (right->type() == T_ARRAY) || (right->type() == T_ADDRESS))), - "unexpected right operand"); - const Register rreg = right->as_pointer_register(); - switch (code) { - case lir_add: __ add(res, lreg, rreg); break; - case lir_sub: __ sub(res, lreg, rreg); break; - case lir_mul: __ mul(res, lreg, rreg); break; - default: ShouldNotReachHere(); - } - } -#else // AARCH64 Register res_lo = dest->as_register_lo(); Register res_hi = dest->as_register_hi(); Register lreg_lo = left->as_register_lo(); @@ -2118,7 +1637,6 @@ void LIR_Assembler::arith_op(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Opr } } move_regs(res_lo, dest->as_register_lo()); -#endif // AARCH64 } else if (dest->is_single_fpu()) { assert(left->is_single_fpu(), "must be"); @@ -2175,11 +1693,6 @@ void LIR_Assembler::logic_op(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Opr assert(left->is_register(), "wrong items state"); if (dest->is_single_cpu()) { -#ifdef AARCH64 - assert (dest->type() == T_INT, "unexpected result type"); - assert (left->type() == T_INT, "unexpected left type"); - assert (right->type() == T_INT, "unexpected right type"); -#endif // AARCH64 const Register res = dest->as_register(); const Register lreg = left->as_register(); @@ -2206,10 +1719,6 @@ void LIR_Assembler::logic_op(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Opr assert(dest->is_double_cpu(), "should be"); Register res_lo = dest->as_register_lo(); -#ifdef AARCH64 - assert ((left->is_single_cpu() && left->is_oop_register()) || left->is_double_cpu(), "should be"); - const Register lreg_lo = left->as_pointer_register(); -#else assert (dest->type() == T_LONG, "unexpected result type"); assert (left->type() == T_LONG, "unexpected left type"); assert (right->type() == T_LONG, "unexpected right type"); @@ -2217,19 +1726,8 @@ void LIR_Assembler::logic_op(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Opr const Register res_hi = dest->as_register_hi(); const Register lreg_lo = left->as_register_lo(); const Register lreg_hi = left->as_register_hi(); -#endif // AARCH64 if (right->is_register()) { -#ifdef AARCH64 - assert ((right->is_single_cpu() && right->is_oop_register()) || right->is_double_cpu(), "should be"); - const Register rreg_lo = right->as_pointer_register(); - switch (code) { - case lir_logic_and: __ andr(res_lo, lreg_lo, rreg_lo); break; - case lir_logic_or: __ orr (res_lo, lreg_lo, rreg_lo); break; - case lir_logic_xor: __ eor (res_lo, lreg_lo, rreg_lo); break; - default: ShouldNotReachHere(); - } -#else const Register rreg_lo = right->as_register_lo(); const Register rreg_hi = right->as_register_hi(); if (res_lo == lreg_hi || res_lo == rreg_hi) { @@ -2252,23 +1750,8 @@ void LIR_Assembler::logic_op(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Opr ShouldNotReachHere(); } move_regs(res_lo, dest->as_register_lo()); -#endif // AARCH64 } else { assert(right->is_constant(), "must be"); -#ifdef AARCH64 - const julong c = (julong)right->as_constant_ptr()->as_jlong(); - Assembler::LogicalImmediate imm(c, false); - if (imm.is_encoded()) { - switch (code) { - case lir_logic_and: __ andr(res_lo, lreg_lo, imm); break; - case lir_logic_or: __ orr (res_lo, lreg_lo, imm); break; - case lir_logic_xor: __ eor (res_lo, lreg_lo, imm); break; - default: ShouldNotReachHere(); - } - } else { - BAILOUT("64 bit constant cannot be inlined"); - } -#else const jint c_lo = (jint) right->as_constant_ptr()->as_jlong(); const jint c_hi = (jint) (right->as_constant_ptr()->as_jlong() >> 32); // Case for logic_or from do_ClassIDIntrinsic() @@ -2303,36 +1786,11 @@ void LIR_Assembler::logic_op(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Opr } else { BAILOUT("64 bit constant cannot be inlined"); } -#endif // AARCH64 } } } -#ifdef AARCH64 - -void LIR_Assembler::long_compare_helper(LIR_Opr opr1, LIR_Opr opr2) { - assert(opr1->is_double_cpu(), "should be"); - Register x = opr1->as_register_lo(); - - if (opr2->is_double_cpu()) { - Register y = opr2->as_register_lo(); - __ cmp(x, y); - - } else { - assert(opr2->is_constant(), "should be"); - assert(opr2->as_constant_ptr()->type() == T_LONG, "long constant expected"); - jlong c = opr2->as_jlong(); - assert(((c >> 31) == 0) || ((c >> 31) == -1), "immediate is out of range"); - if (c >= 0) { - __ cmp(x, (jint)c); - } else { - __ cmn(x, (jint)(-c)); - } - } -} - -#endif // AARCH64 void LIR_Assembler::comp_op(LIR_Condition condition, LIR_Opr opr1, LIR_Opr opr2, LIR_Op2* op) { if (opr1->is_single_cpu()) { @@ -2373,9 +1831,6 @@ void LIR_Assembler::comp_op(LIR_Condition condition, LIR_Opr opr1, LIR_Opr opr2, ShouldNotReachHere(); } } else if (opr1->is_double_cpu()) { -#ifdef AARCH64 - long_compare_helper(opr1, opr2); -#else Register xlo = opr1->as_register_lo(); Register xhi = opr1->as_register_hi(); if (opr2->is_constant() && opr2->as_jlong() == 0) { @@ -2394,7 +1849,6 @@ void LIR_Assembler::comp_op(LIR_Condition condition, LIR_Opr opr1, LIR_Opr opr2, } else { ShouldNotReachHere(); } -#endif // AARCH64 } else if (opr1->is_single_fpu()) { if (opr2->is_constant()) { assert(opr2->as_jfloat() == 0.0f, "cannot handle otherwise"); @@ -2418,15 +1872,6 @@ void LIR_Assembler::comp_fl2i(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Op const Register res = dst->as_register(); if (code == lir_cmp_fd2i || code == lir_ucmp_fd2i) { comp_op(lir_cond_unknown, left, right, op); -#ifdef AARCH64 - if (code == lir_ucmp_fd2i) { // unordered is less - __ cset(res, gt); // 1 if '>', else 0 - __ csinv(res, res, ZR, ge); // previous value if '>=', else -1 - } else { - __ cset(res, hi); // 1 if '>' or unordered, else 0 - __ csinv(res, res, ZR, pl); // previous value if '>=' or unordered, else -1 - } -#else __ fmstat(); if (code == lir_ucmp_fd2i) { // unordered is less __ mvn(res, 0, lt); @@ -2436,17 +1881,10 @@ void LIR_Assembler::comp_fl2i(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Op __ mvn(res, 0, cc); } __ mov(res, 0, eq); -#endif // AARCH64 } else { assert(code == lir_cmp_l2i, "must be"); -#ifdef AARCH64 - long_compare_helper(left, right); - - __ cset(res, gt); // 1 if '>', else 0 - __ csinv(res, res, ZR, ge); // previous value if '>=', else -1 -#else Label done; const Register xlo = left->as_register_lo(); const Register xhi = left->as_register_hi(); @@ -2460,7 +1898,6 @@ void LIR_Assembler::comp_fl2i(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Op __ mov(res, 1, hi); __ mvn(res, 0, lo); __ bind(done); -#endif // AARCH64 } } @@ -2481,19 +1918,15 @@ void LIR_Assembler::ic_call(LIR_OpJavaCall *op) { bool near_range = __ cache_fully_reachable(); address oop_address = pc(); - bool use_movw = AARCH64_ONLY(false) NOT_AARCH64(VM_Version::supports_movw()); + bool use_movw = VM_Version::supports_movw(); // Ricklass may contain something that is not a metadata pointer so // mov_metadata can't be used InlinedAddress value((address)Universe::non_oop_word()); InlinedAddress addr(op->addr()); if (use_movw) { -#ifdef AARCH64 - ShouldNotReachHere(); -#else __ movw(Ricklass, ((unsigned int)Universe::non_oop_word()) & 0xffff); __ movt(Ricklass, ((unsigned int)Universe::non_oop_word()) >> 16); -#endif // AARCH64 } else { // No movw/movt, must be load a pc relative value but no // relocation so no metadata table to load from. @@ -2585,35 +2018,6 @@ void LIR_Assembler::unwind_op(LIR_Opr exceptionOop) { } void LIR_Assembler::shift_op(LIR_Code code, LIR_Opr left, LIR_Opr count, LIR_Opr dest, LIR_Opr tmp) { -#ifdef AARCH64 - if (dest->is_single_cpu()) { - Register res = dest->as_register(); - Register x = left->as_register(); - Register y = count->as_register(); - assert (dest->type() == T_INT, "unexpected result type"); - assert (left->type() == T_INT, "unexpected left type"); - - switch (code) { - case lir_shl: __ lslv_w(res, x, y); break; - case lir_shr: __ asrv_w(res, x, y); break; - case lir_ushr: __ lsrv_w(res, x, y); break; - default: ShouldNotReachHere(); - } - } else if (dest->is_double_cpu()) { - Register res = dest->as_register_lo(); - Register x = left->as_register_lo(); - Register y = count->as_register(); - - switch (code) { - case lir_shl: __ lslv(res, x, y); break; - case lir_shr: __ asrv(res, x, y); break; - case lir_ushr: __ lsrv(res, x, y); break; - default: ShouldNotReachHere(); - } - } else { - ShouldNotReachHere(); - } -#else AsmShift shift = lsl; switch (code) { case lir_shl: shift = lsl; break; @@ -2648,43 +2052,10 @@ void LIR_Assembler::shift_op(LIR_Code code, LIR_Opr left, LIR_Opr count, LIR_Opr } else { ShouldNotReachHere(); } -#endif // AARCH64 } void LIR_Assembler::shift_op(LIR_Code code, LIR_Opr left, jint count, LIR_Opr dest) { -#ifdef AARCH64 - if (dest->is_single_cpu()) { - assert (dest->type() == T_INT, "unexpected result type"); - assert (left->type() == T_INT, "unexpected left type"); - count &= 31; - if (count != 0) { - switch (code) { - case lir_shl: __ _lsl_w(dest->as_register(), left->as_register(), count); break; - case lir_shr: __ _asr_w(dest->as_register(), left->as_register(), count); break; - case lir_ushr: __ _lsr_w(dest->as_register(), left->as_register(), count); break; - default: ShouldNotReachHere(); - } - } else { - move_regs(left->as_register(), dest->as_register()); - } - } else if (dest->is_double_cpu()) { - count &= 63; - if (count != 0) { - switch (code) { - case lir_shl: __ _lsl(dest->as_register_lo(), left->as_register_lo(), count); break; - case lir_shr: __ _asr(dest->as_register_lo(), left->as_register_lo(), count); break; - case lir_ushr: __ _lsr(dest->as_register_lo(), left->as_register_lo(), count); break; - default: ShouldNotReachHere(); - } - } else { - move_regs(left->as_register_lo(), dest->as_register_lo()); - } - } else { - ShouldNotReachHere(); - } - -#else AsmShift shift = lsl; switch (code) { case lir_shl: shift = lsl; break; @@ -2723,29 +2094,18 @@ void LIR_Assembler::shift_op(LIR_Code code, LIR_Opr left, jint count, LIR_Opr de } else { ShouldNotReachHere(); } -#endif // AARCH64 } // Saves 4 given registers in reserved argument area. void LIR_Assembler::save_in_reserved_area(Register r1, Register r2, Register r3, Register r4) { verify_reserved_argument_area_size(4); -#ifdef AARCH64 - __ stp(r1, r2, Address(SP, 0)); - __ stp(r3, r4, Address(SP, 2*wordSize)); -#else __ stmia(SP, RegisterSet(r1) | RegisterSet(r2) | RegisterSet(r3) | RegisterSet(r4)); -#endif // AARCH64 } // Restores 4 given registers from reserved argument area. void LIR_Assembler::restore_from_reserved_area(Register r1, Register r2, Register r3, Register r4) { -#ifdef AARCH64 - __ ldp(r1, r2, Address(SP, 0)); - __ ldp(r3, r4, Address(SP, 2*wordSize)); -#else __ ldmia(SP, RegisterSet(r1) | RegisterSet(r2) | RegisterSet(r3) | RegisterSet(r4), no_writeback); -#endif // AARCH64 } @@ -2760,9 +2120,6 @@ void LIR_Assembler::emit_arraycopy(LIR_OpArrayCopy* op) { Register tmp2 = Rtemp; assert(src == R0 && src_pos == R1 && dst == R2 && dst_pos == R3, "code assumption"); -#ifdef AARCH64 - assert(length == R4, "code assumption"); -#endif // AARCH64 __ resolve(ACCESS_READ, src); __ resolve(ACCESS_WRITE, dst); @@ -2779,13 +2136,8 @@ void LIR_Assembler::emit_arraycopy(LIR_OpArrayCopy* op) { // save arguments, because they will be killed by a runtime call save_in_reserved_area(R0, R1, R2, R3); -#ifdef AARCH64 - // save length argument, will be killed by a runtime call - __ raw_push(length, ZR); -#else // pass length argument on SP[0] __ str(length, Address(SP, -2*wordSize, pre_indexed)); // 2 words for a proper stack alignment -#endif // AARCH64 address copyfunc_addr = StubRoutines::generic_arraycopy(); assert(copyfunc_addr != NULL, "generic arraycopy stub required"); @@ -2797,11 +2149,7 @@ void LIR_Assembler::emit_arraycopy(LIR_OpArrayCopy* op) { // the stub is in the code cache so close enough __ call(copyfunc_addr, relocInfo::runtime_call_type); -#ifdef AARCH64 - __ raw_pop(length, ZR); -#else __ add(SP, SP, 2*wordSize); -#endif // AARCH64 __ cbz_32(R0, *stub->continuation()); @@ -2975,7 +2323,7 @@ void LIR_Assembler::emit_arraycopy(LIR_OpArrayCopy* op) { Register dst_ptr = R1; Register len = R2; Register chk_off = R3; - Register super_k = AARCH64_ONLY(R4) NOT_AARCH64(tmp); + Register super_k = tmp; __ add(src_ptr, src, arrayOopDesc::base_offset_in_bytes(basic_type)); __ add_ptr_scaled_int32(src_ptr, src_ptr, src_pos, shift); @@ -2987,20 +2335,11 @@ void LIR_Assembler::emit_arraycopy(LIR_OpArrayCopy* op) { int ek_offset = in_bytes(ObjArrayKlass::element_klass_offset()); int sco_offset = in_bytes(Klass::super_check_offset_offset()); -#ifdef AARCH64 - __ raw_push(length, ZR); // Preserve length around *copyfunc_addr call - - __ mov(len, length); - __ ldr(super_k, Address(tmp, ek_offset)); // super_k == R4 == length, so this load cannot be performed earlier - // TODO-AARCH64: check whether it is faster to load super klass early by using tmp and additional mov. - __ ldr_u32(chk_off, Address(super_k, sco_offset)); -#else // AARCH64 __ ldr(super_k, Address(tmp, ek_offset)); __ mov(len, length); __ ldr_u32(chk_off, Address(super_k, sco_offset)); __ push(super_k); -#endif // AARCH64 __ call(copyfunc_addr, relocInfo::runtime_call_type); @@ -3013,11 +2352,7 @@ void LIR_Assembler::emit_arraycopy(LIR_OpArrayCopy* op) { } #endif // PRODUCT -#ifdef AARCH64 - __ raw_pop(length, ZR); -#else __ add(SP, SP, wordSize); // Drop super_k argument -#endif // AARCH64 __ cbz_32(R0, *stub->continuation()); __ mvn_32(tmp, R0); @@ -3079,9 +2414,6 @@ void LIR_Assembler::emit_arraycopy(LIR_OpArrayCopy* op) { void LIR_Assembler::emit_assert(LIR_OpAssert* op) { assert(op->code() == lir_assert, "must be"); -#ifdef AARCH64 - __ NOT_IMPLEMENTED(); -#else if (op->in_opr1()->is_valid()) { assert(op->in_opr2()->is_valid(), "both operands must be valid"); comp_op(op->condition(), op->in_opr1(), op->in_opr2(), op); @@ -3113,7 +2445,6 @@ void LIR_Assembler::emit_assert(LIR_OpAssert* op) { breakpoint(); } __ bind(ok); -#endif // AARCH64 } #endif // ASSERT @@ -3163,7 +2494,7 @@ void LIR_Assembler::emit_profile_call(LIR_OpProfileCall* op) { assert_different_registers(mdo, tmp1); __ mov_metadata(mdo, md->constant_encoding()); int mdo_offset_bias = 0; - int max_offset = AARCH64_ONLY(4096 << LogBytesPerWord) NOT_AARCH64(4096); + int max_offset = 4096; if (md->byte_offset_of_slot(data, CounterData::count_offset()) + data->size_in_bytes() >= max_offset) { // The offset is large so bias the mdo by the base of the slot so // that the ldr can use an immediate offset to reference the slots of the data @@ -3259,7 +2590,6 @@ void LIR_Assembler::monitor_address(int monitor_no, LIR_Opr dst) { void LIR_Assembler::align_backward_branch_target() { - // TODO-AARCH64 review it // Some ARM processors do better with 8-byte branch target alignment __ align(8); } @@ -3274,9 +2604,6 @@ void LIR_Assembler::negate(LIR_Opr left, LIR_Opr dest, LIR_Opr tmp) { assert (left->type() == T_INT, "unexpected left type"); __ neg_32(dest->as_register(), left->as_register()); } else if (left->is_double_cpu()) { -#ifdef AARCH64 - __ neg(dest->as_register_lo(), left->as_register_lo()); -#else Register dest_lo = dest->as_register_lo(); Register dest_hi = dest->as_register_hi(); Register src_lo = left->as_register_lo(); @@ -3287,7 +2614,6 @@ void LIR_Assembler::negate(LIR_Opr left, LIR_Opr dest, LIR_Opr tmp) { __ rsbs(dest_lo, src_lo, 0); __ rsc(dest_hi, src_hi, 0); move_regs(dest_lo, dest->as_register_lo()); -#endif // AARCH64 } else if (left->is_single_fpu()) { __ neg_float(dest->as_float_reg(), left->as_float_reg()); } else if (left->is_double_fpu()) { @@ -3309,9 +2635,6 @@ void LIR_Assembler::leal(LIR_Opr addr_opr, LIR_Opr dest, LIR_PatchCode patch_cod __ add(dest->as_pointer_register(), addr->base()->as_pointer_register(), c); } else { assert(addr->disp() == 0, "cannot handle otherwise"); -#ifdef AARCH64 - assert(addr->index()->is_double_cpu(), "should be"); -#endif // AARCH64 __ add(dest->as_pointer_register(), addr->base()->as_pointer_register(), AsmOperand(addr->index()->as_pointer_register(), lsl, addr->scale())); } @@ -3328,9 +2651,6 @@ void LIR_Assembler::rt_call(LIR_Opr result, address dest, const LIR_OprList* arg void LIR_Assembler::volatile_move_op(LIR_Opr src, LIR_Opr dest, BasicType type, CodeEmitInfo* info) { -#ifdef AARCH64 - Unimplemented(); // TODO-AARCH64: Use stlr/ldar instructions for volatile load/store -#else assert(src->is_double_cpu() && dest->is_address() || src->is_address() && dest->is_double_cpu(), "Simple move_op is called for all other cases"); @@ -3372,7 +2692,6 @@ void LIR_Assembler::volatile_move_op(LIR_Opr src, LIR_Opr dest, BasicType type, if (info != NULL) { add_debug_info_for_null_check(null_check_offset, info); } -#endif // AARCH64 } @@ -3414,9 +2733,6 @@ void LIR_Assembler::get_thread(LIR_Opr result_reg) { } void LIR_Assembler::peephole(LIR_List* lir) { -#ifdef AARCH64 - return; // TODO-AARCH64 implement peephole optimizations -#endif LIR_OpList* inst = lir->instructions_list(); const int inst_length = inst->length(); for (int i = 0; i < inst_length; i++) { @@ -3480,38 +2796,23 @@ void LIR_Assembler::peephole(LIR_List* lir) { } void LIR_Assembler::atomic_op(LIR_Code code, LIR_Opr src, LIR_Opr data, LIR_Opr dest, LIR_Opr tmp) { -#ifdef AARCH64 - Register ptr = src->as_pointer_register(); -#else assert(src->is_address(), "sanity"); Address addr = as_Address(src->as_address_ptr()); -#endif if (code == lir_xchg) { -#ifdef AARCH64 - if (UseCompressedOops && data->is_oop()) { - __ encode_heap_oop(tmp->as_pointer_register(), data->as_register()); - } -#endif // AARCH64 } else { assert (!data->is_oop(), "xadd for oops"); } -#ifndef AARCH64 __ membar(MacroAssembler::Membar_mask_bits(MacroAssembler::StoreStore | MacroAssembler::LoadStore), Rtemp); -#endif // !AARCH64 Label retry; __ bind(retry); - if ((data->type() == T_INT) || (data->is_oop() AARCH64_ONLY(&& UseCompressedOops))) { + if (data->type() == T_INT || data->is_oop()) { Register dst = dest->as_register(); Register new_val = noreg; -#ifdef AARCH64 - __ ldaxr_w(dst, ptr); -#else __ ldrex(dst, addr); -#endif if (code == lir_xadd) { Register tmp_reg = tmp->as_register(); if (data->is_constant()) { @@ -3530,35 +2831,8 @@ void LIR_Assembler::atomic_op(LIR_Code code, LIR_Opr src, LIR_Opr data, LIR_Opr } assert_different_registers(dst, new_val); } -#ifdef AARCH64 - __ stlxr_w(Rtemp, new_val, ptr); -#else __ strex(Rtemp, new_val, addr); -#endif // AARCH64 -#ifdef AARCH64 - } else if ((data->type() == T_LONG) || (data->is_oop() && !UseCompressedOops)) { - Register dst = dest->as_pointer_register(); - Register new_val = noreg; - __ ldaxr(dst, ptr); - if (code == lir_xadd) { - Register tmp_reg = tmp->as_pointer_register(); - if (data->is_constant()) { - assert_different_registers(dst, ptr, tmp_reg); - jlong c = data->as_constant_ptr()->as_jlong(); - assert((jlong)((jint)c) == c, "overflow"); - __ add(tmp_reg, dst, (jint)c); - } else { - assert_different_registers(dst, ptr, tmp_reg, data->as_pointer_register()); - __ add(tmp_reg, dst, data->as_pointer_register()); - } - new_val = tmp_reg; - } else { - new_val = data->as_pointer_register(); - assert_different_registers(dst, ptr, new_val); - } - __ stlxr(Rtemp, new_val, ptr); -#else } else if (data->type() == T_LONG) { Register dst_lo = dest->as_register_lo(); Register new_val_lo = noreg; @@ -3599,7 +2873,6 @@ void LIR_Assembler::atomic_op(LIR_Code code, LIR_Opr src, LIR_Opr data, LIR_Opr assert((new_val_lo->encoding() & 0x1) == 0, "misaligned register pair"); } __ strexd(Rtemp, new_val_lo, addr); -#endif // AARCH64 } else { ShouldNotReachHere(); } @@ -3607,11 +2880,6 @@ void LIR_Assembler::atomic_op(LIR_Code code, LIR_Opr src, LIR_Opr data, LIR_Opr __ cbnz_32(Rtemp, retry); __ membar(MacroAssembler::Membar_mask_bits(MacroAssembler::StoreLoad | MacroAssembler::StoreStore), Rtemp); -#ifdef AARCH64 - if (UseCompressedOops && data->is_oop()) { - __ decode_heap_oop(dest->as_register()); - } -#endif // AARCH64 } #undef __ diff --git a/src/hotspot/cpu/arm/c1_LIRAssembler_arm.hpp b/src/hotspot/cpu/arm/c1_LIRAssembler_arm.hpp index 83abf67743e..98cf334f1dc 100644 --- a/src/hotspot/cpu/arm/c1_LIRAssembler_arm.hpp +++ b/src/hotspot/cpu/arm/c1_LIRAssembler_arm.hpp @@ -44,9 +44,6 @@ Label* profile_cast_success, Label* profile_cast_failure, Label* success, Label* failure); -#ifdef AARCH64 - void long_compare_helper(LIR_Opr opr1, LIR_Opr opr2); -#endif // AARCH64 // Saves 4 given registers in reserved argument area. void save_in_reserved_area(Register r1, Register r2, Register r3, Register r4); @@ -55,10 +52,10 @@ void restore_from_reserved_area(Register r1, Register r2, Register r3, Register r4); enum { - _call_stub_size = AARCH64_ONLY(32) NOT_AARCH64(16), + _call_stub_size = 16, _call_aot_stub_size = 0, - _exception_handler_size = PRODUCT_ONLY(AARCH64_ONLY(256) NOT_AARCH64(68)) NOT_PRODUCT(AARCH64_ONLY(256+216) NOT_AARCH64(68+60)), - _deopt_handler_size = AARCH64_ONLY(32) NOT_AARCH64(16) + _exception_handler_size = PRODUCT_ONLY(68) NOT_PRODUCT(68+60), + _deopt_handler_size = 16 }; public: diff --git a/src/hotspot/cpu/arm/c1_LIRGenerator_arm.cpp b/src/hotspot/cpu/arm/c1_LIRGenerator_arm.cpp index 05db1a29bcc..8719448528f 100644 --- a/src/hotspot/cpu/arm/c1_LIRGenerator_arm.cpp +++ b/src/hotspot/cpu/arm/c1_LIRGenerator_arm.cpp @@ -118,19 +118,6 @@ LIR_Opr LIRGenerator::rlock_byte(BasicType type) { bool LIRGenerator::can_store_as_constant(Value v, BasicType type) const { -#ifdef AARCH64 - if (v->type()->as_IntConstant() != NULL) { - return v->type()->as_IntConstant()->value() == 0; - } else if (v->type()->as_LongConstant() != NULL) { - return v->type()->as_LongConstant()->value() == 0; - } else if (v->type()->as_ObjectConstant() != NULL) { - return v->type()->as_ObjectConstant()->value()->is_null_object(); - } else if (v->type()->as_FloatConstant() != NULL) { - return jint_cast(v->type()->as_FloatConstant()->value()) == 0; - } else if (v->type()->as_DoubleConstant() != NULL) { - return jlong_cast(v->type()->as_DoubleConstant()->value()) == 0; - } -#endif // AARCH64 return false; } @@ -140,15 +127,10 @@ bool LIRGenerator::can_inline_as_constant(Value v) const { return Assembler::is_arith_imm_in_range(v->type()->as_IntConstant()->value()); } else if (v->type()->as_ObjectConstant() != NULL) { return v->type()->as_ObjectConstant()->value()->is_null_object(); -#ifdef AARCH64 - } else if (v->type()->as_LongConstant() != NULL) { - return Assembler::is_arith_imm_in_range(v->type()->as_LongConstant()->value()); -#else } else if (v->type()->as_FloatConstant() != NULL) { return v->type()->as_FloatConstant()->value() == 0.0f; } else if (v->type()->as_DoubleConstant() != NULL) { return v->type()->as_DoubleConstant()->value() == 0.0; -#endif // AARCH64 } return false; } @@ -160,39 +142,6 @@ bool LIRGenerator::can_inline_as_constant(LIR_Const* c) const { } -#ifdef AARCH64 - -static bool can_inline_as_constant_in_cmp(Value v) { - jlong constant; - if (v->type()->as_IntConstant() != NULL) { - constant = v->type()->as_IntConstant()->value(); - } else if (v->type()->as_LongConstant() != NULL) { - constant = v->type()->as_LongConstant()->value(); - } else if (v->type()->as_ObjectConstant() != NULL) { - return v->type()->as_ObjectConstant()->value()->is_null_object(); - } else if (v->type()->as_FloatConstant() != NULL) { - return v->type()->as_FloatConstant()->value() == 0.0f; - } else if (v->type()->as_DoubleConstant() != NULL) { - return v->type()->as_DoubleConstant()->value() == 0.0; - } else { - return false; - } - - return Assembler::is_arith_imm_in_range(constant) || Assembler::is_arith_imm_in_range(-constant); -} - - -static bool can_inline_as_constant_in_logic(Value v) { - if (v->type()->as_IntConstant() != NULL) { - return Assembler::LogicalImmediate(v->type()->as_IntConstant()->value(), true).is_encoded(); - } else if (v->type()->as_LongConstant() != NULL) { - return Assembler::LogicalImmediate(v->type()->as_LongConstant()->value(), false).is_encoded(); - } - return false; -} - - -#endif // AARCH64 LIR_Opr LIRGenerator::safepoint_poll_register() { @@ -211,48 +160,10 @@ static LIR_Opr make_constant(BasicType type, jlong c) { } } -#ifdef AARCH64 - -void LIRGenerator::add_constant(LIR_Opr src, jlong c, LIR_Opr dest) { - if (c == 0) { - __ move(src, dest); - return; - } - - BasicType type = src->type(); - bool is_neg = (c < 0); - c = ABS(c); - - if ((c >> 24) == 0) { - for (int shift = 0; shift <= 12; shift += 12) { - int part = ((int)c) & (right_n_bits(12) << shift); - if (part != 0) { - if (is_neg) { - __ sub(src, make_constant(type, part), dest); - } else { - __ add(src, make_constant(type, part), dest); - } - src = dest; - } - } - } else { - __ move(make_constant(type, c), dest); - if (is_neg) { - __ sub(src, dest, dest); - } else { - __ add(src, dest, dest); - } - } -} - -#endif // AARCH64 void LIRGenerator::add_large_constant(LIR_Opr src, int c, LIR_Opr dest) { assert(c != 0, "must be"); -#ifdef AARCH64 - add_constant(src, c, dest); -#else // Find first non-zero bit int shift = 0; while ((c & (3 << shift)) == 0) { @@ -272,7 +183,6 @@ void LIRGenerator::add_large_constant(LIR_Opr src, int c, LIR_Opr dest) { if (c & (mask << 24)) { __ add(dest, LIR_OprFact::intConst(c & (mask << 24)), dest); } -#endif // AARCH64 } static LIR_Address* make_address(LIR_Opr base, LIR_Opr index, LIR_Address::Scale scale, BasicType type) { @@ -288,7 +198,6 @@ LIR_Address* LIRGenerator::generate_address(LIR_Opr base, LIR_Opr index, index = LIR_OprFact::illegalOpr; } -#ifndef AARCH64 if (base->type() == T_LONG) { LIR_Opr tmp = new_register(T_INT); __ convert(Bytecodes::_l2i, base, tmp); @@ -302,26 +211,11 @@ LIR_Address* LIRGenerator::generate_address(LIR_Opr base, LIR_Opr index, // At this point base and index should be all ints and not constants assert(base->is_single_cpu() && !base->is_constant(), "base should be an non-constant int"); assert(index->is_illegal() || (index->type() == T_INT && !index->is_constant()), "index should be an non-constant int"); -#endif int max_disp; bool disp_is_in_range; bool embedded_shift; -#ifdef AARCH64 - int align = exact_log2(type2aelembytes(type, true)); - assert((disp & right_n_bits(align)) == 0, "displacement is not aligned"); - assert(shift == 0 || shift == align, "shift should be zero or equal to embedded align"); - max_disp = (1 << 12) << align; - - if (disp >= 0) { - disp_is_in_range = Assembler::is_unsigned_imm_in_range(disp, 12, align); - } else { - disp_is_in_range = Assembler::is_imm_in_range(disp, 9, 0); - } - - embedded_shift = true; -#else switch (type) { case T_BYTE: case T_SHORT: @@ -344,7 +238,6 @@ LIR_Address* LIRGenerator::generate_address(LIR_Opr base, LIR_Opr index, } disp_is_in_range = (-max_disp < disp && disp < max_disp); -#endif // !AARCH64 if (index->is_register()) { LIR_Opr tmp = new_pointer_register(); @@ -394,11 +287,7 @@ LIR_Address* LIRGenerator::emit_array_address(LIR_Opr array_opr, LIR_Opr index_o LIR_Opr LIRGenerator::load_immediate(int x, BasicType type) { assert(type == T_LONG || type == T_INT, "should be"); LIR_Opr r = make_constant(type, x); -#ifdef AARCH64 - bool imm_in_range = Assembler::LogicalImmediate(x, type == T_INT).is_encoded(); -#else bool imm_in_range = AsmOperand::is_rotated_imm(x); -#endif // AARCH64 if (!imm_in_range) { LIR_Opr tmp = new_register(type); __ move(r, tmp); @@ -439,14 +328,9 @@ void LIRGenerator::cmp_reg_mem(LIR_Condition condition, LIR_Opr reg, LIR_Opr bas bool LIRGenerator::strength_reduce_multiply(LIR_Opr left, int c, LIR_Opr result, LIR_Opr tmp) { assert(left != result, "should be different registers"); if (is_power_of_2(c + 1)) { -#ifdef AARCH64 - __ shift_left(left, log2_intptr(c + 1), result); - __ sub(result, left, result); -#else LIR_Address::Scale scale = (LIR_Address::Scale) log2_intptr(c + 1); LIR_Address* addr = new LIR_Address(left, left, scale, 0, T_INT); __ sub(LIR_OprFact::address(addr), left, result); // rsb with shifted register -#endif // AARCH64 return true; } else if (is_power_of_2(c - 1)) { LIR_Address::Scale scale = (LIR_Address::Scale) log2_intptr(c - 1); @@ -465,12 +349,7 @@ void LIRGenerator::store_stack_parameter(LIR_Opr item, ByteSize offset_from_sp) void LIRGenerator::set_card(LIR_Opr value, LIR_Address* card_addr) { assert(CardTable::dirty_card_val() == 0, - "Cannot use ZR register (aarch64) or the register containing the card table base address directly (aarch32) otherwise"); -#ifdef AARCH64 - // AARCH64 has a register that is constant zero. We can use that one to set the - // value in the card table to dirty. - __ move(FrameMap::ZR_opr, card_addr); -#else // AARCH64 + "Cannot use the register containing the card table base address directly"); if((ci_card_table_address_as() & 0xff) == 0) { // If the card table base address is aligned to 256 bytes, we can use the register // that contains the card_table_base_address. @@ -481,7 +360,6 @@ void LIRGenerator::set_card(LIR_Opr value, LIR_Address* card_addr) { __ move(LIR_OprFact::intConst(CardTable::dirty_card_val()), tmp_zero); __ move(tmp_zero, card_addr); } -#endif // AARCH64 } void LIRGenerator::CardTableBarrierSet_post_barrier_helper(LIR_OprDesc* addr, LIR_Const* card_table_base) { @@ -492,24 +370,16 @@ void LIRGenerator::CardTableBarrierSet_post_barrier_helper(LIR_OprDesc* addr, LI LIR_Opr tmp = FrameMap::LR_ptr_opr; - // TODO-AARCH64: check performance - bool load_card_table_base_const = AARCH64_ONLY(false) NOT_AARCH64(VM_Version::supports_movw()); + bool load_card_table_base_const = VM_Version::supports_movw(); if (load_card_table_base_const) { __ move((LIR_Opr)card_table_base, tmp); } else { __ move(new LIR_Address(FrameMap::Rthread_opr, in_bytes(JavaThread::card_table_base_offset()), T_ADDRESS), tmp); } -#ifdef AARCH64 - LIR_Address* shifted_reg_operand = new LIR_Address(tmp, addr, (LIR_Address::Scale) -CardTable::card_shift, 0, T_BYTE); - LIR_Opr tmp2 = tmp; - __ add(tmp, LIR_OprFact::address(shifted_reg_operand), tmp2); // tmp2 = tmp + (addr >> CardTable::card_shift) - LIR_Address* card_addr = new LIR_Address(tmp2, T_BYTE); -#else // Use unsigned type T_BOOLEAN here rather than (signed) T_BYTE since signed load // byte instruction does not support the addressing mode we need. LIR_Address* card_addr = new LIR_Address(tmp, addr, (LIR_Address::Scale) -CardTable::card_shift, 0, T_BOOLEAN); -#endif if (UseCondCardMark) { if (ct->scanned_concurrently()) { __ membar_storeload(); @@ -679,63 +549,6 @@ void LIRGenerator::do_ArithmeticOp_Long(ArithmeticOp* x) { info = state_for(x); } -#ifdef AARCH64 - LIRItem left(x->x(), this); - LIRItem right(x->y(), this); - LIRItem* left_arg = &left; - LIRItem* right_arg = &right; - - // Test if instr is commutative and if we should swap - if (x->is_commutative() && left.is_constant()) { - left_arg = &right; - right_arg = &left; - } - - left_arg->load_item(); - switch (x->op()) { - case Bytecodes::_ldiv: - right_arg->load_item(); - make_div_by_zero_check(right_arg->result(), T_LONG, info); - __ idiv(left_arg->result(), right_arg->result(), rlock_result(x), LIR_OprFact::illegalOpr, NULL); - break; - - case Bytecodes::_lrem: { - right_arg->load_item(); - make_div_by_zero_check(right_arg->result(), T_LONG, info); - // a % b is implemented with 2 instructions: - // tmp = a/b (sdiv) - // res = a - b*tmp (msub) - LIR_Opr tmp = FrameMap::as_long_opr(Rtemp); - __ irem(left_arg->result(), right_arg->result(), rlock_result(x), tmp, NULL); - break; - } - - case Bytecodes::_lmul: - if (right_arg->is_constant() && is_power_of_2_long(right_arg->get_jlong_constant())) { - right_arg->dont_load_item(); - __ shift_left(left_arg->result(), exact_log2_long(right_arg->get_jlong_constant()), rlock_result(x)); - } else { - right_arg->load_item(); - __ mul(left_arg->result(), right_arg->result(), rlock_result(x)); - } - break; - - case Bytecodes::_ladd: - case Bytecodes::_lsub: - if (right_arg->is_constant()) { - jlong c = right_arg->get_jlong_constant(); - add_constant(left_arg->result(), (x->op() == Bytecodes::_ladd) ? c : -c, rlock_result(x)); - } else { - right_arg->load_item(); - arithmetic_op_long(x->op(), rlock_result(x), left_arg->result(), right_arg->result(), NULL); - } - break; - - default: - ShouldNotReachHere(); - return; - } -#else switch (x->op()) { case Bytecodes::_ldiv: case Bytecodes::_lrem: { @@ -777,7 +590,6 @@ void LIRGenerator::do_ArithmeticOp_Long(ArithmeticOp* x) { default: ShouldNotReachHere(); } -#endif // AARCH64 } @@ -804,20 +616,6 @@ void LIRGenerator::do_ArithmeticOp_Int(ArithmeticOp* x) { LIR_Opr result = rlock_result(x); __ idiv(left_arg->result(), right_arg->result(), result, tmp, info); } else { -#ifdef AARCH64 - left_arg->load_item(); - right_arg->load_item(); - make_div_by_zero_check(right_arg->result(), T_INT, info); - if (x->op() == Bytecodes::_idiv) { - __ idiv(left_arg->result(), right_arg->result(), rlock_result(x), LIR_OprFact::illegalOpr, NULL); - } else { - // a % b is implemented with 2 instructions: - // tmp = a/b (sdiv) - // res = a - b*tmp (msub) - LIR_Opr tmp = FrameMap::as_opr(Rtemp); - __ irem(left_arg->result(), right_arg->result(), rlock_result(x), tmp, NULL); - } -#else left_arg->load_item_force(FrameMap::R0_opr); right_arg->load_item_force(FrameMap::R2_opr); LIR_Opr tmp = FrameMap::R1_opr; @@ -831,16 +629,8 @@ void LIRGenerator::do_ArithmeticOp_Int(ArithmeticOp* x) { __ idiv(left_arg->result(), right_arg->result(), out_reg, tmp, info); } __ move(out_reg, result); -#endif // AARCH64 } -#ifdef AARCH64 - } else if (((x->op() == Bytecodes::_iadd) || (x->op() == Bytecodes::_isub)) && right_arg->is_constant()) { - left_arg->load_item(); - jint c = right_arg->get_jint_constant(); - right_arg->dont_load_item(); - add_constant(left_arg->result(), (x->op() == Bytecodes::_iadd) ? c : -c, rlock_result(x)); -#endif // AARCH64 } else { left_arg->load_item(); @@ -852,7 +642,6 @@ void LIRGenerator::do_ArithmeticOp_Int(ArithmeticOp* x) { right_arg->load_item(); } } else { - AARCH64_ONLY(assert(!right_arg->is_constant(), "constant right_arg is already handled by this moment");) right_arg->load_nonconstant(); } rlock_result(x); @@ -880,11 +669,9 @@ void LIRGenerator::do_ShiftOp(ShiftOp* x) { LIRItem value(x->x(), this); LIRItem count(x->y(), this); -#ifndef AARCH64 if (value.type()->is_long()) { count.set_destroys_register(); } -#endif // !AARCH64 if (count.is_constant()) { assert(count.type()->as_IntConstant() != NULL, "should be"); @@ -906,15 +693,7 @@ void LIRGenerator::do_LogicOp(LogicOp* x) { left.load_item(); -#ifdef AARCH64 - if (right.is_constant() && can_inline_as_constant_in_logic(right.value())) { - right.dont_load_item(); - } else { - right.load_item(); - } -#else right.load_nonconstant(); -#endif // AARCH64 logic_op(x->op(), rlock_result(x), left.result(), right.result()); } @@ -956,15 +735,7 @@ void LIRGenerator::do_CompareOp(CompareOp* x) { LIRItem right(x->y(), this); left.load_item(); -#ifdef AARCH64 - if (right.is_constant() && can_inline_as_constant_in_cmp(right.value())) { - right.dont_load_item(); - } else { - right.load_item(); - } -#else right.load_nonconstant(); -#endif // AARCH64 LIR_Opr reg = rlock_result(x); @@ -987,19 +758,11 @@ LIR_Opr LIRGenerator::atomic_cmpxchg(BasicType type, LIR_Opr addr, LIRItem& cmp_ cmp_value.load_item(); LIR_Opr result = new_register(T_INT); if (type == T_OBJECT || type == T_ARRAY) { -#ifdef AARCH64 - if (UseCompressedOops) { - tmp1 = new_pointer_register(); - tmp2 = new_pointer_register(); - } -#endif __ cas_obj(addr, cmp_value.result(), new_value.result(), new_register(T_INT), new_register(T_INT), result); } else if (type == T_INT) { __ cas_int(addr->as_address_ptr()->base(), cmp_value.result(), new_value.result(), tmp1, tmp1, result); } else if (type == T_LONG) { -#ifndef AARCH64 tmp1 = new_register(T_LONG); -#endif // !AARCH64 __ cas_long(addr->as_address_ptr()->base(), cmp_value.result(), new_value.result(), tmp1, tmp2, result); } else { ShouldNotReachHere(); @@ -1135,7 +898,6 @@ void LIRGenerator::do_update_CRC32C(Intrinsic* x) { void LIRGenerator::do_Convert(Convert* x) { address runtime_func; switch (x->op()) { -#ifndef AARCH64 case Bytecodes::_l2f: runtime_func = CAST_FROM_FN_PTR(address, SharedRuntime::l2f); break; @@ -1170,7 +932,6 @@ void LIRGenerator::do_Convert(Convert* x) { runtime_func = CAST_FROM_FN_PTR(address, SharedRuntime::d2i); break; #endif // __SOFTFP__ -#endif // !AARCH64 default: { LIRItem value(x->value(), this); value.load_item(); @@ -1488,7 +1249,6 @@ void LIRGenerator::do_If(If* x) { LIRItem* yin = &yitem; If::Condition cond = x->cond(); -#ifndef AARCH64 if (tag == longTag) { if (cond == If::gtr || cond == If::leq) { cond = Instruction::mirror(cond); @@ -1497,20 +1257,11 @@ void LIRGenerator::do_If(If* x) { } xin->set_destroys_register(); } -#endif // !AARCH64 xin->load_item(); LIR_Opr left = xin->result(); LIR_Opr right; -#ifdef AARCH64 - if (yin->is_constant() && can_inline_as_constant_in_cmp(yin->value())) { - yin->dont_load_item(); - } else { - yin->load_item(); - } - right = yin->result(); -#else if (tag == longTag && yin->is_constant() && yin->get_jlong_constant() == 0 && (cond == If::eql || cond == If::neq)) { // inline long zero @@ -1519,7 +1270,6 @@ void LIRGenerator::do_If(If* x) { yin->load_nonconstant(); right = yin->result(); } -#endif // AARCH64 set_no_result(x); @@ -1558,7 +1308,6 @@ void LIRGenerator::trace_block_entry(BlockBegin* block) { void LIRGenerator::volatile_field_store(LIR_Opr value, LIR_Address* address, CodeEmitInfo* info) { -#ifndef AARCH64 if (value->is_double_cpu()) { assert(address->index()->is_illegal(), "should have a constant displacement"); LIR_Opr tmp = new_pointer_register(); @@ -1566,14 +1315,11 @@ void LIRGenerator::volatile_field_store(LIR_Opr value, LIR_Address* address, __ volatile_store_mem_reg(value, new LIR_Address(tmp, (intx)0, address->type()), info); return; } -#endif // !AARCH64 - // TODO-AARCH64 implement with stlr instruction __ store(value, address, info, lir_patch_none); } void LIRGenerator::volatile_field_load(LIR_Address* address, LIR_Opr result, CodeEmitInfo* info) { -#ifndef AARCH64 if (result->is_double_cpu()) { assert(address->index()->is_illegal(), "should have a constant displacement"); LIR_Opr tmp = new_pointer_register(); @@ -1581,7 +1327,5 @@ void LIRGenerator::volatile_field_load(LIR_Address* address, LIR_Opr result, __ volatile_load_mem_reg(new LIR_Address(tmp, (intx)0, address->type()), result, info); return; } -#endif // !AARCH64 - // TODO-AARCH64 implement with ldar instruction __ load(address, result, info, lir_patch_none); } diff --git a/src/hotspot/cpu/arm/c1_LIRGenerator_arm.hpp b/src/hotspot/cpu/arm/c1_LIRGenerator_arm.hpp index 24552cb1528..5bb8e473e7e 100644 --- a/src/hotspot/cpu/arm/c1_LIRGenerator_arm.hpp +++ b/src/hotspot/cpu/arm/c1_LIRGenerator_arm.hpp @@ -27,7 +27,3 @@ void make_div_by_zero_check(LIR_Opr right_arg, BasicType type, CodeEmitInfo* info); -#ifdef AARCH64 - // the helper for arithmetic - void add_constant(LIR_Opr src, jlong c, LIR_Opr dest); -#endif // AARCH64 diff --git a/src/hotspot/cpu/arm/c1_LIR_arm.cpp b/src/hotspot/cpu/arm/c1_LIR_arm.cpp index 806da320209..791c6985137 100644 --- a/src/hotspot/cpu/arm/c1_LIR_arm.cpp +++ b/src/hotspot/cpu/arm/c1_LIR_arm.cpp @@ -33,17 +33,6 @@ FloatRegister LIR_OprDesc::as_double_reg() const { return as_FloatRegister(fpu_regnrLo()); } -#ifdef AARCH64 -// Reg2 unused. -LIR_Opr LIR_OprFact::double_fpu(int reg1, int reg2) { - assert(as_FloatRegister(reg2) == fnoreg, "Not used on this platform"); - return (LIR_Opr)(intptr_t)((reg1 << LIR_OprDesc::reg1_shift) | - (reg1 << LIR_OprDesc::reg2_shift) | - LIR_OprDesc::double_type | - LIR_OprDesc::fpu_register | - LIR_OprDesc::double_size); -} -#else LIR_Opr LIR_OprFact::double_fpu(int reg1, int reg2) { assert(as_FloatRegister(reg2) != fnoreg, "Arm32 holds double in two regs."); return (LIR_Opr)(intptr_t)((reg1 << LIR_OprDesc::reg1_shift) | @@ -52,22 +41,12 @@ LIR_Opr LIR_OprFact::double_fpu(int reg1, int reg2) { LIR_OprDesc::fpu_register | LIR_OprDesc::double_size); } -#endif #ifndef PRODUCT void LIR_Address::verify() const { #ifdef _LP64 assert(base()->is_cpu_register(), "wrong base operand"); #endif -#ifdef AARCH64 - if (base()->type() == T_INT) { - assert(index()->is_single_cpu() && (index()->type() == T_INT), "wrong index operand"); - } else { - assert(index()->is_illegal() || index()->is_double_cpu() || - (index()->is_single_cpu() && (index()->is_oop_register() || index()->type() == T_INT)), "wrong index operand"); - assert(base()->type() == T_OBJECT || base()->type() == T_LONG || base()->type() == T_METADATA, "wrong type for addresses"); - } -#else assert(disp() == 0 || index()->is_illegal(), "can't have both"); // Note: offsets higher than 4096 must not be rejected here. They can // be handled by the back-end or will be rejected if not. @@ -81,6 +60,5 @@ void LIR_Address::verify() const { assert(base()->type() == T_OBJECT || base()->type() == T_INT || base()->type() == T_METADATA, "wrong type for addresses"); #endif -#endif // AARCH64 } #endif // PRODUCT diff --git a/src/hotspot/cpu/arm/c1_LinearScan_arm.hpp b/src/hotspot/cpu/arm/c1_LinearScan_arm.hpp index d67643c7dbf..5a5ad691b5b 100644 --- a/src/hotspot/cpu/arm/c1_LinearScan_arm.hpp +++ b/src/hotspot/cpu/arm/c1_LinearScan_arm.hpp @@ -31,24 +31,17 @@ inline bool LinearScan::is_processed_reg_num(int reg_num) { } inline int LinearScan::num_physical_regs(BasicType type) { -#ifndef AARCH64 if (type == T_LONG || type == T_DOUBLE) return 2; -#endif // !AARCH64 return 1; } inline bool LinearScan::requires_adjacent_regs(BasicType type) { -#ifdef AARCH64 - return false; -#else return type == T_DOUBLE || type == T_LONG; -#endif // AARCH64 } inline bool LinearScan::is_caller_save(int assigned_reg) { assert(assigned_reg >= 0 && assigned_reg < nof_regs, "should call this only for registers"); - // TODO-AARCH64 try to add callee-saved registers return true; } diff --git a/src/hotspot/cpu/arm/c1_MacroAssembler_arm.cpp b/src/hotspot/cpu/arm/c1_MacroAssembler_arm.cpp index b2872b395e1..b335acade47 100644 --- a/src/hotspot/cpu/arm/c1_MacroAssembler_arm.cpp +++ b/src/hotspot/cpu/arm/c1_MacroAssembler_arm.cpp @@ -46,11 +46,7 @@ void C1_MacroAssembler::inline_cache_check(Register receiver, Register iCache) { load_klass(Rtemp, receiver); cmp(Rtemp, iCache); b(verified, eq); // jump over alignment no-ops -#ifdef AARCH64 - jump(SharedRuntime::get_ic_miss_stub(), relocInfo::runtime_call_type, Rtemp); -#else jump(SharedRuntime::get_ic_miss_stub(), relocInfo::runtime_call_type); -#endif align(CodeEntryAlignment); bind(verified); } @@ -59,10 +55,6 @@ void C1_MacroAssembler::build_frame(int frame_size_in_bytes, int bang_size_in_by assert(bang_size_in_bytes >= frame_size_in_bytes, "stack bang size incorrect"); assert((frame_size_in_bytes % StackAlignmentInBytes) == 0, "frame size should be aligned"); -#ifdef AARCH64 - // Extra nop for MT-safe patching in NativeJump::patch_verified_entry - nop(); -#endif // AARCH64 arm_stack_overflow_check(bang_size_in_bytes, Rtemp); @@ -103,28 +95,12 @@ void C1_MacroAssembler::initialize_header(Register obj, Register klass, Register mov(tmp, (intptr_t)markOopDesc::prototype()); } -#ifdef AARCH64 - if (UseCompressedClassPointers) { - str(tmp, Address(obj, oopDesc::mark_offset_in_bytes())); - encode_klass_not_null(tmp, klass); // Take care not to kill klass - str_w(tmp, Address(obj, oopDesc::klass_offset_in_bytes())); - } else { - assert(oopDesc::mark_offset_in_bytes() + wordSize == oopDesc::klass_offset_in_bytes(), "adjust this code"); - stp(tmp, klass, Address(obj, oopDesc::mark_offset_in_bytes())); - } -#else str(tmp, Address(obj, oopDesc::mark_offset_in_bytes())); str(klass, Address(obj, oopDesc::klass_offset_in_bytes())); -#endif // AARCH64 if (len->is_valid()) { str_32(len, Address(obj, arrayOopDesc::length_offset_in_bytes())); } -#ifdef AARCH64 - else if (UseCompressedClassPointers) { - store_klass_gap(obj); - } -#endif // AARCH64 } @@ -145,40 +121,6 @@ void C1_MacroAssembler::initialize_object(Register obj, Register obj_end, Regist const Register ptr = tmp2; if (!(UseTLAB && ZeroTLAB && is_tlab_allocated)) { -#ifdef AARCH64 - if (obj_size_in_bytes < 0) { - add_rc(ptr, obj, header_size); - initialize_body(ptr, obj_end, tmp1); - - } else { - int base = instanceOopDesc::header_size() * HeapWordSize; - assert(obj_size_in_bytes >= base, "should be"); - - const int zero_bytes = obj_size_in_bytes - base; - assert((zero_bytes % wordSize) == 0, "should be"); - - if ((zero_bytes % (2*wordSize)) != 0) { - str(ZR, Address(obj, base)); - base += wordSize; - } - - const int stp_count = zero_bytes / (2*wordSize); - - if (zero_bytes > 8 * wordSize) { - Label loop; - add(ptr, obj, base); - mov(tmp1, stp_count); - bind(loop); - subs(tmp1, tmp1, 1); - stp(ZR, ZR, Address(ptr, 2*wordSize, post_indexed)); - b(loop, gt); - } else { - for (int i = 0; i < stp_count; i++) { - stp(ZR, ZR, Address(obj, base + i * 2 * wordSize)); - } - } - } -#else if (obj_size_in_bytes >= 0 && obj_size_in_bytes <= 8 * BytesPerWord) { mov(tmp1, 0); const int base = instanceOopDesc::header_size() * HeapWordSize; @@ -190,7 +132,6 @@ void C1_MacroAssembler::initialize_object(Register obj, Register obj_end, Regist add(ptr, obj, header_size); initialize_body(ptr, obj_end, tmp1); } -#endif // AARCH64 } // StoreStore barrier required after complete initialization @@ -227,12 +168,7 @@ void C1_MacroAssembler::allocate_array(Register obj, Register len, const int scale_shift = exact_log2(element_size); const Register obj_size = Rtemp; // Rtemp should be free at c1 LIR level -#ifdef AARCH64 - mov_slow(Rtemp, max_array_allocation_length); - cmp_32(len, Rtemp); -#else cmp_32(len, max_array_allocation_length); -#endif // AARCH64 b(slow_case, hs); bool align_header = ((header_size_in_bytes | element_size) & MinObjAlignmentInBytesMask) != 0; @@ -271,34 +207,6 @@ int C1_MacroAssembler::lock_object(Register hdr, Register obj, assert(oopDesc::mark_offset_in_bytes() == 0, "Required by atomic instructions"); -#ifdef AARCH64 - - str(obj, Address(disp_hdr, obj_offset)); - - if (!UseBiasedLocking) { - null_check_offset = offset(); - } - ldr(hdr, obj); - - // Test if object is already locked - assert(markOopDesc::unlocked_value == 1, "adjust this code"); - tbnz(hdr, exact_log2(markOopDesc::unlocked_value), fast_lock); - - // Check for recursive locking - // See comments in InterpreterMacroAssembler::lock_object for - // explanations on the fast recursive locking check. - intptr_t mask = ((intptr_t)3) - ((intptr_t)os::vm_page_size()); - Assembler::LogicalImmediate imm(mask, false); - mov(tmp2, SP); - sub(tmp2, hdr, tmp2); - ands(tmp2, tmp2, imm); - b(slow_case, ne); - - // Recursive locking: store 0 into a lock record - str(ZR, Address(disp_hdr, mark_offset)); - b(fast_lock_done); - -#else // AARCH64 if (!UseBiasedLocking) { null_check_offset = offset(); @@ -328,7 +236,6 @@ int C1_MacroAssembler::lock_object(Register hdr, Register obj, // else need slow case b(slow_case); -#endif // AARCH64 bind(fast_lock); // Save previous object header in BasicLock structure and update the header diff --git a/src/hotspot/cpu/arm/c1_Runtime1_arm.cpp b/src/hotspot/cpu/arm/c1_Runtime1_arm.cpp index 95bf1e47335..3709c9e27b9 100644 --- a/src/hotspot/cpu/arm/c1_Runtime1_arm.cpp +++ b/src/hotspot/cpu/arm/c1_Runtime1_arm.cpp @@ -80,15 +80,8 @@ int StubAssembler::call_RT(Register oop_result1, Register metadata_result, addre // Runtime1::exception_handler_for_pc if (_stub_id != Runtime1::forward_exception_id) { assert(frame_size() != no_frame_size, "cannot directly call forward_exception_id"); -#ifdef AARCH64 - Label skip; - cbz(R3, skip); - jump(Runtime1::entry_for(Runtime1::forward_exception_id), relocInfo::runtime_call_type, Rtemp); - bind(skip); -#else cmp(R3, 0); jump(Runtime1::entry_for(Runtime1::forward_exception_id), relocInfo::runtime_call_type, Rtemp, ne); -#endif // AARCH64 } else { #ifdef ASSERT // Should not have pending exception in forward_exception stub @@ -124,43 +117,6 @@ int StubAssembler::call_RT(Register oop_result1, Register metadata_result, addre #define __ sasm-> // TODO: ARM - does this duplicate RegisterSaver in SharedRuntime? -#ifdef AARCH64 - - // - // On AArch64 registers save area has the following layout: - // - // |---------------------| - // | return address (LR) | - // | FP | - // |---------------------| - // | D31 | - // | ... | - // | D0 | - // |---------------------| - // | padding | - // |---------------------| - // | R28 | - // | ... | - // | R0 | - // |---------------------| <-- SP - // - -enum RegisterLayout { - number_of_saved_gprs = 29, - number_of_saved_fprs = FloatRegisterImpl::number_of_registers, - - R0_offset = 0, - D0_offset = R0_offset + number_of_saved_gprs + 1, - FP_offset = D0_offset + number_of_saved_fprs, - LR_offset = FP_offset + 1, - - reg_save_size = LR_offset + 1, - - arg1_offset = reg_save_size * wordSize, - arg2_offset = (reg_save_size + 1) * wordSize -}; - -#else enum RegisterLayout { fpu_save_size = pd_nof_fpu_regs_reg_alloc, @@ -191,7 +147,6 @@ enum RegisterLayout { arg2_offset = (reg_save_size + 1) * wordSize }; -#endif // AARCH64 static OopMap* generate_oop_map(StubAssembler* sasm, bool save_fpu_registers = HaveVFP) { sasm->set_frame_size(reg_save_size /* in words */); @@ -200,19 +155,6 @@ static OopMap* generate_oop_map(StubAssembler* sasm, bool save_fpu_registers = H // Locations are offsets from sp after runtime call. OopMap* map = new OopMap(VMRegImpl::slots_per_word * reg_save_size, 0); -#ifdef AARCH64 - for (int i = 0; i < number_of_saved_gprs; i++) { - map->set_callee_saved(VMRegImpl::stack2reg((R0_offset + i) * VMRegImpl::slots_per_word), as_Register(i)->as_VMReg()); - } - map->set_callee_saved(VMRegImpl::stack2reg(FP_offset * VMRegImpl::slots_per_word), FP->as_VMReg()); - map->set_callee_saved(VMRegImpl::stack2reg(LR_offset * VMRegImpl::slots_per_word), LR->as_VMReg()); - - if (save_fpu_registers) { - for (int i = 0; i < number_of_saved_fprs; i++) { - map->set_callee_saved(VMRegImpl::stack2reg((D0_offset + i) * VMRegImpl::slots_per_word), as_FloatRegister(i)->as_VMReg()); - } - } -#else int j=0; for (int i = R0_offset; i < R10_offset; i++) { if (j == FP_REG_NUM) { @@ -235,7 +177,6 @@ static OopMap* generate_oop_map(StubAssembler* sasm, bool save_fpu_registers = H map->set_callee_saved(VMRegImpl::stack2reg(i), as_FloatRegister(i)->as_VMReg()); } } -#endif // AARCH64 return map; } @@ -244,29 +185,6 @@ static OopMap* save_live_registers(StubAssembler* sasm, bool save_fpu_registers __ block_comment("save_live_registers"); sasm->set_frame_size(reg_save_size /* in words */); -#ifdef AARCH64 - assert((reg_save_size * wordSize) % StackAlignmentInBytes == 0, "SP should be aligned"); - - __ raw_push(FP, LR); - - __ sub(SP, SP, (reg_save_size - 2) * wordSize); - - for (int i = 0; i < align_down((int)number_of_saved_gprs, 2); i += 2) { - __ stp(as_Register(i), as_Register(i+1), Address(SP, (R0_offset + i) * wordSize)); - } - - if (is_odd(number_of_saved_gprs)) { - int i = number_of_saved_gprs - 1; - __ str(as_Register(i), Address(SP, (R0_offset + i) * wordSize)); - } - - if (save_fpu_registers) { - assert (is_even(number_of_saved_fprs), "adjust this code"); - for (int i = 0; i < number_of_saved_fprs; i += 2) { - __ stp_d(as_FloatRegister(i), as_FloatRegister(i+1), Address(SP, (D0_offset + i) * wordSize)); - } - } -#else __ push(RegisterSet(FP) | RegisterSet(LR)); __ push(RegisterSet(R0, R6) | RegisterSet(R8, R10) | R12 | altFP_7_11); if (save_fpu_registers) { @@ -274,7 +192,6 @@ static OopMap* save_live_registers(StubAssembler* sasm, bool save_fpu_registers } else { __ sub(SP, SP, fpu_save_size * wordSize); } -#endif // AARCH64 return generate_oop_map(sasm, save_fpu_registers); } @@ -287,34 +204,6 @@ static void restore_live_registers(StubAssembler* sasm, bool restore_fpu_registers = HaveVFP) { __ block_comment("restore_live_registers"); -#ifdef AARCH64 - if (restore_R0) { - __ ldr(R0, Address(SP, R0_offset * wordSize)); - } - - assert(is_odd(number_of_saved_gprs), "adjust this code"); - for (int i = 1; i < number_of_saved_gprs; i += 2) { - __ ldp(as_Register(i), as_Register(i+1), Address(SP, (R0_offset + i) * wordSize)); - } - - if (restore_fpu_registers) { - assert (is_even(number_of_saved_fprs), "adjust this code"); - for (int i = 0; i < number_of_saved_fprs; i += 2) { - __ ldp_d(as_FloatRegister(i), as_FloatRegister(i+1), Address(SP, (D0_offset + i) * wordSize)); - } - } - - __ add(SP, SP, (reg_save_size - 2) * wordSize); - - if (restore_FP_LR) { - __ raw_pop(FP, LR); - if (do_return) { - __ ret(); - } - } else { - assert (!do_return, "return without restoring FP/LR"); - } -#else if (restore_fpu_registers) { __ fldmiad(SP, FloatRegisterSet(D0, fpu_save_size / 2), writeback); if (!restore_R0) { @@ -329,7 +218,6 @@ static void restore_live_registers(StubAssembler* sasm, } else { assert (!do_return, "return without restoring FP/LR"); } -#endif // AARCH64 } @@ -341,11 +229,9 @@ static void restore_live_registers(StubAssembler* sasm, bool restore_fpu_registe restore_live_registers(sasm, true, true, true, restore_fpu_registers); } -#ifndef AARCH64 static void restore_live_registers_except_FP_LR(StubAssembler* sasm, bool restore_fpu_registers = HaveVFP) { restore_live_registers(sasm, true, false, false, restore_fpu_registers); } -#endif // !AARCH64 static void restore_live_registers_without_return(StubAssembler* sasm, bool restore_fpu_registers = HaveVFP) { restore_live_registers(sasm, true, true, false, restore_fpu_registers); @@ -386,15 +272,8 @@ OopMapSet* Runtime1::generate_exception_throw(StubAssembler* sasm, address targe static void restore_sp_for_method_handle(StubAssembler* sasm) { // Restore SP from its saved reg (FP) if the exception PC is a MethodHandle call site. __ ldr_s32(Rtemp, Address(Rthread, JavaThread::is_method_handle_return_offset())); -#ifdef AARCH64 - Label skip; - __ cbz(Rtemp, skip); - __ mov(SP, Rmh_SP_save); - __ bind(skip); -#else __ cmp(Rtemp, 0); __ mov(SP, Rmh_SP_save, ne); -#endif // AARCH64 } @@ -500,22 +379,12 @@ OopMapSet* Runtime1::generate_patching(StubAssembler* sasm, address target) { __ cmp_32(R0, 0); -#ifdef AARCH64 - Label call_deopt; - - restore_live_registers_without_return(sasm); - __ b(call_deopt, ne); - __ ret(); - - __ bind(call_deopt); -#else restore_live_registers_except_FP_LR(sasm); __ pop(RegisterSet(FP) | RegisterSet(PC), eq); // Deoptimization needed // TODO: ARM - no need to restore FP & LR because unpack_with_reexecution() stores them back __ pop(RegisterSet(FP) | RegisterSet(LR)); -#endif // AARCH64 __ jump(deopt_blob->unpack_with_reexecution(), relocInfo::runtime_call_type, Rtemp); @@ -622,12 +491,7 @@ OopMapSet* Runtime1::generate_code_for(StubID id, StubAssembler* sasm) { if (!UseTLAB && Universe::heap()->supports_inline_contig_alloc()) { Label slow_case, slow_case_no_pop; -#ifdef AARCH64 - __ mov_slow(Rtemp, C1_MacroAssembler::max_array_allocation_length); - __ cmp_32(length, Rtemp); -#else __ cmp_32(length, C1_MacroAssembler::max_array_allocation_length); -#endif // AARCH64 __ b(slow_case_no_pop, hs); // Free some temporary registers @@ -644,12 +508,7 @@ OopMapSet* Runtime1::generate_code_for(StubID id, StubAssembler* sasm) { __ mov(arr_size, MinObjAlignmentInBytesMask); __ and_32(tmp2, tmp1, (unsigned int)(Klass::_lh_header_size_mask << Klass::_lh_header_size_shift)); -#ifdef AARCH64 - __ lslv_w(tmp3, length, tmp1); - __ add(arr_size, arr_size, tmp3); -#else __ add(arr_size, arr_size, AsmOperand(length, lsl, tmp1)); -#endif // AARCH64 __ add(arr_size, arr_size, AsmOperand(tmp2, lsr, Klass::_lh_header_size_shift)); __ align_reg(arr_size, arr_size, MinObjAlignmentInBytes); @@ -714,15 +573,8 @@ OopMapSet* Runtime1::generate_code_for(StubID id, StubAssembler* sasm) { __ load_klass(Rtemp, R0); __ ldr_u32(Rtemp, Address(Rtemp, Klass::access_flags_offset())); -#ifdef AARCH64 - Label L; - __ tbnz(Rtemp, exact_log2(JVM_ACC_HAS_FINALIZER), L); - __ ret(); - __ bind(L); -#else __ tst(Rtemp, JVM_ACC_HAS_FINALIZER); __ bx(LR, eq); -#endif // AARCH64 // Call VM OopMap* map = save_live_registers(sasm); @@ -744,9 +596,6 @@ OopMapSet* Runtime1::generate_code_for(StubID id, StubAssembler* sasm) { case throw_index_exception_id: { __ set_info("index_range_check_failed", dont_gc_arguments); -#ifdef AARCH64 - __ NOT_TESTED(); -#endif oop_maps = generate_exception_throw(sasm, CAST_FROM_FN_PTR(address, throw_index_exception), true); } break; @@ -804,9 +653,6 @@ OopMapSet* Runtime1::generate_code_for(StubID id, StubAssembler* sasm) { case throw_incompatible_class_change_error_id: { __ set_info("throw_incompatible_class_cast_exception", dont_gc_arguments); -#ifdef AARCH64 - __ NOT_TESTED(); -#endif oop_maps = generate_exception_throw(sasm, CAST_FROM_FN_PTR(address, throw_incompatible_class_change_error), false); } break; @@ -890,7 +736,7 @@ OopMapSet* Runtime1::generate_code_for(StubID id, StubAssembler* sasm) { restore_live_registers_without_return(sasm); DeoptimizationBlob* deopt_blob = SharedRuntime::deopt_blob(); assert(deopt_blob != NULL, "deoptimization blob must have been created"); - __ jump(deopt_blob->unpack_with_reexecution(), relocInfo::runtime_call_type, AARCH64_ONLY(Rtemp) NOT_AARCH64(noreg)); + __ jump(deopt_blob->unpack_with_reexecution(), relocInfo::runtime_call_type, noreg); } break; diff --git a/src/hotspot/cpu/arm/c2_globals_arm.hpp b/src/hotspot/cpu/arm/c2_globals_arm.hpp index 2c0919660b9..636af54243a 100644 --- a/src/hotspot/cpu/arm/c2_globals_arm.hpp +++ b/src/hotspot/cpu/arm/c2_globals_arm.hpp @@ -39,27 +39,15 @@ define_pd_global(bool, PreferInterpreterNativeStubs, false); define_pd_global(bool, ProfileTraps, true); define_pd_global(bool, UseOnStackReplacement, true); define_pd_global(bool, ProfileInterpreter, true); -#ifdef AARCH64 -define_pd_global(bool, TieredCompilation, trueInTiered); -#else define_pd_global(bool, TieredCompilation, false); -#endif define_pd_global(intx, CompileThreshold, 10000); define_pd_global(intx, OnStackReplacePercentage, 140); define_pd_global(intx, ConditionalMoveLimit, 4); // C2 gets to use all the float/double registers -#ifdef AARCH64 -define_pd_global(intx, FLOATPRESSURE, 31); -#else define_pd_global(intx, FLOATPRESSURE, 30); -#endif define_pd_global(intx, FreqInlineSize, 175); -#ifdef AARCH64 -define_pd_global(intx, INTPRESSURE, 27); -#else define_pd_global(intx, INTPRESSURE, 12); -#endif define_pd_global(intx, InteriorEntryAlignment, 16); // = CodeEntryAlignment define_pd_global(size_t, NewSizeThreadIncrease, ScaleForWordSize(4*K)); // The default setting 16/16 seems to work best. diff --git a/src/hotspot/cpu/arm/frame_arm.cpp b/src/hotspot/cpu/arm/frame_arm.cpp index b31b8a3e700..675d3c2cabf 100644 --- a/src/hotspot/cpu/arm/frame_arm.cpp +++ b/src/hotspot/cpu/arm/frame_arm.cpp @@ -304,26 +304,12 @@ void frame::interpreter_frame_set_monitor_end(BasicObjectLock* value) { *((BasicObjectLock**)addr_at(interpreter_frame_monitor_block_top_offset)) = value; } -#ifdef AARCH64 - -// Used by template based interpreter deoptimization -void frame::interpreter_frame_set_stack_top(intptr_t* stack_top) { - *((intptr_t**)addr_at(interpreter_frame_stack_top_offset)) = stack_top; -} - -// Used by template based interpreter deoptimization -void frame::interpreter_frame_set_extended_sp(intptr_t* sp) { - *((intptr_t**)addr_at(interpreter_frame_extended_sp_offset)) = sp; -} - -#else // Used by template based interpreter deoptimization void frame::interpreter_frame_set_last_sp(intptr_t* sp) { *((intptr_t**)addr_at(interpreter_frame_last_sp_offset)) = sp; } -#endif // AARCH64 frame frame::sender_for_entry_frame(RegisterMap* map) const { assert(map != NULL, "map must be set"); @@ -334,18 +320,12 @@ frame frame::sender_for_entry_frame(RegisterMap* map) const { assert(jfa->last_Java_sp() > sp(), "must be above this frame on stack"); map->clear(); assert(map->include_argument_oops(), "should be set by clear"); -#ifdef AARCH64 - assert (jfa->last_Java_pc() != NULL, "pc should be stored"); - frame fr(jfa->last_Java_sp(), jfa->last_Java_fp(), jfa->last_Java_pc()); - return fr; -#else if (jfa->last_Java_pc() != NULL) { frame fr(jfa->last_Java_sp(), jfa->last_Java_fp(), jfa->last_Java_pc()); return fr; } frame fr(jfa->last_Java_sp(), jfa->last_Java_fp()); return fr; -#endif // AARCH64 } //------------------------------------------------------------------------------ @@ -403,10 +383,6 @@ void frame::adjust_unextended_sp() { void frame::update_map_with_saved_link(RegisterMap* map, intptr_t** link_addr) { // see x86 for comments map->set_location(FP->as_VMReg(), (address) link_addr); -#ifdef AARCH64 - // also adjust a high part of register - map->set_location(FP->as_VMReg()->next(), (address) link_addr); -#endif // AARCH64 } frame frame::sender_for_interpreter_frame(RegisterMap* map) const { @@ -539,14 +515,6 @@ BasicType frame::interpreter_frame_result(oop* oop_result, jvalue* value_result) if (method->is_native()) { // Prior to calling into the runtime to report the method_exit both of // the possible return value registers are saved. -#ifdef AARCH64 - // Return value registers are saved into the frame - if (type == T_FLOAT || type == T_DOUBLE) { - res_addr = addr_at(interpreter_frame_fp_saved_result_offset); - } else { - res_addr = addr_at(interpreter_frame_gp_saved_result_offset); - } -#else // Return value registers are pushed to the native stack res_addr = (intptr_t*)sp(); #ifdef __ABI_HARD__ @@ -555,7 +523,6 @@ BasicType frame::interpreter_frame_result(oop* oop_result, jvalue* value_result) res_addr += 2; } #endif // __ABI_HARD__ -#endif // AARCH64 } else { res_addr = (intptr_t*)interpreter_frame_tos_address(); } @@ -602,12 +569,7 @@ intptr_t* frame::interpreter_frame_tos_at(jint offset) const { void frame::describe_pd(FrameValues& values, int frame_no) { if (is_interpreted_frame()) { DESCRIBE_FP_OFFSET(interpreter_frame_sender_sp); -#ifdef AARCH64 - DESCRIBE_FP_OFFSET(interpreter_frame_stack_top); - DESCRIBE_FP_OFFSET(interpreter_frame_extended_sp); -#else DESCRIBE_FP_OFFSET(interpreter_frame_last_sp); -#endif // AARCH64 DESCRIBE_FP_OFFSET(interpreter_frame_method); DESCRIBE_FP_OFFSET(interpreter_frame_mdp); DESCRIBE_FP_OFFSET(interpreter_frame_cache); @@ -631,7 +593,6 @@ intptr_t *frame::initial_deoptimization_info() { } intptr_t* frame::real_fp() const { -#ifndef AARCH64 if (is_entry_frame()) { // Work-around: FP (currently) does not conform to the ABI for entry // frames (see generate_call_stub). Might be worth fixing as another CR. @@ -644,7 +605,6 @@ intptr_t* frame::real_fp() const { #endif return new_fp; } -#endif // !AARCH64 if (_cb != NULL) { // use the frame size if valid int size = _cb->frame_size(); diff --git a/src/hotspot/cpu/arm/frame_arm.hpp b/src/hotspot/cpu/arm/frame_arm.hpp index 9d0081cf946..eba3fc58c78 100644 --- a/src/hotspot/cpu/arm/frame_arm.hpp +++ b/src/hotspot/cpu/arm/frame_arm.hpp @@ -37,22 +37,12 @@ sender_sp_offset = 2, // Interpreter frames -#ifdef AARCH64 - interpreter_frame_gp_saved_result_offset = 4, // for native calls only - interpreter_frame_fp_saved_result_offset = 3, // for native calls only -#endif interpreter_frame_oop_temp_offset = 2, // for native calls only interpreter_frame_sender_sp_offset = -1, -#ifdef AARCH64 - interpreter_frame_stack_top_offset = interpreter_frame_sender_sp_offset - 1, - interpreter_frame_extended_sp_offset = interpreter_frame_stack_top_offset - 1, - interpreter_frame_method_offset = interpreter_frame_extended_sp_offset - 1, -#else // outgoing sp before a call to an invoked method interpreter_frame_last_sp_offset = interpreter_frame_sender_sp_offset - 1, interpreter_frame_method_offset = interpreter_frame_last_sp_offset - 1, -#endif // AARCH64 interpreter_frame_mirror_offset = interpreter_frame_method_offset - 1, interpreter_frame_mdp_offset = interpreter_frame_mirror_offset - 1, interpreter_frame_cache_offset = interpreter_frame_mdp_offset - 1, @@ -64,7 +54,7 @@ interpreter_frame_monitor_block_bottom_offset = interpreter_frame_initial_sp_offset, // Entry frames - entry_frame_call_wrapper_offset = AARCH64_ONLY(2) NOT_AARCH64(0) + entry_frame_call_wrapper_offset = 0 }; intptr_t ptr_at(int offset) const { @@ -107,9 +97,7 @@ frame(intptr_t* sp, intptr_t* unextended_sp, intptr_t* fp, address pc); -#ifndef AARCH64 frame(intptr_t* sp, intptr_t* fp); -#endif // !AARCH64 void init(intptr_t* sp, intptr_t* fp, address pc); @@ -119,18 +107,11 @@ inline address* sender_pc_addr() const; -#ifdef AARCH64 - // Used by template based interpreter deoptimization - void interpreter_frame_set_stack_top(intptr_t* stack_top); - void interpreter_frame_set_extended_sp(intptr_t* sp); - -#else // expression stack tos if we are nested in a java call intptr_t* interpreter_frame_last_sp() const; // deoptimization support void interpreter_frame_set_last_sp(intptr_t* sp); -#endif // AARCH64 // helper to update a map with callee-saved FP static void update_map_with_saved_link(RegisterMap* map, intptr_t** link_addr); diff --git a/src/hotspot/cpu/arm/frame_arm.inline.hpp b/src/hotspot/cpu/arm/frame_arm.inline.hpp index 6f22cfa25ce..cb2c5e6d91d 100644 --- a/src/hotspot/cpu/arm/frame_arm.inline.hpp +++ b/src/hotspot/cpu/arm/frame_arm.inline.hpp @@ -83,7 +83,6 @@ inline frame::frame(intptr_t* sp, intptr_t* unextended_sp, intptr_t* fp, address } } -#ifndef AARCH64 inline frame::frame(intptr_t* sp, intptr_t* fp) { _sp = sp; @@ -104,7 +103,6 @@ inline frame::frame(intptr_t* sp, intptr_t* fp) { } } -#endif // !AARCH64 // Accessors @@ -148,11 +146,9 @@ inline intptr_t** frame::interpreter_frame_locals_addr() const { return (intptr_t**)addr_at(interpreter_frame_locals_offset); } -#ifndef AARCH64 inline intptr_t* frame::interpreter_frame_last_sp() const { return *(intptr_t**)addr_at(interpreter_frame_last_sp_offset); } -#endif // !AARCH64 inline intptr_t* frame::interpreter_frame_bcp_addr() const { return (intptr_t*)addr_at(interpreter_frame_bcp_offset); @@ -181,12 +177,6 @@ inline oop* frame::interpreter_frame_mirror_addr() const { // top of expression stack inline intptr_t* frame::interpreter_frame_tos_address() const { -#ifdef AARCH64 - intptr_t* stack_top = (intptr_t*)*addr_at(interpreter_frame_stack_top_offset); - assert(stack_top != NULL, "should be stored before call"); - assert(stack_top <= (intptr_t*) interpreter_frame_monitor_end(), "bad tos"); - return stack_top; -#else intptr_t* last_sp = interpreter_frame_last_sp(); if (last_sp == NULL ) { return sp(); @@ -197,7 +187,6 @@ inline intptr_t* frame::interpreter_frame_tos_address() const { assert(last_sp <= (intptr_t*) interpreter_frame_monitor_end(), "bad tos"); return last_sp; } -#endif // AARCH64 } inline oop* frame::interpreter_frame_temp_oop_addr() const { diff --git a/src/hotspot/cpu/arm/gc/g1/g1BarrierSetAssembler_arm.cpp b/src/hotspot/cpu/arm/gc/g1/g1BarrierSetAssembler_arm.cpp index 34b5a6d519a..d695107ea93 100644 --- a/src/hotspot/cpu/arm/gc/g1/g1BarrierSetAssembler_arm.cpp +++ b/src/hotspot/cpu/arm/gc/g1/g1BarrierSetAssembler_arm.cpp @@ -60,27 +60,16 @@ void G1BarrierSetAssembler::gen_write_ref_array_pre_barrier(MacroAssembler* masm BLOCK_COMMENT("PreBarrier"); -#ifdef AARCH64 - callee_saved_regs = align_up(callee_saved_regs, 2); - for (int i = 0; i < callee_saved_regs; i += 2) { - __ raw_push(as_Register(i), as_Register(i+1)); - } -#else RegisterSet saved_regs = RegisterSet(R0, as_Register(callee_saved_regs-1)); __ push(saved_regs | R9ifScratched); -#endif // AARCH64 if (addr != R0) { assert_different_registers(count, R0); __ mov(R0, addr); } -#ifdef AARCH64 - __ zero_extend(R1, count, 32); // G1BarrierSetRuntime::write_ref_array_pre_*_entry takes size_t -#else if (count != R1) { __ mov(R1, count); } -#endif // AARCH64 if (UseCompressedOops) { __ call(CAST_FROM_FN_PTR(address, G1BarrierSetRuntime::write_ref_array_pre_narrow_oop_entry)); @@ -88,13 +77,7 @@ void G1BarrierSetAssembler::gen_write_ref_array_pre_barrier(MacroAssembler* masm __ call(CAST_FROM_FN_PTR(address, G1BarrierSetRuntime::write_ref_array_pre_oop_entry)); } -#ifdef AARCH64 - for (int i = callee_saved_regs - 2; i >= 0; i -= 2) { - __ raw_pop(as_Register(i), as_Register(i+1)); - } -#else __ pop(saved_regs | R9ifScratched); -#endif // AARCH64 } } @@ -106,9 +89,6 @@ void G1BarrierSetAssembler::gen_write_ref_array_post_barrier(MacroAssembler* mas assert_different_registers(count, R0); __ mov(R0, addr); } -#ifdef AARCH64 - __ zero_extend(R1, count, 32); // G1BarrierSetRuntime::write_ref_array_post_entry takes size_t -#else if (count != R1) { __ mov(R1, count); } @@ -120,17 +100,14 @@ void G1BarrierSetAssembler::gen_write_ref_array_post_barrier(MacroAssembler* mas // difficult for this particular call site. __ push(R9); #endif // !R9_IS_SCRATCHED -#endif // !AARCH64 __ call(CAST_FROM_FN_PTR(address, G1BarrierSetRuntime::write_ref_array_post_entry)); -#ifndef AARCH64 #if R9_IS_SCRATCHED __ pop(R9); #endif // !R9_IS_SCRATCHED -#endif // !AARCH64 } // G1 pre-barrier. -// Blows all volatile registers (R0-R3 on 32-bit ARM, R0-R18 on AArch64, Rtemp, LR). +// Blows all volatile registers R0-R3, Rtemp, LR). // If store_addr != noreg, then previous value is loaded from [store_addr]; // in such case store_addr and new_val registers are preserved; // otherwise pre_val register is preserved. @@ -186,20 +163,12 @@ void G1BarrierSetAssembler::g1_write_barrier_pre(MacroAssembler* masm, __ bind(runtime); // save the live input values -#ifdef AARCH64 - if (store_addr != noreg) { - __ raw_push(store_addr, new_val); - } else { - __ raw_push(pre_val, ZR); - } -#else if (store_addr != noreg) { // avoid raw_push to support any ordering of store_addr and new_val __ push(RegisterSet(store_addr) | RegisterSet(new_val)); } else { __ push(pre_val); } -#endif // AARCH64 if (pre_val != R0) { __ mov(R0, pre_val); @@ -208,25 +177,17 @@ void G1BarrierSetAssembler::g1_write_barrier_pre(MacroAssembler* masm, __ call_VM_leaf(CAST_FROM_FN_PTR(address, G1BarrierSetRuntime::write_ref_field_pre_entry), R0, R1); -#ifdef AARCH64 - if (store_addr != noreg) { - __ raw_pop(store_addr, new_val); - } else { - __ raw_pop(pre_val, ZR); - } -#else if (store_addr != noreg) { __ pop(RegisterSet(store_addr) | RegisterSet(new_val)); } else { __ pop(pre_val); } -#endif // AARCH64 __ bind(done); } // G1 post-barrier. -// Blows all volatile registers (R0-R3 on 32-bit ARM, R0-R18 on AArch64, Rtemp, LR). +// Blows all volatile registers R0-R3, Rtemp, LR). void G1BarrierSetAssembler::g1_write_barrier_post(MacroAssembler* masm, Register store_addr, Register new_val, @@ -246,13 +207,8 @@ void G1BarrierSetAssembler::g1_write_barrier_post(MacroAssembler* masm, // Does store cross heap regions? __ eor(tmp1, store_addr, new_val); -#ifdef AARCH64 - __ logical_shift_right(tmp1, tmp1, HeapRegion::LogOfHRGrainBytes); - __ cbz(tmp1, done); -#else __ movs(tmp1, AsmOperand(tmp1, lsr, HeapRegion::LogOfHRGrainBytes)); __ b(done, eq); -#endif // crosses regions, storing NULL? @@ -333,12 +289,8 @@ void G1BarrierSetAssembler::oop_store_at(MacroAssembler* masm, DecoratorSet deco const Register store_addr = obj.base(); if (obj.index() != noreg) { assert (obj.disp() == 0, "index or displacement, not both"); -#ifdef AARCH64 - __ add(store_addr, obj.base(), obj.index(), obj.extend(), obj.shift_imm()); -#else assert(obj.offset_op() == add_offset, "addition is expected"); __ add(store_addr, obj.base(), AsmOperand(obj.index(), obj.shift(), obj.shift_imm())); -#endif // AARCH64 } else if (obj.disp() != 0) { __ add(store_addr, obj.base(), obj.disp()); } @@ -415,16 +367,10 @@ void G1BarrierSetAssembler::generate_c1_pre_barrier_runtime_stub(StubAssembler* __ set_info("g1_pre_barrier_slow_id", false); // save at least the registers that need saving if the runtime is called -#ifdef AARCH64 - __ raw_push(R0, R1); - __ raw_push(R2, R3); - const int nb_saved_regs = 4; -#else // AARCH64 const RegisterSet saved_regs = RegisterSet(R0,R3) | RegisterSet(R12) | RegisterSet(LR); const int nb_saved_regs = 6; assert(nb_saved_regs == saved_regs.size(), "fix nb_saved_regs"); __ push(saved_regs); -#endif // AARCH64 const Register r_pre_val_0 = R0; // must be R0, to be ready for the runtime call const Register r_index_1 = R1; @@ -454,12 +400,7 @@ void G1BarrierSetAssembler::generate_c1_pre_barrier_runtime_stub(StubAssembler* __ bind(done); -#ifdef AARCH64 - __ raw_pop(R2, R3); - __ raw_pop(R0, R1); -#else // AARCH64 __ pop(saved_regs); -#endif // AARCH64 __ ret(); @@ -492,16 +433,10 @@ void G1BarrierSetAssembler::generate_c1_post_barrier_runtime_stub(StubAssembler* AddressLiteral cardtable(ci_card_table_address_as
(), relocInfo::none); // save at least the registers that need saving if the runtime is called -#ifdef AARCH64 - __ raw_push(R0, R1); - __ raw_push(R2, R3); - const int nb_saved_regs = 4; -#else // AARCH64 const RegisterSet saved_regs = RegisterSet(R0,R3) | RegisterSet(R12) | RegisterSet(LR); const int nb_saved_regs = 6; assert(nb_saved_regs == saved_regs.size(), "fix nb_saved_regs"); __ push(saved_regs); -#endif // AARCH64 const Register r_card_addr_0 = R0; // must be R0 for the slow case const Register r_obj_0 = R0; @@ -528,12 +463,7 @@ void G1BarrierSetAssembler::generate_c1_post_barrier_runtime_stub(StubAssembler* __ bind(done); -#ifdef AARCH64 - __ raw_pop(R2, R3); - __ raw_pop(R0, R1); -#else // AARCH64 __ pop(saved_regs); -#endif // AARCH64 __ ret(); diff --git a/src/hotspot/cpu/arm/gc/shared/barrierSetAssembler_arm.cpp b/src/hotspot/cpu/arm/gc/shared/barrierSetAssembler_arm.cpp index ea32a1d1b35..d73364f1310 100644 --- a/src/hotspot/cpu/arm/gc/shared/barrierSetAssembler_arm.cpp +++ b/src/hotspot/cpu/arm/gc/shared/barrierSetAssembler_arm.cpp @@ -37,12 +37,6 @@ void BarrierSetAssembler::load_at(MacroAssembler* masm, DecoratorSet decorators, case T_OBJECT: case T_ARRAY: { if (in_heap) { -#ifdef AARCH64 - if (UseCompressedOops) { - __ ldr_w(dst, src); - __ decode_heap_oop(dst); - } else -#endif // AARCH64 { __ ldr(dst, src); } @@ -59,13 +53,9 @@ void BarrierSetAssembler::load_at(MacroAssembler* masm, DecoratorSet decorators, case T_INT: __ ldr_s32 (dst, src); break; case T_ADDRESS: __ ldr (dst, src); break; case T_LONG: -#ifdef AARCH64 - __ ldr (dst, src); break; -#else assert(dst == noreg, "only to ltos"); __ add (src.index(), src.index(), src.base()); __ ldmia (src.index(), RegisterSet(R0_tos_lo) | RegisterSet(R1_tos_hi)); -#endif // AARCH64 break; #ifdef __SOFTFP__ case T_FLOAT: @@ -102,15 +92,6 @@ void BarrierSetAssembler::store_at(MacroAssembler* masm, DecoratorSet decorators case T_OBJECT: case T_ARRAY: { if (in_heap) { -#ifdef AARCH64 - if (UseCompressedOops) { - assert(!dst.uses(src), "not enough registers"); - if (!is_null) { - __ encode_heap_oop(src); - } - __ str_w(val, obj); - } else -#endif // AARCH64 { __ str(val, obj); } @@ -130,13 +111,9 @@ void BarrierSetAssembler::store_at(MacroAssembler* masm, DecoratorSet decorators case T_INT: __ str (val, obj); break; case T_ADDRESS: __ str (val, obj); break; case T_LONG: -#ifdef AARCH64 - __ str (val, obj); break; -#else // AARCH64 assert(val == noreg, "only tos"); __ add (obj.index(), obj.index(), obj.base()); __ stmia (obj.index(), RegisterSet(R0_tos_lo) | RegisterSet(R1_tos_hi)); -#endif // AARCH64 break; #ifdef __SOFTFP__ case T_FLOAT: @@ -188,7 +165,7 @@ void BarrierSetAssembler::eden_allocate(MacroAssembler* masm, Register obj, Regi assert_different_registers(obj, obj_end, top_addr, heap_end); } - bool load_const = AARCH64_ONLY(false) NOT_AARCH64(VM_Version::supports_movw() ); // TODO-AARCH64 check performance + bool load_const = VM_Version::supports_movw(); if (load_const) { __ mov_address(top_addr, (address)Universe::heap()->top_addr(), symbolic_Relocation::eden_top_reference); } else { @@ -197,13 +174,7 @@ void BarrierSetAssembler::eden_allocate(MacroAssembler* masm, Register obj, Regi // Calculate new heap_top by adding the size of the object Label retry; __ bind(retry); - -#ifdef AARCH64 - __ ldxr(obj, top_addr); -#else __ ldr(obj, Address(top_addr)); -#endif // AARCH64 - __ ldr(heap_end, Address(top_addr, (intptr_t)ch->end_addr() - (intptr_t)ch->top_addr())); __ add_rc(obj_end, obj, size_expression); // Check if obj_end wrapped around, i.e., obj_end < obj. If yes, jump to the slow case. @@ -213,13 +184,8 @@ void BarrierSetAssembler::eden_allocate(MacroAssembler* masm, Register obj, Regi __ cmp(obj_end, heap_end); __ b(slow_case, hi); -#ifdef AARCH64 - __ stxr(heap_end/*scratched*/, obj_end, top_addr); - __ cbnz_w(heap_end, retry); -#else __ atomic_cas_bool(obj, obj_end, top_addr, 0, heap_end/*scratched*/); __ b(retry, ne); -#endif // AARCH64 incr_allocated_bytes(masm, size_expression, tmp1); } @@ -239,11 +205,6 @@ void BarrierSetAssembler::tlab_allocate(MacroAssembler* masm, Register obj, Regi } void BarrierSetAssembler::incr_allocated_bytes(MacroAssembler* masm, RegisterOrConstant size_in_bytes, Register tmp) { -#ifdef AARCH64 - __ ldr(tmp, Address(Rthread, in_bytes(JavaThread::allocated_bytes_offset()))); - __ add_rc(tmp, tmp, size_in_bytes); - __ str(tmp, Address(Rthread, in_bytes(JavaThread::allocated_bytes_offset()))); -#else // Bump total bytes allocated by this thread Label done; @@ -281,5 +242,4 @@ void BarrierSetAssembler::incr_allocated_bytes(MacroAssembler* masm, RegisterOrC // Unborrow the Rthread __ sub(Rthread, Ralloc, in_bytes(JavaThread::allocated_bytes_offset())); -#endif // AARCH64 } diff --git a/src/hotspot/cpu/arm/gc/shared/cardTableBarrierSetAssembler_arm.cpp b/src/hotspot/cpu/arm/gc/shared/cardTableBarrierSetAssembler_arm.cpp index c538561ca5e..50f5b9a4aec 100644 --- a/src/hotspot/cpu/arm/gc/shared/cardTableBarrierSetAssembler_arm.cpp +++ b/src/hotspot/cpu/arm/gc/shared/cardTableBarrierSetAssembler_arm.cpp @@ -119,7 +119,6 @@ void CardTableBarrierSetAssembler::store_check_part1(MacroAssembler* masm, Regis Possible cause is a cache miss (card table base address resides in a rarely accessed area of thread descriptor). */ - // TODO-AARCH64 Investigate if mov_slow is faster than ldr from Rthread on AArch64 __ mov_address(card_table_base, (address)ct->byte_map_base(), symbolic_Relocation::card_table_reference); } @@ -136,12 +135,7 @@ void CardTableBarrierSetAssembler::store_check_part2(MacroAssembler* masm, Regis assert(sizeof(*ct->byte_map_base()) == sizeof(jbyte), "Adjust store check code"); assert(CardTable::dirty_card_val() == 0, "Dirty card value must be 0 due to optimizations."); -#ifdef AARCH64 - add(card_table_base, card_table_base, AsmOperand(obj, lsr, CardTable::card_shift)); - Address card_table_addr(card_table_base); -#else Address card_table_addr(card_table_base, obj, lsr, CardTable::card_shift); -#endif if (UseCondCardMark) { if (ct->scanned_concurrently()) { @@ -164,9 +158,6 @@ void CardTableBarrierSetAssembler::store_check_part2(MacroAssembler* masm, Regis } void CardTableBarrierSetAssembler::set_card(MacroAssembler* masm, Register card_table_base, Address card_table_addr, Register tmp) { -#ifdef AARCH64 - strb(ZR, card_table_addr); -#else CardTableBarrierSet* ctbs = barrier_set_cast(BarrierSet::barrier_set()); CardTable* ct = ctbs->card_table(); if ((((uintptr_t)ct->byte_map_base() & 0xff) == 0)) { @@ -178,5 +169,4 @@ void CardTableBarrierSetAssembler::set_card(MacroAssembler* masm, Register card_ __ mov(tmp, 0); __ strb(tmp, card_table_addr); } -#endif // AARCH64 } diff --git a/src/hotspot/cpu/arm/globalDefinitions_arm.hpp b/src/hotspot/cpu/arm/globalDefinitions_arm.hpp index 0ede3bfac81..07a367c328f 100644 --- a/src/hotspot/cpu/arm/globalDefinitions_arm.hpp +++ b/src/hotspot/cpu/arm/globalDefinitions_arm.hpp @@ -25,19 +25,7 @@ #ifndef CPU_ARM_VM_GLOBALDEFINITIONS_ARM_HPP #define CPU_ARM_VM_GLOBALDEFINITIONS_ARM_HPP -#ifdef AARCH64 -#define AARCH64_ONLY(code) code -#define AARCH64_ONLY_ARG(arg) , arg -#define NOT_AARCH64(code) -#define NOT_AARCH64_ARG(arg) -#else -#define AARCH64_ONLY(code) -#define AARCH64_ONLY_ARG(arg) -#define NOT_AARCH64(code) code -#define NOT_AARCH64_ARG(arg) , arg -#endif - -const int StackAlignmentInBytes = AARCH64_ONLY(16) NOT_AARCH64(8); +const int StackAlignmentInBytes = 8; // Indicates whether the C calling conventions require that // 32-bit integer argument values are extended to 64 bits. @@ -49,24 +37,19 @@ const bool HaveVFP = false; const bool HaveVFP = true; #endif -#if defined(__ARM_PCS_VFP) || defined(AARCH64) +#if defined(__ARM_PCS_VFP) #define __ABI_HARD__ #endif -#if defined(__ARM_ARCH_7A__) || defined(AARCH64) +#if defined(__ARM_ARCH_7A__) #define SUPPORTS_NATIVE_CX8 #endif #define STUBROUTINES_MD_HPP "stubRoutines_arm.hpp" #define INTERP_MASM_MD_HPP "interp_masm_arm.hpp" #define TEMPLATETABLE_MD_HPP "templateTable_arm.hpp" -#ifdef AARCH64 -#define ADGLOBALS_MD_HPP "adfiles/adGlobals_arm_64.hpp" -#define AD_MD_HPP "adfiles/ad_arm_64.hpp" -#else #define ADGLOBALS_MD_HPP "adfiles/adGlobals_arm_32.hpp" #define AD_MD_HPP "adfiles/ad_arm_32.hpp" -#endif #define C1_LIRGENERATOR_MD_HPP "c1_LIRGenerator_arm.hpp" #ifdef TARGET_COMPILER_gcc diff --git a/src/hotspot/cpu/arm/globals_arm.hpp b/src/hotspot/cpu/arm/globals_arm.hpp index eadb8418df6..302339e3f90 100644 --- a/src/hotspot/cpu/arm/globals_arm.hpp +++ b/src/hotspot/cpu/arm/globals_arm.hpp @@ -88,13 +88,5 @@ define_pd_global(bool, ThreadLocalHandshakes, false); notproduct, \ range, \ constraint, \ - writeable) \ - \ - develop(bool, VerifyInterpreterStackTop, false, \ - "Verify interpreter stack top at every stack expansion (AArch64 only)") \ - \ - develop(bool, ZapHighNonSignificantBits, false, \ - "Zap high non-significant bits of values (AArch64 only)") \ - \ - + writeable) #endif // CPU_ARM_VM_GLOBALS_ARM_HPP diff --git a/src/hotspot/cpu/arm/icBuffer_arm.cpp b/src/hotspot/cpu/arm/icBuffer_arm.cpp index b158572c0dd..03a53ec19bb 100644 --- a/src/hotspot/cpu/arm/icBuffer_arm.cpp +++ b/src/hotspot/cpu/arm/icBuffer_arm.cpp @@ -35,7 +35,7 @@ #define __ masm-> int InlineCacheBuffer::ic_stub_code_size() { - return (AARCH64_ONLY(8) NOT_AARCH64(4)) * Assembler::InstructionSize; + return (4 * Assembler::InstructionSize); } void InlineCacheBuffer::assemble_ic_buffer_code(address code_begin, void* cached_value, address entry_point) { diff --git a/src/hotspot/cpu/arm/icache_arm.cpp b/src/hotspot/cpu/arm/icache_arm.cpp index ae163619fdc..7f258ab8b27 100644 --- a/src/hotspot/cpu/arm/icache_arm.cpp +++ b/src/hotspot/cpu/arm/icache_arm.cpp @@ -29,49 +29,12 @@ #define __ _masm-> -#ifdef AARCH64 - -static int icache_flush(address addr, int lines, int magic) { - // TODO-AARCH64 Figure out actual cache line size (mrs Xt, CTR_EL0) - - address p = addr; - for (int i = 0; i < lines; i++, p += ICache::line_size) { - __asm__ volatile( - " dc cvau, %[p]" - : - : [p] "r" (p) - : "memory"); - } - - __asm__ volatile( - " dsb ish" - : : : "memory"); - - p = addr; - for (int i = 0; i < lines; i++, p += ICache::line_size) { - __asm__ volatile( - " ic ivau, %[p]" - : - : [p] "r" (p) - : "memory"); - } - - __asm__ volatile( - " dsb ish\n\t" - " isb\n\t" - : : : "memory"); - - return magic; -} - -#else static int icache_flush(address addr, int lines, int magic) { __builtin___clear_cache(addr, addr + (lines << ICache::log2_line_size)); return magic; } -#endif // AARCH64 void ICacheStubGenerator::generate_icache_flush(ICache::flush_icache_stub_t* flush_icache_stub) { address start = (address)icache_flush; diff --git a/src/hotspot/cpu/arm/interp_masm_arm.cpp b/src/hotspot/cpu/arm/interp_masm_arm.cpp index d65a450bce2..ee21271159e 100644 --- a/src/hotspot/cpu/arm/interp_masm_arm.cpp +++ b/src/hotspot/cpu/arm/interp_masm_arm.cpp @@ -54,7 +54,7 @@ InterpreterMacroAssembler::InterpreterMacroAssembler(CodeBuffer* code) : MacroAs } void InterpreterMacroAssembler::call_VM_helper(Register oop_result, address entry_point, int number_of_arguments, bool check_exceptions) { -#if defined(ASSERT) && !defined(AARCH64) +#ifdef ASSERT // Ensure that last_sp is not filled. { Label L; ldr(Rtemp, Address(FP, frame::interpreter_frame_last_sp_offset * wordSize)); @@ -62,27 +62,15 @@ void InterpreterMacroAssembler::call_VM_helper(Register oop_result, address entr stop("InterpreterMacroAssembler::call_VM_helper: last_sp != NULL"); bind(L); } -#endif // ASSERT && !AARCH64 +#endif // ASSERT // Rbcp must be saved/restored since it may change due to GC. save_bcp(); -#ifdef AARCH64 - check_no_cached_stack_top(Rtemp); - save_stack_top(); - check_extended_sp(Rtemp); - cut_sp_before_call(); -#endif // AARCH64 // super call MacroAssembler::call_VM_helper(oop_result, entry_point, number_of_arguments, check_exceptions); -#ifdef AARCH64 - // Restore SP to extended SP - restore_sp_after_call(Rtemp); - check_stack_top(); - clear_cached_stack_top(); -#endif // AARCH64 // Restore interpreter specific registers. restore_bcp(); @@ -128,10 +116,8 @@ void InterpreterMacroAssembler::load_earlyret_value(TosState state) { const Address tos_addr(thread_state, JvmtiThreadState::earlyret_tos_offset()); const Address oop_addr(thread_state, JvmtiThreadState::earlyret_oop_offset()); const Address val_addr(thread_state, JvmtiThreadState::earlyret_value_offset()); -#ifndef AARCH64 const Address val_addr_hi(thread_state, JvmtiThreadState::earlyret_value_offset() + in_ByteSize(wordSize)); -#endif // !AARCH64 Register zero = zero_register(Rtemp); @@ -141,11 +127,7 @@ void InterpreterMacroAssembler::load_earlyret_value(TosState state) { interp_verify_oop(R0_tos, state, __FILE__, __LINE__); break; -#ifdef AARCH64 - case ltos: ldr(R0_tos, val_addr); break; -#else case ltos: ldr(R1_tos_hi, val_addr_hi); // fall through -#endif // AARCH64 case btos: // fall through case ztos: // fall through case ctos: // fall through @@ -163,9 +145,7 @@ void InterpreterMacroAssembler::load_earlyret_value(TosState state) { } // Clean up tos value in the thread object str(zero, val_addr); -#ifndef AARCH64 str(zero, val_addr_hi); -#endif // !AARCH64 mov(Rtemp, (int) ilgl); str_32(Rtemp, tos_addr); @@ -220,7 +200,6 @@ void InterpreterMacroAssembler::get_index_at_bcp(Register index, int bcp_offset, ldrb(tmp_reg, Address(Rbcp, bcp_offset)); orr(index, tmp_reg, AsmOperand(index, lsl, BitsPerByte)); } else if (index_size == sizeof(u4)) { - // TODO-AARCH64: consider using unaligned access here ldrb(index, Address(Rbcp, bcp_offset+3)); ldrb(tmp_reg, Address(Rbcp, bcp_offset+2)); orr(index, tmp_reg, AsmOperand(index, lsl, BitsPerByte)); @@ -252,7 +231,6 @@ void InterpreterMacroAssembler::get_cache_and_index_at_bcp(Register cache, Regis // convert from field index to ConstantPoolCacheEntry index assert(sizeof(ConstantPoolCacheEntry) == 4*wordSize, "adjust code below"); - // TODO-AARCH64 merge this shift with shift "add(..., Rcache, AsmOperand(Rindex, lsl, LogBytesPerWord))" after this method is called logical_shift_left(index, index, 2); } @@ -261,13 +239,8 @@ void InterpreterMacroAssembler::get_cache_and_index_and_bytecode_at_bcp(Register get_cache_and_index_at_bcp(cache, index, bcp_offset, index_size); // caution index and bytecode can be the same add(bytecode, cache, AsmOperand(index, lsl, LogBytesPerWord)); -#ifdef AARCH64 - add(bytecode, bytecode, (1 + byte_no) + in_bytes(ConstantPoolCache::base_offset() + ConstantPoolCacheEntry::indices_offset())); - ldarb(bytecode, bytecode); -#else ldrb(bytecode, Address(bytecode, (1 + byte_no) + in_bytes(ConstantPoolCache::base_offset() + ConstantPoolCacheEntry::indices_offset()))); TemplateTable::volatile_barrier(MacroAssembler::LoadLoad, noreg, true); -#endif // AARCH64 } // Sets cache. Blows reg_tmp. @@ -365,31 +338,21 @@ void InterpreterMacroAssembler::gen_subtype_check(Register Rsub_klass, ldr(supers_arr, Address(Rsub_klass, Klass::secondary_supers_offset())); ldr_u32(supers_cnt, Address(supers_arr, Array::length_offset_in_bytes())); // Load the array length -#ifdef AARCH64 - cbz(supers_cnt, not_subtype); - add(supers_arr, supers_arr, Array::base_offset_in_bytes()); -#else cmp(supers_cnt, 0); // Skip to the start of array elements and prefetch the first super-klass. ldr(cur_super, Address(supers_arr, Array::base_offset_in_bytes(), pre_indexed), ne); b(not_subtype, eq); -#endif // AARCH64 bind(loop); -#ifdef AARCH64 - ldr(cur_super, Address(supers_arr, wordSize, post_indexed)); -#endif // AARCH64 cmp(cur_super, Rsuper_klass); b(update_cache, eq); subs(supers_cnt, supers_cnt, 1); -#ifndef AARCH64 ldr(cur_super, Address(supers_arr, wordSize, pre_indexed), ne); -#endif // !AARCH64 b(loop, ne); @@ -419,33 +382,18 @@ void InterpreterMacroAssembler::pop_i(Register r) { zap_high_non_significant_bits(r); } -#ifdef AARCH64 -void InterpreterMacroAssembler::pop_l(Register r) { - assert(r != Rstack_top, "unpredictable instruction"); - ldr(r, Address(Rstack_top, 2*wordSize, post_indexed)); -} -#else void InterpreterMacroAssembler::pop_l(Register lo, Register hi) { assert_different_registers(lo, hi); assert(lo < hi, "lo must be < hi"); pop(RegisterSet(lo) | RegisterSet(hi)); } -#endif // AARCH64 void InterpreterMacroAssembler::pop_f(FloatRegister fd) { -#ifdef AARCH64 - ldr_s(fd, Address(Rstack_top, wordSize, post_indexed)); -#else fpops(fd); -#endif // AARCH64 } void InterpreterMacroAssembler::pop_d(FloatRegister fd) { -#ifdef AARCH64 - ldr_d(fd, Address(Rstack_top, 2*wordSize, post_indexed)); -#else fpopd(fd); -#endif // AARCH64 } @@ -458,11 +406,7 @@ void InterpreterMacroAssembler::pop(TosState state) { case ctos: // fall through case stos: // fall through case itos: pop_i(R0_tos); break; -#ifdef AARCH64 - case ltos: pop_l(R0_tos); break; -#else case ltos: pop_l(R0_tos_lo, R1_tos_hi); break; -#endif // AARCH64 #ifdef __SOFTFP__ case ftos: pop_i(R0_tos); break; case dtos: pop_l(R0_tos_lo, R1_tos_hi); break; @@ -488,36 +432,18 @@ void InterpreterMacroAssembler::push_i(Register r) { check_stack_top_on_expansion(); } -#ifdef AARCH64 -void InterpreterMacroAssembler::push_l(Register r) { - assert(r != Rstack_top, "unpredictable instruction"); - stp(r, ZR, Address(Rstack_top, -2*wordSize, pre_indexed)); - check_stack_top_on_expansion(); -} -#else void InterpreterMacroAssembler::push_l(Register lo, Register hi) { assert_different_registers(lo, hi); assert(lo < hi, "lo must be < hi"); push(RegisterSet(lo) | RegisterSet(hi)); } -#endif // AARCH64 void InterpreterMacroAssembler::push_f() { -#ifdef AARCH64 - str_s(S0_tos, Address(Rstack_top, -wordSize, pre_indexed)); - check_stack_top_on_expansion(); -#else fpushs(S0_tos); -#endif // AARCH64 } void InterpreterMacroAssembler::push_d() { -#ifdef AARCH64 - str_d(D0_tos, Address(Rstack_top, -2*wordSize, pre_indexed)); - check_stack_top_on_expansion(); -#else fpushd(D0_tos); -#endif // AARCH64 } // Transition state -> vtos. Blows Rtemp. @@ -530,11 +456,7 @@ void InterpreterMacroAssembler::push(TosState state) { case ctos: // fall through case stos: // fall through case itos: push_i(R0_tos); break; -#ifdef AARCH64 - case ltos: push_l(R0_tos); break; -#else case ltos: push_l(R0_tos_lo, R1_tos_hi); break; -#endif // AARCH64 #ifdef __SOFTFP__ case ftos: push_i(R0_tos); break; case dtos: push_l(R0_tos_lo, R1_tos_hi); break; @@ -548,7 +470,6 @@ void InterpreterMacroAssembler::push(TosState state) { } -#ifndef AARCH64 // Converts return value in R0/R1 (interpreter calling conventions) to TOS cached value. void InterpreterMacroAssembler::convert_retval_to_tos(TosState state) { @@ -576,7 +497,6 @@ void InterpreterMacroAssembler::convert_tos_to_retval(TosState state) { #endif // !__SOFTFP__ && !__ABI_HARD__ } -#endif // !AARCH64 // Helpers for swap and dup @@ -590,20 +510,12 @@ void InterpreterMacroAssembler::store_ptr(int n, Register val) { void InterpreterMacroAssembler::prepare_to_jump_from_interpreted() { -#ifdef AARCH64 - check_no_cached_stack_top(Rtemp); - save_stack_top(); - cut_sp_before_call(); - mov(Rparams, Rstack_top); -#endif // AARCH64 // set sender sp mov(Rsender_sp, SP); -#ifndef AARCH64 // record last_sp str(Rsender_sp, Address(FP, frame::interpreter_frame_last_sp_offset * wordSize)); -#endif // !AARCH64 } // Jump to from_interpreted entry of a call unless single stepping is possible @@ -619,19 +531,8 @@ void InterpreterMacroAssembler::jump_from_interpreted(Register method) { // interp_only_mode if these events CAN be enabled. ldr_s32(Rtemp, Address(Rthread, JavaThread::interp_only_mode_offset())); -#ifdef AARCH64 - { - Label not_interp_only_mode; - - cbz(Rtemp, not_interp_only_mode); - indirect_jump(Address(method, Method::interpreter_entry_offset()), Rtemp); - - bind(not_interp_only_mode); - } -#else cmp(Rtemp, 0); ldr(PC, Address(method, Method::interpreter_entry_offset()), ne); -#endif // AARCH64 } indirect_jump(Address(method, Method::from_interpreted_offset()), Rtemp); @@ -658,12 +559,7 @@ void InterpreterMacroAssembler::dispatch_base(TosState state, bool verifyoop) { if (VerifyActivationFrameSize) { Label L; -#ifdef AARCH64 - mov(Rtemp, SP); - sub(Rtemp, FP, Rtemp); -#else sub(Rtemp, FP, SP); -#endif // AARCH64 int min_frame_size = (frame::link_offset - frame::interpreter_frame_initial_sp_offset) * wordSize; cmp(Rtemp, min_frame_size); b(L, ge); @@ -692,16 +588,10 @@ void InterpreterMacroAssembler::dispatch_base(TosState state, if (state == vtos) { indirect_jump(Address::indexed_ptr(RdispatchTable, R3_bytecode), Rtemp); } else { -#ifdef AARCH64 - sub(Rtemp, R3_bytecode, (Interpreter::distance_from_dispatch_table(vtos) - - Interpreter::distance_from_dispatch_table(state))); - indirect_jump(Address::indexed_ptr(RdispatchTable, Rtemp), Rtemp); -#else // on 32-bit ARM this method is faster than the one above. sub(Rtemp, RdispatchTable, (Interpreter::distance_from_dispatch_table(vtos) - Interpreter::distance_from_dispatch_table(state)) * wordSize); indirect_jump(Address::indexed_ptr(Rtemp, R3_bytecode), Rtemp); -#endif } } else { assert(table_mode == DispatchNormal, "invalid dispatch table mode"); @@ -897,25 +787,18 @@ void InterpreterMacroAssembler::remove_activation(TosState state, Register ret_a // points to word before bottom of monitor block cmp(Rcur, Rbottom); // check if there are no monitors -#ifndef AARCH64 ldr(Rcur_obj, Address(Rcur, BasicObjectLock::obj_offset_in_bytes()), ne); // prefetch monitor's object -#endif // !AARCH64 b(no_unlock, eq); bind(loop); -#ifdef AARCH64 - ldr(Rcur_obj, Address(Rcur, BasicObjectLock::obj_offset_in_bytes())); -#endif // AARCH64 // check if current entry is used cbnz(Rcur_obj, exception_monitor_is_still_locked); add(Rcur, Rcur, entry_size); // otherwise advance to next entry cmp(Rcur, Rbottom); // check if bottom reached -#ifndef AARCH64 ldr(Rcur_obj, Address(Rcur, BasicObjectLock::obj_offset_in_bytes()), ne); // prefetch monitor's object -#endif // !AARCH64 b(loop, ne); // if not at bottom then check this entry } @@ -929,15 +812,9 @@ void InterpreterMacroAssembler::remove_activation(TosState state, Register ret_a } // remove activation -#ifdef AARCH64 - ldr(Rtemp, Address(FP, frame::interpreter_frame_sender_sp_offset * wordSize)); - ldp(FP, LR, Address(FP)); - mov(SP, Rtemp); -#else mov(Rtemp, FP); ldmia(FP, RegisterSet(FP) | RegisterSet(LR)); ldr(SP, Address(Rtemp, frame::interpreter_frame_sender_sp_offset * wordSize)); -#endif if (ret_addr != LR) { mov(ret_addr, LR); @@ -965,7 +842,7 @@ void InterpreterMacroAssembler::set_do_not_unlock_if_synchronized(bool flag, Reg // // Argument: R1 : Points to BasicObjectLock to be used for locking. // Must be initialized with object to lock. -// Blows volatile registers (R0-R3 on 32-bit ARM, R0-R18 on AArch64), Rtemp, LR. Calls VM. +// Blows volatile registers R0-R3, Rtemp, LR. Calls VM. void InterpreterMacroAssembler::lock_object(Register Rlock) { assert(Rlock == R1, "the second argument"); @@ -991,15 +868,6 @@ void InterpreterMacroAssembler::lock_object(Register Rlock) { biased_locking_enter(Robj, Rmark/*scratched*/, R0, false, Rtemp, done, slow_case); } -#ifdef AARCH64 - assert(oopDesc::mark_offset_in_bytes() == 0, "must be"); - ldr(Rmark, Robj); - - // Test if object is already locked - assert(markOopDesc::unlocked_value == 1, "adjust this code"); - tbz(Rmark, exact_log2(markOopDesc::unlocked_value), already_locked); - -#else // AARCH64 // On MP platforms the next load could return a 'stale' value if the memory location has been modified by another thread. // That would be acceptable as ether CAS or slow case path is taken in that case. @@ -1013,7 +881,6 @@ void InterpreterMacroAssembler::lock_object(Register Rlock) { tst(Rmark, markOopDesc::unlocked_value); b(already_locked, eq); -#endif // !AARCH64 // Save old object->mark() into BasicLock's displaced header str(Rmark, Address(Rlock, mark_offset)); @@ -1059,19 +926,6 @@ void InterpreterMacroAssembler::lock_object(Register Rlock) { // conditions into a single test: // => ((mark - SP) & (3 - os::pagesize())) == 0 -#ifdef AARCH64 - // Use the single check since the immediate is OK for AARCH64 - sub(R0, Rmark, Rstack_top); - intptr_t mask = ((intptr_t)3) - ((intptr_t)os::vm_page_size()); - Assembler::LogicalImmediate imm(mask, false); - ands(R0, R0, imm); - - // For recursive case store 0 into lock record. - // It is harmless to store it unconditionally as lock record contains some garbage - // value in its _displaced_header field by this moment. - str(ZR, Address(Rlock, mark_offset)); - -#else // AARCH64 // (3 - os::pagesize()) cannot be encoded as an ARM immediate operand. // Check independently the low bits and the distance to SP. // -1- test low 2 bits @@ -1082,7 +936,6 @@ void InterpreterMacroAssembler::lock_object(Register Rlock) { // If still 'eq' then recursive locking OK: store 0 into lock record str(R0, Address(Rlock, mark_offset), eq); -#endif // AARCH64 #ifndef PRODUCT if (PrintBiasedLockingStatistics) { @@ -1106,7 +959,7 @@ void InterpreterMacroAssembler::lock_object(Register Rlock) { // // Argument: R1: Points to BasicObjectLock structure for lock // Throw an IllegalMonitorException if object is not locked by current thread -// Blows volatile registers (R0-R3 on 32-bit ARM, R0-R18 on AArch64), Rtemp, LR. Calls VM. +// Blows volatile registers R0-R3, Rtemp, LR. Calls VM. void InterpreterMacroAssembler::unlock_object(Register Rlock) { assert(Rlock == R1, "the second argument"); @@ -1168,7 +1021,7 @@ void InterpreterMacroAssembler::test_method_data_pointer(Register mdp, Label& ze // Set the method data pointer for the current bcp. -// Blows volatile registers (R0-R3 on 32-bit ARM, R0-R18 on AArch64), Rtemp, LR. +// Blows volatile registers R0-R3, Rtemp, LR. void InterpreterMacroAssembler::set_method_data_pointer_for_bcp() { assert(ProfileInterpreter, "must be profiling interpreter"); Label set_mdp; @@ -1265,22 +1118,12 @@ void InterpreterMacroAssembler::increment_mdp_data_at(Address data, // Decrement the register. Set condition codes. subs(bumped_count, bumped_count, DataLayout::counter_increment); // Avoid overflow. -#ifdef AARCH64 - assert(DataLayout::counter_increment == 1, "required for cinc"); - cinc(bumped_count, bumped_count, pl); -#else add(bumped_count, bumped_count, DataLayout::counter_increment, pl); -#endif // AARCH64 } else { // Increment the register. Set condition codes. adds(bumped_count, bumped_count, DataLayout::counter_increment); // Avoid overflow. -#ifdef AARCH64 - assert(DataLayout::counter_increment == 1, "required for cinv"); - cinv(bumped_count, bumped_count, mi); // inverts 0x80..00 back to 0x7f..ff -#else sub(bumped_count, bumped_count, DataLayout::counter_increment, mi); -#endif // AARCH64 } str(bumped_count, data); } @@ -1328,7 +1171,7 @@ void InterpreterMacroAssembler::update_mdp_by_constant(Register mdp_in, int cons } -// Blows volatile registers (R0-R3 on 32-bit ARM, R0-R18 on AArch64, Rtemp, LR). +// Blows volatile registers R0-R3, Rtemp, LR). void InterpreterMacroAssembler::update_mdp_for_ret(Register return_bci) { assert(ProfileInterpreter, "must be profiling interpreter"); assert_different_registers(return_bci, R0, R1, R2, R3, Rtemp); @@ -1542,7 +1385,7 @@ void InterpreterMacroAssembler::record_klass_in_profile(Register receiver, bind (done); } -// Sets mdp, blows volatile registers (R0-R3 on 32-bit ARM, R0-R18 on AArch64, Rtemp, LR). +// Sets mdp, blows volatile registers R0-R3, Rtemp, LR). void InterpreterMacroAssembler::profile_ret(Register mdp, Register return_bci) { assert_different_registers(mdp, return_bci, Rtemp, R0, R1, R2, R3); @@ -1704,9 +1547,6 @@ void InterpreterMacroAssembler::profile_switch_case(Register mdp, Register index void InterpreterMacroAssembler::byteswap_u32(Register r, Register rtmp1, Register rtmp2) { -#ifdef AARCH64 - rev_w(r, r); -#else if (VM_Version::supports_rev()) { rev(r, r); } else { @@ -1715,7 +1555,6 @@ void InterpreterMacroAssembler::byteswap_u32(Register r, Register rtmp1, Registe andr(rtmp1, rtmp2, AsmOperand(rtmp1, lsr, 8)); eor(r, rtmp1, AsmOperand(r, ror, 8)); } -#endif // AARCH64 } @@ -1723,7 +1562,7 @@ void InterpreterMacroAssembler::inc_global_counter(address address_of_counter, i const intx addr = (intx) (address_of_counter + offset); assert ((addr & 0x3) == 0, "address of counter should be aligned"); - const intx offset_mask = right_n_bits(AARCH64_ONLY(12 + 2) NOT_AARCH64(12)); + const intx offset_mask = right_n_bits(12); const address base = (address) (addr & ~offset_mask); const int offs = (int) (addr & offset_mask); @@ -1736,14 +1575,7 @@ void InterpreterMacroAssembler::inc_global_counter(address address_of_counter, i if (avoid_overflow) { adds_32(val, val, 1); -#ifdef AARCH64 - Label L; - b(L, mi); - str_32(val, Address(addr_base, offs)); - bind(L); -#else str(val, Address(addr_base, offs), pl); -#endif // AARCH64 } else { add_32(val, val, 1); str_32(val, Address(addr_base, offs)); @@ -1823,17 +1655,9 @@ void InterpreterMacroAssembler::notify_method_exit( if (native) { // For c++ and template interpreter push both result registers on the // stack in native, we don't know the state. - // On AArch64 result registers are stored into the frame at known locations. // See frame::interpreter_frame_result for code that gets the result values from here. assert(result_lo != noreg, "result registers should be defined"); -#ifdef AARCH64 - assert(result_hi == noreg, "result_hi is not used on AArch64"); - assert(result_fp != fnoreg, "FP result register must be defined"); - - str_d(result_fp, Address(FP, frame::interpreter_frame_fp_saved_result_offset * wordSize)); - str(result_lo, Address(FP, frame::interpreter_frame_gp_saved_result_offset * wordSize)); -#else assert(result_hi != noreg, "result registers should be defined"); #ifdef __ABI_HARD__ @@ -1843,20 +1667,14 @@ void InterpreterMacroAssembler::notify_method_exit( #endif // __ABI_HARD__ push(RegisterSet(result_lo) | RegisterSet(result_hi)); -#endif // AARCH64 call_VM(noreg, CAST_FROM_FN_PTR(address, InterpreterRuntime::post_method_exit)); -#ifdef AARCH64 - ldr_d(result_fp, Address(FP, frame::interpreter_frame_fp_saved_result_offset * wordSize)); - ldr(result_lo, Address(FP, frame::interpreter_frame_gp_saved_result_offset * wordSize)); -#else pop(RegisterSet(result_lo) | RegisterSet(result_hi)); #ifdef __ABI_HARD__ fldd(result_fp, Address(SP)); add(SP, SP, 2 * wordSize); #endif // __ABI_HARD__ -#endif // AARCH64 } else { // For the template interpreter, the value on tos is the size of the @@ -1932,13 +1750,8 @@ void InterpreterMacroAssembler::increment_mask_and_jump(Address counter_addr, add(scratch, scratch, increment); str_32(scratch, counter_addr); -#ifdef AARCH64 - ldr_u32(scratch2, mask_addr); - ands_w(ZR, scratch, scratch2); -#else ldr(scratch2, mask_addr); andrs(scratch, scratch, scratch2); -#endif // AARCH64 b(*where, cond); } @@ -1959,26 +1772,15 @@ void InterpreterMacroAssembler::get_method_counters(Register method, // Save and restore in use caller-saved registers since they will be trashed by call_VM assert(reg1 != noreg, "must specify reg1"); assert(reg2 != noreg, "must specify reg2"); -#ifdef AARCH64 - assert(reg3 != noreg, "must specify reg3"); - stp(reg1, reg2, Address(Rstack_top, -2*wordSize, pre_indexed)); - stp(reg3, ZR, Address(Rstack_top, -2*wordSize, pre_indexed)); -#else assert(reg3 == noreg, "must not specify reg3"); push(RegisterSet(reg1) | RegisterSet(reg2)); -#endif } mov(R1, method); call_VM(noreg, CAST_FROM_FN_PTR(address, InterpreterRuntime::build_method_counters), R1); if (saveRegs) { -#ifdef AARCH64 - ldp(reg3, ZR, Address(Rstack_top, 2*wordSize, post_indexed)); - ldp(reg1, reg2, Address(Rstack_top, 2*wordSize, post_indexed)); -#else pop(RegisterSet(reg1) | RegisterSet(reg2)); -#endif } ldr(Rcounters, method_counters); diff --git a/src/hotspot/cpu/arm/interp_masm_arm.hpp b/src/hotspot/cpu/arm/interp_masm_arm.hpp index 70d694ae494..3b72f29f5fc 100644 --- a/src/hotspot/cpu/arm/interp_masm_arm.hpp +++ b/src/hotspot/cpu/arm/interp_masm_arm.hpp @@ -63,48 +63,12 @@ class InterpreterMacroAssembler: public MacroAssembler { virtual void check_and_handle_earlyret(); // Interpreter-specific registers -#if defined(AARCH64) && defined(ASSERT) - -#define check_stack_top() _check_stack_top("invalid Rstack_top at " __FILE__ ":" XSTR(__LINE__)) -#define check_stack_top_on_expansion() _check_stack_top("invalid Rstack_top at " __FILE__ ":" XSTR(__LINE__), VerifyInterpreterStackTop) -#define check_extended_sp(tmp) _check_extended_sp(tmp, "SP does not match extended SP in frame at " __FILE__ ":" XSTR(__LINE__)) -#define check_no_cached_stack_top(tmp) _check_no_cached_stack_top(tmp, "stack_top is already cached in frame at " __FILE__ ":" XSTR(__LINE__)) - - void _check_stack_top(const char* msg, bool enabled = true) { - if (enabled) { - Label L; - cmp(SP, Rstack_top); - b(L, ls); - stop(msg); - bind(L); - } - } - - void _check_extended_sp(Register tmp, const char* msg) { - Label L; - ldr(tmp, Address(FP, frame::interpreter_frame_extended_sp_offset * wordSize)); - cmp(SP, tmp); - b(L, eq); - stop(msg); - bind(L); - } - - void _check_no_cached_stack_top(Register tmp, const char* msg) { - Label L; - ldr(tmp, Address(FP, frame::interpreter_frame_stack_top_offset * wordSize)); - cbz(tmp, L); - stop(msg); - bind(L); - } - -#else inline void check_stack_top() {} inline void check_stack_top_on_expansion() {} inline void check_extended_sp(Register tmp) {} inline void check_no_cached_stack_top(Register tmp) {} -#endif // AARCH64 && ASSERT void save_bcp() { str(Rbcp, Address(FP, frame::interpreter_frame_bcp_offset * wordSize)); } void restore_bcp() { ldr(Rbcp, Address(FP, frame::interpreter_frame_bcp_offset * wordSize)); } @@ -112,13 +76,6 @@ class InterpreterMacroAssembler: public MacroAssembler { void restore_method() { ldr(Rmethod, Address(FP, frame::interpreter_frame_method_offset * wordSize)); } void restore_dispatch(); -#ifdef AARCH64 - void save_stack_top() { check_stack_top(); str(Rstack_top, Address(FP, frame::interpreter_frame_stack_top_offset * wordSize)); } - void clear_cached_stack_top() { str(ZR, Address(FP, frame::interpreter_frame_stack_top_offset * wordSize)); } - void restore_stack_top() { ldr(Rstack_top, Address(FP, frame::interpreter_frame_stack_top_offset * wordSize)); clear_cached_stack_top(); check_stack_top(); } - void cut_sp_before_call() { align_reg(SP, Rstack_top, StackAlignmentInBytes); } - void restore_sp_after_call(Register tmp) { ldr(tmp, Address(FP, frame::interpreter_frame_extended_sp_offset * wordSize)); mov(SP, tmp); } -#endif // Helpers for runtime call arguments/results void get_const(Register reg) { ldr(reg, Address(Rmethod, Method::const_offset())); } @@ -145,21 +102,13 @@ class InterpreterMacroAssembler: public MacroAssembler { void pop_ptr(Register r); void pop_i(Register r = R0_tos); -#ifdef AARCH64 - void pop_l(Register r = R0_tos); -#else void pop_l(Register lo = R0_tos_lo, Register hi = R1_tos_hi); -#endif void pop_f(FloatRegister fd); void pop_d(FloatRegister fd); void push_ptr(Register r); void push_i(Register r = R0_tos); -#ifdef AARCH64 - void push_l(Register r = R0_tos); -#else void push_l(Register lo = R0_tos_lo, Register hi = R1_tos_hi); -#endif void push_f(); void push_d(); @@ -168,7 +117,6 @@ class InterpreterMacroAssembler: public MacroAssembler { // Transition state -> vtos. Blows Rtemp. void push(TosState state); -#ifndef AARCH64 // The following methods are overridden to allow overloaded calls to // MacroAssembler::push/pop(Register) // MacroAssembler::push/pop(RegisterSet) @@ -183,7 +131,6 @@ class InterpreterMacroAssembler: public MacroAssembler { void convert_retval_to_tos(TosState state); // Converts TOS cached value to return value in R0/R1 (according to interpreter calling conventions). void convert_tos_to_retval(TosState state); -#endif // JVMTI ForceEarlyReturn support void load_earlyret_value(TosState state); @@ -194,12 +141,8 @@ class InterpreterMacroAssembler: public MacroAssembler { void empty_expression_stack() { ldr(Rstack_top, Address(FP, frame::interpreter_frame_monitor_block_top_offset * wordSize)); check_stack_top(); -#ifdef AARCH64 - clear_cached_stack_top(); -#else // NULL last_sp until next java call str(zero_register(Rtemp), Address(FP, frame::interpreter_frame_last_sp_offset * wordSize)); -#endif // AARCH64 } // Helpers for swap and dup diff --git a/src/hotspot/cpu/arm/interpreterRT_arm.cpp b/src/hotspot/cpu/arm/interpreterRT_arm.cpp index 47c0227e8e0..4b582f64795 100644 --- a/src/hotspot/cpu/arm/interpreterRT_arm.cpp +++ b/src/hotspot/cpu/arm/interpreterRT_arm.cpp @@ -44,13 +44,9 @@ InterpreterRuntime::SignatureHandlerGenerator::SignatureHandlerGenerator( _abi_offset = 0; _ireg = is_static() ? 2 : 1; #ifdef __ABI_HARD__ -#ifdef AARCH64 - _freg = 0; -#else _fp_slot = 0; _single_fpr_slot = 0; #endif -#endif } #ifdef SHARING_FAST_NATIVE_FINGERPRINTS @@ -126,17 +122,6 @@ void InterpreterRuntime::SignatureHandlerGenerator::pass_int() { } void InterpreterRuntime::SignatureHandlerGenerator::pass_long() { -#ifdef AARCH64 - if (_ireg < GPR_PARAMS) { - Register dst = as_Register(_ireg); - __ ldr(dst, Address(Rlocals, Interpreter::local_offset_in_bytes(offset() + 1))); - _ireg++; - } else { - __ ldr(Rtemp, Address(Rlocals, Interpreter::local_offset_in_bytes(offset() + 1))); - __ str(Rtemp, Address(SP, _abi_offset * wordSize)); - _abi_offset++; - } -#else if (_ireg <= 2) { #if (ALIGN_WIDE_ARGUMENTS == 1) if ((_ireg & 1) != 0) { @@ -170,24 +155,9 @@ void InterpreterRuntime::SignatureHandlerGenerator::pass_long() { _abi_offset += 2; _ireg = 4; } -#endif // AARCH64 } void InterpreterRuntime::SignatureHandlerGenerator::pass_object() { -#ifdef AARCH64 - __ ldr(Rtemp, Address(Rlocals, Interpreter::local_offset_in_bytes(offset()))); - __ cmp(Rtemp, 0); - __ sub(Rtemp, Rlocals, -Interpreter::local_offset_in_bytes(offset())); - if (_ireg < GPR_PARAMS) { - Register dst = as_Register(_ireg); - __ csel(dst, ZR, Rtemp, eq); - _ireg++; - } else { - __ csel(Rtemp, ZR, Rtemp, eq); - __ str(Rtemp, Address(SP, _abi_offset * wordSize)); - _abi_offset++; - } -#else if (_ireg < 4) { Register dst = as_Register(_ireg); __ ldr(dst, Address(Rlocals, Interpreter::local_offset_in_bytes(offset()))); @@ -201,7 +171,6 @@ void InterpreterRuntime::SignatureHandlerGenerator::pass_object() { __ str(Rtemp, Address(SP, _abi_offset * wordSize)); _abi_offset++; } -#endif // AARCH64 } #ifndef __ABI_HARD__ @@ -220,17 +189,6 @@ void InterpreterRuntime::SignatureHandlerGenerator::pass_float() { #else #ifndef __SOFTFP__ void InterpreterRuntime::SignatureHandlerGenerator::pass_float() { -#ifdef AARCH64 - if (_freg < FPR_PARAMS) { - FloatRegister dst = as_FloatRegister(_freg); - __ ldr_s(dst, Address(Rlocals, Interpreter::local_offset_in_bytes(offset()))); - _freg++; - } else { - __ ldr_u32(Rtemp, Address(Rlocals, Interpreter::local_offset_in_bytes(offset()))); - __ str_32(Rtemp, Address(SP, _abi_offset * wordSize)); - _abi_offset++; - } -#else if((_fp_slot < 16) || (_single_fpr_slot & 1)) { if ((_single_fpr_slot & 1) == 0) { _single_fpr_slot = _fp_slot; @@ -243,21 +201,9 @@ void InterpreterRuntime::SignatureHandlerGenerator::pass_float() { __ str(Rtemp, Address(SP, _abi_offset * wordSize)); _abi_offset++; } -#endif // AARCH64 } void InterpreterRuntime::SignatureHandlerGenerator::pass_double() { -#ifdef AARCH64 - if (_freg < FPR_PARAMS) { - FloatRegister dst = as_FloatRegister(_freg); - __ ldr_d(dst, Address(Rlocals, Interpreter::local_offset_in_bytes(offset() + 1))); - _freg++; - } else { - __ ldr(Rtemp, Address(Rlocals, Interpreter::local_offset_in_bytes(offset() + 1))); - __ str(Rtemp, Address(SP, _abi_offset * wordSize)); - _abi_offset++; - } -#else if(_fp_slot <= 14) { __ fldd(as_FloatRegister(_fp_slot), Address(Rlocals, Interpreter::local_offset_in_bytes(offset()+1))); _fp_slot += 2; @@ -269,7 +215,6 @@ void InterpreterRuntime::SignatureHandlerGenerator::pass_double() { _abi_offset += 2; _single_fpr_slot = 16; } -#endif // AARCH64 } #endif // __SOFTFP__ #endif // __ABI_HARD__ @@ -281,14 +226,10 @@ void InterpreterRuntime::SignatureHandlerGenerator::generate(uint64_t fingerprin address result_handler = Interpreter::result_handler(result_type); -#ifdef AARCH64 - __ mov_slow(R0, (address)result_handler); -#else // Check that result handlers are not real handler on ARM (0 or -1). // This ensures the signature handlers do not need symbolic information. assert((result_handler == NULL)||(result_handler==(address)0xffffffff),""); __ mov_slow(R0, (intptr_t)result_handler); -#endif __ ret(); } @@ -339,9 +280,7 @@ class SlowSignatureHandler: public NativeSignatureIterator { intptr_t* _toGP; int _last_gp; int _last_fp; -#ifndef AARCH64 int _last_single_fp; -#endif // !AARCH64 virtual void pass_int() { if(_last_gp < GPR_PARAMS) { @@ -353,13 +292,6 @@ class SlowSignatureHandler: public NativeSignatureIterator { } virtual void pass_long() { -#ifdef AARCH64 - if(_last_gp < GPR_PARAMS) { - _toGP[_last_gp++] = *(jlong *)(_from+Interpreter::local_offset_in_bytes(1)); - } else { - *_to++ = *(jlong *)(_from+Interpreter::local_offset_in_bytes(1)); - } -#else assert(ALIGN_WIDE_ARGUMENTS == 1, "ABI_HARD not supported with unaligned wide arguments"); if (_last_gp <= 2) { if(_last_gp & 1) _last_gp++; @@ -375,7 +307,6 @@ class SlowSignatureHandler: public NativeSignatureIterator { _to += 2; _last_gp = 4; } -#endif // AARCH64 _from -= 2*Interpreter::stackElementSize; } @@ -390,13 +321,6 @@ class SlowSignatureHandler: public NativeSignatureIterator { } virtual void pass_float() { -#ifdef AARCH64 - if(_last_fp < FPR_PARAMS) { - _toFP[_last_fp++] = *(jint *)(_from+Interpreter::local_offset_in_bytes(0)); - } else { - *_to++ = *(jint *)(_from+Interpreter::local_offset_in_bytes(0)); - } -#else if((_last_fp < 16) || (_last_single_fp & 1)) { if ((_last_single_fp & 1) == 0) { _last_single_fp = _last_fp; @@ -407,18 +331,10 @@ class SlowSignatureHandler: public NativeSignatureIterator { } else { *_to++ = *(jint *)(_from+Interpreter::local_offset_in_bytes(0)); } -#endif // AARCH64 _from -= Interpreter::stackElementSize; } virtual void pass_double() { -#ifdef AARCH64 - if(_last_fp < FPR_PARAMS) { - _toFP[_last_fp++] = *(intptr_t*)(_from+Interpreter::local_offset_in_bytes(1)); - } else { - *_to++ = *(intptr_t*)(_from+Interpreter::local_offset_in_bytes(1)); - } -#else assert(ALIGN_WIDE_ARGUMENTS == 1, "ABI_HARD not supported with unaligned wide arguments"); if(_last_fp <= 14) { _toFP[_last_fp++] = *(intptr_t*)(_from+Interpreter::local_offset_in_bytes(1)); @@ -432,7 +348,6 @@ class SlowSignatureHandler: public NativeSignatureIterator { _to += 2; _last_single_fp = 16; } -#endif // AARCH64 _from -= 2*Interpreter::stackElementSize; } @@ -446,12 +361,10 @@ class SlowSignatureHandler: public NativeSignatureIterator { #ifdef __ABI_HARD__ _toGP = to; _toFP = _toGP + GPR_PARAMS; - _to = _toFP + AARCH64_ONLY(FPR_PARAMS) NOT_AARCH64(8*2); + _to = _toFP + (8*2); _last_gp = (is_static() ? 2 : 1); _last_fp = 0; -#ifndef AARCH64 _last_single_fp = 0; -#endif // !AARCH64 #else _to = to + (is_static() ? 2 : 1); #endif // __ABI_HARD__ diff --git a/src/hotspot/cpu/arm/interpreterRT_arm.hpp b/src/hotspot/cpu/arm/interpreterRT_arm.hpp index 0c04a0c25cc..fc75c79bb29 100644 --- a/src/hotspot/cpu/arm/interpreterRT_arm.hpp +++ b/src/hotspot/cpu/arm/interpreterRT_arm.hpp @@ -34,12 +34,8 @@ class SignatureHandlerGenerator: public NativeSignatureIterator { int _ireg; #ifdef __ABI_HARD__ -#ifdef AARCH64 - int _freg; -#else int _fp_slot; // number of FPR's with arguments loaded int _single_fpr_slot; -#endif #endif void move(int from_offset, int to_offset); @@ -60,10 +56,8 @@ class SignatureHandlerGenerator: public NativeSignatureIterator { void generate(uint64_t fingerprint); }; -#ifndef AARCH64 // ARM provides a normalized fingerprint for native calls (to increase // sharing). See normalize_fast_native_fingerprint #define SHARING_FAST_NATIVE_FINGERPRINTS -#endif #endif // CPU_ARM_VM_INTERPRETERRT_ARM_HPP diff --git a/src/hotspot/cpu/arm/jniFastGetField_arm.cpp b/src/hotspot/cpu/arm/jniFastGetField_arm.cpp index 43427520b20..72384428d15 100644 --- a/src/hotspot/cpu/arm/jniFastGetField_arm.cpp +++ b/src/hotspot/cpu/arm/jniFastGetField_arm.cpp @@ -78,26 +78,19 @@ address JNI_FastGetField::generate_fast_get_int_field0(BasicType type) { // R1 - object handle // R2 - jfieldID - const Register Rsafepoint_counter_addr = AARCH64_ONLY(R4) NOT_AARCH64(R3); - const Register Robj = AARCH64_ONLY(R5) NOT_AARCH64(R1); - const Register Rres = AARCH64_ONLY(R6) NOT_AARCH64(R0); -#ifndef AARCH64 + const Register Rsafepoint_counter_addr = R3; + const Register Robj = R1; + const Register Rres = R0; const Register Rres_hi = R1; -#endif // !AARCH64 const Register Rsafept_cnt = Rtemp; const Register Rsafept_cnt2 = Rsafepoint_counter_addr; - const Register Rtmp1 = AARCH64_ONLY(R7) NOT_AARCH64(R3); // same as Rsafepoint_counter_addr on 32-bit ARM - const Register Rtmp2 = AARCH64_ONLY(R8) NOT_AARCH64(R2); // same as jfieldID on 32-bit ARM + const Register Rtmp1 = R3; // same as Rsafepoint_counter_addr + const Register Rtmp2 = R2; // same as jfieldID -#ifdef AARCH64 - assert_different_registers(Rsafepoint_counter_addr, Rsafept_cnt, Robj, Rres, Rtmp1, Rtmp2, R0, R1, R2, LR); - assert_different_registers(Rsafept_cnt2, Rsafept_cnt, Rres, R0, R1, R2, LR); -#else assert_different_registers(Rsafepoint_counter_addr, Rsafept_cnt, Robj, Rres, LR); assert_different_registers(Rsafept_cnt, R1, R2, Rtmp1, LR); assert_different_registers(Rsafepoint_counter_addr, Rsafept_cnt, Rres, Rres_hi, Rtmp2, LR); assert_different_registers(Rsafept_cnt2, Rsafept_cnt, Rres, Rres_hi, LR); -#endif // AARCH64 address fast_entry; @@ -112,29 +105,17 @@ address JNI_FastGetField::generate_fast_get_int_field0(BasicType type) { Label slow_case; __ ldr_literal(Rsafepoint_counter_addr, safepoint_counter_addr); -#ifndef AARCH64 __ push(RegisterSet(R0, R3)); // save incoming arguments for slow case -#endif // !AARCH64 __ ldr_s32(Rsafept_cnt, Address(Rsafepoint_counter_addr)); __ tbnz(Rsafept_cnt, 0, slow_case); -#ifdef AARCH64 - // If mask changes we need to ensure that the inverse is still encodable as an immediate - STATIC_ASSERT(JNIHandles::weak_tag_mask == 1); - __ andr(R1, R1, ~JNIHandles::weak_tag_mask); -#else __ bic(R1, R1, JNIHandles::weak_tag_mask); -#endif // Address dependency restricts memory access ordering. It's cheaper than explicit LoadLoad barrier __ andr(Rtmp1, Rsafept_cnt, (unsigned)1); __ ldr(Robj, Address(R1, Rtmp1)); -#ifdef AARCH64 - __ add(Robj, Robj, AsmOperand(R2, lsr, 2)); - Address field_addr = Address(Robj); -#else Address field_addr; if (type != T_BOOLEAN && type != T_INT @@ -148,7 +129,6 @@ address JNI_FastGetField::generate_fast_get_int_field0(BasicType type) { } else { field_addr = Address(Robj, R2, lsr, 2); } -#endif // AARCH64 assert(count < LIST_CAPACITY, "LIST_CAPACITY too small"); speculative_load_pclist[count] = __ pc(); @@ -175,12 +155,8 @@ address JNI_FastGetField::generate_fast_get_int_field0(BasicType type) { #ifndef __ABI_HARD__ case T_DOUBLE: #endif -#ifdef AARCH64 - __ ldr(Rres, field_addr); -#else // Safe to use ldrd since long and double fields are 8-byte aligned __ ldrd(Rres, field_addr); -#endif // AARCH64 break; #ifdef __ABI_HARD__ case T_FLOAT: @@ -195,38 +171,28 @@ address JNI_FastGetField::generate_fast_get_int_field0(BasicType type) { } // Address dependency restricts memory access ordering. It's cheaper than explicit LoadLoad barrier -#if defined(__ABI_HARD__) && !defined(AARCH64) +#ifdef __ABI_HARD__ if (type == T_FLOAT || type == T_DOUBLE) { __ ldr_literal(Rsafepoint_counter_addr, safepoint_counter_addr); __ fmrrd(Rres, Rres_hi, D0); __ eor(Rtmp2, Rres, Rres); __ ldr_s32(Rsafept_cnt2, Address(Rsafepoint_counter_addr, Rtmp2)); } else -#endif // __ABI_HARD__ && !AARCH64 +#endif // __ABI_HARD__ { -#ifndef AARCH64 __ ldr_literal(Rsafepoint_counter_addr, safepoint_counter_addr); -#endif // !AARCH64 __ eor(Rtmp2, Rres, Rres); __ ldr_s32(Rsafept_cnt2, Address(Rsafepoint_counter_addr, Rtmp2)); } __ cmp(Rsafept_cnt2, Rsafept_cnt); -#ifdef AARCH64 - __ b(slow_case, ne); - __ mov(R0, Rres); - __ ret(); -#else // discards saved R0 R1 R2 R3 __ add(SP, SP, 4 * wordSize, eq); __ bx(LR, eq); -#endif // AARCH64 slowcase_entry_pclist[count++] = __ pc(); __ bind(slow_case); -#ifndef AARCH64 __ pop(RegisterSet(R0, R3)); -#endif // !AARCH64 // thumb mode switch handled by MacroAssembler::jump if needed __ jump(slow_case_addr, relocInfo::none, Rtemp); diff --git a/src/hotspot/cpu/arm/jniTypes_arm.hpp b/src/hotspot/cpu/arm/jniTypes_arm.hpp index 636f8e81a2c..4c5d7739fd4 100644 --- a/src/hotspot/cpu/arm/jniTypes_arm.hpp +++ b/src/hotspot/cpu/arm/jniTypes_arm.hpp @@ -44,12 +44,10 @@ class JNITypes : AllStatic { private: -#ifndef AARCH64 // 32bit Helper routines. static inline void put_int2r(jint *from, intptr_t *to) { *(jint *)(to++) = from[1]; *(jint *)(to ) = from[0]; } static inline void put_int2r(jint *from, intptr_t *to, int& pos) { put_int2r(from, to + pos); pos += 2; } -#endif public: // Ints are stored in native format in one JavaCallArgument slot at *to. @@ -57,18 +55,11 @@ public: static inline void put_int(jint from, intptr_t *to, int& pos) { *(jint *)(to + pos++) = from; } static inline void put_int(jint *from, intptr_t *to, int& pos) { *(jint *)(to + pos++) = *from; } -#ifdef AARCH64 - // Longs are stored in native format in one JavaCallArgument slot at *(to+1). - static inline void put_long(jlong from, intptr_t *to) { *(jlong *)(to + 1 + 0) = from; } - static inline void put_long(jlong from, intptr_t *to, int& pos) { *(jlong *)(to + 1 + pos) = from; pos += 2; } - static inline void put_long(jlong *from, intptr_t *to, int& pos) { *(jlong *)(to + 1 + pos) = *from; pos += 2; } -#else // Longs are stored in big-endian word format in two JavaCallArgument slots at *to. // The high half is in *to and the low half in *(to+1). static inline void put_long(jlong from, intptr_t *to) { put_int2r((jint *)&from, to); } static inline void put_long(jlong from, intptr_t *to, int& pos) { put_int2r((jint *)&from, to, pos); } static inline void put_long(jlong *from, intptr_t *to, int& pos) { put_int2r((jint *) from, to, pos); } -#endif // Oops are stored in native format in one JavaCallArgument slot at *to. static inline void put_obj(oop from, intptr_t *to) { *(oop *)(to + 0 ) = from; } @@ -80,18 +71,11 @@ public: static inline void put_float(jfloat from, intptr_t *to, int& pos) { *(jfloat *)(to + pos++) = from; } static inline void put_float(jfloat *from, intptr_t *to, int& pos) { *(jfloat *)(to + pos++) = *from; } -#ifdef AARCH64 - // Doubles are stored in native word format in one JavaCallArgument slot at *(to+1). - static inline void put_double(jdouble from, intptr_t *to) { *(jdouble *)(to + 1 + 0) = from; } - static inline void put_double(jdouble from, intptr_t *to, int& pos) { *(jdouble *)(to + 1 + pos) = from; pos += 2; } - static inline void put_double(jdouble *from, intptr_t *to, int& pos) { *(jdouble *)(to + 1 + pos) = *from; pos += 2; } -#else // Doubles are stored in big-endian word format in two JavaCallArgument slots at *to. // The high half is in *to and the low half in *(to+1). static inline void put_double(jdouble from, intptr_t *to) { put_int2r((jint *)&from, to); } static inline void put_double(jdouble from, intptr_t *to, int& pos) { put_int2r((jint *)&from, to, pos); } static inline void put_double(jdouble *from, intptr_t *to, int& pos) { put_int2r((jint *) from, to, pos); } -#endif }; diff --git a/src/hotspot/cpu/arm/macroAssembler_arm.cpp b/src/hotspot/cpu/arm/macroAssembler_arm.cpp index e4984861e8d..e99a4d0b9f9 100644 --- a/src/hotspot/cpu/arm/macroAssembler_arm.cpp +++ b/src/hotspot/cpu/arm/macroAssembler_arm.cpp @@ -97,19 +97,6 @@ RegisterOrConstant MacroAssembler::delayed_value_impl(intptr_t* delayed_value_ad } -#ifdef AARCH64 -// Note: ARM32 version is OS dependent -void MacroAssembler::breakpoint(AsmCondition cond) { - if (cond == al) { - brk(); - } else { - Label L; - b(L, inverse(cond)); - brk(); - bind(L); - } -} -#endif // AARCH64 // virtual method calling @@ -210,9 +197,6 @@ void MacroAssembler::check_klass_subtype_slow_path(Register sub_klass, Label* L_success, Label* L_failure, bool set_cond_codes) { -#ifdef AARCH64 - NOT_IMPLEMENTED(); -#else // Note: if used by code that expects a register to be 0 on success, // this register must be temp_reg and set_cond_codes must be true @@ -313,7 +297,6 @@ void MacroAssembler::check_klass_subtype_slow_path(Register sub_klass, } bind(L_fallthrough); -#endif } // Returns address of receiver parameter, using tmp as base register. tmp and params_count can be the same. @@ -342,14 +325,9 @@ int MacroAssembler::set_last_Java_frame(Register last_java_sp, } else { _fp_saved = false; } - if (AARCH64_ONLY(true) NOT_AARCH64(save_last_java_pc)) { // optional on 32-bit ARM -#ifdef AARCH64 - pc_offset = mov_pc_to(tmp); - str(tmp, Address(Rthread, JavaThread::last_Java_pc_offset())); -#else + if (save_last_java_pc) { str(PC, Address(Rthread, JavaThread::last_Java_pc_offset())); pc_offset = offset() + VM_Version::stored_pc_adjustment(); -#endif _pc_saved = true; } else { _pc_saved = false; @@ -369,16 +347,7 @@ int MacroAssembler::set_last_Java_frame(Register last_java_sp, if (last_java_sp == noreg) { last_java_sp = SP; // always saved } -#ifdef AARCH64 - if (last_java_sp == SP) { - mov(tmp, SP); - str(tmp, Address(Rthread, JavaThread::last_Java_sp_offset())); - } else { - str(last_java_sp, Address(Rthread, JavaThread::last_Java_sp_offset())); - } -#else str(last_java_sp, Address(Rthread, JavaThread::last_Java_sp_offset())); -#endif return pc_offset; // for oopmaps } @@ -401,19 +370,15 @@ void MacroAssembler::call_VM_leaf_helper(address entry_point, int number_of_argu assert(number_of_arguments >= 0, "cannot have negative number of arguments"); assert(number_of_arguments <= 4, "cannot have more than 4 arguments"); -#ifndef AARCH64 // Safer to save R9 here since callers may have been written // assuming R9 survives. This is suboptimal but is not worth // optimizing for the few platforms where R9 is scratched. push(RegisterSet(R4) | R9ifScratched); mov(R4, SP); bic(SP, SP, StackAlignmentInBytes - 1); -#endif // AARCH64 call(entry_point, relocInfo::runtime_call_type); -#ifndef AARCH64 mov(SP, R4); pop(RegisterSet(R4) | R9ifScratched); -#endif // AARCH64 } @@ -426,11 +391,6 @@ void MacroAssembler::call_VM_helper(Register oop_result, address entry_point, in set_last_Java_frame(SP, FP, true, tmp); -#ifdef ASSERT - AARCH64_ONLY(if (UseCompressedOops || UseCompressedClassPointers) { verify_heapbase("call_VM_helper: heap base corrupted?"); }); -#endif // ASSERT - -#ifndef AARCH64 #if R9_IS_SCRATCHED // Safer to save R9 here since callers may have been written // assuming R9 survives. This is suboptimal but is not worth @@ -446,17 +406,14 @@ void MacroAssembler::call_VM_helper(Register oop_result, address entry_point, in #else bic(SP, SP, StackAlignmentInBytes - 1); #endif // R9_IS_SCRATCHED -#endif mov(R0, Rthread); call(entry_point, relocInfo::runtime_call_type); -#ifndef AARCH64 #if R9_IS_SCRATCHED ldr(R9, Address(SP, 0)); #endif ldr(SP, Address(Rthread, JavaThread::last_Java_sp_offset())); -#endif reset_last_Java_frame(tmp); @@ -467,17 +424,9 @@ void MacroAssembler::call_VM_helper(Register oop_result, address entry_point, in if (check_exceptions) { // check for pending exceptions ldr(tmp, Address(Rthread, Thread::pending_exception_offset())); -#ifdef AARCH64 - Label L; - cbz(tmp, L); - mov_pc_to(Rexception_pc); - b(StubRoutines::forward_exception_entry()); - bind(L); -#else cmp(tmp, 0); mov(Rexception_pc, PC, ne); b(StubRoutines::forward_exception_entry(), ne); -#endif // AARCH64 } // get oop result if there is one and reset the value in the thread @@ -608,32 +557,6 @@ void MacroAssembler::add_rc(Register dst, Register arg1, RegisterOrConstant arg2 } void MacroAssembler::add_slow(Register rd, Register rn, int c) { -#ifdef AARCH64 - if (c == 0) { - if (rd != rn) { - mov(rd, rn); - } - return; - } - if (c < 0) { - sub_slow(rd, rn, -c); - return; - } - if (c > right_n_bits(24)) { - guarantee(rd != rn, "no large add_slow with only one register"); - mov_slow(rd, c); - add(rd, rn, rd); - } else { - int lo = c & right_n_bits(12); - int hi = (c >> 12) & right_n_bits(12); - if (lo != 0) { - add(rd, rn, lo, lsl0); - } - if (hi != 0) { - add(rd, (lo == 0) ? rn : rd, hi, lsl12); - } - } -#else // This function is used in compiler for handling large frame offsets if ((c < 0) && (((-c) & ~0x3fc) == 0)) { return sub(rd, rn, (-c)); @@ -650,30 +573,9 @@ void MacroAssembler::add_slow(Register rd, Register rn, int c) { assert(c == 0, ""); mov(rd, rn); // need to generate at least one move! } -#endif // AARCH64 } void MacroAssembler::sub_slow(Register rd, Register rn, int c) { -#ifdef AARCH64 - if (c <= 0) { - add_slow(rd, rn, -c); - return; - } - if (c > right_n_bits(24)) { - guarantee(rd != rn, "no large sub_slow with only one register"); - mov_slow(rd, c); - sub(rd, rn, rd); - } else { - int lo = c & right_n_bits(12); - int hi = (c >> 12) & right_n_bits(12); - if (lo != 0) { - sub(rd, rn, lo, lsl0); - } - if (hi != 0) { - sub(rd, (lo == 0) ? rn : rd, hi, lsl12); - } - } -#else // This function is used in compiler for handling large frame offsets if ((c < 0) && (((-c) & ~0x3fc) == 0)) { return add(rd, rn, (-c)); @@ -690,7 +592,6 @@ void MacroAssembler::sub_slow(Register rd, Register rn, int c) { assert(c == 0, ""); mov(rd, rn); // need to generate at least one move! } -#endif // AARCH64 } void MacroAssembler::mov_slow(Register rd, address addr) { @@ -702,99 +603,6 @@ void MacroAssembler::mov_slow(Register rd, const char *str) { mov_slow(rd, (intptr_t)str); } -#ifdef AARCH64 - -// Common code for mov_slow and instr_count_for_mov_slow. -// Returns number of instructions of mov_slow pattern, -// generating it if non-null MacroAssembler is given. -int MacroAssembler::mov_slow_helper(Register rd, intptr_t c, MacroAssembler* masm) { - // This code pattern is matched in NativeIntruction::is_mov_slow. - // Update it at modifications. - - const intx mask = right_n_bits(16); - // 1 movz instruction - for (int base_shift = 0; base_shift < 64; base_shift += 16) { - if ((c & ~(mask << base_shift)) == 0) { - if (masm != NULL) { - masm->movz(rd, ((uintx)c) >> base_shift, base_shift); - } - return 1; - } - } - // 1 movn instruction - for (int base_shift = 0; base_shift < 64; base_shift += 16) { - if (((~c) & ~(mask << base_shift)) == 0) { - if (masm != NULL) { - masm->movn(rd, ((uintx)(~c)) >> base_shift, base_shift); - } - return 1; - } - } - // 1 orr instruction - { - LogicalImmediate imm(c, false); - if (imm.is_encoded()) { - if (masm != NULL) { - masm->orr(rd, ZR, imm); - } - return 1; - } - } - // 1 movz/movn + up to 3 movk instructions - int zeroes = 0; - int ones = 0; - for (int base_shift = 0; base_shift < 64; base_shift += 16) { - int part = (c >> base_shift) & mask; - if (part == 0) { - ++zeroes; - } else if (part == mask) { - ++ones; - } - } - int def_bits = 0; - if (ones > zeroes) { - def_bits = mask; - } - int inst_count = 0; - for (int base_shift = 0; base_shift < 64; base_shift += 16) { - int part = (c >> base_shift) & mask; - if (part != def_bits) { - if (masm != NULL) { - if (inst_count > 0) { - masm->movk(rd, part, base_shift); - } else { - if (def_bits == 0) { - masm->movz(rd, part, base_shift); - } else { - masm->movn(rd, ~part & mask, base_shift); - } - } - } - inst_count++; - } - } - assert((1 <= inst_count) && (inst_count <= 4), "incorrect number of instructions"); - return inst_count; -} - -void MacroAssembler::mov_slow(Register rd, intptr_t c) { -#ifdef ASSERT - int off = offset(); -#endif - (void) mov_slow_helper(rd, c, this); - assert(offset() - off == instr_count_for_mov_slow(c) * InstructionSize, "size mismatch"); -} - -// Counts instructions generated by mov_slow(rd, c). -int MacroAssembler::instr_count_for_mov_slow(intptr_t c) { - return mov_slow_helper(noreg, c, NULL); -} - -int MacroAssembler::instr_count_for_mov_slow(address c) { - return mov_slow_helper(noreg, (intptr_t)c, NULL); -} - -#else void MacroAssembler::mov_slow(Register rd, intptr_t c, AsmCondition cond) { if (AsmOperand::is_rotated_imm(c)) { @@ -829,25 +637,13 @@ void MacroAssembler::mov_slow(Register rd, intptr_t c, AsmCondition cond) { } } -#endif // AARCH64 void MacroAssembler::mov_oop(Register rd, jobject o, int oop_index, -#ifdef AARCH64 - bool patchable -#else AsmCondition cond -#endif ) { if (o == NULL) { -#ifdef AARCH64 - if (patchable) { - nop(); - } - mov(rd, ZR); -#else mov(rd, 0, cond); -#endif return; } @@ -856,12 +652,6 @@ void MacroAssembler::mov_oop(Register rd, jobject o, int oop_index, } relocate(oop_Relocation::spec(oop_index)); -#ifdef AARCH64 - if (patchable) { - nop(); - } - ldr(rd, pc()); -#else if (VM_Version::supports_movw()) { movw(rd, 0, cond); movt(rd, 0, cond); @@ -870,16 +660,10 @@ void MacroAssembler::mov_oop(Register rd, jobject o, int oop_index, // Extra nop to handle case of large offset of oop placeholder (see NativeMovConstReg::set_data). nop(); } -#endif } -void MacroAssembler::mov_metadata(Register rd, Metadata* o, int metadata_index AARCH64_ONLY_ARG(bool patchable)) { +void MacroAssembler::mov_metadata(Register rd, Metadata* o, int metadata_index) { if (o == NULL) { -#ifdef AARCH64 - if (patchable) { - nop(); - } -#endif mov(rd, 0); return; } @@ -889,18 +673,6 @@ void MacroAssembler::mov_metadata(Register rd, Metadata* o, int metadata_index A } relocate(metadata_Relocation::spec(metadata_index)); -#ifdef AARCH64 - if (patchable) { - nop(); - } -#ifdef COMPILER2 - if (!patchable && VM_Version::prefer_moves_over_load_literal()) { - mov_slow(rd, (address)o); - return; - } -#endif - ldr(rd, pc()); -#else if (VM_Version::supports_movw()) { movw(rd, ((int)o) & 0xffff); movt(rd, (unsigned int)o >> 16); @@ -909,10 +681,9 @@ void MacroAssembler::mov_metadata(Register rd, Metadata* o, int metadata_index A // Extra nop to handle case of large offset of metadata placeholder (see NativeMovConstReg::set_data). nop(); } -#endif // AARCH64 } -void MacroAssembler::mov_float(FloatRegister fd, jfloat c NOT_AARCH64_ARG(AsmCondition cond)) { +void MacroAssembler::mov_float(FloatRegister fd, jfloat c, AsmCondition cond) { Label skip_constant; union { jfloat f; @@ -920,23 +691,13 @@ void MacroAssembler::mov_float(FloatRegister fd, jfloat c NOT_AARCH64_ARG(AsmCon } accessor; accessor.f = c; -#ifdef AARCH64 - // TODO-AARCH64 - try to optimize loading of float constants with fmov and/or mov_slow - Label L; - ldr_s(fd, target(L)); - b(skip_constant); - bind(L); - emit_int32(accessor.i); - bind(skip_constant); -#else flds(fd, Address(PC), cond); b(skip_constant); emit_int32(accessor.i); bind(skip_constant); -#endif // AARCH64 } -void MacroAssembler::mov_double(FloatRegister fd, jdouble c NOT_AARCH64_ARG(AsmCondition cond)) { +void MacroAssembler::mov_double(FloatRegister fd, jdouble c, AsmCondition cond) { Label skip_constant; union { jdouble d; @@ -944,55 +705,21 @@ void MacroAssembler::mov_double(FloatRegister fd, jdouble c NOT_AARCH64_ARG(AsmC } accessor; accessor.d = c; -#ifdef AARCH64 - // TODO-AARCH64 - try to optimize loading of double constants with fmov - Label L; - ldr_d(fd, target(L)); - b(skip_constant); - align(wordSize); - bind(L); - emit_int32(accessor.i[0]); - emit_int32(accessor.i[1]); - bind(skip_constant); -#else fldd(fd, Address(PC), cond); b(skip_constant); emit_int32(accessor.i[0]); emit_int32(accessor.i[1]); bind(skip_constant); -#endif // AARCH64 } void MacroAssembler::ldr_global_s32(Register reg, address address_of_global) { intptr_t addr = (intptr_t) address_of_global; -#ifdef AARCH64 - assert((addr & 0x3) == 0, "address should be aligned"); - - // FIXME: TODO - if (false && page_reachable_from_cache(address_of_global)) { - assert(false,"TODO: relocate"); - //relocate(); - adrp(reg, address_of_global); - ldrsw(reg, Address(reg, addr & 0xfff)); - } else { - mov_slow(reg, addr & ~0x3fff); - ldrsw(reg, Address(reg, addr & 0x3fff)); - } -#else mov_slow(reg, addr & ~0xfff); ldr(reg, Address(reg, addr & 0xfff)); -#endif } void MacroAssembler::ldr_global_ptr(Register reg, address address_of_global) { -#ifdef AARCH64 - intptr_t addr = (intptr_t) address_of_global; - assert ((addr & 0x7) == 0, "address should be aligned"); - mov_slow(reg, addr & ~0x7fff); - ldr(reg, Address(reg, addr & 0x7fff)); -#else ldr_global_s32(reg, address_of_global); -#endif } void MacroAssembler::ldrb_global(Register reg, address address_of_global) { @@ -1002,14 +729,6 @@ void MacroAssembler::ldrb_global(Register reg, address address_of_global) { } void MacroAssembler::zero_extend(Register rd, Register rn, int bits) { -#ifdef AARCH64 - switch (bits) { - case 8: uxtb(rd, rn); break; - case 16: uxth(rd, rn); break; - case 32: mov_w(rd, rn); break; - default: ShouldNotReachHere(); - } -#else if (bits <= 8) { andr(rd, rn, (1 << bits) - 1); } else if (bits >= 24) { @@ -1018,24 +737,13 @@ void MacroAssembler::zero_extend(Register rd, Register rn, int bits) { mov(rd, AsmOperand(rn, lsl, 32 - bits)); mov(rd, AsmOperand(rd, lsr, 32 - bits)); } -#endif } void MacroAssembler::sign_extend(Register rd, Register rn, int bits) { -#ifdef AARCH64 - switch (bits) { - case 8: sxtb(rd, rn); break; - case 16: sxth(rd, rn); break; - case 32: sxtw(rd, rn); break; - default: ShouldNotReachHere(); - } -#else mov(rd, AsmOperand(rn, lsl, 32 - bits)); mov(rd, AsmOperand(rd, asr, 32 - bits)); -#endif } -#ifndef AARCH64 void MacroAssembler::cmpoop(Register obj1, Register obj2) { BarrierSetAssembler* bs = BarrierSet::barrier_set()->barrier_set_assembler(); @@ -1134,7 +842,6 @@ void MacroAssembler::long_shift(Register rd_lo, Register rd_hi, } } } -#endif // !AARCH64 void MacroAssembler::_verify_oop(Register reg, const char* s, const char* file, int line) { // This code pattern is matched in NativeIntruction::skip_verify_oop. @@ -1236,9 +943,6 @@ void MacroAssembler::_verify_oop_addr(Address addr, const char* s, const char* f void MacroAssembler::null_check(Register reg, Register tmp, int offset) { if (needs_explicit_null_check(offset)) { -#ifdef AARCH64 - ldr(ZR, Address(reg)); -#else assert_different_registers(reg, tmp); if (tmp == noreg) { tmp = Rtemp; @@ -1249,7 +953,6 @@ void MacroAssembler::null_check(Register reg, Register tmp, int offset) { // XXX: could we mark the code buffer as not compatible with C2 ? } ldr(tmp, Address(reg)); -#endif } } @@ -1272,42 +975,11 @@ void MacroAssembler::zero_memory(Register start, Register end, Register tmp) { Label loop; const Register ptr = start; -#ifdef AARCH64 - // TODO-AARCH64 - compare performance of 2x word zeroing with simple 1x - const Register size = tmp; - Label remaining, done; - - sub(size, end, start); - -#ifdef ASSERT - { Label L; - tst(size, wordSize - 1); - b(L, eq); - stop("size is not a multiple of wordSize"); - bind(L); - } -#endif // ASSERT - - subs(size, size, wordSize); - b(remaining, le); - - // Zero by 2 words per iteration. - bind(loop); - subs(size, size, 2*wordSize); - stp(ZR, ZR, Address(ptr, 2*wordSize, post_indexed)); - b(loop, gt); - - bind(remaining); - b(done, ne); - str(ZR, Address(ptr)); - bind(done); -#else mov(tmp, 0); bind(loop); cmp(ptr, end); str(tmp, Address(ptr, wordSize, post_indexed), lo); b(loop, lo); -#endif // AARCH64 } void MacroAssembler::arm_stack_overflow_check(int frame_size_in_bytes, Register tmp) { @@ -1317,16 +989,9 @@ void MacroAssembler::arm_stack_overflow_check(int frame_size_in_bytes, Register sub_slow(tmp, SP, JavaThread::stack_shadow_zone_size()); strb(R0, Address(tmp)); -#ifdef AARCH64 - for (; frame_size_in_bytes >= page_size; frame_size_in_bytes -= page_size) { - sub(tmp, tmp, page_size); - strb(R0, Address(tmp)); - } -#else for (; frame_size_in_bytes >= page_size; frame_size_in_bytes -= 0xff0) { strb(R0, Address(tmp, -0xff0, pre_indexed)); } -#endif // AARCH64 } } @@ -1336,16 +1001,9 @@ void MacroAssembler::arm_stack_overflow_check(Register Rsize, Register tmp) { mov(tmp, SP); add_slow(Rsize, Rsize, JavaThread::stack_shadow_zone_size() - os::vm_page_size()); -#ifdef AARCH64 - sub(tmp, tmp, Rsize); - bind(loop); - subs(Rsize, Rsize, os::vm_page_size()); - strb(ZR, Address(tmp, Rsize)); -#else bind(loop); subs(Rsize, Rsize, 0xff0); strb(R0, Address(tmp, -0xff0, pre_indexed)); -#endif // AARCH64 b(loop, hi); } } @@ -1368,24 +1026,10 @@ void MacroAssembler::stop(const char* msg) { ldr_literal(R0, Lmsg); // message mov(R1, SP); // register save area -#ifdef AARCH64 - ldr_literal(Rtemp, Ldebug); - br(Rtemp); -#else ldr_literal(PC, Ldebug); // call MacroAssembler::debug -#endif // AARCH64 -#if defined(COMPILER2) && defined(AARCH64) - int off = offset(); -#endif bind_literal(Lmsg); bind_literal(Ldebug); -#if defined(COMPILER2) && defined(AARCH64) - if (offset() - off == 2 * wordSize) { - // no padding, so insert nop for worst-case sizing - nop(); - } -#endif } void MacroAssembler::warn(const char* msg) { @@ -1401,12 +1045,6 @@ void MacroAssembler::warn(const char* msg) { int push_size = save_caller_save_registers(); -#ifdef AARCH64 - // TODO-AARCH64 - get rid of extra debug parameters - mov(R1, LR); - mov(R2, FP); - add(R3, SP, push_size); -#endif ldr_literal(R0, Lmsg); // message ldr_literal(LR, Lwarn); // call warning @@ -1425,42 +1063,16 @@ void MacroAssembler::warn(const char* msg) { int MacroAssembler::save_all_registers() { // This code pattern is matched in NativeIntruction::is_save_all_registers. // Update it at modifications. -#ifdef AARCH64 - const Register tmp = Rtemp; - raw_push(R30, ZR); - for (int i = 28; i >= 0; i -= 2) { - raw_push(as_Register(i), as_Register(i+1)); - } - mov_pc_to(tmp); - str(tmp, Address(SP, 31*wordSize)); - ldr(tmp, Address(SP, tmp->encoding()*wordSize)); - return 32*wordSize; -#else push(RegisterSet(R0, R12) | RegisterSet(LR) | RegisterSet(PC)); return 15*wordSize; -#endif // AARCH64 } void MacroAssembler::restore_all_registers() { -#ifdef AARCH64 - for (int i = 0; i <= 28; i += 2) { - raw_pop(as_Register(i), as_Register(i+1)); - } - raw_pop(R30, ZR); -#else pop(RegisterSet(R0, R12) | RegisterSet(LR)); // restore registers add(SP, SP, wordSize); // discard saved PC -#endif // AARCH64 } int MacroAssembler::save_caller_save_registers() { -#ifdef AARCH64 - for (int i = 0; i <= 16; i += 2) { - raw_push(as_Register(i), as_Register(i+1)); - } - raw_push(R18, LR); - return 20*wordSize; -#else #if R9_IS_SCRATCHED // Save also R10 to preserve alignment push(RegisterSet(R0, R3) | RegisterSet(R12) | RegisterSet(LR) | RegisterSet(R9,R10)); @@ -1469,22 +1081,14 @@ int MacroAssembler::save_caller_save_registers() { push(RegisterSet(R0, R3) | RegisterSet(R12) | RegisterSet(LR)); return 6*wordSize; #endif -#endif // AARCH64 } void MacroAssembler::restore_caller_save_registers() { -#ifdef AARCH64 - raw_pop(R18, LR); - for (int i = 16; i >= 0; i -= 2) { - raw_pop(as_Register(i), as_Register(i+1)); - } -#else #if R9_IS_SCRATCHED pop(RegisterSet(R0, R3) | RegisterSet(R12) | RegisterSet(LR) | RegisterSet(R9,R10)); #else pop(RegisterSet(R0, R3) | RegisterSet(R12) | RegisterSet(LR)); #endif -#endif // AARCH64 } void MacroAssembler::debug(const char* msg, const intx* registers) { @@ -1498,23 +1102,14 @@ void MacroAssembler::debug(const char* msg, const intx* registers) { BytecodeCounter::print(); } if (os::message_box(msg, "Execution stopped, print registers?")) { -#ifdef AARCH64 - // saved registers: R0-R30, PC - const int nregs = 32; -#else // saved registers: R0-R12, LR, PC const int nregs = 15; const Register regs[nregs] = {R0, R1, R2, R3, R4, R5, R6, R7, R8, R9, R10, R11, R12, LR, PC}; -#endif // AARCH64 - for (int i = 0; i < nregs AARCH64_ONLY(-1); i++) { - tty->print_cr("%s = " INTPTR_FORMAT, AARCH64_ONLY(as_Register(i)) NOT_AARCH64(regs[i])->name(), registers[i]); + for (int i = 0; i < nregs; i++) { + tty->print_cr("%s = " INTPTR_FORMAT, regs[i]->name(), registers[i]); } -#ifdef AARCH64 - tty->print_cr("pc = " INTPTR_FORMAT, registers[nregs-1]); -#endif // AARCH64 - // derive original SP value from the address of register save area tty->print_cr("%s = " INTPTR_FORMAT, SP->name(), p2i(®isters[nregs])); } @@ -1558,22 +1153,6 @@ FixedSizeCodeBlock::~FixedSizeCodeBlock() { } } -#ifdef AARCH64 - -// Serializes memory. -// tmp register is not used on AArch64, this parameter is provided solely for better compatibility with 32-bit ARM -void MacroAssembler::membar(Membar_mask_bits order_constraint, Register tmp) { - // TODO-AARCH64 investigate dsb vs dmb effects - if (order_constraint == StoreStore) { - dmb(DMB_st); - } else if ((order_constraint & ~(LoadLoad | LoadStore)) == 0) { - dmb(DMB_ld); - } else { - dmb(DMB_all); - } -} - -#else // Serializes memory. Potentially blows flags and reg. // tmp is a scratch for v6 co-processor write op (could be noreg for other architecure versions) @@ -1603,7 +1182,6 @@ void MacroAssembler::membar(Membar_mask_bits order_constraint, } } -#endif // AARCH64 // If "allow_fallthrough_on_failure" is false, we always branch to "slow_case" // on failure, so fall-through can only mean success. @@ -1626,36 +1204,6 @@ void MacroAssembler::cas_for_lock_acquire(Register oldval, Register newval, // reordering we must issue a StoreStore or Release barrier before // the CAS store. -#ifdef AARCH64 - - Register Rscratch = tmp; - Register Roop = base; - Register mark = oldval; - Register Rbox = newval; - Label loop; - - assert(oopDesc::mark_offset_in_bytes() == 0, "must be"); - - // Instead of StoreStore here, we use store-release-exclusive below - - bind(loop); - - ldaxr(tmp, base); // acquire - cmp(tmp, oldval); - b(slow_case, ne); - stlxr(tmp, newval, base); // release - if (one_shot) { - cmp_w(tmp, 0); - } else { - cbnz_w(tmp, loop); - fallthrough_is_success = true; - } - - // MemBarAcquireLock would normally go here, but - // we already do ldaxr+stlxr above, which has - // Sequential Consistency - -#else membar(MacroAssembler::StoreStore, noreg); if (one_shot) { @@ -1673,7 +1221,6 @@ void MacroAssembler::cas_for_lock_acquire(Register oldval, Register newval, // the load and store in the CAS sequence, so play it safe and // do a full fence. membar(Membar_mask_bits(LoadLoad | LoadStore | StoreStore | StoreLoad), noreg); -#endif if (!fallthrough_is_success && !allow_fallthrough_on_failure) { b(slow_case, ne); } @@ -1688,24 +1235,6 @@ void MacroAssembler::cas_for_lock_release(Register oldval, Register newval, assert_different_registers(oldval,newval,base,tmp); -#ifdef AARCH64 - Label loop; - - assert(oopDesc::mark_offset_in_bytes() == 0, "must be"); - - bind(loop); - ldxr(tmp, base); - cmp(tmp, oldval); - b(slow_case, ne); - // MemBarReleaseLock barrier - stlxr(tmp, newval, base); - if (one_shot) { - cmp_w(tmp, 0); - } else { - cbnz_w(tmp, loop); - fallthrough_is_success = true; - } -#else // MemBarReleaseLock barrier // According to JSR-133 Cookbook, this should be StoreStore | LoadStore, // but that doesn't prevent a load or store from floating down between @@ -1721,7 +1250,6 @@ void MacroAssembler::cas_for_lock_release(Register oldval, Register newval, } else { atomic_cas_bool(oldval, newval, base, oopDesc::mark_offset_in_bytes(), tmp); } -#endif if (!fallthrough_is_success && !allow_fallthrough_on_failure) { b(slow_case, ne); } @@ -1746,21 +1274,6 @@ void MacroAssembler::cond_atomic_inc32(AsmCondition cond, int* counter_addr) { b(done, inverse(cond)); } -#ifdef AARCH64 - raw_push(R0, R1); - raw_push(R2, ZR); - - ldr_literal(R0, counter_addr_literal); - - bind(retry); - ldxr_w(R1, R0); - add_w(R1, R1, 1); - stxr_w(R2, R1, R0); - cbnz_w(R2, retry); - - raw_pop(R2, ZR); - raw_pop(R0, R1); -#else push(RegisterSet(R0, R3) | RegisterSet(Rtemp)); ldr_literal(R0, counter_addr_literal); @@ -1775,7 +1288,6 @@ void MacroAssembler::cond_atomic_inc32(AsmCondition cond, int* counter_addr) { msr(CPSR_fsxc, Rtemp); pop(RegisterSet(R0, R3) | RegisterSet(Rtemp)); -#endif // AARCH64 b(done); bind_literal(counter_addr_literal); @@ -1861,11 +1373,7 @@ int MacroAssembler::biased_locking_enter(Register obj_reg, Register swap_reg, Re orr(tmp_reg, tmp_reg, Rthread); eor(tmp_reg, tmp_reg, swap_reg); -#ifdef AARCH64 - ands(tmp_reg, tmp_reg, ~((uintx) markOopDesc::age_mask_in_place)); -#else bics(tmp_reg, tmp_reg, ((int) markOopDesc::age_mask_in_place)); -#endif // AARCH64 #ifndef PRODUCT if (counters != NULL) { @@ -1915,19 +1423,12 @@ int MacroAssembler::biased_locking_enter(Register obj_reg, Register swap_reg, Re // Note that we know the owner is not ourself. Hence, success can // only happen when the owner bits is 0 -#ifdef AARCH64 - // Bit mask biased_lock + age + epoch is not a valid AArch64 logical immediate, as it has - // cleared bit in the middle (cms bit). So it is loaded with separate instruction. - mov(tmp2, (markOopDesc::biased_lock_mask_in_place | markOopDesc::age_mask_in_place | markOopDesc::epoch_mask_in_place)); - andr(swap_reg, swap_reg, tmp2); -#else // until the assembler can be made smarter, we need to make some assumptions about the values // so we can optimize this: assert((markOopDesc::biased_lock_mask_in_place | markOopDesc::age_mask_in_place | markOopDesc::epoch_mask_in_place) == 0x1ff, "biased bitmasks changed"); mov(swap_reg, AsmOperand(swap_reg, lsl, 23)); mov(swap_reg, AsmOperand(swap_reg, lsr, 23)); // markOop with thread bits cleared (for CAS) -#endif // AARCH64 orr(tmp_reg, swap_reg, Rthread); // new mark @@ -1955,13 +1456,8 @@ int MacroAssembler::biased_locking_enter(Register obj_reg, Register swap_reg, Re eor(tmp_reg, tmp_reg, swap_reg); // OK except for owner bits (age preserved !) // owner bits 'random'. Set them to Rthread. -#ifdef AARCH64 - mov(tmp2, (markOopDesc::biased_lock_mask_in_place | markOopDesc::age_mask_in_place | markOopDesc::epoch_mask_in_place)); - andr(tmp_reg, tmp_reg, tmp2); -#else mov(tmp_reg, AsmOperand(tmp_reg, lsl, 23)); mov(tmp_reg, AsmOperand(tmp_reg, lsr, 23)); -#endif // AARCH64 orr(tmp_reg, tmp_reg, Rthread); // new mark @@ -1990,13 +1486,8 @@ int MacroAssembler::biased_locking_enter(Register obj_reg, Register swap_reg, Re eor(tmp_reg, tmp_reg, swap_reg); // OK except for owner bits (age preserved !) // owner bits 'random'. Clear them -#ifdef AARCH64 - mov(tmp2, (markOopDesc::biased_lock_mask_in_place | markOopDesc::age_mask_in_place | markOopDesc::epoch_mask_in_place)); - andr(tmp_reg, tmp_reg, tmp2); -#else mov(tmp_reg, AsmOperand(tmp_reg, lsl, 23)); mov(tmp_reg, AsmOperand(tmp_reg, lsr, 23)); -#endif // AARCH64 biased_locking_enter_with_cas(obj_reg, swap_reg, tmp_reg, tmp2, cas_label, (counters != NULL) ? counters->revoked_lock_entry_count_addr() : NULL); @@ -2052,29 +1543,6 @@ void MacroAssembler::resolve_jobject(Register value, ////////////////////////////////////////////////////////////////////////////////// -#ifdef AARCH64 - -void MacroAssembler::load_sized_value(Register dst, Address src, size_t size_in_bytes, bool is_signed) { - switch (size_in_bytes) { - case 8: ldr(dst, src); break; - case 4: is_signed ? ldr_s32(dst, src) : ldr_u32(dst, src); break; - case 2: is_signed ? ldrsh(dst, src) : ldrh(dst, src); break; - case 1: is_signed ? ldrsb(dst, src) : ldrb(dst, src); break; - default: ShouldNotReachHere(); - } -} - -void MacroAssembler::store_sized_value(Register src, Address dst, size_t size_in_bytes) { - switch (size_in_bytes) { - case 8: str(src, dst); break; - case 4: str_32(src, dst); break; - case 2: strh(src, dst); break; - case 1: strb(src, dst); break; - default: ShouldNotReachHere(); - } -} - -#else void MacroAssembler::load_sized_value(Register dst, Address src, size_t size_in_bytes, bool is_signed, AsmCondition cond) { @@ -2095,7 +1563,6 @@ void MacroAssembler::store_sized_value(Register src, Address dst, size_t size_in default: ShouldNotReachHere(); } } -#endif // AARCH64 // Look up the method for a megamorphic invokeinterface call. // The target method is determined by . @@ -2128,24 +1595,12 @@ void MacroAssembler::lookup_interface_method(Register Rklass, Label loop; bind(loop); ldr(Rtmp, Address(Rscan, entry_size, post_indexed)); -#ifdef AARCH64 - Label found; - cmp(Rtmp, Rintf); - b(found, eq); - cbnz(Rtmp, loop); -#else cmp(Rtmp, Rintf); // set ZF and CF if interface is found cmn(Rtmp, 0, ne); // check if tmp == 0 and clear CF if it is b(loop, ne); -#endif // AARCH64 -#ifdef AARCH64 - b(L_no_such_interface); - bind(found); -#else // CF == 0 means we reached the end of itable without finding icklass b(L_no_such_interface, cc); -#endif // !AARCH64 if (method_result != noreg) { // Interface found at previous position of Rscan, now load the method @@ -2224,31 +1679,20 @@ void MacroAssembler::inc_counter(address counter_addr, Register tmpreg1, Registe } void MacroAssembler::floating_cmp(Register dst) { -#ifdef AARCH64 - NOT_TESTED(); - cset(dst, gt); // 1 if '>', else 0 - csinv(dst, dst, ZR, ge); // previous value if '>=', else -1 -#else vmrs(dst, FPSCR); orr(dst, dst, 0x08000000); eor(dst, dst, AsmOperand(dst, lsl, 3)); mov(dst, AsmOperand(dst, asr, 30)); -#endif } void MacroAssembler::restore_default_fp_mode() { -#ifdef AARCH64 - msr(SysReg_FPCR, ZR); -#else #ifndef __SOFTFP__ // Round to Near mode, IEEE compatible, masked exceptions mov(Rtemp, 0); vmsr(FPSCR, Rtemp); #endif // !__SOFTFP__ -#endif // AARCH64 } -#ifndef AARCH64 // 24-bit word range == 26-bit byte range bool check26(int offset) { // this could be simplified, but it mimics encoding and decoding @@ -2258,7 +1702,6 @@ bool check26(int offset) { int decoded = encoded << 8 >> 6; return offset == decoded; } -#endif // !AARCH64 // Perform some slight adjustments so the default 32MB code cache // is fully reachable. @@ -2269,18 +1712,6 @@ static inline address last_cache_address() { return CodeCache::high_bound() - Assembler::InstructionSize; } -#ifdef AARCH64 -// Can we reach target using ADRP? -bool MacroAssembler::page_reachable_from_cache(address target) { - intptr_t cl = (intptr_t)first_cache_address() & ~0xfff; - intptr_t ch = (intptr_t)last_cache_address() & ~0xfff; - intptr_t addr = (intptr_t)target & ~0xfff; - - intptr_t loffset = addr - cl; - intptr_t hoffset = addr - ch; - return is_imm_in_range(loffset >> 12, 21, 0) && is_imm_in_range(hoffset >> 12, 21, 0); -} -#endif // Can we reach target using unconditional branch or call from anywhere // in the code cache (because code can be relocated)? @@ -2305,11 +1736,7 @@ bool MacroAssembler::_reachable_from_cache(address target) { intptr_t loffset = (intptr_t)target - (intptr_t)cl; intptr_t hoffset = (intptr_t)target - (intptr_t)ch; -#ifdef AARCH64 - return is_offset_in_range(loffset, 26) && is_offset_in_range(hoffset, 26); -#else return check26(loffset - 8) && check26(hoffset - 8); -#endif } bool MacroAssembler::reachable_from_cache(address target) { @@ -2329,11 +1756,11 @@ bool MacroAssembler::cache_fully_reachable() { return _cache_fully_reachable(); } -void MacroAssembler::jump(address target, relocInfo::relocType rtype, Register scratch NOT_AARCH64_ARG(AsmCondition cond)) { +void MacroAssembler::jump(address target, relocInfo::relocType rtype, Register scratch, AsmCondition cond) { assert((rtype == relocInfo::runtime_call_type) || (rtype == relocInfo::none), "not supported"); if (reachable_from_cache(target)) { relocate(rtype); - b(target NOT_AARCH64_ARG(cond)); + b(target, cond); return; } @@ -2343,20 +1770,6 @@ void MacroAssembler::jump(address target, relocInfo::relocType rtype, Register s rtype = relocInfo::none; } -#ifdef AARCH64 - assert (scratch != noreg, "should be specified"); - InlinedAddress address_literal(target, rtype); - ldr_literal(scratch, address_literal); - br(scratch); - int off = offset(); - bind_literal(address_literal); -#ifdef COMPILER2 - if (offset() - off == wordSize) { - // no padding, so insert nop for worst-case sizing - nop(); - } -#endif -#else if (VM_Version::supports_movw() && (scratch != noreg) && (rtype == relocInfo::none)) { // Note: this version cannot be (atomically) patched mov_slow(scratch, (intptr_t)target, cond); @@ -2372,20 +1785,19 @@ void MacroAssembler::jump(address target, relocInfo::relocType rtype, Register s bind_literal(address_literal); bind(skip); } -#endif // AARCH64 } // Similar to jump except that: // - near calls are valid only if any destination in the cache is near // - no movt/movw (not atomically patchable) -void MacroAssembler::patchable_jump(address target, relocInfo::relocType rtype, Register scratch NOT_AARCH64_ARG(AsmCondition cond)) { +void MacroAssembler::patchable_jump(address target, relocInfo::relocType rtype, Register scratch, AsmCondition cond) { assert((rtype == relocInfo::runtime_call_type) || (rtype == relocInfo::none), "not supported"); if (cache_fully_reachable()) { // Note: this assumes that all possible targets (the initial one // and the addressed patched to) are all in the code cache. assert(CodeCache::contains(target), "target might be too far"); relocate(rtype); - b(target NOT_AARCH64_ARG(cond)); + b(target, cond); return; } @@ -2395,21 +1807,6 @@ void MacroAssembler::patchable_jump(address target, relocInfo::relocType rtype, rtype = relocInfo::none; } -#ifdef AARCH64 - assert (scratch != noreg, "should be specified"); - InlinedAddress address_literal(target); - relocate(rtype); - ldr_literal(scratch, address_literal); - br(scratch); - int off = offset(); - bind_literal(address_literal); -#ifdef COMPILER2 - if (offset() - off == wordSize) { - // no padding, so insert nop for worst-case sizing - nop(); - } -#endif -#else { Label skip; InlinedAddress address_literal(target); @@ -2421,15 +1818,14 @@ void MacroAssembler::patchable_jump(address target, relocInfo::relocType rtype, bind_literal(address_literal); bind(skip); } -#endif // AARCH64 } -void MacroAssembler::call(address target, RelocationHolder rspec NOT_AARCH64_ARG(AsmCondition cond)) { +void MacroAssembler::call(address target, RelocationHolder rspec, AsmCondition cond) { Register scratch = LR; assert(rspec.type() == relocInfo::runtime_call_type || rspec.type() == relocInfo::none, "not supported"); if (reachable_from_cache(target)) { relocate(rspec); - bl(target NOT_AARCH64_ARG(cond)); + bl(target, cond); return; } @@ -2440,31 +1836,20 @@ void MacroAssembler::call(address target, RelocationHolder rspec NOT_AARCH64_ARG rspec = RelocationHolder::none; } -#ifndef AARCH64 if (VM_Version::supports_movw() && (rspec.type() == relocInfo::none)) { // Note: this version cannot be (atomically) patched mov_slow(scratch, (intptr_t)target, cond); blx(scratch, cond); return; } -#endif { Label ret_addr; -#ifndef AARCH64 if (cond != al) { b(ret_addr, inverse(cond)); } -#endif -#ifdef AARCH64 - // TODO-AARCH64: make more optimal implementation - // [ Keep in sync with MacroAssembler::call_size ] - assert(rspec.type() == relocInfo::none, "call reloc not implemented"); - mov_slow(scratch, target); - blr(scratch); -#else InlinedAddress address_literal(target); relocate(rspec); adr(LR, ret_addr); @@ -2472,18 +1857,9 @@ void MacroAssembler::call(address target, RelocationHolder rspec NOT_AARCH64_ARG bind_literal(address_literal); bind(ret_addr); -#endif } } -#if defined(AARCH64) && defined(COMPILER2) -int MacroAssembler::call_size(address target, bool far, bool patchable) { - // FIXME: mov_slow is variable-length - if (!far) return 1; // bl - if (patchable) return 2; // ldr; blr - return instr_count_for_mov_slow((intptr_t)target) + 1; -} -#endif int MacroAssembler::patchable_call(address target, RelocationHolder const& rspec, bool c2) { assert(rspec.type() == relocInfo::static_call_type || @@ -2498,38 +1874,10 @@ int MacroAssembler::patchable_call(address target, RelocationHolder const& rspec assert(CodeCache::contains(target), "target might be too far"); bl(target); } else { -#if defined(AARCH64) && defined(COMPILER2) - if (c2) { - // return address needs to match call_size(). - // no need to trash Rtemp - int off = offset(); - Label skip_literal; - InlinedAddress address_literal(target); - ldr_literal(LR, address_literal); - blr(LR); - int ret_addr_offset = offset(); - assert(offset() - off == call_size(target, true, true) * InstructionSize, "need to fix call_size()"); - b(skip_literal); - int off2 = offset(); - bind_literal(address_literal); - if (offset() - off2 == wordSize) { - // no padding, so insert nop for worst-case sizing - nop(); - } - bind(skip_literal); - return ret_addr_offset; - } -#endif Label ret_addr; InlinedAddress address_literal(target); -#ifdef AARCH64 - ldr_literal(Rtemp, address_literal); - adr(LR, ret_addr); - br(Rtemp); -#else adr(LR, ret_addr); ldr_literal(PC, address_literal); -#endif bind_literal(address_literal); bind(ret_addr); } @@ -2556,47 +1904,17 @@ void MacroAssembler::load_mirror(Register mirror, Register method, Register tmp) // Compressed pointers -#ifdef AARCH64 - -void MacroAssembler::load_klass(Register dst_klass, Register src_oop) { - if (UseCompressedClassPointers) { - ldr_w(dst_klass, Address(src_oop, oopDesc::klass_offset_in_bytes())); - decode_klass_not_null(dst_klass); - } else { - ldr(dst_klass, Address(src_oop, oopDesc::klass_offset_in_bytes())); - } -} - -#else void MacroAssembler::load_klass(Register dst_klass, Register src_oop, AsmCondition cond) { ldr(dst_klass, Address(src_oop, oopDesc::klass_offset_in_bytes()), cond); } -#endif // AARCH64 // Blows src_klass. void MacroAssembler::store_klass(Register src_klass, Register dst_oop) { -#ifdef AARCH64 - if (UseCompressedClassPointers) { - assert(src_klass != dst_oop, "not enough registers"); - encode_klass_not_null(src_klass); - str_w(src_klass, Address(dst_oop, oopDesc::klass_offset_in_bytes())); - return; - } -#endif // AARCH64 str(src_klass, Address(dst_oop, oopDesc::klass_offset_in_bytes())); } -#ifdef AARCH64 - -void MacroAssembler::store_klass_gap(Register dst) { - if (UseCompressedClassPointers) { - str_w(ZR, Address(dst, oopDesc::klass_gap_offset_in_bytes())); - } -} - -#endif // AARCH64 void MacroAssembler::load_heap_oop(Register dst, Address src, Register tmp1, Register tmp2, Register tmp3, DecoratorSet decorators) { @@ -2645,265 +1963,9 @@ void MacroAssembler::resolve(DecoratorSet decorators, Register obj) { return bs->resolve(this, decorators, obj); } -#ifdef AARCH64 - -// Algorithm must match oop.inline.hpp encode_heap_oop. -void MacroAssembler::encode_heap_oop(Register dst, Register src) { - // This code pattern is matched in NativeIntruction::skip_encode_heap_oop. - // Update it at modifications. - assert (UseCompressedOops, "must be compressed"); - assert (Universe::heap() != NULL, "java heap should be initialized"); -#ifdef ASSERT - verify_heapbase("MacroAssembler::encode_heap_oop: heap base corrupted?"); -#endif - verify_oop(src); - if (Universe::narrow_oop_base() == NULL) { - if (Universe::narrow_oop_shift() != 0) { - assert (LogMinObjAlignmentInBytes == Universe::narrow_oop_shift(), "decode alg wrong"); - _lsr(dst, src, Universe::narrow_oop_shift()); - } else if (dst != src) { - mov(dst, src); - } - } else { - tst(src, src); - csel(dst, Rheap_base, src, eq); - sub(dst, dst, Rheap_base); - if (Universe::narrow_oop_shift() != 0) { - assert (LogMinObjAlignmentInBytes == Universe::narrow_oop_shift(), "decode alg wrong"); - _lsr(dst, dst, Universe::narrow_oop_shift()); - } - } -} - -// Same algorithm as oop.inline.hpp decode_heap_oop. -void MacroAssembler::decode_heap_oop(Register dst, Register src) { -#ifdef ASSERT - verify_heapbase("MacroAssembler::decode_heap_oop: heap base corrupted?"); -#endif - assert(Universe::narrow_oop_shift() == 0 || LogMinObjAlignmentInBytes == Universe::narrow_oop_shift(), "decode alg wrong"); - if (Universe::narrow_oop_base() != NULL) { - tst(src, src); - add(dst, Rheap_base, AsmOperand(src, lsl, Universe::narrow_oop_shift())); - csel(dst, dst, ZR, ne); - } else { - _lsl(dst, src, Universe::narrow_oop_shift()); - } - verify_oop(dst); -} #ifdef COMPILER2 -// Algorithm must match oop.inline.hpp encode_heap_oop. -// Must preserve condition codes, or C2 encodeHeapOop_not_null rule -// must be changed. -void MacroAssembler::encode_heap_oop_not_null(Register dst, Register src) { - assert (UseCompressedOops, "must be compressed"); - assert (Universe::heap() != NULL, "java heap should be initialized"); -#ifdef ASSERT - verify_heapbase("MacroAssembler::encode_heap_oop: heap base corrupted?"); -#endif - verify_oop(src); - if (Universe::narrow_oop_base() == NULL) { - if (Universe::narrow_oop_shift() != 0) { - assert (LogMinObjAlignmentInBytes == Universe::narrow_oop_shift(), "decode alg wrong"); - _lsr(dst, src, Universe::narrow_oop_shift()); - } else if (dst != src) { - mov(dst, src); - } - } else { - sub(dst, src, Rheap_base); - if (Universe::narrow_oop_shift() != 0) { - assert (LogMinObjAlignmentInBytes == Universe::narrow_oop_shift(), "decode alg wrong"); - _lsr(dst, dst, Universe::narrow_oop_shift()); - } - } -} - -// Same algorithm as oops.inline.hpp decode_heap_oop. -// Must preserve condition codes, or C2 decodeHeapOop_not_null rule -// must be changed. -void MacroAssembler::decode_heap_oop_not_null(Register dst, Register src) { -#ifdef ASSERT - verify_heapbase("MacroAssembler::decode_heap_oop: heap base corrupted?"); -#endif - assert(Universe::narrow_oop_shift() == 0 || LogMinObjAlignmentInBytes == Universe::narrow_oop_shift(), "decode alg wrong"); - if (Universe::narrow_oop_base() != NULL) { - add(dst, Rheap_base, AsmOperand(src, lsl, Universe::narrow_oop_shift())); - } else { - _lsl(dst, src, Universe::narrow_oop_shift()); - } - verify_oop(dst); -} - -void MacroAssembler::set_narrow_klass(Register dst, Klass* k) { - assert(UseCompressedClassPointers, "should only be used for compressed header"); - assert(oop_recorder() != NULL, "this assembler needs an OopRecorder"); - int klass_index = oop_recorder()->find_index(k); - RelocationHolder rspec = metadata_Relocation::spec(klass_index); - - // Relocation with special format (see relocInfo_arm.hpp). - relocate(rspec); - narrowKlass encoded_k = Klass::encode_klass(k); - movz(dst, encoded_k & 0xffff, 0); - movk(dst, (encoded_k >> 16) & 0xffff, 16); -} - -void MacroAssembler::set_narrow_oop(Register dst, jobject obj) { - assert(UseCompressedOops, "should only be used for compressed header"); - assert(oop_recorder() != NULL, "this assembler needs an OopRecorder"); - int oop_index = oop_recorder()->find_index(obj); - RelocationHolder rspec = oop_Relocation::spec(oop_index); - - relocate(rspec); - movz(dst, 0xffff, 0); - movk(dst, 0xffff, 16); -} - -#endif // COMPILER2 -// Must preserve condition codes, or C2 encodeKlass_not_null rule -// must be changed. -void MacroAssembler::encode_klass_not_null(Register r) { - if (Universe::narrow_klass_base() != NULL) { - // Use Rheap_base as a scratch register in which to temporarily load the narrow_klass_base. - assert(r != Rheap_base, "Encoding a klass in Rheap_base"); - mov_slow(Rheap_base, Universe::narrow_klass_base()); - sub(r, r, Rheap_base); - } - if (Universe::narrow_klass_shift() != 0) { - assert (LogKlassAlignmentInBytes == Universe::narrow_klass_shift(), "decode alg wrong"); - _lsr(r, r, Universe::narrow_klass_shift()); - } - if (Universe::narrow_klass_base() != NULL) { - reinit_heapbase(); - } -} - -// Must preserve condition codes, or C2 encodeKlass_not_null rule -// must be changed. -void MacroAssembler::encode_klass_not_null(Register dst, Register src) { - if (dst == src) { - encode_klass_not_null(src); - return; - } - if (Universe::narrow_klass_base() != NULL) { - mov_slow(dst, (int64_t)Universe::narrow_klass_base()); - sub(dst, src, dst); - if (Universe::narrow_klass_shift() != 0) { - assert (LogKlassAlignmentInBytes == Universe::narrow_klass_shift(), "decode alg wrong"); - _lsr(dst, dst, Universe::narrow_klass_shift()); - } - } else { - if (Universe::narrow_klass_shift() != 0) { - assert (LogKlassAlignmentInBytes == Universe::narrow_klass_shift(), "decode alg wrong"); - _lsr(dst, src, Universe::narrow_klass_shift()); - } else { - mov(dst, src); - } - } -} - -// Function instr_count_for_decode_klass_not_null() counts the instructions -// generated by decode_klass_not_null(register r) and reinit_heapbase(), -// when (Universe::heap() != NULL). Hence, if the instructions they -// generate change, then this method needs to be updated. -int MacroAssembler::instr_count_for_decode_klass_not_null() { - assert(UseCompressedClassPointers, "only for compressed klass ptrs"); - assert(Universe::heap() != NULL, "java heap should be initialized"); - if (Universe::narrow_klass_base() != NULL) { - return instr_count_for_mov_slow(Universe::narrow_klass_base()) + // mov_slow - 1 + // add - instr_count_for_mov_slow(Universe::narrow_ptrs_base()); // reinit_heapbase() = mov_slow - } else { - if (Universe::narrow_klass_shift() != 0) { - return 1; - } - } - return 0; -} - -// Must preserve condition codes, or C2 decodeKlass_not_null rule -// must be changed. -void MacroAssembler::decode_klass_not_null(Register r) { - int off = offset(); - assert(UseCompressedClassPointers, "should only be used for compressed headers"); - assert(Universe::heap() != NULL, "java heap should be initialized"); - assert(r != Rheap_base, "Decoding a klass in Rheap_base"); - // Cannot assert, instr_count_for_decode_klass_not_null() counts instructions. - // Also do not verify_oop as this is called by verify_oop. - if (Universe::narrow_klass_base() != NULL) { - // Use Rheap_base as a scratch register in which to temporarily load the narrow_klass_base. - mov_slow(Rheap_base, Universe::narrow_klass_base()); - add(r, Rheap_base, AsmOperand(r, lsl, Universe::narrow_klass_shift())); - reinit_heapbase(); - } else { - if (Universe::narrow_klass_shift() != 0) { - assert (LogKlassAlignmentInBytes == Universe::narrow_klass_shift(), "decode alg wrong"); - _lsl(r, r, Universe::narrow_klass_shift()); - } - } - assert((offset() - off) == (instr_count_for_decode_klass_not_null() * InstructionSize), "need to fix instr_count_for_decode_klass_not_null"); -} - -// Must preserve condition codes, or C2 decodeKlass_not_null rule -// must be changed. -void MacroAssembler::decode_klass_not_null(Register dst, Register src) { - if (src == dst) { - decode_klass_not_null(src); - return; - } - - assert(UseCompressedClassPointers, "should only be used for compressed headers"); - assert(Universe::heap() != NULL, "java heap should be initialized"); - assert(src != Rheap_base, "Decoding a klass in Rheap_base"); - assert(dst != Rheap_base, "Decoding a klass into Rheap_base"); - // Also do not verify_oop as this is called by verify_oop. - if (Universe::narrow_klass_base() != NULL) { - mov_slow(dst, Universe::narrow_klass_base()); - add(dst, dst, AsmOperand(src, lsl, Universe::narrow_klass_shift())); - } else { - _lsl(dst, src, Universe::narrow_klass_shift()); - } -} - - -void MacroAssembler::reinit_heapbase() { - if (UseCompressedOops || UseCompressedClassPointers) { - if (Universe::heap() != NULL) { - mov_slow(Rheap_base, Universe::narrow_ptrs_base()); - } else { - ldr_global_ptr(Rheap_base, (address)Universe::narrow_ptrs_base_addr()); - } - } -} - -#ifdef ASSERT -void MacroAssembler::verify_heapbase(const char* msg) { - // This code pattern is matched in NativeIntruction::skip_verify_heapbase. - // Update it at modifications. - assert (UseCompressedOops, "should be compressed"); - assert (Universe::heap() != NULL, "java heap should be initialized"); - if (CheckCompressedOops) { - Label ok; - str(Rthread, Address(Rthread, in_bytes(JavaThread::in_top_frame_unsafe_section_offset()))); - raw_push(Rtemp, ZR); - mrs(Rtemp, Assembler::SysReg_NZCV); - str(Rtemp, Address(SP, 1 * wordSize)); - mov_slow(Rtemp, Universe::narrow_ptrs_base()); - cmp(Rheap_base, Rtemp); - b(ok, eq); - stop(msg); - bind(ok); - ldr(Rtemp, Address(SP, 1 * wordSize)); - msr(Assembler::SysReg_NZCV, Rtemp); - raw_pop(Rtemp, ZR); - str(ZR, Address(Rthread, in_bytes(JavaThread::in_top_frame_unsafe_section_offset()))); - } -} -#endif // ASSERT - -#endif // AARCH64 - -#ifdef COMPILER2 -void MacroAssembler::fast_lock(Register Roop, Register Rbox, Register Rscratch, Register Rscratch2 AARCH64_ONLY_ARG(Register Rscratch3)) +void MacroAssembler::fast_lock(Register Roop, Register Rbox, Register Rscratch, Register Rscratch2) { assert(VM_Version::supports_ldrex(), "unsupported, yet?"); @@ -2918,11 +1980,7 @@ void MacroAssembler::fast_lock(Register Roop, Register Rbox, Register Rscratch, if (UseBiasedLocking && !UseOptoBiasInlining) { Label failed; -#ifdef AARCH64 - biased_locking_enter(Roop, Rmark, Rscratch, false, Rscratch3, done, failed); -#else biased_locking_enter(Roop, Rmark, Rscratch, false, noreg, done, failed); -#endif bind(failed); } @@ -2933,17 +1991,6 @@ void MacroAssembler::fast_lock(Register Roop, Register Rbox, Register Rscratch, // Check for recursive lock // See comments in InterpreterMacroAssembler::lock_object for // explanations on the fast recursive locking check. -#ifdef AARCH64 - intptr_t mask = ((intptr_t)3) - ((intptr_t)os::vm_page_size()); - Assembler::LogicalImmediate imm(mask, false); - mov(Rscratch, SP); - sub(Rscratch, Rmark, Rscratch); - ands(Rscratch, Rscratch, imm); - // set to zero if recursive lock, set to non zero otherwise (see discussion in JDK-8153107) - str(Rscratch, Address(Rbox, BasicLock::displaced_header_offset_in_bytes())); - b(done); - -#else // -1- test low 2 bits movs(Rscratch, AsmOperand(Rmark, lsl, 30)); // -2- test (hdr - SP) if the low two bits are 0 @@ -2953,7 +2000,6 @@ void MacroAssembler::fast_lock(Register Roop, Register Rbox, Register Rscratch, // set to zero if recursive lock, set to non zero otherwise (see discussion in JDK-8153107) str(Rscratch, Address(Rbox, BasicLock::displaced_header_offset_in_bytes())); b(done); -#endif bind(fast_lock); str(Rmark, Address(Rbox, BasicLock::displaced_header_offset_in_bytes())); @@ -2966,7 +2012,7 @@ void MacroAssembler::fast_lock(Register Roop, Register Rbox, Register Rscratch, } -void MacroAssembler::fast_unlock(Register Roop, Register Rbox, Register Rscratch, Register Rscratch2 AARCH64_ONLY_ARG(Register Rscratch3)) +void MacroAssembler::fast_unlock(Register Roop, Register Rbox, Register Rscratch, Register Rscratch2) { assert(VM_Version::supports_ldrex(), "unsupported, yet?"); diff --git a/src/hotspot/cpu/arm/macroAssembler_arm.hpp b/src/hotspot/cpu/arm/macroAssembler_arm.hpp index 2f43f6a74fb..3b137f69ec1 100644 --- a/src/hotspot/cpu/arm/macroAssembler_arm.hpp +++ b/src/hotspot/cpu/arm/macroAssembler_arm.hpp @@ -229,10 +229,6 @@ public: // this was subsequently modified to its present name and return type virtual RegisterOrConstant delayed_value_impl(intptr_t* delayed_value_addr, Register tmp, int offset); -#ifdef AARCH64 -# define NOT_IMPLEMENTED() unimplemented("NYI at " __FILE__ ":" XSTR(__LINE__)) -# define NOT_TESTED() warn("Not tested at " __FILE__ ":" XSTR(__LINE__)) -#endif void align(int modulus); @@ -275,7 +271,7 @@ public: // Always sets/resets sp, which default to SP if (last_sp == noreg) // Optionally sets/resets fp (use noreg to avoid setting it) - // Always sets/resets pc on AArch64; optionally sets/resets pc on 32-bit ARM depending on save_last_java_pc flag + // Optionally sets/resets pc depending on save_last_java_pc flag // Note: when saving PC, set_last_Java_frame returns PC's offset in the code section // (for oop_maps offset computation) int set_last_Java_frame(Register last_sp, Register last_fp, bool save_last_java_pc, Register tmp); @@ -399,7 +395,6 @@ public: void resolve_jobject(Register value, Register tmp1, Register tmp2); -#ifndef AARCH64 void nop() { mov(R0, R0); } @@ -439,7 +434,6 @@ public: void fpops(FloatRegister fd, AsmCondition cond = al) { fldmias(SP, FloatRegisterSet(fd), writeback, cond); } -#endif // !AARCH64 // Order access primitives enum Membar_mask_bits { @@ -449,15 +443,10 @@ public: LoadLoad = 1 << 0 }; -#ifdef AARCH64 - // tmp register is not used on AArch64, this parameter is provided solely for better compatibility with 32-bit ARM - void membar(Membar_mask_bits order_constraint, Register tmp = noreg); -#else void membar(Membar_mask_bits mask, Register tmp, bool preserve_flags = true, Register load_tgt = noreg); -#endif void breakpoint(AsmCondition cond = al); void stop(const char* msg); @@ -489,47 +478,28 @@ public: void add_slow(Register rd, Register rn, int c); void sub_slow(Register rd, Register rn, int c); -#ifdef AARCH64 - static int mov_slow_helper(Register rd, intptr_t c, MacroAssembler* masm /* optional */); -#endif - void mov_slow(Register rd, intptr_t c NOT_AARCH64_ARG(AsmCondition cond = al)); + void mov_slow(Register rd, intptr_t c, AsmCondition cond = al); void mov_slow(Register rd, const char *string); void mov_slow(Register rd, address addr); void patchable_mov_oop(Register rd, jobject o, int oop_index) { - mov_oop(rd, o, oop_index AARCH64_ONLY_ARG(true)); + mov_oop(rd, o, oop_index); } - void mov_oop(Register rd, jobject o, int index = 0 - AARCH64_ONLY_ARG(bool patchable = false) - NOT_AARCH64_ARG(AsmCondition cond = al)); - + void mov_oop(Register rd, jobject o, int index = 0, AsmCondition cond = al); void patchable_mov_metadata(Register rd, Metadata* o, int index) { - mov_metadata(rd, o, index AARCH64_ONLY_ARG(true)); + mov_metadata(rd, o, index); } - void mov_metadata(Register rd, Metadata* o, int index = 0 AARCH64_ONLY_ARG(bool patchable = false)); + void mov_metadata(Register rd, Metadata* o, int index = 0); - void mov_float(FloatRegister fd, jfloat c NOT_AARCH64_ARG(AsmCondition cond = al)); - void mov_double(FloatRegister fd, jdouble c NOT_AARCH64_ARG(AsmCondition cond = al)); + void mov_float(FloatRegister fd, jfloat c, AsmCondition cond = al); + void mov_double(FloatRegister fd, jdouble c, AsmCondition cond = al); -#ifdef AARCH64 - int mov_pc_to(Register rd) { - Label L; - adr(rd, L); - bind(L); - return offset(); - } -#endif // Note: this variant of mov_address assumes the address moves with // the code. Do *not* implement it with non-relocated instructions, // unless PC-relative. -#ifdef AARCH64 - void mov_relative_address(Register rd, address addr) { - adr(rd, addr); - } -#else void mov_relative_address(Register rd, address addr, AsmCondition cond = al) { int offset = addr - pc() - 8; assert((offset & 3) == 0, "bad alignment"); @@ -541,7 +511,6 @@ public: sub(rd, PC, -offset, cond); } } -#endif // AARCH64 // Runtime address that may vary from one execution to another. The // symbolic_reference describes what the address is, allowing @@ -562,7 +531,6 @@ public: mov_slow(rd, (intptr_t)addr); return; } -#ifndef AARCH64 if (VM_Version::supports_movw()) { relocate(rspec); int c = (int)addr; @@ -572,15 +540,11 @@ public: } return; } -#endif Label skip_literal; InlinedAddress addr_literal(addr, rspec); ldr_literal(rd, addr_literal); b(skip_literal); bind_literal(addr_literal); - // AARCH64 WARNING: because of alignment padding, extra padding - // may be required to get a consistent size for C2, or rules must - // overestimate size see MachEpilogNode::size bind(skip_literal); } @@ -594,45 +558,28 @@ public: assert(L.rspec().type() != relocInfo::runtime_call_type, "avoid ldr_literal for calls"); assert(L.rspec().type() != relocInfo::static_call_type, "avoid ldr_literal for calls"); relocate(L.rspec()); -#ifdef AARCH64 - ldr(rd, target(L.label)); -#else ldr(rd, Address(PC, target(L.label) - pc() - 8)); -#endif } void ldr_literal(Register rd, InlinedString& L) { const char* msg = L.msg(); if (code()->consts()->contains((address)msg)) { // string address moves with the code -#ifdef AARCH64 - ldr(rd, (address)msg); -#else ldr(rd, Address(PC, ((address)msg) - pc() - 8)); -#endif return; } // Warning: use external strings with care. They are not relocated // if the code moves. If needed, use code_string to move them // to the consts section. -#ifdef AARCH64 - ldr(rd, target(L.label)); -#else ldr(rd, Address(PC, target(L.label) - pc() - 8)); -#endif } void ldr_literal(Register rd, InlinedMetadata& L) { // relocation done in the bind_literal for metadatas -#ifdef AARCH64 - ldr(rd, target(L.label)); -#else ldr(rd, Address(PC, target(L.label) - pc() - 8)); -#endif } void bind_literal(InlinedAddress& L) { - AARCH64_ONLY(align(wordSize)); bind(L.label); assert(L.rspec().type() != relocInfo::metadata_type, "Must use InlinedMetadata"); // We currently do not use oop 'bound' literals. @@ -650,13 +597,11 @@ public: // to detect errors. return; } - AARCH64_ONLY(align(wordSize)); bind(L.label); AbstractAssembler::emit_address((address)L.msg()); } void bind_literal(InlinedMetadata& L) { - AARCH64_ONLY(align(wordSize)); bind(L.label); relocate(metadata_Relocation::spec_for_immediate()); AbstractAssembler::emit_address((address)L.data()); @@ -665,138 +610,106 @@ public: void resolve_oop_handle(Register result); void load_mirror(Register mirror, Register method, Register tmp); - // Porting layer between 32-bit ARM and AArch64 - -#define COMMON_INSTR_1(common_mnemonic, aarch64_mnemonic, arm32_mnemonic, arg_type) \ +#define ARM_INSTR_1(common_mnemonic, arm32_mnemonic, arg_type) \ void common_mnemonic(arg_type arg) { \ - AARCH64_ONLY(aarch64_mnemonic) NOT_AARCH64(arm32_mnemonic) (arg); \ + arm32_mnemonic(arg); \ } -#define COMMON_INSTR_2(common_mnemonic, aarch64_mnemonic, arm32_mnemonic, arg1_type, arg2_type) \ +#define ARM_INSTR_2(common_mnemonic, arm32_mnemonic, arg1_type, arg2_type) \ void common_mnemonic(arg1_type arg1, arg2_type arg2) { \ - AARCH64_ONLY(aarch64_mnemonic) NOT_AARCH64(arm32_mnemonic) (arg1, arg2); \ + arm32_mnemonic(arg1, arg2); \ } -#define COMMON_INSTR_3(common_mnemonic, aarch64_mnemonic, arm32_mnemonic, arg1_type, arg2_type, arg3_type) \ +#define ARM_INSTR_3(common_mnemonic, arm32_mnemonic, arg1_type, arg2_type, arg3_type) \ void common_mnemonic(arg1_type arg1, arg2_type arg2, arg3_type arg3) { \ - AARCH64_ONLY(aarch64_mnemonic) NOT_AARCH64(arm32_mnemonic) (arg1, arg2, arg3); \ + arm32_mnemonic(arg1, arg2, arg3); \ } - COMMON_INSTR_1(jump, br, bx, Register) - COMMON_INSTR_1(call, blr, blx, Register) + ARM_INSTR_1(jump, bx, Register) + ARM_INSTR_1(call, blx, Register) - COMMON_INSTR_2(cbz_32, cbz_w, cbz, Register, Label&) - COMMON_INSTR_2(cbnz_32, cbnz_w, cbnz, Register, Label&) + ARM_INSTR_2(cbz_32, cbz, Register, Label&) + ARM_INSTR_2(cbnz_32, cbnz, Register, Label&) - COMMON_INSTR_2(ldr_u32, ldr_w, ldr, Register, Address) - COMMON_INSTR_2(ldr_s32, ldrsw, ldr, Register, Address) - COMMON_INSTR_2(str_32, str_w, str, Register, Address) + ARM_INSTR_2(ldr_u32, ldr, Register, Address) + ARM_INSTR_2(ldr_s32, ldr, Register, Address) + ARM_INSTR_2(str_32, str, Register, Address) - COMMON_INSTR_2(mvn_32, mvn_w, mvn, Register, Register) - COMMON_INSTR_2(cmp_32, cmp_w, cmp, Register, Register) - COMMON_INSTR_2(neg_32, neg_w, neg, Register, Register) - COMMON_INSTR_2(clz_32, clz_w, clz, Register, Register) - COMMON_INSTR_2(rbit_32, rbit_w, rbit, Register, Register) + ARM_INSTR_2(mvn_32, mvn, Register, Register) + ARM_INSTR_2(cmp_32, cmp, Register, Register) + ARM_INSTR_2(neg_32, neg, Register, Register) + ARM_INSTR_2(clz_32, clz, Register, Register) + ARM_INSTR_2(rbit_32, rbit, Register, Register) - COMMON_INSTR_2(cmp_32, cmp_w, cmp, Register, int) - COMMON_INSTR_2(cmn_32, cmn_w, cmn, Register, int) + ARM_INSTR_2(cmp_32, cmp, Register, int) + ARM_INSTR_2(cmn_32, cmn, Register, int) - COMMON_INSTR_3(add_32, add_w, add, Register, Register, Register) - COMMON_INSTR_3(sub_32, sub_w, sub, Register, Register, Register) - COMMON_INSTR_3(subs_32, subs_w, subs, Register, Register, Register) - COMMON_INSTR_3(mul_32, mul_w, mul, Register, Register, Register) - COMMON_INSTR_3(and_32, andr_w, andr, Register, Register, Register) - COMMON_INSTR_3(orr_32, orr_w, orr, Register, Register, Register) - COMMON_INSTR_3(eor_32, eor_w, eor, Register, Register, Register) + ARM_INSTR_3(add_32, add, Register, Register, Register) + ARM_INSTR_3(sub_32, sub, Register, Register, Register) + ARM_INSTR_3(subs_32, subs, Register, Register, Register) + ARM_INSTR_3(mul_32, mul, Register, Register, Register) + ARM_INSTR_3(and_32, andr, Register, Register, Register) + ARM_INSTR_3(orr_32, orr, Register, Register, Register) + ARM_INSTR_3(eor_32, eor, Register, Register, Register) - COMMON_INSTR_3(add_32, add_w, add, Register, Register, AsmOperand) - COMMON_INSTR_3(sub_32, sub_w, sub, Register, Register, AsmOperand) - COMMON_INSTR_3(orr_32, orr_w, orr, Register, Register, AsmOperand) - COMMON_INSTR_3(eor_32, eor_w, eor, Register, Register, AsmOperand) - COMMON_INSTR_3(and_32, andr_w, andr, Register, Register, AsmOperand) + ARM_INSTR_3(add_32, add, Register, Register, AsmOperand) + ARM_INSTR_3(sub_32, sub, Register, Register, AsmOperand) + ARM_INSTR_3(orr_32, orr, Register, Register, AsmOperand) + ARM_INSTR_3(eor_32, eor, Register, Register, AsmOperand) + ARM_INSTR_3(and_32, andr, Register, Register, AsmOperand) - COMMON_INSTR_3(add_32, add_w, add, Register, Register, int) - COMMON_INSTR_3(adds_32, adds_w, adds, Register, Register, int) - COMMON_INSTR_3(sub_32, sub_w, sub, Register, Register, int) - COMMON_INSTR_3(subs_32, subs_w, subs, Register, Register, int) + ARM_INSTR_3(add_32, add, Register, Register, int) + ARM_INSTR_3(adds_32, adds, Register, Register, int) + ARM_INSTR_3(sub_32, sub, Register, Register, int) + ARM_INSTR_3(subs_32, subs, Register, Register, int) - COMMON_INSTR_2(tst_32, tst_w, tst, Register, unsigned int) - COMMON_INSTR_2(tst_32, tst_w, tst, Register, AsmOperand) + ARM_INSTR_2(tst_32, tst, Register, unsigned int) + ARM_INSTR_2(tst_32, tst, Register, AsmOperand) - COMMON_INSTR_3(and_32, andr_w, andr, Register, Register, uint) - COMMON_INSTR_3(orr_32, orr_w, orr, Register, Register, uint) - COMMON_INSTR_3(eor_32, eor_w, eor, Register, Register, uint) + ARM_INSTR_3(and_32, andr, Register, Register, uint) + ARM_INSTR_3(orr_32, orr, Register, Register, uint) + ARM_INSTR_3(eor_32, eor, Register, Register, uint) - COMMON_INSTR_1(cmp_zero_float, fcmp0_s, fcmpzs, FloatRegister) - COMMON_INSTR_1(cmp_zero_double, fcmp0_d, fcmpzd, FloatRegister) + ARM_INSTR_1(cmp_zero_float, fcmpzs, FloatRegister) + ARM_INSTR_1(cmp_zero_double, fcmpzd, FloatRegister) - COMMON_INSTR_2(ldr_float, ldr_s, flds, FloatRegister, Address) - COMMON_INSTR_2(str_float, str_s, fsts, FloatRegister, Address) - COMMON_INSTR_2(mov_float, fmov_s, fcpys, FloatRegister, FloatRegister) - COMMON_INSTR_2(neg_float, fneg_s, fnegs, FloatRegister, FloatRegister) - COMMON_INSTR_2(abs_float, fabs_s, fabss, FloatRegister, FloatRegister) - COMMON_INSTR_2(sqrt_float, fsqrt_s, fsqrts, FloatRegister, FloatRegister) - COMMON_INSTR_2(cmp_float, fcmp_s, fcmps, FloatRegister, FloatRegister) + ARM_INSTR_2(ldr_float, flds, FloatRegister, Address) + ARM_INSTR_2(str_float, fsts, FloatRegister, Address) + ARM_INSTR_2(mov_float, fcpys, FloatRegister, FloatRegister) + ARM_INSTR_2(neg_float, fnegs, FloatRegister, FloatRegister) + ARM_INSTR_2(abs_float, fabss, FloatRegister, FloatRegister) + ARM_INSTR_2(sqrt_float, fsqrts, FloatRegister, FloatRegister) + ARM_INSTR_2(cmp_float, fcmps, FloatRegister, FloatRegister) - COMMON_INSTR_3(add_float, fadd_s, fadds, FloatRegister, FloatRegister, FloatRegister) - COMMON_INSTR_3(sub_float, fsub_s, fsubs, FloatRegister, FloatRegister, FloatRegister) - COMMON_INSTR_3(mul_float, fmul_s, fmuls, FloatRegister, FloatRegister, FloatRegister) - COMMON_INSTR_3(div_float, fdiv_s, fdivs, FloatRegister, FloatRegister, FloatRegister) + ARM_INSTR_3(add_float, fadds, FloatRegister, FloatRegister, FloatRegister) + ARM_INSTR_3(sub_float, fsubs, FloatRegister, FloatRegister, FloatRegister) + ARM_INSTR_3(mul_float, fmuls, FloatRegister, FloatRegister, FloatRegister) + ARM_INSTR_3(div_float, fdivs, FloatRegister, FloatRegister, FloatRegister) - COMMON_INSTR_2(ldr_double, ldr_d, fldd, FloatRegister, Address) - COMMON_INSTR_2(str_double, str_d, fstd, FloatRegister, Address) - COMMON_INSTR_2(mov_double, fmov_d, fcpyd, FloatRegister, FloatRegister) - COMMON_INSTR_2(neg_double, fneg_d, fnegd, FloatRegister, FloatRegister) - COMMON_INSTR_2(cmp_double, fcmp_d, fcmpd, FloatRegister, FloatRegister) - COMMON_INSTR_2(abs_double, fabs_d, fabsd, FloatRegister, FloatRegister) - COMMON_INSTR_2(sqrt_double, fsqrt_d, fsqrtd, FloatRegister, FloatRegister) + ARM_INSTR_2(ldr_double, fldd, FloatRegister, Address) + ARM_INSTR_2(str_double, fstd, FloatRegister, Address) + ARM_INSTR_2(mov_double, fcpyd, FloatRegister, FloatRegister) + ARM_INSTR_2(neg_double, fnegd, FloatRegister, FloatRegister) + ARM_INSTR_2(cmp_double, fcmpd, FloatRegister, FloatRegister) + ARM_INSTR_2(abs_double, fabsd, FloatRegister, FloatRegister) + ARM_INSTR_2(sqrt_double, fsqrtd, FloatRegister, FloatRegister) - COMMON_INSTR_3(add_double, fadd_d, faddd, FloatRegister, FloatRegister, FloatRegister) - COMMON_INSTR_3(sub_double, fsub_d, fsubd, FloatRegister, FloatRegister, FloatRegister) - COMMON_INSTR_3(mul_double, fmul_d, fmuld, FloatRegister, FloatRegister, FloatRegister) - COMMON_INSTR_3(div_double, fdiv_d, fdivd, FloatRegister, FloatRegister, FloatRegister) + ARM_INSTR_3(add_double, faddd, FloatRegister, FloatRegister, FloatRegister) + ARM_INSTR_3(sub_double, fsubd, FloatRegister, FloatRegister, FloatRegister) + ARM_INSTR_3(mul_double, fmuld, FloatRegister, FloatRegister, FloatRegister) + ARM_INSTR_3(div_double, fdivd, FloatRegister, FloatRegister, FloatRegister) - COMMON_INSTR_2(convert_f2d, fcvt_ds, fcvtds, FloatRegister, FloatRegister) - COMMON_INSTR_2(convert_d2f, fcvt_sd, fcvtsd, FloatRegister, FloatRegister) + ARM_INSTR_2(convert_f2d, fcvtds, FloatRegister, FloatRegister) + ARM_INSTR_2(convert_d2f, fcvtsd, FloatRegister, FloatRegister) - COMMON_INSTR_2(mov_fpr2gpr_float, fmov_ws, fmrs, Register, FloatRegister) + ARM_INSTR_2(mov_fpr2gpr_float, fmrs, Register, FloatRegister) -#undef COMMON_INSTR_1 -#undef COMMON_INSTR_2 -#undef COMMON_INSTR_3 +#undef ARM_INSTR_1 +#undef ARM_INSTR_2 +#undef ARM_INSTR_3 -#ifdef AARCH64 - - void mov(Register dst, Register src, AsmCondition cond) { - if (cond == al) { - mov(dst, src); - } else { - csel(dst, src, dst, cond); - } - } - - // Propagate other overloaded "mov" methods from Assembler. - void mov(Register dst, Register src) { Assembler::mov(dst, src); } - void mov(Register rd, int imm) { Assembler::mov(rd, imm); } - - void mov(Register dst, int imm, AsmCondition cond) { - assert(imm == 0 || imm == 1, ""); - if (imm == 0) { - mov(dst, ZR, cond); - } else if (imm == 1) { - csinc(dst, dst, ZR, inverse(cond)); - } else if (imm == -1) { - csinv(dst, dst, ZR, inverse(cond)); - } else { - fatal("illegal mov(R%d,%d,cond)", dst->encoding(), imm); - } - } - - void movs(Register dst, Register src) { adds(dst, src, 0); } - -#else // AARCH64 void tbz(Register rt, int bit, Label& L) { assert(0 <= bit && bit < BitsPerWord, "bit number is out of range"); @@ -829,166 +742,91 @@ public: bx(dst); } -#endif // AARCH64 Register zero_register(Register tmp) { -#ifdef AARCH64 - return ZR; -#else mov(tmp, 0); return tmp; -#endif } void logical_shift_left(Register dst, Register src, int shift) { -#ifdef AARCH64 - _lsl(dst, src, shift); -#else mov(dst, AsmOperand(src, lsl, shift)); -#endif } void logical_shift_left_32(Register dst, Register src, int shift) { -#ifdef AARCH64 - _lsl_w(dst, src, shift); -#else mov(dst, AsmOperand(src, lsl, shift)); -#endif } void logical_shift_right(Register dst, Register src, int shift) { -#ifdef AARCH64 - _lsr(dst, src, shift); -#else mov(dst, AsmOperand(src, lsr, shift)); -#endif } void arith_shift_right(Register dst, Register src, int shift) { -#ifdef AARCH64 - _asr(dst, src, shift); -#else mov(dst, AsmOperand(src, asr, shift)); -#endif } void asr_32(Register dst, Register src, int shift) { -#ifdef AARCH64 - _asr_w(dst, src, shift); -#else mov(dst, AsmOperand(src, asr, shift)); -#endif } // If holds, compares r1 and r2. Otherwise, flags are set so that does not hold. void cond_cmp(Register r1, Register r2, AsmCondition cond) { -#ifdef AARCH64 - ccmp(r1, r2, flags_for_condition(inverse(cond)), cond); -#else cmp(r1, r2, cond); -#endif } // If holds, compares r and imm. Otherwise, flags are set so that does not hold. void cond_cmp(Register r, int imm, AsmCondition cond) { -#ifdef AARCH64 - ccmp(r, imm, flags_for_condition(inverse(cond)), cond); -#else cmp(r, imm, cond); -#endif } void align_reg(Register dst, Register src, int align) { assert (is_power_of_2(align), "should be"); -#ifdef AARCH64 - andr(dst, src, ~(uintx)(align-1)); -#else bic(dst, src, align-1); -#endif } void prefetch_read(Address addr) { -#ifdef AARCH64 - prfm(pldl1keep, addr); -#else pld(addr); -#endif } void raw_push(Register r1, Register r2) { -#ifdef AARCH64 - stp(r1, r2, Address(SP, -2*wordSize, pre_indexed)); -#else assert(r1->encoding() < r2->encoding(), "should be ordered"); push(RegisterSet(r1) | RegisterSet(r2)); -#endif } void raw_pop(Register r1, Register r2) { -#ifdef AARCH64 - ldp(r1, r2, Address(SP, 2*wordSize, post_indexed)); -#else assert(r1->encoding() < r2->encoding(), "should be ordered"); pop(RegisterSet(r1) | RegisterSet(r2)); -#endif } void raw_push(Register r1, Register r2, Register r3) { -#ifdef AARCH64 - raw_push(r1, r2); - raw_push(r3, ZR); -#else assert(r1->encoding() < r2->encoding() && r2->encoding() < r3->encoding(), "should be ordered"); push(RegisterSet(r1) | RegisterSet(r2) | RegisterSet(r3)); -#endif } void raw_pop(Register r1, Register r2, Register r3) { -#ifdef AARCH64 - raw_pop(r3, ZR); - raw_pop(r1, r2); -#else assert(r1->encoding() < r2->encoding() && r2->encoding() < r3->encoding(), "should be ordered"); pop(RegisterSet(r1) | RegisterSet(r2) | RegisterSet(r3)); -#endif } // Restores registers r1 and r2 previously saved by raw_push(r1, r2, ret_addr) and returns by ret_addr. Clobbers LR. void raw_pop_and_ret(Register r1, Register r2) { -#ifdef AARCH64 - raw_pop(r1, r2, LR); - ret(); -#else raw_pop(r1, r2, PC); -#endif } void indirect_jump(Address addr, Register scratch) { -#ifdef AARCH64 - ldr(scratch, addr); - br(scratch); -#else ldr(PC, addr); -#endif } void indirect_jump(InlinedAddress& literal, Register scratch) { -#ifdef AARCH64 - ldr_literal(scratch, literal); - br(scratch); -#else ldr_literal(PC, literal); -#endif } -#ifndef AARCH64 void neg(Register dst, Register src) { rsb(dst, src, 0); } -#endif void branch_if_negative_32(Register r, Label& L) { - // Note about branch_if_negative_32() / branch_if_any_negative_32() implementation for AArch64: + // TODO: This function and branch_if_any_negative_32 could possibly + // be revised after the aarch64 removal. // tbnz is not used instead of tst & b.mi because destination may be out of tbnz range (+-32KB) // since these methods are used in LIR_Assembler::emit_arraycopy() to jump to stub entry. tst_32(r, r); @@ -996,56 +834,31 @@ public: } void branch_if_any_negative_32(Register r1, Register r2, Register tmp, Label& L) { -#ifdef AARCH64 - orr_32(tmp, r1, r2); - tst_32(tmp, tmp); -#else orrs(tmp, r1, r2); -#endif b(L, mi); } void branch_if_any_negative_32(Register r1, Register r2, Register r3, Register tmp, Label& L) { orr_32(tmp, r1, r2); -#ifdef AARCH64 - orr_32(tmp, tmp, r3); - tst_32(tmp, tmp); -#else orrs(tmp, tmp, r3); -#endif b(L, mi); } void add_ptr_scaled_int32(Register dst, Register r1, Register r2, int shift) { -#ifdef AARCH64 - add(dst, r1, r2, ex_sxtw, shift); -#else add(dst, r1, AsmOperand(r2, lsl, shift)); -#endif } void sub_ptr_scaled_int32(Register dst, Register r1, Register r2, int shift) { -#ifdef AARCH64 - sub(dst, r1, r2, ex_sxtw, shift); -#else sub(dst, r1, AsmOperand(r2, lsl, shift)); -#endif } // klass oop manipulations if compressed -#ifdef AARCH64 - void load_klass(Register dst_klass, Register src_oop); -#else void load_klass(Register dst_klass, Register src_oop, AsmCondition cond = al); -#endif // AARCH64 void store_klass(Register src_klass, Register dst_oop); -#ifdef AARCH64 - void store_klass_gap(Register dst); -#endif // AARCH64 // oop manipulations @@ -1060,39 +873,6 @@ public: // All other registers are preserved. void resolve(DecoratorSet decorators, Register obj); -#ifdef AARCH64 - void encode_heap_oop(Register dst, Register src); - void encode_heap_oop(Register r) { - encode_heap_oop(r, r); - } - void decode_heap_oop(Register dst, Register src); - void decode_heap_oop(Register r) { - decode_heap_oop(r, r); - } - -#ifdef COMPILER2 - void encode_heap_oop_not_null(Register dst, Register src); - void decode_heap_oop_not_null(Register dst, Register src); - - void set_narrow_klass(Register dst, Klass* k); - void set_narrow_oop(Register dst, jobject obj); -#endif - - void encode_klass_not_null(Register r); - void encode_klass_not_null(Register dst, Register src); - void decode_klass_not_null(Register r); - void decode_klass_not_null(Register dst, Register src); - - void reinit_heapbase(); - -#ifdef ASSERT - void verify_heapbase(const char* msg); -#endif // ASSERT - - static int instr_count_for_mov_slow(intptr_t c); - static int instr_count_for_mov_slow(address addr); - static int instr_count_for_decode_klass_not_null(); -#endif // AARCH64 void ldr_global_ptr(Register reg, address address_of_global); void ldr_global_s32(Register reg, address address_of_global); @@ -1108,12 +888,7 @@ public: assert ((offset() & (wordSize-1)) == 0, "should be aligned by word size"); -#ifdef AARCH64 - emit_int32(address_placeholder_instruction); - emit_int32(address_placeholder_instruction); -#else AbstractAssembler::emit_address((address)address_placeholder_instruction); -#endif } void b(address target, AsmCondition cond = al) { @@ -1124,15 +899,14 @@ public: Assembler::b(target(L), cond); } - void bl(address target NOT_AARCH64_ARG(AsmCondition cond = al)) { - Assembler::bl(target NOT_AARCH64_ARG(cond)); + void bl(address target, AsmCondition cond = al) { + Assembler::bl(target, cond); } - void bl(Label& L NOT_AARCH64_ARG(AsmCondition cond = al)) { + void bl(Label& L, AsmCondition cond = al) { // internal calls - Assembler::bl(target(L) NOT_AARCH64_ARG(cond)); + Assembler::bl(target(L), cond); } -#ifndef AARCH64 void adr(Register dest, Label& L, AsmCondition cond = al) { int delta = target(L) - pc() - 8; if (delta >= 0) { @@ -1141,7 +915,6 @@ public: sub(dest, PC, -delta, cond); } } -#endif // !AARCH64 // Variable-length jump and calls. We now distinguish only the // patchable case from the other cases. Patchable must be @@ -1165,30 +938,23 @@ public: // specified to allow future optimizations. void jump(address target, relocInfo::relocType rtype = relocInfo::runtime_call_type, - Register scratch = AARCH64_ONLY(Rtemp) NOT_AARCH64(noreg) -#ifndef AARCH64 - , AsmCondition cond = al -#endif - ); + Register scratch = noreg, AsmCondition cond = al); void call(address target, - RelocationHolder rspec - NOT_AARCH64_ARG(AsmCondition cond = al)); + RelocationHolder rspec, AsmCondition cond = al); void call(address target, - relocInfo::relocType rtype = relocInfo::runtime_call_type - NOT_AARCH64_ARG(AsmCondition cond = al)) { - call(target, Relocation::spec_simple(rtype) NOT_AARCH64_ARG(cond)); + relocInfo::relocType rtype = relocInfo::runtime_call_type, + AsmCondition cond = al) { + call(target, Relocation::spec_simple(rtype), cond); } void jump(AddressLiteral dest) { jump(dest.target(), dest.reloc()); } -#ifndef AARCH64 void jump(address dest, relocInfo::relocType rtype, AsmCondition cond) { jump(dest, rtype, Rtemp, cond); } -#endif void call(AddressLiteral dest) { call(dest.target(), dest.reloc()); @@ -1206,10 +972,7 @@ public: // specified to allow future optimizations. void patchable_jump(address target, relocInfo::relocType rtype = relocInfo::runtime_call_type, - Register scratch = AARCH64_ONLY(Rtemp) NOT_AARCH64(noreg) -#ifndef AARCH64 - , AsmCondition cond = al -#endif + Register scratch = noreg, AsmCondition cond = al ); // patchable_call may scratch Rtemp @@ -1223,13 +986,7 @@ public: return patchable_call(target, Relocation::spec_simple(rtype), c2); } -#if defined(AARCH64) && defined(COMPILER2) - static int call_size(address target, bool far, bool patchable); -#endif -#ifdef AARCH64 - static bool page_reachable_from_cache(address target); -#endif static bool _reachable_from_cache(address target); static bool _cache_fully_reachable(); bool cache_fully_reachable(); @@ -1239,15 +996,8 @@ public: void sign_extend(Register rd, Register rn, int bits); inline void zap_high_non_significant_bits(Register r) { -#ifdef AARCH64 - if(ZapHighNonSignificantBits) { - movk(r, 0xBAAD, 48); - movk(r, 0xF00D, 32); - } -#endif } -#ifndef AARCH64 void cmpoop(Register obj1, Register obj2); void long_move(Register rd_lo, Register rd_hi, @@ -1263,7 +1013,6 @@ public: void atomic_cas(Register tmpreg1, Register tmpreg2, Register oldval, Register newval, Register base, int offset); void atomic_cas_bool(Register oldval, Register newval, Register base, int offset, Register tmpreg); void atomic_cas64(Register temp_lo, Register temp_hi, Register temp_result, Register oldval_lo, Register oldval_hi, Register newval_lo, Register newval_hi, Register base, int offset); -#endif // !AARCH64 void cas_for_lock_acquire(Register oldval, Register newval, Register base, Register tmp, Label &slow_case, bool allow_fallthrough_on_failure = false, bool one_shot = false); void cas_for_lock_release(Register oldval, Register newval, Register base, Register tmp, Label &slow_case, bool allow_fallthrough_on_failure = false, bool one_shot = false); @@ -1286,14 +1035,9 @@ public: // size must not exceed wordSize (i.e. 8-byte values are not supported on 32-bit ARM); // each of these calls generates exactly one load or store instruction, // so src can be pre- or post-indexed address. -#ifdef AARCH64 - void load_sized_value(Register dst, Address src, size_t size_in_bytes, bool is_signed); - void store_sized_value(Register src, Address dst, size_t size_in_bytes); -#else // 32-bit ARM variants also support conditional execution void load_sized_value(Register dst, Address src, size_t size_in_bytes, bool is_signed, AsmCondition cond = al); void store_sized_value(Register src, Address dst, size_t size_in_bytes, AsmCondition cond = al); -#endif void lookup_interface_method(Register recv_klass, Register intf_klass, @@ -1315,11 +1059,7 @@ public: void ldr_literal(Register rd, AddressLiteral addr) { relocate(addr.rspec()); -#ifdef AARCH64 - ldr(rd, addr.target()); -#else ldr(rd, Address(PC, addr.target() - pc() - 8)); -#endif } void lea(Register Rd, AddressLiteral addr) { @@ -1330,46 +1070,10 @@ public: void restore_default_fp_mode(); #ifdef COMPILER2 -#ifdef AARCH64 - // Code used by cmpFastLock and cmpFastUnlock mach instructions in .ad file. - void fast_lock(Register obj, Register box, Register scratch, Register scratch2, Register scratch3); - void fast_unlock(Register obj, Register box, Register scratch, Register scratch2, Register scratch3); -#else void fast_lock(Register obj, Register box, Register scratch, Register scratch2); void fast_unlock(Register obj, Register box, Register scratch, Register scratch2); #endif -#endif -#ifdef AARCH64 - -#define F(mnemonic) \ - void mnemonic(Register rt, address target) { \ - Assembler::mnemonic(rt, target); \ - } \ - void mnemonic(Register rt, Label& L) { \ - Assembler::mnemonic(rt, target(L)); \ - } - - F(cbz_w); - F(cbnz_w); - F(cbz); - F(cbnz); - -#undef F - -#define F(mnemonic) \ - void mnemonic(Register rt, int bit, address target) { \ - Assembler::mnemonic(rt, bit, target); \ - } \ - void mnemonic(Register rt, int bit, Label& L) { \ - Assembler::mnemonic(rt, bit, target(L)); \ - } - - F(tbz); - F(tbnz); -#undef F - -#endif // AARCH64 }; diff --git a/src/hotspot/cpu/arm/macroAssembler_arm.inline.hpp b/src/hotspot/cpu/arm/macroAssembler_arm.inline.hpp index 96a82ce399d..1fd02c50812 100644 --- a/src/hotspot/cpu/arm/macroAssembler_arm.inline.hpp +++ b/src/hotspot/cpu/arm/macroAssembler_arm.inline.hpp @@ -32,46 +32,9 @@ inline void MacroAssembler::pd_patch_instruction(address branch, address target, const char* file, int line) { int instr = *(int*)branch; - int new_offset = (int)(target - branch NOT_AARCH64(- 8)); + int new_offset = (int)(target - branch - 8); assert((new_offset & 3) == 0, "bad alignment"); -#ifdef AARCH64 - if ((instr & (0x1f << 26)) == (0b00101 << 26)) { - // Unconditional B or BL - assert (is_offset_in_range(new_offset, 26), "offset is too large"); - *(int*)branch = (instr & ~right_n_bits(26)) | encode_offset(new_offset, 26, 0); - } else if ((instr & (0xff << 24)) == (0b01010100 << 24) && (instr & (1 << 4)) == 0) { - // Conditional B - assert (is_offset_in_range(new_offset, 19), "offset is too large"); - *(int*)branch = (instr & ~(right_n_bits(19) << 5)) | encode_offset(new_offset, 19, 5); - } else if ((instr & (0b111111 << 25)) == (0b011010 << 25)) { - // Compare & branch CBZ/CBNZ - assert (is_offset_in_range(new_offset, 19), "offset is too large"); - *(int*)branch = (instr & ~(right_n_bits(19) << 5)) | encode_offset(new_offset, 19, 5); - } else if ((instr & (0b111111 << 25)) == (0b011011 << 25)) { - // Test & branch TBZ/TBNZ - assert (is_offset_in_range(new_offset, 14), "offset is too large"); - *(int*)branch = (instr & ~(right_n_bits(14) << 5)) | encode_offset(new_offset, 14, 5); - } else if ((instr & (0b111011 << 24)) == (0b011000 << 24)) { - // LDR (literal) - unsigned opc = ((unsigned)instr >> 30); - assert (opc != 0b01 || ((uintx)target & 7) == 0, "ldr target should be aligned"); - assert (is_offset_in_range(new_offset, 19), "offset is too large"); - *(int*)branch = (instr & ~(right_n_bits(19) << 5)) | encode_offset(new_offset, 19, 5); - } else if (((instr & (1 << 31)) == 0) && ((instr & (0b11111 << 24)) == (0b10000 << 24))) { - // ADR - assert (is_imm_in_range(new_offset, 21, 0), "offset is too large"); - instr = (instr & ~(right_n_bits(2) << 29)) | (new_offset & 3) << 29; - *(int*)branch = (instr & ~(right_n_bits(19) << 5)) | encode_imm(new_offset >> 2, 19, 0, 5); - } else if((unsigned int)instr == address_placeholder_instruction) { - // address - assert (*(unsigned int *)(branch + InstructionSize) == address_placeholder_instruction, "address placeholder occupies two instructions"); - *(intx*)branch = (intx)target; - } else { - ::tty->print_cr("=============== instruction: 0x%x ================\n", instr); - Unimplemented(); // TODO-AARCH64 - } -#else if ((instr & 0x0e000000) == 0x0a000000) { // B or BL instruction assert(new_offset < 0x2000000 && new_offset > -0x2000000, "encoding constraint"); @@ -98,7 +61,6 @@ inline void MacroAssembler::pd_patch_instruction(address branch, address target, *(int*)branch = (instr & 0xff0ff000) | 1 << 20 | -new_offset; } } -#endif // AARCH64 } #endif // CPU_ARM_VM_MACROASSEMBLER_ARM_INLINE_HPP diff --git a/src/hotspot/cpu/arm/methodHandles_arm.cpp b/src/hotspot/cpu/arm/methodHandles_arm.cpp index 446e6a544bb..152ecde87c6 100644 --- a/src/hotspot/cpu/arm/methodHandles_arm.cpp +++ b/src/hotspot/cpu/arm/methodHandles_arm.cpp @@ -125,15 +125,8 @@ void MethodHandles::jump_from_method_handle(MacroAssembler* _masm, bool for_comp // compiled code in threads for which the event is enabled. Check here for // interp_only_mode if these events CAN be enabled. __ ldr_s32(Rtemp, Address(Rthread, JavaThread::interp_only_mode_offset())); -#ifdef AARCH64 - Label L; - __ cbz(Rtemp, L); - __ indirect_jump(Address(Rmethod, Method::interpreter_entry_offset()), Rtemp); - __ bind(L); -#else __ cmp(Rtemp, 0); __ ldr(PC, Address(Rmethod, Method::interpreter_entry_offset()), ne); -#endif // AARCH64 } const ByteSize entry_offset = for_compiler_entry ? Method::from_compiled_offset() : Method::from_interpreted_offset(); @@ -268,11 +261,7 @@ address MethodHandles::generate_method_handle_interpreter_entry(MacroAssembler* DEBUG_ONLY(rdx_param_size = noreg); } Register rbx_member = rbx_method; // MemberName ptr; incoming method ptr is dead now -#ifdef AARCH64 - __ ldr(rbx_member, Address(Rparams, Interpreter::stackElementSize, post_indexed)); -#else __ pop(rbx_member); -#endif generate_method_handle_dispatch(_masm, iid, rcx_recv, rbx_member, not_for_compiler_entry); } return entry_point; @@ -288,22 +277,15 @@ void MethodHandles::generate_method_handle_dispatch(MacroAssembler* _masm, Register rbx_method = Rmethod; // eventual target of this invocation // temps used in this code are not used in *either* compiled or interpreted calling sequences Register temp1 = (for_compiler_entry ? saved_last_sp_register() : R1_tmp); - Register temp2 = AARCH64_ONLY(R9) NOT_AARCH64(R8); + Register temp2 = R8; Register temp3 = Rtemp; // R12/R16 - Register temp4 = AARCH64_ONLY(Rtemp2) NOT_AARCH64(R5); + Register temp4 = R5; if (for_compiler_entry) { assert(receiver_reg == (iid == vmIntrinsics::_linkToStatic ? noreg : j_rarg0), "only valid assignment"); -#ifdef AARCH64 - assert_different_registers(temp1, j_rarg0, j_rarg1, j_rarg2, j_rarg3, j_rarg4, j_rarg5, j_rarg6, j_rarg7); - assert_different_registers(temp2, j_rarg0, j_rarg1, j_rarg2, j_rarg3, j_rarg4, j_rarg5, j_rarg6, j_rarg7); - assert_different_registers(temp3, j_rarg0, j_rarg1, j_rarg2, j_rarg3, j_rarg4, j_rarg5, j_rarg6, j_rarg7); - assert_different_registers(temp4, j_rarg0, j_rarg1, j_rarg2, j_rarg3, j_rarg4, j_rarg5, j_rarg6, j_rarg7); -#else assert_different_registers(temp1, j_rarg0, j_rarg1, j_rarg2, j_rarg3); assert_different_registers(temp2, j_rarg0, j_rarg1, j_rarg2, j_rarg3); assert_different_registers(temp3, j_rarg0, j_rarg1, j_rarg2, j_rarg3); assert_different_registers(temp4, j_rarg0, j_rarg1, j_rarg2, j_rarg3); -#endif // AARCH64 } assert_different_registers(temp1, temp2, temp3, receiver_reg); assert_different_registers(temp1, temp2, temp3, temp4, member_reg); @@ -353,12 +335,7 @@ void MethodHandles::generate_method_handle_dispatch(MacroAssembler* _masm, __ load_heap_oop(temp2_defc, member_clazz); load_klass_from_Class(_masm, temp2_defc, temp3, temp4); __ verify_klass_ptr(temp2_defc); -#ifdef AARCH64 - // TODO-AARCH64 - __ b(L_ok); -#else __ check_klass_subtype(temp1_recv_klass, temp2_defc, temp3, temp4, noreg, L_ok); -#endif // If we get here, the type check failed! __ stop("receiver class disagrees with MemberName.clazz"); __ bind(L_ok); @@ -484,13 +461,9 @@ enum { // the slop defends against false alarms due to fencepost errors }; -#ifdef AARCH64 -const int trace_mh_nregs = 32; // R0-R30, PC -#else const int trace_mh_nregs = 15; const Register trace_mh_regs[trace_mh_nregs] = {R0, R1, R2, R3, R4, R5, R6, R7, R8, R9, R10, R11, R12, LR, PC}; -#endif // AARCH64 void trace_method_handle_stub(const char* adaptername, intptr_t* saved_regs, @@ -501,7 +474,7 @@ void trace_method_handle_stub(const char* adaptername, strstr(adaptername, "linkTo") == NULL); // static linkers don't have MH intptr_t* entry_sp = (intptr_t*) &saved_regs[trace_mh_nregs]; // just after the saved regs intptr_t* saved_sp = (intptr_t*) saved_regs[Rsender_sp->encoding()]; // save of Rsender_sp - intptr_t* last_sp = (intptr_t*) saved_bp[AARCH64_ONLY(frame::interpreter_frame_stack_top_offset) NOT_AARCH64(frame::interpreter_frame_last_sp_offset)]; + intptr_t* last_sp = (intptr_t*) saved_bp[frame::interpreter_frame_last_sp_offset]; intptr_t* base_sp = last_sp; intptr_t mh_reg = (intptr_t)saved_regs[R5_mh->encoding()]; @@ -517,13 +490,9 @@ void trace_method_handle_stub(const char* adaptername, tty->print(" reg dump: "); int i; for (i = 0; i < trace_mh_nregs; i++) { - if (i > 0 && i % AARCH64_ONLY(2) NOT_AARCH64(4) == 0) + if (i > 0 && i % 4 == 0) tty->print("\n + dump: "); -#ifdef AARCH64 - const char* reg_name = (i == trace_mh_nregs-1) ? "pc" : as_Register(i)->name(); -#else const char* reg_name = trace_mh_regs[i]->name(); -#endif tty->print(" %s: " INTPTR_FORMAT, reg_name, p2i((void *)saved_regs[i])); } tty->cr(); diff --git a/src/hotspot/cpu/arm/nativeInst_arm.hpp b/src/hotspot/cpu/arm/nativeInst_arm.hpp index 1b60ed06f3f..8240ab04ce1 100644 --- a/src/hotspot/cpu/arm/nativeInst_arm.hpp +++ b/src/hotspot/cpu/arm/nativeInst_arm.hpp @@ -30,11 +30,7 @@ #include "runtime/os.hpp" -#ifdef AARCH64 -#include "nativeInst_arm_64.hpp" -#else #include "nativeInst_arm_32.hpp" -#endif #endif // CPU_ARM_VM_NATIVEINST_ARM_HPP diff --git a/src/hotspot/cpu/arm/nativeInst_arm_64.cpp b/src/hotspot/cpu/arm/nativeInst_arm_64.cpp deleted file mode 100644 index 3f614d8519a..00000000000 --- a/src/hotspot/cpu/arm/nativeInst_arm_64.cpp +++ /dev/null @@ -1,243 +0,0 @@ -/* - * 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 - * 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 "assembler_arm.inline.hpp" -#include "code/codeCache.hpp" -#include "memory/resourceArea.hpp" -#include "nativeInst_arm.hpp" -#include "oops/compressedOops.inline.hpp" -#include "oops/klass.inline.hpp" -#include "oops/oop.hpp" -#include "runtime/handles.hpp" -#include "runtime/sharedRuntime.hpp" -#include "runtime/stubRoutines.hpp" -#include "utilities/ostream.hpp" -#ifdef COMPILER1 -#include "c1/c1_Runtime1.hpp" -#endif - -void RawNativeInstruction::verify() { - // make sure code pattern is actually an instruction address - address addr = instruction_address(); - if (addr == NULL || ((intptr_t)addr & (instruction_size - 1)) != 0) { - fatal("not an instruction address"); - } -} - -void NativeMovRegMem::set_offset(int x) { - int scale = get_offset_scale(); - assert((x & right_n_bits(scale)) == 0, "offset should be aligned"); - guarantee((x >> 24) == 0, "encoding constraint"); - - if (Assembler::is_unsigned_imm_in_range(x, 12, scale)) { - set_unsigned_imm(x, 12, get_offset_scale(), 10); - return; - } - - // If offset is too large to be placed into single ldr/str instruction, we replace - // ldr/str Rt, [Rn, #offset] - // nop - // with - // add LR, Rn, #offset_hi - // ldr/str Rt, [LR, #offset_lo] - - // Note: Rtemp cannot be used as a temporary register as it could be used - // for value being stored (see LIR_Assembler::reg2mem). - // Patchable NativeMovRegMem instructions are generated in LIR_Assembler::mem2reg and LIR_Assembler::reg2mem - // which do not use LR, so it is free. Also, it does not conflict with LR usages in c1_LIRGenerator_arm.cpp. - const int tmp = LR->encoding(); - const int rn = (encoding() >> 5) & 0x1f; - - NativeInstruction* next = nativeInstruction_at(next_raw_instruction_address()); - assert(next->is_nop(), "must be"); - - next->set_encoding((encoding() & 0xffc0001f) | Assembler::encode_unsigned_imm((x & 0xfff), 12, scale, 10) | tmp << 5); - this->set_encoding(0x91400000 | Assembler::encode_unsigned_imm((x >> 12), 12, 0, 10) | rn << 5 | tmp); -} - -intptr_t NativeMovConstReg::_data() const { -#ifdef COMPILER2 - if (is_movz()) { - // narrow constant or ic call cached value - RawNativeInstruction* ni = next_raw(); - assert(ni->is_movk(), "movz;movk expected"); - uint lo16 = (encoding() >> 5) & 0xffff; - intptr_t hi = 0; - int i = 0; - while (ni->is_movk() && i < 3) { - uint hi16 = (ni->encoding() >> 5) & 0xffff; - int shift = ((ni->encoding() >> 21) & 0x3) << 4; - hi |= (intptr_t)hi16 << shift; - ni = ni->next_raw(); - ++i; - } - return lo16 | hi; - } -#endif - return (intptr_t)(nativeLdrLiteral_at(instruction_address())->literal_value()); -} - -static void raw_set_data(RawNativeInstruction* si, intptr_t x, oop* oop_addr, Metadata** metadata_addr) { -#ifdef COMPILER2 - if (si->is_movz()) { - // narrow constant or ic call cached value - uintptr_t nx = 0; - int val_size = 32; - if (oop_addr != NULL) { - narrowOop encoded_oop = CompressedOops::encode(*oop_addr); - nx = encoded_oop; - } else if (metadata_addr != NULL) { - assert((*metadata_addr)->is_klass(), "expected Klass"); - narrowKlass encoded_k = Klass::encode_klass((Klass *)*metadata_addr); - nx = encoded_k; - } else { - nx = x; - val_size = 64; - } - RawNativeInstruction* ni = si->next_raw(); - uint lo16 = nx & 0xffff; - int shift = 16; - int imm16 = 0xffff << 5; - si->set_encoding((si->encoding() & ~imm16) | (lo16 << 5)); - while (shift < val_size) { - assert(ni->is_movk(), "movk expected"); - assert((((ni->encoding() >> 21) & 0x3) << 4) == shift, "wrong shift"); - uint hi16 = (nx >> shift) & 0xffff; - ni->set_encoding((ni->encoding() & ~imm16) | (hi16 << 5)); - shift += 16; - ni = ni->next_raw(); - } - return; - } -#endif - - assert(si->is_ldr_literal(), "should be"); - - if (oop_addr == NULL && metadata_addr == NULL) { - // A static ldr_literal without oop_relocation - nativeLdrLiteral_at(si->instruction_address())->set_literal_value((address)x); - } else { - // Oop is loaded from oops section - address addr = oop_addr != NULL ? (address)oop_addr : (address)metadata_addr; - int offset = addr - si->instruction_address(); - - assert((((intptr_t)addr) & 0x7) == 0, "target address should be aligned"); - assert((offset & 0x3) == 0, "offset should be aligned"); - - guarantee(Assembler::is_offset_in_range(offset, 19), "offset is not in range"); - nativeLdrLiteral_at(si->instruction_address())->set_literal_address(si->instruction_address() + offset); - } -} - -void NativeMovConstReg::set_data(intptr_t x) { - // Find and replace the oop corresponding to this instruction in oops section - oop* oop_addr = NULL; - Metadata** metadata_addr = NULL; - CodeBlob* cb = CodeCache::find_blob(instruction_address()); - { - nmethod* nm = cb->as_nmethod_or_null(); - if (nm != NULL) { - RelocIterator iter(nm, instruction_address(), next_raw()->instruction_address()); - while (iter.next()) { - if (iter.type() == relocInfo::oop_type) { - oop_addr = iter.oop_reloc()->oop_addr(); - *oop_addr = cast_to_oop(x); - break; - } else if (iter.type() == relocInfo::metadata_type) { - metadata_addr = iter.metadata_reloc()->metadata_addr(); - *metadata_addr = (Metadata*)x; - break; - } - } - } - } - raw_set_data(adjust(this), x, oop_addr, metadata_addr); -} - -void NativeJump::check_verified_entry_alignment(address entry, address verified_entry) { -} - -void NativeJump::patch_verified_entry(address entry, address verified_entry, address dest) { - assert(dest == SharedRuntime::get_handle_wrong_method_stub(), "should be"); - - NativeInstruction* instr = nativeInstruction_at(verified_entry); - assert(instr->is_nop() || instr->encoding() == zombie_illegal_instruction, "required for MT-safe patching"); - instr->set_encoding(zombie_illegal_instruction); -} - -void NativeGeneralJump::replace_mt_safe(address instr_addr, address code_buffer) { - assert (nativeInstruction_at(instr_addr)->is_b(), "MT-safe patching of arbitrary instructions is not allowed"); - assert (nativeInstruction_at(code_buffer)->is_nop(), "MT-safe patching of arbitrary instructions is not allowed"); - nativeInstruction_at(instr_addr)->set_encoding(*(int*)code_buffer); -} - -void NativeGeneralJump::insert_unconditional(address code_pos, address entry) { - // Insert at code_pos unconditional B instruction jumping to entry - intx offset = entry - code_pos; - assert (Assembler::is_offset_in_range(offset, 26), "offset is out of range"); - - NativeInstruction* instr = nativeInstruction_at(code_pos); - assert (instr->is_b() || instr->is_nop(), "MT-safe patching of arbitrary instructions is not allowed"); - - instr->set_encoding(0x5 << 26 | Assembler::encode_offset(offset, 26, 0)); -} - -static address call_for(address return_address) { - CodeBlob* cb = CodeCache::find_blob(return_address); - nmethod* nm = cb->as_nmethod_or_null(); - if (nm == NULL) { - ShouldNotReachHere(); - return NULL; - } - - // Look back 8 instructions (for LIR_Assembler::ic_call and MacroAssembler::patchable_call) - address begin = return_address - 8*NativeInstruction::instruction_size; - if (begin < nm->code_begin()) { - begin = nm->code_begin(); - } - RelocIterator iter(nm, begin, return_address); - while (iter.next()) { - Relocation* reloc = iter.reloc(); - if (reloc->is_call()) { - address call = reloc->addr(); - if (nativeInstruction_at(call)->is_call()) { - if (nativeCall_at(call)->return_address() == return_address) { - return call; - } - } - } - } - - return NULL; -} - -bool NativeCall::is_call_before(address return_address) { - return (call_for(return_address) != NULL); -} - -NativeCall* nativeCall_before(address return_address) { - assert(NativeCall::is_call_before(return_address), "must be"); - return nativeCall_at(call_for(return_address)); -} diff --git a/src/hotspot/cpu/arm/nativeInst_arm_64.hpp b/src/hotspot/cpu/arm/nativeInst_arm_64.hpp deleted file mode 100644 index 424d862404c..00000000000 --- a/src/hotspot/cpu/arm/nativeInst_arm_64.hpp +++ /dev/null @@ -1,771 +0,0 @@ -/* - * Copyright (c) 2008, 2018, 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. - * - */ - -#ifndef CPU_ARM_VM_NATIVEINST_ARM_64_HPP -#define CPU_ARM_VM_NATIVEINST_ARM_64_HPP - -#include "asm/macroAssembler.hpp" -#include "code/codeCache.hpp" -#include "runtime/icache.hpp" -#include "runtime/os.hpp" - -// ------------------------------------------------------------------- - -// Some experimental projects extend the ARM back-end by implementing -// what the front-end usually assumes is a single native instruction -// with a sequence of instructions. -// -// The 'Raw' variants are the low level initial code (usually one -// instruction wide but some of them were already composed -// instructions). They should be used only by the back-end. -// -// The non-raw classes are the front-end entry point, hiding potential -// back-end extensions or the actual instructions size. -class NativeInstruction; - -class RawNativeInstruction { - public: - - enum ARM_specific { - instruction_size = Assembler::InstructionSize, - instruction_size_in_bits = instruction_size * BitsPerByte, - }; - - // illegal instruction used by NativeJump::patch_verified_entry - static const int zombie_illegal_instruction = 0xd4000542; // hvc #42 - - address addr_at(int offset) const { return (address)this + offset; } - address instruction_address() const { return addr_at(0); } - address next_raw_instruction_address() const { return addr_at(instruction_size); } - - static RawNativeInstruction* at(address address) { - return (RawNativeInstruction*)address; - } - - RawNativeInstruction* next_raw() const { - return at(next_raw_instruction_address()); - } - - int encoding() const { - return *(int*)this; - } - - void set_encoding(int value) { - int old = encoding(); - if (old != value) { - *(int*)this = value; - ICache::invalidate_word((address)this); - } - } - - bool is_nop() const { return encoding() == (int)0xd503201f; } - bool is_b() const { return (encoding() & 0xfc000000) == 0x14000000; } // unconditional branch - bool is_b_cond() const { return (encoding() & 0xff000010) == 0x54000000; } // conditional branch - bool is_bl() const { return (encoding() & 0xfc000000) == 0x94000000; } - bool is_br() const { return (encoding() & 0xfffffc1f) == 0xd61f0000; } - bool is_blr() const { return (encoding() & 0xfffffc1f) == 0xd63f0000; } - bool is_ldr_literal() const { return (encoding() & 0xff000000) == 0x58000000; } - bool is_adr_aligned() const { return (encoding() & 0xff000000) == 0x10000000; } // adr Xn,