From d988e67b89cc655eb356aced89d4875f188b798f Mon Sep 17 00:00:00 2001 From: Gerard Ziemski Date: Wed, 8 May 2019 11:11:50 -0500 Subject: [PATCH] 8185525: Add JFR event for DictionarySizes Added TableStatistics event Reviewed-by: egahlin, coleenp --- .../share/classfile/classLoaderDataGraph.cpp | 2 +- .../share/classfile/classLoaderDataGraph.hpp | 2 +- src/hotspot/share/classfile/stringTable.cpp | 7 + src/hotspot/share/classfile/stringTable.hpp | 1 + src/hotspot/share/classfile/symbolTable.cpp | 7 + src/hotspot/share/classfile/symbolTable.hpp | 1 + .../share/classfile/systemDictionary.cpp | 16 +- .../share/classfile/systemDictionary.hpp | 5 + src/hotspot/share/jfr/metadata/metadata.xml | 62 +++++++- .../share/jfr/periodic/jfrPeriodic.cpp | 43 ++++++ src/hotspot/share/memory/allocation.hpp | 1 + .../share/utilities/concurrentHashTable.hpp | 12 ++ .../utilities/concurrentHashTable.inline.hpp | 76 +++++----- src/hotspot/share/utilities/hashtable.cpp | 46 ++---- src/hotspot/share/utilities/hashtable.hpp | 4 + .../share/utilities/hashtable.inline.hpp | 9 ++ .../share/utilities/tableStatistics.cpp | 140 ++++++++++++++++++ .../share/utilities/tableStatistics.hpp | 91 ++++++++++++ src/jdk.jfr/share/conf/jfr/default.jfc | 25 ++++ src/jdk.jfr/share/conf/jfr/profile.jfc | 25 ++++ .../runtime/TestTableStatisticsEvent.java | 89 +++++++++++ test/lib/jdk/test/lib/jfr/EventNames.java | 5 + 22 files changed, 594 insertions(+), 75 deletions(-) create mode 100644 src/hotspot/share/utilities/tableStatistics.cpp create mode 100644 src/hotspot/share/utilities/tableStatistics.hpp create mode 100644 test/jdk/jdk/jfr/event/runtime/TestTableStatisticsEvent.java diff --git a/src/hotspot/share/classfile/classLoaderDataGraph.cpp b/src/hotspot/share/classfile/classLoaderDataGraph.cpp index 14df71f6e25..fece9fabb36 100644 --- a/src/hotspot/share/classfile/classLoaderDataGraph.cpp +++ b/src/hotspot/share/classfile/classLoaderDataGraph.cpp @@ -443,7 +443,7 @@ void ClassLoaderDataGraph::print_dictionary(outputStream* st) { } } -void ClassLoaderDataGraph::print_dictionary_statistics(outputStream* st) { +void ClassLoaderDataGraph::print_table_statistics(outputStream* st) { FOR_ALL_DICTIONARY(cld) { ResourceMark rm; stringStream tempst; diff --git a/src/hotspot/share/classfile/classLoaderDataGraph.hpp b/src/hotspot/share/classfile/classLoaderDataGraph.hpp index 942bb83b5d4..936f59c2791 100644 --- a/src/hotspot/share/classfile/classLoaderDataGraph.hpp +++ b/src/hotspot/share/classfile/classLoaderDataGraph.hpp @@ -112,7 +112,7 @@ class ClassLoaderDataGraph : public AllStatic { static void verify_dictionary(); static void print_dictionary(outputStream* st); - static void print_dictionary_statistics(outputStream* st); + static void print_table_statistics(outputStream* st); // CMS support. static void remember_new_clds(bool remember) { _saved_head = (remember ? _head : NULL); } diff --git a/src/hotspot/share/classfile/stringTable.cpp b/src/hotspot/share/classfile/stringTable.cpp index 5ed0369d663..cde17cbbe00 100644 --- a/src/hotspot/share/classfile/stringTable.cpp +++ b/src/hotspot/share/classfile/stringTable.cpp @@ -579,6 +579,13 @@ struct SizeFunc : StackObj { }; }; +TableStatistics StringTable::get_table_statistics() { + static TableStatistics ts; + SizeFunc sz; + ts = _local_table->statistics_get(Thread::current(), sz, ts); + return ts; +} + void StringTable::print_table_statistics(outputStream* st, const char* table_name) { SizeFunc sz; diff --git a/src/hotspot/share/classfile/stringTable.hpp b/src/hotspot/share/classfile/stringTable.hpp index e06fb3e1afa..679a16b4a5c 100644 --- a/src/hotspot/share/classfile/stringTable.hpp +++ b/src/hotspot/share/classfile/stringTable.hpp @@ -99,6 +99,7 @@ private: // The string table static StringTable* the_table() { return _the_table; } size_t table_size(); + TableStatistics get_table_statistics(); static OopStorage* weak_storage() { return the_table()->_weak_handles; } diff --git a/src/hotspot/share/classfile/symbolTable.cpp b/src/hotspot/share/classfile/symbolTable.cpp index ce744dc42dc..5cc01333e68 100644 --- a/src/hotspot/share/classfile/symbolTable.cpp +++ b/src/hotspot/share/classfile/symbolTable.cpp @@ -503,6 +503,13 @@ struct SizeFunc : StackObj { }; }; +TableStatistics SymbolTable::get_table_statistics() { + static TableStatistics ts; + SizeFunc sz; + ts = _local_table->statistics_get(Thread::current(), sz, ts); + return ts; +} + void SymbolTable::print_table_statistics(outputStream* st, const char* table_name) { SizeFunc sz; diff --git a/src/hotspot/share/classfile/symbolTable.hpp b/src/hotspot/share/classfile/symbolTable.hpp index 8f24d858feb..8ea6d0932c0 100644 --- a/src/hotspot/share/classfile/symbolTable.hpp +++ b/src/hotspot/share/classfile/symbolTable.hpp @@ -171,6 +171,7 @@ public: // The symbol table static SymbolTable* the_table() { return _the_table; } size_t table_size(); + TableStatistics get_table_statistics(); enum { symbol_alloc_batch_size = 8, diff --git a/src/hotspot/share/classfile/systemDictionary.cpp b/src/hotspot/share/classfile/systemDictionary.cpp index 3f2b7280051..9246a06392a 100644 --- a/src/hotspot/share/classfile/systemDictionary.cpp +++ b/src/hotspot/share/classfile/systemDictionary.cpp @@ -2849,13 +2849,25 @@ void SystemDictionary::dump(outputStream *st, bool verbose) { print_on(st); } else { CDS_ONLY(SystemDictionaryShared::print_table_statistics(st)); - ClassLoaderDataGraph::print_dictionary_statistics(st); + ClassLoaderDataGraph::print_table_statistics(st); placeholders()->print_table_statistics(st, "Placeholder Table"); constraints()->print_table_statistics(st, "LoaderConstraints Table"); - _pd_cache_table->print_table_statistics(st, "ProtectionDomainCache Table"); + pd_cache_table()->print_table_statistics(st, "ProtectionDomainCache Table"); } } +TableStatistics SystemDictionary::placeholders_statistics() { + return placeholders()->statistics_calculate(); +} + +TableStatistics SystemDictionary::loader_constraints_statistics() { + return constraints()->statistics_calculate(); +} + +TableStatistics SystemDictionary::protection_domain_cache_statistics() { + return pd_cache_table()->statistics_calculate(); +} + // Utility for dumping dictionaries. SystemDictionaryDCmd::SystemDictionaryDCmd(outputStream* output, bool heap) : DCmdWithParser(output, heap), diff --git a/src/hotspot/share/classfile/systemDictionary.hpp b/src/hotspot/share/classfile/systemDictionary.hpp index 6b6d4702e46..6d297c8f96c 100644 --- a/src/hotspot/share/classfile/systemDictionary.hpp +++ b/src/hotspot/share/classfile/systemDictionary.hpp @@ -681,6 +681,11 @@ private: static oop _java_platform_loader; static bool _has_checkPackageAccess; + +public: + static TableStatistics placeholders_statistics(); + static TableStatistics loader_constraints_statistics(); + static TableStatistics protection_domain_cache_statistics(); }; #endif // SHARE_CLASSFILE_SYSTEMDICTIONARY_HPP diff --git a/src/hotspot/share/jfr/metadata/metadata.xml b/src/hotspot/share/jfr/metadata/metadata.xml index 1821714887e..208b0db9067 100644 --- a/src/hotspot/share/jfr/metadata/metadata.xml +++ b/src/hotspot/share/jfr/metadata/metadata.xml @@ -1,7 +1,7 @@