8313248: C2: setScopedValueCache intrinsic exposes nullptr pre-values to store barriers

Reviewed-by: thartmann, rkennke
This commit is contained in:
Aleksey Shipilev 2023-08-04 09:53:20 +00:00
parent 29f1d8ef50
commit e8a37b90db
2 changed files with 14 additions and 12 deletions

View File

@ -3586,12 +3586,19 @@ bool LibraryCallKit::inline_native_setCurrentThread() {
return true; return true;
} }
Node* LibraryCallKit::scopedValueCache_helper() { const Type* LibraryCallKit::scopedValueCache_type() {
ciKlass *objects_klass = ciObjArrayKlass::make(env()->Object_klass()); ciKlass* objects_klass = ciObjArrayKlass::make(env()->Object_klass());
const TypeOopPtr *etype = TypeOopPtr::make_from_klass(env()->Object_klass()); const TypeOopPtr* etype = TypeOopPtr::make_from_klass(env()->Object_klass());
const TypeAry* arr0 = TypeAry::make(etype, TypeInt::POS);
// Because we create the scopedValue cache lazily we have to make the
// type of the result BotPTR.
bool xk = etype->klass_is_exact(); bool xk = etype->klass_is_exact();
const Type* objects_type = TypeAryPtr::make(TypePtr::BotPTR, arr0, objects_klass, xk, 0);
return objects_type;
}
Node* LibraryCallKit::scopedValueCache_helper() {
Node* thread = _gvn.transform(new ThreadLocalNode()); Node* thread = _gvn.transform(new ThreadLocalNode());
Node* p = basic_plus_adr(top()/*!oop*/, thread, in_bytes(JavaThread::scopedValueCache_offset())); Node* p = basic_plus_adr(top()/*!oop*/, thread, in_bytes(JavaThread::scopedValueCache_offset()));
// We cannot use immutable_memory() because we might flip onto a // We cannot use immutable_memory() because we might flip onto a
@ -3604,15 +3611,8 @@ Node* LibraryCallKit::scopedValueCache_helper() {
//------------------------inline_native_scopedValueCache------------------ //------------------------inline_native_scopedValueCache------------------
bool LibraryCallKit::inline_native_scopedValueCache() { bool LibraryCallKit::inline_native_scopedValueCache() {
ciKlass *objects_klass = ciObjArrayKlass::make(env()->Object_klass());
const TypeOopPtr *etype = TypeOopPtr::make_from_klass(env()->Object_klass());
const TypeAry* arr0 = TypeAry::make(etype, TypeInt::POS);
// Because we create the scopedValue cache lazily we have to make the
// type of the result BotPTR.
bool xk = etype->klass_is_exact();
const Type* objects_type = TypeAryPtr::make(TypePtr::BotPTR, arr0, objects_klass, xk, 0);
Node* cache_obj_handle = scopedValueCache_helper(); Node* cache_obj_handle = scopedValueCache_helper();
const Type* objects_type = scopedValueCache_type();
set_result(access_load(cache_obj_handle, objects_type, T_OBJECT, IN_NATIVE)); set_result(access_load(cache_obj_handle, objects_type, T_OBJECT, IN_NATIVE));
return true; return true;
@ -3622,9 +3622,10 @@ bool LibraryCallKit::inline_native_scopedValueCache() {
bool LibraryCallKit::inline_native_setScopedValueCache() { bool LibraryCallKit::inline_native_setScopedValueCache() {
Node* arr = argument(0); Node* arr = argument(0);
Node* cache_obj_handle = scopedValueCache_helper(); Node* cache_obj_handle = scopedValueCache_helper();
const Type* objects_type = scopedValueCache_type();
const TypePtr *adr_type = _gvn.type(cache_obj_handle)->isa_ptr(); const TypePtr *adr_type = _gvn.type(cache_obj_handle)->isa_ptr();
access_store_at(nullptr, cache_obj_handle, adr_type, arr, _gvn.type(arr), T_OBJECT, IN_NATIVE | MO_UNORDERED); access_store_at(nullptr, cache_obj_handle, adr_type, arr, objects_type, T_OBJECT, IN_NATIVE | MO_UNORDERED);
return true; return true;
} }

View File

@ -237,6 +237,7 @@ class LibraryCallKit : public GraphKit {
bool inline_native_setCurrentThread(); bool inline_native_setCurrentThread();
bool inline_native_scopedValueCache(); bool inline_native_scopedValueCache();
const Type* scopedValueCache_type();
Node* scopedValueCache_helper(); Node* scopedValueCache_helper();
bool inline_native_setScopedValueCache(); bool inline_native_setScopedValueCache();