From 3e581f13a05ba2d7c302daae5120dea9eee1a22d Mon Sep 17 00:00:00 2001 From: Stefan Karlsson Date: Wed, 17 Apr 2019 07:41:09 +0200 Subject: [PATCH] 8222558: Rework ResolvedMethodTable verification Reviewed-by: coleenp --- src/hotspot/share/memory/universe.cpp | 6 +++ src/hotspot/share/memory/universe.hpp | 1 + .../share/prims/resolvedMethodTable.cpp | 47 ++++--------------- .../share/prims/resolvedMethodTable.hpp | 2 +- .../runtime/MemberName/MemberNameLeak.java | 4 +- 5 files changed, 21 insertions(+), 39 deletions(-) diff --git a/src/hotspot/share/memory/universe.cpp b/src/hotspot/share/memory/universe.cpp index b63cde242b3..f2c2ed2583d 100644 --- a/src/hotspot/share/memory/universe.cpp +++ b/src/hotspot/share/memory/universe.cpp @@ -1151,6 +1151,8 @@ void Universe::initialize_verify_flags() { verify_flags |= Verify_JNIHandles; } else if (strcmp(token, "codecache_oops") == 0) { verify_flags |= Verify_CodeCacheOops; + } else if (strcmp(token, "resolved_method_table") == 0) { + verify_flags |= Verify_ResolvedMethodTable; } else { vm_exit_during_initialization(err_msg("VerifySubSet: \'%s\' memory sub-system is unknown, please correct it", token)); } @@ -1230,6 +1232,10 @@ void Universe::verify(VerifyOption option, const char* prefix) { log_debug(gc, verify)("CodeCache Oops"); CodeCache::verify_oops(); } + if (should_verify_subset(Verify_ResolvedMethodTable)) { + log_debug(gc, verify)("ResolvedMethodTable Oops"); + ResolvedMethodTable::verify(); + } _verify_in_progress = false; } diff --git a/src/hotspot/share/memory/universe.hpp b/src/hotspot/share/memory/universe.hpp index 90a79ac0846..7ba5d47d304 100644 --- a/src/hotspot/share/memory/universe.hpp +++ b/src/hotspot/share/memory/universe.hpp @@ -478,6 +478,7 @@ class Universe: AllStatic { Verify_MetaspaceUtils = 128, Verify_JNIHandles = 256, Verify_CodeCacheOops = 512, + Verify_ResolvedMethodTable = 1024, Verify_All = -1 }; static void initialize_verify_flags(); diff --git a/src/hotspot/share/prims/resolvedMethodTable.cpp b/src/hotspot/share/prims/resolvedMethodTable.cpp index 8aef3895a4c..aea2c93e81d 100644 --- a/src/hotspot/share/prims/resolvedMethodTable.cpp +++ b/src/hotspot/share/prims/resolvedMethodTable.cpp @@ -346,16 +346,6 @@ void ResolvedMethodTable::inc_dead_counter(size_t ndead) { // cleaning. Note it might trigger a resize instead. void ResolvedMethodTable::finish_dead_counter() { check_concurrent_work(); - -#ifdef ASSERT - if (SafepointSynchronize::is_at_safepoint()) { - size_t fail_cnt = verify_and_compare_entries(); - if (fail_cnt != 0) { - tty->print_cr("ERROR: fail_cnt=" SIZE_FORMAT, fail_cnt); - guarantee(fail_cnt == 0, "unexpected ResolvedMethodTable verification failures"); - } - } -#endif // ASSERT } #if INCLUDE_JVMTI @@ -402,26 +392,16 @@ void ResolvedMethodTable::adjust_method_entries(bool * trace_name_printed) { } #endif // INCLUDE_JVMTI -// Verification and comp -class VerifyCompResolvedMethod : StackObj { - GrowableArray* _oops; +// Verification +class VerifyResolvedMethod : StackObj { public: - size_t _errors; - VerifyCompResolvedMethod(GrowableArray* oops) : _oops(oops), _errors(0) {} bool operator()(WeakHandle* val) { - oop s = val->peek(); - if (s == NULL) { - return true; + oop obj = val->peek(); + if (obj != NULL) { + Method* method = (Method*)java_lang_invoke_ResolvedMethodName::vmtarget(obj); + guarantee(method->is_method(), "Must be"); + guarantee(!method->is_old(), "Must be"); } - int len = _oops->length(); - for (int i = 0; i < len; i++) { - bool eq = s == _oops->at(i); - assert(!eq, "Duplicate entries"); - if (eq) { - _errors++; - } - } - _oops->push(s); return true; }; }; @@ -430,16 +410,9 @@ size_t ResolvedMethodTable::items_count() { return _items_count; } -size_t ResolvedMethodTable::verify_and_compare_entries() { - Thread* thr = Thread::current(); - GrowableArray* oops = - new (ResourceObj::C_HEAP, mtInternal) - GrowableArray((int)_current_size, true); - - VerifyCompResolvedMethod vcs(oops); - if (!_local_table->try_scan(thr, vcs)) { +void ResolvedMethodTable::verify() { + VerifyResolvedMethod vcs; + if (!_local_table->try_scan(Thread::current(), vcs)) { log_info(membername, table)("verify unavailable at this moment"); } - delete oops; - return vcs._errors; } diff --git a/src/hotspot/share/prims/resolvedMethodTable.hpp b/src/hotspot/share/prims/resolvedMethodTable.hpp index adcc12b10ac..f7bf176ad66 100644 --- a/src/hotspot/share/prims/resolvedMethodTable.hpp +++ b/src/hotspot/share/prims/resolvedMethodTable.hpp @@ -96,7 +96,7 @@ public: // Debugging static size_t items_count(); - static size_t verify_and_compare_entries(); + static void verify(); }; #endif // SHARE_PRIMS_RESOLVEDMETHODTABLE_HPP diff --git a/test/hotspot/jtreg/runtime/MemberName/MemberNameLeak.java b/test/hotspot/jtreg/runtime/MemberName/MemberNameLeak.java index b6a94042e78..2203a442b41 100644 --- a/test/hotspot/jtreg/runtime/MemberName/MemberNameLeak.java +++ b/test/hotspot/jtreg/runtime/MemberName/MemberNameLeak.java @@ -103,11 +103,13 @@ public class MemberNameLeak { System.err.println("test(" + gc + ", " + doConcurrent + ")"); // Run this Leak class with logging ProcessBuilder pb = ProcessTools.createJavaProcessBuilder( - "-Xlog:membername+table=trace", + "-Xlog:membername+table=trace,gc+verify=debug", "-XX:+UnlockExperimentalVMOptions", "-XX:+UnlockDiagnosticVMOptions", "-XX:+WhiteBoxAPI", "-Xbootclasspath/a:.", + "-XX:+VerifyBeforeGC", + "-XX:+VerifyAfterGC", doConcurrent ? "-XX:+ExplicitGCInvokesConcurrent" : "-XX:-ExplicitGCInvokesConcurrent", "-XX:+ClassUnloading", "-XX:+ClassUnloadingWithConcurrentMark",