From 594e5161b48382d61509b4969bc8f52c3c076452 Mon Sep 17 00:00:00 2001 From: Albert Mingkun Yang Date: Mon, 23 Aug 2021 14:00:31 +0000 Subject: [PATCH] 8272778: Consolidate is_instance and is_instance_inlined in java_lang_String Reviewed-by: coleenp, redestad --- src/hotspot/share/classfile/javaClasses.cpp | 3 --- src/hotspot/share/classfile/javaClasses.hpp | 5 ++--- src/hotspot/share/classfile/javaClasses.inline.hpp | 2 +- src/hotspot/share/gc/g1/g1FullGCMarker.inline.hpp | 2 +- src/hotspot/share/gc/parallel/psCompactionManager.inline.hpp | 2 +- src/hotspot/share/gc/parallel/psPromotionManager.inline.hpp | 2 +- src/hotspot/share/gc/serial/markSweep.inline.hpp | 2 +- src/hotspot/share/gc/serial/serialStringDedup.inline.hpp | 2 +- .../share/gc/shenandoah/shenandoahStringDedup.inline.hpp | 2 +- src/hotspot/share/gc/z/zMark.cpp | 2 +- src/hotspot/share/prims/methodHandles.cpp | 4 ++-- 11 files changed, 12 insertions(+), 16 deletions(-) diff --git a/src/hotspot/share/classfile/javaClasses.cpp b/src/hotspot/share/classfile/javaClasses.cpp index dde42ba528e..c5515d3d73e 100644 --- a/src/hotspot/share/classfile/javaClasses.cpp +++ b/src/hotspot/share/classfile/javaClasses.cpp @@ -206,9 +206,6 @@ int java_lang_String::_flags_offset; bool java_lang_String::_initialized; -bool java_lang_String::is_instance(oop obj) { - return is_instance_inlined(obj); -} bool java_lang_String::test_and_set_flag(oop java_string, uint8_t flag_mask) { uint8_t* addr = flags_addr(java_string); diff --git a/src/hotspot/share/classfile/javaClasses.hpp b/src/hotspot/share/classfile/javaClasses.hpp index 44ae70ac87d..62481fbcc1a 100644 --- a/src/hotspot/share/classfile/javaClasses.hpp +++ b/src/hotspot/share/classfile/javaClasses.hpp @@ -237,9 +237,8 @@ class java_lang_String : AllStatic { static Symbol* as_symbol(oop java_string); static Symbol* as_symbol_or_null(oop java_string); - // Testers - static bool is_instance(oop obj); - static inline bool is_instance_inlined(oop obj); + // Tester + static inline bool is_instance(oop obj); // Debugging static void print(oop java_string, outputStream* st); diff --git a/src/hotspot/share/classfile/javaClasses.inline.hpp b/src/hotspot/share/classfile/javaClasses.inline.hpp index 6d8bcc3cf91..e8ee4fce25e 100644 --- a/src/hotspot/share/classfile/javaClasses.inline.hpp +++ b/src/hotspot/share/classfile/javaClasses.inline.hpp @@ -123,7 +123,7 @@ int java_lang_String::length(oop java_string) { return length(java_string, value); } -bool java_lang_String::is_instance_inlined(oop obj) { +bool java_lang_String::is_instance(oop obj) { return obj != NULL && obj->klass() == vmClasses::String_klass(); } diff --git a/src/hotspot/share/gc/g1/g1FullGCMarker.inline.hpp b/src/hotspot/share/gc/g1/g1FullGCMarker.inline.hpp index 992cbb2321c..3ef6375c3a4 100644 --- a/src/hotspot/share/gc/g1/g1FullGCMarker.inline.hpp +++ b/src/hotspot/share/gc/g1/g1FullGCMarker.inline.hpp @@ -64,7 +64,7 @@ inline bool G1FullGCMarker::mark_object(oop obj) { // Check if deduplicatable string. if (StringDedup::is_enabled() && - java_lang_String::is_instance_inlined(obj) && + java_lang_String::is_instance(obj) && G1StringDedup::is_candidate_from_mark(obj)) { _string_dedup_requests.add(obj); } diff --git a/src/hotspot/share/gc/parallel/psCompactionManager.inline.hpp b/src/hotspot/share/gc/parallel/psCompactionManager.inline.hpp index 45e8dae5aeb..470c9158899 100644 --- a/src/hotspot/share/gc/parallel/psCompactionManager.inline.hpp +++ b/src/hotspot/share/gc/parallel/psCompactionManager.inline.hpp @@ -111,7 +111,7 @@ inline void ParCompactionManager::mark_and_push(T* p) { push(obj); if (StringDedup::is_enabled() && - java_lang_String::is_instance_inlined(obj) && + java_lang_String::is_instance(obj) && psStringDedup::is_candidate_from_mark(obj)) { _string_dedup_requests.add(obj); } diff --git a/src/hotspot/share/gc/parallel/psPromotionManager.inline.hpp b/src/hotspot/share/gc/parallel/psPromotionManager.inline.hpp index 582a587e37b..29053cd5c35 100644 --- a/src/hotspot/share/gc/parallel/psPromotionManager.inline.hpp +++ b/src/hotspot/share/gc/parallel/psPromotionManager.inline.hpp @@ -287,7 +287,7 @@ inline oop PSPromotionManager::copy_unmarked_to_survivor_space(oop o, push_contents(new_obj); if (StringDedup::is_enabled() && - java_lang_String::is_instance_inlined(new_obj) && + java_lang_String::is_instance(new_obj) && psStringDedup::is_candidate_from_evacuation(new_obj, new_obj_is_tenured)) { _string_dedup_requests.add(o); } diff --git a/src/hotspot/share/gc/serial/markSweep.inline.hpp b/src/hotspot/share/gc/serial/markSweep.inline.hpp index 7212b7ec57b..6af4ffe3e3c 100644 --- a/src/hotspot/share/gc/serial/markSweep.inline.hpp +++ b/src/hotspot/share/gc/serial/markSweep.inline.hpp @@ -40,7 +40,7 @@ inline void MarkSweep::mark_object(oop obj) { if (StringDedup::is_enabled() && - java_lang_String::is_instance_inlined(obj) && + java_lang_String::is_instance(obj) && SerialStringDedup::is_candidate_from_mark(obj)) { _string_dedup_requests->add(obj); } diff --git a/src/hotspot/share/gc/serial/serialStringDedup.inline.hpp b/src/hotspot/share/gc/serial/serialStringDedup.inline.hpp index 703ee7450a1..ebf29113a0b 100644 --- a/src/hotspot/share/gc/serial/serialStringDedup.inline.hpp +++ b/src/hotspot/share/gc/serial/serialStringDedup.inline.hpp @@ -32,7 +32,7 @@ bool SerialStringDedup::is_candidate_from_evacuation(oop obj, bool obj_is_tenured) { return StringDedup::is_enabled() && - java_lang_String::is_instance_inlined(obj) && + java_lang_String::is_instance(obj) && (obj_is_tenured ? StringDedup::is_below_threshold_age(obj->age()) : StringDedup::is_threshold_age(obj->age())); diff --git a/src/hotspot/share/gc/shenandoah/shenandoahStringDedup.inline.hpp b/src/hotspot/share/gc/shenandoah/shenandoahStringDedup.inline.hpp index 57b30358e94..869a17c3d9b 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahStringDedup.inline.hpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahStringDedup.inline.hpp @@ -32,7 +32,7 @@ bool ShenandoahStringDedup::is_string_candidate(oop obj) { assert(Thread::current()->is_Worker_thread(), "Only from a GC worker thread"); - return java_lang_String::is_instance_inlined(obj) && + return java_lang_String::is_instance(obj) && java_lang_String::value(obj) != nullptr; } diff --git a/src/hotspot/share/gc/z/zMark.cpp b/src/hotspot/share/gc/z/zMark.cpp index 72f459b97fc..d73c2832854 100644 --- a/src/hotspot/share/gc/z/zMark.cpp +++ b/src/hotspot/share/gc/z/zMark.cpp @@ -288,7 +288,7 @@ static void try_deduplicate(ZMarkContext* context, oop obj) { return; } - if (!java_lang_String::is_instance_inlined(obj)) { + if (!java_lang_String::is_instance(obj)) { // Not a String object return; } diff --git a/src/hotspot/share/prims/methodHandles.cpp b/src/hotspot/share/prims/methodHandles.cpp index 9419bab7b36..5ae35e34a8c 100644 --- a/src/hotspot/share/prims/methodHandles.cpp +++ b/src/hotspot/share/prims/methodHandles.cpp @@ -158,7 +158,7 @@ int MethodHandles::ref_kind_to_flags(int ref_kind) { Handle MethodHandles::resolve_MemberName_type(Handle mname, Klass* caller, TRAPS) { Handle empty; Handle type(THREAD, java_lang_invoke_MemberName::type(mname())); - if (!java_lang_String::is_instance_inlined(type())) { + if (!java_lang_String::is_instance(type())) { return type; // already resolved } Symbol* signature = java_lang_String::as_symbol_or_null(type()); @@ -536,7 +536,7 @@ Symbol* MethodHandles::lookup_signature(oop type_str, bool intern_if_not_found, return java_lang_invoke_MethodType::as_signature(type_str, intern_if_not_found); } else if (java_lang_Class::is_instance(type_str)) { return java_lang_Class::as_signature(type_str, false); - } else if (java_lang_String::is_instance_inlined(type_str)) { + } else if (java_lang_String::is_instance(type_str)) { if (intern_if_not_found) { return java_lang_String::as_symbol(type_str); } else {