From a8210c53e7af1cb558251fcb420de1b8a5461b25 Mon Sep 17 00:00:00 2001 From: Martin Doerr Date: Thu, 30 Sep 2021 08:41:03 +0000 Subject: [PATCH] 8274401: C2: GraphKit::load_array_element bypasses Access API Reviewed-by: kvn, goetz, thartmann --- src/hotspot/share/opto/graphKit.cpp | 7 ++++--- src/hotspot/share/opto/graphKit.hpp | 2 +- src/hotspot/share/opto/library_call.cpp | 2 +- src/hotspot/share/opto/stringopts.cpp | 2 +- 4 files changed, 7 insertions(+), 6 deletions(-) diff --git a/src/hotspot/share/opto/graphKit.cpp b/src/hotspot/share/opto/graphKit.cpp index 40d4e690b0059..cafbc0aaa7ccc 100644 --- a/src/hotspot/share/opto/graphKit.cpp +++ b/src/hotspot/share/opto/graphKit.cpp @@ -1748,14 +1748,15 @@ Node* GraphKit::array_element_address(Node* ary, Node* idx, BasicType elembt, } //-------------------------load_array_element------------------------- -Node* GraphKit::load_array_element(Node* ctl, Node* ary, Node* idx, const TypeAryPtr* arytype) { +Node* GraphKit::load_array_element(Node* ary, Node* idx, const TypeAryPtr* arytype, bool set_ctrl) { const Type* elemtype = arytype->elem(); BasicType elembt = elemtype->array_element_basic_type(); Node* adr = array_element_address(ary, idx, elembt, arytype->size()); if (elembt == T_NARROWOOP) { elembt = T_OBJECT; // To satisfy switch in LoadNode::make() } - Node* ld = make_load(ctl, adr, elemtype, elembt, arytype, MemNode::unordered); + Node* ld = access_load_at(ary, adr, arytype, elemtype, elembt, + IN_HEAP | IS_ARRAY | (set_ctrl ? C2_CONTROL_DEPENDENT_LOAD : 0)); return ld; } @@ -4258,7 +4259,7 @@ void GraphKit::inflate_string_slow(Node* src, Node* dst, Node* start, Node* coun record_for_igvn(mem); set_control(head); set_memory(mem, TypeAryPtr::BYTES); - Node* ch = load_array_element(control(), src, i_byte, TypeAryPtr::BYTES); + Node* ch = load_array_element(src, i_byte, TypeAryPtr::BYTES, /* set_ctrl */ true); Node* st = store_to_memory(control(), array_element_address(dst, i_char, T_BYTE), AndI(ch, intcon(0xff)), T_CHAR, TypeAryPtr::BYTES, MemNode::unordered, false, false, true /* mismatched */); diff --git a/src/hotspot/share/opto/graphKit.hpp b/src/hotspot/share/opto/graphKit.hpp index d2a6dd8d6c809..7b1ae9455e4be 100644 --- a/src/hotspot/share/opto/graphKit.hpp +++ b/src/hotspot/share/opto/graphKit.hpp @@ -660,7 +660,7 @@ class GraphKit : public Phase { Node* ctrl = NULL); // Return a load of array element at idx. - Node* load_array_element(Node* ctl, Node* ary, Node* idx, const TypeAryPtr* arytype); + Node* load_array_element(Node* ary, Node* idx, const TypeAryPtr* arytype, bool set_ctrl); //---------------- Dtrace support -------------------- void make_dtrace_method_entry_exit(ciMethod* method, bool is_entry); diff --git a/src/hotspot/share/opto/library_call.cpp b/src/hotspot/share/opto/library_call.cpp index 139a6c87dd053..7c8b8bae6aafe 100644 --- a/src/hotspot/share/opto/library_call.cpp +++ b/src/hotspot/share/opto/library_call.cpp @@ -6205,7 +6205,7 @@ Node * LibraryCallKit::get_key_start_from_aescrypt_object(Node *aescrypt_object) if (objSessionK == NULL) { return (Node *) NULL; } - Node* objAESCryptKey = load_array_element(control(), objSessionK, intcon(0), TypeAryPtr::OOPS); + Node* objAESCryptKey = load_array_element(objSessionK, intcon(0), TypeAryPtr::OOPS, /* set_ctrl */ true); #else Node* objAESCryptKey = load_field_from_object(aescrypt_object, "K", "[I"); #endif // PPC64 diff --git a/src/hotspot/share/opto/stringopts.cpp b/src/hotspot/share/opto/stringopts.cpp index 809a446f52b53..16507d9781166 100644 --- a/src/hotspot/share/opto/stringopts.cpp +++ b/src/hotspot/share/opto/stringopts.cpp @@ -1244,7 +1244,7 @@ Node* PhaseStringOpts::int_stringSize(GraphKit& kit, Node* arg) { kit.set_control(loop); Node* sizeTable = fetch_static_field(kit, size_table_field); - Node* value = kit.load_array_element(NULL, sizeTable, index, TypeAryPtr::INTS); + Node* value = kit.load_array_element(sizeTable, index, TypeAryPtr::INTS, /* set_ctrl */ false); C->record_for_igvn(value); Node* limit = __ CmpI(phi, value); Node* limitb = __ Bool(limit, BoolTest::le);